Compare commits
784 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
50bab26a3a | ||
|
|
ceb252986e | ||
|
|
750ef296c6 | ||
|
|
454ae8656a | ||
|
|
75450dcdbc | ||
|
|
bd2c7e3bb9 | ||
|
|
9d23cf33fd | ||
|
|
97eb01a28d | ||
|
|
9a2a636aed | ||
|
|
61c8256ef0 | ||
|
|
8e1791570e | ||
|
|
aa30d1f359 | ||
|
|
326f4bd681 | ||
|
|
7690c6c33d | ||
|
|
fece1077f2 | ||
|
|
75fc7db50d | ||
|
|
96da04576e | ||
|
|
001ec3663e | ||
|
|
21a00b77bd | ||
|
|
408f3852ec | ||
|
|
61150c74d2 | ||
|
|
7bb7003c9d | ||
|
|
920463f2ff | ||
|
|
ca1185d0be | ||
|
|
be655ee328 | ||
|
|
02d4186b11 | ||
|
|
3f97bebd69 | ||
|
|
2e378da922 | ||
|
|
b37f51bd7f | ||
|
|
eb8b0f72cc | ||
|
|
d8fe9a4d29 | ||
|
|
c97cdf551e | ||
|
|
80fc60b5e2 | ||
|
|
3b2e142542 | ||
|
|
0e58d99f4e | ||
|
|
92798abb5d | ||
|
|
bd7950b757 | ||
|
|
59a15ceef6 | ||
|
|
4011a113cc | ||
|
|
70cbe91776 | ||
|
|
f92027c44b | ||
|
|
1443335315 | ||
|
|
6ff2229a09 | ||
|
|
bb72672dd9 | ||
|
|
d96dee3aa6 | ||
|
|
bd0aaa343b | ||
|
|
3126e1ac94 | ||
|
|
a117d87f33 | ||
|
|
9dc4f8a1aa | ||
|
|
0d536d11e3 | ||
|
|
72a4962fd0 | ||
|
|
a3045a3953 | ||
|
|
c620a22017 | ||
|
|
856ec03cc7 | ||
|
|
c80c5631f0 | ||
|
|
ef70668a77 | ||
|
|
ebd4691462 | ||
|
|
28554235be | ||
|
|
efbbb6fd20 | ||
|
|
9de57021a3 | ||
|
|
e21f770485 | ||
|
|
697c00dccf | ||
|
|
1caf6a3298 | ||
|
|
02fd02d482 | ||
|
|
239fb0db94 | ||
|
|
fe1d73c3e5 | ||
|
|
43da06a354 | ||
|
|
fea6b67067 | ||
|
|
f065ae54d5 | ||
|
|
3cf417766d | ||
|
|
0fb41b10e9 | ||
|
|
bc9dc3bf1e | ||
|
|
3cde5e28a8 | ||
|
|
cb8e7181c4 | ||
|
|
9a3becdecc | ||
|
|
e3c10d779d | ||
|
|
dd9f1024f4 | ||
|
|
9841f74adc | ||
|
|
b56e493d92 | ||
|
|
a2c5211b20 | ||
|
|
b7a7abed48 | ||
|
|
72bfdfd925 | ||
|
|
b80d34612a | ||
|
|
648cc0f006 | ||
|
|
830692dd60 | ||
|
|
95a6759381 | ||
|
|
960b37b1c2 | ||
|
|
b1d17dea4f | ||
|
|
6b06471953 | ||
|
|
4ca957d3eb | ||
|
|
eb9b63477c | ||
|
|
80c01b055c | ||
|
|
50aec67069 | ||
|
|
7baced75e5 | ||
|
|
99743a94fb | ||
|
|
9bdfd6025b | ||
|
|
91400d2ce0 | ||
|
|
7b88d0efe3 | ||
|
|
4aada65dae | ||
|
|
0560d2cfb7 | ||
|
|
58c1a68ad9 | ||
|
|
588fc6df85 | ||
|
|
2c9e4ded40 | ||
|
|
88a538e71b | ||
|
|
513363504f | ||
|
|
0e844edacb | ||
|
|
5751bb2481 | ||
|
|
28669d940a | ||
|
|
3d87bdb6b4 | ||
|
|
1499ce43bf | ||
|
|
4d22b43d65 | ||
|
|
823603650f | ||
|
|
062867a38d | ||
|
|
f3e0c5d653 | ||
|
|
fc7f48b7db | ||
|
|
04d56420d1 | ||
|
|
a017574f74 | ||
|
|
ae24360c02 | ||
|
|
3fea1976c8 | ||
|
|
cf97dd9fcd | ||
|
|
0e3a48ff76 | ||
|
|
276bf09238 | ||
|
|
05988c1c49 | ||
|
|
d46b26e3bc | ||
|
|
236c172c6f | ||
|
|
59fcb56972 | ||
|
|
c07cd3a856 | ||
|
|
37766347a5 | ||
|
|
79da61782b | ||
|
|
8af87f1a8b | ||
|
|
494c954cbb | ||
|
|
71bc9eea28 | ||
|
|
e3b2bcfd06 | ||
|
|
142d974641 | ||
|
|
e56129111a | ||
|
|
0e1d6aa85c | ||
|
|
bcdb8cd770 | ||
|
|
7b2ca55089 | ||
|
|
f6ef0b684a | ||
|
|
02e1cdf210 | ||
|
|
b58950c574 | ||
|
|
833a60f29c | ||
|
|
f776d67c03 | ||
|
|
13e7cca1a4 | ||
|
|
0f3c477ff3 | ||
|
|
039cc30c07 | ||
|
|
25c8cd9246 | ||
|
|
c58841100a | ||
|
|
03e24cccd0 | ||
|
|
35f011758d | ||
|
|
2ebfaf76f2 | ||
|
|
0cf187dee7 | ||
|
|
bdeb325bad | ||
|
|
a1225b6d0d | ||
|
|
f0368b02c4 | ||
|
|
202de1436d | ||
|
|
7f8746fcd4 | ||
|
|
e05a25d701 | ||
|
|
6930570fa2 | ||
|
|
aba2c5b938 | ||
|
|
d82f86dcd9 | ||
|
|
159b4f9734 | ||
|
|
46a737c7a1 | ||
|
|
a731486ab7 | ||
|
|
c3e57f1fdd | ||
|
|
a9af484412 | ||
|
|
007646774e | ||
|
|
2d78e35e16 | ||
|
|
7524b5e349 | ||
|
|
2a04a48b89 | ||
|
|
3cbdaab81e | ||
|
|
8c858a5953 | ||
|
|
1812958106 | ||
|
|
4e5324916c | ||
|
|
1a77becc6a | ||
|
|
23ccaea2ff | ||
|
|
2a4b252a9d | ||
|
|
9ae4edfee5 | ||
|
|
bf48809b61 | ||
|
|
57a80a3c10 | ||
|
|
3f3e52d7ae | ||
|
|
5c69110658 | ||
|
|
be055d9dcb | ||
|
|
1e34a61911 | ||
|
|
97bd1da2a2 | ||
|
|
330ffb803f | ||
|
|
7b77f200be | ||
|
|
15a3c8408f | ||
|
|
bc1784ed2b | ||
|
|
55f0a82249 | ||
|
|
7aada3f328 | ||
|
|
dad885c051 | ||
|
|
f5c7bbfda8 | ||
|
|
f832743009 | ||
|
|
7551de6439 | ||
|
|
e03b4b7505 | ||
|
|
2d59fdd178 | ||
|
|
e61c8046f4 | ||
|
|
c0796ac3d6 | ||
|
|
68be24ffc6 | ||
|
|
9dcc87c705 | ||
|
|
d36c536107 | ||
|
|
affeeb39de | ||
|
|
f5d8a952f2 | ||
|
|
da07f99d3d | ||
|
|
eef66de68c | ||
|
|
4aa1180fce | ||
|
|
553d52a45e | ||
|
|
347b153884 | ||
|
|
1e7c176481 | ||
|
|
e390405d0c | ||
|
|
7378a84c96 | ||
|
|
b25013c4a2 | ||
|
|
6942916f13 | ||
|
|
f69f0b97f5 | ||
|
|
4361ea9686 | ||
|
|
be2ee33273 | ||
|
|
8c2ddb0255 | ||
|
|
466a5a932b | ||
|
|
8a3c6382e9 | ||
|
|
a2b45120c5 | ||
|
|
546ad52e11 | ||
|
|
1aefc5b540 | ||
|
|
1085ca4a2d | ||
|
|
9766322e99 | ||
|
|
cfb68e3bff | ||
|
|
a006963fb8 | ||
|
|
24c95c27c3 | ||
|
|
3c40c0be6b | ||
|
|
b1fc80b79a | ||
|
|
50d793e49b | ||
|
|
34c43b8349 | ||
|
|
7002a316fd | ||
|
|
1f37faad42 | ||
|
|
68cf24d100 | ||
|
|
86491da253 | ||
|
|
90249cdafa | ||
|
|
7c75111c41 | ||
|
|
7b53b6bfef | ||
|
|
fded5fd900 | ||
|
|
950965bd4a | ||
|
|
3a359319fa | ||
|
|
d3dd82c699 | ||
|
|
81f192bccb | ||
|
|
60a23febed | ||
|
|
d0e280cbac | ||
|
|
ecb62c8659 | ||
|
|
12669df92b | ||
|
|
44b2afeffa | ||
|
|
70f435e909 | ||
|
|
512d82071e | ||
|
|
3896230199 | ||
|
|
b902880a05 | ||
|
|
418526af16 | ||
|
|
45ad212459 | ||
|
|
0f49d424d3 | ||
|
|
01e42c8d6f | ||
|
|
26107bd6c3 | ||
|
|
7d3ecd2297 | ||
|
|
16056661dd | ||
|
|
059f50dad4 | ||
|
|
4c9975a7d9 | ||
|
|
9f9cc1ffb5 | ||
|
|
e768e1e277 | ||
|
|
acaf7b969a | ||
|
|
2b94975345 | ||
|
|
e6b4e12689 | ||
|
|
7eaac995bd | ||
|
|
a19cdb5e72 | ||
|
|
f54fbd057e | ||
|
|
19eceb4ecc | ||
|
|
dcff1ec25f | ||
|
|
567cda4cd3 | ||
|
|
900d8790b3 | ||
|
|
cad284519f | ||
|
|
0727acf458 | ||
|
|
d8813179be | ||
|
|
10d690c8fb | ||
|
|
52f71cdda0 | ||
|
|
2a9a348164 | ||
|
|
00346781bb | ||
|
|
4c6e92eea1 | ||
|
|
b63f469110 | ||
|
|
f6f176afc1 | ||
|
|
3de37a61c5 | ||
|
|
2d955dae48 | ||
|
|
46577fb128 | ||
|
|
37dba6ebfd | ||
|
|
66b949bed1 | ||
|
|
c9a05187fb | ||
|
|
cc956583fb | ||
|
|
14206efb09 | ||
|
|
5e6d7f5d16 | ||
|
|
7a33831d14 | ||
|
|
4f120e19fd | ||
|
|
37d064d836 | ||
|
|
824150f89b | ||
|
|
f7dc4cca2c | ||
|
|
ea39bb4334 | ||
|
|
5680d5a7be | ||
|
|
004246124b | ||
|
|
c41beae99a | ||
|
|
fe2cffb25b | ||
|
|
f71d5c429d | ||
|
|
dce5816b18 | ||
|
|
f99a7b2a8c | ||
|
|
ec36c69984 | ||
|
|
2458db03de | ||
|
|
7528b7bc1a | ||
|
|
8af33084ed | ||
|
|
f643175156 | ||
|
|
0321dda1d7 | ||
|
|
ff5d79e3ee | ||
|
|
4ee3ec09df | ||
|
|
cfe9d47fa0 | ||
|
|
607d6125fc | ||
|
|
6215259565 | ||
|
|
d034fecc89 | ||
|
|
f18d8229c0 | ||
|
|
e736626953 | ||
|
|
c2c438637a | ||
|
|
94638fe42c | ||
|
|
55ecfda39a | ||
|
|
d97a272aa5 | ||
|
|
80a1944b9d | ||
|
|
138cf943a9 | ||
|
|
c7e672e533 | ||
|
|
1b74a04efd | ||
|
|
290c7e6009 | ||
|
|
e8a56e0fea | ||
|
|
1ae7b646b3 | ||
|
|
42e2d73ce2 | ||
|
|
9e2a65a5ce | ||
|
|
fea20ea913 | ||
|
|
5b2480fff2 | ||
|
|
b0dca2a363 | ||
|
|
59bbe72798 | ||
|
|
f99a30a57e | ||
|
|
aa4cb29621 | ||
|
|
91ad4e396b | ||
|
|
351e17aacf | ||
|
|
6c8e09acdb | ||
|
|
1a7b341745 | ||
|
|
af592ea8c1 | ||
|
|
bb096a0357 | ||
|
|
3c226892c6 | ||
|
|
47f6fe069a | ||
|
|
aa3c1d930b | ||
|
|
99b0b4f5b8 | ||
|
|
bcd239ac2b | ||
|
|
2cc25b1e6e | ||
|
|
5fd3ed782f | ||
|
|
c34a24b633 | ||
|
|
775612ec5a | ||
|
|
fd43b16213 | ||
|
|
5a455ec4f7 | ||
|
|
1277c3d156 | ||
|
|
8033d1ca6d | ||
|
|
28df6881a7 | ||
|
|
e5fa5df7be | ||
|
|
f7dbf2bdd4 | ||
|
|
857c57daba | ||
|
|
5515da3c2d | ||
|
|
cfc111f855 | ||
|
|
3dd4043827 | ||
|
|
351ecfae0f | ||
|
|
b22393092b | ||
|
|
1485ee8027 | ||
|
|
60826c2d0c | ||
|
|
fb383458d7 | ||
|
|
196ee1aa8b | ||
|
|
2df97cd2f5 | ||
|
|
501b523680 | ||
|
|
6efa6691b1 | ||
|
|
c47f1ae236 | ||
|
|
aac240fe41 | ||
|
|
041debcd93 | ||
|
|
0632a2d3c8 | ||
|
|
9f40b3a873 | ||
|
|
8fad0af935 | ||
|
|
48ad744ebf | ||
|
|
556d5b0ca5 | ||
|
|
e30d70b6d4 | ||
|
|
a58f5a925a | ||
|
|
a3cc3c57fd | ||
|
|
0d0d3edeae | ||
|
|
dd0be7c522 | ||
|
|
9d2982fcd7 | ||
|
|
ebfd7d2153 | ||
|
|
818cd2454d | ||
|
|
b31d1c06f5 | ||
|
|
6cd884555c | ||
|
|
47ef74a1bb | ||
|
|
cc6d6ddd66 | ||
|
|
6a6cf015a6 | ||
|
|
ca79e81b39 | ||
|
|
a9e86cecf5 | ||
|
|
5773b1c3e5 | ||
|
|
b562b3410b | ||
|
|
f6440e9830 | ||
|
|
e43636e1e9 | ||
|
|
6783bf9903 | ||
|
|
807723c5b2 | ||
|
|
d3c4936116 | ||
|
|
bbb40aef51 | ||
|
|
485a3e29e7 | ||
|
|
1477f99c2c | ||
|
|
2e1f9d5fa9 | ||
|
|
9dea251862 | ||
|
|
17edfd6573 | ||
|
|
458e9d6cc7 | ||
|
|
485459b8b2 | ||
|
|
fcf377d26b | ||
|
|
3be1c9261f | ||
|
|
38600b3347 | ||
|
|
62f7f7a689 | ||
|
|
552f616305 | ||
|
|
a3164177f8 | ||
|
|
fa6bf21cd1 | ||
|
|
eecf76c1fb | ||
|
|
d1635cf24e | ||
|
|
b43e9ed7e7 | ||
|
|
12b2ab5da8 | ||
|
|
1c9085556c | ||
|
|
9122f8acee | ||
|
|
ef8c9f093c | ||
|
|
801dffd571 | ||
|
|
0b1c57b39f | ||
|
|
2febc268f7 | ||
|
|
58995bb3a2 | ||
|
|
8c944815bc | ||
|
|
f065a21542 | ||
|
|
27e032d10d | ||
|
|
ab3980cd38 | ||
|
|
1db648a525 | ||
|
|
ce3b5b683d | ||
|
|
9d23f1298d | ||
|
|
3f791b65b5 | ||
|
|
317d8703ca | ||
|
|
fda619f704 | ||
|
|
e4a0669da8 | ||
|
|
89725df3dc | ||
|
|
51799844c9 | ||
|
|
48de136e9d | ||
|
|
cb6f97a831 | ||
|
|
7e0cd0ab60 | ||
|
|
8521f04087 | ||
|
|
8ba45808be | ||
|
|
d876fd7f5b | ||
|
|
352e409a6e | ||
|
|
d6ec441c8e | ||
|
|
d197497349 | ||
|
|
d892ba6aa5 | ||
|
|
84b2583973 | ||
|
|
108648b427 | ||
|
|
71bf8b6b4d | ||
|
|
576067c1e5 | ||
|
|
e23bab0103 | ||
|
|
4e111c84f3 | ||
|
|
8cecce7570 | ||
|
|
0338fd42e1 | ||
|
|
b3788bc143 | ||
|
|
18d66ddded | ||
|
|
701b5ea561 | ||
|
|
86d0de4b0e | ||
|
|
a95958f9f6 | ||
|
|
69ab236f3f | ||
|
|
4cf3c6a616 | ||
|
|
da48bbf312 | ||
|
|
ac957db6d1 | ||
|
|
64464f23ae | ||
|
|
52cb239194 | ||
|
|
efd54b7523 | ||
|
|
2aca57cb82 | ||
|
|
d68baf08cb | ||
|
|
a7578aa709 | ||
|
|
a8261d376a | ||
|
|
fc346b4efd | ||
|
|
ad09e734da | ||
|
|
a674fea1c2 | ||
|
|
9e22b34fac | ||
|
|
fe24408620 | ||
|
|
c07ad0941c | ||
|
|
2f02b38b62 | ||
|
|
3ac766530d | ||
|
|
de77c71042 | ||
|
|
9c854a1757 | ||
|
|
f66fa1150e | ||
|
|
f820706e4f | ||
|
|
29e9e0f2cc | ||
|
|
2933093e17 | ||
|
|
71cd8918be | ||
|
|
c049ba59ff | ||
|
|
51c5f28443 | ||
|
|
bb1ed902a9 | ||
|
|
b016a60a75 | ||
|
|
890d485bb5 | ||
|
|
208bb2d72f | ||
|
|
267bf289c4 | ||
|
|
b3e083d866 | ||
|
|
a675c64c2d | ||
|
|
8b50c8515f | ||
|
|
1eaa377583 | ||
|
|
4345b1d930 | ||
|
|
06bf0c2622 | ||
|
|
3ac8de0a64 | ||
|
|
f237fd9847 | ||
|
|
5730280325 | ||
|
|
ab4df7e078 | ||
|
|
b52e6c99ab | ||
|
|
7dab548522 | ||
|
|
785c341822 | ||
|
|
7d2e1f63b5 | ||
|
|
e119459411 | ||
|
|
97ef2191fd | ||
|
|
e833ccf309 | ||
|
|
a4134d30fa | ||
|
|
6069fd02d3 | ||
|
|
bb15dc57a4 | ||
|
|
bdfe170c3b | ||
|
|
0fa2ba53ab | ||
|
|
4bb657debf | ||
|
|
dd12840e34 | ||
|
|
b027dcfec9 | ||
|
|
9e9b6f1542 | ||
|
|
7cd66e20d0 | ||
|
|
d93df15eff | ||
|
|
ddfd20d997 | ||
|
|
fd8af88493 | ||
|
|
bfa488f77d | ||
|
|
03be793930 | ||
|
|
37d88d5ff7 | ||
|
|
4616f889fd | ||
|
|
59cbf95c4f | ||
|
|
058711d3a8 | ||
|
|
2ddc61fa5c | ||
|
|
e04b7d0f01 | ||
|
|
2faa2ed1f4 | ||
|
|
5e2889e776 | ||
|
|
5bda36fb28 | ||
|
|
53fbb257b9 | ||
|
|
65a32d6e20 | ||
|
|
92450920d4 | ||
|
|
0099a9822e | ||
|
|
0cf86974dd | ||
|
|
716705aa15 | ||
|
|
757993064e | ||
|
|
3f738cf905 | ||
|
|
570715100b | ||
|
|
ad8750b40d | ||
|
|
757ea93393 | ||
|
|
dbd5a222d5 | ||
|
|
bba80bc80f | ||
|
|
094143bc28 | ||
|
|
24a335d304 | ||
|
|
c62b318b9e | ||
|
|
ea5c7c321a | ||
|
|
6d92775ab5 | ||
|
|
1a9360ca75 | ||
|
|
22b9bbe702 | ||
|
|
6fb44083ec | ||
|
|
ba02be08bb | ||
|
|
56fe3ede5b | ||
|
|
e48a000784 | ||
|
|
6d1c150ff5 | ||
|
|
21190a240f | ||
|
|
8a525bc131 | ||
|
|
734905d1f7 | ||
|
|
90edf2fc60 | ||
|
|
e3f37c14db | ||
|
|
c6c92184d9 | ||
|
|
c4fbc65354 | ||
|
|
54d250bde4 | ||
|
|
ef309bd8d0 | ||
|
|
6cdb6ec711 | ||
|
|
03891b66b6 | ||
|
|
42dd6326d5 | ||
|
|
5c4defdb8e | ||
|
|
f08d53b0c6 | ||
|
|
6859b85266 | ||
|
|
075adb4f03 | ||
|
|
5ce72a3461 | ||
|
|
8c2958b86d | ||
|
|
f15b7cebac | ||
|
|
f6d8df1e83 | ||
|
|
19ed5bf993 | ||
|
|
5567e2843d | ||
|
|
0a8e20fd60 | ||
|
|
558c4341e4 | ||
|
|
250860d92c | ||
|
|
64aecba7a0 | ||
|
|
3689b08237 | ||
|
|
30e567e8b6 | ||
|
|
ddd74549fe | ||
|
|
14620c32aa | ||
|
|
fb7068d415 | ||
|
|
8614ff40df | ||
|
|
aa10a9d899 | ||
|
|
a5b8feca93 | ||
|
|
486e47f985 | ||
|
|
bb5a1ad513 | ||
|
|
eac0a52f10 | ||
|
|
7ac00258cc | ||
|
|
e3a0ae8a4b | ||
|
|
2953159f8b | ||
|
|
9693363c76 | ||
|
|
a2533af116 | ||
|
|
b4aecb5b74 | ||
|
|
15aa2498b5 | ||
|
|
0372ff0c2c | ||
|
|
7a8d5a391a | ||
|
|
2a6c81a89d | ||
|
|
301871aec6 | ||
|
|
25359e5320 | ||
|
|
b6fff53b21 | ||
|
|
ae7b5fac74 | ||
|
|
26168a9520 | ||
|
|
698dfca319 | ||
|
|
3bcb98e644 | ||
|
|
2deb436ccd | ||
|
|
2b3405c4a9 | ||
|
|
677a465630 | ||
|
|
8ecb76fc0b | ||
|
|
0178013fc1 | ||
|
|
c273a8ee69 | ||
|
|
0ed56b706b | ||
|
|
4582b6cf76 | ||
|
|
05513bcd1e | ||
|
|
f5dd135ed8 | ||
|
|
9c8f85741c | ||
|
|
ca515f2eae | ||
|
|
80c1ebd768 | ||
|
|
b51fd7fc13 | ||
|
|
efe86c37b2 | ||
|
|
d20a4a8bfc | ||
|
|
9da2d11e80 | ||
|
|
5ef554aecf | ||
|
|
9a7fea0447 | ||
|
|
ae52ff93b2 | ||
|
|
80a567bf1e | ||
|
|
ce2a3361eb | ||
|
|
ca9ea109c6 | ||
|
|
2a33a746f0 | ||
|
|
e8c5246645 | ||
|
|
98295b85ab | ||
|
|
af1823db8c | ||
|
|
a2ab6b89f1 | ||
|
|
5de300fb35 | ||
|
|
62a4c82e95 | ||
|
|
d522c864d4 | ||
|
|
aa8ff7ace3 | ||
|
|
4e6a931de3 | ||
|
|
5e141e869d | ||
|
|
611555514c | ||
|
|
e1c78fcbd3 | ||
|
|
8640d6bb1e | ||
|
|
28d5bedcc7 | ||
|
|
373b890e1d | ||
|
|
aad0f90a9d | ||
|
|
5dc45c35e6 | ||
|
|
b8c87632e6 | ||
|
|
c85903383a | ||
|
|
4aededf038 | ||
|
|
4bc6501b8d | ||
|
|
a1b3b47573 | ||
|
|
c8cf4fe09c | ||
|
|
ca07d75405 | ||
|
|
c5001f3620 | ||
|
|
8d5f941829 | ||
|
|
c3bfaa1c33 | ||
|
|
ea0d52c0b8 | ||
|
|
fcb37f40f6 | ||
|
|
7f30d07f4c | ||
|
|
59744a96fa | ||
|
|
b82fb58dc4 | ||
|
|
c728214af7 | ||
|
|
305d636217 | ||
|
|
31312747e9 | ||
|
|
5ef288b840 | ||
|
|
f6615a490d | ||
|
|
bd4f5ebcdf | ||
|
|
1fd7ff5655 | ||
|
|
ab7e1b42bd | ||
|
|
a7723e6ded | ||
|
|
1b78001201 | ||
|
|
36c0eae7ed | ||
|
|
0ae43e242f | ||
|
|
bafd4f1860 | ||
|
|
388e58bf1e | ||
|
|
eee973fe86 | ||
|
|
61769c6f9c | ||
|
|
665ef9424e | ||
|
|
7a0f0ca5ce | ||
|
|
63be05146d | ||
|
|
9239cfb3c1 | ||
|
|
6fd24ad54f | ||
|
|
d70933c9f2 | ||
|
|
9ac2ddcb4d | ||
|
|
8d9569e06b | ||
|
|
02f8e657f3 | ||
|
|
3dc711ab9d | ||
|
|
702922dd88 | ||
|
|
2583c809ca | ||
|
|
b6071ce6dc | ||
|
|
186132bb98 | ||
|
|
c15790f230 | ||
|
|
13924a8353 | ||
|
|
fd84b57ac8 | ||
|
|
591a6b330a | ||
|
|
a3b767bb13 | ||
|
|
847ee61bf4 | ||
|
|
0c6cede287 | ||
|
|
ce4b07d7d7 | ||
|
|
a1f49b279f | ||
|
|
1c8075ca40 | ||
|
|
56b0952cd1 | ||
|
|
1c152f6cad | ||
|
|
57c05354c2 | ||
|
|
90b5479735 | ||
|
|
1079c4516c | ||
|
|
7381985c79 | ||
|
|
fd26f9f34e | ||
|
|
88b70973cc | ||
|
|
f0658bbd09 | ||
|
|
661e07c8db | ||
|
|
6e51189d4d | ||
|
|
dfdb7c835b | ||
|
|
f1d7aa09e4 | ||
|
|
88e6b865d9 | ||
|
|
d5c6d74f14 | ||
|
|
202f3d36c4 | ||
|
|
7a54b1d36a | ||
|
|
9091b36249 | ||
|
|
21285d9f6d | ||
|
|
2ebc773863 | ||
|
|
44f4057876 | ||
|
|
d85020079f | ||
|
|
956dc382ea | ||
|
|
99aa214859 | ||
|
|
405e98f429 | ||
|
|
a8c375fc95 | ||
|
|
4a56a2cad6 | ||
|
|
438945907d | ||
|
|
db245add0f | ||
|
|
986699bce5 | ||
|
|
d1803320f1 | ||
|
|
d4609519f0 | ||
|
|
2b4a6284e4 | ||
|
|
3c6be7e04c | ||
|
|
e738e57e26 | ||
|
|
21ebc398fa | ||
|
|
1ac611239e | ||
|
|
97e6047725 | ||
|
|
cf3f0fcc39 | ||
|
|
19c32bf993 | ||
|
|
e86eb16d91 | ||
|
|
1fcd1ff3e8 | ||
|
|
58f4212aa8 | ||
|
|
f01152eda1 | ||
|
|
11ff40bcd6 | ||
|
|
46e985b306 | ||
|
|
fdc014af67 | ||
|
|
bf11a46abe | ||
|
|
8f41130a14 | ||
|
|
e96c4732d6 | ||
|
|
a1d38a6940 | ||
|
|
9b8703cf49 | ||
|
|
c4d77bc18a | ||
|
|
c69fbb72d3 | ||
|
|
64e4791dca | ||
|
|
bc1e62ce51 | ||
|
|
79c1040796 | ||
|
|
eaf55bf12c | ||
|
|
ce528c9783 | ||
|
|
b9c7501012 | ||
|
|
ae10052aaf | ||
|
|
10abcd519f | ||
|
|
1d6c763e92 | ||
|
|
3fa0ce99f0 | ||
|
|
7380585f00 | ||
|
|
7557ffcda1 | ||
|
|
bc9d70109c | ||
|
|
7448159d6b | ||
|
|
f16273772e |
31
.travis.yml
Normal file
31
.travis.yml
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
dist: bionic
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
include:
|
||||||
|
- stage: build
|
||||||
|
# TODO: Shallowly clone again once the .git folder is no longer required for building
|
||||||
|
git:
|
||||||
|
depth: false
|
||||||
|
language: crystal
|
||||||
|
crystal: latest
|
||||||
|
before_install:
|
||||||
|
- shards update
|
||||||
|
- shards install
|
||||||
|
install:
|
||||||
|
- crystal build --warnings all --error-on-warnings src/invidious.cr
|
||||||
|
script:
|
||||||
|
- crystal tool format --check
|
||||||
|
- crystal spec
|
||||||
|
|
||||||
|
- stage: build_docker
|
||||||
|
# TODO: Shallowly clone again once the .git folder is no longer required for building
|
||||||
|
git:
|
||||||
|
depth: false
|
||||||
|
language: minimal
|
||||||
|
services:
|
||||||
|
- docker
|
||||||
|
install:
|
||||||
|
- docker-compose build
|
||||||
|
script:
|
||||||
|
- docker-compose up -d
|
||||||
|
- while curl -Isf http://localhost:3000; do sleep 1; done
|
||||||
458
CHANGELOG.md
458
CHANGELOG.md
@@ -1,3 +1,445 @@
|
|||||||
|
# 0.20.0 (2019-011-06)
|
||||||
|
|
||||||
|
# Version 0.20.0: Custom Playlists
|
||||||
|
|
||||||
|
It's been quite a while since the last release! There've been [198 commits](https://github.com/omarroth/invidious/compare/0.19.0..0.20.0) from 27 contributors.
|
||||||
|
|
||||||
|
A couple smaller features have since been added. Channel pages and playlists in particular have received a bit of a face-lift, with both now displaying their descriptions as expected, and playlists providing video count and published information. Channels will also now provide video descriptions in their RSS feed.
|
||||||
|
|
||||||
|
Turkish (tr), Chinese (zh-TW, in addition to zh-CN), and Japanese (jp) are all now supported languages. Thank you as always to the hard work done by translators that makes this possible.
|
||||||
|
|
||||||
|
The feed menu and default home page are both now configurable for registered and unregistered users, and is quite a bit of an improvement for users looking to reduce distractions for their daily use.
|
||||||
|
|
||||||
|
## For Administrators
|
||||||
|
|
||||||
|
`feed_menu` and `default_home` are now configurable by the user, and have therefore been moved into `default_user_preferences`:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
feed_menu: ["Popular", "Top"]
|
||||||
|
default_home: Top
|
||||||
|
|
||||||
|
# becomes:
|
||||||
|
|
||||||
|
default_user_preferences:
|
||||||
|
feed_menu: ["Popular", "Top"]
|
||||||
|
default_home: Top
|
||||||
|
```
|
||||||
|
|
||||||
|
Several new options have also been added, including the ability to set a support email for the instance using `admin_email: EMAIL`, and forcing the use of a specific connection in the case of rate-limiting using `force_resolve` (see below).
|
||||||
|
|
||||||
|
## For Developers
|
||||||
|
|
||||||
|
Authenticated endpoints are now [properly documented](https://github.com/omarroth/invidious/wiki/Authenticated-Endpoints), as well how to generate and use API tokens. My hope is that this makes some of the more [interesting](https://github.com/omarroth/invidious/wiki/Authenticated-Endpoints#get-apiv1authnotifications) endpoints more accessible for developers to use in their own applications.
|
||||||
|
|
||||||
|
API endpoints for interacting with custom playlists have also been added with documentation available [here](https://github.com/omarroth/invidious/wiki/Authenticated-Endpoints#get-apiv1authplaylists).
|
||||||
|
|
||||||
|
## Custom playlists
|
||||||
|
|
||||||
|
This is probably the feature that has been the longest in the pipe and that I'm quite pleased is now implemented. It is now possible to create custom playlists, which can be played and edited through Invidious. API endpoints have also been added (documentation [here](https://github.com/omarroth/invidious/wiki/Authenticated-Endpoints#get-apiv1authplaylists)).
|
||||||
|
|
||||||
|
Overall I'm quite pleased with how smoothly it has been rolled out and with the experience so far, and I'm exctited for how it can be extended and improved in future.
|
||||||
|
|
||||||
|
## [instances.invidio.us](https://instances.invidio.us)
|
||||||
|
|
||||||
|
It is now possible to view a list of public instances (as provided in the [wiki](https://github.com/omarroth/invidious/wiki/Invidious-Instances)) through an API or a pretty new interface [here](https://instances.invidio.us). It combines uptime information, statistics from each instance and basic information already provided in the wiki. I expect it should be much more user-friendly than compiling the information yourself, and is already used by [Invidition](https://codeberg.org/Booteille/Invidition) to provide a list of instances for users to choose from.
|
||||||
|
|
||||||
|
The site itself is licensed under the AGPLv3 and the source is available [here](https://github.com/omarroth/instances.invidio.us).
|
||||||
|
|
||||||
|
## Video unavailable [#811](https://github.com/omarroth/invidious/issues/811)
|
||||||
|
|
||||||
|
Many users have likely noticed this error message if using Invidious directly or through another service, such as FreeTube. This issue is caused by rate-limiting by Google, and is not a new issuee for projects like Invidious (notably [youtube-dl](https://github.com/ytdl-org/youtube-dl#http-error-429-too-many-requests-or-402-payment-required)) and appears to be affecting smaller, private instances as well.
|
||||||
|
|
||||||
|
There is not a permanent fix for administrators currently, however there is some information available [here](https://github.com/omarroth/invidious/issues/811#issuecomment-540017772) that may provide a temporary solution. Unfortanately, in most cases the best option is to wait for the instance to be unbanned or to move the instance to a different IP. A more informative error message is also now provided, which should help an administrator more quickly diagnose the problem.
|
||||||
|
|
||||||
|
For those interested, I would recommend following [#811](https://github.com/omarroth/invidious/issues/811) for any future progress on the issue.
|
||||||
|
|
||||||
|
## BAT verified publisher
|
||||||
|
|
||||||
|
I'm quite late to this announcement, however I'm pleased to mention that Invidious is now a BAT verified publisher! I would recommend looking [here](https://basicattentiontoken.org/about/) or [here](https://www.reddit.com/r/BATProject/comments/7cr7yc/new_to_bat_read_this_introduction_to_basic/) for learning more about what it is and how it works. Overall I think it makes an interesting substitute for services like Liberapay, and a (hopefully) much less-intrusive alternative to direct advertising.
|
||||||
|
|
||||||
|
BAT is combined under other cryptocurrencies below. Currently there's a fairly significant delay in payout, which is the reason for the large fluctuation in crypto donations between September and October (and also the reason for the late announcement).
|
||||||
|
|
||||||
|
## Release schedule
|
||||||
|
|
||||||
|
Currently I'm quite pleased with the current state of the project. There's plenty of things I'd still like to add, however at this point I expect the rate of most new additions will slow down a bit, with more focus on stabililty and any long-standing bugs.
|
||||||
|
|
||||||
|
Because of this, I'm planning on releasing a new version quarterly, with any necessary hotfixes being pushed as a new patch release as necessary. As always it will be possible to run Invidious directly from [master](https://github.com/omarroth/invidious/wiki/Updating) if you'd still like to have the lastest version.
|
||||||
|
|
||||||
|
I'll plan on providing finances each release, with a similar monthly breakdown as below.
|
||||||
|
|
||||||
|
## Finances for September 2019
|
||||||
|
|
||||||
|
### Donations
|
||||||
|
|
||||||
|
- [Patreon](https://www.patreon.com/omarroth) : \$64.37
|
||||||
|
- [Liberapay](https://liberapay.com/omarroth) : \$76.04
|
||||||
|
- Crypto : ~\$99.89 (converted from BAT, BCH, BTC)
|
||||||
|
- Total : \$240.30
|
||||||
|
|
||||||
|
### Expenses
|
||||||
|
|
||||||
|
- invidious-lb1 (nyc1) : \$10.00 (load balancer)
|
||||||
|
- invidious-update1 (s-1vcpu-1gb) : \$5.00 (updates feeds)
|
||||||
|
- invidious-node1 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node2 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node3 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node4 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node5 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node6 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node7 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node8 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node9 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node10 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node11 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node12 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node13 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node14 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node15 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node16 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-db1 (s-4vcpu-8gb) : \$40.00 (database)
|
||||||
|
- Total : \$135.00
|
||||||
|
|
||||||
|
## Finances for October 2019
|
||||||
|
|
||||||
|
- [Liberapay](https://liberapay.com/omarroth) : \$134.40
|
||||||
|
- Crypto : ~\$8.29 (converted from BAT, BCH, BTC)
|
||||||
|
- Total : \$142.69
|
||||||
|
|
||||||
|
### Expenses
|
||||||
|
|
||||||
|
- invidious-lb1 (nyc1) : \$5.00 (load balancer)
|
||||||
|
- invidious-lb2 (nyc1) : \$5.00 (load balancer)
|
||||||
|
- invidious-lb3 (nyc1) : \$5.00 (load balancer)
|
||||||
|
- invidious-lb4 (nyc1) : \$5.00 (load balancer)
|
||||||
|
- invidious-update1 (s-1vcpu-1gb) : \$5.00 (updates feeds)
|
||||||
|
- invidious-node1 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node2 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node3 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node4 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node5 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node6 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node7 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node8 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node9 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node10 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node11 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node12 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node13 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node14 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node15 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node16 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node17 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node18 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-db1 (s-4vcpu-8gb) : \$40.00 (database)
|
||||||
|
- Total : \$155.00
|
||||||
|
|
||||||
|
# 0.19.0 (2019-07-13)
|
||||||
|
|
||||||
|
# Version 0.19.0: Communities
|
||||||
|
|
||||||
|
Hello again everyone! Focus this month has mainly been on improving playback performance, along with a couple new features I'd like to announce. There have been [109 commits](https://github.com/omarroth/invidious/compare/0.18.0...0.19.0) this past month from 10 contributors.
|
||||||
|
|
||||||
|
This past month has seen the addition of Chinese (`zh-CN`) and Icelandic (`is`) translations. I would like to give a huge thanks to their respective translators, and again an enormous thanks to everyone who helps translate the site.
|
||||||
|
|
||||||
|
I'm delighted to mention that [FreeTube 0.6.0](https://github.com/FreeTubeApp/FreeTube) now supports 1080p thanks to the Invidious API. I would very much recommend reading the [relevant post](https://freetube.writeas.com/freetube-release-0-6-0-beta-1080p-and-a-lot-of-qol) for some more information on how it works, along with several other major improvements. Folks that are interested in adding similar functionality for their own projects should feel free to get in touch.
|
||||||
|
|
||||||
|
This past month there has been quite a bit of work on improving memory usage and improving download and playback speeds. As mentioned in the previous release, some extra hardware has been allocated which should also help with this. I'm still looking for ways to improve performance and feedback is always appreciated.
|
||||||
|
|
||||||
|
Along with performance, a couple quality of life improvements have been added, including author thumbnails and banners, clickable titles for embedded videos, and better styling for captions, among some other enhancements.
|
||||||
|
|
||||||
|
## Communities
|
||||||
|
|
||||||
|
Support for YouTube's [communities tab](https://creatoracademy.youtube.com/page/lesson/community-tab) has been added. It's a very interesting but surprisingly unknown feature. Essentially, providing comments for a channel, rather than a video, where an author can post updates for their subscribers.
|
||||||
|
|
||||||
|
It's commonly used to promote interesting links and foster discussion. I hope this feature helps people find more interesting content that otherwise would have been overlooked.
|
||||||
|
|
||||||
|
## For Developers
|
||||||
|
|
||||||
|
For accessing channel communities, an `/api/v1/channels/comments/:ucid` endpoint has been added, with similar behavior and schema to `/api/v1/comments/:id`, with an extra `attachment` field for top-level comments. More info on usage and available data can be found in the [wiki](https://github.com/omarroth/invidious/wiki/API#get-apiv1channelscommentsucid-apiv1channelsucidcomments).
|
||||||
|
|
||||||
|
An `/api/v1/auth/feeds` endpoint has been added for programmatically accessing a user's subscription feed, with options for displaying notifications and filtering an existing feed.
|
||||||
|
|
||||||
|
An `/api/v1/search/suggestions` endpoint has been added for retrieving suggestions for a given query.
|
||||||
|
|
||||||
|
## For Administrators
|
||||||
|
|
||||||
|
It is now possible to disable more resource intensive features, such as downloads and DASH functionality by adding `disable_proxy` to your config. See [#453](https://github.com/omarroth/invidious/issues/453) and the [Wiki](https://github.com/omarroth/invidious/wiki/Configuration) for more information and example usage. I expect this to be a big help for folks with limited bandwidth when hosting their own instances.
|
||||||
|
|
||||||
|
## Finances
|
||||||
|
|
||||||
|
### Donations
|
||||||
|
|
||||||
|
- [Patreon](https://www.patreon.com/omarroth) : \$38.39
|
||||||
|
- [Liberapay](https://liberapay.com/omarroth) : \$84.85
|
||||||
|
- Crypto : ~\$0.00 (converted from BCH, BTC)
|
||||||
|
- Total : \$123.24
|
||||||
|
|
||||||
|
### Expenses
|
||||||
|
|
||||||
|
- invidious-load1 (nyc1) : \$10.00 (load balancer)
|
||||||
|
- invidious-update1 (s-1vcpu-1gb) : \$5.00 (updates feeds)
|
||||||
|
- invidious-node1 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node2 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node3 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node4 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node5 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node6 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node7 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node8 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node9 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node10 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-db1 (s-4vcpu-8gb) : \$40.00 (database)
|
||||||
|
- Total : \$105.00
|
||||||
|
|
||||||
|
The goal on Patreon has been updated to reflect the above expenses. As mentioned above, the main reason for more hardware is to improve playback and download speeds, although I'm still looking into improving performance without allocating more hardware.
|
||||||
|
|
||||||
|
As always I'm grateful for everyone's support and feedback. I'll see you all next month.
|
||||||
|
|
||||||
|
# 0.18.0 (2019-06-06)
|
||||||
|
|
||||||
|
# Version 0.18.0: Native Notifications and Optimizations
|
||||||
|
|
||||||
|
Hope everyone has been doing well. This past month there have been [97 commits](https://github.com/omarroth/invidious/compare/0.17.0...0.18.0) from 10 contributors. For the most part changes this month have been on optimizing various parts of the site, mainly subscription feeds and support for serving images and other assets.
|
||||||
|
|
||||||
|
I'm quite happy to mention that support for Greek (`el`) has been added, which I hope will continue to make the site accessible for more users.
|
||||||
|
|
||||||
|
Subscription feeds will now only update when necessary, rather than periodically. This greatly lightens the load on DB as well as making the feeds generally more responsive when changing subscriptions, importing data, and when receiving new uploads.
|
||||||
|
|
||||||
|
Caching for images and other assets should be greatly improved with [#456](https://github.com/omarroth/invidious/issues/456). JavaScript has been pulled out into separate files where possible to take advantage of this, which should result in lighter pages and faster load times.
|
||||||
|
|
||||||
|
This past month several people have encountered issues with downloads and watching high quality video through the site, see [#532](https://github.com/omarroth/invidious/issues/532) and [#562](https://github.com/omarroth/invidious/issues/562). For this coming month I've allocated some more hardware which should help with this, and I'm also looking into optimizing how videos are currently served.
|
||||||
|
|
||||||
|
## For Developers
|
||||||
|
|
||||||
|
`viewCount` is now available for `/api/v1/popular` and all videos returned from `/api/v1/auth/notifications`. Both also now provide `"type"` for indicating available information for each object.
|
||||||
|
|
||||||
|
An `/authorize_token` page is now available for more easily creating new tokens for use in applications, see [this comment](https://github.com/omarroth/invidious/issues/473#issuecomment-496230812) in [#473](https://github.com/omarroth/invidious/issues/473) for more details.
|
||||||
|
|
||||||
|
A POST `/api/v1/auth/notifications` endpoint is also now available for correctly returning notifications for 150+ channels.
|
||||||
|
|
||||||
|
## For Administrators
|
||||||
|
|
||||||
|
There are two new schema changes for administrators: `views` for adding view count to the popular page, and `feed_needs_update` for tracking feed changes.
|
||||||
|
|
||||||
|
As always the relevant migration scripts are provided which should run when following instructions for [updating](https://github.com/omarroth/invidious/wiki/Updating). Otherwise, adding `check_tables: true` to your config will automatically make the required changes.
|
||||||
|
|
||||||
|
## Native Notifications
|
||||||
|
|
||||||
|
[<img src="https://omar.yt/81c3ae1839831bd9300d75e273b6552a86dc2352/native_notification.png" height="160" width="472">](https://omar.yt/81c3ae1839831bd9300d75e273b6552a86dc2352/native_notification.png "Example of native notification, available in repository under screnshots/native_notification.png")
|
||||||
|
|
||||||
|
It is now possible to receive [Web notifications](https://developer.mozilla.org/en-US/docs/Web/API/Notifications_API) from subscribed channels.
|
||||||
|
|
||||||
|
You can enable notifications by clicking "Enable web notifications" in your preferences. Generally they appear within 20-60 seconds of a new video being uploaded, and I've found them to be an enormous quality of life improvement.
|
||||||
|
|
||||||
|
Although it has been fairly stable, please feel free to report any issues you find [here](https://github.com/omarroth/invidious/issues) or emailing me directly at omarroth@protonmail.com.
|
||||||
|
|
||||||
|
Important to note for administrators is that instances require [`use_pubsub_feeds`](https://github.com/omarroth/invidious/wiki/Configuration) and must be served over HTTPS in order to correctly send web notifications.
|
||||||
|
|
||||||
|
## Finances
|
||||||
|
|
||||||
|
### Donations
|
||||||
|
|
||||||
|
- [Patreon](https://www.patreon.com/omarroth) : \$49.73
|
||||||
|
- [Liberapay](https://liberapay.com/omarroth) : \$100.57
|
||||||
|
- Crypto : ~\$11.12 (converted from BCH, BTC)
|
||||||
|
- Total : \$161.42
|
||||||
|
|
||||||
|
### Expenses
|
||||||
|
|
||||||
|
- invidious-load1 (nyc1) : \$10.00 (load balancer)
|
||||||
|
- invidious-update1 (s-1vcpu-1gb) : \$5.00 (updates feeds)
|
||||||
|
- invidious-node1 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node2 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node3 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node4 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node5 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node6 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-db1 (s-4vcpu-8gb) : \$40.00 (database)
|
||||||
|
- Total : \$85.00
|
||||||
|
|
||||||
|
See you all next month!
|
||||||
|
|
||||||
|
# 0.17.0 (2019-05-06)
|
||||||
|
|
||||||
|
# Version 0.17.0: Player and Authentication API
|
||||||
|
|
||||||
|
Hello everyone! This past month there have been [130 commits](https://github.com/omarroth/invidious/compare/0.16.0..0.17.0) from 11 contributors. Large focus has been on improving the player as well as adding API access for other projects to make use of Invidious.
|
||||||
|
|
||||||
|
There have also been significant changes in preparation of native notifications (see [#195](https://github.com/omarroth/invidious/issues/195), [#469](https://github.com/omarroth/invidious/issues/469), [#473](https://github.com/omarroth/invidious/issues/473), and [#502](https://github.com/omarroth/invidious/issues/502)), and playlists. I expect to see both of these to be added in the next release.
|
||||||
|
|
||||||
|
I'm quite happy to mention that new translations have been added for Esperanto (`eo`) and Ukranian (`uk`). Support for pluralization has also been added, so it should now be possible to make a more native experience for speakers in other languages. The system currently in place is a bit cumbersome, so for any help using this feature please get in touch!
|
||||||
|
|
||||||
|
## For Administrators
|
||||||
|
|
||||||
|
A `check_tables` option has been added to automatically migrate without the use of custom scripts. This method will likely prove to be much more robust, and is currently enabled for the official instance. To prevent any unintended changes to the DB, `check_tables` is disabled by default and will print commands before executing. Having this makes features that require schema changes much easier to implement, and also makes it easier to upgrade from older instances.
|
||||||
|
|
||||||
|
As part of [#303](https://github.com/omarroth/invidious/issues/303), a `cache_annotations` option has been added to speed up access from `/api/v1/annotations/:id`. This vastly improves the experience for videos with annotations. Currently, only videos that contain legacy annotations will be cached, which should help keep down the size of the cache. `cache_annotations` is disabled by default.
|
||||||
|
|
||||||
|
## For Developers
|
||||||
|
|
||||||
|
An authorization API has been added which allows other applications to read and modify user subscriptions and preferences (see [#473](https://github.com/omarroth/invidious/issues/473)). Support for accessing user feeds and notifications is also planned. I believe this feature is a large step forward in supporting syncing subscriptions and preferences with other services, and I'm excited to see what other developers do with this functionality.
|
||||||
|
|
||||||
|
Support for server-to-client push notifications is currently underway. This allows Invidious users, as well as applications using the Invidious API, to receive notifications about uploads in near real-time (see #469). An `/api/v1/auth/notifications` endpoint is currently available. I'm very excited for this to be integrated into the site, and to see how other developers use it in their own projects.
|
||||||
|
|
||||||
|
An `/api/v1/storyboards/:id` endpoint has been added for accessing storyboard URLs, which allows developers to add video previews to their players (see below).
|
||||||
|
|
||||||
|
## Player
|
||||||
|
|
||||||
|
Support for annotations has been merged into master with [#303](https://github.com/omarroth/invidious/issues/303), thanks @glmdgrielson! Annotations can be enabled by default or only for subscribed channels, and can also be toggled per video. I'm extremely proud of the progress made here, and I'm so thankful to everyone that has made this possible. I expect this to be the last update with regards to supporting annotations, but I do plan on continuing to improve the experience as much as possible.
|
||||||
|
|
||||||
|
The Invidious player now supports video previews and a corresponding API endpoint `/api/v1/storyboards/:id` has been added for developers looking to add similar functionality to their own players. Not much else to say here. Overall it's a very nice quality of life improvement and an attractive addition to the site.
|
||||||
|
|
||||||
|
It is now possible to select specific sources for videos provided using DASH (see [#34](https://github.com/omarroth/invidious/issues/34)). I would consider support largely feature complete, although there are still several issues to be fixed before I would consider it ready for larger rollout. You can watch videos in 1080p by setting `Default quality` to `dash` in your preferences, or by adding `&quality=dash` to the end of video URLs.
|
||||||
|
|
||||||
|
## Finances
|
||||||
|
|
||||||
|
### Donations
|
||||||
|
|
||||||
|
- [Patreon](https://www.patreon.com/omarroth) : \$49.73
|
||||||
|
- [Liberapay](https://liberapay.com/omarroth) : \$63.03
|
||||||
|
- Crypto : ~\$0.00 (converted from BCH, BTC)
|
||||||
|
- Total : \$112.76
|
||||||
|
|
||||||
|
### Expenses
|
||||||
|
|
||||||
|
- invidious-load1 (nyc1) : \$10.00 (load balancer)
|
||||||
|
- invidious-update1 (s-1vcpu-1gb) : \$5.00 (updates feeds)
|
||||||
|
- invidious-node1 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node2 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node3 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node4 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node5 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-db1 (s-4vcpu-8gb) : \$40.00 (database)
|
||||||
|
- Total : \$80.00
|
||||||
|
|
||||||
|
That's all for now. Thanks!
|
||||||
|
|
||||||
|
# 0.16.0 (2019-04-06)
|
||||||
|
|
||||||
|
# Version 0.16.0: API Improvements and Annotations
|
||||||
|
|
||||||
|
Hello again! This past month has seen [116 commits](https://github.com/omarroth/invidious/compare/0.15.0..0.16.0) from 13 contributors and a couple important changes I'd like to announce.
|
||||||
|
|
||||||
|
A privacy policy is now available [here](https://invidio.us/privacy). I've done my best to explain things as clearly as possible without oversimplifying, and would very much recommend reading it if you're concerned about your privacy and want to learn more about how Invidious uses your data. Please let me know if there is anything that needs clarification.
|
||||||
|
|
||||||
|
I'm also very happy to announce that a Spanish translation has been added to the site. You can use it with `?hl=es` or by setting `es` as your default locale. As always I'm extremely grateful to translators for making the site accessible to more people.
|
||||||
|
|
||||||
|
## For Administrators
|
||||||
|
|
||||||
|
Invidious now supports server-to-server [push notifications](https://developers.google.com/youtube/v3/guides/push_notifications). This uses [PubSubHubbub](https://pubsubhubbub.github.io/PubSubHubbub/pubsubhubbub-core-0.4.html) to automatically handle new videos sent to an instance, which is less resource intensive and generally faster. Note that it will not pull all videos from a subscribed channel, so recommended usage is in addition to `channel_threads`. Using PubSub requires a valid `domain` that updates can be sent to, and a random string that can be used to sign updates sent to the instance. You can enable it by adding `use_pubsub_feeds: true` to your `config.yml`. See [Configuration](https://github.com/omarroth/invidious/wiki/Configuration) for more info.
|
||||||
|
|
||||||
|
Unfortunately there are a couple necessary changes to the DB to support `liveNow` and `premiereTimestamp` in subscription feeds. Migration scripts have been provided that should be used automatically if following the instructions [here](https://github.com/omarroth/invidious/wiki/Updating).
|
||||||
|
|
||||||
|
You can now configure default user preferences for your instance. This allows you to set default locale, player preferences, and more. See [#415](https://github.com/omarroth/invidious/issues/415) for more details and example usage.
|
||||||
|
|
||||||
|
## For Developers
|
||||||
|
|
||||||
|
The [fields](https://developers.google.com/youtube/v3/getting-started#fields) API has been added with [#429](https://github.com/omarroth/invidious/pull/429) and is now supported on all JSON endpoints, thanks [**@afrmtbl**](https://github.com/afrmtbl)! Synax is straight-forward and can be used to reduce data transfer and create a simpler response for debugging. You can see an example [here](https://invidio.us/api/v1/videos/CvFH_6DNRCY?pretty=1&fields=title,recommendedVideos/title). I've been quite happy using it and hope it is similarly useful for others.
|
||||||
|
|
||||||
|
An `/api/v1/annotations/:id` endpoint has been added for pulling legacy annotation data from [this](https://archive.org/details/youtubeannotations) archive, see below for more details. You can also access annotation data available on YouTube using `?source=youtube`, although this will only return card data as legacy annotations were deleted on January 15th.
|
||||||
|
|
||||||
|
A couple minor changes to existing endpoints:
|
||||||
|
|
||||||
|
- A `premiereTimestamp` field has been added to `/api/v1/videos/:id`
|
||||||
|
- A `sort_by` param has been added to `/api/v1/comments/:id`, supports `new`, `top`.
|
||||||
|
|
||||||
|
More info is available in the [documentation](https://github.com/omarroth/invidious/wiki/API).
|
||||||
|
|
||||||
|
## Annotations
|
||||||
|
|
||||||
|
I'm pleased to announce that annotation data is finally available from the roughly 1.4 billion videos archived as part of [this](https://www.reddit.com/r/DataHoarder/comments/aa6czg/youtube_annotation_archive/) project. They are accessible from the Internet Archive [here](https://archive.org/details/youtubeannotations) or as a 355GB torrent, see [here](https://www.reddit.com/r/DataHoarder/comments/b7imx9/youtube_annotation_archive_annotation_data_from/) for more details. A corresponding `/api/v1/annotations/:id` endpoint has been added to Invidious which uses the collection from IA to provide legacy annotations.
|
||||||
|
|
||||||
|
Support for them in the player is possible thanks to [this](https://github.com/afrmtbl/videojs-youtube-annotations) plugin developed by [**@afrmtbl**](https://github.com/afrmtbl). A PR for adding support to the site is available as [#303](https://github.com/omarroth/invidious/pull/303). There's also an [extension](https://github.com/afrmtbl/AnnotationsRestored) for overlaying them on top of the YouTube player (again thanks to [**@afrmtbl**](https://github.com/afrmtbl)), and an [extension](https://tech234a.bitbucket.io/AnnotationsReloaded?src=invidious) for hooking into code still present in the YouTube player itself, developed by [**@tech234a**](https://github.com/tech234a).
|
||||||
|
|
||||||
|
I would recommend reading the [official announcement](https://www.reddit.com/r/DataHoarder/comments/b7imx9/youtube_annotation_archive_annotation_data_from/) for more details. I would like to again thank everyone that helped contribute to this project.
|
||||||
|
|
||||||
|
## Finances
|
||||||
|
|
||||||
|
### Donations
|
||||||
|
|
||||||
|
- [Patreon](https://www.patreon.com/omarroth) : \$42.42
|
||||||
|
- [Liberapay](https://liberapay.com/omarroth) : \$70.11
|
||||||
|
- Crypto : ~\$1.76 (converted from BCH, BTC, BSV)
|
||||||
|
- Total : \$114.29
|
||||||
|
|
||||||
|
### Expenses
|
||||||
|
|
||||||
|
- invidious-load1 (nyc1) : \$10.00 (load balancer)
|
||||||
|
- invidious-update1 (s-1vcpu-1gb) : \$5.00 (updates feeds)
|
||||||
|
- invidious-node1 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node2 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node3 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node4 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node5 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-db1 (s-4vcpu-8gb) : \$40.00 (database)
|
||||||
|
- Total : \$80.00
|
||||||
|
|
||||||
|
This past month the site saw a couple abnormal peaks in traffic, so an additional webserver has been added to match the increased load. The goal on Patreon has been updated to match the above expenses.
|
||||||
|
|
||||||
|
Thanks everyone!
|
||||||
|
|
||||||
|
# 0.15.0 (2019-03-06)
|
||||||
|
|
||||||
|
## Version 0.15.0: Preferences and Channel Playlists
|
||||||
|
|
||||||
|
The project has seen quite a bit of activity this past month. Large focus has been on fixing bugs, but there's still quite a few new features I'm happy to announce. There have been [133 commits](https://github.com/omarroth/invidious/compare/0.14.0...0.15.0) from 15 contributors this past month.
|
||||||
|
|
||||||
|
As a couple miscellaneous changes, a couple [nice screenshots](https://github.com/omarroth/invidious#screenshots) have been added to the README, so folks can see more of what the site has to offer without creating an account.
|
||||||
|
|
||||||
|
The footer has also been cleaned up quite a bit, and now displays the current version, so it's easier to know what features are available from the current instance.
|
||||||
|
|
||||||
|
## For Administrators
|
||||||
|
|
||||||
|
This past month there has been a minor release - `0.14.1` - which fixes a breaking change made by YouTube for their polymer redesign.
|
||||||
|
|
||||||
|
There have been several new features that unfortunately require a database migration. There are migration scripts provided in `config/migrate-scripts`, and the [wiki](https://github.com/omarroth/invidious/wiki/Updating) has instructions for automatically applying them. I'll do my best to keep those changes to a minimum, and expect to see a corresponding script to automatically apply any new changes.
|
||||||
|
|
||||||
|
Administrator preferences have been added with [#312](https://github.com/omarroth/invidious/issues/312), which allows administrators to customize their instance. Administrators can change the order of feed menus, change the default homepage, disable open registration, and several other options. There's a short 'how-to' [here](https://github.com/omarroth/invidious/issues/312#issuecomment-468831842), and the new options are documented [here](https://github.com/omarroth/invidious/wiki/Configuration).
|
||||||
|
|
||||||
|
An `/api/v1/stats` endpoint has been added with [#356](https://github.com/omarroth/invidious/issues/356), which reports the instance version and number of active users. Statistics are disabled by default, and can be enabled in administator preferences. Statistics for the official instance are available [here](https://invidio.us/api/v1/stats?pretty=1).
|
||||||
|
|
||||||
|
## For Developers
|
||||||
|
|
||||||
|
`/api/v1/channels/:ucid` now provides an `autoGenerated` tag, which returns true for [topic channels](https://www.youtube.com/channel/UCE80FOXpJydkkMo-BYoJdEg), and larger [genre channels](https://www.youtube.com/channel/UC-9-kyTW8ZkZNDHQJ6FgpwQ) generated by YouTube. These channels don't have any videos of their own, so `latestVideos` will be empty. It is recommended instead to display a list of playlists generated by YouTube.
|
||||||
|
|
||||||
|
You can now pull a list of playlists from a channel with `/api/v1/channels/playlists/:ucid`. Supported options are documented in the [wiki](https://github.com/omarroth/invidious/wiki/API#get-apiv1channelsplaylistsucid-apiv1channelsucidplaylists). Pagination is handled with a `continuation` token, which is generated on each call. Of note is that auto-generated channels currently have one page of results, and subsequent calls will be empty.
|
||||||
|
|
||||||
|
For quickly pulling the latest 30 videos from a channel, there is now `/api/v1/channels/latest/:ucid`. It is much faster than a call to `/api/v1/channels/:ucid`. It will not convert an author name to a valid ucid automatically, and will not return any extra data about a channel.
|
||||||
|
|
||||||
|
## Preferences
|
||||||
|
|
||||||
|
In addition to administrator preferences mentioned above, you can now change your preferences without an account (see [#42](https://github.com/omarroth/invidious/pull/42)). I think this is quite an improvement to the usability of the site, and is much friendlier to privacy-conscious folks that don't want to make an account. Preferences will be automatically imported to a newly created account.
|
||||||
|
|
||||||
|
Several issues with sorting subscriptions have been fixed, and `/manage_subscriptions` has been sped up significantly. The subscription feed has also seen a bump in performance. Delayed notifications have unfortunately started becoming a problem now that there are more users on the site. Some new changes are currently being tested which should mostly resolve the issue, so expect to see more in the next release.
|
||||||
|
|
||||||
|
## Channel Playlists
|
||||||
|
|
||||||
|
You can now view available playlists from a channel, and [auto-generated channels](https://invidio.us/channel/UC-9-kyTW8ZkZNDHQJ6FgpwQ) are no longer empty. You can sort as you would on YouTube, and all the same functionality should be available. I'm quite pleased to finally have it implemented, since it's currently the only data available from the above mentioned auto-generated channels, and makes it much easier to consume music on the site.
|
||||||
|
|
||||||
|
There's also more discussion on improving Invidious for streaming music in [#304](https://github.com/omarroth/invidious/issues/304), and adding support for music.youtube.com. I would appreciate any thoughts on how to improve that experience, since it's a very large and useful part of YouTube.
|
||||||
|
|
||||||
|
## Finances
|
||||||
|
|
||||||
|
### Donations
|
||||||
|
|
||||||
|
- [Patreon](https://www.patreon.com/omarroth) : \$42.42
|
||||||
|
- [Liberapay](https://liberapay.com/omarroth) : \$30.97
|
||||||
|
- Crypto : ~\$0.00 (converted from BCH, BTC)
|
||||||
|
- Total : \$73.39
|
||||||
|
|
||||||
|
### Expenses
|
||||||
|
|
||||||
|
- invidious-load1 (nyc1) : \$10.00 (load balancer)
|
||||||
|
- invidious-update1 (s-1vcpu-1gb) : \$5.00 (updates feeds)
|
||||||
|
- invidious-node1 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node2 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node3 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-node4 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
|
- invidious-db1 (s-4vcpu-8gb) : \$40.00 (database)
|
||||||
|
- Total : \$75.00
|
||||||
|
|
||||||
|
It's been very humbling to see how fast the project has grown, and I look forward to making the site even better. Thank you everyone.
|
||||||
|
|
||||||
# 0.14.0 (2019-02-06)
|
# 0.14.0 (2019-02-06)
|
||||||
|
|
||||||
## Version 0.14.0: Community
|
## Version 0.14.0: Community
|
||||||
@@ -59,14 +501,14 @@ Organizing this project has unfortunately taken up quite a bit of my time, and I
|
|||||||
|
|
||||||
### Expenses
|
### Expenses
|
||||||
|
|
||||||
invidious-load1 (nyc1) : $10.00 (load balancer)
|
- invidious-load1 (nyc1) : \$10.00 (load balancer)
|
||||||
invidious-update1 (s-1vcpu-1gb) : $5.00 (updates feeds)
|
- invidious-update1 (s-1vcpu-1gb) : \$5.00 (updates feeds)
|
||||||
invidious-node1 (s-1vcpu-1gb) : $5.00 (web server)
|
- invidious-node1 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
invidious-node2 (s-1vcpu-1gb) : $5.00 (web server)
|
- invidious-node2 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
invidious-node3 (s-1vcpu-1gb) : $5.00 (web server)
|
- invidious-node3 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
invidious-node4 (s-1vcpu-1gb) : $5.00 (web server)
|
- invidious-node4 (s-1vcpu-1gb) : \$5.00 (web server)
|
||||||
invidious-db1 (s-4vcpu-8gb) : $40.00 (database)
|
- invidious-db1 (s-4vcpu-8gb) : \$40.00 (database)
|
||||||
Total : $75.00
|
- Total : \$75.00
|
||||||
|
|
||||||
As always I'm grateful for everyone's contributions and support. I'll see you all in March.
|
As always I'm grateful for everyone's contributions and support. I'll see you all in March.
|
||||||
|
|
||||||
|
|||||||
83
README.md
83
README.md
@@ -1,9 +1,11 @@
|
|||||||
# Invidious
|
# Invidious
|
||||||
|
|
||||||
|
[](https://travis-ci.org/omarroth/invidious)
|
||||||
|
|
||||||
## Invidious is an alternative front-end to YouTube
|
## Invidious is an alternative front-end to YouTube
|
||||||
|
|
||||||
- Audio-only mode (and no need to keep window open on mobile)
|
- Audio-only mode (and no need to keep window open on mobile)
|
||||||
- [Open-source](https://github.com/omarroth/invidious) (AGPLv3 licensed)
|
- [Free software](https://github.com/omarroth/invidious) (AGPLv3 licensed)
|
||||||
- No ads
|
- No ads
|
||||||
- No need to create a Google account to save subscriptions
|
- No need to create a Google account to save subscriptions
|
||||||
- Lightweight (homepage is ~4 KB compressed)
|
- Lightweight (homepage is ~4 KB compressed)
|
||||||
@@ -23,16 +25,19 @@
|
|||||||
- Developer [API](https://github.com/omarroth/invidious/wiki/API)
|
- Developer [API](https://github.com/omarroth/invidious/wiki/API)
|
||||||
|
|
||||||
Liberapay: https://liberapay.com/omarroth
|
Liberapay: https://liberapay.com/omarroth
|
||||||
Patreon: https://patreon.com/omarroth
|
|
||||||
BTC: 356DpZyMXu6rYd55Yqzjs29n79kGKWcYrY
|
BTC: 356DpZyMXu6rYd55Yqzjs29n79kGKWcYrY
|
||||||
BCH: qq4ptclkzej5eza6a50et5ggc58hxsq5aylqut2npk
|
BCH: qq4ptclkzej5eza6a50et5ggc58hxsq5aylqut2npk
|
||||||
|
|
||||||
Onion links:
|
## Invidious Instances
|
||||||
|
|
||||||
- kgg2m7yk5aybusll.onion
|
See [Invidious Instances](https://github.com/omarroth/invidious/wiki/Invidious-Instances) for a full list of publicly available instances.
|
||||||
- axqzx4s6s54s32yentfqojs3x5i7faxza6xo3ehd4bzzsg2ii4fv2iid.onion
|
|
||||||
|
|
||||||
[Alternative Invidious instances](https://github.com/omarroth/invidious/wiki/Invidious-Instances)
|
### Official Instances
|
||||||
|
|
||||||
|
- [invidio.us](https://invidio.us) 🇺🇸
|
||||||
|
Issuer: Let's Encrypt, [SSLLabs Verification](https://www.ssllabs.com/ssltest/analyze.html?d=invidio.us)
|
||||||
|
- [kgg2m7yk5aybusll.onion](http://kgg2m7yk5aybusll.onion)
|
||||||
|
- [axqzx4s6s54s32yentfqojs3x5i7faxza6xo3ehd4bzzsg2ii4fv2iid.onion](http://axqzx4s6s54s32yentfqojs3x5i7faxza6xo3ehd4bzzsg2ii4fv2iid.onion)
|
||||||
|
|
||||||
## Screenshots
|
## Screenshots
|
||||||
|
|
||||||
@@ -74,7 +79,7 @@ $ docker-compose build
|
|||||||
|
|
||||||
```bash
|
```bash
|
||||||
# Arch Linux
|
# Arch Linux
|
||||||
$ sudo pacman -S shards crystal imagemagick librsvg postgresql
|
$ sudo pacman -S base-devel shards crystal librsvg postgresql
|
||||||
|
|
||||||
# Ubuntu or Debian
|
# Ubuntu or Debian
|
||||||
# First you have to add the repository to your APT configuration. For easy setup just run in your command line:
|
# First you have to add the repository to your APT configuration. For easy setup just run in your command line:
|
||||||
@@ -83,7 +88,7 @@ $ curl -sSL https://dist.crystal-lang.org/apt/setup.sh | sudo bash
|
|||||||
$ curl -sL "https://keybase.io/crystal/pgp_keys.asc" | sudo apt-key add -
|
$ curl -sL "https://keybase.io/crystal/pgp_keys.asc" | sudo apt-key add -
|
||||||
$ echo "deb https://dist.crystal-lang.org/apt crystal main" | sudo tee /etc/apt/sources.list.d/crystal.list
|
$ echo "deb https://dist.crystal-lang.org/apt crystal main" | sudo tee /etc/apt/sources.list.d/crystal.list
|
||||||
$ sudo apt-get update
|
$ sudo apt-get update
|
||||||
$ sudo apt install crystal libssl-dev libxml2-dev libyaml-dev libgmp-dev libreadline-dev librsvg2-dev postgresql imagemagick libsqlite3-dev
|
$ sudo apt install crystal libssl-dev libxml2-dev libyaml-dev libgmp-dev libreadline-dev postgresql librsvg2-bin libsqlite3-dev
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Add invidious user and clone repository
|
#### Add invidious user and clone repository
|
||||||
@@ -101,14 +106,17 @@ $ exit
|
|||||||
$ sudo systemctl enable postgresql
|
$ sudo systemctl enable postgresql
|
||||||
$ sudo systemctl start postgresql
|
$ sudo systemctl start postgresql
|
||||||
$ sudo -i -u postgres
|
$ sudo -i -u postgres
|
||||||
$ psql -c "CREATE USER kemal WITH PASSWORD 'kemal';"
|
$ psql -c "CREATE USER kemal WITH PASSWORD 'kemal';" # Change 'kemal' here to a stronger password, and update `password` in config/config.yml
|
||||||
$ createdb -O kemal invidious
|
$ createdb -O kemal invidious
|
||||||
$ psql invidious < /home/invidious/invidious/config/sql/channels.sql
|
$ psql invidious kemal < /home/invidious/invidious/config/sql/channels.sql
|
||||||
$ psql invidious < /home/invidious/invidious/config/sql/videos.sql
|
$ psql invidious kemal < /home/invidious/invidious/config/sql/videos.sql
|
||||||
$ psql invidious < /home/invidious/invidious/config/sql/channel_videos.sql
|
$ psql invidious kemal < /home/invidious/invidious/config/sql/channel_videos.sql
|
||||||
$ psql invidious < /home/invidious/invidious/config/sql/users.sql
|
$ psql invidious kemal < /home/invidious/invidious/config/sql/users.sql
|
||||||
$ psql invidious < /home/invidious/invidious/config/sql/session_ids.sql
|
$ psql invidious kemal < /home/invidious/invidious/config/sql/session_ids.sql
|
||||||
$ psql invidious < /home/invidious/invidious/config/sql/nonces.sql
|
$ psql invidious kemal < /home/invidious/invidious/config/sql/nonces.sql
|
||||||
|
$ psql invidious kemal < /home/invidious/invidious/config/sql/annotations.sql
|
||||||
|
$ psql invidious kemal < /home/invidious/invidious/config/sql/playlists.sql
|
||||||
|
$ psql invidious kemal < /home/invidious/invidious/config/sql/playlist_videos.sql
|
||||||
$ exit
|
$ exit
|
||||||
```
|
```
|
||||||
|
|
||||||
@@ -132,25 +140,43 @@ $ sudo systemctl enable invidious.service
|
|||||||
$ sudo systemctl start invidious.service
|
$ sudo systemctl start invidious.service
|
||||||
```
|
```
|
||||||
|
|
||||||
|
#### Logrotate
|
||||||
|
|
||||||
|
```bash
|
||||||
|
$ sudo echo "/home/invidious/invidious/invidious.log {
|
||||||
|
rotate 4
|
||||||
|
weekly
|
||||||
|
notifempty
|
||||||
|
missingok
|
||||||
|
compress
|
||||||
|
minsize 1048576
|
||||||
|
}" | tee /etc/logrotate.d/invidious.logrotate
|
||||||
|
$ sudo chmod 0644 /etc/logrotate.d/invidious.logrotate
|
||||||
|
```
|
||||||
|
|
||||||
### OSX:
|
### OSX:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
# Install dependencies
|
# Install dependencies
|
||||||
$ brew update
|
$ brew update
|
||||||
$ brew install shards crystal-lang postgres imagemagick librsvg
|
$ brew install shards crystal postgres imagemagick librsvg
|
||||||
|
|
||||||
# Clone repository and setup postgres database
|
# Clone repository and setup postgres database
|
||||||
$ git clone https://github.com/omarroth/invidious
|
$ git clone https://github.com/omarroth/invidious
|
||||||
$ cd invidious
|
$ cd invidious
|
||||||
$ brew services start postgresql
|
$ brew services start postgresql
|
||||||
$ psql -c "CREATE ROLE kemal WITH LOGIN PASSWORD 'kemal';"
|
$ psql -c "CREATE ROLE kemal WITH PASSWORD 'kemal';" # Change 'kemal' here to a stronger password, and update `password` in config/config.yml
|
||||||
$ createdb invidious -U kemal
|
$ createdb -O kemal invidious
|
||||||
$ psql invidious < config/sql/channels.sql
|
$ psql invidious kemal < config/sql/channels.sql
|
||||||
$ psql invidious < config/sql/videos.sql
|
$ psql invidious kemal < config/sql/videos.sql
|
||||||
$ psql invidious < config/sql/channel_videos.sql
|
$ psql invidious kemal < config/sql/channel_videos.sql
|
||||||
$ psql invidious < config/sql/users.sql
|
$ psql invidious kemal < config/sql/users.sql
|
||||||
$ psql invidious < config/sql/session_ids.sql
|
$ psql invidious kemal < config/sql/session_ids.sql
|
||||||
$ psql invidious < config/sql/nonces.sql
|
$ psql invidious kemal < config/sql/nonces.sql
|
||||||
|
$ psql invidious kemal < config/sql/annotations.sql
|
||||||
|
$ psql invidious kemal < config/sql/privacy.sql
|
||||||
|
$ psql invidious kemal < config/sql/playlists.sql
|
||||||
|
$ psql invidious kemal < config/sql/playlist_videos.sql
|
||||||
|
|
||||||
# Setup Invidious
|
# Setup Invidious
|
||||||
$ shards update && shards install
|
$ shards update && shards install
|
||||||
@@ -172,15 +198,12 @@ Usage: invidious [arguments]
|
|||||||
--ssl-key-file FILE SSL key file
|
--ssl-key-file FILE SSL key file
|
||||||
--ssl-cert-file FILE SSL certificate file
|
--ssl-cert-file FILE SSL certificate file
|
||||||
-h, --help Shows this help
|
-h, --help Shows this help
|
||||||
-t THREADS, --crawl-threads=THREADS
|
|
||||||
Number of threads for crawling YouTube (default: 0)
|
|
||||||
-c THREADS, --channel-threads=THREADS
|
-c THREADS, --channel-threads=THREADS
|
||||||
Number of threads for refreshing channels (default: 1)
|
Number of threads for refreshing channels (default: 1)
|
||||||
-f THREADS, --feed-threads=THREADS
|
-f THREADS, --feed-threads=THREADS
|
||||||
Number of threads for refreshing feeds (default: 1)
|
Number of threads for refreshing feeds (default: 1)
|
||||||
-v THREADS, --video-threads=THREADS
|
|
||||||
Number of threads for refreshing videos (default: 0)
|
|
||||||
-o OUTPUT, --output=OUTPUT Redirect output (default: STDOUT)
|
-o OUTPUT, --output=OUTPUT Redirect output (default: STDOUT)
|
||||||
|
-v, --version Print version
|
||||||
```
|
```
|
||||||
|
|
||||||
Or for development:
|
Or for development:
|
||||||
@@ -188,6 +211,7 @@ Or for development:
|
|||||||
```bash
|
```bash
|
||||||
$ curl -fsSLo- https://raw.githubusercontent.com/samueleaton/sentry/master/install.cr | crystal eval
|
$ curl -fsSLo- https://raw.githubusercontent.com/samueleaton/sentry/master/install.cr | crystal eval
|
||||||
$ ./sentry
|
$ ./sentry
|
||||||
|
🤖 Your SentryBot is vigilant. beep-boop...
|
||||||
```
|
```
|
||||||
|
|
||||||
## Documentation
|
## Documentation
|
||||||
@@ -201,9 +225,10 @@ $ ./sentry
|
|||||||
## Made with Invidious
|
## Made with Invidious
|
||||||
|
|
||||||
- [FreeTube](https://github.com/FreeTubeApp/FreeTube): An Open Source YouTube app for privacy.
|
- [FreeTube](https://github.com/FreeTubeApp/FreeTube): An Open Source YouTube app for privacy.
|
||||||
- [CloudTube](https://github.com/cloudrac3r/cadencegq): Website featuring pastebin, image host, and YouTube player
|
- [CloudTube](https://cadence.moe/cloudtube/subscriptions): A JS-rich alternate YouTube player
|
||||||
- [PeerTubeify](https://gitlab.com/Ealhad/peertubeify): On YouTube, displays a link to the same video on PeerTube, if it exists.
|
- [PeerTubeify](https://gitlab.com/Ealhad/peertubeify): On YouTube, displays a link to the same video on PeerTube, if it exists.
|
||||||
- [MusicPiped](https://github.com/deep-gaurav/MusicPiped): A materialistic music player that streams music from YouTube.
|
- [MusicPiped](https://github.com/deep-gaurav/MusicPiped): A materialistic music player that streams music from YouTube.
|
||||||
|
- [LapisTube](https://github.com/blubbll/lapis-tube): A fancy and advanced (experimental) YouTube frontend. Combined streams & custom YT features.
|
||||||
|
|
||||||
## Contributing
|
## Contributing
|
||||||
|
|
||||||
|
|||||||
@@ -21,13 +21,16 @@ body {
|
|||||||
color: #f0f0f0;
|
color: #f0f0f0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.pure-form > fieldset > input,
|
input,
|
||||||
.pure-control-group > input,
|
select,
|
||||||
.pure-form > fieldset > select,
|
textarea {
|
||||||
.pure-control-group > select {
|
|
||||||
color: rgba(35, 35, 35, 1);
|
color: rgba(35, 35, 35, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.pure-form input[type="file"] {
|
||||||
|
color: #f0f0f0;
|
||||||
|
}
|
||||||
|
|
||||||
.navbar > .searchbar input {
|
.navbar > .searchbar input {
|
||||||
background-color: inherit;
|
background-color: inherit;
|
||||||
color: inherit;
|
color: inherit;
|
||||||
|
|||||||
@@ -1,3 +1,25 @@
|
|||||||
|
html,
|
||||||
|
body {
|
||||||
|
font-family: BlinkMacSystemFont, -apple-system, "Segoe UI", Roboto, Oxygen,
|
||||||
|
Ubuntu, Cantarell, "Fira Sans", "Droid Sans", "Helvetica Neue", Helvetica,
|
||||||
|
Arial, sans-serif;
|
||||||
|
}
|
||||||
|
|
||||||
|
.deleted {
|
||||||
|
background-color: rgb(255, 0, 0, 0.5);
|
||||||
|
}
|
||||||
|
|
||||||
|
.channel-profile > * {
|
||||||
|
font-size: 1.17em;
|
||||||
|
font-weight: bold;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
|
||||||
|
.channel-profile > img {
|
||||||
|
width: 48px;
|
||||||
|
height: auto;
|
||||||
|
}
|
||||||
|
|
||||||
.channel-owner {
|
.channel-owner {
|
||||||
background-color: #008bec;
|
background-color: #008bec;
|
||||||
color: #fff;
|
color: #fff;
|
||||||
@@ -54,6 +76,7 @@ div {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.loading {
|
.loading {
|
||||||
|
display: inline-block;
|
||||||
animation: spin 2s linear infinite;
|
animation: spin 2s linear infinite;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -76,13 +99,18 @@ a.pure-button-primary:hover {
|
|||||||
}
|
}
|
||||||
|
|
||||||
div.thumbnail {
|
div.thumbnail {
|
||||||
|
padding: 28.125%;
|
||||||
position: relative;
|
position: relative;
|
||||||
|
box-sizing: border-box;
|
||||||
}
|
}
|
||||||
|
|
||||||
img.thumbnail {
|
img.thumbnail {
|
||||||
|
position: absolute;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
left: 0;
|
left: 0;
|
||||||
top: 0;
|
top: 0;
|
||||||
|
object-fit: cover;
|
||||||
}
|
}
|
||||||
|
|
||||||
.length {
|
.length {
|
||||||
@@ -93,9 +121,8 @@ img.thumbnail {
|
|||||||
border-radius: 2px;
|
border-radius: 2px;
|
||||||
padding: 2px;
|
padding: 2px;
|
||||||
font-size: 16px;
|
font-size: 16px;
|
||||||
font-family: sans-serif;
|
right: 0.25em;
|
||||||
right: 0.5em;
|
bottom: -0.75em;
|
||||||
bottom: -0.5em;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.watched {
|
.watched {
|
||||||
@@ -106,7 +133,6 @@ img.thumbnail {
|
|||||||
border-radius: 2px;
|
border-radius: 2px;
|
||||||
padding: 4px 8px 4px 8px;
|
padding: 4px 8px 4px 8px;
|
||||||
font-size: 16px;
|
font-size: 16px;
|
||||||
font-family: sans-serif;
|
|
||||||
left: 0.2em;
|
left: 0.2em;
|
||||||
top: -0.7em;
|
top: -0.7em;
|
||||||
}
|
}
|
||||||
@@ -136,9 +162,12 @@ img.thumbnail {
|
|||||||
|
|
||||||
.navbar .index-link {
|
.navbar .index-link {
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
|
display: inline;
|
||||||
}
|
}
|
||||||
|
|
||||||
.navbar > .searchbar .pure-form input[type="search"] {
|
.navbar > .searchbar .pure-form input[type="search"] {
|
||||||
|
margin-bottom: 1px;
|
||||||
|
|
||||||
border-top: 0;
|
border-top: 0;
|
||||||
border-left: 0;
|
border-left: 0;
|
||||||
border-right: 0;
|
border-right: 0;
|
||||||
@@ -149,16 +178,25 @@ img.thumbnail {
|
|||||||
|
|
||||||
box-shadow: none;
|
box-shadow: none;
|
||||||
|
|
||||||
transition: 0.1s border-bottom;
|
|
||||||
-webkit-appearance: none;
|
-webkit-appearance: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* https://stackoverflow.com/a/55170420 */
|
||||||
|
input[type="search"]::-webkit-search-cancel-button {
|
||||||
|
-webkit-appearance: none;
|
||||||
|
height: 14px;
|
||||||
|
width: 14px;
|
||||||
|
background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB4AAAAeCAYAAAA7MK6iAAAAn0lEQVR42u3UMQrDMBBEUZ9WfQqDmm22EaTyjRMHAlM5K+Y7lb0wnUZPIKHlnutOa+25Z4D++MRBX98MD1V/trSppLKHqj9TTBWKcoUqffbUcbBBEhTjBOV4ja4l4OIAZThEOV6jHO8ARXD+gPPvKMABinGOrnu6gTNUawrcQKNCAQ7QeTxORzle3+sDfjJpPCqhJh7GixZq4rHcc9l5A9qZ+WeBhgEuAAAAAElFTkSuQmCC);
|
||||||
|
background-size: 14px;
|
||||||
|
}
|
||||||
|
|
||||||
.navbar > .searchbar .pure-form fieldset {
|
.navbar > .searchbar .pure-form fieldset {
|
||||||
padding: 0;
|
padding: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* attract focus to the searchbar by adding a subtle transition */
|
/* attract focus to the searchbar by adding a subtle transition */
|
||||||
.navbar > .searchbar .pure-form input[type="search"]:focus {
|
.navbar > .searchbar .pure-form input[type="search"]:focus {
|
||||||
|
margin-bottom: 0px;
|
||||||
border-bottom: 2px solid #aaa;
|
border-bottom: 2px solid #aaa;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -177,6 +215,16 @@ img.thumbnail {
|
|||||||
margin-right: 1em;
|
margin-right: 1em;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@media only screen and (max-aspect-ratio: 16/9) {
|
||||||
|
.player-dimensions.vjs-fluid {
|
||||||
|
padding-top: 46.86% !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
#player-container {
|
||||||
|
padding-bottom: 46.86% !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@media screen and (max-width: 767px) {
|
@media screen and (max-width: 767px) {
|
||||||
.navbar {
|
.navbar {
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
@@ -194,6 +242,11 @@ img.thumbnail {
|
|||||||
.navbar > .searchbar > form {
|
.navbar > .searchbar > form {
|
||||||
width: 60%;
|
width: 60%;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
font-size: 1.25em;
|
||||||
|
margin: 0.42em 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@media screen and (max-width: 320px) {
|
@media screen and (max-width: 320px) {
|
||||||
@@ -203,7 +256,7 @@ img.thumbnail {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Footer
|
* Footer
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@@ -230,13 +283,76 @@ img.thumbnail {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Control Bar */
|
/* Control Bar */
|
||||||
@media screen and (max-width: 480px) {
|
@media screen and (max-width: 640px) {
|
||||||
.video-js .vjs-control-bar,
|
.video-js .vjs-control-bar,
|
||||||
.vjs-menu-button-popup .vjs-menu .vjs-menu-content {
|
.vjs-menu-button-popup .vjs-menu .vjs-menu-content {
|
||||||
overflow: -webkit-paged-x;
|
overflow-x: scroll;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ul.vjs-menu-content::-webkit-scrollbar {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.vjs-user-inactive {
|
||||||
|
cursor: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.video-js .vjs-text-track-display > div > div > div {
|
||||||
|
background-color: rgba(0, 0, 0, 0.75) !important;
|
||||||
|
border-radius: 9px !important;
|
||||||
|
padding: 5px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.vjs-play-control,
|
||||||
|
.vjs-volume-panel,
|
||||||
|
.vjs-current-time,
|
||||||
|
.vjs-time-control,
|
||||||
|
.vjs-duration,
|
||||||
|
.vjs-progress-control,
|
||||||
|
.vjs-remaining-time {
|
||||||
|
order: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
.vjs-captions-button {
|
||||||
|
order: 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
.vjs-quality-selector,
|
||||||
|
.video-js .vjs-http-source-selector {
|
||||||
|
order: 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
.vjs-playback-rate {
|
||||||
|
order: 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
.vjs-share-control {
|
||||||
|
order: 5;
|
||||||
|
}
|
||||||
|
|
||||||
|
.vjs-fullscreen-control {
|
||||||
|
order: 6;
|
||||||
|
}
|
||||||
|
|
||||||
|
.vjs-playback-rate > .vjs-menu {
|
||||||
|
width: 50px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.vjs-control-bar {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: row;
|
||||||
|
scrollbar-width: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.vjs-control-bar::-webkit-scrollbar {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.video-js .vjs-icon-cog {
|
||||||
|
font-size: 18px;
|
||||||
|
}
|
||||||
|
|
||||||
.video-js .vjs-control-bar,
|
.video-js .vjs-control-bar,
|
||||||
.vjs-menu-button-popup .vjs-menu .vjs-menu-content {
|
.vjs-menu-button-popup .vjs-menu .vjs-menu-content {
|
||||||
background-color: rgba(35, 35, 35, 0.75);
|
background-color: rgba(35, 35, 35, 0.75);
|
||||||
@@ -259,6 +375,11 @@ img.thumbnail {
|
|||||||
background-color: rgba(15, 15, 15, 0.5);
|
background-color: rgba(15, 15, 15, 0.5);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fieldset > select,
|
||||||
|
span > select {
|
||||||
|
color: rgba(49, 49, 51, 1);
|
||||||
|
}
|
||||||
|
|
||||||
.video-js .vjs-load-progress,
|
.video-js .vjs-load-progress,
|
||||||
.video-js .vjs-load-progress div {
|
.video-js .vjs-load-progress div {
|
||||||
background: rgba(87, 87, 88, 1);
|
background: rgba(87, 87, 88, 1);
|
||||||
@@ -273,9 +394,16 @@ img.thumbnail {
|
|||||||
background-color: rgba(0, 182, 240, 1);
|
background-color: rgba(0, 182, 240, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Overlay */
|
||||||
|
.video-js .vjs-overlay {
|
||||||
|
background-color: rgba(35, 35, 35, 0.75);
|
||||||
|
color: rgba(255, 255, 255, 1);
|
||||||
|
}
|
||||||
|
|
||||||
/* ProgressBar marker */
|
/* ProgressBar marker */
|
||||||
.vjs-marker {
|
.vjs-marker {
|
||||||
background-color: rgba(255, 255, 255, 1);
|
background-color: rgba(255, 255, 255, 1);
|
||||||
|
z-index: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Big "Play" Button */
|
/* Big "Play" Button */
|
||||||
@@ -304,38 +432,40 @@ img.thumbnail {
|
|||||||
object-fit: cover;
|
object-fit: cover;
|
||||||
}
|
}
|
||||||
|
|
||||||
#player {
|
.player-dimensions.vjs-fluid {
|
||||||
position: absolute;
|
padding-top: 82vh;
|
||||||
left: 0;
|
|
||||||
top: 0;
|
|
||||||
height: 100%;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.player-dimensions.vjs-fluid {
|
video.video-js {
|
||||||
padding-top: 46.86%;
|
position: absolute;
|
||||||
|
height: 100%;
|
||||||
}
|
}
|
||||||
|
|
||||||
#player-container {
|
#player-container {
|
||||||
position: relative;
|
position: relative;
|
||||||
padding-bottom: 46.86%;
|
padding-bottom: 82vh;
|
||||||
margin-left: 1em;
|
|
||||||
margin-right: 1em;
|
|
||||||
height: 0;
|
height: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#progress-container {
|
.pure-control-group label {
|
||||||
width: 100%;
|
word-wrap: normal;
|
||||||
border-radius: 2px;
|
|
||||||
background-color: #a0a0a0;
|
|
||||||
color: rgba(35, 35, 35, 1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#download-progress {
|
.video-js.player-style-invidious {
|
||||||
width: 0%;
|
/* This is already the default */
|
||||||
border-radius: 2px;
|
}
|
||||||
height: 10px;
|
|
||||||
background-color: rgba(0, 182, 240, 1);
|
.video-js.player-style-youtube .vjs-control-bar {
|
||||||
color: #fff;
|
display: flex;
|
||||||
margin-top: 0.5em;
|
flex-direction: row;
|
||||||
margin-bottom: 0.5em;
|
}
|
||||||
|
.video-js.player-style-youtube .vjs-big-play-button {
|
||||||
|
/*
|
||||||
|
Styles copied from video-js.min.css, definition of
|
||||||
|
.vjs-big-play-centered .vjs-big-play-button
|
||||||
|
*/
|
||||||
|
top: 50%;
|
||||||
|
left: 50%;
|
||||||
|
margin-top: -0.81666em;
|
||||||
|
margin-left: -1.5em;
|
||||||
}
|
}
|
||||||
|
|||||||
10
assets/css/embed.css
Normal file
10
assets/css/embed.css
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
#player {
|
||||||
|
position: fixed;
|
||||||
|
right: 0;
|
||||||
|
bottom: 0;
|
||||||
|
min-width: 100%;
|
||||||
|
min-height: 100%;
|
||||||
|
width: auto;
|
||||||
|
height: auto;
|
||||||
|
z-index: -100;
|
||||||
|
}
|
||||||
4
assets/css/grids-responsive-min.css
vendored
4
assets/css/grids-responsive-min.css
vendored
File diff suppressed because one or more lines are too long
4
assets/css/ionicons.min.css
vendored
4
assets/css/ionicons.min.css
vendored
File diff suppressed because one or more lines are too long
@@ -9,8 +9,8 @@ a {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* All links that do not fit with the default color goes here */
|
/* All links that do not fit with the default color goes here */
|
||||||
a > .icon,
|
a:not([data-id]) > .icon,
|
||||||
.pure-u-md-1-5 > .h-box > a[href^="/watch?"],
|
.pure-u-lg-1-5 > .h-box > a[href^="/watch?"],
|
||||||
.playlist-restricted > ol > li > a {
|
.playlist-restricted > ol > li > a {
|
||||||
color: #303030;
|
color: #303030;
|
||||||
}
|
}
|
||||||
|
|||||||
6
assets/css/pure-min.css
vendored
6
assets/css/pure-min.css
vendored
File diff suppressed because one or more lines are too long
2
assets/css/video-js.min.css
vendored
2
assets/css/video-js.min.css
vendored
File diff suppressed because one or more lines are too long
7
assets/css/videojs-http-source-selector.css
Normal file
7
assets/css/videojs-http-source-selector.css
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
/**
|
||||||
|
* videojs-http-source-selector
|
||||||
|
* @version 1.1.6
|
||||||
|
* @copyright 2019 Justin Fujita <Justin@pivotshare.com>
|
||||||
|
* @license MIT
|
||||||
|
*/
|
||||||
|
.video-js.vjs-http-source-selector{display:block}
|
||||||
1
assets/css/videojs-overlay.css
Normal file
1
assets/css/videojs-overlay.css
Normal file
@@ -0,0 +1 @@
|
|||||||
|
.video-js .vjs-overlay{color:#fff;position:absolute;text-align:center}.video-js .vjs-overlay-no-background{max-width:33%}.video-js .vjs-overlay-background{background-color:#646464;background-color:rgba(255,255,255,0.4);border-radius:3px;padding:10px;width:33%}.video-js .vjs-overlay-top-left{top:5px;left:5px}.video-js .vjs-overlay-top{left:50%;margin-left:-16.5%;top:5px}.video-js .vjs-overlay-top-right{right:5px;top:5px}.video-js .vjs-overlay-right{right:5px;top:50%;transform:translateY(-50%)}.video-js .vjs-overlay-bottom-right{bottom:3.5em;right:5px}.video-js .vjs-overlay-bottom{bottom:3.5em;left:50%;margin-left:-16.5%}.video-js .vjs-overlay-bottom-left{bottom:3.5em;left:5px}.video-js .vjs-overlay-left{left:5px;top:50%;transform:translateY(-50%)}.video-js .vjs-overlay-center{left:50%;margin-left:-16.5%;top:50%;transform:translateY(-50%)}.video-js .vjs-no-flex .vjs-overlay-left,.video-js .vjs-no-flex .vjs-overlay-center,.video-js .vjs-no-flex .vjs-overlay-right{margin-top:-15px}
|
||||||
@@ -1,7 +1,7 @@
|
|||||||
/**
|
/**
|
||||||
* videojs-share
|
* videojs-share
|
||||||
* @version 2.0.1
|
* @version 3.2.1
|
||||||
* @copyright 2018 Mikhail Khazov <mkhazov.work@gmail.com>
|
* @copyright 2019 Mikhail Khazov <mkhazov.work@gmail.com>
|
||||||
* @license MIT
|
* @license MIT
|
||||||
*/
|
*/
|
||||||
.video-js.vjs-videojs-share_open .vjs-modal-dialog .vjs-modal-dialog-content{display:flex;align-items:center;padding:0;background-image:linear-gradient(to bottom, rgba(0,0,0,0.77), rgba(0,0,0,0.75))}.video-js.vjs-videojs-share_open .vjs-modal-dialog .vjs-close-button{position:absolute;right:0;top:5px;width:30px;height:30px;color:#fff;cursor:pointer;opacity:0.9;transition:opacity 0.25s ease-out}.video-js.vjs-videojs-share_open .vjs-modal-dialog .vjs-close-button:before{content:'×';font-size:20px;line-height:15px}.video-js.vjs-videojs-share_open .vjs-modal-dialog .vjs-close-button:hover{opacity:1}.video-js .vjs-share{display:flex;flex-direction:column;justify-content:space-around;align-items:center;width:100%;height:100%;max-height:400px}.video-js .vjs-share__top,.video-js .vjs-share__middle,.video-js .vjs-share__bottom{display:flex}.video-js .vjs-share__top,.video-js .vjs-share__middle{flex-direction:column;justify-content:space-between}.video-js .vjs-share__middle{padding:0 25px}.video-js .vjs-share__title{align-self:center;font-size:22px;color:#fff}.video-js .vjs-share__subtitle{width:100%;margin:0 auto 12px;font-size:16px;color:#fff;opacity:0.7}.video-js .vjs-share__short-link-wrapper{position:relative;display:block;width:100%;height:40px;margin:0 auto;margin-bottom:15px;border:0;color:rgba(255,255,255,0.65);background-color:#363636;outline:none;overflow:hidden;flex-shrink:0}.video-js .vjs-share__short-link{display:block;width:100%;height:100%;padding:0 40px 0 15px;border:0;color:rgba(255,255,255,0.65);background-color:#363636;outline:none}.video-js .vjs-share__btn{position:absolute;right:0;bottom:0;height:40px;width:40px;display:flex;align-items:center;padding:0 11px;border:0;color:#fff;background-color:#2e2e2e;background-size:18px 19px;background-position:center;background-repeat:no-repeat;cursor:pointer;outline:none;transition:width 0.3s ease-out, padding 0.3s ease-out}.video-js .vjs-share__btn svg{flex-shrink:0}.video-js .vjs-share__btn span{position:relative;padding-left:10px;opacity:0;transition:opacity 0.3s ease-out}.video-js .vjs-share__btn:hover{justify-content:center;width:100%;padding:0 40px;background-image:none}.video-js .vjs-share__btn:hover span{opacity:1}.video-js .vjs-share__socials{display:flex;flex-wrap:wrap;justify-content:center;align-content:flex-start;transition:width 0.3s ease-out, height 0.3s ease-out}.video-js .vjs-share__social{display:flex;justify-content:center;align-items:center;flex-shrink:0;width:32px;height:32px;margin-right:6px;margin-bottom:6px;cursor:pointer;font-size:8px;transition:transform 0.3s ease-out, filter 0.2s ease-out;border:none;outline:none}.video-js .vjs-share__social:hover{filter:brightness(115%)}.video-js .vjs-share__social svg{width:100%;max-height:24px}.video-js .vjs-share__social_vk{background-color:#5d7294}.video-js .vjs-share__social_ok{background-color:#ed7c20}.video-js .vjs-share__social_mail{background-color:#134785}.video-js .vjs-share__social_tw{background-color:#76aaeb}.video-js .vjs-share__social_reddit{background-color:#ff4500}.video-js .vjs-share__social_fbFeed{background-color:#475995}.video-js .vjs-share__social_messenger{background-color:#0084ff}.video-js .vjs-share__social_gp{background-color:#d53f35}.video-js .vjs-share__social_linkedin{background-color:#0077b5}.video-js .vjs-share__social_viber{background-color:#766db5}.video-js .vjs-share__social_telegram{background-color:#4bb0e2}.video-js .vjs-share__social_whatsapp{background-color:#78c870}.video-js .vjs-share__bottom{justify-content:center}@media (max-height: 220px){.video-js .vjs-share .hidden-xs{display:none}}@media (max-height: 350px){.video-js .vjs-share .hidden-sm{display:none}}@media (min-height: 400px){.video-js .vjs-share__title{margin-bottom:15px}.video-js .vjs-share__short-link-wrapper{margin-bottom:30px}}@media (min-width: 320px){.video-js.vjs-videojs-share_open .vjs-modal-dialog .vjs-close-button{right:5px;top:10px}}@media (min-width: 660px){.video-js.vjs-videojs-share_open .vjs-modal-dialog .vjs-close-button{right:20px;top:20px}.video-js .vjs-share__social{width:40px;height:40px}}
|
.video-js.vjs-videojs-share_open .vjs-modal-dialog .vjs-modal-dialog-content{display:flex;align-items:center;padding:0;background-image:linear-gradient(to bottom, rgba(0,0,0,0.77), rgba(0,0,0,0.75))}.video-js.vjs-videojs-share_open .vjs-modal-dialog .vjs-close-button{position:absolute;right:0;top:5px;width:30px;height:30px;color:#fff;cursor:pointer;opacity:0.9;transition:opacity 0.25s ease-out}.video-js.vjs-videojs-share_open .vjs-modal-dialog .vjs-close-button:before{content:'×';font-size:20px;line-height:15px}.video-js.vjs-videojs-share_open .vjs-modal-dialog .vjs-close-button:hover{opacity:1}.video-js .vjs-share{display:flex;flex-direction:column;justify-content:space-around;align-items:center;width:100%;height:100%;max-height:400px}.video-js .vjs-share__top,.video-js .vjs-share__middle,.video-js .vjs-share__bottom{display:flex}.video-js .vjs-share__top,.video-js .vjs-share__middle{flex-direction:column;justify-content:space-between}.video-js .vjs-share__middle{padding:0 25px}.video-js .vjs-share__title{align-self:center;font-size:22px;color:#fff}.video-js .vjs-share__subtitle{width:100%;margin:0 auto 12px;font-size:16px;color:#fff;opacity:0.7}.video-js .vjs-share__short-link-wrapper{position:relative;display:block;width:100%;height:40px;margin:0 auto;margin-bottom:15px;border:0;color:rgba(255,255,255,0.65);background-color:#363636;outline:none;overflow:hidden;flex-shrink:0}.video-js .vjs-share__short-link{display:block;width:100%;height:100%;padding:0 40px 0 15px;border:0;color:rgba(255,255,255,0.65);background-color:#363636;outline:none}.video-js .vjs-share__btn{position:absolute;right:0;bottom:0;height:40px;width:40px;display:flex;align-items:center;padding:0 11px;border:0;color:#fff;background-color:#2e2e2e;background-size:18px 19px;background-position:center;background-repeat:no-repeat;cursor:pointer;outline:none;transition:width 0.3s ease-out, padding 0.3s ease-out}.video-js .vjs-share__btn svg{flex-shrink:0}.video-js .vjs-share__btn span{position:relative;padding-left:10px;opacity:0;transition:opacity 0.3s ease-out}.video-js .vjs-share__btn:hover{justify-content:center;width:100%;padding:0 40px;background-image:none}.video-js .vjs-share__btn:hover span{opacity:1}.video-js .vjs-share__socials{display:flex;flex-wrap:wrap;justify-content:center;align-content:flex-start;transition:width 0.3s ease-out, height 0.3s ease-out}.video-js .vjs-share__social{display:flex;justify-content:center;align-items:center;flex-shrink:0;width:32px;height:32px;margin-right:6px;margin-bottom:6px;cursor:pointer;font-size:8px;transition:transform 0.3s ease-out, filter 0.2s ease-out;border:none;outline:none}.video-js .vjs-share__social:hover{filter:brightness(115%)}.video-js .vjs-share__social svg{overflow:visible;max-height:24px}.video-js .vjs-share__social_vk{background-color:#5d7294}.video-js .vjs-share__social_ok{background-color:#ed7c20}.video-js .vjs-share__social_mail,.video-js .vjs-share__social_email{background-color:#134785}.video-js .vjs-share__social_tw{background-color:#76aaeb}.video-js .vjs-share__social_reddit{background-color:#ff4500}.video-js .vjs-share__social_fbFeed{background-color:#475995}.video-js .vjs-share__social_messenger{background-color:#0084ff}.video-js .vjs-share__social_gp{background-color:#d53f35}.video-js .vjs-share__social_linkedin{background-color:#0077b5}.video-js .vjs-share__social_viber{background-color:#766db5}.video-js .vjs-share__social_telegram{background-color:#4bb0e2}.video-js .vjs-share__social_whatsapp{background-color:#78c870}.video-js .vjs-share__bottom{justify-content:center}@media (max-height: 220px){.video-js .vjs-share .hidden-xs{display:none}}@media (max-height: 350px){.video-js .vjs-share .hidden-sm{display:none}}@media (min-height: 400px){.video-js .vjs-share__title{margin-bottom:15px}.video-js .vjs-share__short-link-wrapper{margin-bottom:30px}}@media (min-width: 320px){.video-js.vjs-videojs-share_open .vjs-modal-dialog .vjs-close-button{right:5px;top:10px}}@media (min-width: 660px){.video-js.vjs-videojs-share_open .vjs-modal-dialog .vjs-close-button{right:20px;top:20px}.video-js .vjs-share__social{width:40px;height:40px}}
|
||||||
|
|||||||
7
assets/css/videojs-vtt-thumbnails.css
Normal file
7
assets/css/videojs-vtt-thumbnails.css
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
/**
|
||||||
|
* videojs-vtt-thumbnails
|
||||||
|
* @version 0.0.13
|
||||||
|
* @copyright 2019 Chris Boustead <chris@forgemotion.com>
|
||||||
|
* @license MIT
|
||||||
|
*/
|
||||||
|
.video-js.vjs-vtt-thumbnails{display:block}.video-js .vjs-vtt-thumbnail-display{position:absolute;bottom:85%;pointer-events:none;box-shadow:0 0 7px rgba(0,0,0,0.6)}
|
||||||
1
assets/css/videojs-youtube-annotations.min.css
vendored
Normal file
1
assets/css/videojs-youtube-annotations.min.css
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
.__cxt-ar-annotations-container__{--annotation-close-size: 20px;position:absolute;width:100%;height:100%;top:0;left:0;pointer-events:none;overflow:hidden}.__cxt-ar-annotation__{position:absolute;box-sizing:border-box;font-family:Arial,sans-serif;color:#fff;z-index:20;pointer-events:auto}.__cxt-ar-annotation__ span{position:absolute;left:0;top:0;overflow:hidden;word-wrap:break-word;white-space:pre-wrap;pointer-events:none;box-sizing:border-box;padding:2%;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.__cxt-ar-annotation-close__{display:none;position:absolute;width:var(--annotation-close-size);height:var(--annotation-close-size);cursor:pointer;right:calc(var(--annotation-close-size)/-1.8);top:calc(var(--annotation-close-size)/-1.8);z-index:1}.__cxt-ar-annotation__:hover:not([hidden]):not([data-ar-closed]) .__cxt-ar-annotation-close__{display:block}.__cxt-ar-annotation__[hidden]{display:none!important}.__cxt-ar-annotation__[data-ar-type=highlight]{border:1px solid rgba(255,255,255,.1);background-color:transparent}.__cxt-ar-annotation__[data-ar-type=highlight]:hover{border:1px solid rgba(255,255,255,.5);background-color:transparent}.__cxt-ar-annotation__ svg{pointer-events:all}
|
||||||
Binary file not shown.
@@ -1,13 +1,13 @@
|
|||||||
<?xml version="1.0" standalone="no"?>
|
<?xml version="1.0" standalone="no"?>
|
||||||
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd" >
|
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd" >
|
||||||
<!--
|
<!--
|
||||||
2018-6-14: Created with FontForge (http://fontforge.org)
|
2019-5-24: Created with FontForge (http://fontforge.org)
|
||||||
-->
|
-->
|
||||||
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1">
|
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1">
|
||||||
<metadata>
|
<metadata>
|
||||||
Created by FontForge 20160407 at Thu Jun 14 08:50:34 2018
|
Created by FontForge 20160407 at Fri May 24 15:45:40 2019
|
||||||
By Adam Bradley
|
By Adam Bradley
|
||||||
Copyright (c) 2018, Adam Bradley
|
Copyright (c) 2019, Adam Bradley
|
||||||
</metadata>
|
</metadata>
|
||||||
<defs>
|
<defs>
|
||||||
<font id="Ionicons" horiz-adv-x="416" >
|
<font id="Ionicons" horiz-adv-x="416" >
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 305 KiB After Width: | Height: | Size: 305 KiB |
Binary file not shown.
Binary file not shown.
Binary file not shown.
103
assets/js/community.js
Normal file
103
assets/js/community.js
Normal file
@@ -0,0 +1,103 @@
|
|||||||
|
var community_data = JSON.parse(document.getElementById('community_data').innerHTML);
|
||||||
|
|
||||||
|
String.prototype.supplant = function (o) {
|
||||||
|
return this.replace(/{([^{}]*)}/g, function (a, b) {
|
||||||
|
var r = o[b];
|
||||||
|
return typeof r === 'string' || typeof r === 'number' ? r : a;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function hide_youtube_replies(event) {
|
||||||
|
var target = event.target;
|
||||||
|
|
||||||
|
sub_text = target.getAttribute('data-inner-text');
|
||||||
|
inner_text = target.getAttribute('data-sub-text');
|
||||||
|
|
||||||
|
body = target.parentNode.parentNode.children[1];
|
||||||
|
body.style.display = 'none';
|
||||||
|
|
||||||
|
target.innerHTML = sub_text;
|
||||||
|
target.onclick = show_youtube_replies;
|
||||||
|
target.setAttribute('data-inner-text', inner_text);
|
||||||
|
target.setAttribute('data-sub-text', sub_text);
|
||||||
|
}
|
||||||
|
|
||||||
|
function show_youtube_replies(event) {
|
||||||
|
var target = event.target;
|
||||||
|
|
||||||
|
sub_text = target.getAttribute('data-inner-text');
|
||||||
|
inner_text = target.getAttribute('data-sub-text');
|
||||||
|
|
||||||
|
body = target.parentNode.parentNode.children[1];
|
||||||
|
body.style.display = '';
|
||||||
|
|
||||||
|
target.innerHTML = sub_text;
|
||||||
|
target.onclick = hide_youtube_replies;
|
||||||
|
target.setAttribute('data-inner-text', inner_text);
|
||||||
|
target.setAttribute('data-sub-text', sub_text);
|
||||||
|
}
|
||||||
|
|
||||||
|
function number_with_separator(val) {
|
||||||
|
while (/(\d+)(\d{3})/.test(val.toString())) {
|
||||||
|
val = val.toString().replace(/(\d+)(\d{3})/, '$1' + ',' + '$2');
|
||||||
|
}
|
||||||
|
return val;
|
||||||
|
}
|
||||||
|
|
||||||
|
function get_youtube_replies(target, load_more) {
|
||||||
|
var continuation = target.getAttribute('data-continuation');
|
||||||
|
|
||||||
|
var body = target.parentNode.parentNode;
|
||||||
|
var fallback = body.innerHTML;
|
||||||
|
body.innerHTML =
|
||||||
|
'<h3 style="text-align:center"><div class="loading"><i class="icon ion-ios-refresh"></i></div></h3>';
|
||||||
|
|
||||||
|
var url = '/api/v1/channels/comments/' + community_data.ucid +
|
||||||
|
'?format=html' +
|
||||||
|
'&hl=' + community_data.preferences.locale +
|
||||||
|
'&thin_mode=' + community_data.preferences.thin_mode +
|
||||||
|
'&continuation=' + continuation;
|
||||||
|
var xhr = new XMLHttpRequest();
|
||||||
|
xhr.responseType = 'json';
|
||||||
|
xhr.timeout = 10000;
|
||||||
|
xhr.open('GET', url, true);
|
||||||
|
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
if (xhr.readyState == 4) {
|
||||||
|
if (xhr.status == 200) {
|
||||||
|
if (load_more) {
|
||||||
|
body = body.parentNode.parentNode;
|
||||||
|
body.removeChild(body.lastElementChild);
|
||||||
|
body.innerHTML += xhr.response.contentHtml;
|
||||||
|
} else {
|
||||||
|
body.removeChild(body.lastElementChild);
|
||||||
|
|
||||||
|
var p = document.createElement('p');
|
||||||
|
var a = document.createElement('a');
|
||||||
|
p.appendChild(a);
|
||||||
|
|
||||||
|
a.href = 'javascript:void(0)';
|
||||||
|
a.onclick = hide_youtube_replies;
|
||||||
|
a.setAttribute('data-sub-text', community_data.hide_replies_text);
|
||||||
|
a.setAttribute('data-inner-text', community_data.show_replies_text);
|
||||||
|
a.innerText = community_data.hide_replies_text;
|
||||||
|
|
||||||
|
var div = document.createElement('div');
|
||||||
|
div.innerHTML = xhr.response.contentHtml;
|
||||||
|
|
||||||
|
body.appendChild(p);
|
||||||
|
body.appendChild(div);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
body.innerHTML = fallback;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.ontimeout = function () {
|
||||||
|
console.log('Pulling comments failed.');
|
||||||
|
body.innerHTML = fallback;
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.send();
|
||||||
|
}
|
||||||
29
assets/js/dash.mediaplayer.min.js
vendored
29
assets/js/dash.mediaplayer.min.js
vendored
File diff suppressed because one or more lines are too long
104
assets/js/embed.js
Normal file
104
assets/js/embed.js
Normal file
@@ -0,0 +1,104 @@
|
|||||||
|
var video_data = JSON.parse(document.getElementById('video_data').innerHTML);
|
||||||
|
|
||||||
|
function get_playlist(plid, retries) {
|
||||||
|
if (retries == undefined) retries = 5;
|
||||||
|
|
||||||
|
if (retries <= 0) {
|
||||||
|
console.log('Failed to pull playlist');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (plid.startsWith('RD')) {
|
||||||
|
var plid_url = '/api/v1/mixes/' + plid +
|
||||||
|
'?continuation=' + video_data.id +
|
||||||
|
'&format=html&hl=' + video_data.preferences.locale;
|
||||||
|
} else {
|
||||||
|
var plid_url = '/api/v1/playlists/' + plid +
|
||||||
|
'?index=' + video_data.index +
|
||||||
|
'&continuation' + video_data.id +
|
||||||
|
'&format=html&hl=' + video_data.preferences.locale;
|
||||||
|
}
|
||||||
|
|
||||||
|
var xhr = new XMLHttpRequest();
|
||||||
|
xhr.responseType = 'json';
|
||||||
|
xhr.timeout = 10000;
|
||||||
|
xhr.open('GET', plid_url, true);
|
||||||
|
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
if (xhr.readyState === 4) {
|
||||||
|
if (xhr.status === 200) {
|
||||||
|
if (xhr.response.nextVideo) {
|
||||||
|
player.on('ended', function () {
|
||||||
|
var url = new URL('https://example.com/embed/' + xhr.response.nextVideo);
|
||||||
|
|
||||||
|
if (video_data.params.autoplay || video_data.params.continue_autoplay) {
|
||||||
|
url.searchParams.set('autoplay', '1');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (video_data.params.listen !== video_data.preferences.listen) {
|
||||||
|
url.searchParams.set('listen', video_data.params.listen);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (video_data.params.speed !== video_data.preferences.speed) {
|
||||||
|
url.searchParams.set('speed', video_data.params.speed);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (video_data.params.local !== video_data.preferences.local) {
|
||||||
|
url.searchParams.set('local', video_data.params.local);
|
||||||
|
}
|
||||||
|
|
||||||
|
url.searchParams.set('list', plid);
|
||||||
|
if (!plid.startsWith('RD')) {
|
||||||
|
url.searchParams.set('index', xhr.response.index);
|
||||||
|
}
|
||||||
|
location.assign(url.pathname + url.search);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.onerror = function () {
|
||||||
|
console.log('Pulling playlist failed... ' + retries + '/5');
|
||||||
|
setTimeout(function () { get_playlist(plid, retries - 1) }, 1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.ontimeout = function () {
|
||||||
|
console.log('Pulling playlist failed... ' + retries + '/5');
|
||||||
|
get_playlist(plid, retries - 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.send();
|
||||||
|
}
|
||||||
|
|
||||||
|
window.addEventListener('load', function (e) {
|
||||||
|
if (video_data.plid) {
|
||||||
|
get_playlist(video_data.plid);
|
||||||
|
} else if (video_data.video_series) {
|
||||||
|
player.on('ended', function () {
|
||||||
|
var url = new URL('https://example.com/embed/' + video_data.video_series.shift());
|
||||||
|
|
||||||
|
if (video_data.params.autoplay || video_data.params.continue_autoplay) {
|
||||||
|
url.searchParams.set('autoplay', '1');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (video_data.params.listen !== video_data.preferences.listen) {
|
||||||
|
url.searchParams.set('listen', video_data.params.listen);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (video_data.params.speed !== video_data.preferences.speed) {
|
||||||
|
url.searchParams.set('speed', video_data.params.speed);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (video_data.params.local !== video_data.preferences.local) {
|
||||||
|
url.searchParams.set('local', video_data.params.local);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (video_data.video_series.length !== 0) {
|
||||||
|
url.searchParams.set('playlist', video_data.video_series.join(','))
|
||||||
|
}
|
||||||
|
|
||||||
|
location.assign(url.pathname + url.search);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
3
assets/js/global.js
Normal file
3
assets/js/global.js
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
// Disable Web Workers. Fixes Video.js CSP violation (created by `new Worker(objURL)`):
|
||||||
|
// Refused to create a worker from 'blob:http://host/id' because it violates the following Content Security Policy directive: "worker-src 'self'".
|
||||||
|
window.Worker = undefined;
|
||||||
144
assets/js/handlers.js
Normal file
144
assets/js/handlers.js
Normal file
@@ -0,0 +1,144 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
(function () {
|
||||||
|
var n2a = function (n) { return Array.prototype.slice.call(n); };
|
||||||
|
|
||||||
|
var video_player = document.getElementById('player_html5_api');
|
||||||
|
if (video_player) {
|
||||||
|
video_player.onmouseenter = function () { video_player['data-title'] = video_player['title']; video_player['title'] = ''; };
|
||||||
|
video_player.onmouseleave = function () { video_player['title'] = video_player['data-title']; video_player['data-title'] = ''; };
|
||||||
|
video_player.oncontextmenu = function () { video_player['title'] = video_player['data-title']; };
|
||||||
|
}
|
||||||
|
|
||||||
|
// For dynamically inserted elements
|
||||||
|
document.addEventListener('click', function (e) {
|
||||||
|
if (!e || !e.target) { return; }
|
||||||
|
e = e.target;
|
||||||
|
var handler_name = e.getAttribute('data-onclick');
|
||||||
|
switch (handler_name) {
|
||||||
|
case 'jump_to_time':
|
||||||
|
var time = e.getAttribute('data-jump-time');
|
||||||
|
player.currentTime(time);
|
||||||
|
break;
|
||||||
|
case 'get_youtube_replies':
|
||||||
|
var load_more = e.getAttribute('data-load-more') !== null;
|
||||||
|
get_youtube_replies(e, load_more);
|
||||||
|
break;
|
||||||
|
case 'toggle_parent':
|
||||||
|
toggle_parent(e);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
n2a(document.querySelectorAll('[data-mouse="switch_classes"]')).forEach(function (e) {
|
||||||
|
var classes = e.getAttribute('data-switch-classes').split(',');
|
||||||
|
var ec = classes[0];
|
||||||
|
var lc = classes[1];
|
||||||
|
var onoff = function (on, off) {
|
||||||
|
var cs = e.getAttribute('class');
|
||||||
|
cs = cs.split(off).join(on);
|
||||||
|
e.setAttribute('class', cs);
|
||||||
|
};
|
||||||
|
e.onmouseenter = function () { onoff(ec, lc); };
|
||||||
|
e.onmouseleave = function () { onoff(lc, ec); };
|
||||||
|
});
|
||||||
|
|
||||||
|
n2a(document.querySelectorAll('[data-onsubmit="return_false"]')).forEach(function (e) {
|
||||||
|
e.onsubmit = function () { return false; };
|
||||||
|
});
|
||||||
|
|
||||||
|
n2a(document.querySelectorAll('[data-onclick="mark_watched"]')).forEach(function (e) {
|
||||||
|
e.onclick = function () { mark_watched(e); };
|
||||||
|
});
|
||||||
|
n2a(document.querySelectorAll('[data-onclick="mark_unwatched"]')).forEach(function (e) {
|
||||||
|
e.onclick = function () { mark_unwatched(e); };
|
||||||
|
});
|
||||||
|
n2a(document.querySelectorAll('[data-onclick="add_playlist_video"]')).forEach(function (e) {
|
||||||
|
e.onclick = function () { add_playlist_video(e); };
|
||||||
|
});
|
||||||
|
n2a(document.querySelectorAll('[data-onclick="add_playlist_item"]')).forEach(function (e) {
|
||||||
|
e.onclick = function () { add_playlist_item(e); };
|
||||||
|
});
|
||||||
|
n2a(document.querySelectorAll('[data-onclick="remove_playlist_item"]')).forEach(function (e) {
|
||||||
|
e.onclick = function () { remove_playlist_item(e); };
|
||||||
|
});
|
||||||
|
n2a(document.querySelectorAll('[data-onclick="revoke_token"]')).forEach(function (e) {
|
||||||
|
e.onclick = function () { revoke_token(e); };
|
||||||
|
});
|
||||||
|
n2a(document.querySelectorAll('[data-onclick="remove_subscription"]')).forEach(function (e) {
|
||||||
|
e.onclick = function () { remove_subscription(e); };
|
||||||
|
});
|
||||||
|
n2a(document.querySelectorAll('[data-onclick="notification_requestPermission"]')).forEach(function (e) {
|
||||||
|
e.onclick = function () { Notification.requestPermission(); };
|
||||||
|
});
|
||||||
|
|
||||||
|
n2a(document.querySelectorAll('[data-onrange="update_volume_value"]')).forEach(function (e) {
|
||||||
|
var cb = function () { update_volume_value(e); }
|
||||||
|
e.oninput = cb;
|
||||||
|
e.onchange = cb;
|
||||||
|
});
|
||||||
|
|
||||||
|
function update_volume_value(element) {
|
||||||
|
document.getElementById('volume-value').innerText = element.value;
|
||||||
|
}
|
||||||
|
|
||||||
|
function revoke_token(target) {
|
||||||
|
var row = target.parentNode.parentNode.parentNode.parentNode.parentNode;
|
||||||
|
row.style.display = 'none';
|
||||||
|
var count = document.getElementById('count');
|
||||||
|
count.innerText = count.innerText - 1;
|
||||||
|
|
||||||
|
var referer = window.encodeURIComponent(document.location.href);
|
||||||
|
var url = '/token_ajax?action_revoke_token=1&redirect=false' +
|
||||||
|
'&referer=' + referer +
|
||||||
|
'&session=' + target.getAttribute('data-session');
|
||||||
|
var xhr = new XMLHttpRequest();
|
||||||
|
xhr.responseType = 'json';
|
||||||
|
xhr.timeout = 10000;
|
||||||
|
xhr.open('POST', url, true);
|
||||||
|
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
|
||||||
|
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
if (xhr.readyState == 4) {
|
||||||
|
if (xhr.status != 200) {
|
||||||
|
count.innerText = parseInt(count.innerText) + 1;
|
||||||
|
row.style.display = '';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var csrf_token = target.parentNode.querySelector('input[name="csrf_token"]').value;
|
||||||
|
xhr.send('csrf_token=' + csrf_token);
|
||||||
|
}
|
||||||
|
|
||||||
|
function remove_subscription(target) {
|
||||||
|
var row = target.parentNode.parentNode.parentNode.parentNode.parentNode;
|
||||||
|
row.style.display = 'none';
|
||||||
|
var count = document.getElementById('count');
|
||||||
|
count.innerText = count.innerText - 1;
|
||||||
|
|
||||||
|
var referer = window.encodeURIComponent(document.location.href);
|
||||||
|
var url = '/subscription_ajax?action_remove_subscriptions=1&redirect=false' +
|
||||||
|
'&referer=' + referer +
|
||||||
|
'&c=' + target.getAttribute('data-ucid');
|
||||||
|
var xhr = new XMLHttpRequest();
|
||||||
|
xhr.responseType = 'json';
|
||||||
|
xhr.timeout = 10000;
|
||||||
|
xhr.open('POST', url, true);
|
||||||
|
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
|
||||||
|
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
if (xhr.readyState == 4) {
|
||||||
|
if (xhr.status != 200) {
|
||||||
|
count.innerText = parseInt(count.innerText) + 1;
|
||||||
|
row.style.display = '';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var csrf_token = target.parentNode.querySelector('input[name="csrf_token"]').value;
|
||||||
|
xhr.send('csrf_token=' + csrf_token);
|
||||||
|
}
|
||||||
|
})();
|
||||||
143
assets/js/notifications.js
Normal file
143
assets/js/notifications.js
Normal file
@@ -0,0 +1,143 @@
|
|||||||
|
var notification_data = JSON.parse(document.getElementById('notification_data').innerHTML);
|
||||||
|
|
||||||
|
var notifications, delivered;
|
||||||
|
|
||||||
|
function get_subscriptions(callback, retries) {
|
||||||
|
if (retries == undefined) retries = 5;
|
||||||
|
|
||||||
|
if (retries <= 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var xhr = new XMLHttpRequest();
|
||||||
|
xhr.responseType = 'json';
|
||||||
|
xhr.timeout = 10000;
|
||||||
|
xhr.open('GET', '/api/v1/auth/subscriptions?fields=authorId', true);
|
||||||
|
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
if (xhr.readyState === 4) {
|
||||||
|
if (xhr.status === 200) {
|
||||||
|
subscriptions = xhr.response;
|
||||||
|
callback(subscriptions);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.onerror = function () {
|
||||||
|
console.log('Pulling subscriptions failed... ' + retries + '/5');
|
||||||
|
setTimeout(function () { get_subscriptions(callback, retries - 1) }, 1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.ontimeout = function () {
|
||||||
|
console.log('Pulling subscriptions failed... ' + retries + '/5');
|
||||||
|
get_subscriptions(callback, retries - 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.send();
|
||||||
|
}
|
||||||
|
|
||||||
|
function create_notification_stream(subscriptions) {
|
||||||
|
notifications = new SSE(
|
||||||
|
'/api/v1/auth/notifications?fields=videoId,title,author,authorId,publishedText,published,authorThumbnails,liveNow', {
|
||||||
|
withCredentials: true,
|
||||||
|
payload: 'topics=' + subscriptions.map(function (subscription) { return subscription.authorId }).join(','),
|
||||||
|
headers: { 'Content-Type': 'application/x-www-form-urlencoded' }
|
||||||
|
});
|
||||||
|
delivered = [];
|
||||||
|
|
||||||
|
var start_time = Math.round(new Date() / 1000);
|
||||||
|
|
||||||
|
notifications.onmessage = function (event) {
|
||||||
|
if (!event.id) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var notification = JSON.parse(event.data);
|
||||||
|
console.log('Got notification:', notification);
|
||||||
|
|
||||||
|
if (start_time < notification.published && !delivered.includes(notification.videoId)) {
|
||||||
|
if (Notification.permission === 'granted') {
|
||||||
|
var system_notification =
|
||||||
|
new Notification((notification.liveNow ? notification_data.live_now_text : notification_data.upload_text).replace('`x`', notification.author), {
|
||||||
|
body: notification.title,
|
||||||
|
icon: '/ggpht' + new URL(notification.authorThumbnails[2].url).pathname,
|
||||||
|
img: '/ggpht' + new URL(notification.authorThumbnails[4].url).pathname,
|
||||||
|
tag: notification.videoId
|
||||||
|
});
|
||||||
|
|
||||||
|
system_notification.onclick = function (event) {
|
||||||
|
window.open('/watch?v=' + event.currentTarget.tag, '_blank');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
delivered.push(notification.videoId);
|
||||||
|
localStorage.setItem('notification_count', parseInt(localStorage.getItem('notification_count') || '0') + 1);
|
||||||
|
var notification_ticker = document.getElementById('notification_ticker');
|
||||||
|
|
||||||
|
if (parseInt(localStorage.getItem('notification_count')) > 0) {
|
||||||
|
notification_ticker.innerHTML =
|
||||||
|
'<span id="notification_count">' + localStorage.getItem('notification_count') + '</span> <i class="icon ion-ios-notifications"></i>';
|
||||||
|
} else {
|
||||||
|
notification_ticker.innerHTML =
|
||||||
|
'<i class="icon ion-ios-notifications-outline"></i>';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
notifications.addEventListener('error', handle_notification_error);
|
||||||
|
notifications.stream();
|
||||||
|
}
|
||||||
|
|
||||||
|
function handle_notification_error(event) {
|
||||||
|
console.log('Something went wrong with notifications, trying to reconnect...');
|
||||||
|
notifications = { close: function () { } };
|
||||||
|
setTimeout(function () { get_subscriptions(create_notification_stream) }, 1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
window.addEventListener('load', function (e) {
|
||||||
|
localStorage.setItem('notification_count', document.getElementById('notification_count') ? document.getElementById('notification_count').innerText : '0');
|
||||||
|
|
||||||
|
if (localStorage.getItem('stream')) {
|
||||||
|
localStorage.removeItem('stream');
|
||||||
|
} else {
|
||||||
|
setTimeout(function () {
|
||||||
|
if (!localStorage.getItem('stream')) {
|
||||||
|
notifications = { close: function () { } };
|
||||||
|
localStorage.setItem('stream', true);
|
||||||
|
get_subscriptions(create_notification_stream);
|
||||||
|
}
|
||||||
|
}, Math.random() * 1000 + 50);
|
||||||
|
}
|
||||||
|
|
||||||
|
window.addEventListener('storage', function (e) {
|
||||||
|
if (e.key === 'stream' && !e.newValue) {
|
||||||
|
if (notifications) {
|
||||||
|
localStorage.setItem('stream', true);
|
||||||
|
} else {
|
||||||
|
setTimeout(function () {
|
||||||
|
if (!localStorage.getItem('stream')) {
|
||||||
|
notifications = { close: function () { } };
|
||||||
|
localStorage.setItem('stream', true);
|
||||||
|
get_subscriptions(create_notification_stream);
|
||||||
|
}
|
||||||
|
}, Math.random() * 1000 + 50);
|
||||||
|
}
|
||||||
|
} else if (e.key === 'notification_count') {
|
||||||
|
var notification_ticker = document.getElementById('notification_ticker');
|
||||||
|
|
||||||
|
if (parseInt(e.newValue) > 0) {
|
||||||
|
notification_ticker.innerHTML =
|
||||||
|
'<span id="notification_count">' + e.newValue + '</span> <i class="icon ion-ios-notifications"></i>';
|
||||||
|
} else {
|
||||||
|
notification_ticker.innerHTML =
|
||||||
|
'<i class="icon ion-ios-notifications-outline"></i>';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
window.addEventListener('unload', function (e) {
|
||||||
|
if (notifications) {
|
||||||
|
localStorage.removeItem('stream');
|
||||||
|
}
|
||||||
|
});
|
||||||
474
assets/js/player.js
Normal file
474
assets/js/player.js
Normal file
@@ -0,0 +1,474 @@
|
|||||||
|
var player_data = JSON.parse(document.getElementById('player_data').innerHTML);
|
||||||
|
var video_data = JSON.parse(document.getElementById('video_data').innerHTML);
|
||||||
|
|
||||||
|
var options = {
|
||||||
|
preload: 'auto',
|
||||||
|
liveui: true,
|
||||||
|
playbackRates: [0.25, 0.5, 0.75, 1.0, 1.25, 1.5, 1.75, 2.0],
|
||||||
|
controlBar: {
|
||||||
|
children: [
|
||||||
|
'playToggle',
|
||||||
|
'volumePanel',
|
||||||
|
'currentTimeDisplay',
|
||||||
|
'timeDivider',
|
||||||
|
'durationDisplay',
|
||||||
|
'progressControl',
|
||||||
|
'remainingTimeDisplay',
|
||||||
|
'captionsButton',
|
||||||
|
'qualitySelector',
|
||||||
|
'playbackRateMenuButton',
|
||||||
|
'fullscreenToggle'
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (player_data.aspect_ratio) {
|
||||||
|
options.aspectRatio = player_data.aspect_ratio;
|
||||||
|
}
|
||||||
|
|
||||||
|
var embed_url = new URL(location);
|
||||||
|
embed_url.searchParams.delete('v');
|
||||||
|
short_url = location.origin + '/' + video_data.id + embed_url.search;
|
||||||
|
embed_url = location.origin + '/embed/' + video_data.id + embed_url.search;
|
||||||
|
|
||||||
|
var shareOptions = {
|
||||||
|
socials: ['fbFeed', 'tw', 'reddit', 'email'],
|
||||||
|
|
||||||
|
url: short_url,
|
||||||
|
title: player_data.title,
|
||||||
|
description: player_data.description,
|
||||||
|
image: player_data.thumbnail,
|
||||||
|
embedCode: "<iframe id='ivplayer' width='640' height='360' src='" + embed_url + "' style='border:none;'></iframe>"
|
||||||
|
}
|
||||||
|
|
||||||
|
var player = videojs('player', options);
|
||||||
|
|
||||||
|
if (location.pathname.startsWith('/embed/')) {
|
||||||
|
player.overlay({
|
||||||
|
overlays: [{
|
||||||
|
start: 'loadstart',
|
||||||
|
content: '<h1><a rel="noopener" target="_blank" href="' + location.origin + '/watch?v=' + video_data.id + '">' + player_data.title + '</a></h1>',
|
||||||
|
end: 'playing',
|
||||||
|
align: 'top'
|
||||||
|
}, {
|
||||||
|
start: 'pause',
|
||||||
|
content: '<h1><a rel="noopener" target="_blank" href="' + location.origin + '/watch?v=' + video_data.id + '">' + player_data.title + '</a></h1>',
|
||||||
|
end: 'playing',
|
||||||
|
align: 'top'
|
||||||
|
}]
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
player.on('error', function (event) {
|
||||||
|
if (player.error().code === 2 || player.error().code === 4) {
|
||||||
|
setInterval(setTimeout(function (event) {
|
||||||
|
console.log('An error occured in the player, reloading...');
|
||||||
|
|
||||||
|
var currentTime = player.currentTime();
|
||||||
|
var playbackRate = player.playbackRate();
|
||||||
|
var paused = player.paused();
|
||||||
|
|
||||||
|
player.load();
|
||||||
|
|
||||||
|
if (currentTime > 0.5) {
|
||||||
|
currentTime -= 0.5;
|
||||||
|
}
|
||||||
|
|
||||||
|
player.currentTime(currentTime);
|
||||||
|
player.playbackRate(playbackRate);
|
||||||
|
|
||||||
|
if (!paused) {
|
||||||
|
player.play();
|
||||||
|
}
|
||||||
|
}, 5000), 5000);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Add markers
|
||||||
|
if (video_data.params.video_start > 0 || video_data.params.video_end > 0) {
|
||||||
|
var markers = [{ time: video_data.params.video_start, text: 'Start' }];
|
||||||
|
|
||||||
|
if (video_data.params.video_end < 0) {
|
||||||
|
markers.push({ time: video_data.length_seconds - 0.5, text: 'End' });
|
||||||
|
} else {
|
||||||
|
markers.push({ time: video_data.params.video_end, text: 'End' });
|
||||||
|
}
|
||||||
|
|
||||||
|
player.markers({
|
||||||
|
onMarkerReached: function (marker) {
|
||||||
|
if (marker.text === 'End') {
|
||||||
|
if (player.loop()) {
|
||||||
|
player.markers.prev('Start');
|
||||||
|
} else {
|
||||||
|
player.pause();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
markers: markers
|
||||||
|
});
|
||||||
|
|
||||||
|
player.currentTime(video_data.params.video_start);
|
||||||
|
}
|
||||||
|
|
||||||
|
player.volume(video_data.params.volume / 100);
|
||||||
|
player.playbackRate(video_data.params.speed);
|
||||||
|
|
||||||
|
player.on('waiting', function () {
|
||||||
|
if (player.playbackRate() > 1 && player.liveTracker.isLive() && player.liveTracker.atLiveEdge()) {
|
||||||
|
console.log('Player has caught up to source, resetting playbackRate.')
|
||||||
|
player.playbackRate(1);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
if (video_data.premiere_timestamp && Math.round(new Date() / 1000) < video_data.premiere_timestamp) {
|
||||||
|
player.getChild('bigPlayButton').hide();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (video_data.params.autoplay) {
|
||||||
|
var bpb = player.getChild('bigPlayButton');
|
||||||
|
bpb.hide();
|
||||||
|
|
||||||
|
player.ready(function () {
|
||||||
|
new Promise(function (resolve, reject) {
|
||||||
|
setTimeout(() => resolve(1), 1);
|
||||||
|
}).then(function (result) {
|
||||||
|
var promise = player.play();
|
||||||
|
|
||||||
|
if (promise !== undefined) {
|
||||||
|
promise.then(_ => {
|
||||||
|
}).catch(error => {
|
||||||
|
bpb.show();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!video_data.params.listen && video_data.params.quality === 'dash') {
|
||||||
|
player.httpSourceSelector();
|
||||||
|
}
|
||||||
|
|
||||||
|
player.vttThumbnails({
|
||||||
|
src: location.origin + '/api/v1/storyboards/' + video_data.id + '?height=90'
|
||||||
|
});
|
||||||
|
|
||||||
|
// Enable annotations
|
||||||
|
if (!video_data.params.listen && video_data.params.annotations) {
|
||||||
|
window.addEventListener('load', function (e) {
|
||||||
|
var video_container = document.getElementById('player');
|
||||||
|
let xhr = new XMLHttpRequest();
|
||||||
|
xhr.responseType = 'text';
|
||||||
|
xhr.timeout = 60000;
|
||||||
|
xhr.open('GET', '/api/v1/annotations/' + video_data.id, true);
|
||||||
|
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
if (xhr.readyState === 4) {
|
||||||
|
if (xhr.status === 200) {
|
||||||
|
videojs.registerPlugin('youtubeAnnotationsPlugin', youtubeAnnotationsPlugin);
|
||||||
|
if (!player.paused()) {
|
||||||
|
player.youtubeAnnotationsPlugin({ annotationXml: xhr.response, videoContainer: video_container });
|
||||||
|
} else {
|
||||||
|
player.one('play', function (event) {
|
||||||
|
player.youtubeAnnotationsPlugin({ annotationXml: xhr.response, videoContainer: video_container });
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
window.addEventListener('__ar_annotation_click', e => {
|
||||||
|
const { url, target, seconds } = e.detail;
|
||||||
|
var path = new URL(url);
|
||||||
|
|
||||||
|
if (path.href.startsWith('https://www.youtube.com/watch?') && seconds) {
|
||||||
|
path.search += '&t=' + seconds;
|
||||||
|
}
|
||||||
|
|
||||||
|
path = path.pathname + path.search;
|
||||||
|
|
||||||
|
if (target === 'current') {
|
||||||
|
window.location.href = path;
|
||||||
|
} else if (target === 'new') {
|
||||||
|
window.open(path, '_blank');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
xhr.send();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function increase_volume(delta) {
|
||||||
|
const curVolume = player.volume();
|
||||||
|
let newVolume = curVolume + delta;
|
||||||
|
if (newVolume > 1) {
|
||||||
|
newVolume = 1;
|
||||||
|
} else if (newVolume < 0) {
|
||||||
|
newVolume = 0;
|
||||||
|
}
|
||||||
|
player.volume(newVolume);
|
||||||
|
}
|
||||||
|
|
||||||
|
function toggle_muted() {
|
||||||
|
const isMuted = player.muted();
|
||||||
|
player.muted(!isMuted);
|
||||||
|
}
|
||||||
|
|
||||||
|
function skip_seconds(delta) {
|
||||||
|
const duration = player.duration();
|
||||||
|
const curTime = player.currentTime();
|
||||||
|
let newTime = curTime + delta;
|
||||||
|
if (newTime > duration) {
|
||||||
|
newTime = duration;
|
||||||
|
} else if (newTime < 0) {
|
||||||
|
newTime = 0;
|
||||||
|
}
|
||||||
|
player.currentTime(newTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
function set_time_percent(percent) {
|
||||||
|
const duration = player.duration();
|
||||||
|
const newTime = duration * (percent / 100);
|
||||||
|
player.currentTime(newTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
function toggle_play() {
|
||||||
|
if (player.paused()) {
|
||||||
|
player.play();
|
||||||
|
} else {
|
||||||
|
player.pause();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const toggle_captions = (function () {
|
||||||
|
let toggledTrack = null;
|
||||||
|
const onChange = function (e) {
|
||||||
|
toggledTrack = null;
|
||||||
|
};
|
||||||
|
const bindChange = function (onOrOff) {
|
||||||
|
player.textTracks()[onOrOff]('change', onChange);
|
||||||
|
};
|
||||||
|
// Wrapper function to ignore our own emitted events and only listen
|
||||||
|
// to events emitted by Video.js on click on the captions menu items.
|
||||||
|
const setMode = function (track, mode) {
|
||||||
|
bindChange('off');
|
||||||
|
track.mode = mode;
|
||||||
|
window.setTimeout(function () {
|
||||||
|
bindChange('on');
|
||||||
|
}, 0);
|
||||||
|
};
|
||||||
|
bindChange('on');
|
||||||
|
return function () {
|
||||||
|
if (toggledTrack !== null) {
|
||||||
|
if (toggledTrack.mode !== 'showing') {
|
||||||
|
setMode(toggledTrack, 'showing');
|
||||||
|
} else {
|
||||||
|
setMode(toggledTrack, 'disabled');
|
||||||
|
}
|
||||||
|
toggledTrack = null;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Used as a fallback if no captions are currently active.
|
||||||
|
// TODO: Make this more intelligent by e.g. relying on browser language.
|
||||||
|
let fallbackCaptionsTrack = null;
|
||||||
|
|
||||||
|
const tracks = player.textTracks();
|
||||||
|
for (let i = 0; i < tracks.length; i++) {
|
||||||
|
const track = tracks[i];
|
||||||
|
if (track.kind !== 'captions') {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (fallbackCaptionsTrack === null) {
|
||||||
|
fallbackCaptionsTrack = track;
|
||||||
|
}
|
||||||
|
if (track.mode === 'showing') {
|
||||||
|
setMode(track, 'disabled');
|
||||||
|
toggledTrack = track;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Fallback if no captions are currently active.
|
||||||
|
if (fallbackCaptionsTrack !== null) {
|
||||||
|
setMode(fallbackCaptionsTrack, 'showing');
|
||||||
|
toggledTrack = fallbackCaptionsTrack;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
})();
|
||||||
|
|
||||||
|
function toggle_fullscreen() {
|
||||||
|
if (player.isFullscreen()) {
|
||||||
|
player.exitFullscreen();
|
||||||
|
} else {
|
||||||
|
player.requestFullscreen();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function increase_playback_rate(steps) {
|
||||||
|
const maxIndex = options.playbackRates.length - 1;
|
||||||
|
const curIndex = options.playbackRates.indexOf(player.playbackRate());
|
||||||
|
let newIndex = curIndex + steps;
|
||||||
|
if (newIndex > maxIndex) {
|
||||||
|
newIndex = maxIndex;
|
||||||
|
} else if (newIndex < 0) {
|
||||||
|
newIndex = 0;
|
||||||
|
}
|
||||||
|
player.playbackRate(options.playbackRates[newIndex]);
|
||||||
|
}
|
||||||
|
|
||||||
|
window.addEventListener('keydown', e => {
|
||||||
|
if (e.target.tagName.toLowerCase() === 'input') {
|
||||||
|
// Ignore input when focus is on certain elements, e.g. form fields.
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// See https://github.com/ctd1500/videojs-hotkeys/blob/bb4a158b2e214ccab87c2e7b95f42bc45c6bfd87/videojs.hotkeys.js#L310-L313
|
||||||
|
const isPlayerFocused = false
|
||||||
|
|| e.target === document.querySelector('.video-js')
|
||||||
|
|| e.target === document.querySelector('.vjs-tech')
|
||||||
|
|| e.target === document.querySelector('.iframeblocker')
|
||||||
|
|| e.target === document.querySelector('.vjs-control-bar')
|
||||||
|
;
|
||||||
|
let action = null;
|
||||||
|
|
||||||
|
const code = e.keyCode;
|
||||||
|
const decoratedKey =
|
||||||
|
e.key
|
||||||
|
+ (e.altKey ? '+alt' : '')
|
||||||
|
+ (e.ctrlKey ? '+ctrl' : '')
|
||||||
|
+ (e.metaKey ? '+meta' : '')
|
||||||
|
;
|
||||||
|
switch (decoratedKey) {
|
||||||
|
case ' ':
|
||||||
|
case 'k':
|
||||||
|
action = toggle_play;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'ArrowUp':
|
||||||
|
if (isPlayerFocused) {
|
||||||
|
action = increase_volume.bind(this, 0.1);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'ArrowDown':
|
||||||
|
if (isPlayerFocused) {
|
||||||
|
action = increase_volume.bind(this, -0.1);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'm':
|
||||||
|
action = toggle_muted;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'ArrowRight':
|
||||||
|
action = skip_seconds.bind(this, 5);
|
||||||
|
break;
|
||||||
|
case 'ArrowLeft':
|
||||||
|
action = skip_seconds.bind(this, -5);
|
||||||
|
break;
|
||||||
|
case 'l':
|
||||||
|
action = skip_seconds.bind(this, 10);
|
||||||
|
break;
|
||||||
|
case 'j':
|
||||||
|
action = skip_seconds.bind(this, -10);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case '0':
|
||||||
|
case '1':
|
||||||
|
case '2':
|
||||||
|
case '3':
|
||||||
|
case '4':
|
||||||
|
case '5':
|
||||||
|
case '6':
|
||||||
|
case '7':
|
||||||
|
case '8':
|
||||||
|
case '9':
|
||||||
|
const percent = (code - 48) * 10;
|
||||||
|
action = set_time_percent.bind(this, percent);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'c':
|
||||||
|
action = toggle_captions;
|
||||||
|
break;
|
||||||
|
case 'f':
|
||||||
|
action = toggle_fullscreen;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'N':
|
||||||
|
action = next_video;
|
||||||
|
break;
|
||||||
|
case 'P':
|
||||||
|
// TODO: Add support to play back previous video.
|
||||||
|
break;
|
||||||
|
|
||||||
|
case '.':
|
||||||
|
// TODO: Add support for next-frame-stepping.
|
||||||
|
break;
|
||||||
|
case ',':
|
||||||
|
// TODO: Add support for previous-frame-stepping.
|
||||||
|
break;
|
||||||
|
|
||||||
|
case '>':
|
||||||
|
action = increase_playback_rate.bind(this, 1);
|
||||||
|
break;
|
||||||
|
case '<':
|
||||||
|
action = increase_playback_rate.bind(this, -1);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
console.info('Unhandled key down event: %s:', decoratedKey, e);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (action) {
|
||||||
|
e.preventDefault();
|
||||||
|
action();
|
||||||
|
}
|
||||||
|
}, false);
|
||||||
|
|
||||||
|
// Add support for controlling the player volume by scrolling over it. Adapted from
|
||||||
|
// https://github.com/ctd1500/videojs-hotkeys/blob/bb4a158b2e214ccab87c2e7b95f42bc45c6bfd87/videojs.hotkeys.js#L292-L328
|
||||||
|
(function () {
|
||||||
|
const volumeStep = 0.05;
|
||||||
|
const enableVolumeScroll = true;
|
||||||
|
const enableHoverScroll = true;
|
||||||
|
const doc = document;
|
||||||
|
const pEl = document.getElementById('player');
|
||||||
|
|
||||||
|
var volumeHover = false;
|
||||||
|
var volumeSelector = pEl.querySelector('.vjs-volume-menu-button') || pEl.querySelector('.vjs-volume-panel');
|
||||||
|
if (volumeSelector != null) {
|
||||||
|
volumeSelector.onmouseover = function () { volumeHover = true; };
|
||||||
|
volumeSelector.onmouseout = function () { volumeHover = false; };
|
||||||
|
}
|
||||||
|
|
||||||
|
var mouseScroll = function mouseScroll(event) {
|
||||||
|
var activeEl = doc.activeElement;
|
||||||
|
if (enableHoverScroll) {
|
||||||
|
// If we leave this undefined then it can match non-existent elements below
|
||||||
|
activeEl = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// When controls are disabled, hotkeys will be disabled as well
|
||||||
|
if (player.controls()) {
|
||||||
|
if (volumeHover) {
|
||||||
|
if (enableVolumeScroll) {
|
||||||
|
event = window.event || event;
|
||||||
|
var delta = Math.max(-1, Math.min(1, (event.wheelDelta || -event.detail)));
|
||||||
|
event.preventDefault();
|
||||||
|
|
||||||
|
if (delta == 1) {
|
||||||
|
increase_volume(volumeStep);
|
||||||
|
} else if (delta == -1) {
|
||||||
|
increase_volume(-volumeStep);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
player.on('mousewheel', mouseScroll);
|
||||||
|
player.on("DOMMouseScroll", mouseScroll);
|
||||||
|
}());
|
||||||
|
|
||||||
|
// Since videojs-share can sometimes be blocked, we defer it until last
|
||||||
|
player.share(shareOptions);
|
||||||
73
assets/js/playlist_widget.js
Normal file
73
assets/js/playlist_widget.js
Normal file
@@ -0,0 +1,73 @@
|
|||||||
|
var playlist_data = JSON.parse(document.getElementById('playlist_data').innerHTML);
|
||||||
|
|
||||||
|
function add_playlist_video(target) {
|
||||||
|
var select = target.parentNode.children[0].children[1];
|
||||||
|
var option = select.children[select.selectedIndex];
|
||||||
|
|
||||||
|
var url = '/playlist_ajax?action_add_video=1&redirect=false' +
|
||||||
|
'&video_id=' + target.getAttribute('data-id') +
|
||||||
|
'&playlist_id=' + option.getAttribute('data-plid');
|
||||||
|
var xhr = new XMLHttpRequest();
|
||||||
|
xhr.responseType = 'json';
|
||||||
|
xhr.timeout = 10000;
|
||||||
|
xhr.open('POST', url, true);
|
||||||
|
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
|
||||||
|
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
if (xhr.readyState == 4) {
|
||||||
|
if (xhr.status == 200) {
|
||||||
|
option.innerText = '✓' + option.innerText;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.send('csrf_token=' + playlist_data.csrf_token);
|
||||||
|
}
|
||||||
|
|
||||||
|
function add_playlist_item(target) {
|
||||||
|
var tile = target.parentNode.parentNode.parentNode.parentNode.parentNode;
|
||||||
|
tile.style.display = 'none';
|
||||||
|
|
||||||
|
var url = '/playlist_ajax?action_add_video=1&redirect=false' +
|
||||||
|
'&video_id=' + target.getAttribute('data-id') +
|
||||||
|
'&playlist_id=' + target.getAttribute('data-plid');
|
||||||
|
var xhr = new XMLHttpRequest();
|
||||||
|
xhr.responseType = 'json';
|
||||||
|
xhr.timeout = 10000;
|
||||||
|
xhr.open('POST', url, true);
|
||||||
|
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
|
||||||
|
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
if (xhr.readyState == 4) {
|
||||||
|
if (xhr.status != 200) {
|
||||||
|
tile.style.display = '';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.send('csrf_token=' + playlist_data.csrf_token);
|
||||||
|
}
|
||||||
|
|
||||||
|
function remove_playlist_item(target) {
|
||||||
|
var tile = target.parentNode.parentNode.parentNode.parentNode.parentNode;
|
||||||
|
tile.style.display = 'none';
|
||||||
|
|
||||||
|
var url = '/playlist_ajax?action_remove_video=1&redirect=false' +
|
||||||
|
'&set_video_id=' + target.getAttribute('data-index') +
|
||||||
|
'&playlist_id=' + target.getAttribute('data-plid');
|
||||||
|
var xhr = new XMLHttpRequest();
|
||||||
|
xhr.responseType = 'json';
|
||||||
|
xhr.timeout = 10000;
|
||||||
|
xhr.open('POST', url, true);
|
||||||
|
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
|
||||||
|
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
if (xhr.readyState == 4) {
|
||||||
|
if (xhr.status != 200) {
|
||||||
|
tile.style.display = '';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.send('csrf_token=' + playlist_data.csrf_token);
|
||||||
|
}
|
||||||
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
200
assets/js/sse.js
Normal file
200
assets/js/sse.js
Normal file
@@ -0,0 +1,200 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (C) 2016 Maxime Petazzoni <maxime.petazzoni@bulix.org>.
|
||||||
|
* All rights reserved.
|
||||||
|
*/
|
||||||
|
|
||||||
|
var SSE = function (url, options) {
|
||||||
|
if (!(this instanceof SSE)) {
|
||||||
|
return new SSE(url, options);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.INITIALIZING = -1;
|
||||||
|
this.CONNECTING = 0;
|
||||||
|
this.OPEN = 1;
|
||||||
|
this.CLOSED = 2;
|
||||||
|
|
||||||
|
this.url = url;
|
||||||
|
|
||||||
|
options = options || {};
|
||||||
|
this.headers = options.headers || {};
|
||||||
|
this.payload = options.payload !== undefined ? options.payload : '';
|
||||||
|
this.method = options.method || (this.payload && 'POST' || 'GET');
|
||||||
|
|
||||||
|
this.FIELD_SEPARATOR = ':';
|
||||||
|
this.listeners = {};
|
||||||
|
|
||||||
|
this.xhr = null;
|
||||||
|
this.readyState = this.INITIALIZING;
|
||||||
|
this.progress = 0;
|
||||||
|
this.chunk = '';
|
||||||
|
|
||||||
|
this.addEventListener = function(type, listener) {
|
||||||
|
if (this.listeners[type] === undefined) {
|
||||||
|
this.listeners[type] = [];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.listeners[type].indexOf(listener) === -1) {
|
||||||
|
this.listeners[type].push(listener);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
this.removeEventListener = function(type, listener) {
|
||||||
|
if (this.listeners[type] === undefined) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var filtered = [];
|
||||||
|
this.listeners[type].forEach(function(element) {
|
||||||
|
if (element !== listener) {
|
||||||
|
filtered.push(element);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
if (filtered.length === 0) {
|
||||||
|
delete this.listeners[type];
|
||||||
|
} else {
|
||||||
|
this.listeners[type] = filtered;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
this.dispatchEvent = function(e) {
|
||||||
|
if (!e) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
e.source = this;
|
||||||
|
|
||||||
|
var onHandler = 'on' + e.type;
|
||||||
|
if (this.hasOwnProperty(onHandler)) {
|
||||||
|
this[onHandler].call(this, e);
|
||||||
|
if (e.defaultPrevented) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.listeners[e.type]) {
|
||||||
|
return this.listeners[e.type].every(function(callback) {
|
||||||
|
callback(e);
|
||||||
|
return !e.defaultPrevented;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
};
|
||||||
|
|
||||||
|
this._setReadyState = function (state) {
|
||||||
|
var event = new CustomEvent('readystatechange');
|
||||||
|
event.readyState = state;
|
||||||
|
this.readyState = state;
|
||||||
|
this.dispatchEvent(event);
|
||||||
|
};
|
||||||
|
|
||||||
|
this._onStreamFailure = function(e) {
|
||||||
|
this.dispatchEvent(new CustomEvent('error'));
|
||||||
|
this.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
this._onStreamProgress = function(e) {
|
||||||
|
if (this.xhr.status !== 200 && this.readyState !== this.CLOSED) {
|
||||||
|
this._onStreamFailure(e);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.readyState == this.CONNECTING) {
|
||||||
|
this.dispatchEvent(new CustomEvent('open'));
|
||||||
|
this._setReadyState(this.OPEN);
|
||||||
|
}
|
||||||
|
|
||||||
|
var data = this.xhr.responseText.substring(this.progress);
|
||||||
|
this.progress += data.length;
|
||||||
|
data.split(/(\r\n|\r|\n){2}/g).forEach(function(part) {
|
||||||
|
if (part.trim().length === 0) {
|
||||||
|
this.dispatchEvent(this._parseEventChunk(this.chunk.trim()));
|
||||||
|
this.chunk = '';
|
||||||
|
} else {
|
||||||
|
this.chunk += part;
|
||||||
|
}
|
||||||
|
}.bind(this));
|
||||||
|
};
|
||||||
|
|
||||||
|
this._onStreamLoaded = function(e) {
|
||||||
|
this._onStreamProgress(e);
|
||||||
|
|
||||||
|
// Parse the last chunk.
|
||||||
|
this.dispatchEvent(this._parseEventChunk(this.chunk));
|
||||||
|
this.chunk = '';
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parse a received SSE event chunk into a constructed event object.
|
||||||
|
*/
|
||||||
|
this._parseEventChunk = function(chunk) {
|
||||||
|
if (!chunk || chunk.length === 0) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
var e = {'id': null, 'retry': null, 'data': '', 'event': 'message'};
|
||||||
|
chunk.split(/\n|\r\n|\r/).forEach(function(line) {
|
||||||
|
line = line.trimRight();
|
||||||
|
var index = line.indexOf(this.FIELD_SEPARATOR);
|
||||||
|
if (index <= 0) {
|
||||||
|
// Line was either empty, or started with a separator and is a comment.
|
||||||
|
// Either way, ignore.
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var field = line.substring(0, index);
|
||||||
|
if (!(field in e)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var value = line.substring(index + 1).trimLeft();
|
||||||
|
if (field === 'data') {
|
||||||
|
e[field] += value;
|
||||||
|
} else {
|
||||||
|
e[field] = value;
|
||||||
|
}
|
||||||
|
}.bind(this));
|
||||||
|
|
||||||
|
var event = new CustomEvent(e.event);
|
||||||
|
event.data = e.data;
|
||||||
|
event.id = e.id;
|
||||||
|
return event;
|
||||||
|
};
|
||||||
|
|
||||||
|
this._checkStreamClosed = function() {
|
||||||
|
if (this.xhr.readyState === XMLHttpRequest.DONE) {
|
||||||
|
this._setReadyState(this.CLOSED);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
this.stream = function() {
|
||||||
|
this._setReadyState(this.CONNECTING);
|
||||||
|
|
||||||
|
this.xhr = new XMLHttpRequest();
|
||||||
|
this.xhr.addEventListener('progress', this._onStreamProgress.bind(this));
|
||||||
|
this.xhr.addEventListener('load', this._onStreamLoaded.bind(this));
|
||||||
|
this.xhr.addEventListener('readystatechange', this._checkStreamClosed.bind(this));
|
||||||
|
this.xhr.addEventListener('error', this._onStreamFailure.bind(this));
|
||||||
|
this.xhr.addEventListener('abort', this._onStreamFailure.bind(this));
|
||||||
|
this.xhr.open(this.method, this.url);
|
||||||
|
for (var header in this.headers) {
|
||||||
|
this.xhr.setRequestHeader(header, this.headers[header]);
|
||||||
|
}
|
||||||
|
this.xhr.send(this.payload);
|
||||||
|
};
|
||||||
|
|
||||||
|
this.close = function() {
|
||||||
|
if (this.readyState === this.CLOSED) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.xhr.abort();
|
||||||
|
this.xhr = null;
|
||||||
|
this._setReadyState(this.CLOSED);
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
// Export our SSE module for npm.js
|
||||||
|
if (typeof exports !== 'undefined') {
|
||||||
|
exports.SSE = SSE;
|
||||||
|
}
|
||||||
90
assets/js/subscribe_widget.js
Normal file
90
assets/js/subscribe_widget.js
Normal file
@@ -0,0 +1,90 @@
|
|||||||
|
var subscribe_data = JSON.parse(document.getElementById('subscribe_data').innerHTML);
|
||||||
|
|
||||||
|
var subscribe_button = document.getElementById('subscribe');
|
||||||
|
subscribe_button.parentNode['action'] = 'javascript:void(0)';
|
||||||
|
|
||||||
|
if (subscribe_button.getAttribute('data-type') === 'subscribe') {
|
||||||
|
subscribe_button.onclick = subscribe;
|
||||||
|
} else {
|
||||||
|
subscribe_button.onclick = unsubscribe;
|
||||||
|
}
|
||||||
|
|
||||||
|
function subscribe(retries = 5) {
|
||||||
|
if (retries <= 0) {
|
||||||
|
console.log('Failed to subscribe.');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var url = '/subscription_ajax?action_create_subscription_to_channel=1&redirect=false' +
|
||||||
|
'&c=' + subscribe_data.ucid;
|
||||||
|
var xhr = new XMLHttpRequest();
|
||||||
|
xhr.responseType = 'json';
|
||||||
|
xhr.timeout = 10000;
|
||||||
|
xhr.open('POST', url, true);
|
||||||
|
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
|
||||||
|
|
||||||
|
var fallback = subscribe_button.innerHTML;
|
||||||
|
subscribe_button.onclick = unsubscribe;
|
||||||
|
subscribe_button.innerHTML = '<b>' + subscribe_data.unsubscribe_text + ' | ' + subscribe_data.sub_count_text + '</b>';
|
||||||
|
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
if (xhr.readyState == 4) {
|
||||||
|
if (xhr.status != 200) {
|
||||||
|
subscribe_button.onclick = subscribe;
|
||||||
|
subscribe_button.innerHTML = fallback;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.onerror = function () {
|
||||||
|
console.log('Subscribing failed... ' + retries + '/5');
|
||||||
|
setTimeout(function () { subscribe(retries - 1) }, 1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.ontimeout = function () {
|
||||||
|
console.log('Subscribing failed... ' + retries + '/5');
|
||||||
|
subscribe(retries - 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.send('csrf_token=' + subscribe_data.csrf_token);
|
||||||
|
}
|
||||||
|
|
||||||
|
function unsubscribe(retries = 5) {
|
||||||
|
if (retries <= 0) {
|
||||||
|
console.log('Failed to subscribe');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var url = '/subscription_ajax?action_remove_subscriptions=1&redirect=false' +
|
||||||
|
'&c=' + subscribe_data.ucid;
|
||||||
|
var xhr = new XMLHttpRequest();
|
||||||
|
xhr.responseType = 'json';
|
||||||
|
xhr.timeout = 10000;
|
||||||
|
xhr.open('POST', url, true);
|
||||||
|
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
|
||||||
|
|
||||||
|
var fallback = subscribe_button.innerHTML;
|
||||||
|
subscribe_button.onclick = subscribe;
|
||||||
|
subscribe_button.innerHTML = '<b>' + subscribe_data.subscribe_text + ' | ' + subscribe_data.sub_count_text + '</b>';
|
||||||
|
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
if (xhr.readyState == 4) {
|
||||||
|
if (xhr.status != 200) {
|
||||||
|
subscribe_button.onclick = unsubscribe;
|
||||||
|
subscribe_button.innerHTML = fallback;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.onerror = function () {
|
||||||
|
console.log('Unsubscribing failed... ' + retries + '/5');
|
||||||
|
setTimeout(function () { unsubscribe(retries - 1) }, 1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.ontimeout = function () {
|
||||||
|
console.log('Unsubscribing failed... ' + retries + '/5');
|
||||||
|
unsubscribe(retries - 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.send('csrf_token=' + subscribe_data.csrf_token);
|
||||||
|
}
|
||||||
79
assets/js/themes.js
Normal file
79
assets/js/themes.js
Normal file
@@ -0,0 +1,79 @@
|
|||||||
|
var toggle_theme = document.getElementById('toggle_theme');
|
||||||
|
toggle_theme.href = 'javascript:void(0);';
|
||||||
|
|
||||||
|
toggle_theme.addEventListener('click', function () {
|
||||||
|
var dark_mode = document.getElementById('dark_theme').media === 'none';
|
||||||
|
|
||||||
|
var url = '/toggle_theme?redirect=false';
|
||||||
|
var xhr = new XMLHttpRequest();
|
||||||
|
xhr.responseType = 'json';
|
||||||
|
xhr.timeout = 10000;
|
||||||
|
xhr.open('GET', url, true);
|
||||||
|
|
||||||
|
set_mode(dark_mode);
|
||||||
|
window.localStorage.setItem('dark_mode', dark_mode ? 'dark' : 'light');
|
||||||
|
|
||||||
|
xhr.send();
|
||||||
|
});
|
||||||
|
|
||||||
|
window.addEventListener('storage', function (e) {
|
||||||
|
if (e.key === 'dark_mode') {
|
||||||
|
update_mode(e.newValue);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
window.addEventListener('load', function () {
|
||||||
|
window.localStorage.setItem('dark_mode', document.getElementById('dark_mode_pref').textContent);
|
||||||
|
// Update localStorage if dark mode preference changed on preferences page
|
||||||
|
update_mode(window.localStorage.dark_mode);
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
var darkScheme = window.matchMedia('(prefers-color-scheme: dark)');
|
||||||
|
var lightScheme = window.matchMedia('(prefers-color-scheme: light)');
|
||||||
|
|
||||||
|
darkScheme.addListener(scheme_switch);
|
||||||
|
lightScheme.addListener(scheme_switch);
|
||||||
|
|
||||||
|
function scheme_switch (e) {
|
||||||
|
// ignore this method if we have a preference set
|
||||||
|
if (localStorage.getItem('dark_mode')) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (e.matches) {
|
||||||
|
if (e.media.includes("dark")) {
|
||||||
|
set_mode(true);
|
||||||
|
} else if (e.media.includes("light")) {
|
||||||
|
set_mode(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function set_mode (bool) {
|
||||||
|
document.getElementById('dark_theme').media = !bool ? 'none' : '';
|
||||||
|
document.getElementById('light_theme').media = bool ? 'none' : '';
|
||||||
|
|
||||||
|
if (bool) {
|
||||||
|
toggle_theme.children[0].setAttribute('class', 'icon ion-ios-sunny');
|
||||||
|
} else {
|
||||||
|
toggle_theme.children[0].setAttribute('class', 'icon ion-ios-moon');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function update_mode (mode) {
|
||||||
|
if (mode === 'true' /* for backwards compatibility */ || mode === 'dark') {
|
||||||
|
// If preference for dark mode indicated
|
||||||
|
set_mode(true);
|
||||||
|
}
|
||||||
|
else if (mode === 'false' /* for backwards compaibility */ || mode === 'light') {
|
||||||
|
// If preference for light mode indicated
|
||||||
|
set_mode(false);
|
||||||
|
}
|
||||||
|
else if (document.getElementById('dark_mode_pref').textContent === '' && window.matchMedia('(prefers-color-scheme: dark)').matches) {
|
||||||
|
// If no preference indicated here and no preference indicated on the preferences page (backend), but the browser tells us that the operating system has a dark theme
|
||||||
|
set_mode(true);
|
||||||
|
}
|
||||||
|
// else do nothing, falling back to the mode defined by the `dark_mode` preference on the preferences page (backend)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
28
assets/js/video.min.js
vendored
28
assets/js/video.min.js
vendored
File diff suppressed because one or more lines are too long
@@ -1,2 +1,2 @@
|
|||||||
/*! @name videojs-contrib-quality-levels @version 2.0.7 @license Apache-2.0 */
|
/*! @name videojs-contrib-quality-levels @version 2.0.9 @license Apache-2.0 */
|
||||||
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("video.js"),require("global/document")):"function"==typeof define&&define.amd?define(["video.js","global/document"],t):e.videojsContribQualityLevels=t(e.videojs,e.document)}(this,function(e,t){"use strict";e=e&&e.hasOwnProperty("default")?e.default:e,t=t&&t.hasOwnProperty("default")?t.default:t;var n=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")},r=function(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t},i=function(i){function o(){n(this,o);var l=r(this,i.call(this)),s=l;if(e.browser.IS_IE8)for(var u in s=t.createElement("custom"),o.prototype)"constructor"!==u&&(s[u]=o.prototype[u]);return s.levels_=[],s.selectedIndex_=-1,Object.defineProperty(s,"selectedIndex",{get:function(){return s.selectedIndex_}}),Object.defineProperty(s,"length",{get:function(){return s.levels_.length}}),r(l,s)}return function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}(o,i),o.prototype.addQualityLevel=function(r){var i=this.getQualityLevelById(r.id);if(i)return i;var o=this.levels_.length;return i=new function r(i){n(this,r);var o=this;if(e.browser.IS_IE8)for(var l in o=t.createElement("custom"),r.prototype)"constructor"!==l&&(o[l]=r.prototype[l]);return o.id=i.id,o.label=o.id,o.width=i.width,o.height=i.height,o.bitrate=i.bandwidth,o.enabled_=i.enabled,Object.defineProperty(o,"enabled",{get:function(){return o.enabled_()},set:function(e){o.enabled_(e)}}),o}(r),""+o in this||Object.defineProperty(this,o,{get:function(){return this.levels_[o]}}),this.levels_.push(i),this.trigger({qualityLevel:i,type:"addqualitylevel"}),i},o.prototype.removeQualityLevel=function(e){for(var t=null,n=0,r=this.length;n<r;n++)if(this[n]===e){t=this.levels_.splice(n,1)[0],this.selectedIndex_===n?this.selectedIndex_=-1:this.selectedIndex_>n&&this.selectedIndex_--;break}return t&&this.trigger({qualityLevel:e,type:"removequalitylevel"}),t},o.prototype.getQualityLevelById=function(e){for(var t=0,n=this.length;t<n;t++){var r=this[t];if(r.id===e)return r}return null},o.prototype.dispose=function(){this.selectedIndex_=-1,this.levels_.length=0},o}(e.EventTarget);for(var o in i.prototype.allowedEvents_={change:"change",addqualitylevel:"addqualitylevel",removequalitylevel:"removequalitylevel"},i.prototype.allowedEvents_)i.prototype["on"+o]=null;var l=function(t){return n=this,e.mergeOptions({},t),r=n.qualityLevels,o=new i,n.on("dispose",function e(){o.dispose(),n.qualityLevels=r,n.off("dispose",e)}),n.qualityLevels=function(){return o},n.qualityLevels.VERSION="__VERSION__",o;var n,r,o};return(e.registerPlugin||e.plugin)("qualityLevels",l),l.VERSION="__VERSION__",l});
|
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("video.js"),require("global/document")):"function"==typeof define&&define.amd?define(["video.js","global/document"],t):e.videojsContribQualityLevels=t(e.videojs,e.document)}(this,function(e,t){"use strict";function n(e){if(void 0===e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return e}e=e&&e.hasOwnProperty("default")?e.default:e,t=t&&t.hasOwnProperty("default")?t.default:t;var r=function(r){var i,l;function o(){var i,l=n(n(i=r.call(this)||this));if(e.browser.IS_IE8)for(var s in l=t.createElement("custom"),o.prototype)"constructor"!==s&&(l[s]=o.prototype[s]);return l.levels_=[],l.selectedIndex_=-1,Object.defineProperty(l,"selectedIndex",{get:function(){return l.selectedIndex_}}),Object.defineProperty(l,"length",{get:function(){return l.levels_.length}}),l||n(i)}l=r,(i=o).prototype=Object.create(l.prototype),i.prototype.constructor=i,i.__proto__=l;var s=o.prototype;return s.addQualityLevel=function(n){var r=this.getQualityLevelById(n.id);if(r)return r;var i=this.levels_.length;return r=new function n(r){var i=this;if(e.browser.IS_IE8)for(var l in i=t.createElement("custom"),n.prototype)"constructor"!==l&&(i[l]=n.prototype[l]);return i.id=r.id,i.label=i.id,i.width=r.width,i.height=r.height,i.bitrate=r.bandwidth,i.enabled_=r.enabled,Object.defineProperty(i,"enabled",{get:function(){return i.enabled_()},set:function(e){i.enabled_(e)}}),i}(n),""+i in this||Object.defineProperty(this,i,{get:function(){return this.levels_[i]}}),this.levels_.push(r),this.trigger({qualityLevel:r,type:"addqualitylevel"}),r},s.removeQualityLevel=function(e){for(var t=null,n=0,r=this.length;n<r;n++)if(this[n]===e){t=this.levels_.splice(n,1)[0],this.selectedIndex_===n?this.selectedIndex_=-1:this.selectedIndex_>n&&this.selectedIndex_--;break}return t&&this.trigger({qualityLevel:e,type:"removequalitylevel"}),t},s.getQualityLevelById=function(e){for(var t=0,n=this.length;t<n;t++){var r=this[t];if(r.id===e)return r}return null},s.dispose=function(){this.selectedIndex_=-1,this.levels_.length=0},o}(e.EventTarget);for(var i in r.prototype.allowedEvents_={change:"change",addqualitylevel:"addqualitylevel",removequalitylevel:"removequalitylevel"},r.prototype.allowedEvents_)r.prototype["on"+i]=null;var l=function(t){return n=this,e.mergeOptions({},t),i=n.qualityLevels,l=new r,n.on("dispose",function e(){l.dispose(),n.qualityLevels=i,n.off("dispose",e)}),n.qualityLevels=function(){return l},n.qualityLevels.VERSION="2.0.9",l;var n,i,l};return(e.registerPlugin||e.plugin)("qualityLevels",l),l.VERSION="2.0.9",l});
|
||||||
|
|||||||
3
assets/js/videojs-dash.min.js
vendored
3
assets/js/videojs-dash.min.js
vendored
File diff suppressed because one or more lines are too long
7
assets/js/videojs-http-source-selector.min.js
vendored
Normal file
7
assets/js/videojs-http-source-selector.min.js
vendored
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
/**
|
||||||
|
* videojs-http-source-selector
|
||||||
|
* @version 1.1.6
|
||||||
|
* @copyright 2019 Justin Fujita <Justin@pivotshare.com>
|
||||||
|
* @license MIT
|
||||||
|
*/
|
||||||
|
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("video.js")):"function"==typeof define&&define.amd?define(["video.js"],t):(e=e||self)["videojs-http-source-selector"]=t(e.videojs)}(this,function(r){"use strict";function o(e,t){e.prototype=Object.create(t.prototype),(e.prototype.constructor=e).__proto__=t}function s(e){if(void 0===e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return e}var e=(r=r&&r.hasOwnProperty("default")?r.default:r).getComponent("MenuItem"),t=r.getComponent("Component"),a=function(n){function e(e,t){return t.selectable=!0,t.multiSelectable=!1,n.call(this,e,t)||this}o(e,n);var t=e.prototype;return t.handleClick=function(){var e=this.options_;console.log("Changing quality to:",e.label),n.prototype.handleClick.call(this);for(var t=this.player().qualityLevels(),o=0;o<t.length;o++)e.index==t.length?t[o].enabled=!0:e.index==o?t[o].enabled=!0:t[o].enabled=!1},t.update=function(){var e=this.player().qualityLevels().selectedIndex;this.selected(this.options_.index==e)},e}(e);t.registerComponent("SourceMenuItem",a);var u=r.getComponent("MenuButton"),n=function(i){function e(e,t){var o;o=i.call(this,e,t)||this,u.apply(s(o),arguments);var n=o.player().qualityLevels();if(t&&t.default)if("low"==t.default)for(var l=0;l<n.length;l++)n[l].enabled=0==l;else if(t.default="high")for(l=0;l<n.length;l++)n[l].enabled=l==n.length-1;return o.player().qualityLevels().on(["change","addqualitylevel"],r.bind(s(o),o.update)),o}o(e,i);var t=e.prototype;return t.createEl=function(){return r.dom.createEl("div",{className:"vjs-http-source-selector vjs-menu-button vjs-menu-button-popup vjs-control vjs-button"})},t.buildCSSClass=function(){return u.prototype.buildCSSClass.call(this)+" vjs-icon-cog"},t.update=function(){return u.prototype.update.call(this)},t.createItems=function(){for(var e=[],t=this.player().qualityLevels(),o=[],n=0;n<t.length;n++){var l=t.length-(n+1),i=l===t.selectedIndex,r=""+l,s=l;t[l].height?(r=t[l].height+"p",s=parseInt(t[l].height,10)):t[l].bitrate&&(r=Math.floor(t[l].bitrate/1e3)+" kbps",s=parseInt(t[l].bitrate,10)),0<=o.indexOf(r)||(o.push(r),e.push(new a(this.player_,{label:r,index:l,selected:i,sortVal:s})))}return 1<t.length&&e.push(new a(this.player_,{label:"Auto",index:t.length,selected:!1,sortVal:99999})),e.sort(function(e,t){return e.options_.sortVal<t.options_.sortVal?1:e.options_.sortVal>t.options_.sortVal?-1:0}),e},e}(u),l={},i=r.registerPlugin||r.plugin,c=function(e){var t=this;this.ready(function(){!function(n,e){if(n.addClass("vjs-http-source-selector"),console.log("videojs-http-source-selector initialized!"),console.log("player.techName_:"+n.techName_),"Html5"!=n.techName_)return;n.on(["loadedmetadata"],function(e){if(n.qualityLevels(),r.log("loadmetadata event"),"undefined"==n.videojs_http_source_selector_initialized||1==n.videojs_http_source_selector_initialized)console.log("player.videojs_http_source_selector_initialized == true");else{console.log("player.videojs_http_source_selector_initialized == false"),n.videojs_http_source_selector_initialized=!0;var t=n.controlBar,o=t.getChild("fullscreenToggle").el();t.el().insertBefore(t.addChild("SourceMenuButton").el(),o)}})}(t,r.mergeOptions(l,e))}),r.registerComponent("SourceMenuButton",n),r.registerComponent("SourceMenuItem",a)};return i("httpSourceSelector",c),c.VERSION="1.1.6",c});
|
||||||
14
assets/js/videojs-http-streaming.min.js
vendored
14
assets/js/videojs-http-streaming.min.js
vendored
File diff suppressed because one or more lines are too long
2
assets/js/videojs-overlay.min.js
vendored
Normal file
2
assets/js/videojs-overlay.min.js
vendored
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
/*! @name videojs-overlay @version 2.1.4 @license Apache-2.0 */
|
||||||
|
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e(require("video.js"),require("global/window")):"function"==typeof define&&define.amd?define(["video.js","global/window"],e):t.videojsOverlay=e(t.videojs,t.window)}(this,function(t,e){"use strict";function n(t){if(void 0===t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return t}t=t&&t.hasOwnProperty("default")?t.default:t,e=e&&e.hasOwnProperty("default")?e.default:e;var r={align:"top-left",class:"",content:"This overlay will show up while the video is playing",debug:!1,showBackground:!0,attachToControlBar:!1,overlays:[{start:"playing",end:"paused"}]},i=t.getComponent("Component"),o=t.dom||t,s=t.registerPlugin||t.plugin,a=function(t){return"number"==typeof t&&t==t},h=function(t){return"string"==typeof t&&/^\S+$/.test(t)},d=function(r){var i,s;function d(t,e){var i;return i=r.call(this,t,e)||this,["start","end"].forEach(function(t){var e=i.options_[t];if(a(e))i[t+"Event_"]="timeupdate";else if(h(e))i[t+"Event_"]=e;else if("start"===t)throw new Error('invalid "start" option; expected number or string')}),["endListener_","rewindListener_","startListener_"].forEach(function(t){i[t]=function(e){return d.prototype[t].call(n(n(i)),e)}}),"timeupdate"===i.startEvent_&&i.on(t,"timeupdate",i.rewindListener_),i.debug('created, listening to "'+i.startEvent_+'" for "start" and "'+(i.endEvent_||"nothing")+'" for "end"'),i.hide(),i}s=r,(i=d).prototype=Object.create(s.prototype),i.prototype.constructor=i,i.__proto__=s;var l=d.prototype;return l.createEl=function(){var t=this.options_,n=t.content,r=t.showBackground?"vjs-overlay-background":"vjs-overlay-no-background",i=o.createEl("div",{className:"\n vjs-overlay\n vjs-overlay-"+t.align+"\n "+t.class+"\n "+r+"\n vjs-hidden\n "});return"string"==typeof n?i.innerHTML=n:n instanceof e.DocumentFragment?i.appendChild(n):o.appendContent(i,n),i},l.debug=function(){if(this.options_.debug){for(var e=t.log,n=e,r=arguments.length,i=new Array(r),o=0;o<r;o++)i[o]=arguments[o];e.hasOwnProperty(i[0])&&"function"==typeof e[i[0]]&&(n=e[i.shift()]),n.apply(void 0,["overlay#"+this.id()+": "].concat(i))}},l.hide=function(){return r.prototype.hide.call(this),this.debug("hidden"),this.debug('bound `startListener_` to "'+this.startEvent_+'"'),this.endEvent_&&(this.debug('unbound `endListener_` from "'+this.endEvent_+'"'),this.off(this.player(),this.endEvent_,this.endListener_)),this.on(this.player(),this.startEvent_,this.startListener_),this},l.shouldHide_=function(t,e){var n=this.options_.end;return a(n)?t>=n:n===e},l.show=function(){return r.prototype.show.call(this),this.off(this.player(),this.startEvent_,this.startListener_),this.debug("shown"),this.debug('unbound `startListener_` from "'+this.startEvent_+'"'),this.endEvent_&&(this.debug('bound `endListener_` to "'+this.endEvent_+'"'),this.on(this.player(),this.endEvent_,this.endListener_)),this},l.shouldShow_=function(t,e){var n=this.options_.start,r=this.options_.end;return a(n)?a(r)?t>=n&&t<r:this.hasShownSinceSeek_?Math.floor(t)===n:(this.hasShownSinceSeek_=!0,t>=n):n===e},l.startListener_=function(t){var e=this.player().currentTime();this.shouldShow_(e,t.type)&&this.show()},l.endListener_=function(t){var e=this.player().currentTime();this.shouldHide_(e,t.type)&&this.hide()},l.rewindListener_=function(t){var e=this.player().currentTime(),n=this.previousTime_,r=this.options_.start,i=this.options_.end;e<n&&(this.debug("rewind detected"),a(i)&&!this.shouldShow_(e)?(this.debug("hiding; "+i+" is an integer and overlay should not show at this time"),this.hasShownSinceSeek_=!1,this.hide()):h(i)&&e<r&&(this.debug("hiding; show point ("+r+") is before now ("+e+") and end point ("+i+") is an event"),this.hasShownSinceSeek_=!1,this.hide())),this.previousTime_=e},d}(i);t.registerComponent("Overlay",d);var l=function(e){var n=this,i=t.mergeOptions(r,e);Array.isArray(this.overlays_)&&this.overlays_.forEach(function(t){n.removeChild(t),n.controlBar&&n.controlBar.removeChild(t),t.dispose()});var o=i.overlays;delete i.overlays,this.overlays_=o.map(function(e){var r=t.mergeOptions(i,e),o="string"==typeof r.attachToControlBar||!0===r.attachToControlBar;if(!n.controls()||!n.controlBar)return n.addChild("overlay",r);if(o&&-1!==r.align.indexOf("bottom")){var s=n.controlBar.children()[0];if(void 0!==n.controlBar.getChild(r.attachToControlBar)&&(s=n.controlBar.getChild(r.attachToControlBar)),s){var a=n.controlBar.addChild("overlay",r);return n.controlBar.el().insertBefore(a.el(),s.el()),a}}var h=n.addChild("overlay",r);return n.el().insertBefore(h.el(),n.controlBar.el()),h})};return l.VERSION="2.1.4",s("overlay",l),l});
|
||||||
6
assets/js/videojs-share.min.js
vendored
6
assets/js/videojs-share.min.js
vendored
File diff suppressed because one or more lines are too long
7
assets/js/videojs-vtt-thumbnails.min.js
vendored
Normal file
7
assets/js/videojs-vtt-thumbnails.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
1
assets/js/videojs-youtube-annotations.min.js
vendored
Normal file
1
assets/js/videojs-youtube-annotations.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
@@ -1,413 +0,0 @@
|
|||||||
/*
|
|
||||||
* Video.js Hotkeys
|
|
||||||
* https://github.com/ctd1500/videojs-hotkeys
|
|
||||||
*
|
|
||||||
* Copyright (c) 2015 Chris Dougherty
|
|
||||||
* Licensed under the Apache-2.0 license.
|
|
||||||
*/
|
|
||||||
|
|
||||||
;(function(root, factory) {
|
|
||||||
if (typeof window !== 'undefined' && window.videojs) {
|
|
||||||
factory(window.videojs);
|
|
||||||
} else if (typeof define === 'function' && define.amd) {
|
|
||||||
define('videojs-hotkeys', ['video.js'], function (module) {
|
|
||||||
return factory(module.default || module);
|
|
||||||
});
|
|
||||||
} else if (typeof module !== 'undefined' && module.exports) {
|
|
||||||
module.exports = factory(require('video.js'));
|
|
||||||
}
|
|
||||||
}(this, function (videojs) {
|
|
||||||
"use strict";
|
|
||||||
if (typeof window !== 'undefined') {
|
|
||||||
window['videojs_hotkeys'] = { version: "0.2.22" };
|
|
||||||
}
|
|
||||||
|
|
||||||
var hotkeys = function(options) {
|
|
||||||
var player = this;
|
|
||||||
var pEl = player.el();
|
|
||||||
var doc = document;
|
|
||||||
var def_options = {
|
|
||||||
volumeStep: 0.1,
|
|
||||||
seekStep: 5,
|
|
||||||
enableMute: true,
|
|
||||||
enableVolumeScroll: true,
|
|
||||||
enableHoverScroll: true,
|
|
||||||
enableFullscreen: true,
|
|
||||||
enableNumbers: true,
|
|
||||||
enableJogStyle: false,
|
|
||||||
alwaysCaptureHotkeys: false,
|
|
||||||
enableModifiersForNumbers: true,
|
|
||||||
enableInactiveFocus: true,
|
|
||||||
skipInitialFocus: false,
|
|
||||||
playPauseKey: playPauseKey,
|
|
||||||
rewindKey: rewindKey,
|
|
||||||
forwardKey: forwardKey,
|
|
||||||
volumeUpKey: volumeUpKey,
|
|
||||||
volumeDownKey: volumeDownKey,
|
|
||||||
muteKey: muteKey,
|
|
||||||
fullscreenKey: fullscreenKey,
|
|
||||||
customKeys: {}
|
|
||||||
};
|
|
||||||
|
|
||||||
var cPlay = 1,
|
|
||||||
cRewind = 2,
|
|
||||||
cForward = 3,
|
|
||||||
cVolumeUp = 4,
|
|
||||||
cVolumeDown = 5,
|
|
||||||
cMute = 6,
|
|
||||||
cFullscreen = 7;
|
|
||||||
|
|
||||||
// Use built-in merge function from Video.js v5.0+ or v4.4.0+
|
|
||||||
var mergeOptions = videojs.mergeOptions || videojs.util.mergeOptions;
|
|
||||||
options = mergeOptions(def_options, options || {});
|
|
||||||
|
|
||||||
var volumeStep = options.volumeStep,
|
|
||||||
seekStep = options.seekStep,
|
|
||||||
enableMute = options.enableMute,
|
|
||||||
enableVolumeScroll = options.enableVolumeScroll,
|
|
||||||
enableHoverScroll = options.enableHoverScroll,
|
|
||||||
enableFull = options.enableFullscreen,
|
|
||||||
enableNumbers = options.enableNumbers,
|
|
||||||
enableJogStyle = options.enableJogStyle,
|
|
||||||
alwaysCaptureHotkeys = options.alwaysCaptureHotkeys,
|
|
||||||
enableModifiersForNumbers = options.enableModifiersForNumbers,
|
|
||||||
enableInactiveFocus = options.enableInactiveFocus,
|
|
||||||
skipInitialFocus = options.skipInitialFocus;
|
|
||||||
|
|
||||||
// Set default player tabindex to handle keydown and doubleclick events
|
|
||||||
if (!pEl.hasAttribute('tabIndex')) {
|
|
||||||
pEl.setAttribute('tabIndex', '-1');
|
|
||||||
}
|
|
||||||
|
|
||||||
// Remove player outline to fix video performance issue
|
|
||||||
pEl.style.outline = "none";
|
|
||||||
|
|
||||||
if (alwaysCaptureHotkeys || !player.autoplay()) {
|
|
||||||
if (!skipInitialFocus) {
|
|
||||||
player.one('play', function() {
|
|
||||||
pEl.focus(); // Fixes the .vjs-big-play-button handing focus back to body instead of the player
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (enableInactiveFocus) {
|
|
||||||
player.on('userinactive', function() {
|
|
||||||
// When the control bar fades, re-apply focus to the player if last focus was a control button
|
|
||||||
var cancelFocusingPlayer = function() {
|
|
||||||
clearTimeout(focusingPlayerTimeout);
|
|
||||||
};
|
|
||||||
var focusingPlayerTimeout = setTimeout(function() {
|
|
||||||
player.off('useractive', cancelFocusingPlayer);
|
|
||||||
var activeElement = doc.activeElement;
|
|
||||||
var controlBar = pEl.querySelector('.vjs-control-bar');
|
|
||||||
if (activeElement && activeElement.parentElement == controlBar) {
|
|
||||||
pEl.focus();
|
|
||||||
}
|
|
||||||
}, 10);
|
|
||||||
|
|
||||||
player.one('useractive', cancelFocusingPlayer);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
player.on('play', function() {
|
|
||||||
// Fix allowing the YouTube plugin to have hotkey support.
|
|
||||||
var ifblocker = pEl.querySelector('.iframeblocker');
|
|
||||||
if (ifblocker && ifblocker.style.display === '') {
|
|
||||||
ifblocker.style.display = "block";
|
|
||||||
ifblocker.style.bottom = "39px";
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
var keyDown = function keyDown(event) {
|
|
||||||
var ewhich = event.which, wasPlaying, seekTime;
|
|
||||||
var ePreventDefault = event.preventDefault;
|
|
||||||
var duration = player.duration();
|
|
||||||
// When controls are disabled, hotkeys will be disabled as well
|
|
||||||
if (player.controls()) {
|
|
||||||
|
|
||||||
// Don't catch keys if any control buttons are focused, unless alwaysCaptureHotkeys is true
|
|
||||||
var activeEl = doc.activeElement;
|
|
||||||
if (alwaysCaptureHotkeys ||
|
|
||||||
activeEl == pEl ||
|
|
||||||
activeEl == pEl.querySelector('.vjs-tech') ||
|
|
||||||
activeEl == pEl.querySelector('.vjs-control-bar') ||
|
|
||||||
activeEl == pEl.querySelector('.iframeblocker')) {
|
|
||||||
|
|
||||||
switch (checkKeys(event, player)) {
|
|
||||||
// Spacebar toggles play/pause
|
|
||||||
case cPlay:
|
|
||||||
ePreventDefault();
|
|
||||||
if (alwaysCaptureHotkeys) {
|
|
||||||
// Prevent control activation with space
|
|
||||||
event.stopPropagation();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (player.paused()) {
|
|
||||||
player.play();
|
|
||||||
} else {
|
|
||||||
player.pause();
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
// Seeking with the left/right arrow keys
|
|
||||||
case cRewind: // Seek Backward
|
|
||||||
wasPlaying = !player.paused();
|
|
||||||
ePreventDefault();
|
|
||||||
if (wasPlaying) {
|
|
||||||
player.pause();
|
|
||||||
}
|
|
||||||
seekTime = player.currentTime() - seekStepD(event);
|
|
||||||
// The flash player tech will allow you to seek into negative
|
|
||||||
// numbers and break the seekbar, so try to prevent that.
|
|
||||||
if (seekTime <= 0) {
|
|
||||||
seekTime = 0;
|
|
||||||
}
|
|
||||||
player.currentTime(seekTime);
|
|
||||||
if (wasPlaying) {
|
|
||||||
player.play();
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case cForward: // Seek Forward
|
|
||||||
wasPlaying = !player.paused();
|
|
||||||
ePreventDefault();
|
|
||||||
if (wasPlaying) {
|
|
||||||
player.pause();
|
|
||||||
}
|
|
||||||
seekTime = player.currentTime() + seekStepD(event);
|
|
||||||
// Fixes the player not sending the end event if you
|
|
||||||
// try to seek past the duration on the seekbar.
|
|
||||||
if (seekTime >= duration) {
|
|
||||||
seekTime = wasPlaying ? duration - .001 : duration;
|
|
||||||
}
|
|
||||||
player.currentTime(seekTime);
|
|
||||||
if (wasPlaying) {
|
|
||||||
player.play();
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
// Volume control with the up/down arrow keys
|
|
||||||
case cVolumeDown:
|
|
||||||
ePreventDefault();
|
|
||||||
if (!enableJogStyle) {
|
|
||||||
player.volume(player.volume() - volumeStep);
|
|
||||||
} else {
|
|
||||||
seekTime = player.currentTime() - 1;
|
|
||||||
if (player.currentTime() <= 1) {
|
|
||||||
seekTime = 0;
|
|
||||||
}
|
|
||||||
player.currentTime(seekTime);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case cVolumeUp:
|
|
||||||
ePreventDefault();
|
|
||||||
if (!enableJogStyle) {
|
|
||||||
player.volume(player.volume() + volumeStep);
|
|
||||||
} else {
|
|
||||||
seekTime = player.currentTime() + 1;
|
|
||||||
if (seekTime >= duration) {
|
|
||||||
seekTime = duration;
|
|
||||||
}
|
|
||||||
player.currentTime(seekTime);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
// Toggle Mute with the M key
|
|
||||||
case cMute:
|
|
||||||
if (enableMute) {
|
|
||||||
player.muted(!player.muted());
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
// Toggle Fullscreen with the F key
|
|
||||||
case cFullscreen:
|
|
||||||
if (enableFull) {
|
|
||||||
if (player.isFullscreen()) {
|
|
||||||
player.exitFullscreen();
|
|
||||||
} else {
|
|
||||||
player.requestFullscreen();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
// Number keys from 0-9 skip to a percentage of the video. 0 is 0% and 9 is 90%
|
|
||||||
if ((ewhich > 47 && ewhich < 59) || (ewhich > 95 && ewhich < 106)) {
|
|
||||||
// Do not handle if enableModifiersForNumbers set to false and keys are Ctrl, Cmd or Alt
|
|
||||||
if (enableModifiersForNumbers || !(event.metaKey || event.ctrlKey || event.altKey)) {
|
|
||||||
if (enableNumbers) {
|
|
||||||
var sub = 48;
|
|
||||||
if (ewhich > 95) {
|
|
||||||
sub = 96;
|
|
||||||
}
|
|
||||||
var number = ewhich - sub;
|
|
||||||
ePreventDefault();
|
|
||||||
player.currentTime(player.duration() * number * 0.1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Handle any custom hotkeys
|
|
||||||
for (var customKey in options.customKeys) {
|
|
||||||
var customHotkey = options.customKeys[customKey];
|
|
||||||
// Check for well formed custom keys
|
|
||||||
if (customHotkey && customHotkey.key && customHotkey.handler) {
|
|
||||||
// Check if the custom key's condition matches
|
|
||||||
if (customHotkey.key(event)) {
|
|
||||||
ePreventDefault();
|
|
||||||
customHotkey.handler(player, options, event);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
var doubleClick = function doubleClick(event) {
|
|
||||||
// When controls are disabled, hotkeys will be disabled as well
|
|
||||||
if (player.controls()) {
|
|
||||||
|
|
||||||
// Don't catch clicks if any control buttons are focused
|
|
||||||
var activeEl = event.relatedTarget || event.toElement || doc.activeElement;
|
|
||||||
if (activeEl == pEl ||
|
|
||||||
activeEl == pEl.querySelector('.vjs-tech') ||
|
|
||||||
activeEl == pEl.querySelector('.iframeblocker')) {
|
|
||||||
|
|
||||||
if (enableFull) {
|
|
||||||
if (player.isFullscreen()) {
|
|
||||||
player.exitFullscreen();
|
|
||||||
} else {
|
|
||||||
player.requestFullscreen();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
var volumeHover = false;
|
|
||||||
var volumeSelector = pEl.querySelector('.vjs-volume-menu-button') || pEl.querySelector('.vjs-volume-panel');
|
|
||||||
volumeSelector.onmouseover = function() { volumeHover = true; }
|
|
||||||
volumeSelector.onmouseout = function() { volumeHover = false; }
|
|
||||||
|
|
||||||
var mouseScroll = function mouseScroll(event) {
|
|
||||||
if (enableHoverScroll) {
|
|
||||||
// If we leave this undefined then it can match non-existent elements below
|
|
||||||
var activeEl = 0;
|
|
||||||
} else {
|
|
||||||
var activeEl = doc.activeElement;
|
|
||||||
}
|
|
||||||
|
|
||||||
// When controls are disabled, hotkeys will be disabled as well
|
|
||||||
if (player.controls()) {
|
|
||||||
if (alwaysCaptureHotkeys ||
|
|
||||||
activeEl == pEl ||
|
|
||||||
activeEl == pEl.querySelector('.vjs-tech') ||
|
|
||||||
activeEl == pEl.querySelector('.iframeblocker') ||
|
|
||||||
activeEl == pEl.querySelector('.vjs-control-bar') ||
|
|
||||||
volumeHover) {
|
|
||||||
|
|
||||||
if (enableVolumeScroll) {
|
|
||||||
event = window.event || event;
|
|
||||||
var delta = Math.max(-1, Math.min(1, (event.wheelDelta || -event.detail)));
|
|
||||||
event.preventDefault();
|
|
||||||
|
|
||||||
if (delta == 1) {
|
|
||||||
player.volume(player.volume() + volumeStep);
|
|
||||||
} else if (delta == -1) {
|
|
||||||
player.volume(player.volume() - volumeStep);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
var checkKeys = function checkKeys(e, player) {
|
|
||||||
// Allow some modularity in defining custom hotkeys
|
|
||||||
|
|
||||||
// Play/Pause check
|
|
||||||
if (options.playPauseKey(e, player)) {
|
|
||||||
return cPlay;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Seek Backward check
|
|
||||||
if (options.rewindKey(e, player)) {
|
|
||||||
return cRewind;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Seek Forward check
|
|
||||||
if (options.forwardKey(e, player)) {
|
|
||||||
return cForward;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Volume Up check
|
|
||||||
if (options.volumeUpKey(e, player)) {
|
|
||||||
return cVolumeUp;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Volume Down check
|
|
||||||
if (options.volumeDownKey(e, player)) {
|
|
||||||
return cVolumeDown;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Mute check
|
|
||||||
if (options.muteKey(e, player)) {
|
|
||||||
return cMute;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Fullscreen check
|
|
||||||
if (options.fullscreenKey(e, player)) {
|
|
||||||
return cFullscreen;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
function playPauseKey(e) {
|
|
||||||
// Space bar or MediaPlayPause
|
|
||||||
return (e.which === 32 || e.which === 179);
|
|
||||||
}
|
|
||||||
|
|
||||||
function rewindKey(e) {
|
|
||||||
// Left Arrow or MediaRewind
|
|
||||||
return (e.which === 37 || e.which === 177);
|
|
||||||
}
|
|
||||||
|
|
||||||
function forwardKey(e) {
|
|
||||||
// Right Arrow or MediaForward
|
|
||||||
return (e.which === 39 || e.which === 176);
|
|
||||||
}
|
|
||||||
|
|
||||||
function volumeUpKey(e) {
|
|
||||||
// Up Arrow
|
|
||||||
return (e.which === 38);
|
|
||||||
}
|
|
||||||
|
|
||||||
function volumeDownKey(e) {
|
|
||||||
// Down Arrow
|
|
||||||
return (e.which === 40);
|
|
||||||
}
|
|
||||||
|
|
||||||
function muteKey(e) {
|
|
||||||
// M key
|
|
||||||
return (e.which === 77);
|
|
||||||
}
|
|
||||||
|
|
||||||
function fullscreenKey(e) {
|
|
||||||
// F key
|
|
||||||
return (e.which === 70);
|
|
||||||
}
|
|
||||||
|
|
||||||
function seekStepD(e) {
|
|
||||||
// SeekStep caller, returns an int, or a function returning an int
|
|
||||||
return (typeof seekStep === "function" ? seekStep(e) : seekStep);
|
|
||||||
}
|
|
||||||
|
|
||||||
player.on('keydown', keyDown);
|
|
||||||
player.on('dblclick', doubleClick);
|
|
||||||
player.on('mousewheel', mouseScroll);
|
|
||||||
player.on("DOMMouseScroll", mouseScroll);
|
|
||||||
|
|
||||||
return this;
|
|
||||||
};
|
|
||||||
|
|
||||||
var registerPlugin = videojs.registerPlugin || videojs.plugin;
|
|
||||||
registerPlugin('hotkeys', hotkeys);
|
|
||||||
}));
|
|
||||||
2
assets/js/videojs.hotkeys.min.js
vendored
2
assets/js/videojs.hotkeys.min.js
vendored
@@ -1,2 +0,0 @@
|
|||||||
/* videojs-hotkeys v0.2.22 - https://github.com/ctd1500/videojs-hotkeys */
|
|
||||||
!function(e,t){"undefined"!=typeof window&&window.videojs?t(window.videojs):"function"==typeof define&&define.amd?define("videojs-hotkeys",["video.js"],function(e){return t(e.default||e)}):"undefined"!=typeof module&&module.exports&&(module.exports=t(require("video.js")))}(0,function(s){"use strict";"undefined"!=typeof window&&(window.videojs_hotkeys={version:"0.2.22"});(s.registerPlugin||s.plugin)("hotkeys",function(m){var y=this,v=y.el(),f=document,e={volumeStep:.1,seekStep:5,enableMute:!0,enableVolumeScroll:!0,enableHoverScroll:!0,enableFullscreen:!0,enableNumbers:!0,enableJogStyle:!1,alwaysCaptureHotkeys:!1,enableModifiersForNumbers:!0,enableInactiveFocus:!0,skipInitialFocus:!1,playPauseKey:function(e){return 32===e.which||179===e.which},rewindKey:function(e){return 37===e.which||177===e.which},forwardKey:function(e){return 39===e.which||176===e.which},volumeUpKey:function(e){return 38===e.which},volumeDownKey:function(e){return 40===e.which},muteKey:function(e){return 77===e.which},fullscreenKey:function(e){return 70===e.which},customKeys:{}},t=s.mergeOptions||s.util.mergeOptions,d=(m=t(e,m||{})).volumeStep,n=m.seekStep,p=m.enableMute,r=m.enableVolumeScroll,o=m.enableHoverScroll,b=m.enableFullscreen,h=m.enableNumbers,w=m.enableJogStyle,k=m.alwaysCaptureHotkeys,S=m.enableModifiersForNumbers,u=m.enableInactiveFocus,l=m.skipInitialFocus;v.hasAttribute("tabIndex")||v.setAttribute("tabIndex","-1"),v.style.outline="none",!k&&y.autoplay()||l||y.one("play",function(){v.focus()}),u&&y.on("userinactive",function(){var n=function(){clearTimeout(e)},e=setTimeout(function(){y.off("useractive",n);var e=f.activeElement,t=v.querySelector(".vjs-control-bar");e&&e.parentElement==t&&v.focus()},10);y.one("useractive",n)}),y.on("play",function(){var e=v.querySelector(".iframeblocker");e&&""===e.style.display&&(e.style.display="block",e.style.bottom="39px")});var i=!1,c=v.querySelector(".vjs-volume-menu-button")||v.querySelector(".vjs-volume-panel");c.onmouseover=function(){i=!0},c.onmouseout=function(){i=!1};var a=function(e){if(o)var t=0;else t=f.activeElement;if(y.controls()&&(k||t==v||t==v.querySelector(".vjs-tech")||t==v.querySelector(".iframeblocker")||t==v.querySelector(".vjs-control-bar")||i)&&r){e=window.event||e;var n=Math.max(-1,Math.min(1,e.wheelDelta||-e.detail));e.preventDefault(),1==n?y.volume(y.volume()+d):-1==n&&y.volume(y.volume()-d)}},K=function(e,t){return m.playPauseKey(e,t)?1:m.rewindKey(e,t)?2:m.forwardKey(e,t)?3:m.volumeUpKey(e,t)?4:m.volumeDownKey(e,t)?5:m.muteKey(e,t)?6:m.fullscreenKey(e,t)?7:void 0};function q(e){return"function"==typeof n?n(e):n}return y.on("keydown",function(e){var t,n,r=e.which,o=e.preventDefault,u=y.duration();if(y.controls()){var l=f.activeElement;if(k||l==v||l==v.querySelector(".vjs-tech")||l==v.querySelector(".vjs-control-bar")||l==v.querySelector(".iframeblocker"))switch(K(e,y)){case 1:o(),k&&e.stopPropagation(),y.paused()?y.play():y.pause();break;case 2:t=!y.paused(),o(),t&&y.pause(),(n=y.currentTime()-q(e))<=0&&(n=0),y.currentTime(n),t&&y.play();break;case 3:t=!y.paused(),o(),t&&y.pause(),u<=(n=y.currentTime()+q(e))&&(n=t?u-.001:u),y.currentTime(n),t&&y.play();break;case 5:o(),w?(n=y.currentTime()-1,y.currentTime()<=1&&(n=0),y.currentTime(n)):y.volume(y.volume()-d);break;case 4:o(),w?(u<=(n=y.currentTime()+1)&&(n=u),y.currentTime(n)):y.volume(y.volume()+d);break;case 6:p&&y.muted(!y.muted());break;case 7:b&&(y.isFullscreen()?y.exitFullscreen():y.requestFullscreen());break;default:if((47<r&&r<59||95<r&&r<106)&&(S||!(e.metaKey||e.ctrlKey||e.altKey))&&h){var i=48;95<r&&(i=96);var c=r-i;o(),y.currentTime(y.duration()*c*.1)}for(var a in m.customKeys){var s=m.customKeys[a];s&&s.key&&s.handler&&s.key(e)&&(o(),s.handler(y,m,e))}}}}),y.on("dblclick",function(e){if(y.controls()){var t=e.relatedTarget||e.toElement||f.activeElement;t!=v&&t!=v.querySelector(".vjs-tech")&&t!=v.querySelector(".iframeblocker")||b&&(y.isFullscreen()?y.exitFullscreen():y.requestFullscreen())}}),y.on("mousewheel",a),y.on("DOMMouseScroll",a),this})});
|
|
||||||
@@ -1,52 +1,461 @@
|
|||||||
|
var video_data = JSON.parse(document.getElementById('video_data').innerHTML);
|
||||||
|
|
||||||
|
String.prototype.supplant = function (o) {
|
||||||
|
return this.replace(/{([^{}]*)}/g, function (a, b) {
|
||||||
|
var r = o[b];
|
||||||
|
return typeof r === 'string' || typeof r === 'number' ? r : a;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
function toggle_parent(target) {
|
function toggle_parent(target) {
|
||||||
body = target.parentNode.parentNode.children[1];
|
body = target.parentNode.parentNode.children[1];
|
||||||
if (body.style.display === null || body.style.display === "") {
|
if (body.style.display === null || body.style.display === '') {
|
||||||
target.innerHTML = "[ + ]";
|
target.innerHTML = '[ + ]';
|
||||||
body.style.display = "none";
|
body.style.display = 'none';
|
||||||
} else {
|
} else {
|
||||||
target.innerHTML = "[ - ]";
|
target.innerHTML = '[ - ]';
|
||||||
body.style.display = "";
|
body.style.display = '';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function toggle_comments(target) {
|
function toggle_comments(event) {
|
||||||
body = target.parentNode.parentNode.parentNode.children[1];
|
var target = event.target;
|
||||||
if (body.style.display === null || body.style.display === "") {
|
body = target.parentNode.parentNode.parentNode.children[1];
|
||||||
target.innerHTML = "[ + ]";
|
if (body.style.display === null || body.style.display === '') {
|
||||||
body.style.display = "none";
|
target.innerHTML = '[ + ]';
|
||||||
} else {
|
body.style.display = 'none';
|
||||||
target.innerHTML = "[ - ]";
|
} else {
|
||||||
body.style.display = "";
|
target.innerHTML = '[ - ]';
|
||||||
}
|
body.style.display = '';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function swap_comments(source) {
|
function swap_comments(event) {
|
||||||
if (source == "youtube") {
|
var source = event.target.getAttribute('data-comments');
|
||||||
get_youtube_comments();
|
|
||||||
} else if (source == "reddit") {
|
if (source === 'youtube') {
|
||||||
get_reddit_comments();
|
get_youtube_comments();
|
||||||
}
|
} else if (source === 'reddit') {
|
||||||
|
get_reddit_comments();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
String.prototype.supplant = function(o) {
|
function hide_youtube_replies(event) {
|
||||||
return this.replace(/{([^{}]*)}/g, function(a, b) {
|
var target = event.target;
|
||||||
var r = o[b];
|
|
||||||
return typeof r === "string" || typeof r === "number" ? r : a;
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
function show_youtube_replies(target, inner_text, sub_text) {
|
sub_text = target.getAttribute('data-inner-text');
|
||||||
body = target.parentNode.parentNode.children[1];
|
inner_text = target.getAttribute('data-sub-text');
|
||||||
body.style.display = "";
|
|
||||||
|
|
||||||
target.innerHTML = inner_text;
|
body = target.parentNode.parentNode.children[1];
|
||||||
target.setAttribute("onclick", "hide_youtube_replies(this, \'" + inner_text + "\', \'" + sub_text + "\')");
|
body.style.display = 'none';
|
||||||
|
|
||||||
|
target.innerHTML = sub_text;
|
||||||
|
target.onclick = show_youtube_replies;
|
||||||
|
target.setAttribute('data-inner-text', inner_text);
|
||||||
|
target.setAttribute('data-sub-text', sub_text);
|
||||||
}
|
}
|
||||||
|
|
||||||
function hide_youtube_replies(target, inner_text, sub_text) {
|
function show_youtube_replies(event) {
|
||||||
body = target.parentNode.parentNode.children[1];
|
var target = event.target;
|
||||||
body.style.display = "none";
|
|
||||||
|
|
||||||
target.innerHTML = sub_text;
|
sub_text = target.getAttribute('data-inner-text');
|
||||||
target.setAttribute("onclick", "show_youtube_replies(this, \'" + inner_text + "\', \'" + sub_text + "\')");
|
inner_text = target.getAttribute('data-sub-text');
|
||||||
|
|
||||||
|
body = target.parentNode.parentNode.children[1];
|
||||||
|
body.style.display = '';
|
||||||
|
|
||||||
|
target.innerHTML = sub_text;
|
||||||
|
target.onclick = hide_youtube_replies;
|
||||||
|
target.setAttribute('data-inner-text', inner_text);
|
||||||
|
target.setAttribute('data-sub-text', sub_text);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var continue_button = document.getElementById('continue');
|
||||||
|
if (continue_button) {
|
||||||
|
continue_button.onclick = continue_autoplay;
|
||||||
|
}
|
||||||
|
|
||||||
|
function next_video() {
|
||||||
|
var url = new URL('https://example.com/watch?v=' + video_data.next_video);
|
||||||
|
|
||||||
|
if (video_data.params.autoplay || video_data.params.continue_autoplay) {
|
||||||
|
url.searchParams.set('autoplay', '1');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (video_data.params.listen !== video_data.preferences.listen) {
|
||||||
|
url.searchParams.set('listen', video_data.params.listen);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (video_data.params.speed !== video_data.preferences.speed) {
|
||||||
|
url.searchParams.set('speed', video_data.params.speed);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (video_data.params.local !== video_data.preferences.local) {
|
||||||
|
url.searchParams.set('local', video_data.params.local);
|
||||||
|
}
|
||||||
|
|
||||||
|
url.searchParams.set('continue', '1');
|
||||||
|
location.assign(url.pathname + url.search);
|
||||||
|
}
|
||||||
|
|
||||||
|
function continue_autoplay(event) {
|
||||||
|
if (event.target.checked) {
|
||||||
|
player.on('ended', function () {
|
||||||
|
next_video();
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
player.off('ended');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function number_with_separator(val) {
|
||||||
|
while (/(\d+)(\d{3})/.test(val.toString())) {
|
||||||
|
val = val.toString().replace(/(\d+)(\d{3})/, '$1' + ',' + '$2');
|
||||||
|
}
|
||||||
|
return val;
|
||||||
|
}
|
||||||
|
|
||||||
|
function get_playlist(plid, retries) {
|
||||||
|
if (retries == undefined) retries = 5;
|
||||||
|
playlist = document.getElementById('playlist');
|
||||||
|
|
||||||
|
if (retries <= 0) {
|
||||||
|
console.log('Failed to pull playlist');
|
||||||
|
playlist.innerHTML = '';
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
playlist.innerHTML = ' \
|
||||||
|
<h3 style="text-align:center"><div class="loading"><i class="icon ion-ios-refresh"></i></div></h3> \
|
||||||
|
<hr>'
|
||||||
|
|
||||||
|
if (plid.startsWith('RD')) {
|
||||||
|
var plid_url = '/api/v1/mixes/' + plid +
|
||||||
|
'?continuation=' + video_data.id +
|
||||||
|
'&format=html&hl=' + video_data.preferences.locale;
|
||||||
|
} else {
|
||||||
|
var plid_url = '/api/v1/playlists/' + plid +
|
||||||
|
'?index=' + video_data.index +
|
||||||
|
'&continuation=' + video_data.id +
|
||||||
|
'&format=html&hl=' + video_data.preferences.locale;
|
||||||
|
}
|
||||||
|
|
||||||
|
var xhr = new XMLHttpRequest();
|
||||||
|
xhr.responseType = 'json';
|
||||||
|
xhr.timeout = 10000;
|
||||||
|
xhr.open('GET', plid_url, true);
|
||||||
|
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
if (xhr.readyState == 4) {
|
||||||
|
if (xhr.status == 200) {
|
||||||
|
playlist.innerHTML = xhr.response.playlistHtml;
|
||||||
|
|
||||||
|
if (xhr.response.nextVideo) {
|
||||||
|
player.on('ended', function () {
|
||||||
|
var url = new URL('https://example.com/watch?v=' + xhr.response.nextVideo);
|
||||||
|
|
||||||
|
if (video_data.params.autoplay || video_data.params.continue_autoplay) {
|
||||||
|
url.searchParams.set('autoplay', '1');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (video_data.params.listen !== video_data.preferences.listen) {
|
||||||
|
url.searchParams.set('listen', video_data.params.listen);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (video_data.params.speed !== video_data.preferences.speed) {
|
||||||
|
url.searchParams.set('speed', video_data.params.speed);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (video_data.params.local !== video_data.preferences.local) {
|
||||||
|
url.searchParams.set('local', video_data.params.local);
|
||||||
|
}
|
||||||
|
|
||||||
|
url.searchParams.set('list', plid);
|
||||||
|
if (!plid.startsWith('RD')) {
|
||||||
|
url.searchParams.set('index', xhr.response.index);
|
||||||
|
}
|
||||||
|
location.assign(url.pathname + url.search);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
playlist.innerHTML = '';
|
||||||
|
document.getElementById('continue').style.display = '';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.onerror = function () {
|
||||||
|
playlist = document.getElementById('playlist');
|
||||||
|
playlist.innerHTML =
|
||||||
|
'<h3 style="text-align:center"><div class="loading"><i class="icon ion-ios-refresh"></i></div></h3><hr>';
|
||||||
|
|
||||||
|
console.log('Pulling playlist timed out... ' + retries + '/5');
|
||||||
|
setTimeout(function () { get_playlist(plid, retries - 1) }, 1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.ontimeout = function () {
|
||||||
|
playlist = document.getElementById('playlist');
|
||||||
|
playlist.innerHTML =
|
||||||
|
'<h3 style="text-align:center"><div class="loading"><i class="icon ion-ios-refresh"></i></div></h3><hr>';
|
||||||
|
|
||||||
|
console.log('Pulling playlist timed out... ' + retries + '/5');
|
||||||
|
get_playlist(plid, retries - 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.send();
|
||||||
|
}
|
||||||
|
|
||||||
|
function get_reddit_comments(retries) {
|
||||||
|
if (retries == undefined) retries = 5;
|
||||||
|
comments = document.getElementById('comments');
|
||||||
|
|
||||||
|
if (retries <= 0) {
|
||||||
|
console.log('Failed to pull comments');
|
||||||
|
comments.innerHTML = '';
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var fallback = comments.innerHTML;
|
||||||
|
comments.innerHTML =
|
||||||
|
'<h3 style="text-align:center"><div class="loading"><i class="icon ion-ios-refresh"></i></div></h3>';
|
||||||
|
|
||||||
|
var url = '/api/v1/comments/' + video_data.id +
|
||||||
|
'?source=reddit&format=html' +
|
||||||
|
'&hl=' + video_data.preferences.locale;
|
||||||
|
var xhr = new XMLHttpRequest();
|
||||||
|
xhr.responseType = 'json';
|
||||||
|
xhr.timeout = 10000;
|
||||||
|
xhr.open('GET', url, true);
|
||||||
|
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
if (xhr.readyState == 4) {
|
||||||
|
if (xhr.status == 200) {
|
||||||
|
comments.innerHTML = ' \
|
||||||
|
<div> \
|
||||||
|
<h3> \
|
||||||
|
<a href="javascript:void(0)">[ - ]</a> \
|
||||||
|
{title} \
|
||||||
|
</h3> \
|
||||||
|
<p> \
|
||||||
|
<b> \
|
||||||
|
<a href="javascript:void(0)" data-comments="youtube"> \
|
||||||
|
{youtubeCommentsText} \
|
||||||
|
</a> \
|
||||||
|
</b> \
|
||||||
|
</p> \
|
||||||
|
<b> \
|
||||||
|
<a rel="noopener" target="_blank" href="https://reddit.com{permalink}">{redditPermalinkText}</a> \
|
||||||
|
</b> \
|
||||||
|
</div> \
|
||||||
|
<div>{contentHtml}</div> \
|
||||||
|
<hr>'.supplant({
|
||||||
|
title: xhr.response.title,
|
||||||
|
youtubeCommentsText: video_data.youtube_comments_text,
|
||||||
|
redditPermalinkText: video_data.reddit_permalink_text,
|
||||||
|
permalink: xhr.response.permalink,
|
||||||
|
contentHtml: xhr.response.contentHtml
|
||||||
|
});
|
||||||
|
|
||||||
|
comments.children[0].children[0].children[0].onclick = toggle_comments;
|
||||||
|
comments.children[0].children[1].children[0].onclick = swap_comments;
|
||||||
|
} else {
|
||||||
|
if (video_data.params.comments[1] === 'youtube') {
|
||||||
|
console.log('Pulling comments failed... ' + retries + '/5');
|
||||||
|
setTimeout(function () { get_youtube_comments(retries - 1) }, 1000);
|
||||||
|
} else {
|
||||||
|
comments.innerHTML = fallback;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.onerror = function () {
|
||||||
|
console.log('Pulling comments failed... ' + retries + '/5');
|
||||||
|
setInterval(function () { get_reddit_comments(retries - 1) }, 1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.ontimeout = function () {
|
||||||
|
console.log('Pulling comments failed... ' + retries + '/5');
|
||||||
|
get_reddit_comments(retries - 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.send();
|
||||||
|
}
|
||||||
|
|
||||||
|
function get_youtube_comments(retries) {
|
||||||
|
if (retries == undefined) retries = 5;
|
||||||
|
comments = document.getElementById('comments');
|
||||||
|
|
||||||
|
if (retries <= 0) {
|
||||||
|
console.log('Failed to pull comments');
|
||||||
|
comments.innerHTML = '';
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var fallback = comments.innerHTML;
|
||||||
|
comments.innerHTML =
|
||||||
|
'<h3 style="text-align:center"><div class="loading"><i class="icon ion-ios-refresh"></i></div></h3>';
|
||||||
|
|
||||||
|
var url = '/api/v1/comments/' + video_data.id +
|
||||||
|
'?format=html' +
|
||||||
|
'&hl=' + video_data.preferences.locale +
|
||||||
|
'&thin_mode=' + video_data.preferences.thin_mode;
|
||||||
|
var xhr = new XMLHttpRequest();
|
||||||
|
xhr.responseType = 'json';
|
||||||
|
xhr.timeout = 10000;
|
||||||
|
xhr.open('GET', url, true);
|
||||||
|
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
if (xhr.readyState == 4) {
|
||||||
|
if (xhr.status == 200) {
|
||||||
|
comments.innerHTML = ' \
|
||||||
|
<div> \
|
||||||
|
<h3> \
|
||||||
|
<a href="javascript:void(0)">[ - ]</a> \
|
||||||
|
{commentsText} \
|
||||||
|
</h3> \
|
||||||
|
<b> \
|
||||||
|
<a href="javascript:void(0)" data-comments="reddit"> \
|
||||||
|
{redditComments} \
|
||||||
|
</a> \
|
||||||
|
</b> \
|
||||||
|
</div> \
|
||||||
|
<div>{contentHtml}</div> \
|
||||||
|
<hr>'.supplant({
|
||||||
|
contentHtml: xhr.response.contentHtml,
|
||||||
|
redditComments: video_data.reddit_comments_text,
|
||||||
|
commentsText: video_data.comments_text.supplant(
|
||||||
|
{ commentCount: number_with_separator(xhr.response.commentCount) }
|
||||||
|
)
|
||||||
|
});
|
||||||
|
|
||||||
|
comments.children[0].children[0].children[0].onclick = toggle_comments;
|
||||||
|
comments.children[0].children[1].children[0].onclick = swap_comments;
|
||||||
|
} else {
|
||||||
|
if (video_data.params.comments[1] === 'youtube') {
|
||||||
|
setTimeout(function () { get_youtube_comments(retries - 1) }, 1000);
|
||||||
|
} else {
|
||||||
|
comments.innerHTML = '';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.onerror = function () {
|
||||||
|
comments.innerHTML =
|
||||||
|
'<h3 style="text-align:center"><div class="loading"><i class="icon ion-ios-refresh"></i></div></h3>';
|
||||||
|
console.log('Pulling comments failed... ' + retries + '/5');
|
||||||
|
setInterval(function () { get_youtube_comments(retries - 1) }, 1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.ontimeout = function () {
|
||||||
|
comments.innerHTML =
|
||||||
|
'<h3 style="text-align:center"><div class="loading"><i class="icon ion-ios-refresh"></i></div></h3>';
|
||||||
|
console.log('Pulling comments failed... ' + retries + '/5');
|
||||||
|
get_youtube_comments(retries - 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.send();
|
||||||
|
}
|
||||||
|
|
||||||
|
function get_youtube_replies(target, load_more) {
|
||||||
|
var continuation = target.getAttribute('data-continuation');
|
||||||
|
|
||||||
|
var body = target.parentNode.parentNode;
|
||||||
|
var fallback = body.innerHTML;
|
||||||
|
body.innerHTML =
|
||||||
|
'<h3 style="text-align:center"><div class="loading"><i class="icon ion-ios-refresh"></i></div></h3>';
|
||||||
|
|
||||||
|
var url = '/api/v1/comments/' + video_data.id +
|
||||||
|
'?format=html' +
|
||||||
|
'&hl=' + video_data.preferences.locale +
|
||||||
|
'&thin_mode=' + video_data.preferences.thin_mode +
|
||||||
|
'&continuation=' + continuation;
|
||||||
|
var xhr = new XMLHttpRequest();
|
||||||
|
xhr.responseType = 'json';
|
||||||
|
xhr.timeout = 10000;
|
||||||
|
xhr.open('GET', url, true);
|
||||||
|
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
if (xhr.readyState == 4) {
|
||||||
|
if (xhr.status == 200) {
|
||||||
|
if (load_more) {
|
||||||
|
body = body.parentNode.parentNode;
|
||||||
|
body.removeChild(body.lastElementChild);
|
||||||
|
body.innerHTML += xhr.response.contentHtml;
|
||||||
|
} else {
|
||||||
|
body.removeChild(body.lastElementChild);
|
||||||
|
|
||||||
|
var p = document.createElement('p');
|
||||||
|
var a = document.createElement('a');
|
||||||
|
p.appendChild(a);
|
||||||
|
|
||||||
|
a.href = 'javascript:void(0)';
|
||||||
|
a.onclick = hide_youtube_replies;
|
||||||
|
a.setAttribute('data-sub-text', video_data.hide_replies_text);
|
||||||
|
a.setAttribute('data-inner-text', video_data.show_replies_text);
|
||||||
|
a.innerText = video_data.hide_replies_text;
|
||||||
|
|
||||||
|
var div = document.createElement('div');
|
||||||
|
div.innerHTML = xhr.response.contentHtml;
|
||||||
|
|
||||||
|
body.appendChild(p);
|
||||||
|
body.appendChild(div);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
body.innerHTML = fallback;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.ontimeout = function () {
|
||||||
|
console.log('Pulling comments failed.');
|
||||||
|
body.innerHTML = fallback;
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.send();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (video_data.play_next) {
|
||||||
|
player.on('ended', function () {
|
||||||
|
var url = new URL('https://example.com/watch?v=' + video_data.next_video);
|
||||||
|
|
||||||
|
if (video_data.params.autoplay || video_data.params.continue_autoplay) {
|
||||||
|
url.searchParams.set('autoplay', '1');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (video_data.params.listen !== video_data.preferences.listen) {
|
||||||
|
url.searchParams.set('listen', video_data.params.listen);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (video_data.params.speed !== video_data.preferences.speed) {
|
||||||
|
url.searchParams.set('speed', video_data.params.speed);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (video_data.params.local !== video_data.preferences.local) {
|
||||||
|
url.searchParams.set('local', video_data.params.local);
|
||||||
|
}
|
||||||
|
|
||||||
|
url.searchParams.set('continue', '1');
|
||||||
|
location.assign(url.pathname + url.search);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
window.addEventListener('load', function (e) {
|
||||||
|
if (video_data.plid) {
|
||||||
|
get_playlist(video_data.plid);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (video_data.params.comments[0] === 'youtube') {
|
||||||
|
get_youtube_comments();
|
||||||
|
} else if (video_data.params.comments[0] === 'reddit') {
|
||||||
|
get_reddit_comments();
|
||||||
|
} else if (video_data.params.comments[1] === 'youtube') {
|
||||||
|
get_youtube_comments();
|
||||||
|
} else if (video_data.params.comments[1] === 'reddit') {
|
||||||
|
get_reddit_comments();
|
||||||
|
} else {
|
||||||
|
comments = document.getElementById('comments');
|
||||||
|
comments.innerHTML = '';
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|||||||
50
assets/js/watched_widget.js
Normal file
50
assets/js/watched_widget.js
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
var watched_data = JSON.parse(document.getElementById('watched_data').innerHTML);
|
||||||
|
|
||||||
|
function mark_watched(target) {
|
||||||
|
var tile = target.parentNode.parentNode.parentNode.parentNode.parentNode;
|
||||||
|
tile.style.display = 'none';
|
||||||
|
|
||||||
|
var url = '/watch_ajax?action_mark_watched=1&redirect=false' +
|
||||||
|
'&id=' + target.getAttribute('data-id');
|
||||||
|
var xhr = new XMLHttpRequest();
|
||||||
|
xhr.responseType = 'json';
|
||||||
|
xhr.timeout = 10000;
|
||||||
|
xhr.open('POST', url, true);
|
||||||
|
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
|
||||||
|
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
if (xhr.readyState == 4) {
|
||||||
|
if (xhr.status != 200) {
|
||||||
|
tile.style.display = '';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.send('csrf_token=' + watched_data.csrf_token);
|
||||||
|
}
|
||||||
|
|
||||||
|
function mark_unwatched(target) {
|
||||||
|
var tile = target.parentNode.parentNode.parentNode.parentNode.parentNode;
|
||||||
|
tile.style.display = 'none';
|
||||||
|
var count = document.getElementById('count')
|
||||||
|
count.innerText = count.innerText - 1;
|
||||||
|
|
||||||
|
var url = '/watch_ajax?action_mark_unwatched=1&redirect=false' +
|
||||||
|
'&id=' + target.getAttribute('data-id');
|
||||||
|
var xhr = new XMLHttpRequest();
|
||||||
|
xhr.responseType = 'json';
|
||||||
|
xhr.timeout = 10000;
|
||||||
|
xhr.open('POST', url, true);
|
||||||
|
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
|
||||||
|
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
if (xhr.readyState == 4) {
|
||||||
|
if (xhr.status != 200) {
|
||||||
|
count.innerText = count.innerText - 1 + 2;
|
||||||
|
tile.style.display = '';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
xhr.send('csrf_token=' + watched_data.csrf_token);
|
||||||
|
}
|
||||||
@@ -1,5 +1,3 @@
|
|||||||
video_threads: 0
|
|
||||||
crawl_threads: 0
|
|
||||||
channel_threads: 1
|
channel_threads: 1
|
||||||
feed_threads: 1
|
feed_threads: 1
|
||||||
db:
|
db:
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
psql invidious -c "ALTER TABLE channels ADD COLUMN subscribed bool;"
|
psql invidious kemal -c "ALTER TABLE channels ADD COLUMN subscribed bool;"
|
||||||
psql invidious -c "UPDATE channels SET subscribed = false;"
|
psql invidious kemal -c "UPDATE channels SET subscribed = false;"
|
||||||
|
|||||||
7
config/migrate-scripts/migrate-db-1c8075c.sh
Executable file
7
config/migrate-scripts/migrate-db-1c8075c.sh
Executable file
@@ -0,0 +1,7 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
psql invidious kemal -c "ALTER TABLE channel_videos DROP COLUMN live_now CASCADE"
|
||||||
|
psql invidious kemal -c "ALTER TABLE channel_videos DROP COLUMN premiere_timestamp CASCADE"
|
||||||
|
|
||||||
|
psql invidious kemal -c "ALTER TABLE channel_videos ADD COLUMN live_now bool"
|
||||||
|
psql invidious kemal -c "ALTER TABLE channel_videos ADD COLUMN premiere_timestamp timestamptz"
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
psql invidious -c "ALTER TABLE channels ADD COLUMN deleted bool;"
|
psql invidious kemal -c "ALTER TABLE channels ADD COLUMN deleted bool;"
|
||||||
psql invidious -c "UPDATE channels SET deleted = false;"
|
psql invidious kemal -c "UPDATE channels SET deleted = false;"
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
psql invidious < config/sql/session_ids.sql
|
psql invidious kemal < config/sql/session_ids.sql
|
||||||
psql invidious -c "INSERT INTO session_ids (SELECT unnest(id), email, CURRENT_TIMESTAMP FROM users) ON CONFLICT (id) DO NOTHING"
|
psql invidious kemal -c "INSERT INTO session_ids (SELECT unnest(id), email, CURRENT_TIMESTAMP FROM users) ON CONFLICT (id) DO NOTHING"
|
||||||
psql invidious -c "ALTER TABLE users DROP COLUMN id"
|
psql invidious kemal -c "ALTER TABLE users DROP COLUMN id"
|
||||||
|
|||||||
3
config/migrate-scripts/migrate-db-3bcb98e.sh
Executable file
3
config/migrate-scripts/migrate-db-3bcb98e.sh
Executable file
@@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
psql invidious kemal < config/sql/annotations.sql
|
||||||
3
config/migrate-scripts/migrate-db-52cb239.sh
Executable file
3
config/migrate-scripts/migrate-db-52cb239.sh
Executable file
@@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
psql invidious kemal -c "ALTER TABLE channel_videos ADD COLUMN views bigint;"
|
||||||
4
config/migrate-scripts/migrate-db-6e51189.sh
Executable file
4
config/migrate-scripts/migrate-db-6e51189.sh
Executable file
@@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
psql invidious kemal -c "ALTER TABLE channel_videos ADD COLUMN live_now bool;"
|
||||||
|
psql invidious kemal -c "UPDATE channel_videos SET live_now = false;"
|
||||||
3
config/migrate-scripts/migrate-db-701b5ea.sh
Executable file
3
config/migrate-scripts/migrate-db-701b5ea.sh
Executable file
@@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
psql invidious kemal -c "ALTER TABLE users ADD COLUMN feed_needs_update boolean"
|
||||||
3
config/migrate-scripts/migrate-db-88b7097.sh
Executable file
3
config/migrate-scripts/migrate-db-88b7097.sh
Executable file
@@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
psql invidious kemal -c "ALTER TABLE channel_videos ADD COLUMN premiere_timestamp timestamptz;"
|
||||||
5
config/migrate-scripts/migrate-db-8e884fe.sh
Executable file
5
config/migrate-scripts/migrate-db-8e884fe.sh
Executable file
@@ -0,0 +1,5 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
psql invidious kemal -c "ALTER TABLE channels DROP COLUMN subscribed"
|
||||||
|
psql invidious kemal -c "ALTER TABLE channels ADD COLUMN subscribed timestamptz"
|
||||||
|
psql invidious kemal -c "UPDATE channels SET subscribed = '2019-01-01 00:00:00+00'"
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
|
|
||||||
psql invidious -c "ALTER TABLE channels DROP COLUMN subscribed"
|
|
||||||
psql invidious -c "ALTER TABLE channels ADD COLUMN subscribed timestamptz"
|
|
||||||
psql invidious -c "UPDATE channels SET subscribed = '2019-01-01 00:00:00+00'"
|
|
||||||
12
config/sql/annotations.sql
Normal file
12
config/sql/annotations.sql
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
-- Table: public.annotations
|
||||||
|
|
||||||
|
-- DROP TABLE public.annotations;
|
||||||
|
|
||||||
|
CREATE TABLE public.annotations
|
||||||
|
(
|
||||||
|
id text NOT NULL,
|
||||||
|
annotations xml,
|
||||||
|
CONSTRAINT annotations_id_key UNIQUE (id)
|
||||||
|
);
|
||||||
|
|
||||||
|
GRANT ALL ON TABLE public.annotations TO kemal;
|
||||||
@@ -11,20 +11,14 @@ CREATE TABLE public.channel_videos
|
|||||||
ucid text,
|
ucid text,
|
||||||
author text,
|
author text,
|
||||||
length_seconds integer,
|
length_seconds integer,
|
||||||
|
live_now boolean,
|
||||||
|
premiere_timestamp timestamp with time zone,
|
||||||
|
views bigint,
|
||||||
CONSTRAINT channel_videos_id_key UNIQUE (id)
|
CONSTRAINT channel_videos_id_key UNIQUE (id)
|
||||||
);
|
);
|
||||||
|
|
||||||
GRANT ALL ON TABLE public.channel_videos TO kemal;
|
GRANT ALL ON TABLE public.channel_videos TO kemal;
|
||||||
|
|
||||||
-- Index: public.channel_videos_published_idx
|
|
||||||
|
|
||||||
-- DROP INDEX public.channel_videos_published_idx;
|
|
||||||
|
|
||||||
CREATE INDEX channel_videos_published_idx
|
|
||||||
ON public.channel_videos
|
|
||||||
USING btree
|
|
||||||
(published);
|
|
||||||
|
|
||||||
-- Index: public.channel_videos_ucid_idx
|
-- Index: public.channel_videos_ucid_idx
|
||||||
|
|
||||||
-- DROP INDEX public.channel_videos_ucid_idx;
|
-- DROP INDEX public.channel_videos_ucid_idx;
|
||||||
|
|||||||
19
config/sql/playlist_videos.sql
Normal file
19
config/sql/playlist_videos.sql
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
-- Table: public.playlist_videos
|
||||||
|
|
||||||
|
-- DROP TABLE public.playlist_videos;
|
||||||
|
|
||||||
|
CREATE TABLE playlist_videos
|
||||||
|
(
|
||||||
|
title text,
|
||||||
|
id text,
|
||||||
|
author text,
|
||||||
|
ucid text,
|
||||||
|
length_seconds integer,
|
||||||
|
published timestamptz,
|
||||||
|
plid text references playlists(id),
|
||||||
|
index int8,
|
||||||
|
live_now boolean,
|
||||||
|
PRIMARY KEY (index,plid)
|
||||||
|
);
|
||||||
|
|
||||||
|
GRANT ALL ON TABLE public.playlist_videos TO kemal;
|
||||||
29
config/sql/playlists.sql
Normal file
29
config/sql/playlists.sql
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
-- Type: public.privacy
|
||||||
|
|
||||||
|
-- DROP TYPE public.privacy;
|
||||||
|
|
||||||
|
CREATE TYPE public.privacy AS ENUM
|
||||||
|
(
|
||||||
|
'Public',
|
||||||
|
'Unlisted',
|
||||||
|
'Private'
|
||||||
|
);
|
||||||
|
|
||||||
|
-- Table: public.playlists
|
||||||
|
|
||||||
|
-- DROP TABLE public.playlists;
|
||||||
|
|
||||||
|
CREATE TABLE public.playlists
|
||||||
|
(
|
||||||
|
title text,
|
||||||
|
id text primary key,
|
||||||
|
author text,
|
||||||
|
description text,
|
||||||
|
video_count integer,
|
||||||
|
created timestamptz,
|
||||||
|
updated timestamptz,
|
||||||
|
privacy privacy,
|
||||||
|
index int8[]
|
||||||
|
);
|
||||||
|
|
||||||
|
GRANT ALL ON public.playlists TO kemal;
|
||||||
@@ -12,6 +12,7 @@ CREATE TABLE public.users
|
|||||||
password text,
|
password text,
|
||||||
token text,
|
token text,
|
||||||
watched text[],
|
watched text[],
|
||||||
|
feed_needs_update boolean,
|
||||||
CONSTRAINT users_email_key UNIQUE (email)
|
CONSTRAINT users_email_key UNIQUE (email)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|||||||
@@ -7,13 +7,29 @@ services:
|
|||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
volumes:
|
volumes:
|
||||||
- postgresdata:/var/lib/postgresql/data
|
- postgresdata:/var/lib/postgresql/data
|
||||||
|
healthcheck:
|
||||||
|
test: ["CMD", "pg_isready", "-U", "postgres"]
|
||||||
invidious:
|
invidious:
|
||||||
build:
|
build:
|
||||||
context: .
|
context: .
|
||||||
dockerfile: docker/Dockerfile
|
dockerfile: docker/Dockerfile
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
ports:
|
ports:
|
||||||
- "3000:3000"
|
- "127.0.0.1:3000:3000"
|
||||||
|
environment:
|
||||||
|
# Adapted from ./config/config.yml
|
||||||
|
INVIDIOUS_CONFIG: |
|
||||||
|
channel_threads: 1
|
||||||
|
feed_threads: 1
|
||||||
|
db:
|
||||||
|
user: kemal
|
||||||
|
password: kemal
|
||||||
|
host: postgres
|
||||||
|
port: 5432
|
||||||
|
dbname: invidious
|
||||||
|
full_refresh: false
|
||||||
|
https_only: false
|
||||||
|
domain:
|
||||||
depends_on:
|
depends_on:
|
||||||
- postgres
|
- postgres
|
||||||
|
|
||||||
|
|||||||
@@ -1,15 +1,38 @@
|
|||||||
FROM archlinux/base
|
FROM alpine:edge AS builder
|
||||||
|
RUN apk add --no-cache curl crystal shards libc-dev \
|
||||||
RUN pacman -Sy --noconfirm shards crystal imagemagick librsvg \
|
yaml-dev libxml2-dev sqlite-dev zlib-dev openssl-dev \
|
||||||
which pkgconf gcc ttf-liberation
|
yaml-static sqlite-static zlib-static openssl-libs-static
|
||||||
# base-devel contains many other basic packages, that are normally assumed to already exist on a clean arch system
|
|
||||||
|
|
||||||
ADD . /invidious
|
|
||||||
|
|
||||||
WORKDIR /invidious
|
WORKDIR /invidious
|
||||||
|
RUN curl -Lo /etc/apk/keys/omarroth.rsa.pub https://github.com/omarroth/boringssl-alpine/releases/download/1.1.0-r0/omarroth.rsa.pub && \
|
||||||
|
curl -Lo boringssl-dev.apk https://github.com/omarroth/boringssl-alpine/releases/download/1.1.0-r0/boringssl-dev-1.1.0-r0.apk && \
|
||||||
|
curl -Lo lsquic.apk https://github.com/omarroth/lsquic-alpine/releases/download/2.6.3-r0/lsquic-2.6.3-r0.apk && \
|
||||||
|
apk verify --no-cache boringssl-dev.apk lsquic.apk && \
|
||||||
|
tar -xf boringssl-dev.apk usr/lib/libcrypto.a usr/lib/libssl.a && \
|
||||||
|
tar -xf lsquic.apk usr/lib/liblsquic.a && \
|
||||||
|
rm /etc/apk/keys/omarroth.rsa.pub boringssl-dev.apk lsquic.apk
|
||||||
|
COPY ./shard.yml ./shard.yml
|
||||||
|
RUN shards update && shards install && \
|
||||||
|
mv ./usr/lib/* ./lib/lsquic/src/lsquic/ext && \
|
||||||
|
rm -r ./usr /root/.cache
|
||||||
|
COPY ./src/ ./src/
|
||||||
|
# TODO: .git folder is required for building – this is destructive.
|
||||||
|
# See definition of CURRENT_BRANCH, CURRENT_COMMIT and CURRENT_VERSION.
|
||||||
|
COPY ./.git/ ./.git/
|
||||||
|
RUN crystal build ./src/invidious.cr \
|
||||||
|
--static --warnings all --error-on-warnings \
|
||||||
|
--link-flags "-lxml2 -llzma"
|
||||||
|
|
||||||
RUN sed -i 's/host: localhost/host: postgres/' config/config.yml && \
|
FROM alpine:latest
|
||||||
shards update && shards install && \
|
RUN apk add --no-cache librsvg ttf-opensans
|
||||||
crystal build src/invidious.cr
|
WORKDIR /invidious
|
||||||
|
RUN addgroup -g 1000 -S invidious && \
|
||||||
|
adduser -u 1000 -S invidious -G invidious
|
||||||
|
COPY ./assets/ ./assets/
|
||||||
|
COPY --chown=invidious ./config/config.yml ./config/config.yml
|
||||||
|
RUN sed -i 's/host: \(127.0.0.1\|localhost\)/host: postgres/' config/config.yml
|
||||||
|
COPY ./config/sql/ ./config/sql/
|
||||||
|
COPY ./locales/ ./locales/
|
||||||
|
COPY --from=builder /invidious/invidious .
|
||||||
|
|
||||||
|
USER invidious
|
||||||
CMD [ "/invidious/invidious" ]
|
CMD [ "/invidious/invidious" ]
|
||||||
|
|||||||
@@ -1,6 +1,9 @@
|
|||||||
FROM postgres:10
|
FROM postgres:10
|
||||||
|
|
||||||
ENV POSTGRES_USER postgres
|
ENV POSTGRES_USER postgres
|
||||||
|
# Do not require a PostgreSQL superuser password.
|
||||||
|
# See https://github.com/docker-library/postgres/issues/681.
|
||||||
|
ENV POSTGRES_HOST_AUTH_METHOD trust
|
||||||
|
|
||||||
ADD ./config/sql /config/sql
|
ADD ./config/sql /config/sql
|
||||||
ADD ./docker/entrypoint.postgres.sh /entrypoint.sh
|
ADD ./docker/entrypoint.postgres.sh /entrypoint.sh
|
||||||
|
|||||||
@@ -12,12 +12,15 @@ if [ ! -f /var/lib/postgresql/data/setupFinished ]; then
|
|||||||
>&2 echo "### importing table schemas"
|
>&2 echo "### importing table schemas"
|
||||||
su postgres -c 'createdb invidious'
|
su postgres -c 'createdb invidious'
|
||||||
su postgres -c 'psql -c "CREATE USER kemal WITH PASSWORD '"'kemal'"'"'
|
su postgres -c 'psql -c "CREATE USER kemal WITH PASSWORD '"'kemal'"'"'
|
||||||
su postgres -c 'psql invidious < config/sql/channels.sql'
|
su postgres -c 'psql invidious kemal < config/sql/channels.sql'
|
||||||
su postgres -c 'psql invidious < config/sql/videos.sql'
|
su postgres -c 'psql invidious kemal < config/sql/videos.sql'
|
||||||
su postgres -c 'psql invidious < config/sql/channel_videos.sql'
|
su postgres -c 'psql invidious kemal < config/sql/channel_videos.sql'
|
||||||
su postgres -c 'psql invidious < config/sql/users.sql'
|
su postgres -c 'psql invidious kemal < config/sql/users.sql'
|
||||||
su postgres -c 'psql invidious < config/sql/session_ids.sql'
|
su postgres -c 'psql invidious kemal < config/sql/session_ids.sql'
|
||||||
su postgres -c 'psql invidious < config/sql/nonces.sql'
|
su postgres -c 'psql invidious kemal < config/sql/nonces.sql'
|
||||||
|
su postgres -c 'psql invidious kemal < config/sql/annotations.sql'
|
||||||
|
su postgres -c 'psql invidious kemal < config/sql/playlists.sql'
|
||||||
|
su postgres -c 'psql invidious kemal < config/sql/playlist_videos.sql'
|
||||||
touch /var/lib/postgresql/data/setupFinished
|
touch /var/lib/postgresql/data/setupFinished
|
||||||
echo "### invidious database setup finished"
|
echo "### invidious database setup finished"
|
||||||
exit
|
exit
|
||||||
|
|||||||
1
kubernetes/.gitignore
vendored
Normal file
1
kubernetes/.gitignore
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
/charts/*.tgz
|
||||||
6
kubernetes/Chart.lock
Normal file
6
kubernetes/Chart.lock
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
dependencies:
|
||||||
|
- name: postgresql
|
||||||
|
repository: https://kubernetes-charts.storage.googleapis.com/
|
||||||
|
version: 8.3.0
|
||||||
|
digest: sha256:1feec3c396cbf27573dc201831ccd3376a4a6b58b2e7618ce30a89b8f5d707fd
|
||||||
|
generated: "2020-02-07T13:39:38.624846+01:00"
|
||||||
22
kubernetes/Chart.yaml
Normal file
22
kubernetes/Chart.yaml
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
apiVersion: v2
|
||||||
|
name: invidious
|
||||||
|
description: Invidious is an alternative front-end to YouTube
|
||||||
|
version: 1.0.0
|
||||||
|
appVersion: 0.20.1
|
||||||
|
keywords:
|
||||||
|
- youtube
|
||||||
|
- proxy
|
||||||
|
- video
|
||||||
|
- privacy
|
||||||
|
home: https://invidio.us/
|
||||||
|
icon: https://raw.githubusercontent.com/omarroth/invidious/05988c1c49851b7d0094fca16aeaf6382a7f64ab/assets/favicon-32x32.png
|
||||||
|
sources:
|
||||||
|
- https://github.com/omarroth/invidious
|
||||||
|
maintainers:
|
||||||
|
- name: Leon Klingele
|
||||||
|
email: mail@leonklingele.de
|
||||||
|
dependencies:
|
||||||
|
- name: postgresql
|
||||||
|
version: ~8.3.0
|
||||||
|
repository: "https://kubernetes-charts.storage.googleapis.com/"
|
||||||
|
engine: gotpl
|
||||||
41
kubernetes/README.md
Normal file
41
kubernetes/README.md
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
# Invidious Helm chart
|
||||||
|
|
||||||
|
Easily deploy Invidious to Kubernetes.
|
||||||
|
|
||||||
|
## Installing Helm chart
|
||||||
|
|
||||||
|
```sh
|
||||||
|
# Build Helm dependencies
|
||||||
|
$ helm dep build
|
||||||
|
|
||||||
|
# Add PostgreSQL init scripts
|
||||||
|
$ kubectl create configmap invidious-postgresql-init \
|
||||||
|
--from-file=../config/sql/channels.sql \
|
||||||
|
--from-file=../config/sql/videos.sql \
|
||||||
|
--from-file=../config/sql/channel_videos.sql \
|
||||||
|
--from-file=../config/sql/users.sql \
|
||||||
|
--from-file=../config/sql/session_ids.sql \
|
||||||
|
--from-file=../config/sql/nonces.sql \
|
||||||
|
--from-file=../config/sql/annotations.sql \
|
||||||
|
--from-file=../config/sql/playlists.sql \
|
||||||
|
--from-file=../config/sql/playlist_videos.sql
|
||||||
|
|
||||||
|
# Install Helm app to your Kubernetes cluster
|
||||||
|
$ helm install invidious ./
|
||||||
|
```
|
||||||
|
|
||||||
|
## Upgrading
|
||||||
|
|
||||||
|
```sh
|
||||||
|
# Upgrading is easy, too!
|
||||||
|
$ helm upgrade invidious ./
|
||||||
|
```
|
||||||
|
|
||||||
|
## Uninstall
|
||||||
|
|
||||||
|
```sh
|
||||||
|
# Get rid of everything (except database)
|
||||||
|
$ helm delete invidious
|
||||||
|
|
||||||
|
# To also delete the database, remove all invidious-postgresql PVCs
|
||||||
|
```
|
||||||
16
kubernetes/templates/_helpers.tpl
Normal file
16
kubernetes/templates/_helpers.tpl
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
{{/* vim: set filetype=mustache: */}}
|
||||||
|
{{/*
|
||||||
|
Expand the name of the chart.
|
||||||
|
*/}}
|
||||||
|
{{- define "invidious.name" -}}
|
||||||
|
{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{/*
|
||||||
|
Create a default fully qualified app name.
|
||||||
|
We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec).
|
||||||
|
*/}}
|
||||||
|
{{- define "invidious.fullname" -}}
|
||||||
|
{{- $name := default .Chart.Name .Values.nameOverride -}}
|
||||||
|
{{- printf "%s-%s" .Release.Name $name | trunc 63 | trimSuffix "-" -}}
|
||||||
|
{{- end -}}
|
||||||
11
kubernetes/templates/configmap.yaml
Normal file
11
kubernetes/templates/configmap.yaml
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: ConfigMap
|
||||||
|
metadata:
|
||||||
|
name: {{ template "invidious.fullname" . }}
|
||||||
|
labels:
|
||||||
|
app: {{ template "invidious.name" . }}
|
||||||
|
chart: "{{ .Chart.Name }}-{{ .Chart.Version }}"
|
||||||
|
release: {{ .Release.Name }}
|
||||||
|
data:
|
||||||
|
INVIDIOUS_CONFIG: |
|
||||||
|
{{ toYaml .Values.config | indent 4 }}
|
||||||
53
kubernetes/templates/deployment.yaml
Normal file
53
kubernetes/templates/deployment.yaml
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: {{ template "invidious.fullname" . }}
|
||||||
|
labels:
|
||||||
|
app: {{ template "invidious.name" . }}
|
||||||
|
chart: "{{ .Chart.Name }}-{{ .Chart.Version }}"
|
||||||
|
release: {{ .Release.Name }}
|
||||||
|
spec:
|
||||||
|
replicas: {{ .Values.replicaCount }}
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: {{ template "invidious.name" . }}
|
||||||
|
release: {{ .Release.Name }}
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: {{ template "invidious.name" . }}
|
||||||
|
chart: "{{ .Chart.Name }}-{{ .Chart.Version }}"
|
||||||
|
release: {{ .Release.Name }}
|
||||||
|
spec:
|
||||||
|
securityContext:
|
||||||
|
runAsUser: {{ .Values.securityContext.runAsUser }}
|
||||||
|
runAsGroup: {{ .Values.securityContext.runAsGroup }}
|
||||||
|
fsGroup: {{ .Values.securityContext.fsGroup }}
|
||||||
|
containers:
|
||||||
|
- name: {{ .Chart.Name }}
|
||||||
|
image: "{{ .Values.image.repository }}:{{ .Values.image.tag }}"
|
||||||
|
imagePullPolicy: {{ .Values.image.pullPolicy }}
|
||||||
|
ports:
|
||||||
|
- containerPort: 3000
|
||||||
|
env:
|
||||||
|
- name: INVIDIOUS_CONFIG
|
||||||
|
valueFrom:
|
||||||
|
configMapKeyRef:
|
||||||
|
key: INVIDIOUS_CONFIG
|
||||||
|
name: {{ template "invidious.fullname" . }}
|
||||||
|
securityContext:
|
||||||
|
allowPrivilegeEscalation: {{ .Values.securityContext.allowPrivilegeEscalation }}
|
||||||
|
capabilities:
|
||||||
|
drop:
|
||||||
|
- ALL
|
||||||
|
resources:
|
||||||
|
{{ toYaml .Values.resources | indent 10 }}
|
||||||
|
readinessProbe:
|
||||||
|
httpGet:
|
||||||
|
port: 3000
|
||||||
|
path: /
|
||||||
|
livenessProbe:
|
||||||
|
httpGet:
|
||||||
|
port: 3000
|
||||||
|
path: /
|
||||||
|
restartPolicy: Always
|
||||||
18
kubernetes/templates/hpa.yaml
Normal file
18
kubernetes/templates/hpa.yaml
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
{{- if .Values.autoscaling.enabled }}
|
||||||
|
apiVersion: autoscaling/v1
|
||||||
|
kind: HorizontalPodAutoscaler
|
||||||
|
metadata:
|
||||||
|
name: {{ template "invidious.fullname" . }}
|
||||||
|
labels:
|
||||||
|
app: {{ template "invidious.name" . }}
|
||||||
|
chart: "{{ .Chart.Name }}-{{ .Chart.Version }}"
|
||||||
|
release: {{ .Release.Name }}
|
||||||
|
spec:
|
||||||
|
scaleTargetRef:
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
name: {{ template "invidious.fullname" . }}
|
||||||
|
minReplicas: {{ .Values.autoscaling.minReplicas }}
|
||||||
|
maxReplicas: {{ .Values.autoscaling.maxReplicas }}
|
||||||
|
targetCPUUtilizationPercentage: {{ .Values.autoscaling.targetCPUUtilizationPercentage }}
|
||||||
|
{{- end }}
|
||||||
16
kubernetes/templates/service.yaml
Normal file
16
kubernetes/templates/service.yaml
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: {{ template "invidious.fullname" . }}
|
||||||
|
labels:
|
||||||
|
app: {{ template "invidious.name" . }}
|
||||||
|
chart: {{ .Chart.Name }}
|
||||||
|
release: {{ .Release.Name }}
|
||||||
|
spec:
|
||||||
|
ports:
|
||||||
|
- name: http
|
||||||
|
port: 3000
|
||||||
|
targetPort: 3000
|
||||||
|
selector:
|
||||||
|
app: {{ template "invidious.name" . }}
|
||||||
|
release: {{ .Release.Name }}
|
||||||
51
kubernetes/values.yaml
Normal file
51
kubernetes/values.yaml
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
name: invidious
|
||||||
|
|
||||||
|
image:
|
||||||
|
repository: omarroth/invidious
|
||||||
|
tag: latest
|
||||||
|
pullPolicy: Always
|
||||||
|
|
||||||
|
replicaCount: 1
|
||||||
|
|
||||||
|
autoscaling:
|
||||||
|
enabled: false
|
||||||
|
minReplicas: 1
|
||||||
|
maxReplicas: 16
|
||||||
|
targetCPUUtilizationPercentage: 50
|
||||||
|
|
||||||
|
resources: {}
|
||||||
|
#requests:
|
||||||
|
# cpu: 100m
|
||||||
|
# memory: 64Mi
|
||||||
|
#limits:
|
||||||
|
# cpu: 800m
|
||||||
|
# memory: 512Mi
|
||||||
|
|
||||||
|
securityContext:
|
||||||
|
allowPrivilegeEscalation: false
|
||||||
|
runAsUser: 1000
|
||||||
|
runAsGroup: 1000
|
||||||
|
fsGroup: 1000
|
||||||
|
|
||||||
|
# See https://github.com/helm/charts/tree/master/stable/postgresql
|
||||||
|
postgresql:
|
||||||
|
postgresqlUsername: kemal
|
||||||
|
postgresqlPassword: kemal
|
||||||
|
postgresqlDatabase: invidious
|
||||||
|
initdbUsername: kemal
|
||||||
|
initdbPassword: kemal
|
||||||
|
initdbScriptsConfigMap: invidious-postgresql-init
|
||||||
|
|
||||||
|
# Adapted from ../config/config.yml
|
||||||
|
config:
|
||||||
|
channel_threads: 1
|
||||||
|
feed_threads: 1
|
||||||
|
db:
|
||||||
|
user: kemal
|
||||||
|
password: kemal
|
||||||
|
host: invidious-postgresql
|
||||||
|
port: 5432
|
||||||
|
dbname: invidious
|
||||||
|
full_refresh: false
|
||||||
|
https_only: false
|
||||||
|
domain:
|
||||||
628
locales/ar.json
628
locales/ar.json
@@ -1,294 +1,336 @@
|
|||||||
{
|
{
|
||||||
"`x` subscribers": "`x` المشتركين",
|
"`x` subscribers": "`x` المشتركين",
|
||||||
"`x` videos": "`x` الفيديوهات",
|
"`x` videos": "`x` الفيديوهات",
|
||||||
"LIVE": "مباشر",
|
"`x` playlists": "`x` قوائم التشغيل",
|
||||||
"Shared `x` ago": "تم رفع الفيديو منذ `x`",
|
"LIVE": "مباشر",
|
||||||
"Unsubscribe": "إلغاء الإشتراك",
|
"Shared `x` ago": "تم رفع الفيديو منذ `x`",
|
||||||
"Subscribe": "إشتراك",
|
"Unsubscribe": "إلغاء الإشتراك",
|
||||||
"Login to subscribe to `x`": "سجل الدخول للإشتراك فى `x`",
|
"Subscribe": "إشتراك",
|
||||||
"View channel on YouTube": "زيارة القناة على موقع يوتيوب",
|
"View channel on YouTube": "زيارة القناة على موقع يوتيوب",
|
||||||
"newest": "الأجدد",
|
"View playlist on YouTube": "عرض قائمة التشغيل على اليوتيوب",
|
||||||
"oldest": "الأقدم",
|
"newest": "الأجدد",
|
||||||
"popular": "الاكثر شعبية",
|
"oldest": "الأقدم",
|
||||||
"Preview page": "معاينة الصفحة",
|
"popular": "الأكثر شعبية",
|
||||||
"Next page": "الصفحة الثانية",
|
"last": "اخر قوائم التشغيل المعدلة",
|
||||||
"Clear watch history?": "مسح السجل ؟",
|
"Next page": "الصفحة الثانية",
|
||||||
"Yes": "نعم",
|
"Previous page": "الصفحة السابقة",
|
||||||
"No": "لا",
|
"Clear watch history?": "مسح السجل ؟",
|
||||||
"Import and Export Data": "استخراج و إضافة البيانات",
|
"New password": "الرقم السرى الجديد",
|
||||||
"Import": "إضافة",
|
"New passwords must match": "الأرقام السرية يجب ان تكون متطابقة",
|
||||||
"Import Invidious data": "إضافة بيانات Invidious",
|
"Cannot change password for Google accounts": "لا يستطيع تغيير الرقم السرى لحساب جوجل",
|
||||||
"Import YouTube subscriptions": "إضافةالإشتراكات من موقع يوتيوب",
|
"Authorize token?": "رمز الإذن ؟",
|
||||||
"Import FreeTube subscriptions (.db)": "إضافةالمشتركين من FreeTube (.db)",
|
"Authorize token for `x`?": "تصريح الرمز لـ `x` ؟",
|
||||||
"Import NewPipe subscriptions (.json)": "إضافة المشتركين من NewPipe (.json)",
|
"Yes": "نعم",
|
||||||
"Import NewPipe data (.zip)": "إضافة بيانات NewPipe (.zip)",
|
"No": "لا",
|
||||||
"Export": "استخراج",
|
"Import and Export Data": "استخراج و إضافة البيانات",
|
||||||
"Export subscriptions as OPML": "استخراج المشتركين كـ OPML",
|
"Import": "إضافة",
|
||||||
"Export subscriptions as OPML (for NewPipe & FreeTube)": "استخراج المشتركين كـ OPML (لـ NewPipe و FreeTube)",
|
"Import Invidious data": "إضافة بيانات Invidious",
|
||||||
"Export data as JSON": "استخراج البيانات كـ JSON",
|
"Import YouTube subscriptions": "إضافةالإشتراكات من موقع يوتيوب",
|
||||||
"Delete account?": "حذف الحساب ؟",
|
"Import FreeTube subscriptions (.db)": "إضافةالمشتركين من FreeTube (.db)",
|
||||||
"History": "السجل",
|
"Import NewPipe subscriptions (.json)": "إضافة المشتركين من NewPipe (.json)",
|
||||||
"Previous page": "الصفحة السابقة",
|
"Import NewPipe data (.zip)": "إضافة بيانات NewPipe (.zip)",
|
||||||
"An alternative front-end to YouTube": "البديل الكامل لموقع يوتيوب",
|
"Export": "استخراج",
|
||||||
"JavaScript license information": "معلومات ترخيص JavaScript",
|
"Export subscriptions as OPML": "استخراج المشتركين كـ OPML",
|
||||||
"source": "المصدر",
|
"Export subscriptions as OPML (for NewPipe & FreeTube)": "استخراج المشتركين كـ OPML (لـ NewPipe و FreeTube)",
|
||||||
"Login": "تسجيل الدخول",
|
"Export data as JSON": "استخراج البيانات كـ JSON",
|
||||||
"Login/Register": "تسجيل الدخول\\إنشاء حساب",
|
"Delete account?": "حذف الحساب ؟",
|
||||||
"Login to Google": "تسجيل الدخول بإستخدام جوجل",
|
"History": "السجل",
|
||||||
"User ID:": "إسم المستخدم:",
|
"An alternative front-end to YouTube": "البديل الكامل لموقع يوتيوب",
|
||||||
"Password:": "الرقم السرى:",
|
"JavaScript license information": "معلومات ترخيص JavaScript",
|
||||||
"Time (h:mm:ss):": "(يجب ان يكتب مثل هذا التنسيق) الوقت (h(ساعات):mm(دقائق):ss(ثوانى)):",
|
"source": "المصدر",
|
||||||
"Text CAPTCHA": "CAPTCHA كلامية",
|
"Log in": "تسجيل الدخول",
|
||||||
"Image CAPTCHA": "CAPTCHA صورية",
|
"Log in/register": "تسجيل الدخول\\إنشاء حساب",
|
||||||
"Sign In": "تسجيل الدخول",
|
"Log in with Google": "تسجيل الدخول بإستخدام جوجل",
|
||||||
"Register": "انشاء الحساب",
|
"User ID": "إسم المستخدم",
|
||||||
"Email:": "الإيميل:",
|
"Password": "الرقم السرى",
|
||||||
"Google verification code:": "رمز تحقق جوجل:",
|
"Time (h:mm:ss):": "(يجب ان يكتب مثل هذا التنسيق) الوقت (h(ساعات):mm(دقائق):ss(ثوانى)):",
|
||||||
"Preferences": "التفضيلات",
|
"Text CAPTCHA": "CAPTCHA كلامية",
|
||||||
"Player preferences": "التفضيلات المشغل",
|
"Image CAPTCHA": "CAPTCHA صورية",
|
||||||
"Always loop: ": "كرر الفيديو دائما: ",
|
"Sign In": "تسجيل الدخول",
|
||||||
"Autoplay: ": "تشغيل تلقائى: ",
|
"Register": "انشاء الحساب",
|
||||||
"Autoplay next video: ": "شغل الفيديو التالى تلقائى: ",
|
"E-mail": "الإيميل",
|
||||||
"Listen by default: ": "تشغيل النسخة السمعية تلقائى: ",
|
"Google verification code": "رمز تحقق جوجل",
|
||||||
"Default speed: ": "السرعة الإفتراضية: ",
|
"Preferences": "التفضيلات",
|
||||||
"Preferred video quality: ": "الجودة المفضلة للفيديوهات: ",
|
"Player preferences": "التفضيلات المشغل",
|
||||||
"Player volume: ": "صوت المشغل: ",
|
"Always loop: ": "كرر الفيديو دائما: ",
|
||||||
"Default comments: ": "إضهار التعليقات الإفتراضية لـ: ",
|
"Autoplay: ": "تشغيل تلقائى: ",
|
||||||
"youtube": "يوتيوب",
|
"Play next by default: ": "شغل الفيديو التالي تلقائيا: ",
|
||||||
"reddit": "Reddit",
|
"Autoplay next video: ": "شغل الفيديو التالي تلقائيا (في قوائم التشغيل) ",
|
||||||
"Default captions: ": "الترجمات الإفتراضية: ",
|
"Listen by default: ": "تشغيل النسخة السمعية تلقائى: ",
|
||||||
"Fallback captions: ": "الترجمات المصاحبة: ",
|
"Proxy videos: ": "عرض الفيديوهات عن طريق البروكسي؟ ",
|
||||||
"Show related videos? ": "عرض مقاطع الفيديو ذات الصلة؟",
|
"Default speed: ": "السرعة الإفتراضية: ",
|
||||||
"Visual preferences": "التفضيلات المرئية",
|
"Preferred video quality: ": "الجودة المفضلة للفيديوهات: ",
|
||||||
"Dark mode: ": "الوضع الليلى: ",
|
"Player volume: ": "صوت المشغل: ",
|
||||||
"Thin mode: ": "الوضع الخفيف: ",
|
"Default comments: ": "إضهار التعليقات الإفتراضية لـ: ",
|
||||||
"Subscription preferences": "تفضيلات الإشتراك",
|
"youtube": "يوتيوب",
|
||||||
"Redirect homepage to feed: ": "إعادة التوجية من الصفحة الرئيسية لصفحة المشتركين (لرؤية اخر فيديوهات المشتركين): ",
|
"reddit": "Reddit",
|
||||||
"Number of videos shown in feed: ": "عدد الفيديوهات التى ستظهر فى صفحة المشتركين: ",
|
"Default captions: ": "الترجمات الإفتراضية: ",
|
||||||
"Sort videos by: ": "ترتيب الفيديو بـ: ",
|
"Fallback captions: ": "الترجمات المصاحبة: ",
|
||||||
"published": "احدث فيديو",
|
"Show related videos: ": "اعرض الفيديوهات ذات الصلة: ",
|
||||||
"published - reverse": "احدث فيديو - عكسى",
|
"Show annotations by default: ": "اعرض الملاحظات في الفيديو تلقائيا: ",
|
||||||
"alphabetically": "ترتيب ابجدى",
|
"Visual preferences": "التفضيلات المرئية",
|
||||||
"alphabetically - reverse": "ابجدى - عكسى",
|
"Player style: ": "شكل مشغل الفيديوهات: ",
|
||||||
"channel name": "بإسم القناة",
|
"Dark mode: ": "الوضع الليلى: ",
|
||||||
"channel name - reverse": "بإسم القناة - عكسى",
|
"Theme: ": "المظهر: ",
|
||||||
"Only show latest video from channel: ": "فقط إظهر اخر فيديو من القناة: ",
|
"dark": "غامق (اسود)",
|
||||||
"Only show latest unwatched video from channel: ": "فقط اظهر اخر فيديو لم يتم رؤيتة من القناة: ",
|
"light": "فاتح (ابيض)",
|
||||||
"Only show unwatched: ": "فقط اظهر الذى لم يتم رؤيتة: ",
|
"Thin mode: ": "الوضع الخفيف: ",
|
||||||
"Only show notifications (if there are any): ": "إظهار الإشعارات فقط (إذا كان هناك أي): ",
|
"Subscription preferences": "تفضيلات الإشتراك",
|
||||||
"Data preferences": "إعدادات التفضيلات",
|
"Show annotations by default for subscribed channels: ": "عرض الملاحظات في الفيديوهات تلقائيا في القنوات المشترك بها فقط: ",
|
||||||
"Clear watch history": "حذف سجل المشاهدة",
|
"Redirect homepage to feed: ": "إعادة التوجية من الصفحة الرئيسية لصفحة المشتركين (لرؤية اخر فيديوهات المشتركين): ",
|
||||||
"Import/Export data": "إضافة\\إستخراج البيانات",
|
"Number of videos shown in feed: ": "عدد الفيديوهات التى ستظهر فى صفحة المشتركين: ",
|
||||||
"Manage subscriptions": "إدارة المشتركين",
|
"Sort videos by: ": "ترتيب الفيديو بـ: ",
|
||||||
"Watch history": "سجل المشاهدة",
|
"published": "احدث فيديو",
|
||||||
"Delete account": "حذف الحساب",
|
"published - reverse": "احدث فيديو - عكسى",
|
||||||
"Administrator preferences": "",
|
"alphabetically": "ترتيب ابجدى",
|
||||||
"Default homepage: ": "",
|
"alphabetically - reverse": "ابجدى - عكسى",
|
||||||
"Feed menu: ": "",
|
"channel name": "بإسم القناة",
|
||||||
"Top enabled? ": "",
|
"channel name - reverse": "بإسم القناة - عكسى",
|
||||||
"CAPTCHA enabled? ": "",
|
"Only show latest video from channel: ": "فقط إظهر اخر فيديو من القناة: ",
|
||||||
"Login enabled? ": "",
|
"Only show latest unwatched video from channel: ": "فقط اظهر اخر فيديو لم يتم رؤيتة من القناة: ",
|
||||||
"Registration enabled? ": "",
|
"Only show unwatched: ": "فقط اظهر الذى لم يتم رؤيتة: ",
|
||||||
"Report statistics? ": "",
|
"Only show notifications (if there are any): ": "إظهار الإشعارات فقط (إذا كان هناك أي): ",
|
||||||
"Save preferences": "حفظ التفضيلات",
|
"Enable web notifications": "تفعيل إشعارات المتصفح",
|
||||||
"Subscription manager": "مدير الإشتراكات",
|
"`x` uploaded a video": "`x` رفع فيديو",
|
||||||
"`x` subscriptions": "`x` مشتركين",
|
"`x` is live": "`x` فى بث مباشر",
|
||||||
"Import/Export": "إضافة\\إستخراج",
|
"Data preferences": "إعدادات التفضيلات",
|
||||||
"unsubscribe": "إلغاء الإشتراك",
|
"Clear watch history": "حذف سجل المشاهدة",
|
||||||
"Subscriptions": "الإشتراكات",
|
"Import/export data": "إضافة\\إستخراج البيانات",
|
||||||
"`x` unseen notifications": "`x` إشعارات لم تشاهدها بعد ",
|
"Change password": "غير الرقم السرى",
|
||||||
"search": "بحث",
|
"Manage subscriptions": "إدارة المشتركين",
|
||||||
"Sign out": "تسجيل الخروج",
|
"Manage tokens": "إدارة الرموز",
|
||||||
"Released under the AGPLv3 by Omar Roth.": "تم الإنشاء تحت AGPLv3 بواسطة عمر روث.",
|
"Watch history": "سجل المشاهدة",
|
||||||
"Source available here.": "الأكواد متوفرة هنا.",
|
"Delete account": "حذف الحساب",
|
||||||
"Liberapay: ": "ليبرباى: ",
|
"Administrator preferences": "إعدادات المدير",
|
||||||
"Patreon: ": "باتريون: ",
|
"Default homepage: ": "الصفحة الرئيسية الافتراضية ",
|
||||||
"BTC: ": "بيتكوين: ",
|
"Feed menu: ": "قائمة التدفقات: ",
|
||||||
"BCH: ": "بيتكوين كاش: ",
|
"Top enabled: ": "تفعيل 'الأفضل' ؟ ",
|
||||||
"View JavaScript license information.": "مشاهدة معلومات حول تراخيص الجافاسكريبت.",
|
"CAPTCHA enabled: ": "تفعيل الكابتشا: ",
|
||||||
"Trending": "الشائع",
|
"Login enabled: ": "تفعيل الولوج: ",
|
||||||
"Watch video on Youtube": "مشاهدة الفيديو على اليوتيوب",
|
"Registration enabled: ": "تفعيل التسجيل: ",
|
||||||
"Genre: ": "النوع: ",
|
"Report statistics: ": "الإبلاغ عن الإحصائيات: ",
|
||||||
"License: ": "التراخيص: ",
|
"Save preferences": "حفظ التفضيلات",
|
||||||
"Family friendly? ": "محتوى عائلى? ",
|
"Subscription manager": "مدير الإشتراكات",
|
||||||
"Wilson score: ": "درجة ويلسون: ",
|
"Token manager": "إداره الرمز",
|
||||||
"Engagement: ": "نسبة المشاركة (عدد المشاهدات\\عدد الإعجابات): ",
|
"Token": "الرمز",
|
||||||
"Whitelisted regions: ": "الدول المسموح فيها هذا الفيديو: ",
|
"`x` subscriptions": "`x` مشتركين",
|
||||||
"Blacklisted regions: ": "الدول الحظور فيها هذا الفيديو: ",
|
"`x` tokens": "`x` رموز",
|
||||||
"Shared `x`": "شارك منذ `x`",
|
"Import/export": "إضافة\\إستخراج",
|
||||||
"Hi! Looks like you have JavaScript disabled. Click here to view comments, keep in mind it may take a bit longer to load.": "اهلا! يبدو ان الجافاسكريبت معطلة. اضغط هنا لعرض التعليقات, ضع فى إعتبارك انها ستأخذ وقت اطول للعرض.",
|
"unsubscribe": "إلغاء الإشتراك",
|
||||||
"View YouTube comments": "عرض تعليقات اليوتيوب",
|
"revoke": "مسح",
|
||||||
"View more comments on Reddit": "عرض المزيد من التعليقات على\\من موقع Reddit",
|
"Subscriptions": "الإشتراكات",
|
||||||
"View `x` comments": "عرض `x` تعليقات",
|
"`x` unseen notifications": "`x` إشعارات لم تشاهدها بعد",
|
||||||
"View Reddit comments": "عرض تعليقات ريدإت Reddit",
|
"search": "بحث",
|
||||||
"Hide replies": "إخفاء الردود",
|
"Log out": "تسجيل الخروج",
|
||||||
"Show replies": "عرض الردود",
|
"Released under the AGPLv3 by Omar Roth.": "تم الإنشاء تحت AGPLv3 بواسطة عمر روث.",
|
||||||
"Incorrect password": "الرقم السرى غير صحيح",
|
"Source available here.": "الأكواد متوفرة هنا.",
|
||||||
"Quota exceeded, try again in a few hours": "تم تجاوز عدد المرات المسموح بها, حاول مرة اخرى بعد عدة ساعات",
|
"View JavaScript license information.": "مشاهدة معلومات حول تراخيص الجافاسكريبت.",
|
||||||
"Unable to login, make sure two-factor authentication (Authenticator or SMS) is enabled.": "غير قادر على تسجيل الدخول, تأكد من تشغيل المصادقة الثنائية 2FA.",
|
"View privacy policy.": "عرض سياسة الخصوصية.",
|
||||||
"Invalid TFA code": "كود مصادقة ثنائية 2FA غير صحيح",
|
"Trending": "الشائع",
|
||||||
"Login failed. This may be because two-factor authentication is not enabled on your account.": "لم يتم تسجيل الدخول. هذا ربما بسبب ان المصادقة الثنائية 2FA معطلة فى حسابك.",
|
"Public": "عام",
|
||||||
"Invalid answer": "إجابة خاطئة",
|
"Unlisted": "غير مصنف",
|
||||||
"Invalid CAPTCHA": "الكابتشا CAPTCHA غير صاحلة",
|
"Private": "خاص",
|
||||||
"CAPTCHA is a required field": "مكان الكابتشا CAPTCHA مطلوب",
|
"View all playlists": "عرض جميع قوائم التشغيل",
|
||||||
"User ID is a required field": "مكان إسم المستخدم مطلوب",
|
"Updated `x` ago": "تم تحديثه منذ `x`",
|
||||||
"Password is a required field": "مكان الرقم السرى مطلوب",
|
"Delete playlist `x`?": "حذف قائمه التشغيل `x` ?",
|
||||||
"Invalid username or password": "إسم المستخدم او الرقم السرى غير صحيح",
|
"Delete playlist": "حذف قائمه التغشيل",
|
||||||
"Please sign in using 'Sign in with Google'": "الرجاء تسجيل الدخول 'تسجيل الدخول بواسطة جوجل'",
|
"Create playlist": "إنشاء قائمه تشغيل",
|
||||||
"Password cannot be empty": "الرقم السرى لايمكن ان يكون فارغ",
|
"Title": "العنوان",
|
||||||
"Password cannot be longer than 55 characters": "الرقم السرى لا يتعدى 55 حرف",
|
"Playlist privacy": "إعدادات الخصوصيه",
|
||||||
"Please sign in": "الرجاء تسجيل الدخول",
|
"Editing playlist `x`": "تعديل قائمه التشفيل `x`",
|
||||||
"Invidious Private Feed for `x`": "صفحة Invidious للمشتركين الخاصة\\مخفية لـ `x`",
|
"Watch on YouTube": "مشاهدة الفيديو على اليوتيوب",
|
||||||
"channel:`x`": "قناة:`x`",
|
"Hide annotations": "إخفاء الملاحظات فى الفيديو",
|
||||||
"Deleted or invalid channel": "قناة ممسوحة او غير صالحة",
|
"Show annotations": "عرض الملاحظات فى الفيديو",
|
||||||
"This channel does not exist.": "القناة غير موجودة.",
|
"Genre: ": "النوع: ",
|
||||||
"Could not get channel info.": "لم يستطع الحصول على معلومات القناة.",
|
"License: ": "التراخيص: ",
|
||||||
"Could not fetch comments": "لم يتمكن من إحضار التعليقات",
|
"Family friendly? ": "محتوى عائلى? ",
|
||||||
"View `x` replies": "عرض `x` ردود",
|
"Wilson score: ": "درجة ويلسون: ",
|
||||||
"`x` ago": "`x` منذ",
|
"Engagement: ": "نسبة المشاركة (عدد المشاهدات\\عدد الإعجابات): ",
|
||||||
"Load more": "عرض المزيد",
|
"Whitelisted regions: ": "الدول المسموح فيها هذا الفيديو: ",
|
||||||
"`x` points": "`x` نقاط",
|
"Blacklisted regions: ": "الدول الحظور فيها هذا الفيديو: ",
|
||||||
"Could not create mix.": "لم يستطع عمل خلط.",
|
"Shared `x`": "شارك منذ `x`",
|
||||||
"Playlist is empty": "قائمة التشغيل فارغة",
|
"`x` views": "`x` مشاهدات",
|
||||||
"Invalid playlist.": "قائمة التشغيل غير صالحة.",
|
"Premieres in `x`": "يعرض فى `x`",
|
||||||
"Playlist does not exist.": "قائمة التشغيل غير موجودة.",
|
"Premieres `x`": "يعرض `x`",
|
||||||
"Could not pull trending pages.": "لم يستطع عرض الصفحات الراجئة.",
|
"Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.": "اهلا! يبدو ان الجافاسكريبت معطلة. اضغط هنا لعرض التعليقات, ضع فى إعتبارك انها ستأخذ وقت اطول للعرض.",
|
||||||
"Hidden field \"challenge\" is a required field": "مكان مخفى \"تحدى\" مكان مطلوب",
|
"View YouTube comments": "عرض تعليقات اليوتيوب",
|
||||||
"Hidden field \"token\" is a required field": "مكان مخفى \"رمز\" مكان مطلوب",
|
"View more comments on Reddit": "عرض المزيد من التعليقات على\\من موقع Reddit",
|
||||||
"Invalid challenge": "تحدى غير صالح",
|
"View `x` comments": "عرض `x` تعليقات",
|
||||||
"Invalid token": "روز غير صالح",
|
"View Reddit comments": "عرض تعليقات ريدإت Reddit",
|
||||||
"Invalid user": "مستخدم غير صالح",
|
"Hide replies": "إخفاء الردود",
|
||||||
"Token is expired, please try again": "الرمز منتهى الصلاحية , الرجاء المحاولة مرة اخرى",
|
"Show replies": "عرض الردود",
|
||||||
"English": "إنجليزى",
|
"Incorrect password": "الرقم السرى غير صحيح",
|
||||||
"English (auto-generated)": "إنجليزى (تم إنشائة تلقائى)",
|
"Quota exceeded, try again in a few hours": "تم تجاوز عدد المرات المسموح بها, حاول مرة اخرى بعد عدة ساعات",
|
||||||
"Afrikaans": "الأفريكانية",
|
"Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.": "غير قادر على تسجيل الدخول, تأكد من تشغيل المصادقة الثنائية 2FA.",
|
||||||
"Albanian": "الألبانية",
|
"Invalid TFA code": "كود مصادقة ثنائية 2FA غير صحيح",
|
||||||
"Amharic": "الأمهرية",
|
"Login failed. This may be because two-factor authentication is not turned on for your account.": "لم يتم تسجيل الدخول. هذا ربما بسبب ان المصادقة الثنائية 2FA معطلة فى حسابك.",
|
||||||
"Arabic": "العربية",
|
"Wrong answer": "إجابة خاطئة",
|
||||||
"Armenian": "الأرميني",
|
"Erroneous CAPTCHA": "الكابتشا CAPTCHA غير صاحلة",
|
||||||
"Azerbaijani": "أذربيجان",
|
"CAPTCHA is a required field": "مكان الكابتشا CAPTCHA مطلوب",
|
||||||
"Bangla": "البنغالية",
|
"User ID is a required field": "مكان إسم المستخدم مطلوب",
|
||||||
"Basque": "الباسكي",
|
"Password is a required field": "مكان الرقم السرى مطلوب",
|
||||||
"Belarusian": "البيلاروسية",
|
"Wrong username or password": "إسم المستخدم او الرقم السرى غير صحيح",
|
||||||
"Bosnian": "البوسنية",
|
"Please sign in using 'Log in with Google'": "الرجاء تسجيل الدخول 'تسجيل الدخول بواسطة جوجل'",
|
||||||
"Bulgarian": "البلغارية",
|
"Password cannot be empty": "الرقم السرى لايمكن ان يكون فارغ",
|
||||||
"Burmese": "البورمية",
|
"Password cannot be longer than 55 characters": "الرقم السرى لا يتعدى 55 حرف",
|
||||||
"Catalan": "الكاتالونية",
|
"Please log in": "الرجاء تسجيل الدخول",
|
||||||
"Cebuano": "السيبيونو",
|
"Invidious Private Feed for `x`": "صفحة Invidious للمشتركين الخاصة\\مخفية لـ `x`",
|
||||||
"Chinese (Simplified)": "الصينية (المبسطة)",
|
"channel:`x`": "قناة:`x`",
|
||||||
"Chinese (Traditional)": "الصينية (التقليدية)",
|
"Deleted or invalid channel": "قناة ممسوحة او غير صالحة",
|
||||||
"Corsican": "الكورسيكية",
|
"This channel does not exist.": "القناة غير موجودة.",
|
||||||
"Croatian": "الكرواتية",
|
"Could not get channel info.": "لم يستطع الحصول على معلومات القناة.",
|
||||||
"Czech": "تشيكي",
|
"Could not fetch comments": "لم يتمكن من إحضار التعليقات",
|
||||||
"Danish": "دانماركي",
|
"View `x` replies": "عرض `x` ردود",
|
||||||
"Dutch": "هولندي",
|
"`x` ago": "`x` منذ",
|
||||||
"Esperanto": "الاسبرانتو",
|
"Load more": "عرض المزيد",
|
||||||
"Estonian": "الإستونية",
|
"`x` points": "`x` نقاط",
|
||||||
"Filipino": "الفلبينية",
|
"Could not create mix.": "لم يستطع عمل خلط.",
|
||||||
"Finnish": "الفنلندية",
|
"Empty playlist": "قائمة التشغيل فارغة",
|
||||||
"French": "الفرنسية",
|
"Not a playlist.": "قائمة التشغيل غير صالحة.",
|
||||||
"Galician": "الجاليكية",
|
"Playlist does not exist.": "قائمة التشغيل غير موجودة.",
|
||||||
"Georgian": "الجورجية",
|
"Could not pull trending pages.": "لم يستطع عرض الصفحات الراجئة.",
|
||||||
"German": "ألمانية",
|
"Hidden field \"challenge\" is a required field": "مكان مخفى \"تحدى\" مكان مطلوب",
|
||||||
"Greek": "الإغريقي",
|
"Hidden field \"token\" is a required field": "مكان مخفى \"رمز\" مكان مطلوب",
|
||||||
"Gujarati": "الغوجاراتية",
|
"Erroneous challenge": "تحدى غير صالح",
|
||||||
"Haitian Creole": "الكاثوليكية الهايتية",
|
"Erroneous token": "روز غير صالح",
|
||||||
"Hausa": "الهوسا",
|
"No such user": "مستخدم غير صالح",
|
||||||
"Hawaiian": "هاواي",
|
"Token is expired, please try again": "الرمز منتهى الصلاحية , الرجاء المحاولة مرة اخرى",
|
||||||
"Hebrew": "العبرية",
|
"English": "إنجليزى",
|
||||||
"Hindi": "الهندية",
|
"English (auto-generated)": "إنجليزى (تم إنشائة تلقائى)",
|
||||||
"Hmong": "همونغ",
|
"Afrikaans": "الأفريكانية",
|
||||||
"Hungarian": "الهنغارية",
|
"Albanian": "الألبانية",
|
||||||
"Icelandic": "أيسلندي",
|
"Amharic": "الأمهرية",
|
||||||
"Igbo": "الإيبو",
|
"Arabic": "العربية",
|
||||||
"Indonesian": "الأندونيسية",
|
"Armenian": "الأرميني",
|
||||||
"Irish": "الأيرلندية",
|
"Azerbaijani": "أذربيجان",
|
||||||
"Italian": "الإيطالي",
|
"Bangla": "البنغالية",
|
||||||
"Japanese": "اليابانية",
|
"Basque": "الباسكي",
|
||||||
"Javanese": "جاوي",
|
"Belarusian": "البيلاروسية",
|
||||||
"Kannada": "الكانادا",
|
"Bosnian": "البوسنية",
|
||||||
"Kazakh": "الكازاخية",
|
"Bulgarian": "البلغارية",
|
||||||
"Khmer": "الخمير",
|
"Burmese": "البورمية",
|
||||||
"Korean": "الكورية",
|
"Catalan": "الكاتالونية",
|
||||||
"Kurdish": "كردي",
|
"Cebuano": "السيبيونو",
|
||||||
"Kyrgyz": "قيرغيزستان",
|
"Chinese (Simplified)": "الصينية (المبسطة)",
|
||||||
"Lao": "لاو",
|
"Chinese (Traditional)": "الصينية (التقليدية)",
|
||||||
"Latin": "لاتينية",
|
"Corsican": "الكورسيكية",
|
||||||
"Latvian": "اللاتفية",
|
"Croatian": "الكرواتية",
|
||||||
"Lithuanian": "اللتوانية",
|
"Czech": "تشيكي",
|
||||||
"Luxembourgish": "اللوكسمبرجية",
|
"Danish": "دانماركي",
|
||||||
"Macedonian": "المقدونية",
|
"Dutch": "هولندي",
|
||||||
"Malagasy": "مدجشقر\\مدغشقر",
|
"Esperanto": "الاسبرانتو",
|
||||||
"Malay": "الملايو",
|
"Estonian": "الإستونية",
|
||||||
"Malayalam": "المالايالامية",
|
"Filipino": "الفلبينية",
|
||||||
"Maltese": "المالطية",
|
"Finnish": "الفنلندية",
|
||||||
"Maori": "الماوري",
|
"French": "الفرنسية",
|
||||||
"Marathi": "المهاراتية",
|
"Galician": "الجاليكية",
|
||||||
"Mongolian": "المنغولية",
|
"Georgian": "الجورجية",
|
||||||
"Nepali": "النيبالية",
|
"German": "ألمانية",
|
||||||
"Norwegian": "النرويجية",
|
"Greek": "الإغريقي",
|
||||||
"Nyanja": "نيانجا",
|
"Gujarati": "الغوجاراتية",
|
||||||
"Pashto": "الباشتو",
|
"Haitian Creole": "الكاثوليكية الهايتية",
|
||||||
"Persian": "الفارسية",
|
"Hausa": "الهوسا",
|
||||||
"Polish": "البولندي",
|
"Hawaiian": "هاواي",
|
||||||
"Portuguese": "البرتغالية",
|
"Hebrew": "العبرية",
|
||||||
"Punjabi": "البنجابية",
|
"Hindi": "الهندية",
|
||||||
"Romanian": "روماني",
|
"Hmong": "همونغ",
|
||||||
"Russian": "الروسية",
|
"Hungarian": "الهنغارية",
|
||||||
"Samoan": "ساموا",
|
"Icelandic": "أيسلندي",
|
||||||
"Scottish Gaelic": "الغيلية الاسكتلندية",
|
"Igbo": "الإيبو",
|
||||||
"Serbian": "صربي",
|
"Indonesian": "الأندونيسية",
|
||||||
"Shona": "شونا",
|
"Irish": "الأيرلندية",
|
||||||
"Sindhi": "السندية",
|
"Italian": "الإيطالي",
|
||||||
"Sinhala": "السنهالية",
|
"Japanese": "اليابانية",
|
||||||
"Slovak": "السلوفاكية",
|
"Javanese": "جاوي",
|
||||||
"Slovenian": "سلوفيني",
|
"Kannada": "الكانادا",
|
||||||
"Somali": "الصومالية",
|
"Kazakh": "الكازاخية",
|
||||||
"Southern Sotho": "جنوب سوثو",
|
"Khmer": "الخمير",
|
||||||
"Spanish": "الأسبانية",
|
"Korean": "الكورية",
|
||||||
"Spanish (Latin America)": "الأسبانية (أمريكا اللاتينية)",
|
"Kurdish": "كردي",
|
||||||
"Sundanese": "السودانية",
|
"Kyrgyz": "قيرغيزستان",
|
||||||
"Swahili": "السواحلية",
|
"Lao": "لاو",
|
||||||
"Swedish": "السويدية",
|
"Latin": "لاتينية",
|
||||||
"Tajik": "الطاجيكية",
|
"Latvian": "اللاتفية",
|
||||||
"Tamil": "التاميل",
|
"Lithuanian": "اللتوانية",
|
||||||
"Telugu": "التيلجو",
|
"Luxembourgish": "اللوكسمبرجية",
|
||||||
"Thai": "التايلاندية",
|
"Macedonian": "المقدونية",
|
||||||
"Turkish": "التركية",
|
"Malagasy": "مدجشقر\\مدغشقر",
|
||||||
"Ukrainian": "الأوكراني",
|
"Malay": "الملايو",
|
||||||
"Urdu": "الأردية",
|
"Malayalam": "المالايالامية",
|
||||||
"Uzbek": "الأوزبكي",
|
"Maltese": "المالطية",
|
||||||
"Vietnamese": "الفيتنامية",
|
"Maori": "الماوري",
|
||||||
"Welsh": "الولزية",
|
"Marathi": "المهاراتية",
|
||||||
"Western Frisian": "الفريزية الغربية",
|
"Mongolian": "المنغولية",
|
||||||
"Xhosa": "زوسا",
|
"Nepali": "النيبالية",
|
||||||
"Yiddish": "اليديشية",
|
"Norwegian Bokmål": "النرويجية",
|
||||||
"Yoruba": "اليوروبا",
|
"Nyanja": "نيانجا",
|
||||||
"Zulu": "الزولو",
|
"Pashto": "الباشتو",
|
||||||
"`x` years": "`x` سنوات",
|
"Persian": "الفارسية",
|
||||||
"`x` months": "`x` شهور",
|
"Polish": "البولندي",
|
||||||
"`x` weeks": "`x` اسابيع",
|
"Portuguese": "البرتغالية",
|
||||||
"`x` days": "`x` ايام",
|
"Punjabi": "البنجابية",
|
||||||
"`x` hours": "`x` ساعات",
|
"Romanian": "روماني",
|
||||||
"`x` minutes": "`x` دقائق",
|
"Russian": "الروسية",
|
||||||
"`x` seconds": "`x` ثوانى",
|
"Samoan": "ساموا",
|
||||||
"Fallback comments: ": "التعليقات المصاحبة",
|
"Scottish Gaelic": "الغيلية الاسكتلندية",
|
||||||
"Popular": "لاكثر شعبية",
|
"Serbian": "صربي",
|
||||||
"Top": "الأفضل",
|
"Shona": "شونا",
|
||||||
"About": "حول",
|
"Sindhi": "السندية",
|
||||||
"Rating: ": "التقييم",
|
"Sinhala": "السنهالية",
|
||||||
"Language: ": "اللغة",
|
"Slovak": "السلوفاكية",
|
||||||
"Default": "الكل",
|
"Slovenian": "سلوفيني",
|
||||||
"Music": "الاغانى",
|
"Somali": "الصومالية",
|
||||||
"Gaming": "الألعاب",
|
"Southern Sotho": "جنوب سوثو",
|
||||||
"News": "الأخبار",
|
"Spanish": "الأسبانية",
|
||||||
"Movies": "الأفلام",
|
"Spanish (Latin America)": "الأسبانية (أمريكا اللاتينية)",
|
||||||
"Download as: ": "تحميل كـ",
|
"Sundanese": "السودانية",
|
||||||
"Download": "تحميل",
|
"Swahili": "السواحلية",
|
||||||
"%A %B %-d, %Y": "",
|
"Swedish": "السويدية",
|
||||||
"(edited)": "",
|
"Tajik": "الطاجيكية",
|
||||||
"Youtube permalink of the comment": "",
|
"Tamil": "التاميل",
|
||||||
"`x` marked it with a ❤": "",
|
"Telugu": "التيلجو",
|
||||||
"Audio mode": "",
|
"Thai": "التايلاندية",
|
||||||
"Video mode": ""
|
"Turkish": "التركية",
|
||||||
}
|
"Ukrainian": "الأوكراني",
|
||||||
|
"Urdu": "الأردية",
|
||||||
|
"Uzbek": "الأوزبكي",
|
||||||
|
"Vietnamese": "الفيتنامية",
|
||||||
|
"Welsh": "الولزية",
|
||||||
|
"Western Frisian": "الفريزية الغربية",
|
||||||
|
"Xhosa": "زوسا",
|
||||||
|
"Yiddish": "اليديشية",
|
||||||
|
"Yoruba": "اليوروبا",
|
||||||
|
"Zulu": "الزولو",
|
||||||
|
"`x` years": "`x` سنوات",
|
||||||
|
"`x` months": "`x` شهور",
|
||||||
|
"`x` weeks": "`x` اسابيع",
|
||||||
|
"`x` days": "`x` ايام",
|
||||||
|
"`x` hours": "`x` ساعات",
|
||||||
|
"`x` minutes": "`x` دقائق",
|
||||||
|
"`x` seconds": "`x` ثوانى",
|
||||||
|
"Fallback comments: ": "التعليقات البديلة: ",
|
||||||
|
"Popular": "الأكثر شعبية",
|
||||||
|
"Top": "الأفضل",
|
||||||
|
"About": "حول",
|
||||||
|
"Rating: ": "التقييم: ",
|
||||||
|
"Language: ": "اللغة: ",
|
||||||
|
"View as playlist": "عرض كا قائمة التشغيل",
|
||||||
|
"Default": "الكل",
|
||||||
|
"Music": "الاغانى",
|
||||||
|
"Gaming": "الألعاب",
|
||||||
|
"News": "الأخبار",
|
||||||
|
"Movies": "الأفلام",
|
||||||
|
"Download": "نزّل",
|
||||||
|
"Download as: ": "نزّله كـ: ",
|
||||||
|
"%A %B %-d, %Y": "%A %-d %B %Y",
|
||||||
|
"(edited)": "(تم تعديلة)",
|
||||||
|
"YouTube comment permalink": "رابط التعليق على اليوتيوب",
|
||||||
|
"permalink": "الرابط",
|
||||||
|
"`x` marked it with a ❤": "`x` اعجب بهذا",
|
||||||
|
"Audio mode": "الوضع الصوتى",
|
||||||
|
"Video mode": "وضع الفيديو",
|
||||||
|
"Videos": "الفيديوهات",
|
||||||
|
"Playlists": "قوائم التشغيل",
|
||||||
|
"Community": "المجتمع",
|
||||||
|
"Current version: ": "الإصدار الحالي: "
|
||||||
|
}
|
||||||
628
locales/de.json
628
locales/de.json
@@ -1,294 +1,336 @@
|
|||||||
{
|
{
|
||||||
"`x` subscribers": "`x` Abonnenten",
|
"`x` subscribers": "`x` Abonnenten",
|
||||||
"`x` videos": "`x` Videos",
|
"`x` videos": "`x` Videos",
|
||||||
"LIVE": "LIVE",
|
"`x` playlists": "`x` Wiedergabelisten",
|
||||||
"Shared `x` ago": "Vor `x` geteilt",
|
"LIVE": "LIVE",
|
||||||
"Unsubscribe": "Abbestellen",
|
"Shared `x` ago": "Vor `x` geteilt",
|
||||||
"Subscribe": "Abonnieren",
|
"Unsubscribe": "Abbestellen",
|
||||||
"Login to subscribe to `x`": "Einloggen um `x` zu abonnieren",
|
"Subscribe": "Abonnieren",
|
||||||
"View channel on YouTube": "Kanal auf YouTube anzeigen",
|
"View channel on YouTube": "Kanal auf YouTube anzeigen",
|
||||||
"newest": "neueste",
|
"View playlist on YouTube": "Wiedergabeliste auf YouTube anzeigen",
|
||||||
"oldest": "älteste",
|
"newest": "neueste",
|
||||||
"popular": "beliebt",
|
"oldest": "älteste",
|
||||||
"Preview page": "Vorschau Seite",
|
"popular": "beliebt",
|
||||||
"Next page": "Nächste Seite",
|
"last": "letzte",
|
||||||
"Clear watch history?": "Verlauf löschen?",
|
"Next page": "Nächste Seite",
|
||||||
"Yes": "Ja",
|
"Previous page": "Vorherige Seite",
|
||||||
"No": "Nein",
|
"Clear watch history?": "Verlauf löschen?",
|
||||||
"Import and Export Data": "Import und Export Daten",
|
"New password": "Neues Passwort",
|
||||||
"Import": "Importieren",
|
"New passwords must match": "Neue Passwörter müssen gleich sein",
|
||||||
"Import Invidious data": "Invidious Daten importieren",
|
"Cannot change password for Google accounts": "Ich kann das Passwort deines Google Kontos nicht ändern",
|
||||||
"Import YouTube subscriptions": "YouTube Abonnements importieren",
|
"Authorize token?": "Token autorisieren?",
|
||||||
"Import FreeTube subscriptions (.db)": "FreeTube Abonnements importieren (.db)",
|
"Authorize token for `x`?": "Token für `x` autorisieren?",
|
||||||
"Import NewPipe subscriptions (.json)": "NewPipe Abonnements importieren (.json)",
|
"Yes": "Ja",
|
||||||
"Import NewPipe data (.zip)": "NewPipe Daten importieren (.zip)",
|
"No": "Nein",
|
||||||
"Export": "Exportieren",
|
"Import and Export Data": "Daten importieren und exportieren",
|
||||||
"Export subscriptions as OPML": "Abonnements als OPML exportieren",
|
"Import": "Importieren",
|
||||||
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Abonnements als OPML exportieren (für NewPipe & FreeTube)",
|
"Import Invidious data": "Invidious Daten importieren",
|
||||||
"Export data as JSON": "Daten als JSON exportieren",
|
"Import YouTube subscriptions": "YouTube Abonnements importieren",
|
||||||
"Delete account?": "Account löschen?",
|
"Import FreeTube subscriptions (.db)": "FreeTube Abonnements importieren (.db)",
|
||||||
"History": "Verlauf",
|
"Import NewPipe subscriptions (.json)": "NewPipe Abonnements importieren (.json)",
|
||||||
"Previous page": "Vorherige Seite",
|
"Import NewPipe data (.zip)": "NewPipe Daten importieren (.zip)",
|
||||||
"An alternative front-end to YouTube": "Eine alternative Oberfläche für YouTube",
|
"Export": "Exportieren",
|
||||||
"JavaScript license information": "JavaScript Lizenzinformationen",
|
"Export subscriptions as OPML": "Abonnements als OPML exportieren",
|
||||||
"source": "Quelle",
|
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Abonnements als OPML exportieren (für NewPipe & FreeTube)",
|
||||||
"Login": "Einloggen",
|
"Export data as JSON": "Daten als JSON exportieren",
|
||||||
"Login/Register": "Einloggen/Registrieren",
|
"Delete account?": "Account löschen?",
|
||||||
"Login to Google": "In Google einloggen",
|
"History": "Verlauf",
|
||||||
"User ID:": "Benutzer ID:",
|
"An alternative front-end to YouTube": "Eine alternative Oberfläche für YouTube",
|
||||||
"Password:": "Passwort:",
|
"JavaScript license information": "JavaScript Lizenzinformationen",
|
||||||
"Time (h:mm:ss):": "Zeit (h:mm:ss):",
|
"source": "Quelle",
|
||||||
"Text CAPTCHA": "Text CAPTCHA",
|
"Log in": "Einloggen",
|
||||||
"Image CAPTCHA": "Image CAPTCHA",
|
"Log in/register": "Einloggen/Registrieren",
|
||||||
"Sign In": "Einloggen",
|
"Log in with Google": "Mit Google einloggen",
|
||||||
"Register": "Registrieren",
|
"User ID": "Benutzer ID",
|
||||||
"Email:": "Email:",
|
"Password": "Passwort",
|
||||||
"Google verification code:": "Google Bestätigungscode:",
|
"Time (h:mm:ss):": "Zeit (h:mm:ss):",
|
||||||
"Preferences": "Einstellungen",
|
"Text CAPTCHA": "Text CAPTCHA",
|
||||||
"Player preferences": "Playereinstellungen",
|
"Image CAPTCHA": "Bild CAPTCHA",
|
||||||
"Always loop: ": "Immer wiederholen: ",
|
"Sign In": "Anmelden",
|
||||||
"Autoplay: ": "Automatisch abspielen: ",
|
"Register": "Registrieren",
|
||||||
"Autoplay next video: ": "nächstes Video automatisch abspielen: ",
|
"E-mail": "E-Mail",
|
||||||
"Listen by default: ": "Nur Ton als Standard: ",
|
"Google verification code": "Google-Bestätigungscode",
|
||||||
"Default speed: ": "Standardgeschwindigkeit: ",
|
"Preferences": "Einstellungen",
|
||||||
"Preferred video quality: ": "Bevorzugte Videoqualität: ",
|
"Player preferences": "Wiedergabeeinstellungen",
|
||||||
"Player volume: ": "Playerlautstärke: ",
|
"Always loop: ": "Immer wiederholen: ",
|
||||||
"Default comments: ": "Standardkommentare: ",
|
"Autoplay: ": "Automatisch abspielen: ",
|
||||||
"youtube": "youtube",
|
"Play next by default: ": "Immer automatisch nächstes Video spielen: ",
|
||||||
"reddit": "reddit",
|
"Autoplay next video: ": "nächstes Video automatisch abspielen: ",
|
||||||
"Default captions: ": "Standarduntertitel: ",
|
"Listen by default: ": "Nur Ton als Standard: ",
|
||||||
"Fallback captions: ": "Ersatzuntertitel: ",
|
"Proxy videos: ": "Proxy-Videos: ",
|
||||||
"Show related videos? ": "Ähnliche Videos anzeigen? ",
|
"Default speed: ": "Standardgeschwindigkeit: ",
|
||||||
"Visual preferences": "Anzeigeeinstellungen",
|
"Preferred video quality: ": "Bevorzugte Videoqualität: ",
|
||||||
"Dark mode: ": "Nachtmodus: ",
|
"Player volume: ": "Wiedergabelautstärke: ",
|
||||||
"Thin mode: ": "Schlanker Modus: ",
|
"Default comments: ": "Standardkommentare: ",
|
||||||
"Subscription preferences": "Abonnementeinstellungen",
|
"youtube": "youtube",
|
||||||
"Redirect homepage to feed: ": "Startseite zu Feed umleiten: ",
|
"reddit": "reddit",
|
||||||
"Number of videos shown in feed: ": "Anzahl von Videos die im Feed angezeigt werden: ",
|
"Default captions: ": "Standarduntertitel: ",
|
||||||
"Sort videos by: ": "Videos sortieren nach: ",
|
"Fallback captions: ": "Ersatzuntertitel: ",
|
||||||
"published": "veröffentlicht",
|
"Show related videos: ": "Ähnliche Videos anzeigen? ",
|
||||||
"published - reverse": "veröffentlicht - invertiert",
|
"Show annotations by default: ": "Standardmäßig Anmerkungen anzeigen? ",
|
||||||
"alphabetically": "alphabetisch",
|
"Visual preferences": "Anzeigeeinstellungen",
|
||||||
"alphabetically - reverse": "alphabetisch - invertiert",
|
"Player style: ": "Abspielgeräterstil: ",
|
||||||
"channel name": "Kanalname",
|
"Dark mode: ": "Nachtmodus: ",
|
||||||
"channel name - reverse": "Kanalname - invertiert",
|
"Theme: ": "Modus: ",
|
||||||
"Only show latest video from channel: ": "Nur neueste Videos des Kanals anzeigen: ",
|
"dark": "Nachtmodus",
|
||||||
"Only show latest unwatched video from channel: ": "Nur neueste ungesehene Videos des Kanals anzeigen: ",
|
"light": "klarer Modus",
|
||||||
"Only show unwatched: ": "Nur ungesehene anzeigen: ",
|
"Thin mode: ": "Schlanker Modus: ",
|
||||||
"Only show notifications (if there are any): ": "Nur Benachrichtigungen anzeigen (wenn es welche gibt): ",
|
"Subscription preferences": "Abonnementeinstellungen",
|
||||||
"Data preferences": "Dateneinstellungen",
|
"Show annotations by default for subscribed channels: ": "Anmerkungen für abonnierte Kanäle standardmäßig anzeigen? ",
|
||||||
"Clear watch history": "Verlauf löschen",
|
"Redirect homepage to feed: ": "Startseite zu Feed umleiten: ",
|
||||||
"Import/Export data": "Daten im- exportieren",
|
"Number of videos shown in feed: ": "Anzahl von Videos die im Feed angezeigt werden: ",
|
||||||
"Manage subscriptions": "Abonnements verwalten",
|
"Sort videos by: ": "Videos sortieren nach: ",
|
||||||
"Watch history": "Verlauf",
|
"published": "veröffentlicht",
|
||||||
"Delete account": "Account löschen",
|
"published - reverse": "veröffentlicht - invertiert",
|
||||||
"Administrator preferences": "",
|
"alphabetically": "alphabetisch",
|
||||||
"Default homepage: ": "",
|
"alphabetically - reverse": "alphabetisch - invertiert",
|
||||||
"Feed menu: ": "",
|
"channel name": "Kanalname",
|
||||||
"Top enabled? ": "",
|
"channel name - reverse": "Kanalname - invertiert",
|
||||||
"CAPTCHA enabled? ": "",
|
"Only show latest video from channel: ": "Nur neueste Videos des Kanals anzeigen: ",
|
||||||
"Login enabled? ": "",
|
"Only show latest unwatched video from channel: ": "Nur neueste ungesehene Videos des Kanals anzeigen: ",
|
||||||
"Registration enabled? ": "",
|
"Only show unwatched: ": "Nur ungesehene anzeigen: ",
|
||||||
"Report statistics? ": "",
|
"Only show notifications (if there are any): ": "Nur Benachrichtigungen anzeigen (wenn es welche gibt): ",
|
||||||
"Save preferences": "Einstellungen speichern",
|
"Enable web notifications": "Webbenachrichtigungen aktivieren",
|
||||||
"Subscription manager": "Abonnementverwaltung",
|
"`x` uploaded a video": "`x` hat ein Video hochgeladen",
|
||||||
"`x` subscriptions": "`x` Abonnements",
|
"`x` is live": "`x` ist live",
|
||||||
"Import/Export": "Importieren/Exportieren",
|
"Data preferences": "Dateneinstellungen",
|
||||||
"unsubscribe": "abbestellen",
|
"Clear watch history": "Verlauf löschen",
|
||||||
"Subscriptions": "Abonnements",
|
"Import/export data": "Daten im-/exportieren",
|
||||||
"`x` unseen notifications": "`x` ungesehene Benachrichtigungen",
|
"Change password": "Passwort ändern",
|
||||||
"search": "Suchen",
|
"Manage subscriptions": "Abonnements verwalten",
|
||||||
"Sign out": "Abmelden",
|
"Manage tokens": "Tokens verwalten",
|
||||||
"Released under the AGPLv3 by Omar Roth.": "Veröffentlicht unter AGPLv3 von Omar Roth.",
|
"Watch history": "Verlauf",
|
||||||
"Source available here.": "Quellcode verfügbar hier.",
|
"Delete account": "Account löschen",
|
||||||
"Liberapay: ": "Liberapay: ",
|
"Administrator preferences": "Administrator-Einstellungen",
|
||||||
"Patreon: ": "Patreon: ",
|
"Default homepage: ": "Standard-Startseite: ",
|
||||||
"BTC: ": "BTC: ",
|
"Feed menu: ": "Feed-Menü: ",
|
||||||
"BCH: ": "BCH: ",
|
"Top enabled: ": "Top aktiviert? ",
|
||||||
"View JavaScript license information.": "Javascript Lizenzinformationen anzeigen.",
|
"CAPTCHA enabled: ": "CAPTCHA aktiviert? ",
|
||||||
"Trending": "Trending",
|
"Login enabled: ": "Login aktiviert? ",
|
||||||
"Watch video on Youtube": "Video auf YouTube ansehen",
|
"Registration enabled: ": "Registrierung aktiviert? ",
|
||||||
"Genre: ": "Genre: ",
|
"Report statistics: ": "Statistiken berichten? ",
|
||||||
"License: ": "Lizenz: ",
|
"Save preferences": "Einstellungen speichern",
|
||||||
"Family friendly? ": "Familienfreundlich? ",
|
"Subscription manager": "Abonnementverwaltung",
|
||||||
"Wilson score: ": "Wilson-Score: ",
|
"Token manager": "Tokenverwalter",
|
||||||
"Engagement: ": "Engagement: ",
|
"Token": "Token",
|
||||||
"Whitelisted regions: ": "Erlaubte Regionen: ",
|
"`x` subscriptions": "`x` Abonnements",
|
||||||
"Blacklisted regions: ": "Unerlaubte Regionen: ",
|
"`x` tokens": "`x` Tokens",
|
||||||
"Shared `x`": "Geteilt `x`",
|
"Import/export": "Importieren/Exportieren",
|
||||||
"Hi! Looks like you have JavaScript disabled. Click here to view comments, keep in mind it may take a bit longer to load.": "Hallo! Anscheinend haben Sie JavaScript deaktiviert. Klicken Sie hier um Kommentare anzuzeigen, beachten sie dass es etwas länger dauern kann um sie zu laden.",
|
"unsubscribe": "abbestellen",
|
||||||
"View YouTube comments": "YouTube Kommentare anzeigen",
|
"revoke": "widerrufen",
|
||||||
"View more comments on Reddit": "Mehr Kommentare auf Reddit anzeigen",
|
"Subscriptions": "Abonnements",
|
||||||
"View `x` comments": "`x` Kommentare anzeigen",
|
"`x` unseen notifications": "`x` ungesehene Benachrichtigungen",
|
||||||
"View Reddit comments": "Reddit Kommentare anzeigen",
|
"search": "Suchen",
|
||||||
"Hide replies": "Antworten verstecken",
|
"Log out": "Abmelden",
|
||||||
"Show replies": "Antworten anzeigen",
|
"Released under the AGPLv3 by Omar Roth.": "Veröffentlicht unter AGPLv3 von Omar Roth.",
|
||||||
"Incorrect password": "Falsches Passwort",
|
"Source available here.": "Quellcode verfügbar hier.",
|
||||||
"Quota exceeded, try again in a few hours": "Kontingent überschritten, versuche es in ein paar Stunden erneut",
|
"View JavaScript license information.": "Javascript Lizenzinformationen anzeigen.",
|
||||||
"Unable to login, make sure two-factor authentication (Authenticator or SMS) is enabled.": "Login nicht möglich, stellen Sie sicher dass two-factor Authentifikation (Authentifizierung oder SMS) aktiviert ist.",
|
"View privacy policy.": "Datenschutzerklärung einsehen.",
|
||||||
"Invalid TFA code": "Ungültiger TFA Code",
|
"Trending": "Trending",
|
||||||
"Login failed. This may be because two-factor authentication is not enabled on your account.": "Login fehlgeschlagen. Das kann daran liegen dass two-factor Authentifizierung in ihrem Account nicht aktiviert ist.",
|
"Public": "Öffentlich",
|
||||||
"Invalid answer": "Ungültige Antwort",
|
"Unlisted": "Nicht aufgeführt",
|
||||||
"Invalid CAPTCHA": "Ungültiges CAPTCHA",
|
"Private": "Privat",
|
||||||
"CAPTCHA is a required field": "CAPTCHA ist eine erforderliche Eingabe",
|
"View all playlists": "Alle Wiedergabelisten anzeigen",
|
||||||
"User ID is a required field": "Benutzer ID ist eine erforderliche Eingabe",
|
"Updated `x` ago": "Aktualisiert `x` vor",
|
||||||
"Password is a required field": "Passwort ist eine erforderliche Eingabe",
|
"Delete playlist `x`?": "Wiedergabeliste löschen `x`?",
|
||||||
"Invalid username or password": "Ungültiger Benutzername oder Passwort",
|
"Delete playlist": "Wiedergabeliste löschen",
|
||||||
"Please sign in using 'Sign in with Google'": "Bitte melden sie sich mit 'Mit Google anmelden' an",
|
"Create playlist": "Wiedergabeliste erstellen",
|
||||||
"Password cannot be empty": "Passwort darf nicht leer sein",
|
"Title": "Titel",
|
||||||
"Password cannot be longer than 55 characters": "Passwort darf nicht länger als 55 Zeichen sein",
|
"Playlist privacy": "Vertrauliche Wiedergabeliste",
|
||||||
"Please sign in": "Bitte anmelden",
|
"Editing playlist `x`": "Wiedergabeliste bearbeiten `x`",
|
||||||
"Invidious Private Feed for `x`": "Invidious Persönlicher Feed für `x`",
|
"Watch on YouTube": "Video auf YouTube ansehen",
|
||||||
"channel:`x`": "Kanal:`x`",
|
"Hide annotations": "Anmerkungen ausblenden",
|
||||||
"Deleted or invalid channel": "Gelöschter oder ungültiger Kanal",
|
"Show annotations": "Anmerkungen anzeigen",
|
||||||
"This channel does not exist.": "Dieser Kanal existiert nicht.",
|
"Genre: ": "Genre: ",
|
||||||
"Could not get channel info.": "Kanalinformationen konnten nicht geladen werden.",
|
"License: ": "Lizenz: ",
|
||||||
"Could not fetch comments": "Kommentare konnten nicht geladen werden",
|
"Family friendly? ": "Familienfreundlich? ",
|
||||||
"View `x` replies": "Zeige `x` Antworten",
|
"Wilson score: ": "Wilson-Score: ",
|
||||||
"`x` ago": "vor `x`",
|
"Engagement: ": "Engagement: ",
|
||||||
"Load more": "Mehr laden",
|
"Whitelisted regions: ": "Erlaubte Regionen: ",
|
||||||
"`x` points": "`x` Punkte",
|
"Blacklisted regions: ": "Unerlaubte Regionen: ",
|
||||||
"Could not create mix.": "Mix konnte nicht erstellt werden.",
|
"Shared `x`": "Geteilt `x`",
|
||||||
"Playlist is empty": "Playlist ist leer",
|
"`x` views": "`x` Aufrufe",
|
||||||
"Invalid playlist.": "Ungültige Playlist.",
|
"Premieres in `x`": "Zuerst gesehen in `x`",
|
||||||
"Playlist does not exist.": "Playlist existiert nicht.",
|
"Premieres `x`": "Erster Start `x`",
|
||||||
"Could not pull trending pages.": "Trending Seiten konnten nicht geladen werden.",
|
"Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.": "Hallo! Anscheinend haben Sie JavaScript deaktiviert. Klicken Sie hier um Kommentare anzuzeigen, beachten sie dass es etwas länger dauern kann um sie zu laden.",
|
||||||
"Hidden field \"challenge\" is a required field": "Verstecktes Feld \"challenge\" ist eine erforderliche Eingabe",
|
"View YouTube comments": "YouTube Kommentare anzeigen",
|
||||||
"Hidden field \"token\" is a required field": "Verstecktes Feld \"token\" ist eine erforderliche Eingabe",
|
"View more comments on Reddit": "Mehr Kommentare auf Reddit anzeigen",
|
||||||
"Invalid challenge": "Ungültiger Test",
|
"View `x` comments": "`x` Kommentare anzeigen",
|
||||||
"Invalid token": "Ungöltige Marke",
|
"View Reddit comments": "Reddit Kommentare anzeigen",
|
||||||
"Invalid user": "Ungültiger Benutzer",
|
"Hide replies": "Antworten verstecken",
|
||||||
"Token is expired, please try again": "Marke ist abgelaufen, bitte erneut versuchen",
|
"Show replies": "Antworten anzeigen",
|
||||||
"English": "Englisch",
|
"Incorrect password": "Falsches Passwort",
|
||||||
"English (auto-generated)": "Englisch (automatisch erzeugt)",
|
"Quota exceeded, try again in a few hours": "Kontingent überschritten, versuche es in ein paar Stunden erneut",
|
||||||
"Afrikaans": "Afrikaans",
|
"Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.": "Login nicht möglich, stellen Sie sicher dass two-factor Authentifikation (Authentifizierung oder SMS) aktiviert ist.",
|
||||||
"Albanian": "Albanisch",
|
"Invalid TFA code": "Ungültiger TFA Code",
|
||||||
"Amharic": "Amharisch",
|
"Login failed. This may be because two-factor authentication is not turned on for your account.": "Login fehlgeschlagen. Das kann daran liegen dass two-factor Authentifizierung in ihrem Account nicht aktiviert ist.",
|
||||||
"Arabic": "Arabisch",
|
"Wrong answer": "Ungültige Antwort",
|
||||||
"Armenian": "Armenisch",
|
"Erroneous CAPTCHA": "Ungültiges CAPTCHA",
|
||||||
"Azerbaijani": "Aserbaidschanisch",
|
"CAPTCHA is a required field": "CAPTCHA ist eine erforderliche Eingabe",
|
||||||
"Bangla": "Bengalisch",
|
"User ID is a required field": "Benutzer ID ist eine erforderliche Eingabe",
|
||||||
"Basque": "Baskisch",
|
"Password is a required field": "Passwort ist eine erforderliche Eingabe",
|
||||||
"Belarusian": "Weißrussisch",
|
"Wrong username or password": "Ungültiger Benutzername oder Passwort",
|
||||||
"Bosnian": "Bosnisch",
|
"Please sign in using 'Log in with Google'": "Bitte melden sie sich mit 'Mit Google anmelden' an",
|
||||||
"Bulgarian": "Bulgarisch",
|
"Password cannot be empty": "Passwort darf nicht leer sein",
|
||||||
"Burmese": "Burmesisch",
|
"Password cannot be longer than 55 characters": "Passwort darf nicht länger als 55 Zeichen sein",
|
||||||
"Catalan": "Katalanisch",
|
"Please log in": "Bitte anmelden",
|
||||||
"Cebuano": "Cebuano",
|
"Invidious Private Feed for `x`": "Invidious Persönlicher Feed für `x`",
|
||||||
"Chinese (Simplified)": "Chinesisch (vereinfacht)",
|
"channel:`x`": "Kanal:`x`",
|
||||||
"Chinese (Traditional)": "Chinesisch (traditionell)",
|
"Deleted or invalid channel": "Gelöschter oder ungültiger Kanal",
|
||||||
"Corsican": "Korsisch",
|
"This channel does not exist.": "Dieser Kanal existiert nicht.",
|
||||||
"Croatian": "Kroatisch",
|
"Could not get channel info.": "Kanalinformationen konnten nicht geladen werden.",
|
||||||
"Czech": "Tschechisch",
|
"Could not fetch comments": "Kommentare konnten nicht geladen werden",
|
||||||
"Danish": "Dänisch",
|
"View `x` replies": "Zeige `x` Antworten",
|
||||||
"Dutch": "Niederländisch",
|
"`x` ago": "vor `x`",
|
||||||
"Esperanto": "Esperanto",
|
"Load more": "Mehr laden",
|
||||||
"Estonian": "Estnisch",
|
"`x` points": "`x` Punkte",
|
||||||
"Filipino": "Philippinisch",
|
"Could not create mix.": "Mix konnte nicht erstellt werden.",
|
||||||
"Finnish": "Finnisch",
|
"Empty playlist": "Playlist ist leer",
|
||||||
"French": "Französisch",
|
"Not a playlist.": "Ungültige Playlist.",
|
||||||
"Galician": "Galizisch",
|
"Playlist does not exist.": "Playlist existiert nicht.",
|
||||||
"Georgian": "Georgisch",
|
"Could not pull trending pages.": "Trending Seiten konnten nicht geladen werden.",
|
||||||
"German": "Deutsch",
|
"Hidden field \"challenge\" is a required field": "Verstecktes Feld \"challenge\" ist eine erforderliche Eingabe",
|
||||||
"Greek": "Griechisch",
|
"Hidden field \"token\" is a required field": "Verstecktes Feld \"token\" ist eine erforderliche Eingabe",
|
||||||
"Gujarati": "Gujarati",
|
"Erroneous challenge": "Ungültiger Test",
|
||||||
"Haitian Creole": "Haitianisches Kreolisch",
|
"Erroneous token": "Ungültiger Token",
|
||||||
"Hausa": "Hausa",
|
"No such user": "Ungültiger Benutzer",
|
||||||
"Hawaiian": "Hawaiianisch",
|
"Token is expired, please try again": "Token ist abgelaufen, bitte erneut versuchen",
|
||||||
"Hebrew": "Hebräisch",
|
"English": "Englisch",
|
||||||
"Hindi": "Hindi",
|
"English (auto-generated)": "Englisch (automatisch erzeugt)",
|
||||||
"Hmong": "Hmong",
|
"Afrikaans": "Afrikaans",
|
||||||
"Hungarian": "Ungarisch",
|
"Albanian": "Albanisch",
|
||||||
"Icelandic": "Isländisch",
|
"Amharic": "Amharisch",
|
||||||
"Igbo": "Igbo",
|
"Arabic": "Arabisch",
|
||||||
"Indonesian": "Indonesisch",
|
"Armenian": "Armenisch",
|
||||||
"Irish": "Irisch",
|
"Azerbaijani": "Aserbaidschanisch",
|
||||||
"Italian": "Italienisch",
|
"Bangla": "Bengalisch",
|
||||||
"Japanese": "Japanisch",
|
"Basque": "Baskisch",
|
||||||
"Javanese": "Javanisch",
|
"Belarusian": "Weißrussisch",
|
||||||
"Kannada": "Kannada",
|
"Bosnian": "Bosnisch",
|
||||||
"Kazakh": "Kasachisch",
|
"Bulgarian": "Bulgarisch",
|
||||||
"Khmer": "Khmer",
|
"Burmese": "Burmesisch",
|
||||||
"Korean": "Koreanisch",
|
"Catalan": "Katalanisch",
|
||||||
"Kurdish": "Kurdisch",
|
"Cebuano": "Cebuano",
|
||||||
"Kyrgyz": "Kirgisisch",
|
"Chinese (Simplified)": "Chinesisch (vereinfacht)",
|
||||||
"Lao": "Laotisch",
|
"Chinese (Traditional)": "Chinesisch (traditionell)",
|
||||||
"Latin": "Lateinisch",
|
"Corsican": "Korsisch",
|
||||||
"Latvian": "Lettisch",
|
"Croatian": "Kroatisch",
|
||||||
"Lithuanian": "Litauisch",
|
"Czech": "Tschechisch",
|
||||||
"Luxembourgish": "Luxemburgisch",
|
"Danish": "Dänisch",
|
||||||
"Macedonian": "Mazedonisch",
|
"Dutch": "Niederländisch",
|
||||||
"Malagasy": "Madagassisch",
|
"Esperanto": "Esperanto",
|
||||||
"Malay": "Malaiisch",
|
"Estonian": "Estnisch",
|
||||||
"Malayalam": "Malayalam",
|
"Filipino": "Philippinisch",
|
||||||
"Maltese": "Maltesisch",
|
"Finnish": "Finnisch",
|
||||||
"Maori": "Maori",
|
"French": "Französisch",
|
||||||
"Marathi": "Marathi",
|
"Galician": "Galizisch",
|
||||||
"Mongolian": "Mongolisch",
|
"Georgian": "Georgisch",
|
||||||
"Nepali": "Nepalesisch",
|
"German": "Deutsch",
|
||||||
"Norwegian": "Norwegisch",
|
"Greek": "Griechisch",
|
||||||
"Nyanja": "Nyanja",
|
"Gujarati": "Gujarati",
|
||||||
"Pashto": "Paschtunisch",
|
"Haitian Creole": "Haitianisches Kreolisch",
|
||||||
"Persian": "Persisch",
|
"Hausa": "Hausa",
|
||||||
"Polish": "Polnisch",
|
"Hawaiian": "Hawaiianisch",
|
||||||
"Portuguese": "Portugiesisch",
|
"Hebrew": "Hebräisch",
|
||||||
"Punjabi": "Pandschabi",
|
"Hindi": "Hindi",
|
||||||
"Romanian": "Rumänisch",
|
"Hmong": "Hmong",
|
||||||
"Russian": "Russisch",
|
"Hungarian": "Ungarisch",
|
||||||
"Samoan": "Samoanisch",
|
"Icelandic": "Isländisch",
|
||||||
"Scottish Gaelic": "Schottisches Gälisch",
|
"Igbo": "Igbo",
|
||||||
"Serbian": "Serbisch",
|
"Indonesian": "Indonesisch",
|
||||||
"Shona": "Schona",
|
"Irish": "Irisch",
|
||||||
"Sindhi": "Sindhi",
|
"Italian": "Italienisch",
|
||||||
"Sinhala": "Singhalesisch",
|
"Japanese": "Japanisch",
|
||||||
"Slovak": "Slowakisch",
|
"Javanese": "Javanisch",
|
||||||
"Slovenian": "Slowenisch",
|
"Kannada": "Kannada",
|
||||||
"Somali": "Somali",
|
"Kazakh": "Kasachisch",
|
||||||
"Southern Sotho": "Südliches Sotho",
|
"Khmer": "Khmer",
|
||||||
"Spanish": "Spanisch",
|
"Korean": "Koreanisch",
|
||||||
"Spanish (Latin America)": "Spanisch (Lateinamerika)",
|
"Kurdish": "Kurdisch",
|
||||||
"Sundanese": "Sundanesisch",
|
"Kyrgyz": "Kirgisisch",
|
||||||
"Swahili": "Suaheli",
|
"Lao": "Laotisch",
|
||||||
"Swedish": "Schwedisch",
|
"Latin": "Lateinisch",
|
||||||
"Tajik": "Tadschikisch",
|
"Latvian": "Lettisch",
|
||||||
"Tamil": "Tamilisch",
|
"Lithuanian": "Litauisch",
|
||||||
"Telugu": "Telugu",
|
"Luxembourgish": "Luxemburgisch",
|
||||||
"Thai": "Thailändisch",
|
"Macedonian": "Mazedonisch",
|
||||||
"Turkish": "Türkisch",
|
"Malagasy": "Madagassisch",
|
||||||
"Ukrainian": "Ukrainisch",
|
"Malay": "Malaiisch",
|
||||||
"Urdu": "Urdu",
|
"Malayalam": "Malayalam",
|
||||||
"Uzbek": "Usbekisch",
|
"Maltese": "Maltesisch",
|
||||||
"Vietnamese": "Vietnamesisch",
|
"Maori": "Maori",
|
||||||
"Welsh": "Walisisch",
|
"Marathi": "Marathi",
|
||||||
"Western Frisian": "Westfriesisch",
|
"Mongolian": "Mongolisch",
|
||||||
"Xhosa": "Xhosa",
|
"Nepali": "Nepalesisch",
|
||||||
"Yiddish": "Jiddisch",
|
"Norwegian Bokmål": "Norwegisch",
|
||||||
"Yoruba": "Joruba",
|
"Nyanja": "Nyanja",
|
||||||
"Zulu": "Zulu",
|
"Pashto": "Paschtunisch",
|
||||||
"`x` years": "`x` Jahre",
|
"Persian": "Persisch",
|
||||||
"`x` months": "`x` Monate",
|
"Polish": "Polnisch",
|
||||||
"`x` weeks": "`x` Wochen",
|
"Portuguese": "Portugiesisch",
|
||||||
"`x` days": "`x` Tage",
|
"Punjabi": "Pandschabi",
|
||||||
"`x` hours": "`x` Stunden",
|
"Romanian": "Rumänisch",
|
||||||
"`x` minutes": "`x` Minuten",
|
"Russian": "Russisch",
|
||||||
"`x` seconds": "`x` Sekunden",
|
"Samoan": "Samoanisch",
|
||||||
"Fallback comments: ": "Alternative Kommentare: ",
|
"Scottish Gaelic": "Schottisches Gälisch",
|
||||||
"Popular": "Populär",
|
"Serbian": "Serbisch",
|
||||||
"Top": "Top",
|
"Shona": "Schona",
|
||||||
"About": "Über",
|
"Sindhi": "Sindhi",
|
||||||
"Rating: ": "Bewertung: ",
|
"Sinhala": "Singhalesisch",
|
||||||
"Language: ": "Sprache: ",
|
"Slovak": "Slowakisch",
|
||||||
"Default": "",
|
"Slovenian": "Slowenisch",
|
||||||
"Music": "",
|
"Somali": "Somali",
|
||||||
"Gaming": "",
|
"Southern Sotho": "Südliches Sotho",
|
||||||
"News": "",
|
"Spanish": "Spanisch",
|
||||||
"Movies": "",
|
"Spanish (Latin America)": "Spanisch (Lateinamerika)",
|
||||||
"Download": "",
|
"Sundanese": "Sundanesisch",
|
||||||
"Download as: ": "",
|
"Swahili": "Suaheli",
|
||||||
"%A %B %-d, %Y": "",
|
"Swedish": "Schwedisch",
|
||||||
"(edited)": "",
|
"Tajik": "Tadschikisch",
|
||||||
"Youtube permalink of the comment": "",
|
"Tamil": "Tamilisch",
|
||||||
"`x` marked it with a ❤": "",
|
"Telugu": "Telugu",
|
||||||
"Audio mode": "",
|
"Thai": "Thailändisch",
|
||||||
"Video mode": ""
|
"Turkish": "Türkisch",
|
||||||
}
|
"Ukrainian": "Ukrainisch",
|
||||||
|
"Urdu": "Urdu",
|
||||||
|
"Uzbek": "Usbekisch",
|
||||||
|
"Vietnamese": "Vietnamesisch",
|
||||||
|
"Welsh": "Walisisch",
|
||||||
|
"Western Frisian": "Westfriesisch",
|
||||||
|
"Xhosa": "Xhosa",
|
||||||
|
"Yiddish": "Jiddisch",
|
||||||
|
"Yoruba": "Joruba",
|
||||||
|
"Zulu": "Zulu",
|
||||||
|
"`x` years": "`x` Jahre",
|
||||||
|
"`x` months": "`x` Monate",
|
||||||
|
"`x` weeks": "`x` Wochen",
|
||||||
|
"`x` days": "`x` Tage",
|
||||||
|
"`x` hours": "`x` Stunden",
|
||||||
|
"`x` minutes": "`x` Minuten",
|
||||||
|
"`x` seconds": "`x` Sekunden",
|
||||||
|
"Fallback comments: ": "Alternative Kommentare: ",
|
||||||
|
"Popular": "Populär",
|
||||||
|
"Top": "Top",
|
||||||
|
"About": "Über",
|
||||||
|
"Rating: ": "Bewertung: ",
|
||||||
|
"Language: ": "Sprache: ",
|
||||||
|
"View as playlist": "Als Wiedergabeliste anzeigen",
|
||||||
|
"Default": "Standard",
|
||||||
|
"Music": "Musik",
|
||||||
|
"Gaming": "Videospiele",
|
||||||
|
"News": "Neuigkeiten",
|
||||||
|
"Movies": "Filme",
|
||||||
|
"Download": "Herunterladen",
|
||||||
|
"Download as: ": "Herunterladen als: ",
|
||||||
|
"%A %B %-d, %Y": "%A %B %-d, %Y",
|
||||||
|
"(edited)": "(editiert)",
|
||||||
|
"YouTube comment permalink": "YouTube-Kommentar Permalink",
|
||||||
|
"permalink": "Permalink",
|
||||||
|
"`x` marked it with a ❤": "`x` markierte es mit einem ❤",
|
||||||
|
"Audio mode": "Audiomodus",
|
||||||
|
"Video mode": "Videomodus",
|
||||||
|
"Videos": "Videos",
|
||||||
|
"Playlists": "Wiedergabelisten",
|
||||||
|
"Community": "Gemeinschaft",
|
||||||
|
"Current version: ": "Aktuelle Version: "
|
||||||
|
}
|
||||||
381
locales/el.json
Normal file
381
locales/el.json
Normal file
@@ -0,0 +1,381 @@
|
|||||||
|
{
|
||||||
|
"`x` subscribers": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` συνδρομητής",
|
||||||
|
"": "`x` συνδρομητές"
|
||||||
|
},
|
||||||
|
"`x` videos": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` βίντεο",
|
||||||
|
"": "`x` βίντεο"
|
||||||
|
},
|
||||||
|
"`x` playlists": "",
|
||||||
|
"LIVE": "ΖΩΝΤΑΝΑ",
|
||||||
|
"Shared `x` ago": "Μοιράστηκε πριν `x`",
|
||||||
|
"Unsubscribe": "Απεγγραφή",
|
||||||
|
"Subscribe": "Εγγραφή",
|
||||||
|
"View channel on YouTube": "Προβολή καναλιού στο YouTube",
|
||||||
|
"View playlist on YouTube": "",
|
||||||
|
"newest": "νεότερα",
|
||||||
|
"oldest": "παλιότερα",
|
||||||
|
"popular": "δημοφιλή",
|
||||||
|
"last": "τελευταία",
|
||||||
|
"Next page": "Επόμενη σελίδα",
|
||||||
|
"Previous page": "Προηγούμενη σελίδα",
|
||||||
|
"Clear watch history?": "Διαγραφή ιστορικού προβολής;",
|
||||||
|
"New password": "Νέος κωδικός πρόσβασης",
|
||||||
|
"New passwords must match": "Οι νέοι κωδικοί πρόσβασης πρέπει να ταιριάζουν",
|
||||||
|
"Cannot change password for Google accounts": "Δεν επιτρέπεται η αλλαγή κωδικού πρόσβασης λογαριασμών Google",
|
||||||
|
"Authorize token?": "Εξουσιοδότηση διασύνδεσης;",
|
||||||
|
"Authorize token for `x`?": "Εξουσιοδότηση διασύνδεσης με `x`;",
|
||||||
|
"Yes": "Ναι",
|
||||||
|
"No": "Όχι",
|
||||||
|
"Import and Export Data": "Εισαγωγή και Εξαγωγή Δεδομένων",
|
||||||
|
"Import": "Εισαγωγή",
|
||||||
|
"Import Invidious data": "Εισαγωγή δεδομένων Invidious",
|
||||||
|
"Import YouTube subscriptions": "Εισαγωγή συνδρομών YouTube",
|
||||||
|
"Import FreeTube subscriptions (.db)": "Εισαγωγή συνδρομών FreeTube (.db)",
|
||||||
|
"Import NewPipe subscriptions (.json)": "Εισαγωγή συνδρομών NewPipe (.json)",
|
||||||
|
"Import NewPipe data (.zip)": "Εισαγωγή δεδομένων NewPipe (.zip)",
|
||||||
|
"Export": "Εξαγωγή",
|
||||||
|
"Export subscriptions as OPML": "Εξαγωγή συνδρομών ως OPML",
|
||||||
|
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Εξαγωγή συνδρομών ως OPML (για NewPipe & FreeTube)",
|
||||||
|
"Export data as JSON": "Εξαγωγή δεδομένων ως JSON",
|
||||||
|
"Delete account?": "Διαγραφή λογαριασμού;",
|
||||||
|
"History": "Ιστορικό",
|
||||||
|
"An alternative front-end to YouTube": "Μία εναλλακτική πλατφόρμα για το YouTube",
|
||||||
|
"JavaScript license information": "Πληροφορίες άδειας JavaScript",
|
||||||
|
"source": "πηγή",
|
||||||
|
"Log in": "Σύνδεση",
|
||||||
|
"Log in/register": "Σύνδεση/εγγραφή",
|
||||||
|
"Log in with Google": "Σύνδεση με Google",
|
||||||
|
"User ID": "Ταυτότητα χρήστη",
|
||||||
|
"Password": "Κωδικός πρόσβασης",
|
||||||
|
"Time (h:mm:ss):": "Ώρα (ω:λλ:δδ):",
|
||||||
|
"Text CAPTCHA": "Κείμενο CAPTCHA",
|
||||||
|
"Image CAPTCHA": "Εικόνα CAPTCHA",
|
||||||
|
"Sign In": "Σύνδεση",
|
||||||
|
"Register": "Εγγραφή",
|
||||||
|
"E-mail": "E-mail",
|
||||||
|
"Google verification code": "Κωδικός επαλήθευσης Google",
|
||||||
|
"Preferences": "Προτιμήσεις",
|
||||||
|
"Player preferences": "Προτιμήσεις αναπαραγωγής",
|
||||||
|
"Always loop: ": "Αυτόματη επανάληψη: ",
|
||||||
|
"Autoplay: ": "Αυτόματη αναπαραγωγή: ",
|
||||||
|
"Play next by default: ": "Αναπαραγωγή επόμενου: ",
|
||||||
|
"Autoplay next video: ": "Αυτόματη αναπαραγωγή επόμενου: ",
|
||||||
|
"Listen by default: ": "Φόρτωση μόνο ήχου: ",
|
||||||
|
"Proxy videos: ": "Αναπαραγωγή με διακομιστή μεσολάβησης (proxy): ",
|
||||||
|
"Default speed: ": "Προεπιλεγμένη ταχύτητα: ",
|
||||||
|
"Preferred video quality: ": "Προτιμώμενη ανάλυση: ",
|
||||||
|
"Player volume: ": "Ένταση αναπαραγωγής: ",
|
||||||
|
"Default comments: ": "Προεπιλεγμένα σχόλια: ",
|
||||||
|
"youtube": "youtube",
|
||||||
|
"reddit": "reddit",
|
||||||
|
"Default captions: ": "Προεπιλεγμένοι υπότιτλοι: ",
|
||||||
|
"Fallback captions: ": "Εναλλακτικοί υπότιτλοι: ",
|
||||||
|
"Show related videos: ": "Προβολή σχετικών βίντεο; ",
|
||||||
|
"Show annotations by default: ": "Αυτόματη προβολή σημειώσεων; :",
|
||||||
|
"Visual preferences": "Προτιμήσεις εμφάνισης",
|
||||||
|
"Player style: ": "",
|
||||||
|
"Dark mode: ": "Σκοτεινή λειτουργία: ",
|
||||||
|
"Theme: ": "",
|
||||||
|
"dark": "",
|
||||||
|
"light": "",
|
||||||
|
"Thin mode: ": "Ελαφριά λειτουργία: ",
|
||||||
|
"Subscription preferences": "Προτιμήσεις συνδρομών",
|
||||||
|
"Show annotations by default for subscribed channels: ": "Προβολή σημειώσεων μόνο για κανάλια στα οποία είστε συνδρομητής; ",
|
||||||
|
"Redirect homepage to feed: ": "Ανακατεύθυνση αρχικής στη ροή συνδρομών: ",
|
||||||
|
"Number of videos shown in feed: ": "Αριθμός βίντεο ανά σελίδα ροής συνδρομών: ",
|
||||||
|
"Sort videos by: ": "Ταξινόμηση ανά: ",
|
||||||
|
"published": "ημερομηνία δημοσίευσης",
|
||||||
|
"published - reverse": "ημερομηνία δημοσίευσης - ανάποδα",
|
||||||
|
"alphabetically": "αλφαβητικά",
|
||||||
|
"alphabetically - reverse": "αλφαβητικά - ανάποδα",
|
||||||
|
"channel name": "όνομα καναλιού",
|
||||||
|
"channel name - reverse": "όνομα καναλιού - ανάποδα",
|
||||||
|
"Only show latest video from channel: ": "Προβολή μόνο του τελευταίου βίντεο του καναλιού: ",
|
||||||
|
"Only show latest unwatched video from channel: ": "Προβολή μόνο του τελευταίου μη-προβεβλημένου βίντεο του καναλιού: ",
|
||||||
|
"Only show unwatched: ": "Προβολή μόνο μη-προβεβλημένων: ",
|
||||||
|
"Only show notifications (if there are any): ": "Προβολή μόνο ειδοποιήσεων (αν υπάρχουν): ",
|
||||||
|
"Enable web notifications": "",
|
||||||
|
"`x` uploaded a video": "",
|
||||||
|
"`x` is live": "",
|
||||||
|
"Data preferences": "Προτιμήσεις δεδομένων",
|
||||||
|
"Clear watch history": "Εκκαθάριση ιστορικού προβολής",
|
||||||
|
"Import/export data": "Εισαγωγή/εξαγωγή δεδομένων",
|
||||||
|
"Change password": "Αλλαγή κωδικού πρόσβασης",
|
||||||
|
"Manage subscriptions": "Διαχείριση συνδρομών",
|
||||||
|
"Manage tokens": "Διαχείριση διασυνδέσεων",
|
||||||
|
"Watch history": "Ιστορικό προβολής",
|
||||||
|
"Delete account": "Διαγραφή λογαριασμού",
|
||||||
|
"Administrator preferences": "Προτιμήσεις διαχειριστή",
|
||||||
|
"Default homepage: ": "Προεπιλεγμένη αρχική: ",
|
||||||
|
"Feed menu: ": "Μενού ροής συνδρομών: ",
|
||||||
|
"Top enabled: ": "Ενεργοποίηση κορυφαίων; ",
|
||||||
|
"CAPTCHA enabled: ": "Ενεργοποίηση CAPTCHA; ",
|
||||||
|
"Login enabled: ": "Ενεργοποίηση σύνδεσης; ",
|
||||||
|
"Registration enabled: ": "Ενεργοποίηση εγγραφής; ",
|
||||||
|
"Report statistics: ": "Αναφορά στατιστικών; ",
|
||||||
|
"Save preferences": "Αποθήκευση προτιμήσεων",
|
||||||
|
"Subscription manager": "Διαχειριστής συνδρομών",
|
||||||
|
"Token manager": "Διαχειριστής διασυνδέσεων",
|
||||||
|
"Token": "Διασύνδεση",
|
||||||
|
"`x` subscriptions": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` συνδρομή",
|
||||||
|
"": "`x` συνδρομές"
|
||||||
|
},
|
||||||
|
"`x` tokens": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` διασύνδεση",
|
||||||
|
"": "`x` διασυνδέσεις"
|
||||||
|
},
|
||||||
|
"Import/export": "Εισαγωγή/εξαγωγή",
|
||||||
|
"unsubscribe": "κατάργηση συνδρομής",
|
||||||
|
"revoke": "ανάκληση",
|
||||||
|
"Subscriptions": "Συνδρομές",
|
||||||
|
"`x` unseen notifications": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` καινούρια ειδοποίηση",
|
||||||
|
"": "`x` καινούριες ειδοποιήσεις"
|
||||||
|
},
|
||||||
|
"search": "αναζήτηση",
|
||||||
|
"Log out": "Αποσύνδεση",
|
||||||
|
"Released under the AGPLv3 by Omar Roth.": "Κυκλοφορεί υπό την άδεια AGPLv3 από τον Omar Roth.",
|
||||||
|
"Source available here.": "Προβολή πηγαίου κώδικα εδώ.",
|
||||||
|
"View JavaScript license information.": "Προβολή πληροφοριών άδειας JavaScript.",
|
||||||
|
"View privacy policy.": "Προβολή πολιτικής απορρήτου.",
|
||||||
|
"Trending": "Τάσεις",
|
||||||
|
"Public": "",
|
||||||
|
"Unlisted": "Κρυφό",
|
||||||
|
"Private": "",
|
||||||
|
"View all playlists": "",
|
||||||
|
"Updated `x` ago": "",
|
||||||
|
"Delete playlist `x`?": "",
|
||||||
|
"Delete playlist": "",
|
||||||
|
"Create playlist": "",
|
||||||
|
"Title": "",
|
||||||
|
"Playlist privacy": "",
|
||||||
|
"Editing playlist `x`": "",
|
||||||
|
"Watch on YouTube": "Προβολή στο YouTube",
|
||||||
|
"Hide annotations": "Απόκρυψη σημειώσεων",
|
||||||
|
"Show annotations": "Προβολή σημειώσεων",
|
||||||
|
"Genre: ": "Είδος: ",
|
||||||
|
"License: ": "Άδεια: ",
|
||||||
|
"Family friendly? ": "Φιλικό προς την οικογένεια; ",
|
||||||
|
"Wilson score: ": "Wilson score: ",
|
||||||
|
"Engagement: ": "Ενδιαφέρον: ",
|
||||||
|
"Whitelisted regions: ": "Επιτρεπτές περιοχές: ",
|
||||||
|
"Blacklisted regions: ": "Μη-επιτρεπτές περιοχές: ",
|
||||||
|
"Shared `x`": "Μοιράστηκε το `x`",
|
||||||
|
"`x` views": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` προβολή",
|
||||||
|
"": "`x` προβολές"
|
||||||
|
},
|
||||||
|
"Premieres in `x`": "Πρώτη προβολή σε `x`",
|
||||||
|
"Premieres `x`": "",
|
||||||
|
"Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.": "Γεια! Φαίνεται πως έχετε απενεργοποιήσει το JavaScript. Πατήστε εδώ για προβολή σχολίων, αλλά έχετε υπ'όψιν σας πως ίσως φορτώσουν πιο αργά. ",
|
||||||
|
"View YouTube comments": "Προβολή σχολίων από το YouTube",
|
||||||
|
"View more comments on Reddit": "Προβολή περισσότερων σχολίων στο Reddit",
|
||||||
|
"View `x` comments": "Προβολή `x` σχολίων",
|
||||||
|
"View Reddit comments": "Προβολή σχολίων από το Reddit",
|
||||||
|
"Hide replies": "Απόκρυψη απαντήσεων",
|
||||||
|
"Show replies": "Προβολή απαντήσεων",
|
||||||
|
"Incorrect password": "Λανθασμένος κωδικός πρόσβασης",
|
||||||
|
"Quota exceeded, try again in a few hours": "Έχετε υπερβεί το όριο προσπαθειών, δοκιμάστε ξανα σε λίγες ώρες",
|
||||||
|
"Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.": "Αδυναμία σύνδεσης, βεβαιωθείτε πως ο έλεγχος ταυτότητας δύο παραγόντων (με Authenticator ή SMS) είναι ενεργοποιημένος.",
|
||||||
|
"Invalid TFA code": "Μη έγκυρος κωδικός ελέγχου ταυτότητας δύο παραγόντων",
|
||||||
|
"Login failed. This may be because two-factor authentication is not turned on for your account.": "Αποτυχία σύνδεσης. Ίσως ευθύνεται η έλλειψη ελέγχου ταυτότητας δύο παραγόντων για το λογαριασμό σας.",
|
||||||
|
"Wrong answer": "Λανθασμένη απάντηση",
|
||||||
|
"Erroneous CAPTCHA": "Λανθασμένο CAPTCHA",
|
||||||
|
"CAPTCHA is a required field": "Το CAPTCHA είναι απαιτούμενο πεδίο",
|
||||||
|
"User ID is a required field": "Η ταυτότητα χρήστη είναι απαιτούμενο πεδίο",
|
||||||
|
"Password is a required field": "Ο κωδικός πρόσβασης είναι απαιτούμενο πεδίο",
|
||||||
|
"Wrong username or password": "Λανθασμένο όνομα χρήστη ή κωδικός πρόσβασης",
|
||||||
|
"Please sign in using 'Log in with Google'": "Συνδεθείτε με την επιλογή 'Σύνδεση με Google'",
|
||||||
|
"Password cannot be empty": "Ο κωδικός πρόσβασης δεν γίνεται να είναι κενός",
|
||||||
|
"Password cannot be longer than 55 characters": "Ο κωδικός πρόσβασης δεν γίνεται να υπερβαίνει τους 55 χαρακτήρες",
|
||||||
|
"Please log in": "Συνδεθείτε",
|
||||||
|
"Invidious Private Feed for `x`": "Ροή RSS του Invidious για το χρήστη `x`",
|
||||||
|
"channel:`x`": "κανάλι:`x`",
|
||||||
|
"Deleted or invalid channel": "Διαγραμμένο ή μη έγκυρο κανάλι",
|
||||||
|
"This channel does not exist.": "Αυτό το κανάλι δεν υπάρχει.",
|
||||||
|
"Could not get channel info.": "Αδύναμια εύρεσης πληροφοριών καναλιού.",
|
||||||
|
"Could not fetch comments": "Αδυναμία λήψης σχολίων",
|
||||||
|
"View `x` replies": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "Προβολή `x` απάντησης",
|
||||||
|
"": "Προβολή `x` απαντήσεων"
|
||||||
|
},
|
||||||
|
"`x` ago": "Πριν `x`",
|
||||||
|
"Load more": "Φόρτωση περισσότερων",
|
||||||
|
"`x` points": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` βαθμός",
|
||||||
|
"": "`x` βαθμοί"
|
||||||
|
},
|
||||||
|
"Could not create mix.": "Αδυναμία δημιουργίας μίξης.",
|
||||||
|
"Empty playlist": "Κενή λίστα αναπαραγωγής",
|
||||||
|
"Not a playlist.": "Μη έγκυρη λίστα αναπαραγωγής",
|
||||||
|
"Playlist does not exist.": "Μη υπαρκτή λίστα αναπαραγωγής.",
|
||||||
|
"Could not pull trending pages.": "Αδυναμία λήψης σελίδας τάσεων.",
|
||||||
|
"Hidden field \"challenge\" is a required field": "Το Κρυφό πεδίο \"δοκιμασία\" είναι απαραίτητο",
|
||||||
|
"Hidden field \"token\" is a required field": "Το κρυφό πεδίο \"αναγνωριστικό διασύνδεσης\" είναι απαραίτητο",
|
||||||
|
"Erroneous challenge": "Λανθασμένη δοκιμασία",
|
||||||
|
"Erroneous token": "Λανθασμένο αναγνωριστικό διασύνδεσης",
|
||||||
|
"No such user": "Μη υπαρκτός χρήστης",
|
||||||
|
"Token is expired, please try again": "Το αναγνωριστικό διασύνδεσης έχει λήξει, παρακαλώ ξαναπροσπαθήστε",
|
||||||
|
"English": "Αγγλικά",
|
||||||
|
"English (auto-generated)": "Αγγλικά (αυτόματα)",
|
||||||
|
"Afrikaans": "Αφρικάανς",
|
||||||
|
"Albanian": "Αλβανικά",
|
||||||
|
"Amharic": "Αμχαρικά",
|
||||||
|
"Arabic": "Αραβικά",
|
||||||
|
"Armenian": "Αρμένικα",
|
||||||
|
"Azerbaijani": "Αζερικά",
|
||||||
|
"Bangla": "Μπενγκάλι",
|
||||||
|
"Basque": "Βασκικά",
|
||||||
|
"Belarusian": "Λευκορωσικά",
|
||||||
|
"Bosnian": "Βοσνιακά",
|
||||||
|
"Bulgarian": "Βουλγάρικα",
|
||||||
|
"Burmese": "Βιρμανικά",
|
||||||
|
"Catalan": "Καταλανικά",
|
||||||
|
"Cebuano": "Κεμπουάνο",
|
||||||
|
"Chinese (Simplified)": "Κινέζικα (Απλοποιημένα)",
|
||||||
|
"Chinese (Traditional)": "Κινέζικα (Παραδοσιακά)",
|
||||||
|
"Corsican": "Κορσικανικά",
|
||||||
|
"Croatian": "Κροατικά",
|
||||||
|
"Czech": "Τσέχικα",
|
||||||
|
"Danish": "Δανέζικα",
|
||||||
|
"Dutch": "Ολλανδικά",
|
||||||
|
"Esperanto": "Εσπεράντο",
|
||||||
|
"Estonian": "Εσθονικά",
|
||||||
|
"Filipino": "Φιλιππινέζικα",
|
||||||
|
"Finnish": "Φινλανδικά",
|
||||||
|
"French": "Γαλλικά",
|
||||||
|
"Galician": "Γαλικιακά",
|
||||||
|
"Georgian": "Γεωργιανά",
|
||||||
|
"German": "Γερμανικά",
|
||||||
|
"Greek": "Ελληνικά",
|
||||||
|
"Gujarati": "Γκουτζαρατικά",
|
||||||
|
"Haitian Creole": "Κρεόλ Αϊτής",
|
||||||
|
"Hausa": "Χάουσα",
|
||||||
|
"Hawaiian": "Χαβανέζικα",
|
||||||
|
"Hebrew": "Εβραϊκά",
|
||||||
|
"Hindi": "Χίντι",
|
||||||
|
"Hmong": "Χμονγκ",
|
||||||
|
"Hungarian": "Ουγγαρέζικα",
|
||||||
|
"Icelandic": "Ισλανδικά",
|
||||||
|
"Igbo": "Ιγκμπό",
|
||||||
|
"Indonesian": "Ινδονησιακά",
|
||||||
|
"Irish": "Ιρλανδικά",
|
||||||
|
"Italian": "Ιταλικά",
|
||||||
|
"Japanese": "Ιαπωνικά",
|
||||||
|
"Javanese": "Ιαβανέζικα",
|
||||||
|
"Kannada": "Κανάντα",
|
||||||
|
"Kazakh": "Καζακικά",
|
||||||
|
"Khmer": "Χμερ",
|
||||||
|
"Korean": "Κορεάτικα",
|
||||||
|
"Kurdish": "Κούρδικα",
|
||||||
|
"Kyrgyz": "Κιργιστανικά",
|
||||||
|
"Lao": "Lao",
|
||||||
|
"Latin": "Λατινικά",
|
||||||
|
"Latvian": "Λετονικά",
|
||||||
|
"Lithuanian": "Λιθουανικά",
|
||||||
|
"Luxembourgish": "Λουξεμβουργιανά",
|
||||||
|
"Macedonian": "Μακεδονικά",
|
||||||
|
"Malagasy": "Μαλαγασικά",
|
||||||
|
"Malay": "Μαλαισιανά",
|
||||||
|
"Malayalam": "Μαλαγιαλάμ",
|
||||||
|
"Maltese": "Μαλτέζικα",
|
||||||
|
"Maori": "Μαορί",
|
||||||
|
"Marathi": "Μαράτι",
|
||||||
|
"Mongolian": "Μογγολικά",
|
||||||
|
"Nepali": "Νεπαλικά",
|
||||||
|
"Norwegian Bokmål": "Νορβηγικά Μποκμάλ",
|
||||||
|
"Nyanja": "Νιάντζα",
|
||||||
|
"Pashto": "Αφγανικά",
|
||||||
|
"Persian": "Περσικά",
|
||||||
|
"Polish": "Πολωνικά",
|
||||||
|
"Portuguese": "Πορτογαλικά",
|
||||||
|
"Punjabi": "Παντζάμπι",
|
||||||
|
"Romanian": "Ρουμανικά",
|
||||||
|
"Russian": "Ρώσικα",
|
||||||
|
"Samoan": "Σαμόα",
|
||||||
|
"Scottish Gaelic": "Σκωτικά Γαελικά",
|
||||||
|
"Serbian": "Σέρβικα",
|
||||||
|
"Shona": "Σόνα",
|
||||||
|
"Sindhi": "Σίντι",
|
||||||
|
"Sinhala": "Σιναλεζικά",
|
||||||
|
"Slovak": "Σλοβακικά",
|
||||||
|
"Slovenian": "ΣΛοβενικά",
|
||||||
|
"Somali": "Σομαλικά",
|
||||||
|
"Southern Sotho": "Νότια Σούτου",
|
||||||
|
"Spanish": "Ισπανικά",
|
||||||
|
"Spanish (Latin America)": "Ισπανικά (Λατινική Αμερική)",
|
||||||
|
"Sundanese": "Σουντανέζικα",
|
||||||
|
"Swahili": "Σουαχίλι",
|
||||||
|
"Swedish": "Σουηδικά",
|
||||||
|
"Tajik": "Τατζικικά",
|
||||||
|
"Tamil": "Ταμίλ",
|
||||||
|
"Telugu": "Τελούγκου",
|
||||||
|
"Thai": "Ταϊλανδικά",
|
||||||
|
"Turkish": "Τούρκικα",
|
||||||
|
"Ukrainian": "Ουκρανικά",
|
||||||
|
"Urdu": "Ουρντού",
|
||||||
|
"Uzbek": "Ουζμπεκικά",
|
||||||
|
"Vietnamese": "Βιετναμέζικα",
|
||||||
|
"Welsh": "Ουαλικά",
|
||||||
|
"Western Frisian": "Δυτική Φριζική",
|
||||||
|
"Xhosa": "Xhosa",
|
||||||
|
"Yiddish": "Γίντις",
|
||||||
|
"Yoruba": "Γιορούμπα",
|
||||||
|
"Zulu": "Ζουλού",
|
||||||
|
"`x` years": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` χρόνο",
|
||||||
|
"": "`x` χρόνια"
|
||||||
|
},
|
||||||
|
"`x` months": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` μήνα",
|
||||||
|
"": "`x` μήνες"
|
||||||
|
},
|
||||||
|
"`x` weeks": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` εβδομάδα",
|
||||||
|
"": "`x` εβδομάδες"
|
||||||
|
},
|
||||||
|
"`x` days": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` ημέρα",
|
||||||
|
"": "`x` ημέρες"
|
||||||
|
},
|
||||||
|
"`x` hours": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` ώρα",
|
||||||
|
"": "`x` ώρες"
|
||||||
|
},
|
||||||
|
"`x` minutes": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` λεπτό",
|
||||||
|
"": "`x` λεπτά"
|
||||||
|
},
|
||||||
|
"`x` seconds": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` δευτερόλεπτο",
|
||||||
|
"": "`x` δευτερόλεπτα"
|
||||||
|
},
|
||||||
|
"Fallback comments: ": "Εναλλακτικά σχόλια: ",
|
||||||
|
"Popular": "Δημοφιλή",
|
||||||
|
"Top": "Κορυφαία",
|
||||||
|
"About": "Σχετικά",
|
||||||
|
"Rating: ": "Aξιολόγηση: ",
|
||||||
|
"Language: ": "Γλώσσα: ",
|
||||||
|
"View as playlist": "Προβολή ως λίστα αναπαραγωγής",
|
||||||
|
"Default": "Προεπιλογή",
|
||||||
|
"Music": "Μουσική",
|
||||||
|
"Gaming": "Παιχνίδια",
|
||||||
|
"News": "Ειδήσεις",
|
||||||
|
"Movies": "Ταινίες",
|
||||||
|
"Download": "Λήψη",
|
||||||
|
"Download as: ": "Λήψη ως: ",
|
||||||
|
"%A %B %-d, %Y": "%A %B %-d, %Y",
|
||||||
|
"(edited)": "(τροποποιημένο)",
|
||||||
|
"YouTube comment permalink": "Σύνδεσμος YouTube σχολίου",
|
||||||
|
"permalink": "",
|
||||||
|
"`x` marked it with a ❤": "Ο χρηστης `x` έβαλε ❤",
|
||||||
|
"Audio mode": "Λειτουργία ήχου",
|
||||||
|
"Video mode": "Λειτουργία βίντεο",
|
||||||
|
"Videos": "Βίντεο",
|
||||||
|
"Playlists": "Λίστες Αναπαραγωγής",
|
||||||
|
"Community": "",
|
||||||
|
"Current version: ": "Τρέχουσα έκδοση: "
|
||||||
|
}
|
||||||
@@ -1,288 +1,387 @@
|
|||||||
{
|
{
|
||||||
"`x` subscribers": "`x` subscribers",
|
"`x` subscribers": {
|
||||||
"`x` videos": "`x` videos",
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` subscriber",
|
||||||
"LIVE": "LIVE",
|
"": "`x` subscribers"
|
||||||
"Shared `x` ago": "Shared `x` ago",
|
},
|
||||||
"Unsubscribe": "Unsubscribe",
|
"`x` videos": {
|
||||||
"Subscribe": "Subscribe",
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` video",
|
||||||
"Login to subscribe to `x`": "Login to subscribe to `x`",
|
"": "`x` videos"
|
||||||
"View channel on YouTube": "View channel on YouTube",
|
},
|
||||||
"newest": "newest",
|
"`x` playlists": {
|
||||||
"oldest": "oldest",
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` playlist",
|
||||||
"popular": "popular",
|
"": "`x` playlists"
|
||||||
"Preview page": "Preview page",
|
},
|
||||||
"Next page": "Next page",
|
"LIVE": "LIVE",
|
||||||
"Clear watch history?": "Clear watch history?",
|
"Shared `x` ago": "Shared `x` ago",
|
||||||
"Yes": "Yes",
|
"Unsubscribe": "Unsubscribe",
|
||||||
"No": "No",
|
"Subscribe": "Subscribe",
|
||||||
"Import and Export Data": "Import and Export Data",
|
"View channel on YouTube": "View channel on YouTube",
|
||||||
"Import": "Import",
|
"View playlist on YouTube": "View playlist on YouTube",
|
||||||
"Import Invidious data": "Import Invidious data",
|
"newest": "newest",
|
||||||
"Import YouTube subscriptions": "Import YouTube subscriptions",
|
"oldest": "oldest",
|
||||||
"Import FreeTube subscriptions (.db)": "Import FreeTube subscriptions (.db)",
|
"popular": "popular",
|
||||||
"Import NewPipe subscriptions (.json)": "Import NewPipe subscriptions (.json)",
|
"last": "last",
|
||||||
"Import NewPipe data (.zip)": "Import NewPipe data (.zip)",
|
"Next page": "Next page",
|
||||||
"Export": "Export",
|
"Previous page": "Previous page",
|
||||||
"Export subscriptions as OPML": "Export subscriptions as OPML",
|
"Clear watch history?": "Clear watch history?",
|
||||||
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Export subscriptions as OPML (for NewPipe & FreeTube)",
|
"New password": "New password",
|
||||||
"Export data as JSON": "Export data as JSON",
|
"New passwords must match": "New passwords must match",
|
||||||
"Delete account?": "Delete account?",
|
"Cannot change password for Google accounts": "Cannot change password for Google accounts",
|
||||||
"History": "History",
|
"Authorize token?": "Authorize token?",
|
||||||
"Previous page": "Previous page",
|
"Authorize token for `x`?": "Authorize token for `x`?",
|
||||||
"An alternative front-end to YouTube": "An alternative front-end to YouTube",
|
"Yes": "Yes",
|
||||||
"JavaScript license information": "JavaScript license information",
|
"No": "No",
|
||||||
"source": "source",
|
"Import and Export Data": "Import and Export Data",
|
||||||
"Login": "Login",
|
"Import": "Import",
|
||||||
"Login/Register": "Login/Register",
|
"Import Invidious data": "Import Invidious data",
|
||||||
"Login to Google": "Login to Google",
|
"Import YouTube subscriptions": "Import YouTube subscriptions",
|
||||||
"User ID:": "User ID:",
|
"Import FreeTube subscriptions (.db)": "Import FreeTube subscriptions (.db)",
|
||||||
"Password:": "Password:",
|
"Import NewPipe subscriptions (.json)": "Import NewPipe subscriptions (.json)",
|
||||||
"Time (h:mm:ss):": "Time (h:mm:ss):",
|
"Import NewPipe data (.zip)": "Import NewPipe data (.zip)",
|
||||||
"Text CAPTCHA": "Text CAPTCHA",
|
"Export": "Export",
|
||||||
"Image CAPTCHA": "Image CAPTCHA",
|
"Export subscriptions as OPML": "Export subscriptions as OPML",
|
||||||
"Sign In": "Sign In",
|
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Export subscriptions as OPML (for NewPipe & FreeTube)",
|
||||||
"Register": "Register",
|
"Export data as JSON": "Export data as JSON",
|
||||||
"Email:": "Email:",
|
"Delete account?": "Delete account?",
|
||||||
"Google verification code:": "Google verification code:",
|
"History": "History",
|
||||||
"Preferences": "Preferences",
|
"An alternative front-end to YouTube": "An alternative front-end to YouTube",
|
||||||
"Player preferences": "Player preferences",
|
"JavaScript license information": "JavaScript license information",
|
||||||
"Always loop: ": "Always loop: ",
|
"source": "source",
|
||||||
"Autoplay: ": "Autoplay: ",
|
"Log in": "Log in",
|
||||||
"Autoplay next video: ": "Autoplay next video: ",
|
"Log in/register": "Log in/register",
|
||||||
"Listen by default: ": "Listen by default: ",
|
"Log in with Google": "Log in with Google",
|
||||||
"Default speed: ": "Default speed: ",
|
"User ID": "User ID",
|
||||||
"Preferred video quality: ": "Preferred video quality: ",
|
"Password": "Password",
|
||||||
"Player volume: ": "Player volume: ",
|
"Time (h:mm:ss):": "Time (h:mm:ss):",
|
||||||
"Default comments: ": "Default comments: ",
|
"Text CAPTCHA": "Text CAPTCHA",
|
||||||
"Default captions: ": "Default captions: ",
|
"Image CAPTCHA": "Image CAPTCHA",
|
||||||
"Fallback captions: ": "Fallback captions: ",
|
"Sign In": "Sign In",
|
||||||
"Show related videos? ": "Show related videos? ",
|
"Register": "Register",
|
||||||
"Visual preferences": "Visual preferences",
|
"E-mail": "E-mail",
|
||||||
"Dark mode: ": "Dark mode: ",
|
"Google verification code": "Google verification code",
|
||||||
"Thin mode: ": "Thin mode: ",
|
"Preferences": "Preferences",
|
||||||
"Subscription preferences": "Subscription preferences",
|
"Player preferences": "Player preferences",
|
||||||
"Redirect homepage to feed: ": "Redirect homepage to feed: ",
|
"Always loop: ": "Always loop: ",
|
||||||
"Number of videos shown in feed: ": "Number of videos shown in feed: ",
|
"Autoplay: ": "Autoplay: ",
|
||||||
"Sort videos by: ": "Sort videos by: ",
|
"Play next by default: ": "Play next by default: ",
|
||||||
"published": "published",
|
"Autoplay next video: ": "Autoplay next video: ",
|
||||||
"published - reverse": "published - reverse",
|
"Listen by default: ": "Listen by default: ",
|
||||||
"alphabetically": "alphabetically",
|
"Proxy videos: ": "Proxy videos: ",
|
||||||
"alphabetically - reverse": "alphabetically - reverse",
|
"Default speed: ": "Default speed: ",
|
||||||
"channel name": "channel name",
|
"Preferred video quality: ": "Preferred video quality: ",
|
||||||
"channel name - reverse": "channel name - reverse",
|
"Player volume: ": "Player volume: ",
|
||||||
"Only show latest video from channel: ": "Only show latest video from channel: ",
|
"Default comments: ": "Default comments: ",
|
||||||
"Only show latest unwatched video from channel: ": "Only show latest unwatched video from channel: ",
|
"youtube": "youtube",
|
||||||
"Only show unwatched: ": "Only show unwatched: ",
|
"reddit": "reddit",
|
||||||
"Only show notifications (if there are any): ": "Only show notifications (if there are any): ",
|
"Default captions: ": "Default captions: ",
|
||||||
"Data preferences": "Data preferences",
|
"Fallback captions: ": "Fallback captions: ",
|
||||||
"Clear watch history": "Clear watch history",
|
"Show related videos: ": "Show related videos: ",
|
||||||
"Import/Export data": "Import/Export data",
|
"Show annotations by default: ": "Show annotations by default: ",
|
||||||
"Manage subscriptions": "Manage subscriptions",
|
"Visual preferences": "Visual preferences",
|
||||||
"Watch history": "Watch history",
|
"Player style: ": "Player style: ",
|
||||||
"Delete account": "Delete account",
|
"Dark mode: ": "Dark mode: ",
|
||||||
"Administrator preferences": "Administrator preferences",
|
"Theme: ": "Theme: ",
|
||||||
"Default homepage: ": "Default homepage: ",
|
"dark": "dark",
|
||||||
"Feed menu: ": "Feed menu: ",
|
"light": "light",
|
||||||
"Top enabled? ": "Top enabled? ",
|
"Thin mode: ": "Thin mode: ",
|
||||||
"CAPTCHA enabled? ": "CAPTCHA enabled? ",
|
"Subscription preferences": "Subscription preferences",
|
||||||
"Login enabled? ": "Login enabled? ",
|
"Show annotations by default for subscribed channels: ": "Show annotations by default for subscribed channels? ",
|
||||||
"Registration enabled? ": "Registration enabled? ",
|
"Redirect homepage to feed: ": "Redirect homepage to feed: ",
|
||||||
"Report statistics? ": "Report statistics? ",
|
"Number of videos shown in feed: ": "Number of videos shown in feed: ",
|
||||||
"Save preferences": "Save preferences",
|
"Sort videos by: ": "Sort videos by: ",
|
||||||
"Subscription manager": "Subscription manager",
|
"published": "published",
|
||||||
"`x` subscriptions": "`x` subscriptions",
|
"published - reverse": "published - reverse",
|
||||||
"Import/Export": "Import/Export",
|
"alphabetically": "alphabetically",
|
||||||
"unsubscribe": "unsubscribe",
|
"alphabetically - reverse": "alphabetically - reverse",
|
||||||
"Subscriptions": "Subscriptions",
|
"channel name": "channel name",
|
||||||
"`x` unseen notifications": "`x` unseen notifications",
|
"channel name - reverse": "channel name - reverse",
|
||||||
"search": "search",
|
"Only show latest video from channel: ": "Only show latest video from channel: ",
|
||||||
"Sign out": "Sign out",
|
"Only show latest unwatched video from channel: ": "Only show latest unwatched video from channel: ",
|
||||||
"Released under the AGPLv3 by Omar Roth.": "Released under the AGPLv3 by Omar Roth.",
|
"Only show unwatched: ": "Only show unwatched: ",
|
||||||
"Source available here.": "Source available here.",
|
"Only show notifications (if there are any): ": "Only show notifications (if there are any): ",
|
||||||
"View JavaScript license information.": "View JavaScript license information.",
|
"Enable web notifications": "Enable web notifications",
|
||||||
"Trending": "Trending",
|
"`x` uploaded a video": "`x` uploaded a video",
|
||||||
"Watch video on Youtube": "Watch video on Youtube",
|
"`x` is live": "`x` is live",
|
||||||
"Genre: ": "Genre: ",
|
"Data preferences": "Data preferences",
|
||||||
"License: ": "License: ",
|
"Clear watch history": "Clear watch history",
|
||||||
"Family friendly? ": "Family friendly? ",
|
"Import/export data": "Import/export data",
|
||||||
"Wilson score: ": "Wilson score: ",
|
"Change password": "Change password",
|
||||||
"Engagement: ": "Engagement: ",
|
"Manage subscriptions": "Manage subscriptions",
|
||||||
"Whitelisted regions: ": "Whitelisted regions: ",
|
"Manage tokens": "Manage tokens",
|
||||||
"Blacklisted regions: ": "Blacklisted regions: ",
|
"Watch history": "Watch history",
|
||||||
"Shared `x`": "Shared `x`",
|
"Delete account": "Delete account",
|
||||||
"Hi! Looks like you have JavaScript disabled. Click here to view comments, keep in mind it may take a bit longer to load.": "Hi! Looks like you have JavaScript disabled. Click here to view comments, keep in mind it may take a bit longer to load.",
|
"Administrator preferences": "Administrator preferences",
|
||||||
"View YouTube comments": "View YouTube comments",
|
"Default homepage: ": "Default homepage: ",
|
||||||
"View more comments on Reddit": "View more comments on Reddit",
|
"Feed menu: ": "Feed menu: ",
|
||||||
"View `x` comments": "View `x` comments",
|
"Top enabled: ": "Top enabled: ",
|
||||||
"View Reddit comments": "View Reddit comments",
|
"CAPTCHA enabled: ": "CAPTCHA enabled: ",
|
||||||
"Hide replies": "Hide replies",
|
"Login enabled: ": "Login enabled: ",
|
||||||
"Show replies": "Show replies",
|
"Registration enabled: ": "Registration enabled: ",
|
||||||
"Incorrect password": "Incorrect password",
|
"Report statistics: ": "Report statistics: ",
|
||||||
"Quota exceeded, try again in a few hours": "Quota exceeded, try again in a few hours",
|
"Save preferences": "Save preferences",
|
||||||
"Unable to login, make sure two-factor authentication (Authenticator or SMS) is enabled.": "Unable to login, make sure two-factor authentication (Authenticator or SMS) is enabled.",
|
"Subscription manager": "Subscription manager",
|
||||||
"Invalid TFA code": "Invalid TFA code",
|
"Token manager": "Token manager",
|
||||||
"Login failed. This may be because two-factor authentication is not enabled on your account.": "Login failed. This may be because two-factor authentication is not enabled on your account.",
|
"Token": "Token",
|
||||||
"Invalid answer": "Invalid answer",
|
"`x` subscriptions": {
|
||||||
"Invalid CAPTCHA": "Invalid CAPTCHA",
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` subscription",
|
||||||
"CAPTCHA is a required field": "CAPTCHA is a required field",
|
"": "`x` subscriptions"
|
||||||
"User ID is a required field": "User ID is a required field",
|
},
|
||||||
"Password is a required field": "Password is a required field",
|
"`x` tokens": {
|
||||||
"Invalid username or password": "Invalid username or password",
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` token",
|
||||||
"Please sign in using 'Sign in with Google'": "Please sign in using 'Sign in with Google'",
|
"": "`x` tokens"
|
||||||
"Password cannot be empty": "Password cannot be empty",
|
},
|
||||||
"Password cannot be longer than 55 characters": "Password cannot be longer than 55 characters",
|
"Import/export": "Import/export",
|
||||||
"Please sign in": "Please sign in",
|
"unsubscribe": "unsubscribe",
|
||||||
"Invidious Private Feed for `x`": "Invidious Private Feed for `x`",
|
"revoke": "revoke",
|
||||||
"channel:`x`": "channel:`x`",
|
"Subscriptions": "Subscriptions",
|
||||||
"Deleted or invalid channel": "Deleted or invalid channel",
|
"`x` unseen notifications": {
|
||||||
"This channel does not exist.": "This channel does not exist.",
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` unseen notification",
|
||||||
"Could not get channel info.": "Could not get channel info.",
|
"": "`x` unseen notifications"
|
||||||
"Could not fetch comments": "Could not fetch comments",
|
},
|
||||||
"View `x` replies": "View `x` replies",
|
"search": "search",
|
||||||
"`x` ago": "`x` ago",
|
"Log out": "Log out",
|
||||||
"Load more": "Load more",
|
"Released under the AGPLv3 by Omar Roth.": "Released under the AGPLv3 by Omar Roth.",
|
||||||
"`x` points": "`x` points",
|
"Source available here.": "Source available here.",
|
||||||
"Could not create mix.": "Could not create mix.",
|
"View JavaScript license information.": "View JavaScript license information.",
|
||||||
"Playlist is empty": "Playlist is empty",
|
"View privacy policy.": "View privacy policy.",
|
||||||
"Invalid playlist.": "Invalid playlist.",
|
"Trending": "Trending",
|
||||||
"Playlist does not exist.": "Playlist does not exist.",
|
"Public": "Public",
|
||||||
"Could not pull trending pages.": "Could not pull trending pages.",
|
"Unlisted": "Unlisted",
|
||||||
"Hidden field \"challenge\" is a required field": "Hidden field \"challenge\" is a required field",
|
"Private": "Private",
|
||||||
"Hidden field \"token\" is a required field": "Hidden field \"token\" is a required field",
|
"View all playlists": "View all playlists",
|
||||||
"Invalid challenge": "Invalid challenge",
|
"Updated `x` ago": "Updated `x` ago",
|
||||||
"Invalid token": "Invalid token",
|
"Delete playlist `x`?": "Delete playlist `x`?",
|
||||||
"Invalid user": "Invalid user",
|
"Delete playlist": "Delete playlist",
|
||||||
"Token is expired, please try again": "Token is expired, please try again",
|
"Create playlist": "Create playlist",
|
||||||
"English": "English",
|
"Title": "Title",
|
||||||
"English (auto-generated)": "English (auto-generated)",
|
"Playlist privacy": "Playlist privacy",
|
||||||
"Afrikaans": "Afrikaans",
|
"Editing playlist `x`": "Editing playlist `x`",
|
||||||
"Albanian": "Albanian",
|
"Watch on YouTube": "Watch on YouTube",
|
||||||
"Amharic": "Amharic",
|
"Hide annotations": "Hide annotations",
|
||||||
"Arabic": "Arabic",
|
"Show annotations": "Show annotations",
|
||||||
"Armenian": "Armenian",
|
"Genre: ": "Genre: ",
|
||||||
"Azerbaijani": "Azerbaijani",
|
"License: ": "License: ",
|
||||||
"Bangla": "Bangla",
|
"Family friendly? ": "Family friendly? ",
|
||||||
"Basque": "Basque",
|
"Wilson score: ": "Wilson score: ",
|
||||||
"Belarusian": "Belarusian",
|
"Engagement: ": "Engagement: ",
|
||||||
"Bosnian": "Bosnian",
|
"Whitelisted regions: ": "Whitelisted regions: ",
|
||||||
"Bulgarian": "Bulgarian",
|
"Blacklisted regions: ": "Blacklisted regions: ",
|
||||||
"Burmese": "Burmese",
|
"Shared `x`": "Shared `x`",
|
||||||
"Catalan": "Catalan",
|
"`x` views": {
|
||||||
"Cebuano": "Cebuano",
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` view",
|
||||||
"Chinese (Simplified)": "Chinese (Simplified)",
|
"": "`x` views"
|
||||||
"Chinese (Traditional)": "Chinese (Traditional)",
|
},
|
||||||
"Corsican": "Corsican",
|
"Premieres in `x`": "Premieres in `x`",
|
||||||
"Croatian": "Croatian",
|
"Premieres `x`": "Premieres `x`",
|
||||||
"Czech": "Czech",
|
"Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.": "Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.",
|
||||||
"Danish": "Danish",
|
"View YouTube comments": "View YouTube comments",
|
||||||
"Dutch": "Dutch",
|
"View more comments on Reddit": "View more comments on Reddit",
|
||||||
"Esperanto": "Esperanto",
|
"View `x` comments": {
|
||||||
"Estonian": "Estonian",
|
"([^.,0-9]|^)1([^.,0-9]|$)": "View `x` comment",
|
||||||
"Filipino": "Filipino",
|
"": "View `x` comments"
|
||||||
"Finnish": "Finnish",
|
},
|
||||||
"French": "French",
|
"View Reddit comments": "View Reddit comments",
|
||||||
"Galician": "Galician",
|
"Hide replies": "Hide replies",
|
||||||
"Georgian": "Georgian",
|
"Show replies": "Show replies",
|
||||||
"German": "German",
|
"Incorrect password": "Incorrect password",
|
||||||
"Greek": "Greek",
|
"Quota exceeded, try again in a few hours": "Quota exceeded, try again in a few hours",
|
||||||
"Gujarati": "Gujarati",
|
"Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.": "Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.",
|
||||||
"Haitian Creole": "Haitian Creole",
|
"Invalid TFA code": "Invalid TFA code",
|
||||||
"Hausa": "Hausa",
|
"Login failed. This may be because two-factor authentication is not turned on for your account.": "Login failed. This may be because two-factor authentication is not turned on for your account.",
|
||||||
"Hawaiian": "Hawaiian",
|
"Wrong answer": "Wrong answer",
|
||||||
"Hebrew": "Hebrew",
|
"Erroneous CAPTCHA": "Erroneous CAPTCHA",
|
||||||
"Hindi": "Hindi",
|
"CAPTCHA is a required field": "CAPTCHA is a required field",
|
||||||
"Hmong": "Hmong",
|
"User ID is a required field": "User ID is a required field",
|
||||||
"Hungarian": "Hungarian",
|
"Password is a required field": "Password is a required field",
|
||||||
"Icelandic": "Icelandic",
|
"Wrong username or password": "Wrong username or password",
|
||||||
"Igbo": "Igbo",
|
"Please sign in using 'Log in with Google'": "Please sign in using 'Log in with Google'",
|
||||||
"Indonesian": "Indonesian",
|
"Password cannot be empty": "Password cannot be empty",
|
||||||
"Irish": "Irish",
|
"Password cannot be longer than 55 characters": "Password cannot be longer than 55 characters",
|
||||||
"Italian": "Italian",
|
"Please log in": "Please log in",
|
||||||
"Japanese": "Japanese",
|
"Invidious Private Feed for `x`": "Invidious Private Feed for `x`",
|
||||||
"Javanese": "Javanese",
|
"channel:`x`": "channel:`x`",
|
||||||
"Kannada": "Kannada",
|
"Deleted or invalid channel": "Deleted or invalid channel",
|
||||||
"Kazakh": "Kazakh",
|
"This channel does not exist.": "This channel does not exist.",
|
||||||
"Khmer": "Khmer",
|
"Could not get channel info.": "Could not get channel info.",
|
||||||
"Korean": "Korean",
|
"Could not fetch comments": "Could not fetch comments",
|
||||||
"Kurdish": "Kurdish",
|
"View `x` replies": {
|
||||||
"Kyrgyz": "Kyrgyz",
|
"([^.,0-9]|^)1([^.,0-9]|$)": "View `x` reply",
|
||||||
"Lao": "Lao",
|
"": "View `x` replies"
|
||||||
"Latin": "Latin",
|
},
|
||||||
"Latvian": "Latvian",
|
"`x` ago": "`x` ago",
|
||||||
"Lithuanian": "Lithuanian",
|
"Load more": "Load more",
|
||||||
"Luxembourgish": "Luxembourgish",
|
"`x` points": {
|
||||||
"Macedonian": "Macedonian",
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` point",
|
||||||
"Malagasy": "Malagasy",
|
"": "`x` points"
|
||||||
"Malay": "Malay",
|
},
|
||||||
"Malayalam": "Malayalam",
|
"Could not create mix.": "Could not create mix.",
|
||||||
"Maltese": "Maltese",
|
"Empty playlist": "Empty playlist",
|
||||||
"Maori": "Maori",
|
"Not a playlist.": "Not a playlist.",
|
||||||
"Marathi": "Marathi",
|
"Playlist does not exist.": "Playlist does not exist.",
|
||||||
"Mongolian": "Mongolian",
|
"Could not pull trending pages.": "Could not pull trending pages.",
|
||||||
"Nepali": "Nepali",
|
"Hidden field \"challenge\" is a required field": "Hidden field \"challenge\" is a required field",
|
||||||
"Norwegian": "Norwegian",
|
"Hidden field \"token\" is a required field": "Hidden field \"token\" is a required field",
|
||||||
"Nyanja": "Nyanja",
|
"Erroneous challenge": "Erroneous challenge",
|
||||||
"Pashto": "Pashto",
|
"Erroneous token": "Erroneous token",
|
||||||
"Persian": "Persian",
|
"No such user": "No such user",
|
||||||
"Polish": "Polish",
|
"Token is expired, please try again": "Token is expired, please try again",
|
||||||
"Portuguese": "Portuguese",
|
"English": "English",
|
||||||
"Punjabi": "Punjabi",
|
"English (auto-generated)": "English (auto-generated)",
|
||||||
"Romanian": "Romanian",
|
"Afrikaans": "Afrikaans",
|
||||||
"Russian": "Russian",
|
"Albanian": "Albanian",
|
||||||
"Samoan": "Samoan",
|
"Amharic": "Amharic",
|
||||||
"Scottish Gaelic": "Scottish Gaelic",
|
"Arabic": "Arabic",
|
||||||
"Serbian": "Serbian",
|
"Armenian": "Armenian",
|
||||||
"Shona": "Shona",
|
"Azerbaijani": "Azerbaijani",
|
||||||
"Sindhi": "Sindhi",
|
"Bangla": "Bangla",
|
||||||
"Sinhala": "Sinhala",
|
"Basque": "Basque",
|
||||||
"Slovak": "Slovak",
|
"Belarusian": "Belarusian",
|
||||||
"Slovenian": "Slovenian",
|
"Bosnian": "Bosnian",
|
||||||
"Somali": "Somali",
|
"Bulgarian": "Bulgarian",
|
||||||
"Southern Sotho": "Southern Sotho",
|
"Burmese": "Burmese",
|
||||||
"Spanish": "Spanish",
|
"Catalan": "Catalan",
|
||||||
"Spanish (Latin America)": "Spanish (Latin America)",
|
"Cebuano": "Cebuano",
|
||||||
"Sundanese": "Sundanese",
|
"Chinese (Simplified)": "Chinese (Simplified)",
|
||||||
"Swahili": "Swahili",
|
"Chinese (Traditional)": "Chinese (Traditional)",
|
||||||
"Swedish": "Swedish",
|
"Corsican": "Corsican",
|
||||||
"Tajik": "Tajik",
|
"Croatian": "Croatian",
|
||||||
"Tamil": "Tamil",
|
"Czech": "Czech",
|
||||||
"Telugu": "Telugu",
|
"Danish": "Danish",
|
||||||
"Thai": "Thai",
|
"Dutch": "Dutch",
|
||||||
"Turkish": "Turkish",
|
"Esperanto": "Esperanto",
|
||||||
"Ukrainian": "Ukrainian",
|
"Estonian": "Estonian",
|
||||||
"Urdu": "Urdu",
|
"Filipino": "Filipino",
|
||||||
"Uzbek": "Uzbek",
|
"Finnish": "Finnish",
|
||||||
"Vietnamese": "Vietnamese",
|
"French": "French",
|
||||||
"Welsh": "Welsh",
|
"Galician": "Galician",
|
||||||
"Western Frisian": "Western Frisian",
|
"Georgian": "Georgian",
|
||||||
"Xhosa": "Xhosa",
|
"German": "German",
|
||||||
"Yiddish": "Yiddish",
|
"Greek": "Greek",
|
||||||
"Yoruba": "Yoruba",
|
"Gujarati": "Gujarati",
|
||||||
"Zulu": "Zulu",
|
"Haitian Creole": "Haitian Creole",
|
||||||
"`x` years": "`x` years",
|
"Hausa": "Hausa",
|
||||||
"`x` months": "`x` months",
|
"Hawaiian": "Hawaiian",
|
||||||
"`x` weeks": "`x` weeks",
|
"Hebrew": "Hebrew",
|
||||||
"`x` days": "`x` days",
|
"Hindi": "Hindi",
|
||||||
"`x` hours": "`x` hours",
|
"Hmong": "Hmong",
|
||||||
"`x` minutes": "`x` minutes",
|
"Hungarian": "Hungarian",
|
||||||
"`x` seconds": "`x` seconds",
|
"Icelandic": "Icelandic",
|
||||||
"Fallback comments: ": "Fallback comments: ",
|
"Igbo": "Igbo",
|
||||||
"Popular": "Popular",
|
"Indonesian": "Indonesian",
|
||||||
"Top": "Top",
|
"Irish": "Irish",
|
||||||
"About": "About",
|
"Italian": "Italian",
|
||||||
"Rating: ": "Rating: ",
|
"Japanese": "Japanese",
|
||||||
"Language: ": "Language: ",
|
"Javanese": "Javanese",
|
||||||
"Default": "Default",
|
"Kannada": "Kannada",
|
||||||
"Music": "Music",
|
"Kazakh": "Kazakh",
|
||||||
"Gaming": "Gaming",
|
"Khmer": "Khmer",
|
||||||
"News": "News",
|
"Korean": "Korean",
|
||||||
"Movies": "Movies",
|
"Kurdish": "Kurdish",
|
||||||
"Download": "Download",
|
"Kyrgyz": "Kyrgyz",
|
||||||
"Download as: ": "Download as: ",
|
"Lao": "Lao",
|
||||||
"%A %B %-d, %Y": "%A %B %-d, %Y",
|
"Latin": "Latin",
|
||||||
"(edited)": "(edited)",
|
"Latvian": "Latvian",
|
||||||
"Youtube permalink of the comment": "Youtube permalink of the comment",
|
"Lithuanian": "Lithuanian",
|
||||||
"`x` marked it with a ❤": "`x` marked it with a ❤",
|
"Luxembourgish": "Luxembourgish",
|
||||||
"Audio mode": "Audio mode",
|
"Macedonian": "Macedonian",
|
||||||
"Video mode": "Video mode"
|
"Malagasy": "Malagasy",
|
||||||
}
|
"Malay": "Malay",
|
||||||
|
"Malayalam": "Malayalam",
|
||||||
|
"Maltese": "Maltese",
|
||||||
|
"Maori": "Maori",
|
||||||
|
"Marathi": "Marathi",
|
||||||
|
"Mongolian": "Mongolian",
|
||||||
|
"Nepali": "Nepali",
|
||||||
|
"Norwegian Bokmål": "Norwegian Bokmål",
|
||||||
|
"Nyanja": "Nyanja",
|
||||||
|
"Pashto": "Pashto",
|
||||||
|
"Persian": "Persian",
|
||||||
|
"Polish": "Polish",
|
||||||
|
"Portuguese": "Portuguese",
|
||||||
|
"Punjabi": "Punjabi",
|
||||||
|
"Romanian": "Romanian",
|
||||||
|
"Russian": "Russian",
|
||||||
|
"Samoan": "Samoan",
|
||||||
|
"Scottish Gaelic": "Scottish Gaelic",
|
||||||
|
"Serbian": "Serbian",
|
||||||
|
"Shona": "Shona",
|
||||||
|
"Sindhi": "Sindhi",
|
||||||
|
"Sinhala": "Sinhala",
|
||||||
|
"Slovak": "Slovak",
|
||||||
|
"Slovenian": "Slovenian",
|
||||||
|
"Somali": "Somali",
|
||||||
|
"Southern Sotho": "Southern Sotho",
|
||||||
|
"Spanish": "Spanish",
|
||||||
|
"Spanish (Latin America)": "Spanish (Latin America)",
|
||||||
|
"Sundanese": "Sundanese",
|
||||||
|
"Swahili": "Swahili",
|
||||||
|
"Swedish": "Swedish",
|
||||||
|
"Tajik": "Tajik",
|
||||||
|
"Tamil": "Tamil",
|
||||||
|
"Telugu": "Telugu",
|
||||||
|
"Thai": "Thai",
|
||||||
|
"Turkish": "Turkish",
|
||||||
|
"Ukrainian": "Ukrainian",
|
||||||
|
"Urdu": "Urdu",
|
||||||
|
"Uzbek": "Uzbek",
|
||||||
|
"Vietnamese": "Vietnamese",
|
||||||
|
"Welsh": "Welsh",
|
||||||
|
"Western Frisian": "Western Frisian",
|
||||||
|
"Xhosa": "Xhosa",
|
||||||
|
"Yiddish": "Yiddish",
|
||||||
|
"Yoruba": "Yoruba",
|
||||||
|
"Zulu": "Zulu",
|
||||||
|
"`x` years": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` year",
|
||||||
|
"": "`x` years"
|
||||||
|
},
|
||||||
|
"`x` months": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` month",
|
||||||
|
"": "`x` months"
|
||||||
|
},
|
||||||
|
"`x` weeks": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` week",
|
||||||
|
"": "`x` weeks"
|
||||||
|
},
|
||||||
|
"`x` days": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` day",
|
||||||
|
"": "`x` days"
|
||||||
|
},
|
||||||
|
"`x` hours": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` hour",
|
||||||
|
"": "`x` hours"
|
||||||
|
},
|
||||||
|
"`x` minutes": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` minute",
|
||||||
|
"": "`x` minutes"
|
||||||
|
},
|
||||||
|
"`x` seconds": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` second",
|
||||||
|
"": "`x` seconds"
|
||||||
|
},
|
||||||
|
"Fallback comments: ": "Fallback comments: ",
|
||||||
|
"Popular": "Popular",
|
||||||
|
"Top": "Top",
|
||||||
|
"About": "About",
|
||||||
|
"Rating: ": "Rating: ",
|
||||||
|
"Language: ": "Language: ",
|
||||||
|
"View as playlist": "View as playlist",
|
||||||
|
"Default": "Default",
|
||||||
|
"Music": "Music",
|
||||||
|
"Gaming": "Gaming",
|
||||||
|
"News": "News",
|
||||||
|
"Movies": "Movies",
|
||||||
|
"Download": "Download",
|
||||||
|
"Download as: ": "Download as: ",
|
||||||
|
"%A %B %-d, %Y": "%A %B %-d, %Y",
|
||||||
|
"(edited)": "(edited)",
|
||||||
|
"YouTube comment permalink": "YouTube comment permalink",
|
||||||
|
"permalink": "permalink",
|
||||||
|
"`x` marked it with a ❤": "`x` marked it with a ❤",
|
||||||
|
"Audio mode": "Audio mode",
|
||||||
|
"Video mode": "Video mode",
|
||||||
|
"Videos": "Videos",
|
||||||
|
"Playlists": "Playlists",
|
||||||
|
"Community": "Community",
|
||||||
|
"Current version: ": "Current version: "
|
||||||
|
}
|
||||||
336
locales/eo.json
Normal file
336
locales/eo.json
Normal file
@@ -0,0 +1,336 @@
|
|||||||
|
{
|
||||||
|
"`x` subscribers": "`x` abonantoj",
|
||||||
|
"`x` videos": "`x` filmetoj",
|
||||||
|
"`x` playlists": "`x` ludlistoj",
|
||||||
|
"LIVE": "NUNA",
|
||||||
|
"Shared `x` ago": "Konigita antaŭ `x`",
|
||||||
|
"Unsubscribe": "Malaboni",
|
||||||
|
"Subscribe": "Aboni",
|
||||||
|
"View channel on YouTube": "Vidi kanalon en JuTubo",
|
||||||
|
"View playlist on YouTube": "Vidi ludliston en JuTubo",
|
||||||
|
"newest": "pli novaj",
|
||||||
|
"oldest": "pli malnovaj",
|
||||||
|
"popular": "popularaj",
|
||||||
|
"last": "lasta",
|
||||||
|
"Next page": "Sekva paĝo",
|
||||||
|
"Previous page": "Antaŭa paĝo",
|
||||||
|
"Clear watch history?": "Ĉu forigi vidohistorion?",
|
||||||
|
"New password": "Nova pasvorto",
|
||||||
|
"New passwords must match": "Novaj pasvortoj devas kongrui",
|
||||||
|
"Cannot change password for Google accounts": "Ne eblas ŝanĝi pasvorton por kontoj de Google",
|
||||||
|
"Authorize token?": "Ĉu rajtigi ĵetonon?",
|
||||||
|
"Authorize token for `x`?": "Ĉu rajtigi ĵetonon por `x`?",
|
||||||
|
"Yes": "Jes",
|
||||||
|
"No": "Ne",
|
||||||
|
"Import and Export Data": "Importi kaj Eksporti Datumojn",
|
||||||
|
"Import": "Importi",
|
||||||
|
"Import Invidious data": "Importi datumojn de Invidious",
|
||||||
|
"Import YouTube subscriptions": "Importi abonojn de JuTubo",
|
||||||
|
"Import FreeTube subscriptions (.db)": "Importi abonojn de FreeTube (.db)",
|
||||||
|
"Import NewPipe subscriptions (.json)": "Importi abonojn de NewPipe (.json)",
|
||||||
|
"Import NewPipe data (.zip)": "Importi datumojn de NewPipe (.zip)",
|
||||||
|
"Export": "Eksporti",
|
||||||
|
"Export subscriptions as OPML": "Eksporti abonojn kiel OPML",
|
||||||
|
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Eksporti abonojn kiel OPML (por NewPipe kaj FreeTube)",
|
||||||
|
"Export data as JSON": "Eksporti datumojn kiel JSON",
|
||||||
|
"Delete account?": "Ĉu forigi konton?",
|
||||||
|
"History": "Historio",
|
||||||
|
"An alternative front-end to YouTube": "Alternativa fasado al JuTubo",
|
||||||
|
"JavaScript license information": "Ĝavoskripta licenca informo",
|
||||||
|
"source": "fonto",
|
||||||
|
"Log in": "Ensaluti",
|
||||||
|
"Log in/register": "Ensaluti/Registriĝi",
|
||||||
|
"Log in with Google": "Ensaluti al Google",
|
||||||
|
"User ID": "Uzula identigilo",
|
||||||
|
"Password": "Pasvorto",
|
||||||
|
"Time (h:mm:ss):": "Horo (h:mm:ss):",
|
||||||
|
"Text CAPTCHA": "Teksta CAPTCHA",
|
||||||
|
"Image CAPTCHA": "Bilda CAPTCHA",
|
||||||
|
"Sign In": "Ensaluti",
|
||||||
|
"Register": "Registriĝi",
|
||||||
|
"E-mail": "Retpoŝto",
|
||||||
|
"Google verification code": "Kontrolkodo de Google",
|
||||||
|
"Preferences": "Agordoj",
|
||||||
|
"Player preferences": "Spektilaj agordoj",
|
||||||
|
"Always loop: ": "Ĉiam ripeti: ",
|
||||||
|
"Autoplay: ": "Aŭtomate ludi: ",
|
||||||
|
"Play next by default: ": "Ludi sekvan defaŭlte: ",
|
||||||
|
"Autoplay next video: ": "Aŭtomate ludi sekvan filmeton: ",
|
||||||
|
"Listen by default: ": "Aŭskulti defaŭlte: ",
|
||||||
|
"Proxy videos: ": "Ĉu uzi prokuran servilon por filmetojn? ",
|
||||||
|
"Default speed: ": "Defaŭlta rapido: ",
|
||||||
|
"Preferred video quality: ": "Preferita filmetkvalito: ",
|
||||||
|
"Player volume: ": "Ludila sonforteco: ",
|
||||||
|
"Default comments: ": "Defaŭltaj komentoj: ",
|
||||||
|
"youtube": "JuTubo",
|
||||||
|
"reddit": "Reddit",
|
||||||
|
"Default captions: ": "Defaŭltaj subtekstoj: ",
|
||||||
|
"Fallback captions: ": "Retrodefaŭltaj subtekstoj: ",
|
||||||
|
"Show related videos: ": "Ĉu montri rilatajn filmetojn? ",
|
||||||
|
"Show annotations by default: ": "Ĉu montri prinotojn defaŭlte? ",
|
||||||
|
"Visual preferences": "Vidaj preferoj",
|
||||||
|
"Player style: ": "Ludila stilo: ",
|
||||||
|
"Dark mode: ": "Malhela reĝimo: ",
|
||||||
|
"Theme: ": "Etoso: ",
|
||||||
|
"dark": "malhela",
|
||||||
|
"light": "hela",
|
||||||
|
"Thin mode: ": "Maldika reĝimo: ",
|
||||||
|
"Subscription preferences": "Abonaj agordoj",
|
||||||
|
"Show annotations by default for subscribed channels: ": "Ĉu montri prinotojn defaŭlte por abonitaj kanaloj? ",
|
||||||
|
"Redirect homepage to feed: ": "Alidirekti hejmpâgon al fluo: ",
|
||||||
|
"Number of videos shown in feed: ": "Nombro da filmetoj montritaj en fluo: ",
|
||||||
|
"Sort videos by: ": "Ordi filmetojn per: ",
|
||||||
|
"published": "publikigo",
|
||||||
|
"published - reverse": "publitigo - renverse",
|
||||||
|
"alphabetically": "alfabete",
|
||||||
|
"alphabetically - reverse": "alfabete - renverse",
|
||||||
|
"channel name": "kanala nombro",
|
||||||
|
"channel name - reverse": "kanala nombro - renverse",
|
||||||
|
"Only show latest video from channel: ": "Nur montri pli novan filmeton el kanalo: ",
|
||||||
|
"Only show latest unwatched video from channel: ": "Nur montri pli novan malviditan filmeton el kanalo: ",
|
||||||
|
"Only show unwatched: ": "Nur montri malviditajn: ",
|
||||||
|
"Only show notifications (if there are any): ": "Nur montri sciigojn (se estas): ",
|
||||||
|
"Enable web notifications": "Ebligi retejajn sciigojn",
|
||||||
|
"`x` uploaded a video": "`x` alŝutis filmeton",
|
||||||
|
"`x` is live": "`x` estas nuna",
|
||||||
|
"Data preferences": "Datumagordoj",
|
||||||
|
"Clear watch history": "Forigi vidohistorion",
|
||||||
|
"Import/export data": "Importi/Eksporti datumojn",
|
||||||
|
"Change password": "Ŝanĝi pasvorton",
|
||||||
|
"Manage subscriptions": "Administri abonojn",
|
||||||
|
"Manage tokens": "Administri ĵetonojn",
|
||||||
|
"Watch history": "Vidohistorio",
|
||||||
|
"Delete account": "Forigi konton",
|
||||||
|
"Administrator preferences": "Agordoj de administranto",
|
||||||
|
"Default homepage: ": "Defaŭlta hejmpaĝo: ",
|
||||||
|
"Feed menu: ": "Flua menuo: ",
|
||||||
|
"Top enabled: ": "Ĉu pli bonaj ŝaltitaj? ",
|
||||||
|
"CAPTCHA enabled: ": "Ĉu CAPTCHA ŝaltita? ",
|
||||||
|
"Login enabled: ": "Ĉu ensaluto aktivita? ",
|
||||||
|
"Registration enabled: ": "Ĉu registriĝo aktivita? ",
|
||||||
|
"Report statistics: ": "Ĉu raporti statistikojn? ",
|
||||||
|
"Save preferences": "Konservi agordojn",
|
||||||
|
"Subscription manager": "Administrilo de abonoj",
|
||||||
|
"Token manager": "Ĵetona administrilo",
|
||||||
|
"Token": "Ĵetono",
|
||||||
|
"`x` subscriptions": "`x` abonoj",
|
||||||
|
"`x` tokens": "`x` ĵetonoj",
|
||||||
|
"Import/export": "Importi/Eksporti",
|
||||||
|
"unsubscribe": "malaboni",
|
||||||
|
"revoke": "senvalidigi",
|
||||||
|
"Subscriptions": "Abonoj",
|
||||||
|
"`x` unseen notifications": "`x` neviditaj sciigoj",
|
||||||
|
"search": "serĉi",
|
||||||
|
"Log out": "Elsaluti",
|
||||||
|
"Released under the AGPLv3 by Omar Roth.": "Eldonita sub la AGPLv3 de Omar Roth.",
|
||||||
|
"Source available here.": "Fonto havebla ĉi tie.",
|
||||||
|
"View JavaScript license information.": "Vidi Ĝavoskriptan licencan informon.",
|
||||||
|
"View privacy policy.": "Vidi regularon pri privateco.",
|
||||||
|
"Trending": "Tendencoj",
|
||||||
|
"Public": "Publika",
|
||||||
|
"Unlisted": "Ne listigita",
|
||||||
|
"Private": "Privata",
|
||||||
|
"View all playlists": "Vidi ĉiujn ludlistojn",
|
||||||
|
"Updated `x` ago": "Ĝisdatigita antaŭ `x`",
|
||||||
|
"Delete playlist `x`?": "Ĉu forigi ludliston `x`?",
|
||||||
|
"Delete playlist": "Forigi ludliston",
|
||||||
|
"Create playlist": "Krei ludliston",
|
||||||
|
"Title": "Titolo",
|
||||||
|
"Playlist privacy": "Privateco de ludlisto",
|
||||||
|
"Editing playlist `x`": "Redaktante ludlisto `x`",
|
||||||
|
"Watch on YouTube": "Vidi filmeton en JuTubo",
|
||||||
|
"Hide annotations": "Kaŝi prinotojn",
|
||||||
|
"Show annotations": "Montri prinotojn",
|
||||||
|
"Genre: ": "Ĝenro: ",
|
||||||
|
"License: ": "Licenco: ",
|
||||||
|
"Family friendly? ": "Ĉu familie amika? ",
|
||||||
|
"Wilson score: ": "Poentaro de Wilson: ",
|
||||||
|
"Engagement: ": "Intereso: ",
|
||||||
|
"Whitelisted regions: ": "Regionoj listigitaj en blanka listo: ",
|
||||||
|
"Blacklisted regions: ": "Regionoj listigitaj en nigra listo: ",
|
||||||
|
"Shared `x`": "Konigita `x`",
|
||||||
|
"`x` views": "`x` spektaĵoj",
|
||||||
|
"Premieres in `x`": "Premieras en `x`",
|
||||||
|
"Premieres `x`": "Premieras `x`",
|
||||||
|
"Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.": "Saluton! Ŝajnas, ke vi havas Ĝavoskripton malebligitan. Klaku ĉi tie por vidi komentojn, memoru, ke la ŝargado povus daŭri iom pli.",
|
||||||
|
"View YouTube comments": "Vidi komentojn de JuTubo",
|
||||||
|
"View more comments on Reddit": "Vidi pli komentoj en Reddit",
|
||||||
|
"View `x` comments": "Vidi `x` komentojn",
|
||||||
|
"View Reddit comments": "Vidi komentojn de Reddit",
|
||||||
|
"Hide replies": "Kaŝi respondojn",
|
||||||
|
"Show replies": "Montri respondojn",
|
||||||
|
"Incorrect password": "Malbona pasvorto",
|
||||||
|
"Quota exceeded, try again in a few hours": "Kvoto transpasita, provu denove post iuj horoj",
|
||||||
|
"Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.": "Ne povas ensaluti, certigu, ke dufaktora aŭtentigo (Authenticator aŭ SMS) estas ebligita.",
|
||||||
|
"Invalid TFA code": "Nevalida TFA-kodo",
|
||||||
|
"Login failed. This may be because two-factor authentication is not turned on for your account.": "Ensalutado fiaskis. Eble ĉar la dufaktora aŭtentigo estas malebligita en via konto.",
|
||||||
|
"Wrong answer": "Nevalida respondo",
|
||||||
|
"Erroneous CAPTCHA": "Nevalida CAPTCHA",
|
||||||
|
"CAPTCHA is a required field": "CAPTCHA estas deviga kampo",
|
||||||
|
"User ID is a required field": "Uzula identigilo estas deviga kampo",
|
||||||
|
"Password is a required field": "Pasvorto estas deviga kampo",
|
||||||
|
"Wrong username or password": "Nevalida uzantnomo aŭ pasvorto",
|
||||||
|
"Please sign in using 'Log in with Google'": "Bonvolu ensaluti per 'Ensaluti per Google'",
|
||||||
|
"Password cannot be empty": "Pasvorto ne povas esti malplena",
|
||||||
|
"Password cannot be longer than 55 characters": "Pasvorto ne povas esti pli longa ol 55 signoj",
|
||||||
|
"Please log in": "Bonvolu ensaluti",
|
||||||
|
"Invidious Private Feed for `x`": "Privata Fluo de Invidious por `x`",
|
||||||
|
"channel:`x`": "kanalo:`x`",
|
||||||
|
"Deleted or invalid channel": "Forigita aŭ nevalida kanalo",
|
||||||
|
"This channel does not exist.": "Ĉi tiu kanalo ne ekzistas.",
|
||||||
|
"Could not get channel info.": "Ne povis havigi kanalan informon.",
|
||||||
|
"Could not fetch comments": "Ne povis venigi komentojn",
|
||||||
|
"View `x` replies": "Vidi `x` respondojn",
|
||||||
|
"`x` ago": "antaŭ `x`",
|
||||||
|
"Load more": "Ŝarĝi pli",
|
||||||
|
"`x` points": "`x` poentoj",
|
||||||
|
"Could not create mix.": "Ne povis krei mikson.",
|
||||||
|
"Empty playlist": "Ludlisto estas malplena",
|
||||||
|
"Not a playlist.": "Nevalida ludlisto.",
|
||||||
|
"Playlist does not exist.": "Ludlisto ne ekzistas.",
|
||||||
|
"Could not pull trending pages.": "Ne povis venigi tendencajn paĝojn.",
|
||||||
|
"Hidden field \"challenge\" is a required field": "Kaŝita kampo \"challenge\" estas deviga kampo",
|
||||||
|
"Hidden field \"token\" is a required field": "Kaŝita kampo \"token\" estas deviga kampo",
|
||||||
|
"Erroneous challenge": "Nevalida defio",
|
||||||
|
"Erroneous token": "Nevalida ĵetono",
|
||||||
|
"No such user": "Nevalida uzanto",
|
||||||
|
"Token is expired, please try again": "Ĵetono senvalidiĝis, bonvolu provi denove",
|
||||||
|
"English": "Angla",
|
||||||
|
"English (auto-generated)": "Angla (aŭtomate generita)",
|
||||||
|
"Afrikaans": "Afrikansa",
|
||||||
|
"Albanian": "Albana",
|
||||||
|
"Amharic": "Amhara",
|
||||||
|
"Arabic": "Araba",
|
||||||
|
"Armenian": "Armena",
|
||||||
|
"Azerbaijani": "Azerbajĝana",
|
||||||
|
"Bangla": "Bengala",
|
||||||
|
"Basque": "Eŭska",
|
||||||
|
"Belarusian": "Belorusa",
|
||||||
|
"Bosnian": "Bosna",
|
||||||
|
"Bulgarian": "Bulgara",
|
||||||
|
"Burmese": "Birma",
|
||||||
|
"Catalan": "Kataluna",
|
||||||
|
"Cebuano": "Cebua",
|
||||||
|
"Chinese (Simplified)": "Ĉina (simpligita)",
|
||||||
|
"Chinese (Traditional)": "Ĉina (tradicia)",
|
||||||
|
"Corsican": "Korsika",
|
||||||
|
"Croatian": "Kroata",
|
||||||
|
"Czech": "Ĉeĥa",
|
||||||
|
"Danish": "Dana",
|
||||||
|
"Dutch": "Nederlanda",
|
||||||
|
"Esperanto": "Esperanto",
|
||||||
|
"Estonian": "Estona",
|
||||||
|
"Filipino": "Filipina",
|
||||||
|
"Finnish": "Finna",
|
||||||
|
"French": "Franca",
|
||||||
|
"Galician": "Galega",
|
||||||
|
"Georgian": "Kartvela",
|
||||||
|
"German": "Germana",
|
||||||
|
"Greek": "Greka",
|
||||||
|
"Gujarati": "Guĝarata",
|
||||||
|
"Haitian Creole": "Haitia kreola",
|
||||||
|
"Hausa": "Haŭsa",
|
||||||
|
"Hawaiian": "Havaja",
|
||||||
|
"Hebrew": "Hebrea",
|
||||||
|
"Hindi": "Hindia",
|
||||||
|
"Hmong": "Miaa",
|
||||||
|
"Hungarian": "Hungara",
|
||||||
|
"Icelandic": "Islanda",
|
||||||
|
"Igbo": "Igba",
|
||||||
|
"Indonesian": "Indonezia",
|
||||||
|
"Irish": "Irlanda",
|
||||||
|
"Italian": "Itala",
|
||||||
|
"Japanese": "Japana",
|
||||||
|
"Javanese": "Java",
|
||||||
|
"Kannada": "Kanara",
|
||||||
|
"Kazakh": "Kazaĥa",
|
||||||
|
"Khmer": "Kmera",
|
||||||
|
"Korean": "Korea",
|
||||||
|
"Kurdish": "Kurda",
|
||||||
|
"Kyrgyz": "Kirgiza",
|
||||||
|
"Lao": "Laosa",
|
||||||
|
"Latin": "Latina",
|
||||||
|
"Latvian": "Latva",
|
||||||
|
"Lithuanian": "Litova",
|
||||||
|
"Luxembourgish": "Luksemburga",
|
||||||
|
"Macedonian": "Makedona",
|
||||||
|
"Malagasy": "Malagasa",
|
||||||
|
"Malay": "Malaja",
|
||||||
|
"Malayalam": "Malajala",
|
||||||
|
"Maltese": "Malta",
|
||||||
|
"Maori": "Maoria",
|
||||||
|
"Marathi": "Marata",
|
||||||
|
"Mongolian": "Mongola",
|
||||||
|
"Nepali": "Nepala",
|
||||||
|
"Norwegian Bokmål": "Norvega",
|
||||||
|
"Nyanja": "Njanĝa",
|
||||||
|
"Pashto": "Paŝtuna",
|
||||||
|
"Persian": "Persa",
|
||||||
|
"Polish": "Pola",
|
||||||
|
"Portuguese": "Portugala",
|
||||||
|
"Punjabi": "Panĝaba",
|
||||||
|
"Romanian": "Rumana",
|
||||||
|
"Russian": "Rusa",
|
||||||
|
"Samoan": "Samoa",
|
||||||
|
"Scottish Gaelic": "Skotgaela",
|
||||||
|
"Serbian": "Serba",
|
||||||
|
"Shona": "Ŝona",
|
||||||
|
"Sindhi": "Sinda",
|
||||||
|
"Sinhala": "Sinhala",
|
||||||
|
"Slovak": "Slovaka",
|
||||||
|
"Slovenian": "Slovena",
|
||||||
|
"Somali": "Somala",
|
||||||
|
"Southern Sotho": "Sota",
|
||||||
|
"Spanish": "Hispana",
|
||||||
|
"Spanish (Latin America)": "Hispana (Latinameriko)",
|
||||||
|
"Sundanese": "Sunda",
|
||||||
|
"Swahili": "Svahila",
|
||||||
|
"Swedish": "Sveda",
|
||||||
|
"Tajik": "Taĝika",
|
||||||
|
"Tamil": "Tamila",
|
||||||
|
"Telugu": "Telugua",
|
||||||
|
"Thai": "Taja",
|
||||||
|
"Turkish": "Turka",
|
||||||
|
"Ukrainian": "Ukraina",
|
||||||
|
"Urdu": "Urduo",
|
||||||
|
"Uzbek": "Uzbeka",
|
||||||
|
"Vietnamese": "Vjetnama",
|
||||||
|
"Welsh": "Kimra",
|
||||||
|
"Western Frisian": "Okcidentfrisa",
|
||||||
|
"Xhosa": "Kosa",
|
||||||
|
"Yiddish": "Jida",
|
||||||
|
"Yoruba": "Joruba",
|
||||||
|
"Zulu": "Zulua",
|
||||||
|
"`x` years": "`x` jaroj",
|
||||||
|
"`x` months": "`x` monatoj",
|
||||||
|
"`x` weeks": "`x` semajnoj",
|
||||||
|
"`x` days": "`x` tagoj",
|
||||||
|
"`x` hours": "`x` horoj",
|
||||||
|
"`x` minutes": "`x` minutoj",
|
||||||
|
"`x` seconds": "`x` sekundoj",
|
||||||
|
"Fallback comments: ": "Retrodefaŭltaj komentoj: ",
|
||||||
|
"Popular": "Popularaj",
|
||||||
|
"Top": "Supraj",
|
||||||
|
"About": "Pri",
|
||||||
|
"Rating: ": "Takso: ",
|
||||||
|
"Language: ": "Lingvo: ",
|
||||||
|
"View as playlist": "Vidi kiel ludlisto",
|
||||||
|
"Default": "Defaŭlte",
|
||||||
|
"Music": "Musiko",
|
||||||
|
"Gaming": "Komputiloludoj",
|
||||||
|
"News": "Novaĵoj",
|
||||||
|
"Movies": "Filmoj",
|
||||||
|
"Download": "Elŝuti",
|
||||||
|
"Download as: ": "Elŝuti kiel: ",
|
||||||
|
"%A %B %-d, %Y": "%A %-d de %B %Y",
|
||||||
|
"(edited)": "(redaktita)",
|
||||||
|
"YouTube comment permalink": "Fiksligilo de la komento en JuTubo",
|
||||||
|
"permalink": "konstanta ligilo",
|
||||||
|
"`x` marked it with a ❤": "`x` markis ĝin per ❤",
|
||||||
|
"Audio mode": "Aŭda reĝimo",
|
||||||
|
"Video mode": "Videa reĝimo",
|
||||||
|
"Videos": "Filmetoj",
|
||||||
|
"Playlists": "Ludlistoj",
|
||||||
|
"Community": "Komunumo",
|
||||||
|
"Current version: ": "Nuna versio: "
|
||||||
|
}
|
||||||
336
locales/es.json
Normal file
336
locales/es.json
Normal file
@@ -0,0 +1,336 @@
|
|||||||
|
{
|
||||||
|
"`x` subscribers": "`x` suscriptores",
|
||||||
|
"`x` videos": "`x` vídeos",
|
||||||
|
"`x` playlists": "`x` listas de reproducción",
|
||||||
|
"LIVE": "DIRECTO",
|
||||||
|
"Shared `x` ago": "Compartido hace `x`",
|
||||||
|
"Unsubscribe": "Desuscribirse",
|
||||||
|
"Subscribe": "Suscribirse",
|
||||||
|
"View channel on YouTube": "Ver el canal en YouTube",
|
||||||
|
"View playlist on YouTube": "Ver lista de reproducción en YouTube",
|
||||||
|
"newest": "más nuevos",
|
||||||
|
"oldest": "más viejos",
|
||||||
|
"popular": "populares",
|
||||||
|
"last": "último",
|
||||||
|
"Next page": "Página siguiente",
|
||||||
|
"Previous page": "Página anterior",
|
||||||
|
"Clear watch history?": "¿Quiere borrar el historial de reproducción?",
|
||||||
|
"New password": "Nueva contraseña",
|
||||||
|
"New passwords must match": "Las nuevas contraseñas deben coincidir",
|
||||||
|
"Cannot change password for Google accounts": "No se puede cambiar la contraseña de la cuenta de Google",
|
||||||
|
"Authorize token?": "¿Autorizar el token?",
|
||||||
|
"Authorize token for `x`?": "¿Autorizar el token para `x`?",
|
||||||
|
"Yes": "Sí",
|
||||||
|
"No": "No",
|
||||||
|
"Import and Export Data": "Importación y exportación de datos",
|
||||||
|
"Import": "Importar",
|
||||||
|
"Import Invidious data": "Importar datos de Invidious",
|
||||||
|
"Import YouTube subscriptions": "Importar suscripciones de YouTube",
|
||||||
|
"Import FreeTube subscriptions (.db)": "Importar suscripciones de FreeTube (.db)",
|
||||||
|
"Import NewPipe subscriptions (.json)": "Importar suscripciones de NewPipe (.json)",
|
||||||
|
"Import NewPipe data (.zip)": "Importar datos de NewPipe (.zip)",
|
||||||
|
"Export": "Exportar",
|
||||||
|
"Export subscriptions as OPML": "Exportar suscripciones como OPML",
|
||||||
|
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Exportar suscripciones como OPML (para NewPipe y FreeTube)",
|
||||||
|
"Export data as JSON": "Exportar datos como JSON",
|
||||||
|
"Delete account?": "¿Quiere borrar la cuenta?",
|
||||||
|
"History": "Historial",
|
||||||
|
"An alternative front-end to YouTube": "Una interfaz alternativa para YouTube",
|
||||||
|
"JavaScript license information": "Información de licencia de JavaScript",
|
||||||
|
"source": "código fuente",
|
||||||
|
"Log in": "Iniciar sesión",
|
||||||
|
"Log in/register": "Iniciar sesión/Registrarse",
|
||||||
|
"Log in with Google": "Iniciar sesión en Google",
|
||||||
|
"User ID": "Nombre",
|
||||||
|
"Password": "Contraseña",
|
||||||
|
"Time (h:mm:ss):": "Hora (h:mm:ss):",
|
||||||
|
"Text CAPTCHA": "CAPTCHA en texto",
|
||||||
|
"Image CAPTCHA": "CAPTCHA en imagen",
|
||||||
|
"Sign In": "Iniciar sesión",
|
||||||
|
"Register": "Registrarse",
|
||||||
|
"E-mail": "Correo",
|
||||||
|
"Google verification code": "Código de verificación de Google",
|
||||||
|
"Preferences": "Preferencias",
|
||||||
|
"Player preferences": "Preferencias del reproductor",
|
||||||
|
"Always loop: ": "Repetir siempre: ",
|
||||||
|
"Autoplay: ": "Reproducción automática: ",
|
||||||
|
"Play next by default: ": "Reproducir siguiente por defecto: ",
|
||||||
|
"Autoplay next video: ": "Reproducir automáticamente el vídeo siguiente: ",
|
||||||
|
"Listen by default: ": "Activar el sonido por defecto: ",
|
||||||
|
"Proxy videos: ": "¿Usar un proxy para los vídeos? ",
|
||||||
|
"Default speed: ": "Velocidad por defecto: ",
|
||||||
|
"Preferred video quality: ": "Calidad de vídeo preferida: ",
|
||||||
|
"Player volume: ": "Volumen del reproductor: ",
|
||||||
|
"Default comments: ": "Comentarios por defecto: ",
|
||||||
|
"youtube": "YouTube",
|
||||||
|
"reddit": "Reddit",
|
||||||
|
"Default captions: ": "Subtítulos por defecto: ",
|
||||||
|
"Fallback captions: ": "Subtítulos alternativos: ",
|
||||||
|
"Show related videos: ": "¿Mostrar vídeos relacionados? ",
|
||||||
|
"Show annotations by default: ": "¿Mostrar anotaciones por defecto? ",
|
||||||
|
"Visual preferences": "Preferencias visuales",
|
||||||
|
"Player style: ": "Estilo de reproductor: ",
|
||||||
|
"Dark mode: ": "Modo oscuro: ",
|
||||||
|
"Theme: ": "Tema: ",
|
||||||
|
"dark": "oscuro",
|
||||||
|
"light": "claro",
|
||||||
|
"Thin mode: ": "Modo compacto: ",
|
||||||
|
"Subscription preferences": "Preferencias de la suscripción",
|
||||||
|
"Show annotations by default for subscribed channels: ": "¿Mostrar anotaciones por defecto para los canales suscritos? ",
|
||||||
|
"Redirect homepage to feed: ": "Redirigir la página de inicio a la fuente: ",
|
||||||
|
"Number of videos shown in feed: ": "Número de vídeos mostrados en la fuente: ",
|
||||||
|
"Sort videos by: ": "Ordenar los vídeos por: ",
|
||||||
|
"published": "fecha de publicación",
|
||||||
|
"published - reverse": "fecha de publicación: orden inverso",
|
||||||
|
"alphabetically": "alfabéticamente",
|
||||||
|
"alphabetically - reverse": "alfabéticamente: orden inverso",
|
||||||
|
"channel name": "nombre del canal",
|
||||||
|
"channel name - reverse": "nombre del canal: orden inverso",
|
||||||
|
"Only show latest video from channel: ": "Mostrar solo el último vídeo del canal: ",
|
||||||
|
"Only show latest unwatched video from channel: ": "Mostrar solo el último vídeo sin ver del canal: ",
|
||||||
|
"Only show unwatched: ": "Mostrar solo los no vistos: ",
|
||||||
|
"Only show notifications (if there are any): ": "Mostrar solo notificaciones (si hay alguna): ",
|
||||||
|
"Enable web notifications": "Habilitar notificaciones web",
|
||||||
|
"`x` uploaded a video": "`x` subió un video",
|
||||||
|
"`x` is live": "`x` esta en vivo",
|
||||||
|
"Data preferences": "Preferencias de los datos",
|
||||||
|
"Clear watch history": "Borrar el historial de reproducción",
|
||||||
|
"Import/export data": "Importar/Exportar datos",
|
||||||
|
"Change password": "Cambiar contraseña",
|
||||||
|
"Manage subscriptions": "Gestionar las suscripciones",
|
||||||
|
"Manage tokens": "Gestionar tokens",
|
||||||
|
"Watch history": "Historial de reproducción",
|
||||||
|
"Delete account": "Borrar cuenta",
|
||||||
|
"Administrator preferences": "Preferencias de administrador",
|
||||||
|
"Default homepage: ": "Página de inicio por defecto: ",
|
||||||
|
"Feed menu: ": "Menú de fuentes: ",
|
||||||
|
"Top enabled: ": "¿Habilitar los destacados? ",
|
||||||
|
"CAPTCHA enabled: ": "¿Habilitar los CAPTCHA? ",
|
||||||
|
"Login enabled: ": "¿Habilitar el inicio de sesión? ",
|
||||||
|
"Registration enabled: ": "¿Habilitar el registro? ",
|
||||||
|
"Report statistics: ": "¿Enviar estadísticas? ",
|
||||||
|
"Save preferences": "Guardar las preferencias",
|
||||||
|
"Subscription manager": "Gestor de suscripciones",
|
||||||
|
"Token manager": "Gestor de tokens",
|
||||||
|
"Token": "Token",
|
||||||
|
"`x` subscriptions": "`x` suscripciones",
|
||||||
|
"`x` tokens": "`x` tokens",
|
||||||
|
"Import/export": "Importar/Exportar",
|
||||||
|
"unsubscribe": "Desuscribirse",
|
||||||
|
"revoke": "revocar",
|
||||||
|
"Subscriptions": "Suscripciones",
|
||||||
|
"`x` unseen notifications": "`x` notificaciones sin ver",
|
||||||
|
"search": "buscar",
|
||||||
|
"Log out": "Cerrar la sesión",
|
||||||
|
"Released under the AGPLv3 by Omar Roth.": "Publicado bajo licencia AGPLv3 por Omar Roth.",
|
||||||
|
"Source available here.": "Código fuente disponible aquí.",
|
||||||
|
"View JavaScript license information.": "Ver información de licencia de JavaScript.",
|
||||||
|
"View privacy policy.": "Ver la política de privacidad.",
|
||||||
|
"Trending": "Tendencias",
|
||||||
|
"Public": "Público",
|
||||||
|
"Unlisted": "No listado",
|
||||||
|
"Private": "Privado",
|
||||||
|
"View all playlists": "Ver todas las listas de reproducción",
|
||||||
|
"Updated `x` ago": "Actualizado hace `x`",
|
||||||
|
"Delete playlist `x`?": "¿Eliminar la lista de reproducción `x`?",
|
||||||
|
"Delete playlist": "Eliminar lista de reproducción",
|
||||||
|
"Create playlist": "Crear lista de reproducción",
|
||||||
|
"Title": "Título",
|
||||||
|
"Playlist privacy": "Privacidad de la lista de reproducción",
|
||||||
|
"Editing playlist `x`": "Editando la lista de reproducción 'x'",
|
||||||
|
"Watch on YouTube": "Ver el vídeo en Youtube",
|
||||||
|
"Hide annotations": "Ocultar anotaciones",
|
||||||
|
"Show annotations": "Mostrar anotaciones",
|
||||||
|
"Genre: ": "Género: ",
|
||||||
|
"License: ": "Licencia: ",
|
||||||
|
"Family friendly? ": "¿Filtrar contenidos? ",
|
||||||
|
"Wilson score: ": "Puntuación Wilson: ",
|
||||||
|
"Engagement: ": "Compromiso: ",
|
||||||
|
"Whitelisted regions: ": "Regiones permitidas: ",
|
||||||
|
"Blacklisted regions: ": "Regiones bloqueadas: ",
|
||||||
|
"Shared `x`": "Compartido `x`",
|
||||||
|
"`x` views": "`x` visualizaciones",
|
||||||
|
"Premieres in `x`": "Se estrena en `x`",
|
||||||
|
"Premieres `x`": "Estrenos `x`",
|
||||||
|
"Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.": "¡Hola! Parece que tiene JavaScript desactivado. Haga clic aquí para ver los comentarios, pero tenga en cuenta que pueden tardar un poco más en cargarse.",
|
||||||
|
"View YouTube comments": "Ver los comentarios de YouTube",
|
||||||
|
"View more comments on Reddit": "Ver más comentarios en Reddit",
|
||||||
|
"View `x` comments": "Ver `x` comentarios",
|
||||||
|
"View Reddit comments": "Ver los comentarios de Reddit",
|
||||||
|
"Hide replies": "Ocultar las respuestas",
|
||||||
|
"Show replies": "Mostrar las respuestas",
|
||||||
|
"Incorrect password": "Contraseña incorrecta",
|
||||||
|
"Quota exceeded, try again in a few hours": "Cuota excedida, pruebe otra vez en unas horas",
|
||||||
|
"Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.": "No se puede iniciar sesión, asegúrese de que la autentificación de dos factores (autentificador o SMS) esté habilitada.",
|
||||||
|
"Invalid TFA code": "Código TFA no válido",
|
||||||
|
"Login failed. This may be because two-factor authentication is not turned on for your account.": "Error de inicio de sesion. Puede deberse a que la autentificación de dos factores no está habilitada en su cuenta.",
|
||||||
|
"Wrong answer": "Respuesta no válida",
|
||||||
|
"Erroneous CAPTCHA": "CAPTCHA no válido",
|
||||||
|
"CAPTCHA is a required field": "El CAPTCHA es un campo obligatorio",
|
||||||
|
"User ID is a required field": "El nombre es un campo obligatorio",
|
||||||
|
"Password is a required field": "La contraseña es un campo obligatorio",
|
||||||
|
"Wrong username or password": "Nombre o contraseña incorrecto",
|
||||||
|
"Please sign in using 'Log in with Google'": "Inicie sesión con «Iniciar sesión con Google»",
|
||||||
|
"Password cannot be empty": "La contraseña no puede estar en blanco",
|
||||||
|
"Password cannot be longer than 55 characters": "La contraseña no puede tener más de 55 caracteres",
|
||||||
|
"Please log in": "Inicie sesión, por favor",
|
||||||
|
"Invidious Private Feed for `x`": "Fuente privada de Invidious para `x`",
|
||||||
|
"channel:`x`": "canal: `x`",
|
||||||
|
"Deleted or invalid channel": "El canal no es válido o ha sido borrado",
|
||||||
|
"This channel does not exist.": "El canal no existe.",
|
||||||
|
"Could not get channel info.": "No se ha podido obtener información del canal.",
|
||||||
|
"Could not fetch comments": "No se han podido recuperar los comentarios",
|
||||||
|
"View `x` replies": "Ver `x` respuestas",
|
||||||
|
"`x` ago": "hace `x`",
|
||||||
|
"Load more": "Cargar más",
|
||||||
|
"`x` points": "`x` puntos",
|
||||||
|
"Could not create mix.": "No se ha podido crear la mezcla.",
|
||||||
|
"Empty playlist": "La lista de reproducción está vacía",
|
||||||
|
"Not a playlist.": "Lista de reproducción no válida.",
|
||||||
|
"Playlist does not exist.": "La lista de reproducción no existe.",
|
||||||
|
"Could not pull trending pages.": "No se han podido obtener las páginas de tendencias.",
|
||||||
|
"Hidden field \"challenge\" is a required field": "El campo oculto «desafío» es un campo obligatorio",
|
||||||
|
"Hidden field \"token\" is a required field": "El campo oculto «símbolo» es un campo obligatorio",
|
||||||
|
"Erroneous challenge": "Desafío no válido",
|
||||||
|
"Erroneous token": "Símbolo no válido",
|
||||||
|
"No such user": "Usuario no válido",
|
||||||
|
"Token is expired, please try again": "El símbolo ha caducado, inténtelo de nuevo",
|
||||||
|
"English": "Inglés",
|
||||||
|
"English (auto-generated)": "Inglés (autogenerado)",
|
||||||
|
"Afrikaans": "Afrikáans",
|
||||||
|
"Albanian": "Albanés",
|
||||||
|
"Amharic": "Amárico",
|
||||||
|
"Arabic": "Árabe",
|
||||||
|
"Armenian": "Armenio",
|
||||||
|
"Azerbaijani": "Azerbaiyano",
|
||||||
|
"Bangla": "Bengalí",
|
||||||
|
"Basque": "Euskera",
|
||||||
|
"Belarusian": "Bielorruso",
|
||||||
|
"Bosnian": "Bosnio",
|
||||||
|
"Bulgarian": "Búlgaro",
|
||||||
|
"Burmese": "Birmano",
|
||||||
|
"Catalan": "Catalán",
|
||||||
|
"Cebuano": "Cebuano",
|
||||||
|
"Chinese (Simplified)": "Chino (simplificado)",
|
||||||
|
"Chinese (Traditional)": "Chino (tradicional)",
|
||||||
|
"Corsican": "Corso",
|
||||||
|
"Croatian": "Croata",
|
||||||
|
"Czech": "Checo",
|
||||||
|
"Danish": "Danés",
|
||||||
|
"Dutch": "Holandés",
|
||||||
|
"Esperanto": "Esperanto",
|
||||||
|
"Estonian": "Estonio",
|
||||||
|
"Filipino": "Filipino",
|
||||||
|
"Finnish": "Finés",
|
||||||
|
"French": "Francés",
|
||||||
|
"Galician": "Gallego",
|
||||||
|
"Georgian": "Georgiano",
|
||||||
|
"German": "Alemán",
|
||||||
|
"Greek": "Griego",
|
||||||
|
"Gujarati": "Guyaratí",
|
||||||
|
"Haitian Creole": "Criollo haitiano",
|
||||||
|
"Hausa": "Hausa",
|
||||||
|
"Hawaiian": "Hawaiano",
|
||||||
|
"Hebrew": "Hebreo",
|
||||||
|
"Hindi": "Hindi",
|
||||||
|
"Hmong": "Hmong",
|
||||||
|
"Hungarian": "Húngaro",
|
||||||
|
"Icelandic": "Islandés",
|
||||||
|
"Igbo": "Igbo",
|
||||||
|
"Indonesian": "Indonesio",
|
||||||
|
"Irish": "Irlandés",
|
||||||
|
"Italian": "Italiano",
|
||||||
|
"Japanese": "Japonés",
|
||||||
|
"Javanese": "Javanés",
|
||||||
|
"Kannada": "Canarés",
|
||||||
|
"Kazakh": "Kazajo",
|
||||||
|
"Khmer": "Camboyano",
|
||||||
|
"Korean": "Coreano",
|
||||||
|
"Kurdish": "Kurdo",
|
||||||
|
"Kyrgyz": "Kirguís",
|
||||||
|
"Lao": "Laosiano",
|
||||||
|
"Latin": "Latín",
|
||||||
|
"Latvian": "Letón",
|
||||||
|
"Lithuanian": "Lituano",
|
||||||
|
"Luxembourgish": "Luxemburgués",
|
||||||
|
"Macedonian": "Macedonio",
|
||||||
|
"Malagasy": "Malgache",
|
||||||
|
"Malay": "Malayo",
|
||||||
|
"Malayalam": "Malabar",
|
||||||
|
"Maltese": "Maltés",
|
||||||
|
"Maori": "Maorí",
|
||||||
|
"Marathi": "Maratí",
|
||||||
|
"Mongolian": "Mongol",
|
||||||
|
"Nepali": "Nepalí",
|
||||||
|
"Norwegian Bokmål": "Noruego",
|
||||||
|
"Nyanja": "Chichewa",
|
||||||
|
"Pashto": "Pastún",
|
||||||
|
"Persian": "Persa",
|
||||||
|
"Polish": "Polaco",
|
||||||
|
"Portuguese": "Portugués",
|
||||||
|
"Punjabi": "Panyabí",
|
||||||
|
"Romanian": "Rumano",
|
||||||
|
"Russian": "Ruso",
|
||||||
|
"Samoan": "Samoano",
|
||||||
|
"Scottish Gaelic": "Gaélico escocés",
|
||||||
|
"Serbian": "Serbio",
|
||||||
|
"Shona": "Shona",
|
||||||
|
"Sindhi": "Sindi",
|
||||||
|
"Sinhala": "Cingalés",
|
||||||
|
"Slovak": "Eslovaco",
|
||||||
|
"Slovenian": "Esloveno",
|
||||||
|
"Somali": "Somalí",
|
||||||
|
"Southern Sotho": "Sesoto",
|
||||||
|
"Spanish": "Español",
|
||||||
|
"Spanish (Latin America)": "Español (Hispanoamérica)",
|
||||||
|
"Sundanese": "Sondanés",
|
||||||
|
"Swahili": "Suajili",
|
||||||
|
"Swedish": "Sueco",
|
||||||
|
"Tajik": "Tayiko",
|
||||||
|
"Tamil": "Tamil",
|
||||||
|
"Telugu": "Telugu",
|
||||||
|
"Thai": "Tailandés",
|
||||||
|
"Turkish": "Turco",
|
||||||
|
"Ukrainian": "Ucraniano",
|
||||||
|
"Urdu": "Urdu",
|
||||||
|
"Uzbek": "Uzbeko",
|
||||||
|
"Vietnamese": "Vietnamita",
|
||||||
|
"Welsh": "Galés",
|
||||||
|
"Western Frisian": "Frisón",
|
||||||
|
"Xhosa": "Xhosa",
|
||||||
|
"Yiddish": "Yidis",
|
||||||
|
"Yoruba": "Yoruba",
|
||||||
|
"Zulu": "Zulú",
|
||||||
|
"`x` years": "`x` años",
|
||||||
|
"`x` months": "`x` meses",
|
||||||
|
"`x` weeks": "`x` semanas",
|
||||||
|
"`x` days": "`x` días",
|
||||||
|
"`x` hours": "`x` horas",
|
||||||
|
"`x` minutes": "`x` minutos",
|
||||||
|
"`x` seconds": "`x` segundos",
|
||||||
|
"Fallback comments: ": "Comentarios alternativos: ",
|
||||||
|
"Popular": "Populares",
|
||||||
|
"Top": "Destacados",
|
||||||
|
"About": "Acerca de",
|
||||||
|
"Rating: ": "Valoración: ",
|
||||||
|
"Language: ": "Idioma: ",
|
||||||
|
"View as playlist": "Ver como lista de reproducción",
|
||||||
|
"Default": "Por defecto",
|
||||||
|
"Music": "Música",
|
||||||
|
"Gaming": "Videojuegos",
|
||||||
|
"News": "Noticias",
|
||||||
|
"Movies": "Películas",
|
||||||
|
"Download": "Descargar",
|
||||||
|
"Download as: ": "Descargar como: ",
|
||||||
|
"%A %B %-d, %Y": "%A %B %-d, %Y",
|
||||||
|
"(edited)": "(editado)",
|
||||||
|
"YouTube comment permalink": "Enlace permanente de YouTube del comentario",
|
||||||
|
"permalink": "permalink",
|
||||||
|
"`x` marked it with a ❤": "`x` lo ha marcado con un ❤",
|
||||||
|
"Audio mode": "Modo de audio",
|
||||||
|
"Video mode": "Modo de vídeo",
|
||||||
|
"Videos": "Vídeos",
|
||||||
|
"Playlists": "Listas de reproducción",
|
||||||
|
"Community": "Comunidad",
|
||||||
|
"Current version: ": "Versión actual: "
|
||||||
|
}
|
||||||
622
locales/eu.json
622
locales/eu.json
@@ -1,288 +1,336 @@
|
|||||||
{
|
{
|
||||||
"`x` subscribers": "`x` harpidedun",
|
"`x` subscribers": "`x` harpidedun",
|
||||||
"`x` videos": "`x` bideo",
|
"`x` videos": "`x` bideo",
|
||||||
"LIVE": "ZUZENEAN",
|
"`x` playlists": "`x` erreprodukzio-zerrenda",
|
||||||
"Shared `x` ago": "Duela `x` partekatua",
|
"LIVE": "ZUZENEAN",
|
||||||
"Unsubscribe": "Harpidetza kendu",
|
"Shared `x` ago": "Duela `x` partekatua",
|
||||||
"Subscribe": "Harpidetu",
|
"Unsubscribe": "Harpidetza kendu",
|
||||||
"Login to subscribe to `x`": "Saioa hasi `x`(e)ra harpidetzeko",
|
"Subscribe": "Harpidetu",
|
||||||
"View channel on YouTube": "Ikusi kanala YouTuben",
|
"View channel on YouTube": "Ikusi kanala YouTuben",
|
||||||
"newest": "berrienak",
|
"View playlist on YouTube": "Ikusi erreprodukzio-zerrenda YouTuben",
|
||||||
"oldest": "zaharrenak",
|
"newest": "berrienak",
|
||||||
"popular": "ospetsuenak",
|
"oldest": "zaharrenak",
|
||||||
"Preview page": "Aurrebista orria",
|
"popular": "ospetsuenak",
|
||||||
"Next page": "Hurrengo orria",
|
"last": "azkena",
|
||||||
"Clear watch history?": "Garbitu ikusitakoen historia?",
|
"Next page": "Hurrengo orria",
|
||||||
"Yes": "Bai",
|
"Previous page": "Aurreko orria",
|
||||||
"No": "Ez",
|
"Clear watch history?": "Garbitu ikusitakoen historia?",
|
||||||
"Import and Export Data": "Datuak inportatu eta esportatu",
|
"New password": "Pasahitz berria",
|
||||||
"Import": "Inportatu",
|
"New passwords must match": "Pasahitza berriek bat egin behar dute",
|
||||||
"Import Invidious data": "Invidiouseko datuak inportatu",
|
"Cannot change password for Google accounts": "Ezin da pasahitza aldatu Google kontuetan",
|
||||||
"Import YouTube subscriptions": "YouTubeko harpidetzak inportatu",
|
"Authorize token?": "Baimendu tokena?",
|
||||||
"Import FreeTube subscriptions (.db)": "FreeTubeko harpidetzak inportatu (.db)",
|
"Authorize token for `x`?": "",
|
||||||
"Import NewPipe subscriptions (.json)": "NewPipeko harpidetzak inportatu (.json)",
|
"Yes": "Bai",
|
||||||
"Import NewPipe data (.zip)": "NewPipeko datuak inportatu (.zip)",
|
"No": "Ez",
|
||||||
"Export": "Esportatu",
|
"Import and Export Data": "Datuak inportatu eta esportatu",
|
||||||
"Export subscriptions as OPML": "Esportatu harpidetzak OPML bezala",
|
"Import": "Inportatu",
|
||||||
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Harpidetzak OPML bezala esportatu (NewPipe eta FreeTuberako)",
|
"Import Invidious data": "Inportatu Invidiouseko datuak",
|
||||||
"Export data as JSON": "Datuak JSON bezala esportatu",
|
"Import YouTube subscriptions": "Inportatu YouTubeko harpidetzak",
|
||||||
"Delete account?": "Kontua ezabatu?",
|
"Import FreeTube subscriptions (.db)": "Inportatu FreeTubeko harpidetzak (.db)",
|
||||||
"History": "Historia",
|
"Import NewPipe subscriptions (.json)": "Inportatu NewPipeko harpidetzak (.json)",
|
||||||
"Previous page": "Aurreko orria",
|
"Import NewPipe data (.zip)": "Inportatu NewPipeko datuak (.zip)",
|
||||||
"An alternative front-end to YouTube": "YouTuberako interfaze alternatibo bat",
|
"Export": "Esportatu",
|
||||||
"JavaScript license information": "JavaScript lizentzia informazioa",
|
"Export subscriptions as OPML": "Esportatu harpidetzak OPML bezala",
|
||||||
"source": "iturburua",
|
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Esportatu harpidetzak OPML bezala (NewPipe eta FreeTuberako)",
|
||||||
"Login": "Saioa hasi",
|
"Export data as JSON": "Esportatu datuak JSON bezala",
|
||||||
"Login/Register": "Saioa hasi/Izena eman",
|
"Delete account?": "Kontua ezabatu?",
|
||||||
"Login to Google": "Googlekin hasi saioa",
|
"History": "Historia",
|
||||||
"User ID:": "Erabiltzaile IDa:",
|
"An alternative front-end to YouTube": "YouTuberako interfaze alternatibo bat",
|
||||||
"Password:": "Pasahitza:",
|
"JavaScript license information": "JavaScript lizentzia informazioa",
|
||||||
"Time (h:mm:ss):": "Denbora (o:mm:ss):",
|
"source": "iturburua",
|
||||||
"Text CAPTCHA": "Testu CAPTCHA",
|
"Log in": "Saioa hasi",
|
||||||
"Image CAPTCHA": "Irudi CAPTCHA",
|
"Log in/register": "Hasi saioa / Eman izena",
|
||||||
"Sign In": "",
|
"Log in with Google": "Hasi saioa Googlekin",
|
||||||
"Register": "",
|
"User ID": "Erabiltzaile IDa",
|
||||||
"Email:": "",
|
"Password": "Pasahitza",
|
||||||
"Google verification code:": "",
|
"Time (h:mm:ss):": "Denbora (h:mm:ss):",
|
||||||
"Preferences": "",
|
"Text CAPTCHA": "CAPTCHA testua",
|
||||||
"Player preferences": "",
|
"Image CAPTCHA": "CAPTCHA irudia",
|
||||||
"Always loop: ": "",
|
"Sign In": "Hasi saioa",
|
||||||
"Autoplay: ": "",
|
"Register": "Eman izena",
|
||||||
"Autoplay next video: ": "",
|
"E-mail": "E-posta",
|
||||||
"Listen by default: ": "",
|
"Google verification code": "",
|
||||||
"Default speed: ": "",
|
"Preferences": "Hobespenak",
|
||||||
"Preferred video quality: ": "",
|
"Player preferences": "Erreproduzigailuaren hobespenak",
|
||||||
"Player volume: ": "",
|
"Always loop: ": "",
|
||||||
"Default comments: ": "",
|
"Autoplay: ": "Automatikoki erreproduzitu: ",
|
||||||
"Default captions: ": "",
|
"Play next by default: ": "",
|
||||||
"Fallback captions: ": "",
|
"Autoplay next video: ": "Erreproduzitu automatikoki hurrengo bideoa: ",
|
||||||
"Show related videos? ": "",
|
"Listen by default: ": "",
|
||||||
"Visual preferences": "",
|
"Proxy videos: ": "",
|
||||||
"Dark mode: ": "",
|
"Default speed: ": "",
|
||||||
"Thin mode: ": "",
|
"Preferred video quality: ": "Hobetsitako bideoaren kalitatea: ",
|
||||||
"Subscription preferences": "",
|
"Player volume: ": "Erreproduzigailuaren bolumena: ",
|
||||||
"Redirect homepage to feed: ": "",
|
"Default comments: ": "Lehenetsitako iruzkinak: ",
|
||||||
"Number of videos shown in feed: ": "",
|
"youtube": "youtube",
|
||||||
"Sort videos by: ": "",
|
"reddit": "reddit",
|
||||||
"published": "",
|
"Default captions: ": "Lehenetsitako azpitituluak: ",
|
||||||
"published - reverse": "",
|
"Fallback captions: ": "",
|
||||||
"alphabetically": "",
|
"Show related videos: ": "Erakutsi erlazionatutako bideoak: ",
|
||||||
"alphabetically - reverse": "",
|
"Show annotations by default: ": "Erakutsi oharrak modu lehenetsian: ",
|
||||||
"channel name": "",
|
"Visual preferences": "Hobespen bisualak",
|
||||||
"channel name - reverse": "",
|
"Player style: ": "Erreproduzigailu mota: ",
|
||||||
"Only show latest video from channel: ": "",
|
"Dark mode: ": "Gai iluna: ",
|
||||||
"Only show latest unwatched video from channel: ": "",
|
"Theme: ": "Gaia: ",
|
||||||
"Only show unwatched: ": "",
|
"dark": "iluna",
|
||||||
"Only show notifications (if there are any): ": "",
|
"light": "argia",
|
||||||
"Data preferences": "",
|
"Thin mode: ": "",
|
||||||
"Clear watch history": "",
|
"Subscription preferences": "Harpidetzen hobespenak",
|
||||||
"Import/Export data": "",
|
"Show annotations by default for subscribed channels: ": "",
|
||||||
"Manage subscriptions": "",
|
"Redirect homepage to feed: ": "",
|
||||||
"Watch history": "",
|
"Number of videos shown in feed: ": "",
|
||||||
"Delete account": "",
|
"Sort videos by: ": "",
|
||||||
"Administrator preferences": "",
|
"published": "",
|
||||||
"Default homepage: ": "",
|
"published - reverse": "",
|
||||||
"Feed menu: ": "",
|
"alphabetically": "",
|
||||||
"Top enabled? ": "",
|
"alphabetically - reverse": "",
|
||||||
"CAPTCHA enabled? ": "",
|
"channel name": "",
|
||||||
"Login enabled? ": "",
|
"channel name - reverse": "",
|
||||||
"Registration enabled? ": "",
|
"Only show latest video from channel: ": "",
|
||||||
"Report statistics? ": "",
|
"Only show latest unwatched video from channel: ": "",
|
||||||
"Save preferences": "",
|
"Only show unwatched: ": "",
|
||||||
"Subscription manager": "",
|
"Only show notifications (if there are any): ": "",
|
||||||
"`x` subscriptions": "",
|
"Enable web notifications": "",
|
||||||
"Import/Export": "",
|
"`x` uploaded a video": "",
|
||||||
"unsubscribe": "",
|
"`x` is live": "",
|
||||||
"Subscriptions": "",
|
"Data preferences": "",
|
||||||
"`x` unseen notifications": "",
|
"Clear watch history": "",
|
||||||
"search": "",
|
"Import/export data": "",
|
||||||
"Sign out": "",
|
"Change password": "",
|
||||||
"Released under the AGPLv3 by Omar Roth.": "",
|
"Manage subscriptions": "",
|
||||||
"Source available here.": "",
|
"Manage tokens": "",
|
||||||
"View JavaScript license information.": "",
|
"Watch history": "",
|
||||||
"Trending": "",
|
"Delete account": "",
|
||||||
"Watch video on Youtube": "",
|
"Administrator preferences": "",
|
||||||
"Genre: ": "",
|
"Default homepage: ": "",
|
||||||
"License: ": "",
|
"Feed menu: ": "",
|
||||||
"Family friendly? ": "",
|
"Top enabled: ": "",
|
||||||
"Wilson score: ": "",
|
"CAPTCHA enabled: ": "",
|
||||||
"Engagement: ": "",
|
"Login enabled: ": "",
|
||||||
"Whitelisted regions: ": "",
|
"Registration enabled: ": "",
|
||||||
"Blacklisted regions: ": "",
|
"Report statistics: ": "",
|
||||||
"Shared `x`": "",
|
"Save preferences": "",
|
||||||
"Hi! Looks like you have JavaScript disabled. Click here to view comments, keep in mind it may take a bit longer to load.": "",
|
"Subscription manager": "",
|
||||||
"View YouTube comments": "",
|
"Token manager": "",
|
||||||
"View more comments on Reddit": "",
|
"Token": "",
|
||||||
"View `x` comments": "",
|
"`x` subscriptions": "",
|
||||||
"View Reddit comments": "",
|
"`x` tokens": "",
|
||||||
"Hide replies": "",
|
"Import/export": "",
|
||||||
"Show replies": "",
|
"unsubscribe": "",
|
||||||
"Incorrect password": "",
|
"revoke": "",
|
||||||
"Quota exceeded, try again in a few hours": "",
|
"Subscriptions": "",
|
||||||
"Unable to login, make sure two-factor authentication (Authenticator or SMS) is enabled.": "",
|
"`x` unseen notifications": "",
|
||||||
"Invalid TFA code": "",
|
"search": "",
|
||||||
"Login failed. This may be because two-factor authentication is not enabled on your account.": "",
|
"Log out": "",
|
||||||
"Invalid answer": "",
|
"Released under the AGPLv3 by Omar Roth.": "",
|
||||||
"Invalid CAPTCHA": "",
|
"Source available here.": "",
|
||||||
"CAPTCHA is a required field": "",
|
"View JavaScript license information.": "",
|
||||||
"User ID is a required field": "",
|
"View privacy policy.": "",
|
||||||
"Password is a required field": "",
|
"Trending": "",
|
||||||
"Invalid username or password": "",
|
"Public": "",
|
||||||
"Please sign in using 'Sign in with Google'": "",
|
"Unlisted": "",
|
||||||
"Password cannot be empty": "",
|
"Private": "",
|
||||||
"Password cannot be longer than 55 characters": "",
|
"View all playlists": "",
|
||||||
"Please sign in": "",
|
"Updated `x` ago": "",
|
||||||
"Invidious Private Feed for `x`": "",
|
"Delete playlist `x`?": "",
|
||||||
"channel:`x`": "",
|
"Delete playlist": "",
|
||||||
"Deleted or invalid channel": "",
|
"Create playlist": "",
|
||||||
"This channel does not exist.": "",
|
"Title": "",
|
||||||
"Could not get channel info.": "",
|
"Playlist privacy": "",
|
||||||
"Could not fetch comments": "",
|
"Editing playlist `x`": "",
|
||||||
"View `x` replies": "",
|
"Watch on YouTube": "",
|
||||||
"`x` ago": "",
|
"Hide annotations": "",
|
||||||
"Load more": "",
|
"Show annotations": "",
|
||||||
"`x` points": "",
|
"Genre: ": "",
|
||||||
"Could not create mix.": "",
|
"License: ": "",
|
||||||
"Playlist is empty": "",
|
"Family friendly? ": "",
|
||||||
"Invalid playlist.": "",
|
"Wilson score: ": "",
|
||||||
"Playlist does not exist.": "",
|
"Engagement: ": "",
|
||||||
"Could not pull trending pages.": "",
|
"Whitelisted regions: ": "",
|
||||||
"Hidden field \"challenge\" is a required field": "",
|
"Blacklisted regions: ": "",
|
||||||
"Hidden field \"token\" is a required field": "",
|
"Shared `x`": "",
|
||||||
"Invalid challenge": "",
|
"`x` views": "",
|
||||||
"Invalid token": "",
|
"Premieres in `x`": "",
|
||||||
"Invalid user": "",
|
"Premieres `x`": "",
|
||||||
"Token is expired, please try again": "",
|
"Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.": "",
|
||||||
"English": "",
|
"View YouTube comments": "",
|
||||||
"English (auto-generated)": "",
|
"View more comments on Reddit": "",
|
||||||
"Afrikaans": "",
|
"View `x` comments": "",
|
||||||
"Albanian": "",
|
"View Reddit comments": "",
|
||||||
"Amharic": "",
|
"Hide replies": "",
|
||||||
"Arabic": "",
|
"Show replies": "",
|
||||||
"Armenian": "",
|
"Incorrect password": "",
|
||||||
"Azerbaijani": "",
|
"Quota exceeded, try again in a few hours": "",
|
||||||
"Bangla": "",
|
"Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.": "",
|
||||||
"Basque": "",
|
"Invalid TFA code": "",
|
||||||
"Belarusian": "",
|
"Login failed. This may be because two-factor authentication is not turned on for your account.": "",
|
||||||
"Bosnian": "",
|
"Wrong answer": "",
|
||||||
"Bulgarian": "",
|
"Erroneous CAPTCHA": "",
|
||||||
"Burmese": "",
|
"CAPTCHA is a required field": "",
|
||||||
"Catalan": "",
|
"User ID is a required field": "",
|
||||||
"Cebuano": "",
|
"Password is a required field": "",
|
||||||
"Chinese (Simplified)": "",
|
"Wrong username or password": "",
|
||||||
"Chinese (Traditional)": "",
|
"Please sign in using 'Log in with Google'": "",
|
||||||
"Corsican": "",
|
"Password cannot be empty": "",
|
||||||
"Croatian": "",
|
"Password cannot be longer than 55 characters": "",
|
||||||
"Czech": "",
|
"Please log in": "",
|
||||||
"Danish": "",
|
"Invidious Private Feed for `x`": "",
|
||||||
"Dutch": "",
|
"channel:`x`": "",
|
||||||
"Esperanto": "",
|
"Deleted or invalid channel": "",
|
||||||
"Estonian": "",
|
"This channel does not exist.": "",
|
||||||
"Filipino": "",
|
"Could not get channel info.": "",
|
||||||
"Finnish": "",
|
"Could not fetch comments": "",
|
||||||
"French": "",
|
"View `x` replies": "",
|
||||||
"Galician": "",
|
"`x` ago": "",
|
||||||
"Georgian": "",
|
"Load more": "",
|
||||||
"German": "",
|
"`x` points": "",
|
||||||
"Greek": "",
|
"Could not create mix.": "",
|
||||||
"Gujarati": "",
|
"Empty playlist": "",
|
||||||
"Haitian Creole": "",
|
"Not a playlist.": "",
|
||||||
"Hausa": "",
|
"Playlist does not exist.": "",
|
||||||
"Hawaiian": "",
|
"Could not pull trending pages.": "",
|
||||||
"Hebrew": "",
|
"Hidden field \"challenge\" is a required field": "",
|
||||||
"Hindi": "",
|
"Hidden field \"token\" is a required field": "",
|
||||||
"Hmong": "",
|
"Erroneous challenge": "",
|
||||||
"Hungarian": "",
|
"Erroneous token": "",
|
||||||
"Icelandic": "",
|
"No such user": "",
|
||||||
"Igbo": "",
|
"Token is expired, please try again": "",
|
||||||
"Indonesian": "",
|
"English": "",
|
||||||
"Irish": "",
|
"English (auto-generated)": "",
|
||||||
"Italian": "",
|
"Afrikaans": "",
|
||||||
"Japanese": "",
|
"Albanian": "",
|
||||||
"Javanese": "",
|
"Amharic": "",
|
||||||
"Kannada": "",
|
"Arabic": "",
|
||||||
"Kazakh": "",
|
"Armenian": "",
|
||||||
"Khmer": "",
|
"Azerbaijani": "",
|
||||||
"Korean": "",
|
"Bangla": "",
|
||||||
"Kurdish": "",
|
"Basque": "",
|
||||||
"Kyrgyz": "",
|
"Belarusian": "",
|
||||||
"Lao": "",
|
"Bosnian": "",
|
||||||
"Latin": "",
|
"Bulgarian": "",
|
||||||
"Latvian": "",
|
"Burmese": "",
|
||||||
"Lithuanian": "",
|
"Catalan": "",
|
||||||
"Luxembourgish": "",
|
"Cebuano": "",
|
||||||
"Macedonian": "",
|
"Chinese (Simplified)": "",
|
||||||
"Malagasy": "",
|
"Chinese (Traditional)": "",
|
||||||
"Malay": "",
|
"Corsican": "",
|
||||||
"Malayalam": "",
|
"Croatian": "",
|
||||||
"Maltese": "",
|
"Czech": "",
|
||||||
"Maori": "",
|
"Danish": "",
|
||||||
"Marathi": "",
|
"Dutch": "",
|
||||||
"Mongolian": "",
|
"Esperanto": "",
|
||||||
"Nepali": "",
|
"Estonian": "",
|
||||||
"Norwegian": "",
|
"Filipino": "",
|
||||||
"Nyanja": "",
|
"Finnish": "",
|
||||||
"Pashto": "",
|
"French": "",
|
||||||
"Persian": "",
|
"Galician": "",
|
||||||
"Polish": "",
|
"Georgian": "",
|
||||||
"Portuguese": "",
|
"German": "",
|
||||||
"Punjabi": "",
|
"Greek": "",
|
||||||
"Romanian": "",
|
"Gujarati": "",
|
||||||
"Russian": "",
|
"Haitian Creole": "",
|
||||||
"Samoan": "",
|
"Hausa": "",
|
||||||
"Scottish Gaelic": "",
|
"Hawaiian": "",
|
||||||
"Serbian": "",
|
"Hebrew": "",
|
||||||
"Shona": "",
|
"Hindi": "",
|
||||||
"Sindhi": "",
|
"Hmong": "",
|
||||||
"Sinhala": "",
|
"Hungarian": "",
|
||||||
"Slovak": "",
|
"Icelandic": "",
|
||||||
"Slovenian": "",
|
"Igbo": "",
|
||||||
"Somali": "",
|
"Indonesian": "",
|
||||||
"Southern Sotho": "",
|
"Irish": "",
|
||||||
"Spanish": "",
|
"Italian": "",
|
||||||
"Spanish (Latin America)": "",
|
"Japanese": "",
|
||||||
"Sundanese": "",
|
"Javanese": "",
|
||||||
"Swahili": "",
|
"Kannada": "",
|
||||||
"Swedish": "",
|
"Kazakh": "",
|
||||||
"Tajik": "",
|
"Khmer": "",
|
||||||
"Tamil": "",
|
"Korean": "",
|
||||||
"Telugu": "",
|
"Kurdish": "",
|
||||||
"Thai": "",
|
"Kyrgyz": "",
|
||||||
"Turkish": "",
|
"Lao": "",
|
||||||
"Ukrainian": "",
|
"Latin": "",
|
||||||
"Urdu": "",
|
"Latvian": "",
|
||||||
"Uzbek": "",
|
"Lithuanian": "",
|
||||||
"Vietnamese": "",
|
"Luxembourgish": "",
|
||||||
"Welsh": "",
|
"Macedonian": "",
|
||||||
"Western Frisian": "",
|
"Malagasy": "",
|
||||||
"Xhosa": "",
|
"Malay": "",
|
||||||
"Yiddish": "",
|
"Malayalam": "",
|
||||||
"Yoruba": "",
|
"Maltese": "",
|
||||||
"Zulu": "",
|
"Maori": "",
|
||||||
"`x` years": "",
|
"Marathi": "",
|
||||||
"`x` months": "",
|
"Mongolian": "",
|
||||||
"`x` weeks": "",
|
"Nepali": "",
|
||||||
"`x` days": "",
|
"Norwegian Bokmål": "",
|
||||||
"`x` hours": "",
|
"Nyanja": "",
|
||||||
"`x` minutes": "",
|
"Pashto": "",
|
||||||
"`x` seconds": "",
|
"Persian": "",
|
||||||
"Fallback comments: ": "",
|
"Polish": "",
|
||||||
"Popular": "",
|
"Portuguese": "",
|
||||||
"Top": "",
|
"Punjabi": "",
|
||||||
"About": "",
|
"Romanian": "",
|
||||||
"Rating: ": "",
|
"Russian": "",
|
||||||
"Language: ": "",
|
"Samoan": "",
|
||||||
"Default": "",
|
"Scottish Gaelic": "",
|
||||||
"Music": "",
|
"Serbian": "",
|
||||||
"Gaming": "",
|
"Shona": "",
|
||||||
"News": "",
|
"Sindhi": "",
|
||||||
"Movies": "",
|
"Sinhala": "",
|
||||||
"Download": "",
|
"Slovak": "",
|
||||||
"Download as: ": "",
|
"Slovenian": "",
|
||||||
"%A %B %-d, %Y": "",
|
"Somali": "",
|
||||||
"(edited)": "",
|
"Southern Sotho": "",
|
||||||
"Youtube permalink of the comment": "",
|
"Spanish": "",
|
||||||
"`x` marked it with a ❤": "",
|
"Spanish (Latin America)": "",
|
||||||
"Audio mode": "",
|
"Sundanese": "",
|
||||||
"Video mode": ""
|
"Swahili": "",
|
||||||
}
|
"Swedish": "",
|
||||||
|
"Tajik": "",
|
||||||
|
"Tamil": "",
|
||||||
|
"Telugu": "",
|
||||||
|
"Thai": "",
|
||||||
|
"Turkish": "",
|
||||||
|
"Ukrainian": "",
|
||||||
|
"Urdu": "",
|
||||||
|
"Uzbek": "",
|
||||||
|
"Vietnamese": "",
|
||||||
|
"Welsh": "",
|
||||||
|
"Western Frisian": "",
|
||||||
|
"Xhosa": "",
|
||||||
|
"Yiddish": "",
|
||||||
|
"Yoruba": "",
|
||||||
|
"Zulu": "",
|
||||||
|
"`x` years": "",
|
||||||
|
"`x` months": "",
|
||||||
|
"`x` weeks": "",
|
||||||
|
"`x` days": "",
|
||||||
|
"`x` hours": "",
|
||||||
|
"`x` minutes": "",
|
||||||
|
"`x` seconds": "",
|
||||||
|
"Fallback comments: ": "",
|
||||||
|
"Popular": "",
|
||||||
|
"Top": "",
|
||||||
|
"About": "",
|
||||||
|
"Rating: ": "",
|
||||||
|
"Language: ": "",
|
||||||
|
"View as playlist": "",
|
||||||
|
"Default": "",
|
||||||
|
"Music": "",
|
||||||
|
"Gaming": "",
|
||||||
|
"News": "",
|
||||||
|
"Movies": "",
|
||||||
|
"Download": "",
|
||||||
|
"Download as: ": "",
|
||||||
|
"%A %B %-d, %Y": "",
|
||||||
|
"(edited)": "",
|
||||||
|
"YouTube comment permalink": "",
|
||||||
|
"permalink": "",
|
||||||
|
"`x` marked it with a ❤": "",
|
||||||
|
"Audio mode": "",
|
||||||
|
"Video mode": "",
|
||||||
|
"Videos": "",
|
||||||
|
"Playlists": "",
|
||||||
|
"Community": "",
|
||||||
|
"Current version: ": ""
|
||||||
|
}
|
||||||
621
locales/fr.json
621
locales/fr.json
@@ -1,287 +1,336 @@
|
|||||||
{
|
{
|
||||||
"`x` subscribers": "`x` abonnés",
|
"`x` subscribers": "`x` abonnés",
|
||||||
"`x` videos": "`x` vidéos",
|
"`x` videos": "`x` vidéos",
|
||||||
"LIVE": "EN DIRECT",
|
"`x` playlists": "`x` listes de lecture",
|
||||||
"Shared `x` ago": "Partagé il y a `x`",
|
"LIVE": "EN DIRECT",
|
||||||
"Unsubscribe": "Se désabonner",
|
"Shared `x` ago": "Ajoutée il y a `x`",
|
||||||
"Subscribe": "S'abonner",
|
"Unsubscribe": "Se désabonner",
|
||||||
"Login to subscribe to `x`": "Vous devez vous connecter pour vous abonner à `x`",
|
"Subscribe": "S'abonner",
|
||||||
"View channel on YouTube": "Voir la chaîne sur YouTube",
|
"View channel on YouTube": "Voir la chaîne sur YouTube",
|
||||||
"newest": "Date d'ajout (la plus récente)",
|
"View playlist on YouTube": "Voir la liste de lecture sur YouTube",
|
||||||
"oldest": "Date d'ajout (la plus ancienne)",
|
"newest": "Date d'ajout (la plus récente)",
|
||||||
"popular": "Les plus populaires",
|
"oldest": "Date d'ajout (la plus ancienne)",
|
||||||
"Next page": "Page suivante",
|
"popular": "Les plus populaires",
|
||||||
"Clear watch history?": "Êtes-vous sûr de vouloir supprimer l'historique des vidéos regardées ?",
|
"last": "Dernières",
|
||||||
"Yes": "Oui",
|
"Next page": "Page suivante",
|
||||||
"No": "Non",
|
"Previous page": "Page précédente",
|
||||||
"Import and Export Data": "Importer et Exporter les Données",
|
"Clear watch history?": "Êtes-vous sûr de vouloir supprimer l'historique des vidéos regardées ?",
|
||||||
"Import": "Importer",
|
"New password": "Nouveau mot de passe",
|
||||||
"Import Invidious data": "Importer des données Invidious",
|
"New passwords must match": "Les champs \"Nouveau mot de passe\" doivent être identiques",
|
||||||
"Import YouTube subscriptions": "Importer des abonnements YouTube",
|
"Cannot change password for Google accounts": "Le mot de passe d'un compte Google ne peut pas être changé depuis Invidious",
|
||||||
"Import FreeTube subscriptions (.db)": "Importer des abonnements FreeTube (.db)",
|
"Authorize token?": "Autoriser le token ?",
|
||||||
"Import NewPipe subscriptions (.json)": "Importer des abonnements NewPipe (.json)",
|
"Authorize token for `x`?": "Autoriser le token pour `x` ?",
|
||||||
"Import NewPipe data (.zip)": "Importer des données NewPipe (.zip)",
|
"Yes": "Oui",
|
||||||
"Export": "Exporter",
|
"No": "Non",
|
||||||
"Export subscriptions as OPML": "Exporter les abonnements en OPML",
|
"Import and Export Data": "Importer et exporter des données",
|
||||||
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Exporter les abonnements en OPML (pour NewPipe & FreeTube)",
|
"Import": "Importer",
|
||||||
"Export data as JSON": "Exporter les données au format JSON",
|
"Import Invidious data": "Importer des données Invidious",
|
||||||
"Delete account?": "Supprimer votre compte ?",
|
"Import YouTube subscriptions": "Importer des abonnements YouTube",
|
||||||
"History": "Historique",
|
"Import FreeTube subscriptions (.db)": "Importer des abonnements FreeTube (.db)",
|
||||||
"Previous page": "Page précédente",
|
"Import NewPipe subscriptions (.json)": "Importer des abonnements NewPipe (.json)",
|
||||||
"An alternative front-end to YouTube": "Un front-end alternatif à YouTube",
|
"Import NewPipe data (.zip)": "Importer des données NewPipe (.zip)",
|
||||||
"JavaScript license information": "Informations sur les licences JavaScript",
|
"Export": "Exporter",
|
||||||
"source": "source",
|
"Export subscriptions as OPML": "Exporter les abonnements au format OPML",
|
||||||
"Login": "Connexion",
|
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Exporter les abonnements au format OPML (pour NewPipe & FreeTube)",
|
||||||
"Login/Register": "Connexion/S'inscrire",
|
"Export data as JSON": "Exporter les données au format JSON",
|
||||||
"Login to Google": "Se connecter à Google",
|
"Delete account?": "Êtes-vous sûr de vouloir supprimer votre compte ?",
|
||||||
"User ID:": "ID utilisateur :",
|
"History": "Historique",
|
||||||
"Password:": "Mot de passe :",
|
"An alternative front-end to YouTube": "Un front-end alternatif à YouTube",
|
||||||
"Time (h:mm:ss):": "Heure (h:mm:ss) :",
|
"JavaScript license information": "Informations sur les licences JavaScript",
|
||||||
"Text CAPTCHA": "CAPTCHA Texte",
|
"source": "source",
|
||||||
"Image CAPTCHA": "CAPTCHA Image",
|
"Log in": "Se connecter",
|
||||||
"Sign In": "S'identifier",
|
"Log in/register": "Se connecter/Créer un compte",
|
||||||
"Register": "S'inscrire",
|
"Log in with Google": "Se connecter avec Google",
|
||||||
"Email:": "Email :",
|
"User ID": "Identifiant utilisateur",
|
||||||
"Google verification code:": "Code de vérification Google :",
|
"Password": "Mot de passe",
|
||||||
"Preferences": "Préférences",
|
"Time (h:mm:ss):": "Heure (h:mm:ss) :",
|
||||||
"Player preferences": "Préférences du Lecteur",
|
"Text CAPTCHA": "CAPTCHA Texte",
|
||||||
"Always loop: ": "Lire en boucle : ",
|
"Image CAPTCHA": "CAPTCHA Image",
|
||||||
"Autoplay: ": "Lire Automatiquement : ",
|
"Sign In": "Se connecter",
|
||||||
"Autoplay next video: ": "Lire automatiquement la vidéo suivante : ",
|
"Register": "S'inscrire",
|
||||||
"Listen by default: ": "Audio Uniquement par défaut : ",
|
"E-mail": "E-mail",
|
||||||
"Default speed: ": "Vitesse par défaut : ",
|
"Google verification code": "Code de vérification Google",
|
||||||
"Preferred video quality: ": "Qualité vidéo souhaitée : ",
|
"Preferences": "Préférences",
|
||||||
"Player volume: ": "Volume du lecteur : ",
|
"Player preferences": "Préférences du lecteur",
|
||||||
"Default comments: ": "Source des Commentaires : ",
|
"Always loop: ": "Lire en boucle : ",
|
||||||
"Default captions: ": "Sous-titres principal : ",
|
"Autoplay: ": "Lancer la lecture automatiquement : ",
|
||||||
"Fallback captions: ": "Sous-titres secondaire : ",
|
"Play next by default: ": "Lire les vidéos suivantes par défaut : ",
|
||||||
"Show related videos? ": "Voir les vidéos liées à ce sujet ? ",
|
"Autoplay next video: ": "Lancer la lecture automatiquement pour la vidéo suivant la vidéo regardée : ",
|
||||||
"Visual preferences": "Préférences visuelles",
|
"Listen by default: ": "Audio uniquement : ",
|
||||||
"Dark mode: ": "Mode Sombre : ",
|
"Proxy videos: ": "Charger les vidéos à travers un proxy : ",
|
||||||
"Thin mode: ": "Mode Simplifié : ",
|
"Default speed: ": "Vitesse par défaut : ",
|
||||||
"Subscription preferences": "Préférences de la page d'abonnements",
|
"Preferred video quality: ": "Qualité vidéo souhaitée : ",
|
||||||
"Redirect homepage to feed: ": "Rediriger la page d'accueil vers la page d'abonnements : ",
|
"Player volume: ": "Volume du lecteur : ",
|
||||||
"Number of videos shown in feed: ": "Nombre de vidéos montrées dans la page d'abonnements : ",
|
"Default comments: ": "Source des commentaires : ",
|
||||||
"Sort videos by: ": "Trier les vidéos par : ",
|
"youtube": "YouTube",
|
||||||
"published": "publication",
|
"reddit": "Reddit",
|
||||||
"published - reverse": "publication - inversé",
|
"Default captions: ": "Sous-titres par défaut : ",
|
||||||
"alphabetically": "alphabétiquement",
|
"Fallback captions: ": "Sous-titres alternatifs : ",
|
||||||
"alphabetically - reverse": "alphabétiquement - inversé",
|
"Show related videos: ": "Voir les vidéos liées : ",
|
||||||
"channel name": "nom de la chaîne",
|
"Show annotations by default: ": "Afficher les annotations par défaut : ",
|
||||||
"channel name - reverse": "nom de la chaîne - inversé",
|
"Visual preferences": "Préférences du site",
|
||||||
"Only show latest video from channel: ": "Afficher uniquement la dernière vidéo de la chaîne : ",
|
"Player style: ": "Style du lecteur : ",
|
||||||
"Only show latest unwatched video from channel: ": "Afficher uniquement la dernière vidéo de la chaîne non regardée : ",
|
"Dark mode: ": "Mode sombre : ",
|
||||||
"Only show unwatched: ": "Afficher uniquement les vidéos non regardées : ",
|
"Theme: ": "Thème : ",
|
||||||
"Only show notifications (if there are any): ": "Afficher uniquement les notifications (s'il y en a) : ",
|
"dark": "sombre",
|
||||||
"Data preferences": "Préférences liées aux données",
|
"light": "clair",
|
||||||
"Clear watch history": "Supprimer l'historique des vidéos regardées",
|
"Thin mode: ": "Mode léger : ",
|
||||||
"Import/Export data": "Importer/exporter les données",
|
"Subscription preferences": "Préférences de la page d'abonnements",
|
||||||
"Manage subscriptions": "Gérer les abonnements",
|
"Show annotations by default for subscribed channels: ": "Afficher les annotations par défaut sur les chaînes auxquelles vous êtes abonnés : ",
|
||||||
"Watch history": "Historique de visionnage",
|
"Redirect homepage to feed: ": "Rediriger la page d'accueil vers la page d'abonnements : ",
|
||||||
"Delete account": "Supprimer votre compte",
|
"Number of videos shown in feed: ": "Nombre de vidéos affichées dans la page d'abonnements : ",
|
||||||
"Administrator preferences": "",
|
"Sort videos by: ": "Trier les vidéos par : ",
|
||||||
"Default homepage: ": "",
|
"published": "date de publication",
|
||||||
"Feed menu: ": "",
|
"published - reverse": "date de publication - inversé",
|
||||||
"Top enabled? ": "",
|
"alphabetically": "alphabétiquement",
|
||||||
"CAPTCHA enabled? ": "",
|
"alphabetically - reverse": "alphabétiquement - inversé",
|
||||||
"Login enabled? ": "",
|
"channel name": "nom de la chaîne",
|
||||||
"Registration enabled? ": "",
|
"channel name - reverse": "nom de la chaîne - inversé",
|
||||||
"Report statistics? ": "",
|
"Only show latest video from channel: ": "Afficher uniquement la dernière vidéo des chaînes auxquelles vous êtes abonnés : ",
|
||||||
"Save preferences": "Enregistrer les préférences",
|
"Only show latest unwatched video from channel: ": "Afficher uniquement la dernière vidéo des chaînes auxquelles vous êtes abonnés qui n'a pas été regardée : ",
|
||||||
"Subscription manager": "Gestionnaire d'abonnement",
|
"Only show unwatched: ": "Afficher uniquement les vidéos qui n'ont pas été regardées : ",
|
||||||
"`x` subscriptions": "`x` abonnements",
|
"Only show notifications (if there are any): ": "Afficher uniquement les notifications (s'il y en a) : ",
|
||||||
"Import/Export": "Importer/Exporter",
|
"Enable web notifications": "Activer les notifications web",
|
||||||
"unsubscribe": "se désabonner",
|
"`x` uploaded a video": "`x` a partagé(e) une vidéo",
|
||||||
"Subscriptions": "Abonnements",
|
"`x` is live": "`x` est en direct",
|
||||||
"`x` unseen notifications": "`x` notifications non vues",
|
"Data preferences": "Préférences liées aux données",
|
||||||
"search": "Rechercher",
|
"Clear watch history": "Supprimer l'historique des vidéos regardées",
|
||||||
"Sign out": "Déconnexion",
|
"Import/export data": "Importer/exporter les données",
|
||||||
"Released under the AGPLv3 by Omar Roth.": "Publié sous licence AGPLv3 par Omar Roth.",
|
"Change password": "Modifier le mot de passe",
|
||||||
"Source available here.": "Code Source.",
|
"Manage subscriptions": "Gérer les abonnements",
|
||||||
"View JavaScript license information.": "Voir les informations des licences JavaScript.",
|
"Manage tokens": "Gérer les tokens",
|
||||||
"Trending": "Tendances",
|
"Watch history": "Historique de visionnage",
|
||||||
"Watch video on Youtube": "Voir la vidéo sur Youtube",
|
"Delete account": "Supprimer votre compte",
|
||||||
"Genre: ": "Genre : ",
|
"Administrator preferences": "Préferences d'Administration",
|
||||||
"License: ": "Licence : ",
|
"Default homepage: ": "Page d'accueil par défaut : ",
|
||||||
"Family friendly? ": "Tout Public ? ",
|
"Feed menu: ": "Préferences des abonnements : ",
|
||||||
"Wilson score: ": "Score de Wilson : ",
|
"Top enabled: ": "Top activé : ",
|
||||||
"Engagement: ": "Poucentage de spectateur aillant aimé Liker ou Disliker la vidéo : ",
|
"CAPTCHA enabled: ": "CAPTCHA activé : ",
|
||||||
"Whitelisted regions: ": "Régions en liste blanche : ",
|
"Login enabled: ": "Connexion activé : ",
|
||||||
"Blacklisted regions: ": "Régions sur liste noire : ",
|
"Registration enabled: ": "Inscription activée : ",
|
||||||
"Shared `x`": "Partagée `x`",
|
"Report statistics: ": "Télémétrie activé : ",
|
||||||
"Hi! Looks like you have JavaScript disabled. Click here to view comments, keep in mind it may take a bit longer to load.": "Il semblerait que JavaScript sois désactivé. Cliquez ici pour voir les commentaires. Gardez à l'esprit que le chargement peut prendre plus de temps.",
|
"Save preferences": "Enregistrer les préférences",
|
||||||
"View YouTube comments": "Voir les commentaires YouTube",
|
"Subscription manager": "Gestionnaire d'abonnement",
|
||||||
"View more comments on Reddit": "Voir plus de commentaires sur Reddit",
|
"Token manager": "Gestionnaire de tokens",
|
||||||
"View `x` comments": "Voir `x` commentaires",
|
"Token": "Token",
|
||||||
"View Reddit comments": "Voir les commentaires Reddit",
|
"`x` subscriptions": "`x` abonnements",
|
||||||
"Hide replies": "Masquer les réponses",
|
"`x` tokens": "`x` tokens",
|
||||||
"Show replies": "Afficher les réponses",
|
"Import/export": "Importer/Exporter",
|
||||||
"Incorrect password": "Mot de passe incorrect",
|
"unsubscribe": "se désabonner",
|
||||||
"Quota exceeded, try again in a few hours": "Nombre de tentative de connexion dépassé, réessayez dans quelques heures",
|
"revoke": "révoquer",
|
||||||
"Unable to login, make sure two-factor authentication (Authenticator or SMS) is enabled.": "Si vous ne parvenez pas à vous connecter, assurez-vous que l'authentification à deux facteurs (Authenticator ou SMS) est activée.",
|
"Subscriptions": "Abonnements",
|
||||||
"Invalid TFA code": "Code d'authentification à deux facteurs invalide",
|
"`x` unseen notifications": "`x` notifications non vues",
|
||||||
"Login failed. This may be because two-factor authentication is not enabled on your account.": "La connexion a échoué. Cela peut être dû au fait que l'authentification à deux facteurs n'est pas activée sur votre compte.",
|
"search": "rechercher",
|
||||||
"Invalid answer": "Réponse non valide",
|
"Log out": "Déconnexion",
|
||||||
"Invalid CAPTCHA": "CAPTCHA invalide",
|
"Released under the AGPLv3 by Omar Roth.": "Publié sous licence AGPLv3 par Omar Roth.",
|
||||||
"CAPTCHA is a required field": "Veuillez rentrez un CAPTCHA",
|
"Source available here.": "Code source disponible ici.",
|
||||||
"User ID is a required field": "Veuillez rentrez un Identifiant Utilisateur",
|
"View JavaScript license information.": "Informations des licences JavaScript.",
|
||||||
"Password is a required field": "Veuillez rentrez un Mot de passe",
|
"View privacy policy.": "Politique de confidentialité.",
|
||||||
"Invalid username or password": "Nom d'utilisateur ou mot de passe invalide",
|
"Trending": "Tendances",
|
||||||
"Please sign in using 'Sign in with Google'": "Veuillez vous connecter en utilisant \"S'identifier avec Google\"",
|
"Public": "Publique",
|
||||||
"Password cannot be empty": "Le mot de passe ne peut pas être vide",
|
"Unlisted": "Non répertoriée",
|
||||||
"Password cannot be longer than 55 characters": "Le mot de passe ne doit pas comporter plus de 55 caractères",
|
"Private": "Privée",
|
||||||
"Please sign in": "Veuillez vous connecter",
|
"View all playlists": "Voir toutes vos playlists",
|
||||||
"Invidious Private Feed for `x`": "Flux RSS privé pour `x`",
|
"Updated `x` ago": "Dernière mise à jour il y a `x`",
|
||||||
"channel:`x`": "chaîne:`x`",
|
"Delete playlist `x`?": "Êtes-vous sûr de vouloir supprimer la liste de lecture ?",
|
||||||
"Deleted or invalid channel": "Chaîne supprimée ou invalide",
|
"Delete playlist": "Supprimer la liste de lecture",
|
||||||
"This channel does not exist.": "Cette chaine n'existe pas.",
|
"Create playlist": "Créer une liste de lecture",
|
||||||
"Could not get channel info.": "Impossible de charger les informations de cette chaîne.",
|
"Title": "Titre",
|
||||||
"Could not fetch comments": "Impossible de charger les commentaires",
|
"Playlist privacy": "Paramètres de confidentialité de la liste de lecture",
|
||||||
"View `x` replies": "Voir `x` réponses",
|
"Editing playlist `x`": "Liste de lecture modifier le `x`",
|
||||||
"`x` ago": "il y a `x`",
|
"Watch on YouTube": "Voir la vidéo sur Youtube",
|
||||||
"Load more": "Charger plus",
|
"Hide annotations": "Masquer les annotations",
|
||||||
"`x` points": "`x` points",
|
"Show annotations": "Afficher les annotations",
|
||||||
"Could not create mix.": "Impossible de charger cette liste de lecture.",
|
"Genre: ": "Genre : ",
|
||||||
"Playlist is empty": "La liste de lecture est vide",
|
"License: ": "Licence : ",
|
||||||
"Invalid playlist.": "Liste de lecture invalide.",
|
"Family friendly? ": "Vidéo tout public ? ",
|
||||||
"Playlist does not exist.": "La liste de lecture n'existe pas.",
|
"Wilson score: ": "Score de Wilson : ",
|
||||||
"Could not pull trending pages.": "Impossible de charger les pages de tendances.",
|
"Engagement: ": "Pourcentage de spectateur aillant appuyé sur \"J'aime\" ou \"J'aime Pas\" : ",
|
||||||
"Hidden field \"challenge\" is a required field": "Hidden field \"challenge\" is a required field",
|
"Whitelisted regions: ": "Régions sur liste blanche : ",
|
||||||
"Hidden field \"token\" is a required field": "Hidden field \"token\" is a required field",
|
"Blacklisted regions: ": "Régions sur liste noire : ",
|
||||||
"Invalid challenge": "Invalid challenge",
|
"Shared `x`": "Ajoutée le `x`",
|
||||||
"Invalid token": "Invalid token",
|
"`x` views": "`x` vues",
|
||||||
"Invalid user": "Invalid user",
|
"Premieres in `x`": "Première dans `x`",
|
||||||
"Token is expired, please try again": "Token is expired, please try again",
|
"Premieres `x`": "Première le `x`",
|
||||||
"English": "Anglais",
|
"Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.": "Il semblerait que JavaScript soit désactivé. Cliquez ici pour voir les commentaires, mais gardez à l'esprit que le chargement peut prendre plus de temps.",
|
||||||
"English (auto-generated)": "Anglais (générés automatiquement)",
|
"View YouTube comments": "Voir les commentaires YouTube",
|
||||||
"Afrikaans": "Afrikaans",
|
"View more comments on Reddit": "Voir plus de commentaires sur Reddit",
|
||||||
"Albanian": "Albanais",
|
"View `x` comments": "Voir `x` commentaires",
|
||||||
"Amharic": "Amharique",
|
"View Reddit comments": "Voir les commentaires Reddit",
|
||||||
"Arabic": "Arabe",
|
"Hide replies": "Masquer les réponses",
|
||||||
"Armenian": "Arménien",
|
"Show replies": "Afficher les réponses",
|
||||||
"Azerbaijani": "Azerbaïdjanais",
|
"Incorrect password": "Mot de passe incorrect",
|
||||||
"Bangla": "Bangla",
|
"Quota exceeded, try again in a few hours": "Nombre de tentatives de connexion dépassé, réessayez dans quelques heures",
|
||||||
"Basque": "Basque",
|
"Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.": "Impossible de se connecter, si après plusieurs tentative vous ne parvenez toujours pas à vous connecter, assurez-vous que l'authentification à deux facteurs (Authenticator ou SMS) est activée.",
|
||||||
"Belarusian": "Belarusian",
|
"Invalid TFA code": "Code d'authentification à deux facteurs invalide",
|
||||||
"Bosnian": "Bosnian",
|
"Login failed. This may be because two-factor authentication is not turned on for your account.": "La connexion a échoué. Cela peut être dû au fait que l'authentification à deux facteurs n'est pas activée sur votre compte.",
|
||||||
"Bulgarian": "Bulgarian",
|
"Wrong answer": "Réponse invalide",
|
||||||
"Burmese": "Birman",
|
"Erroneous CAPTCHA": "CAPTCHA invalide",
|
||||||
"Catalan": "Catalan",
|
"CAPTCHA is a required field": "Veuillez entrer un CAPTCHA",
|
||||||
"Cebuano": "Cebuano",
|
"User ID is a required field": "Veuillez entrer un Identifiant Utilisateur",
|
||||||
"Chinese (Simplified)": "Chinois (Simplifié)",
|
"Password is a required field": "Veuillez entrer un Mot de passe",
|
||||||
"Chinese (Traditional)": "Chinois (Traditionnel)",
|
"Wrong username or password": "Nom d'utilisateur ou mot de passe invalide",
|
||||||
"Corsican": "Corse",
|
"Please sign in using 'Log in with Google'": "Veuillez vous connecter en utilisant \"Se connecter avec Google\"",
|
||||||
"Croatian": "Croate",
|
"Password cannot be empty": "Le mot de passe ne peut pas être vide",
|
||||||
"Czech": "Tchèque",
|
"Password cannot be longer than 55 characters": "Le mot de passe ne doit pas comporter plus de 55 caractères",
|
||||||
"Danish": "Danois",
|
"Please log in": "Veuillez vous connecter",
|
||||||
"Dutch": "Hollandais",
|
"Invidious Private Feed for `x`": "Flux RSS privé pour `x`",
|
||||||
"Esperanto": "Espéranto",
|
"channel:`x`": "chaîne:`x`",
|
||||||
"Estonian": "Estonien",
|
"Deleted or invalid channel": "Chaîne supprimée ou invalide",
|
||||||
"Filipino": "Philippin",
|
"This channel does not exist.": "Cette chaine n'existe pas.",
|
||||||
"Finnish": "Finlandais",
|
"Could not get channel info.": "Impossible de charger les informations de cette chaîne.",
|
||||||
"French": "Français",
|
"Could not fetch comments": "Impossible de charger les commentaires",
|
||||||
"Galician": "Galicien",
|
"View `x` replies": "Voir `x` réponses",
|
||||||
"Georgian": "Géorgien",
|
"`x` ago": "il y a `x`",
|
||||||
"German": "Allemand",
|
"Load more": "Voir plus",
|
||||||
"Greek": "Grec",
|
"`x` points": "`x` points",
|
||||||
"Gujarati": "Gujarati",
|
"Could not create mix.": "Impossible de charger cette liste de lecture.",
|
||||||
"Haitian Creole": "Créole Haïtien",
|
"Empty playlist": "La liste de lecture est vide",
|
||||||
"Hausa": "Haoussa",
|
"Not a playlist.": "La liste de lecture est invalide.",
|
||||||
"Hawaiian": "Hawaïen",
|
"Playlist does not exist.": "La liste de lecture n'existe pas.",
|
||||||
"Hebrew": "Hébraïque",
|
"Could not pull trending pages.": "Impossible de charger les pages de tendances.",
|
||||||
"Hindi": "Hindi",
|
"Hidden field \"challenge\" is a required field": "Le champ masqué \"challenge\" est un champ obligatoire",
|
||||||
"Hmong": "Hmong",
|
"Hidden field \"token\" is a required field": "Le champ caché \"token\" est requis",
|
||||||
"Hungarian": "Hongrois",
|
"Erroneous challenge": "Challenge invalide",
|
||||||
"Icelandic": "Islandais",
|
"Erroneous token": "Token invalide",
|
||||||
"Igbo": "Igbo",
|
"No such user": "Cet utilisateur n'existe pas",
|
||||||
"Indonesian": "Indonésien",
|
"Token is expired, please try again": "Le token est expiré, veuillez réessayer",
|
||||||
"Irish": "Irlandais",
|
"English": "Anglais",
|
||||||
"Italian": "Italien",
|
"English (auto-generated)": "Anglais (générés automatiquement)",
|
||||||
"Japanese": "Japonais",
|
"Afrikaans": "Afrikaans",
|
||||||
"Javanese": "Javanais",
|
"Albanian": "Albanais",
|
||||||
"Kannada": "Kannada",
|
"Amharic": "Amharique",
|
||||||
"Kazakh": "Kazakh",
|
"Arabic": "Arabe",
|
||||||
"Khmer": "Khmer",
|
"Armenian": "Arménien",
|
||||||
"Korean": "Coréen",
|
"Azerbaijani": "Azerbaïdjanais",
|
||||||
"Kurdish": "Kurde",
|
"Bangla": "Bangla",
|
||||||
"Kyrgyz": "Kirghize",
|
"Basque": "Basque",
|
||||||
"Lao": "Lao",
|
"Belarusian": "Belarusian",
|
||||||
"Latin": "Latin",
|
"Bosnian": "Bosnian",
|
||||||
"Latvian": "Letton",
|
"Bulgarian": "Bulgarian",
|
||||||
"Lithuanian": "Lituanien",
|
"Burmese": "Birman",
|
||||||
"Luxembourgish": "Luxembourgeois",
|
"Catalan": "Catalan",
|
||||||
"Macedonian": "Macédonien",
|
"Cebuano": "Cebuano",
|
||||||
"Malagasy": "Malgache",
|
"Chinese (Simplified)": "Chinois (Simplifié)",
|
||||||
"Malay": "Malais",
|
"Chinese (Traditional)": "Chinois (Traditionnel)",
|
||||||
"Malayalam": "Malayalam",
|
"Corsican": "Corse",
|
||||||
"Maltese": "Maltais",
|
"Croatian": "Croate",
|
||||||
"Maori": "Maori",
|
"Czech": "Tchèque",
|
||||||
"Marathi": "Marathi",
|
"Danish": "Danois",
|
||||||
"Mongolian": "Mongol",
|
"Dutch": "Hollandais",
|
||||||
"Nepali": "Népalais",
|
"Esperanto": "Espéranto",
|
||||||
"Norwegian": "Norvégien",
|
"Estonian": "Estonien",
|
||||||
"Nyanja": "Nyanja",
|
"Filipino": "Philippin",
|
||||||
"Pashto": "Pachtou",
|
"Finnish": "Finlandais",
|
||||||
"Persian": "Persan",
|
"French": "Français",
|
||||||
"Polish": "Polonais",
|
"Galician": "Galicien",
|
||||||
"Portuguese": "Portugais",
|
"Georgian": "Géorgien",
|
||||||
"Punjabi": "Punjabi",
|
"German": "Allemand",
|
||||||
"Romanian": "Roumain",
|
"Greek": "Grec",
|
||||||
"Russian": "Russe",
|
"Gujarati": "Gujarati",
|
||||||
"Samoan": "Samoan",
|
"Haitian Creole": "Créole Haïtien",
|
||||||
"Scottish Gaelic": "Eaélique Ècossais",
|
"Hausa": "Haoussa",
|
||||||
"Serbian": "Serbe",
|
"Hawaiian": "Hawaïen",
|
||||||
"Shona": "Shona",
|
"Hebrew": "Hébraïque",
|
||||||
"Sindhi": "Sindhi",
|
"Hindi": "Hindi",
|
||||||
"Sinhala": "Cinghalais",
|
"Hmong": "Hmong",
|
||||||
"Slovak": "Slovaque",
|
"Hungarian": "Hongrois",
|
||||||
"Slovenian": "Slovène",
|
"Icelandic": "Islandais",
|
||||||
"Somali": "Somalien",
|
"Igbo": "Igbo",
|
||||||
"Southern Sotho": "Sotho du Sud",
|
"Indonesian": "Indonésien",
|
||||||
"Spanish": "Espagnol",
|
"Irish": "Irlandais",
|
||||||
"Spanish (Latin America)": "Espagnol (Amérique latine)",
|
"Italian": "Italien",
|
||||||
"Sundanese": "Sundanais",
|
"Japanese": "Japonais",
|
||||||
"Swahili": "Swahili",
|
"Javanese": "Javanais",
|
||||||
"Swedish": "Suédois",
|
"Kannada": "Kannada",
|
||||||
"Tajik": "Tajik",
|
"Kazakh": "Kazakh",
|
||||||
"Tamil": "Tamil",
|
"Khmer": "Khmer",
|
||||||
"Telugu": "Telugu",
|
"Korean": "Coréen",
|
||||||
"Thai": "Thaï",
|
"Kurdish": "Kurde",
|
||||||
"Turkish": "Turc",
|
"Kyrgyz": "Kirghize",
|
||||||
"Ukrainian": "Ukrainien",
|
"Lao": "Lao",
|
||||||
"Urdu": "Ourdou",
|
"Latin": "Latin",
|
||||||
"Uzbek": "Ouzbek",
|
"Latvian": "Letton",
|
||||||
"Vietnamese": "Vietnamien",
|
"Lithuanian": "Lituanien",
|
||||||
"Welsh": "Gallois",
|
"Luxembourgish": "Luxembourgeois",
|
||||||
"Western Frisian": "Frison occidental",
|
"Macedonian": "Macédonien",
|
||||||
"Xhosa": "Xhosa",
|
"Malagasy": "Malgache",
|
||||||
"Yiddish": "Yiddish",
|
"Malay": "Malais",
|
||||||
"Yoruba": "Yoruba",
|
"Malayalam": "Malayalam",
|
||||||
"Zulu": "Zoulou",
|
"Maltese": "Maltais",
|
||||||
"`x` years": "`x` ans",
|
"Maori": "Maori",
|
||||||
"`x` months": "`x` mois",
|
"Marathi": "Marathi",
|
||||||
"`x` weeks": "`x` semaines",
|
"Mongolian": "Mongol",
|
||||||
"`x` days": "`x` jours",
|
"Nepali": "Népalais",
|
||||||
"`x` hours": "`x` heures",
|
"Norwegian Bokmål": "Norvégien",
|
||||||
"`x` minutes": "`x` minutes",
|
"Nyanja": "Nyanja",
|
||||||
"`x` seconds": "`x` secondes",
|
"Pashto": "Pachtou",
|
||||||
"Fallback comments: ": "Commentaires secondaires : ",
|
"Persian": "Persan",
|
||||||
"Popular": "Populaire",
|
"Polish": "Polonais",
|
||||||
"Top": "Top",
|
"Portuguese": "Portugais",
|
||||||
"About": "A Propos",
|
"Punjabi": "Punjabi",
|
||||||
"Rating: ": "Évaluation : ",
|
"Romanian": "Roumain",
|
||||||
"Language: ": "Langue : ",
|
"Russian": "Russe",
|
||||||
"Default": "Défaut",
|
"Samoan": "Samoan",
|
||||||
"Music": "Musique",
|
"Scottish Gaelic": "Eaélique Ècossais",
|
||||||
"Gaming": "Jeux Vidéo",
|
"Serbian": "Serbe",
|
||||||
"News": "Actualités",
|
"Shona": "Shona",
|
||||||
"Movies": "Films",
|
"Sindhi": "Sindhi",
|
||||||
"Download": "Télécharger",
|
"Sinhala": "Cinghalais",
|
||||||
"Download as: ": "Télécharger en : ",
|
"Slovak": "Slovaque",
|
||||||
"%A %B %-d, %Y": "%A %-d %B %Y",
|
"Slovenian": "Slovène",
|
||||||
"(edited)": "(modifié)",
|
"Somali": "Somalien",
|
||||||
"Youtube permalink of the comment": "Lien YouTube permanent vers le commentaire",
|
"Southern Sotho": "Sotho du Sud",
|
||||||
"`x` marked it with a ❤": "`x` l'a marqué d'un ❤",
|
"Spanish": "Espagnol",
|
||||||
"Audio mode": "Mode Audio",
|
"Spanish (Latin America)": "Espagnol (Amérique latine)",
|
||||||
"Video mode": "Mode Vidéo"
|
"Sundanese": "Sundanais",
|
||||||
}
|
"Swahili": "Swahili",
|
||||||
|
"Swedish": "Suédois",
|
||||||
|
"Tajik": "Tajik",
|
||||||
|
"Tamil": "Tamil",
|
||||||
|
"Telugu": "Telugu",
|
||||||
|
"Thai": "Thaï",
|
||||||
|
"Turkish": "Turc",
|
||||||
|
"Ukrainian": "Ukrainien",
|
||||||
|
"Urdu": "Ourdou",
|
||||||
|
"Uzbek": "Ouzbek",
|
||||||
|
"Vietnamese": "Vietnamien",
|
||||||
|
"Welsh": "Gallois",
|
||||||
|
"Western Frisian": "Frison occidental",
|
||||||
|
"Xhosa": "Xhosa",
|
||||||
|
"Yiddish": "Yiddish",
|
||||||
|
"Yoruba": "Yoruba",
|
||||||
|
"Zulu": "Zoulou",
|
||||||
|
"`x` years": "`x` ans",
|
||||||
|
"`x` months": "`x` mois",
|
||||||
|
"`x` weeks": "`x` semaines",
|
||||||
|
"`x` days": "`x` jours",
|
||||||
|
"`x` hours": "`x` heures",
|
||||||
|
"`x` minutes": "`x` minutes",
|
||||||
|
"`x` seconds": "`x` secondes",
|
||||||
|
"Fallback comments: ": "Commentaires alternatifs : ",
|
||||||
|
"Popular": "Populaire",
|
||||||
|
"Top": "Top",
|
||||||
|
"About": "À propos",
|
||||||
|
"Rating: ": "Évaluation : ",
|
||||||
|
"Language: ": "Langue : ",
|
||||||
|
"View as playlist": "Voir en tant que liste de lecture",
|
||||||
|
"Default": "Défaut",
|
||||||
|
"Music": "Musique",
|
||||||
|
"Gaming": "Jeux Vidéo",
|
||||||
|
"News": "Actualités",
|
||||||
|
"Movies": "Films",
|
||||||
|
"Download": "Télécharger",
|
||||||
|
"Download as: ": "Télécharger en : ",
|
||||||
|
"%A %B %-d, %Y": "%A %-d %B %Y",
|
||||||
|
"(edited)": "(modifié)",
|
||||||
|
"YouTube comment permalink": "Lien permanent vers le commentaire sur YouTube",
|
||||||
|
"permalink": "Lien permanent",
|
||||||
|
"`x` marked it with a ❤": "`x` l'a marqué d'un ❤",
|
||||||
|
"Audio mode": "Mode audio",
|
||||||
|
"Video mode": "Mode vidéo",
|
||||||
|
"Videos": "Vidéos",
|
||||||
|
"Playlists": "Listes de lecture",
|
||||||
|
"Community": "Communauté",
|
||||||
|
"Current version: ": "Version actuelle : "
|
||||||
|
}
|
||||||
335
locales/hu-HU.json
Normal file
335
locales/hu-HU.json
Normal file
@@ -0,0 +1,335 @@
|
|||||||
|
{
|
||||||
|
"`x` subscribers": "`x` feliratkozó",
|
||||||
|
"`x` videos": "`x` videó",
|
||||||
|
"`x` playlists": "`x` playlist",
|
||||||
|
"LIVE": "ÉLŐ",
|
||||||
|
"Shared `x` ago": "`x` óta megosztva",
|
||||||
|
"Unsubscribe": "Leiratkozás",
|
||||||
|
"Subscribe": "Feliratkozás",
|
||||||
|
"View channel on YouTube": "Csatokrna megtekintése a YouTube-on",
|
||||||
|
"View playlist on YouTube": "Playlist megtekintése a YouTube-on",
|
||||||
|
"newest": "legújabb",
|
||||||
|
"oldest": "legrégibb",
|
||||||
|
"popular": "népszerű",
|
||||||
|
"last": "utolsó",
|
||||||
|
"Next page": "Következő oldal",
|
||||||
|
"Previous page": "Előző oldal",
|
||||||
|
"Clear watch history?": "Megtekintési napló törlése?",
|
||||||
|
"New password": "Új jelszó",
|
||||||
|
"New passwords must match": "Az új jelszavaknak egyezniük kell",
|
||||||
|
"Cannot change password for Google accounts": "Google fiók jelszavát nem lehet cserélni",
|
||||||
|
"Authorize token?": "Token felhatalmazása?",
|
||||||
|
"Authorize token for `x`?": "Token felhatalmazása `x`-ra?",
|
||||||
|
"Yes": "Igen",
|
||||||
|
"No": "Nem",
|
||||||
|
"Import and Export Data": "Adatok importálása és exportálása",
|
||||||
|
"Import": "Importálás",
|
||||||
|
"Import Invidious data": "Invidious adatainak importálása",
|
||||||
|
"Import YouTube subscriptions": "YouTube feliratkozások importálása",
|
||||||
|
"Import FreeTube subscriptions (.db)": "FreeTube feliratkozások importálása (.db)",
|
||||||
|
"Import NewPipe subscriptions (.json)": "NewPipe feliratkozások importálása (.json)",
|
||||||
|
"Import NewPipe data (.zip)": "NewPipe adatainak importálása (.zip)",
|
||||||
|
"Export": "Exportálás",
|
||||||
|
"Export subscriptions as OPML": "Feliratkozások exportálása OPML-ként",
|
||||||
|
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Feliratkozások exportálása OPML-ként (NewPipe és FreeTube számára)",
|
||||||
|
"Export data as JSON": "Adat exportálása JSON-ként",
|
||||||
|
"Delete account?": "Fiók törlése?",
|
||||||
|
"History": "Megtekintési napló",
|
||||||
|
"An alternative front-end to YouTube": "Alternatív YouTube front-end",
|
||||||
|
"JavaScript license information": "JavaScript licensz információ",
|
||||||
|
"source": "forrás",
|
||||||
|
"Log in": "Bejelentkezés",
|
||||||
|
"Log in/register": "Bejelentkezés/Regisztráció",
|
||||||
|
"Log in with Google": "Bejelentkezés Google fiókkal",
|
||||||
|
"User ID": "Felhasználó-ID",
|
||||||
|
"Password": "Jelszó",
|
||||||
|
"Time (h:mm:ss):": "Idő (h:mm:ss):",
|
||||||
|
"Text CAPTCHA": "Szöveg-CAPTCHA",
|
||||||
|
"Image CAPTCHA": "Kép-CAPTCHA",
|
||||||
|
"Sign In": "Bejelentkezés",
|
||||||
|
"Register": "Regisztráció",
|
||||||
|
"E-mail": "E-mail",
|
||||||
|
"Google verification code": "Google verifikációs kód",
|
||||||
|
"Preferences": "Beállítások",
|
||||||
|
"Player preferences": "Lejátszó beállítások",
|
||||||
|
"Always loop: ": "Mindig loop-ol: ",
|
||||||
|
"Autoplay: ": "Automatikus lejátszás: ",
|
||||||
|
"Play next by default: ": "Következő lejátszása alapértelmezésben: ",
|
||||||
|
"Autoplay next video: ": "Következő automatikus lejátszása: ",
|
||||||
|
"Listen by default: ": "Hallgatás alapértelmezésben: ",
|
||||||
|
"Proxy videos: ": "Proxy videók: ",
|
||||||
|
"Default speed: ": "Alapértelmezett sebesség: ",
|
||||||
|
"Preferred video quality: ": "Kívánt video minőség: ",
|
||||||
|
"Player volume: ": "Hangerő: ",
|
||||||
|
"Default comments: ": "Alapértelmezett kommentek: ",
|
||||||
|
"youtube": "YouTube",
|
||||||
|
"reddit": "Reddit",
|
||||||
|
"Default captions: ": "Alapértelmezett feliratok: ",
|
||||||
|
"Fallback captions: ": "Másodlagos feliratok: ",
|
||||||
|
"Show related videos: ": "Kapcsolódó videók mutatása: ",
|
||||||
|
"Show annotations by default: ": "Annotációk mutatása alapértelmetésben: ",
|
||||||
|
"Visual preferences": "Vizuális preferenciák",
|
||||||
|
"Player style: ": "Lejátszó stílusa: ",
|
||||||
|
"Dark mode: ": "Sötét mód: ",
|
||||||
|
"Theme: ": "Téma: ",
|
||||||
|
"dark": "Sötét",
|
||||||
|
"light": "Világos",
|
||||||
|
"Thin mode: ": "Vékony mód: ",
|
||||||
|
"Subscription preferences": "Feliratkozási beállítások",
|
||||||
|
"Show annotations by default for subscribed channels: ": "Annotációk mutatása alapértelmezésben feliratkozott csatornák esetében: ",
|
||||||
|
"Redirect homepage to feed: ": "Kezdő oldal átirányitása a feed-re: ",
|
||||||
|
"Number of videos shown in feed: ": "Feed-ben mutatott videók száma: ",
|
||||||
|
"Sort videos by: ": "Videók sorrendje: ",
|
||||||
|
"published": "közzétéve",
|
||||||
|
"published - reverse": "közzétéve (ford.)",
|
||||||
|
"alphabetically": "ABC sorrend",
|
||||||
|
"alphabetically - reverse": "ABC sorrend (ford.)",
|
||||||
|
"channel name": "csatorna neve",
|
||||||
|
"channel name - reverse": "csatorna neve (ford.)",
|
||||||
|
"Only show latest video from channel: ": "Csak a legutolsó videó mutatása a csatornából: ",
|
||||||
|
"Only show latest unwatched video from channel: ": "Csak a legutolsó nem megtekintett videó mutatása a csatornából: ",
|
||||||
|
"Only show unwatched: ": "Csak a nem megtekintettek mutatása: ",
|
||||||
|
"Only show notifications (if there are any): ": "Csak értesítések mutatása (ha van): ",
|
||||||
|
"Enable web notifications": "Web értesítések bekapcsolása",
|
||||||
|
"`x` uploaded a video": "`x` feltöltött egy videót",
|
||||||
|
"`x` is live": "`x` élő",
|
||||||
|
"Data preferences": "Adat beállítások",
|
||||||
|
"Clear watch history": "Megtekintési napló törlése",
|
||||||
|
"Import/export data": "Adat Import/Export",
|
||||||
|
"Change password": "Jelszócsere",
|
||||||
|
"Manage subscriptions": "Feliratkozások kezelése",
|
||||||
|
"Manage tokens": "Tokenek kezelése",
|
||||||
|
"Watch history": "Megtekintési napló",
|
||||||
|
"Delete account": "Fiók törlése",
|
||||||
|
"Administrator preferences": "Adminisztrátor beállítások",
|
||||||
|
"Default homepage: ": "Alapértelmezett honlap: ",
|
||||||
|
"Feed menu: ": "Feed menü: ",
|
||||||
|
"Top enabled: ": "Top lista engedélyezve: ",
|
||||||
|
"CAPTCHA enabled: ": "CAPTCHA engedélyezve: ",
|
||||||
|
"Login enabled: ": "Bejelentkezés engedélyezve: ",
|
||||||
|
"Registration enabled: ": "Registztráció engedélyezve: ",
|
||||||
|
"Report statistics: ": "Statisztikák gyűjtése: ",
|
||||||
|
"Save preferences": "Beállítások mentése",
|
||||||
|
"Subscription manager": "Feliratkozás kezelő",
|
||||||
|
"Token manager": "Token kezelő",
|
||||||
|
"Token": "Token",
|
||||||
|
"`x` subscriptions": "`x` feliratkozás",
|
||||||
|
"`x` tokens": "`x` token",
|
||||||
|
"Import/export": "Import/export",
|
||||||
|
"unsubscribe": "leiratkozás",
|
||||||
|
"revoke": "visszavonás",
|
||||||
|
"Subscriptions": "Feliratkozások",
|
||||||
|
"`x` unseen notifications": "`x` kimaradt érdesítés",
|
||||||
|
"search": "keresés",
|
||||||
|
"Log out": "Kijelentkezés",
|
||||||
|
"Released under the AGPLv3 by Omar Roth.": "Omar Roth által release-elve AGPLv3 licensz alatt.",
|
||||||
|
"Source available here.": "Forrás elérhető itt.",
|
||||||
|
"View JavaScript license information.": "JavaScript licensz inforkációk megtekintése.",
|
||||||
|
"View privacy policy.": "Adatvédelem irányelv megtekintése.",
|
||||||
|
"Trending": "Trending",
|
||||||
|
"Public": "Nyilvános",
|
||||||
|
"Unlisted": "Nem nyilvános",
|
||||||
|
"Private": "Privát",
|
||||||
|
"View all playlists": "Minden playlist megtekintése",
|
||||||
|
"Updated `x` ago": "Frissitve `x`",
|
||||||
|
"Delete playlist `x`?": "`x` playlist törlése?",
|
||||||
|
"Delete playlist": "Playlist törlése",
|
||||||
|
"Create playlist": "Playlist létrehozása",
|
||||||
|
"Title": "Címe",
|
||||||
|
"Playlist privacy": "Playlist láthatósága",
|
||||||
|
"Editing playlist `x`": "`x` playlist szerkesztése",
|
||||||
|
"Watch on YouTube": "Megtekintés a YouTube-on",
|
||||||
|
"Hide annotations": "Annotációk elrejtése",
|
||||||
|
"Show annotations": "Annotációk mutatása",
|
||||||
|
"Genre: ": "Zsáner: ",
|
||||||
|
"License: ": "Licensz: ",
|
||||||
|
"Family friendly? ": "Családbarát? ",
|
||||||
|
"Wilson score: ": "Wilson-ponstszém: ",
|
||||||
|
"Engagement: ": "Engagement: ",
|
||||||
|
"Whitelisted regions: ": "Engedélyezett régiók: ",
|
||||||
|
"Blacklisted regions: ": "Tiltott régiók: ",
|
||||||
|
"Shared `x`": "Megosztva `x`",
|
||||||
|
"`x` views": "`x` megtekintés",
|
||||||
|
"Premieres in `x`": "Premier `x`",
|
||||||
|
"Premieres `x`": "Premier `x`",
|
||||||
|
"Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.": "Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.",
|
||||||
|
"View YouTube comments": "YouTube kommentek megtekintése",
|
||||||
|
"View more comments on Reddit": "További Reddit kommentek megtekintése",
|
||||||
|
"View `x` comments": "`x` komment megtekintése",
|
||||||
|
"View Reddit comments": "Reddit kommentek megtekintése",
|
||||||
|
"Hide replies": "Válaszok elrejtése",
|
||||||
|
"Show replies": "Válaszok mutatása",
|
||||||
|
"Incorrect password": "Helytelen jelszó",
|
||||||
|
"Quota exceeded, try again in a few hours": "Kvóta túllépve, próbálkozz pár órával később",
|
||||||
|
"Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.": "Sikertelen belépés, győződj meg róla hogy a 2FA (Authenticator vagy SMS) engedélyezve van.",
|
||||||
|
"Login failed. This may be because two-factor authentication is not turned on for your account.": "Sikertelen belépés, győződj meg róla hogy a 2FA (Authenticator vagy SMS) engedélyezve van.",
|
||||||
|
"Wrong answer": "Rossz válasz",
|
||||||
|
"Erroneous CAPTCHA": "Hibás CAPTCHA",
|
||||||
|
"CAPTCHA is a required field": "A CAPTCHA kötelező",
|
||||||
|
"User ID is a required field": "A felhasználó-ID kötelező",
|
||||||
|
"Password is a required field": "A jelszó kötelező",
|
||||||
|
"Wrong username or password": "Rossz felhasználónév vagy jelszó",
|
||||||
|
"Please sign in using 'Log in with Google'": "Kérem, jelentkezzen be a \"Bejelentkezés Google-el\"",
|
||||||
|
"Password cannot be empty": "A jelszó nem lehet üres",
|
||||||
|
"Password cannot be longer than 55 characters": "A jelszó nem lehet hosszabb 55 betűnél",
|
||||||
|
"Please log in": "Kérem lépjen be",
|
||||||
|
"Invidious Private Feed for `x`": "`x` Invidious privát feed-je",
|
||||||
|
"channel:`x`": "`x` csatorna",
|
||||||
|
"Deleted or invalid channel": "Törölt vagy nemlétező csatorna",
|
||||||
|
"This channel does not exist.": "Ez a csatorna nem létezik.",
|
||||||
|
"Could not get channel info.": "Nem megszerezhető a csatorna információ.",
|
||||||
|
"Could not fetch comments": "Nem megszerezhetőek a kommentek",
|
||||||
|
"View `x` replies": "`x` válasz megtekintése",
|
||||||
|
"`x` ago": "`x` óta",
|
||||||
|
"Load more": "További betöltése",
|
||||||
|
"`x` points": "`x` pont",
|
||||||
|
"Could not create mix.": "Nem tudok mix-et készíteni.",
|
||||||
|
"Empty playlist": "Üres playlist",
|
||||||
|
"Not a playlist.": "Nem playlist.",
|
||||||
|
"Playlist does not exist.": "Nem létező playlist.",
|
||||||
|
"Could not pull trending pages.": "Nem tudom letölteni a trendek adatait.",
|
||||||
|
"Hidden field \"challenge\" is a required field": "A rejtett \"challenge\" mező kötelező",
|
||||||
|
"Hidden field \"token\" is a required field": "A rejtett \"token\" mező kötelező",
|
||||||
|
"Erroneous challenge": "Hibás challenge",
|
||||||
|
"Erroneous token": "Hibás token",
|
||||||
|
"No such user": "Nincs ilyen felhasználó",
|
||||||
|
"Token is expired, please try again": "Lejárt token, kérem próbáld újra",
|
||||||
|
"English": "",
|
||||||
|
"English (auto-generated)": "English (auto-genererat)",
|
||||||
|
"Afrikaans": "",
|
||||||
|
"Albanian": "",
|
||||||
|
"Amharic": "",
|
||||||
|
"Arabic": "",
|
||||||
|
"Armenian": "",
|
||||||
|
"Azerbaijani": "",
|
||||||
|
"Bangla": "",
|
||||||
|
"Basque": "",
|
||||||
|
"Belarusian": "",
|
||||||
|
"Bosnian": "",
|
||||||
|
"Bulgarian": "",
|
||||||
|
"Burmese": "",
|
||||||
|
"Catalan": "",
|
||||||
|
"Cebuano": "",
|
||||||
|
"Chinese (Simplified)": "",
|
||||||
|
"Chinese (Traditional)": "",
|
||||||
|
"Corsican": "",
|
||||||
|
"Croatian": "",
|
||||||
|
"Czech": "",
|
||||||
|
"Danish": "",
|
||||||
|
"Dutch": "",
|
||||||
|
"Esperanto": "",
|
||||||
|
"Estonian": "",
|
||||||
|
"Filipino": "",
|
||||||
|
"Finnish": "",
|
||||||
|
"French": "",
|
||||||
|
"Galician": "",
|
||||||
|
"Georgian": "",
|
||||||
|
"German": "",
|
||||||
|
"Greek": "",
|
||||||
|
"Gujarati": "",
|
||||||
|
"Haitian Creole": "",
|
||||||
|
"Hausa": "",
|
||||||
|
"Hawaiian": "",
|
||||||
|
"Hebrew": "",
|
||||||
|
"Hindi": "",
|
||||||
|
"Hmong": "",
|
||||||
|
"Hungarian": "",
|
||||||
|
"Icelandic": "",
|
||||||
|
"Igbo": "",
|
||||||
|
"Indonesian": "",
|
||||||
|
"Irish": "",
|
||||||
|
"Italian": "",
|
||||||
|
"Japanese": "",
|
||||||
|
"Javanese": "",
|
||||||
|
"Kannada": "",
|
||||||
|
"Kazakh": "",
|
||||||
|
"Khmer": "",
|
||||||
|
"Korean": "",
|
||||||
|
"Kurdish": "",
|
||||||
|
"Kyrgyz": "",
|
||||||
|
"Lao": "",
|
||||||
|
"Latin": "",
|
||||||
|
"Latvian": "",
|
||||||
|
"Lithuanian": "",
|
||||||
|
"Luxembourgish": "",
|
||||||
|
"Macedonian": "",
|
||||||
|
"Malagasy": "",
|
||||||
|
"Malay": "",
|
||||||
|
"Malayalam": "",
|
||||||
|
"Maltese": "",
|
||||||
|
"Maori": "",
|
||||||
|
"Marathi": "",
|
||||||
|
"Mongolian": "",
|
||||||
|
"Nepali": "",
|
||||||
|
"Norwegian Bokmål": "",
|
||||||
|
"Nyanja": "",
|
||||||
|
"Pashto": "",
|
||||||
|
"Persian": "",
|
||||||
|
"Polish": "",
|
||||||
|
"Portuguese": "",
|
||||||
|
"Punjabi": "",
|
||||||
|
"Romanian": "",
|
||||||
|
"Russian": "",
|
||||||
|
"Samoan": "",
|
||||||
|
"Scottish Gaelic": "",
|
||||||
|
"Serbian": "",
|
||||||
|
"Shona": "",
|
||||||
|
"Sindhi": "",
|
||||||
|
"Sinhala": "",
|
||||||
|
"Slovak": "",
|
||||||
|
"Slovenian": "",
|
||||||
|
"Somali": "",
|
||||||
|
"Southern Sotho": "",
|
||||||
|
"Spanish": "",
|
||||||
|
"Spanish (Latin America)": "",
|
||||||
|
"Sundanese": "",
|
||||||
|
"Swahili": "",
|
||||||
|
"Swedish": "",
|
||||||
|
"Tajik": "",
|
||||||
|
"Tamil": "",
|
||||||
|
"Telugu": "",
|
||||||
|
"Thai": "",
|
||||||
|
"Turkish": "",
|
||||||
|
"Ukrainian": "",
|
||||||
|
"Urdu": "",
|
||||||
|
"Uzbek": "",
|
||||||
|
"Vietnamese": "",
|
||||||
|
"Welsh": "",
|
||||||
|
"Western Frisian": "",
|
||||||
|
"Xhosa": "",
|
||||||
|
"Yiddish": "",
|
||||||
|
"Yoruba": "",
|
||||||
|
"Zulu": "",
|
||||||
|
"`x` years": "`x` év",
|
||||||
|
"`x` months": "`x` hónap",
|
||||||
|
"`x` weeks": "`x` hét",
|
||||||
|
"`x` days": "`x` nap",
|
||||||
|
"`x` hours": "`x` óra",
|
||||||
|
"`x` minutes": "`x` perc",
|
||||||
|
"`x` seconds": "`x` másodperc",
|
||||||
|
"Fallback comments: ": "Másodlagos kommentek: ",
|
||||||
|
"Popular": "Népszerű",
|
||||||
|
"Top": "Top",
|
||||||
|
"About": "Leírás",
|
||||||
|
"Rating: ": "Besorolás: ",
|
||||||
|
"Language: ": "Nyelv: ",
|
||||||
|
"View as playlist": "Megtekintés playlist-ként",
|
||||||
|
"Default": "Alapértelmezett",
|
||||||
|
"Music": "Zene",
|
||||||
|
"Gaming": "Játékok",
|
||||||
|
"News": "Hírek",
|
||||||
|
"Movies": "Filmek",
|
||||||
|
"Download": "Letöltés",
|
||||||
|
"Download as: ": "Letöltés mint: ",
|
||||||
|
"%A %B %-d, %Y": "",
|
||||||
|
"(edited)": "(szerkesztve)",
|
||||||
|
"YouTube comment permalink": "YouTube komment permalink",
|
||||||
|
"permalink": "permalink",
|
||||||
|
"`x` marked it with a ❤": "`x` jelölte ❤-vel",
|
||||||
|
"Audio mode": "Audio mód",
|
||||||
|
"Video mode": "Video mód",
|
||||||
|
"Videos": "Videók",
|
||||||
|
"Playlists": "Playlistek",
|
||||||
|
"Community": "Közösség",
|
||||||
|
"Current version: ": "Jelenlegi verzió: "
|
||||||
|
}
|
||||||
351
locales/is.json
Normal file
351
locales/is.json
Normal file
@@ -0,0 +1,351 @@
|
|||||||
|
{
|
||||||
|
"`x` subscribers": "",
|
||||||
|
"`x` videos": "",
|
||||||
|
"`x` playlists": "",
|
||||||
|
"`x` subscribers.": "`x` áskrifandar.",
|
||||||
|
"`x` videos.": "`x` myndbönd.",
|
||||||
|
"LIVE": "BEINT",
|
||||||
|
"Shared `x` ago": "Deilt `x` síðan",
|
||||||
|
"Unsubscribe": "Afskrá",
|
||||||
|
"Subscribe": "Áskrifa",
|
||||||
|
"View channel on YouTube": "Skoða rás á YouTube",
|
||||||
|
"View playlist on YouTube": "Skoða spilunarlisti á YouTube",
|
||||||
|
"newest": "nýjasta",
|
||||||
|
"oldest": "elsta",
|
||||||
|
"popular": "vinsælt",
|
||||||
|
"last": "síðast",
|
||||||
|
"Next page": "Næsta síða",
|
||||||
|
"Previous page": "Fyrri síða",
|
||||||
|
"Clear watch history?": "Hreinsa áhorfssögu?",
|
||||||
|
"New password": "Nýtt lykilorð",
|
||||||
|
"New passwords must match": "Nýtt lykilorð verður að passa",
|
||||||
|
"Cannot change password for Google accounts": "Ekki er hægt að breyta lykilorði fyrir Google reikninga",
|
||||||
|
"Authorize token?": "Leyfa tákn?",
|
||||||
|
"Authorize token for `x`?": "Leyfa tákn fyrir `x`?",
|
||||||
|
"Yes": "Já",
|
||||||
|
"No": "Nei",
|
||||||
|
"Import and Export Data": "Innflutningur og Útflutningur Gagna",
|
||||||
|
"Import": "Flytja inn",
|
||||||
|
"Import Invidious data": "Flytja inn Invidious gögn",
|
||||||
|
"Import YouTube subscriptions": "Flytja inn YouTube áskriftir",
|
||||||
|
"Import FreeTube subscriptions (.db)": "Flytja inn FreeTube áskriftir (.db)",
|
||||||
|
"Import NewPipe subscriptions (.json)": "Flytja inn NewPipe áskriftir (.json)",
|
||||||
|
"Import NewPipe data (.zip)": "Flytja inn NewPipe gögn (.zip)",
|
||||||
|
"Export": "Flytja út",
|
||||||
|
"Export subscriptions as OPML": "Flytja út áskriftir sem OPML",
|
||||||
|
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Flytja út áskriftir sem OPML (fyrir NewPipe & FreeTube)",
|
||||||
|
"Export data as JSON": "Flytja út gögn sem JSON",
|
||||||
|
"Delete account?": "Eyða reikningi?",
|
||||||
|
"History": "Saga",
|
||||||
|
"An alternative front-end to YouTube": "Önnur framhlið fyrir YouTube",
|
||||||
|
"JavaScript license information": "JavaScript leyfi upplýsingar",
|
||||||
|
"source": "uppspretta",
|
||||||
|
"Log in": "Skrá inn",
|
||||||
|
"Log in/register": "Innskráning/nýskráning",
|
||||||
|
"Log in with Google": "Skrá inn með Google",
|
||||||
|
"User ID": "Notandakenni",
|
||||||
|
"Password": "Lykilorð",
|
||||||
|
"Time (h:mm:ss):": "Tími (h:mm: ss):",
|
||||||
|
"Text CAPTCHA": "Texta CAPTCHA",
|
||||||
|
"Image CAPTCHA": "Mynd CAPTCHA",
|
||||||
|
"Sign In": "Skrá inn",
|
||||||
|
"Register": "Nýskrá",
|
||||||
|
"E-mail": "Tölvupóstur",
|
||||||
|
"Google verification code": "Google staðfestingarkóði",
|
||||||
|
"Preferences": "Kjörstillingar",
|
||||||
|
"Player preferences": "Kjörstillingar spilara",
|
||||||
|
"Always loop: ": "Alltaf lykkja: ",
|
||||||
|
"Autoplay: ": "Spila sjálfkrafa: ",
|
||||||
|
"Play next by default: ": "Spila næst sjálfgefið: ",
|
||||||
|
"Autoplay next video: ": "Spila næst sjálfkrafa: ",
|
||||||
|
"Listen by default: ": "Hlusta sjálfgefið: ",
|
||||||
|
"Proxy videos: ": "Proxy myndbönd? ",
|
||||||
|
"Default speed: ": "Sjálfgefinn hraði: ",
|
||||||
|
"Preferred video quality: ": "Æskilegt myndbands gæði: ",
|
||||||
|
"Player volume: ": "Spilara hljóðstyrkur: ",
|
||||||
|
"Default comments: ": "Sjálfgefin ummæli: ",
|
||||||
|
"youtube": "youtube",
|
||||||
|
"reddit": "reddit",
|
||||||
|
"Default captions: ": "Sjálfgefin texti: ",
|
||||||
|
"Fallback captions: ": "Varatextar: ",
|
||||||
|
"Show related videos: ": "Sýna tengd myndbönd? ",
|
||||||
|
"Show annotations by default: ": "Á að sýna glósur sjálfgefið? ",
|
||||||
|
"Visual preferences": "Sjónrænar stillingar",
|
||||||
|
"Player style: ": "",
|
||||||
|
"Dark mode: ": "Myrkur ham: ",
|
||||||
|
"Theme: ": "",
|
||||||
|
"dark": "",
|
||||||
|
"light": "",
|
||||||
|
"Thin mode: ": "Þunnt ham: ",
|
||||||
|
"Subscription preferences": "Áskriftarstillingar",
|
||||||
|
"Show annotations by default for subscribed channels: ": "Á að sýna glósur sjálfgefið fyrir áskriftarrásir? ",
|
||||||
|
"Redirect homepage to feed: ": "Endurbeina heimasíðu að straumi: ",
|
||||||
|
"Number of videos shown in feed: ": "Fjöldi myndbanda sem sýndir eru í straumi: ",
|
||||||
|
"Sort videos by: ": "Raða myndbönd eftir: ",
|
||||||
|
"published": "birt",
|
||||||
|
"published - reverse": "birt - afturábak",
|
||||||
|
"alphabetically": "í stafrófsröð",
|
||||||
|
"alphabetically - reverse": "stafrófsröð - afturábak",
|
||||||
|
"channel name": "heiti rásar",
|
||||||
|
"channel name - reverse": "heiti rásar - afturábak",
|
||||||
|
"Only show latest video from channel: ": "Sýna aðeins nýjasta myndband frá rás: ",
|
||||||
|
"Only show latest unwatched video from channel: ": "Sýna aðeins nýjasta óséð myndband frá rás: ",
|
||||||
|
"Only show unwatched: ": "Sýna aðeins óséð: ",
|
||||||
|
"Only show notifications (if there are any): ": "Sýna aðeins tilkynningar (ef einhverjar eru): ",
|
||||||
|
"Enable web notifications": "Virkja veftilkynningar",
|
||||||
|
"`x` uploaded a video": "`x` hlóð upp myndband",
|
||||||
|
"`x` is live": "`x` er í beinni",
|
||||||
|
"Data preferences": "Gagnastillingar",
|
||||||
|
"Clear watch history": "Hreinsa áhorfssögu",
|
||||||
|
"Import/export data": "Flytja inn/út gögn",
|
||||||
|
"Change password": "Breyta lykilorði",
|
||||||
|
"Manage subscriptions": "Stjórna áskriftum",
|
||||||
|
"Manage tokens": "Stjórna tákn",
|
||||||
|
"Watch history": "Áhorfssögu",
|
||||||
|
"Delete account": "Eyða reikningi",
|
||||||
|
"Administrator preferences": "Kjörstillingar stjórnanda",
|
||||||
|
"Default homepage: ": "Sjálfgefin heimasíða: ",
|
||||||
|
"Feed menu: ": "Straum valmynd: ",
|
||||||
|
"Top enabled: ": "Toppur virkur? ",
|
||||||
|
"CAPTCHA enabled: ": "CAPTCHA virk? ",
|
||||||
|
"Login enabled: ": "Innskráning virk? ",
|
||||||
|
"Registration enabled: ": "Nýskráning virkjuð? ",
|
||||||
|
"Report statistics: ": "Skrá talnagögn? ",
|
||||||
|
"Save preferences": "Vista stillingar",
|
||||||
|
"Subscription manager": "Áskriftarstjóri",
|
||||||
|
"`x` subscriptions": "",
|
||||||
|
"`x` tokens": "",
|
||||||
|
"Token manager": "Táknstjóri",
|
||||||
|
"Token": "Tákn",
|
||||||
|
"`x` subscriptions.": "`x` áskriftir.",
|
||||||
|
"`x` tokens.": "`x` tákn.",
|
||||||
|
"`x` unseen notifications": "",
|
||||||
|
"Import/export": "Flytja inn/út",
|
||||||
|
"unsubscribe": "afskrá",
|
||||||
|
"revoke": "afturkalla",
|
||||||
|
"Subscriptions": "Áskriftir",
|
||||||
|
"`x` unseen notifications.": "`x` óséðar tilkynningar.",
|
||||||
|
"search": "leita",
|
||||||
|
"Log out": "Útskrá",
|
||||||
|
"Released under the AGPLv3 by Omar Roth.": "Útgefið undir AGPLv3 eftir Omar Roth.",
|
||||||
|
"Source available here.": "Frumkóði aðgengilegur hér.",
|
||||||
|
"View JavaScript license information.": "Skoða JavaScript leyfisupplýsingar.",
|
||||||
|
"View privacy policy.": "Skoða meðferð persónuupplýsinga.",
|
||||||
|
"Trending": "Vinsælt",
|
||||||
|
"Public": "",
|
||||||
|
"Unlisted": "Óskráð",
|
||||||
|
"Private": "",
|
||||||
|
"View all playlists": "",
|
||||||
|
"Updated `x` ago": "",
|
||||||
|
"Delete playlist `x`?": "",
|
||||||
|
"Delete playlist": "",
|
||||||
|
"Create playlist": "",
|
||||||
|
"Title": "",
|
||||||
|
"Playlist privacy": "",
|
||||||
|
"Editing playlist `x`": "",
|
||||||
|
"Watch on YouTube": "Horfa á YouTube",
|
||||||
|
"Hide annotations": "Fela glósur",
|
||||||
|
"Show annotations": "Sýna glósur",
|
||||||
|
"Genre: ": "Tegund: ",
|
||||||
|
"License: ": "Notkunarleyfi: ",
|
||||||
|
"Family friendly? ": "Fjölskylduvænt? ",
|
||||||
|
"`x` views": "",
|
||||||
|
"Wilson score: ": "Wilson stig: ",
|
||||||
|
"Engagement: ": "Þátttöku: ",
|
||||||
|
"Whitelisted regions: ": "Svæði á hvítum lista: ",
|
||||||
|
"Blacklisted regions: ": "Svæði á svörtum lista: ",
|
||||||
|
"Shared `x`": "Deilt `x`",
|
||||||
|
"`x` views.": "`x` áhorf.",
|
||||||
|
"Premieres in `x`": "Frumflutt eftir `x`",
|
||||||
|
"Premieres `x`": "Frumflutt `x`",
|
||||||
|
"Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.": "Hæ! Lítur út eins og þú hafir slökkt á JavaScript. Smelltu hér til að skoða ummæli, hafðu í huga að þær geta tekið aðeins lengri tíma að hlaða.",
|
||||||
|
"View YouTube comments": "Skoða YouTube ummæli",
|
||||||
|
"View more comments on Reddit": "Skoða fleiri ummæli á Reddit",
|
||||||
|
"View `x` comments": "Skoða `x` ummæli",
|
||||||
|
"View Reddit comments": "Skoða Reddit ummæli",
|
||||||
|
"Hide replies": "Fela svör",
|
||||||
|
"Show replies": "Sýna svör",
|
||||||
|
"Incorrect password": "Rangt lykilorð",
|
||||||
|
"Quota exceeded, try again in a few hours": "Kvóti fór yfir, reyndu aftur eftir nokkrar klukkustundir",
|
||||||
|
"Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.": "Ekki er hægt að skrá þig inn, vertu viss um að tvíþætt staðfesting (Authenticator eða SMS) sé kveikt á.",
|
||||||
|
"Invalid TFA code": "Ógildur TFA kóði",
|
||||||
|
"Login failed. This may be because two-factor authentication is not turned on for your account.": "Innskráning mistókst. Þetta gæti verið vegna þess að tvíþátta staðfesting er ekki kveikt á reikningnum þínum.",
|
||||||
|
"Wrong answer": "Rangt svar",
|
||||||
|
"Erroneous CAPTCHA": "Rangt CAPTCHA",
|
||||||
|
"CAPTCHA is a required field": "CAPTCHA er nauðsynlegur reitur",
|
||||||
|
"User ID is a required field": "Notandakenni er nauðsynlegur reitur",
|
||||||
|
"Password is a required field": "Lykilorð er nauðsynlegur reitur",
|
||||||
|
"Wrong username or password": "Rangt notandanafn eða lykilorð",
|
||||||
|
"Please sign in using 'Log in with Google'": "Vinsamlegast skráðu þig inn með því að nota 'Innskráning með Google'",
|
||||||
|
"Password cannot be empty": "Lykilorð má ekki vera autt",
|
||||||
|
"Password cannot be longer than 55 characters": "Lykilorð má ekki vera lengra en 55 stafir",
|
||||||
|
"Please log in": "Vinsamlegast skráðu þig inn",
|
||||||
|
"View `x` replies": "",
|
||||||
|
"Invidious Private Feed for `x`": "Invidious Persónulegur Straumur fyrir `x`",
|
||||||
|
"channel:`x`": "rás:`x`",
|
||||||
|
"`x` points": "",
|
||||||
|
"Deleted or invalid channel": "Eytt eða ógild rás",
|
||||||
|
"This channel does not exist.": "Þessi rás er ekki til.",
|
||||||
|
"Could not get channel info.": "Ekki tókst að fá rásarupplýsingar.",
|
||||||
|
"Could not fetch comments": "Ekki tókst að sækja ummæli",
|
||||||
|
"View `x` replies.": "Skoða `x` svör.",
|
||||||
|
"`x` ago": "`x` síðan",
|
||||||
|
"Load more": "Hlaða meira",
|
||||||
|
"`x` points.": "`x` stig.",
|
||||||
|
"Could not create mix.": "Ekki tókst að búa til blöndu.",
|
||||||
|
"Empty playlist": "Tómur spilunarlisti",
|
||||||
|
"Not a playlist.": "Ekki spilunarlisti.",
|
||||||
|
"Playlist does not exist.": "Spilunarlisti er ekki til.",
|
||||||
|
"Could not pull trending pages.": "Ekki tókst að draga vinsælar síður.",
|
||||||
|
"Hidden field \"challenge\" is a required field": "Falinn reitur \"áskorun\" er nauðsynlegur reitur",
|
||||||
|
"Hidden field \"token\" is a required field": "Falinn reitur \"tákn\" er nauðsynlegur reitur",
|
||||||
|
"Erroneous challenge": "Röng áskorun",
|
||||||
|
"Erroneous token": "Rangt tákn",
|
||||||
|
"No such user": "Enginn slíkur notandi",
|
||||||
|
"Token is expired, please try again": "Tákn er útrunnið, vinsamlegast reyndu aftur",
|
||||||
|
"English": "Enska",
|
||||||
|
"English (auto-generated)": "Enska (sjálfkrafa)",
|
||||||
|
"Afrikaans": "Afríkanska",
|
||||||
|
"Albanian": "Albanska",
|
||||||
|
"Amharic": "Amharíska",
|
||||||
|
"Arabic": "Arabíska",
|
||||||
|
"Armenian": "Armenska",
|
||||||
|
"Azerbaijani": "Aserbaídsjanska",
|
||||||
|
"Bangla": "Bangla",
|
||||||
|
"Basque": "Baskneska",
|
||||||
|
"Belarusian": "Hvítrússneska",
|
||||||
|
"Bosnian": "Bosníska",
|
||||||
|
"Bulgarian": "Búlgarska",
|
||||||
|
"Burmese": "Búrmíska",
|
||||||
|
"Catalan": "Katalónska",
|
||||||
|
"Cebuano": "Cebúanó",
|
||||||
|
"Chinese (Simplified)": "Kínverska (Einfölduð)",
|
||||||
|
"Chinese (Traditional)": "Kínverska (Hefðbundin)",
|
||||||
|
"Corsican": "Korsíska",
|
||||||
|
"Croatian": "Króatíska",
|
||||||
|
"Czech": "Tékkneska",
|
||||||
|
"Danish": "Danska",
|
||||||
|
"Dutch": "Hollenska",
|
||||||
|
"Esperanto": "Esperantó",
|
||||||
|
"Estonian": "Eistneska",
|
||||||
|
"Filipino": "Filippínska",
|
||||||
|
"Finnish": "Finnska",
|
||||||
|
"French": "Franska",
|
||||||
|
"Galician": "Galisíska",
|
||||||
|
"Georgian": "Georgíska",
|
||||||
|
"German": "Þýska",
|
||||||
|
"Greek": "Gríska",
|
||||||
|
"Gujarati": "Gújaratí",
|
||||||
|
"Haitian Creole": "Haítískt Kreólamál",
|
||||||
|
"Hausa": "Hausa",
|
||||||
|
"Hawaiian": "Havaíska",
|
||||||
|
"Hebrew": "Hebreska",
|
||||||
|
"Hindi": "Hindí",
|
||||||
|
"Hmong": "Hmong",
|
||||||
|
"Hungarian": "Ungverska",
|
||||||
|
"Icelandic": "Íslenska",
|
||||||
|
"Igbo": "Igbo",
|
||||||
|
"Indonesian": "Indónesíska",
|
||||||
|
"Irish": "Írska",
|
||||||
|
"Italian": "Ítalska",
|
||||||
|
"Japanese": "Japanska",
|
||||||
|
"Javanese": "Javanska",
|
||||||
|
"Kannada": "Kanaríska",
|
||||||
|
"Kazakh": "Kasakíska",
|
||||||
|
"Khmer": "Khmeríska",
|
||||||
|
"Korean": "Kóreska",
|
||||||
|
"Kurdish": "Kúrdíska",
|
||||||
|
"Kyrgyz": "Kirgisíska",
|
||||||
|
"Lao": "Laó",
|
||||||
|
"Latin": "Latína",
|
||||||
|
"Latvian": "Lettneska",
|
||||||
|
"Lithuanian": "Litháíska",
|
||||||
|
"Luxembourgish": "Lúxemborgíska",
|
||||||
|
"Macedonian": "Makedóníska",
|
||||||
|
"Malagasy": "Malagasíska",
|
||||||
|
"Malay": "Malaíska",
|
||||||
|
"Malayalam": "Malaíalam",
|
||||||
|
"Maltese": "Maltneska",
|
||||||
|
"Maori": "Maórí",
|
||||||
|
"Marathi": "Marathi",
|
||||||
|
"Mongolian": "Mongólska",
|
||||||
|
"Nepali": "Nepalska",
|
||||||
|
"Norwegian Bokmål": "Norskt bókmál",
|
||||||
|
"Nyanja": "Nyanja",
|
||||||
|
"Pashto": "Pashto",
|
||||||
|
"Persian": "Persneska",
|
||||||
|
"Polish": "Pólska",
|
||||||
|
"Portuguese": "Portúgalska",
|
||||||
|
"Punjabi": "Punjabi",
|
||||||
|
"Romanian": "Rúmenska",
|
||||||
|
"Russian": "Rússneska",
|
||||||
|
"Samoan": "Samóíska",
|
||||||
|
"Scottish Gaelic": "Skosk Gelíska",
|
||||||
|
"Serbian": "Serbneska",
|
||||||
|
"Shona": "Shona",
|
||||||
|
"Sindhi": "Sindí",
|
||||||
|
"Sinhala": "Sinhala",
|
||||||
|
"Slovak": "Slóvakíska",
|
||||||
|
"Slovenian": "Slóvenska",
|
||||||
|
"Somali": "Sómalska",
|
||||||
|
"Southern Sotho": "Suður Sótó",
|
||||||
|
"Spanish": "Spænska",
|
||||||
|
"Spanish (Latin America)": "Spænska (Rómönsku Ameríka)",
|
||||||
|
"Sundanese": "Sundaneska",
|
||||||
|
"Swahili": "Svahílí",
|
||||||
|
"Swedish": "Sænska",
|
||||||
|
"Tajik": "Tadsikíska",
|
||||||
|
"Tamil": "Tamílska",
|
||||||
|
"Telugu": "Telúgú",
|
||||||
|
"Thai": "Taílenska",
|
||||||
|
"Turkish": "Tyrkneska",
|
||||||
|
"Ukrainian": "Úkraníska",
|
||||||
|
"Urdu": "Úrdú",
|
||||||
|
"`x` years": "",
|
||||||
|
"`x` months": "",
|
||||||
|
"`x` weeks": "",
|
||||||
|
"`x` days": "",
|
||||||
|
"`x` hours": "",
|
||||||
|
"`x` minutes": "",
|
||||||
|
"`x` seconds": "",
|
||||||
|
"Uzbek": "Úsbekíska",
|
||||||
|
"Vietnamese": "Víetnamska",
|
||||||
|
"Welsh": "Velska",
|
||||||
|
"Western Frisian": "Vestur Frísneska",
|
||||||
|
"Xhosa": "Xhosa",
|
||||||
|
"Yiddish": "Jiddíska",
|
||||||
|
"Yoruba": "Jórúba",
|
||||||
|
"Zulu": "Zúlú",
|
||||||
|
"`x` years.": "`x` ár.",
|
||||||
|
"`x` months.": "`x` mánuði.",
|
||||||
|
"`x` weeks.": "`x` vikur.",
|
||||||
|
"`x` days.": "`x` dagar.",
|
||||||
|
"`x` hours.": "`x` klukkustundir.",
|
||||||
|
"`x` minutes.": "`x` mínútur.",
|
||||||
|
"`x` seconds.": "`x` sekúndur.",
|
||||||
|
"Fallback comments: ": "Vara ummæli: ",
|
||||||
|
"Popular": "Vinsælt",
|
||||||
|
"permalink": "",
|
||||||
|
"Top": "Topp",
|
||||||
|
"About": "Um",
|
||||||
|
"Rating: ": "Einkunn: ",
|
||||||
|
"Language: ": "Tungumál: ",
|
||||||
|
"View as playlist": "Skoða sem spilunarlista",
|
||||||
|
"Community": "",
|
||||||
|
"Default": "Sjálfgefið",
|
||||||
|
"Music": "Tónlist",
|
||||||
|
"Gaming": "Tólvuleikja",
|
||||||
|
"News": "Fréttir",
|
||||||
|
"Movies": "Kvikmyndir",
|
||||||
|
"Download": "Niðurhal",
|
||||||
|
"Download as: ": "Niðurhala sem: ",
|
||||||
|
"%A %B %-d, %Y": "%A %B %-d, %Y",
|
||||||
|
"(edited)": "(breytt)",
|
||||||
|
"YouTube comment permalink": "YouTube ummæli varanlegur tengill",
|
||||||
|
"`x` marked it with a ❤": "`x` merkti það með ❤",
|
||||||
|
"Audio mode": "Hljóð ham",
|
||||||
|
"Video mode": "Myndband ham",
|
||||||
|
"Videos": "Myndbönd",
|
||||||
|
"Playlists": "Spilunarlistar",
|
||||||
|
"Current version: ": "Núverandi útgáfa: "
|
||||||
|
}
|
||||||
666
locales/it.json
666
locales/it.json
@@ -1,287 +1,381 @@
|
|||||||
{
|
{
|
||||||
"`x` subscribers": "`x` iscritti",
|
"`x` subscribers.": {
|
||||||
"`x` videos": "`x` video",
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` iscritto",
|
||||||
"LIVE": "IN DIRETTA",
|
"": "`x` iscritti."
|
||||||
"Shared `x` ago": "Condiviso `x` fa",
|
},
|
||||||
"Unsubscribe": "Disiscriviti",
|
"`x` videos.": {
|
||||||
"Subscribe": "Iscriviti",
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` video",
|
||||||
"Login to subscribe to `x`": "Accedi per iscriverti a `x`",
|
"": "`x` video."
|
||||||
"View channel on YouTube": "Vedi canale su YouTube",
|
},
|
||||||
"newest": "Data di aggiunta (più recente)",
|
"`x` playlists": "`x` playlist",
|
||||||
"oldest": "Data di aggiunta (più vecchia)",
|
"LIVE": "IN DIRETTA",
|
||||||
"popular": "Tendenze",
|
"Shared `x` ago": "Condiviso `x` fa",
|
||||||
"Next page": "Pagina successiva",
|
"Unsubscribe": "Disiscriviti",
|
||||||
"Clear watch history?": "Sei sicuro di voler cancellare la cronologia dei video guardati?",
|
"Subscribe": "Iscriviti",
|
||||||
"Yes": "Si",
|
"View channel on YouTube": "Vedi canale su YouTube",
|
||||||
"No": "No",
|
"View playlist on YouTube": "Vedi playlist su YouTube",
|
||||||
"Import and Export Data": "Importazione ed esportazione dati",
|
"newest": "più recente",
|
||||||
"Import": "Importa",
|
"oldest": "più vecchio",
|
||||||
"Import Invidious data": "Importa dati Invidious",
|
"popular": "Tendenze",
|
||||||
"Import YouTube subscriptions": "Importa le iscrizioni da YouTube",
|
"last": "durare",
|
||||||
"Import FreeTube subscriptions (.db)": "Importa le iscrizioni da FreeTube (.db)",
|
"Next page": "Pagina successiva",
|
||||||
"Import NewPipe subscriptions (.json)": "Importa le iscrizioni da NewPipe (.json)",
|
"Previous page": "Pagina precedente",
|
||||||
"Import NewPipe data (.zip)": "Importa i dati di NewPipe (.zip)",
|
"Clear watch history?": "Eliminare la cronologia dei video guardati?",
|
||||||
"Export": "Esporta",
|
"New password": "Nuova password",
|
||||||
"Export subscriptions as OPML": "Esporta gli abbonamenti come OPML",
|
"New passwords must match": "Le nuove password devono corrispondere",
|
||||||
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Esporta gli abbonamenti come OPML (per NewPipe e FreeTube)",
|
"Cannot change password for Google accounts": "Non è possibile modificare la password per gli account Google",
|
||||||
"Export data as JSON": "Esporta i dati in formato JSON",
|
"Authorize token?": "Autorizzare gettone?",
|
||||||
"Delete account?": "Sei sicuro di voler cancellare l'account?",
|
"Authorize token for `x`?": "Autorizzare gettone per `x`?",
|
||||||
"History": "Cronologia",
|
"Yes": "Sì",
|
||||||
"Previous page": "Pagina precedente",
|
"No": "No",
|
||||||
"An alternative front-end to YouTube": "Un'interfaccia alternativa per YouTube",
|
"Import and Export Data": "Importazione ed esportazione dati",
|
||||||
"JavaScript license information": "Info licenze JavaScript",
|
"Import": "Importa",
|
||||||
"source": "sorgente",
|
"Import Invidious data": "Importa dati Invidious",
|
||||||
"Login": "Entra",
|
"Import YouTube subscriptions": "Importa le iscrizioni da YouTube",
|
||||||
"Login/Register": "Entra/Registrati",
|
"Import FreeTube subscriptions (.db)": "Importa le iscrizioni da FreeTube (.db)",
|
||||||
"Login to Google": "Entra con Google",
|
"Import NewPipe subscriptions (.json)": "Importa le iscrizioni da NewPipe (.json)",
|
||||||
"User ID:": "ID utente:",
|
"Import NewPipe data (.zip)": "Importa i dati di NewPipe (.zip)",
|
||||||
"Password:": "Password:",
|
"Export": "Esporta",
|
||||||
"Time (h:mm:ss):": "Orario (h:mm:ss):",
|
"Export subscriptions as OPML": "Esporta gli abbonamenti come OPML",
|
||||||
"Text CAPTCHA": "Testo del CAPTCHA",
|
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Esporta gli abbonamenti come OPML (per NewPipe e FreeTube)",
|
||||||
"Image CAPTCHA": "Immagine CAPTCHA",
|
"Export data as JSON": "Esporta i dati in formato JSON",
|
||||||
"Sign In": "Entra",
|
"Delete account?": "Eliminare l'account?",
|
||||||
"Register": "Registrati",
|
"History": "Cronologia",
|
||||||
"Email:": "Email:",
|
"An alternative front-end to YouTube": "Un'interfaccia alternativa per YouTube",
|
||||||
"Google verification code:": "Codice di verifica Google:",
|
"JavaScript license information": "Info licenze JavaScript",
|
||||||
"Preferences": "Preferenze",
|
"source": "sorgente",
|
||||||
"Player preferences": "Preferenze del riproduttore",
|
"Log in": "Accedi",
|
||||||
"Always loop: ": "Ripeti sempre: ",
|
"Log in/register": "Accedi/Registrati",
|
||||||
"Autoplay: ": "Riproduzione automatica: ",
|
"Log in with Google": "Accedi con Google",
|
||||||
"Autoplay next video: ": "Riproduci automaticamente il prossimo video: ",
|
"User ID": "ID utente",
|
||||||
"Listen by default: ": "Modalità solo audio come predefinita: ",
|
"Password": "Password",
|
||||||
"Default speed: ": "Velocità di riproduzione predefinita: ",
|
"Time (h:mm:ss):": "Orario (h:mm:ss):",
|
||||||
"Preferred video quality: ": "Preferenza sulla qualità video: ",
|
"Text CAPTCHA": "Testo del CAPTCHA",
|
||||||
"Player volume: ": "Volume di riproduzione: ",
|
"Image CAPTCHA": "Immagine CAPTCHA",
|
||||||
"Default comments: ": "Origine dei commenti: ",
|
"Sign In": "Accedi",
|
||||||
"Default captions: ": "Sottotitoli predefiniti: ",
|
"Register": "Registrati",
|
||||||
"Fallback captions: ": "Sottotitoli alternativi: ",
|
"E-mail": "Email",
|
||||||
"Show related videos? ": "Mostra video correlati? ",
|
"Google verification code": "Codice di verifica Google",
|
||||||
"Visual preferences": "Preferenze grafiche",
|
"Preferences": "Preferenze",
|
||||||
"Dark mode: ": "Tema scuro: ",
|
"Player preferences": "Preferenze del riproduttore",
|
||||||
"Thin mode: ": "Modalità per connessioni lente: ",
|
"Always loop: ": "Ripeti sempre: ",
|
||||||
"Subscription preferences": "Preferenze iscrizioni",
|
"Autoplay: ": "Riproduzione automatica: ",
|
||||||
"Redirect homepage to feed: ": "Reindirizza la pagina principale a quella delle iscrizioni: ",
|
"Play next by default: ": "Riproduzione successiva predefinita: ",
|
||||||
"Number of videos shown in feed: ": "Numero di video da mostrare nelle iscrizioni: ",
|
"Autoplay next video: ": "Riproduci automaticamente il video successivo: ",
|
||||||
"Sort videos by: ": "Ordinare i video per: ",
|
"Listen by default: ": "Modalità solo audio predefinita: ",
|
||||||
"published": "data di pubblicazione",
|
"Proxy videos: ": "Proxy per i video: ",
|
||||||
"published - reverse": "data di pubblicazione - decrescente",
|
"Default speed: ": "Velocità predefinita: ",
|
||||||
"alphabetically": "ordine alfabetico",
|
"Preferred video quality: ": "Qualità video preferita: ",
|
||||||
"alphabetically - reverse": "ordine alfabetico - decrescente",
|
"Player volume: ": "Volume di riproduzione: ",
|
||||||
"channel name": "nome del canale",
|
"Default comments: ": "Origine dei commenti: ",
|
||||||
"channel name - reverse": "nome del canale - decrescente",
|
"youtube": "YouTube",
|
||||||
"Only show latest video from channel: ": "Mostra solo il video più recente del canale: ",
|
"reddit": "Reddit",
|
||||||
"Only show latest unwatched video from channel: ": "Mostra solo il video più recente non guardato del canale: ",
|
"Default captions: ": "Sottotitoli predefiniti: ",
|
||||||
"Only show unwatched: ": "Mostra solo i video non guardati: ",
|
"Fallback captions: ": "Sottotitoli alternativi: ",
|
||||||
"Only show notifications (if there are any): ": "Mostra solo le notifiche (se presenti): ",
|
"Show related videos: ": "Mostra video correlati: ",
|
||||||
"Data preferences": "Preferenze dati",
|
"Show annotations by default: ": "Mostra le annotazioni in modo predefinito: ",
|
||||||
"Clear watch history": "Cancella la cronologia dei video guardati",
|
"Visual preferences": "Preferenze grafiche",
|
||||||
"Import/Export data": "Importazione/esportazione dati",
|
"Player style: ": "Stile riproduttore: ",
|
||||||
"Manage subscriptions": "Gestisci le iscrizioni",
|
"Dark mode: ": "Tema scuro: ",
|
||||||
"Watch history": "Cronologia dei video",
|
"Theme: ": "Tema: ",
|
||||||
"Delete account": "Elimina l'account",
|
"dark": "scuro",
|
||||||
"Administrator preferences": "",
|
"light": "chiaro",
|
||||||
"Default homepage: ": "",
|
"Thin mode: ": "Modalità per connessioni lente: ",
|
||||||
"Feed menu: ": "",
|
"Subscription preferences": "Preferenze iscrizioni",
|
||||||
"Top enabled? ": "",
|
"Show annotations by default for subscribed channels: ": "Mostrare annotazioni in modo predefinito per i canali sottoscritti: ",
|
||||||
"CAPTCHA enabled? ": "",
|
"Redirect homepage to feed: ": "Reindirizza la pagina principale a quella delle iscrizioni: ",
|
||||||
"Login enabled? ": "",
|
"Number of videos shown in feed: ": "Numero di video da mostrare nelle iscrizioni: ",
|
||||||
"Registration enabled? ": "",
|
"Sort videos by: ": "Ordina i video per: ",
|
||||||
"Report statistics? ": "",
|
"published": "data di pubblicazione",
|
||||||
"Save preferences": "Salva le preferenze",
|
"published - reverse": "data di pubblicazione - decrescente",
|
||||||
"Subscription manager": "Gestisci le iscrizioni",
|
"alphabetically": "ordine alfabetico",
|
||||||
"`x` subscriptions": "`x` iscrizioni",
|
"alphabetically - reverse": "ordine alfabetico - decrescente",
|
||||||
"Import/Export": "Importa/esporta",
|
"channel name": "nome del canale",
|
||||||
"unsubscribe": "disiscriviti",
|
"channel name - reverse": "nome del canale - decrescente",
|
||||||
"Subscriptions": "Iscrizioni",
|
"Only show latest video from channel: ": "Mostra solo il video più recente del canale: ",
|
||||||
"`x` unseen notifications": "`x` notifiche non visualizzate",
|
"Only show latest unwatched video from channel: ": "Mostra solo il video più recente non guardato del canale: ",
|
||||||
"search": "Cerca",
|
"Only show unwatched: ": "Mostra solo i video non guardati: ",
|
||||||
"Sign out": "Esci",
|
"Only show notifications (if there are any): ": "Mostra solo le notifiche (se presenti): ",
|
||||||
"Released under the AGPLv3 by Omar Roth.": "Pubblicato con licenza AGPLv3 da Omar Roth.",
|
"Enable web notifications": "Attiva le notifiche web",
|
||||||
"Source available here.": "Codice sorgente.",
|
"`x` uploaded a video": "`x` ha caricato un video",
|
||||||
"View JavaScript license information.": "Guarda le informazioni di licenza del codice JavaScript.",
|
"`x` is live": "`x` è in diretta",
|
||||||
"Trending": "Tendenze",
|
"Data preferences": "Preferenze dati",
|
||||||
"Watch video on Youtube": "Guarda il video su YouTube",
|
"Clear watch history": "Cancella la cronologia dei video guardati",
|
||||||
"Genre: ": "Genere: ",
|
"Import/export data": "Importazione/esportazione dati",
|
||||||
"License: ": "Licenza: ",
|
"Change password": "Modifica password",
|
||||||
"Family friendly? ": "Per tutti? ",
|
"Manage subscriptions": "Gestisci le iscrizioni",
|
||||||
"Wilson score: ": "Punteggio di Wilson: ",
|
"Manage tokens": "Gestisci i gettoni",
|
||||||
"Engagement: ": "Tasso di coinvolgimento: ",
|
"Watch history": "Cronologia dei video",
|
||||||
"Whitelisted regions: ": "Regioni nella lista bianca: ",
|
"Delete account": "Elimina l'account",
|
||||||
"Blacklisted regions: ": "Regioni nella lista nera: ",
|
"Administrator preferences": "Preferenze amministratore",
|
||||||
"Shared `x`": "Condiviso `x`",
|
"Default homepage: ": "Pagina principale predefinita: ",
|
||||||
"Hi! Looks like you have JavaScript disabled. Click here to view comments, keep in mind it may take a bit longer to load.": "Ciao! Sembra che tu abbia disattivato JavaScript. Clicca qui per visualizzare i commenti. Considera che potrebbe volerci più tempo.",
|
"Feed menu: ": "Menu iscrizioni: ",
|
||||||
"View YouTube comments": "Visualizza i commenti da YouTube",
|
"Top enabled: ": "Top abilitato: ",
|
||||||
"View more comments on Reddit": "Visualizza più commenti su Reddit",
|
"CAPTCHA enabled: ": "CAPTCHA attivati: ",
|
||||||
"View `x` comments": "Visualizza `x` commenti",
|
"Login enabled: ": "Accesso attivato: ",
|
||||||
"View Reddit comments": "Visualizza i commenti da Reddit",
|
"Registration enabled: ": "Registrazione attivata: ",
|
||||||
"Hide replies": "Nascondi le risposte",
|
"Report statistics: ": "Resoconto delle statistiche: ",
|
||||||
"Show replies": "Mostra le risposte",
|
"Save preferences": "Salva le preferenze",
|
||||||
"Incorrect password": "Password sbagliata",
|
"Subscription manager": "Gestione delle iscrizioni",
|
||||||
"Quota exceeded, try again in a few hours": "Limite superato, prova di nuovo fra qualche ora",
|
"Token manager": "Gestione dei gettoni",
|
||||||
"Unable to login, make sure two-factor authentication (Authenticator or SMS) is enabled.": "Impossibile autenticarsi, controlla che l'autenticazione in due passaggi (Authenticator o SMS) sia attiva.",
|
"Token": "Gettone",
|
||||||
"Invalid TFA code": "Codice di autenticazione a due fattori non valido",
|
"`x` subscriptions.": {
|
||||||
"Login failed. This may be because two-factor authentication is not enabled on your account.": "Login fallito. L'errore potrebbe essere causato dal fatto che la verifica in due passaggi non è attiva sul tuo account.",
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` iscrizione",
|
||||||
"Invalid answer": "Risposta errata",
|
"": "`x` iscrizioni."
|
||||||
"Invalid CAPTCHA": "CAPTCHA errato",
|
},
|
||||||
"CAPTCHA is a required field": "Il CAPTCHA è un campo obbligatorio",
|
"`x` tokens.": {
|
||||||
"User ID is a required field": "L'ID utente è obbligatorio",
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` gettone",
|
||||||
"Password is a required field": "La password è un campo obbligatorio",
|
"": "`x` gettoni."
|
||||||
"Invalid username or password": "Nome utente o password errati",
|
},
|
||||||
"Please sign in using 'Sign in with Google'": "Per favore accedi con \"Entra con Google\"",
|
"Import/export": "Importa/esporta",
|
||||||
"Password cannot be empty": "La password non può essere vuota",
|
"unsubscribe": "disiscriviti",
|
||||||
"Password cannot be longer than 55 characters": "La password non può contenere più di 55 caratteri",
|
"revoke": "revoca",
|
||||||
"Please sign in": "Per favore, entra",
|
"Subscriptions": "Iscrizioni",
|
||||||
"Invidious Private Feed for `x`": "Feed privato Invidious per `x`",
|
"`x` unseen notifications.": {
|
||||||
"channel:`x`": "canale:`x`",
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` notifica non visualizzata",
|
||||||
"Deleted or invalid channel": "Canale cancellato o invalido",
|
"": "`x` notifiche non visualizzate."
|
||||||
"This channel does not exist.": "Canale inesistente.",
|
},
|
||||||
"Could not get channel info.": "Impossibile ottenere le informazioni del canale.",
|
"search": "Cerca",
|
||||||
"Could not fetch comments": "Impossibile recuperare i commenti",
|
"Log out": "Esci",
|
||||||
"View `x` replies": "Visualizza `x` risposte",
|
"Released under the AGPLv3 by Omar Roth.": "Pubblicato con licenza AGPLv3 da Omar Roth.",
|
||||||
"`x` ago": "`x` fa",
|
"Source available here.": "Codice sorgente.",
|
||||||
"Load more": "Carica altro",
|
"View JavaScript license information.": "Guarda le informazioni di licenza del codice JavaScript.",
|
||||||
"`x` points": "`x` punti",
|
"View privacy policy.": "Vedi la politica sulla privacy.",
|
||||||
"Could not create mix.": "Impossibile creare il mix.",
|
"Trending": "Tendenze",
|
||||||
"Playlist is empty": "Playlist vuota",
|
"Public": "Pubblico",
|
||||||
"Invalid playlist.": "Playlist invalida.",
|
"Unlisted": "Non elencati",
|
||||||
"Playlist does not exist.": "Playlist inesistente.",
|
"Private": "Privato",
|
||||||
"Could not pull trending pages.": "Impossibile recuperare le tendenze.",
|
"View all playlists": "Visualizza tutte le playlist",
|
||||||
"Hidden field \"challenge\" is a required field": "Il campo nascosto \"challenge\" è obbligatorio",
|
"Updated `x` ago": "Aggiornato `x` fa",
|
||||||
"Hidden field \"token\" is a required field": "Il campo nascosto \"token\" è obbligatorio",
|
"Delete playlist `x`?": "Eliminare la playlist `x`?",
|
||||||
"Invalid challenge": "Campo \"challenge\" invalido",
|
"Delete playlist": "Elimina playlist",
|
||||||
"Invalid token": "Campo \"token\" invalido",
|
"Create playlist": "Crea playlist",
|
||||||
"Invalid user": "Utente invalido",
|
"Title": "Titolo",
|
||||||
"Token is expired, please try again": "Token scaduto, riprova",
|
"Playlist privacy": "Privacy playlist",
|
||||||
"English": "Inglese",
|
"Editing playlist `x`": "Modificando la playlist `x`",
|
||||||
"English (auto-generated)": "Inglese (generati automaticamente)",
|
"Watch on YouTube": "Guarda su YouTube",
|
||||||
"Afrikaans": "Afrikaans",
|
"Hide annotations": "Nascondi annotazioni",
|
||||||
"Albanian": "Albanese",
|
"Show annotations": "Mostra annotazioni",
|
||||||
"Amharic": "Amarico",
|
"Genre: ": "Genere: ",
|
||||||
"Arabic": "Arabo",
|
"License: ": "Licenza: ",
|
||||||
"Armenian": "Armeno",
|
"Family friendly? ": "Per tutti? ",
|
||||||
"Azerbaijani": "Azero",
|
"Wilson score: ": "Punteggio di Wilson: ",
|
||||||
"Bangla": "Bengalese",
|
"Engagement: ": "Tasso di coinvolgimento: ",
|
||||||
"Basque": "Basco",
|
"Whitelisted regions: ": "Regioni in lista bianca: ",
|
||||||
"Belarusian": "Biellorusso",
|
"Blacklisted regions: ": "Regioni in lista nera: ",
|
||||||
"Bosnian": "Bosniaco",
|
"Shared `x`": "Condiviso `x`",
|
||||||
"Bulgarian": "Bulgaro",
|
"`x` views.": {
|
||||||
"Burmese": "Birmano",
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` visualizzazione",
|
||||||
"Catalan": "Catalano",
|
"": "`x` visualizzazioni."
|
||||||
"Cebuano": "Sugbuanon",
|
},
|
||||||
"Chinese (Simplified)": "Cinese semplifiato",
|
"Premieres in `x`": "In anteprima in `x`",
|
||||||
"Chinese (Traditional)": "Cinese tradizionale",
|
"Premieres `x`": "In anteprima `x`",
|
||||||
"Corsican": "Corso",
|
"Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.": "Ciao! Sembra che tu abbia disattivato JavaScript. Clicca qui per visualizzare i commenti. Considera che potrebbe volerci più tempo.",
|
||||||
"Croatian": "Croato",
|
"View YouTube comments": "Visualizza i commenti da YouTube",
|
||||||
"Czech": "Ceco",
|
"View more comments on Reddit": "Visualizza più commenti su Reddit",
|
||||||
"Danish": "Danese",
|
"View `x` comments": "Visualizza `x` commenti",
|
||||||
"Dutch": "Olandese",
|
"View Reddit comments": "Visualizza i commenti da Reddit",
|
||||||
"Esperanto": "Esperanto",
|
"Hide replies": "Nascondi le risposte",
|
||||||
"Estonian": "Estone",
|
"Show replies": "Mostra le risposte",
|
||||||
"Filipino": "Filippino",
|
"Incorrect password": "Password sbagliata",
|
||||||
"Finnish": "Finlandese",
|
"Quota exceeded, try again in a few hours": "Limite superato, prova di nuovo fra qualche ora",
|
||||||
"French": "Francese",
|
"Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.": "Impossibile autenticarsi, controlla che l'autenticazione in due passaggi (Authenticator o SMS) sia attiva.",
|
||||||
"Galician": "Galiziano",
|
"Invalid TFA code": "Codice di autenticazione a due fattori non valido",
|
||||||
"Georgian": "Georgiano",
|
"Login failed. This may be because two-factor authentication is not turned on for your account.": "Login fallito. L'errore potrebbe essere causato dal fatto che la verifica in due passaggi non è attiva sul tuo account.",
|
||||||
"German": "Tedesco",
|
"Wrong answer": "Risposta errata",
|
||||||
"Greek": "Greco",
|
"Erroneous CAPTCHA": "CAPTCHA errato",
|
||||||
"Gujarati": "Gujarati",
|
"CAPTCHA is a required field": "Il CAPTCHA è un campo obbligatorio",
|
||||||
"Haitian Creole": "Creolo haitiano",
|
"User ID is a required field": "L'ID utente è obbligatorio",
|
||||||
"Hausa": "Lingua hausa",
|
"Password is a required field": "La password è un campo obbligatorio",
|
||||||
"Hawaiian": "Hawaiano",
|
"Wrong username or password": "Nome utente o password errati",
|
||||||
"Hebrew": "Ebreo",
|
"Please sign in using 'Log in with Google'": "Per favore accedi con \"Entra con Google\"",
|
||||||
"Hindi": "Hindi",
|
"Password cannot be empty": "La password non può essere vuota",
|
||||||
"Hmong": "Hmong",
|
"Password cannot be longer than 55 characters": "La password non può contenere più di 55 caratteri",
|
||||||
"Hungarian": "Ungarese",
|
"Please log in": "Per favore, accedi",
|
||||||
"Icelandic": "Islandese",
|
"Invidious Private Feed for `x`": "Feed privato Invidious per `x`",
|
||||||
"Igbo": "Igbo",
|
"channel:`x`": "canale:`x`",
|
||||||
"Indonesian": "Indonesiano",
|
"Deleted or invalid channel": "Canale eliminato o non valido",
|
||||||
"Irish": "Irlandese",
|
"This channel does not exist.": "Questo canale non esiste.",
|
||||||
"Italian": "Italiano",
|
"Could not get channel info.": "Impossibile ottenere le informazioni del canale.",
|
||||||
"Japanese": "Giapponese",
|
"Could not fetch comments": "Impossibile recuperare i commenti",
|
||||||
"Javanese": "Giavanese",
|
"View `x` replies.": {
|
||||||
"Kannada": "Kannada",
|
"([^.,0-9]|^)1([^.,0-9]|$)": "Visualizza `x` risposta",
|
||||||
"Kazakh": "Kazaco",
|
"": "Visualizza `x` risposte."
|
||||||
"Khmer": "Khmer",
|
},
|
||||||
"Korean": "Coreano",
|
"`x` ago": "`x` fa",
|
||||||
"Kurdish": "Curdo",
|
"Load more": "Carica altro",
|
||||||
"Kyrgyz": "Kirghize",
|
"`x` points.": {
|
||||||
"Lao": "Lao",
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` punto",
|
||||||
"Latin": "Latino",
|
"": "`x` punti."
|
||||||
"Latvian": "Lettone",
|
},
|
||||||
"Lithuanian": "Lituano",
|
"Could not create mix.": "Impossibile creare il mix.",
|
||||||
"Luxembourgish": "Lussemburghese",
|
"Empty playlist": "Playlist vuota",
|
||||||
"Macedonian": "Macedone",
|
"Not a playlist.": "Non è una playlist.",
|
||||||
"Malagasy": "Malgascio",
|
"Playlist does not exist.": "La playlist non esiste.",
|
||||||
"Malay": "Malese",
|
"Could not pull trending pages.": "Impossibile recuperare le tendenze.",
|
||||||
"Malayalam": "Lingua malayalam",
|
"Hidden field \"challenge\" is a required field": "Il campo nascosto \"challenge\" è obbligatorio",
|
||||||
"Maltese": "Maltese",
|
"Hidden field \"token\" is a required field": "Il campo nascosto \"token\" è obbligatorio",
|
||||||
"Maori": "Maori",
|
"Erroneous challenge": "Campo \"challenge\" non valido",
|
||||||
"Marathi": "Marathi",
|
"Erroneous token": "Campo \"token\" non valido",
|
||||||
"Mongolian": "Mongolo",
|
"No such user": "Utente non valido",
|
||||||
"Nepali": "Nepalese",
|
"Token is expired, please try again": "Gettone scaduto, riprova",
|
||||||
"Norwegian": "Norvegese",
|
"English": "Inglese",
|
||||||
"Nyanja": "Nyanja",
|
"English (auto-generated)": "Inglese (generati automaticamente)",
|
||||||
"Pashto": "Lingua pashtu",
|
"Afrikaans": "Afrikaans",
|
||||||
"Persian": "Persiano",
|
"Albanian": "Albanese",
|
||||||
"Polish": "Polacco",
|
"Amharic": "Amarico",
|
||||||
"Portuguese": "Portoghese",
|
"Arabic": "Arabo",
|
||||||
"Punjabi": "Punjabi",
|
"Armenian": "Armeno",
|
||||||
"Romanian": "Rumeno",
|
"Azerbaijani": "Azero",
|
||||||
"Russian": "Russo",
|
"Bangla": "Bengalese",
|
||||||
"Samoan": "Samoan",
|
"Basque": "Basco",
|
||||||
"Scottish Gaelic": "Gaelico scozzese",
|
"Belarusian": "Biellorusso",
|
||||||
"Serbian": "Serbo",
|
"Bosnian": "Bosniaco",
|
||||||
"Shona": "Shona",
|
"Bulgarian": "Bulgaro",
|
||||||
"Sindhi": "Sindhi",
|
"Burmese": "Birmano",
|
||||||
"Sinhala": "Cingalese",
|
"Catalan": "Catalano",
|
||||||
"Slovak": "Slovacco",
|
"Cebuano": "Sugbuanon",
|
||||||
"Slovenian": "Sloveno",
|
"Chinese (Simplified)": "Cinese semplifiato",
|
||||||
"Somali": "Somalo",
|
"Chinese (Traditional)": "Cinese tradizionale",
|
||||||
"Southern Sotho": "Sotho del Sud",
|
"Corsican": "Corso",
|
||||||
"Spanish": "Spagnolo",
|
"Croatian": "Croato",
|
||||||
"Spanish (Latin America)": "Spagnolo (America latina)",
|
"Czech": "Ceco",
|
||||||
"Sundanese": "Sudanese",
|
"Danish": "Danese",
|
||||||
"Swahili": "Swahili",
|
"Dutch": "Olandese",
|
||||||
"Swedish": "Svedese",
|
"Esperanto": "Esperanto",
|
||||||
"Tajik": "Tajik",
|
"Estonian": "Estone",
|
||||||
"Tamil": "Tamil",
|
"Filipino": "Filippino",
|
||||||
"Telugu": "Telugu",
|
"Finnish": "Finlandese",
|
||||||
"Thai": "Thaï",
|
"French": "Francese",
|
||||||
"Turkish": "Turco",
|
"Galician": "Galiziano",
|
||||||
"Ukrainian": "Ucraino",
|
"Georgian": "Georgiano",
|
||||||
"Urdu": "Urdu",
|
"German": "Tedesco",
|
||||||
"Uzbek": "Uzbeco",
|
"Greek": "Greco",
|
||||||
"Vietnamese": "Vietnamese",
|
"Gujarati": "Gujarati",
|
||||||
"Welsh": "Gallese",
|
"Haitian Creole": "Creolo haitiano",
|
||||||
"Western Frisian": "Frisone occidentale",
|
"Hausa": "Lingua hausa",
|
||||||
"Xhosa": "Xhosa",
|
"Hawaiian": "Hawaiano",
|
||||||
"Yiddish": "Yiddish",
|
"Hebrew": "Ebreo",
|
||||||
"Yoruba": "Yoruba",
|
"Hindi": "Hindi",
|
||||||
"Zulu": "Zulu",
|
"Hmong": "Hmong",
|
||||||
"`x` years": "`x` anni",
|
"Hungarian": "Ungarese",
|
||||||
"`x` months": "`x` mesi",
|
"Icelandic": "Islandese",
|
||||||
"`x` weeks": "`x` settimane",
|
"Igbo": "Igbo",
|
||||||
"`x` days": "`x` giorni",
|
"Indonesian": "Indonesiano",
|
||||||
"`x` hours": "`x` ore",
|
"Irish": "Irlandese",
|
||||||
"`x` minutes": "`x` minuti",
|
"Italian": "Italiano",
|
||||||
"`x` seconds": "`x` secondi",
|
"Japanese": "Giapponese",
|
||||||
"Fallback comments: ": "Commenti alternativi: ",
|
"Javanese": "Giavanese",
|
||||||
"Popular": "Popolare",
|
"Kannada": "Kannada",
|
||||||
"Top": "Top",
|
"Kazakh": "Kazaco",
|
||||||
"About": "A proposito",
|
"Khmer": "Khmer",
|
||||||
"Rating: ": "Punteggio: ",
|
"Korean": "Coreano",
|
||||||
"Language: ": "Lingua: ",
|
"Kurdish": "Curdo",
|
||||||
"Default": "Predefinito",
|
"Kyrgyz": "Kirghize",
|
||||||
"Music": "Musica",
|
"Lao": "Lao",
|
||||||
"Gaming": "Videogiochi",
|
"Latin": "Latino",
|
||||||
"News": "Notizie",
|
"Latvian": "Lettone",
|
||||||
"Movies": "Film",
|
"Lithuanian": "Lituano",
|
||||||
"Download": "Scarica",
|
"Luxembourgish": "Lussemburghese",
|
||||||
"Download as: ": "Scarica come: ",
|
"Macedonian": "Macedone",
|
||||||
"%A %B %-d, %Y": "%A %-d %B %Y",
|
"Malagasy": "Malgascio",
|
||||||
"(edited)": "(modificato)",
|
"Malay": "Malese",
|
||||||
"Youtube permalink of the comment": "Link permanente al commento di YouTube",
|
"Malayalam": "Lingua malayalam",
|
||||||
"`x` marked it with a ❤": "`x` l'ha contrassegnato con un ❤",
|
"Maltese": "Maltese",
|
||||||
"Audio mode": "Modalità audio",
|
"Maori": "Maori",
|
||||||
"Video mode": "Modalità video"
|
"Marathi": "Marathi",
|
||||||
}
|
"Mongolian": "Mongolo",
|
||||||
|
"Nepali": "Nepalese",
|
||||||
|
"Norwegian Bokmål": "Norvegese",
|
||||||
|
"Nyanja": "Nyanja",
|
||||||
|
"Pashto": "Lingua pashtu",
|
||||||
|
"Persian": "Persiano",
|
||||||
|
"Polish": "Polacco",
|
||||||
|
"Portuguese": "Portoghese",
|
||||||
|
"Punjabi": "Punjabi",
|
||||||
|
"Romanian": "Rumeno",
|
||||||
|
"Russian": "Russo",
|
||||||
|
"Samoan": "Samoan",
|
||||||
|
"Scottish Gaelic": "Gaelico scozzese",
|
||||||
|
"Serbian": "Serbo",
|
||||||
|
"Shona": "Shona",
|
||||||
|
"Sindhi": "Sindhi",
|
||||||
|
"Sinhala": "Cingalese",
|
||||||
|
"Slovak": "Slovacco",
|
||||||
|
"Slovenian": "Sloveno",
|
||||||
|
"Somali": "Somalo",
|
||||||
|
"Southern Sotho": "Sotho del Sud",
|
||||||
|
"Spanish": "Spagnolo",
|
||||||
|
"Spanish (Latin America)": "Spagnolo (America latina)",
|
||||||
|
"Sundanese": "Sudanese",
|
||||||
|
"Swahili": "Swahili",
|
||||||
|
"Swedish": "Svedese",
|
||||||
|
"Tajik": "Tajik",
|
||||||
|
"Tamil": "Tamil",
|
||||||
|
"Telugu": "Telugu",
|
||||||
|
"Thai": "Thaï",
|
||||||
|
"Turkish": "Turco",
|
||||||
|
"Ukrainian": "Ucraino",
|
||||||
|
"Urdu": "Urdu",
|
||||||
|
"Uzbek": "Uzbeco",
|
||||||
|
"Vietnamese": "Vietnamese",
|
||||||
|
"Welsh": "Gallese",
|
||||||
|
"Western Frisian": "Frisone occidentale",
|
||||||
|
"Xhosa": "Xhosa",
|
||||||
|
"Yiddish": "Yiddish",
|
||||||
|
"Yoruba": "Yoruba",
|
||||||
|
"Zulu": "Zulu",
|
||||||
|
"`x` years.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` anno",
|
||||||
|
"": "`x` anni."
|
||||||
|
},
|
||||||
|
"`x` months.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` mese",
|
||||||
|
"": "`x` mesi."
|
||||||
|
},
|
||||||
|
"`x` weeks.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` settimana",
|
||||||
|
"": "`x` settimane."
|
||||||
|
},
|
||||||
|
"`x` days.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` giorno",
|
||||||
|
"": "`x` giorni."
|
||||||
|
},
|
||||||
|
"`x` hours.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` ora",
|
||||||
|
"": "`x` ore."
|
||||||
|
},
|
||||||
|
"`x` minutes.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` minuto",
|
||||||
|
"": "`x` minuti."
|
||||||
|
},
|
||||||
|
"`x` seconds.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` secondo",
|
||||||
|
"": "`x` secondi."
|
||||||
|
},
|
||||||
|
"Fallback comments: ": "Commenti alternativi: ",
|
||||||
|
"Popular": "Popolare",
|
||||||
|
"Top": "Top",
|
||||||
|
"About": "Al riguardo",
|
||||||
|
"Rating: ": "Punteggio: ",
|
||||||
|
"Language: ": "Lingua: ",
|
||||||
|
"View as playlist": "Vedi come playlist",
|
||||||
|
"Default": "Predefinito",
|
||||||
|
"Music": "Musica",
|
||||||
|
"Gaming": "Videogiochi",
|
||||||
|
"News": "Notizie",
|
||||||
|
"Movies": "Film",
|
||||||
|
"Download": "Scarica",
|
||||||
|
"Download as: ": "Scarica come: ",
|
||||||
|
"%A %B %-d, %Y": "%A %-d %B %Y",
|
||||||
|
"(edited)": "(modificato)",
|
||||||
|
"YouTube comment permalink": "Link permanente al commento di YouTube",
|
||||||
|
"permalink": "permalink",
|
||||||
|
"`x` marked it with a ❤": "`x` l'ha contrassegnato con un ❤",
|
||||||
|
"Audio mode": "Modalità audio",
|
||||||
|
"Video mode": "Modalità video",
|
||||||
|
"Videos": "Video",
|
||||||
|
"Playlists": "Playlist",
|
||||||
|
"Community": "Comunità",
|
||||||
|
"Current version: ": "Versione attuale: "
|
||||||
|
}
|
||||||
387
locales/ja.json
Normal file
387
locales/ja.json
Normal file
@@ -0,0 +1,387 @@
|
|||||||
|
{
|
||||||
|
"`x` subscribers": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` 人の登録者",
|
||||||
|
"": "`x` 人の登録者"
|
||||||
|
},
|
||||||
|
"`x` videos": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` 個の動画",
|
||||||
|
"": "`x` 個の動画"
|
||||||
|
},
|
||||||
|
"`x` playlists": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` 個の再生リスト",
|
||||||
|
"": "`x` 個の再生リスト"
|
||||||
|
},
|
||||||
|
"LIVE": "ライブ",
|
||||||
|
"Shared `x` ago": "`x`前に共有",
|
||||||
|
"Unsubscribe": "登録解除",
|
||||||
|
"Subscribe": "登録",
|
||||||
|
"View channel on YouTube": "YouTube でチャンネルを見る",
|
||||||
|
"View playlist on YouTube": "YouTube で再生リストを見る",
|
||||||
|
"newest": "新しい順",
|
||||||
|
"oldest": "古い順",
|
||||||
|
"popular": "人気順",
|
||||||
|
"last": "追加順",
|
||||||
|
"Next page": "次のページ",
|
||||||
|
"Previous page": "前のページ",
|
||||||
|
"Clear watch history?": "再生履歴を削除しますか?",
|
||||||
|
"New password": "新しいパスワード",
|
||||||
|
"New passwords must match": "新しいパスワードが一致していません",
|
||||||
|
"Cannot change password for Google accounts": "Google アカウントのパスワードは変更できません",
|
||||||
|
"Authorize token?": "トークンを認証しますか?",
|
||||||
|
"Authorize token for `x`?": "トークン `x` を認証しますか?",
|
||||||
|
"Yes": "はい",
|
||||||
|
"No": "いいえ",
|
||||||
|
"Import and Export Data": "データのインポートとエクスポート",
|
||||||
|
"Import": "インポート",
|
||||||
|
"Import Invidious data": "Invidious データをインポート",
|
||||||
|
"Import YouTube subscriptions": "YouTube 登録チャンネルをインポート",
|
||||||
|
"Import FreeTube subscriptions (.db)": "FreeTube 登録チャンネルをインポート (.db)",
|
||||||
|
"Import NewPipe subscriptions (.json)": "NewPipe 登録チャンネルをインポート (.json)",
|
||||||
|
"Import NewPipe data (.zip)": "NewPipe データをインポート (.zip)",
|
||||||
|
"Export": "エクスポート",
|
||||||
|
"Export subscriptions as OPML": "登録チャンネルを OPML でエクスポート",
|
||||||
|
"Export subscriptions as OPML (for NewPipe & FreeTube)": "登録チャンネルを OPML でエクスポート (NewPipe & FreeTube 用)",
|
||||||
|
"Export data as JSON": "データを JSON でエクスポート",
|
||||||
|
"Delete account?": "アカウントを削除しますか?",
|
||||||
|
"History": "履歴",
|
||||||
|
"An alternative front-end to YouTube": "YouTube の代わりとなる新しいフロントエンド",
|
||||||
|
"JavaScript license information": "JavaScript ライセンス情報",
|
||||||
|
"source": "ソース",
|
||||||
|
"Log in": "ログイン",
|
||||||
|
"Log in/register": "ログイン/登録",
|
||||||
|
"Log in with Google": "Google でログイン",
|
||||||
|
"User ID": "ユーザー ID",
|
||||||
|
"Password": "パスワード",
|
||||||
|
"Time (h:mm:ss):": "時間 (時:分分:秒秒):",
|
||||||
|
"Text CAPTCHA": "テキスト CAPTCHA",
|
||||||
|
"Image CAPTCHA": "画像 CAPTCHA",
|
||||||
|
"Sign In": "サインイン",
|
||||||
|
"Register": "登録",
|
||||||
|
"E-mail": "メールアドレス",
|
||||||
|
"Google verification code": "Google 認証コード",
|
||||||
|
"Preferences": "設定",
|
||||||
|
"Player preferences": "プレイヤー設定",
|
||||||
|
"Always loop: ": "常にループ: ",
|
||||||
|
"Autoplay: ": "自動再生: ",
|
||||||
|
"Play next by default: ": "デフォルトで次を再生: ",
|
||||||
|
"Autoplay next video: ": "次の動画を自動再生: ",
|
||||||
|
"Listen by default: ": "デフォルトでオーディオモードを使用: ",
|
||||||
|
"Proxy videos: ": "動画をプロキシーに通す: ",
|
||||||
|
"Default speed: ": "デフォルトの再生速度: ",
|
||||||
|
"Preferred video quality: ": "優先する画質: ",
|
||||||
|
"Player volume: ": "プレイヤーの音量: ",
|
||||||
|
"Default comments: ": "デフォルトのコメント: ",
|
||||||
|
"youtube": "youtube",
|
||||||
|
"reddit": "reddit",
|
||||||
|
"Default captions: ": "デフォルトの字幕: ",
|
||||||
|
"Fallback captions: ": "フォールバック時の字幕: ",
|
||||||
|
"Show related videos: ": "関連動画を表示: ",
|
||||||
|
"Show annotations by default: ": "デフォルトでアノテーションを表示: ",
|
||||||
|
"Visual preferences": "外観設定",
|
||||||
|
"Player style: ": "プレイヤースタイル: ",
|
||||||
|
"Dark mode: ": "ダークモード: ",
|
||||||
|
"Theme: ": "テーマ: ",
|
||||||
|
"dark": "ダーク",
|
||||||
|
"light": "ライト",
|
||||||
|
"Thin mode: ": "最小モード: ",
|
||||||
|
"Subscription preferences": "登録チャンネル設定",
|
||||||
|
"Show annotations by default for subscribed channels: ": "デフォルトで登録チャンネルのアノテーションを表示しますか? ",
|
||||||
|
"Redirect homepage to feed: ": "ホームからフィードにリダイレクト: ",
|
||||||
|
"Number of videos shown in feed: ": "フィードに表示する動画の量: ",
|
||||||
|
"Sort videos by: ": "動画を並び替え: ",
|
||||||
|
"published": "投稿日",
|
||||||
|
"published - reverse": "投稿日 - 逆順",
|
||||||
|
"alphabetically": "アルファベット",
|
||||||
|
"alphabetically - reverse": "アルファベット - 逆順",
|
||||||
|
"channel name": "チャンネル名",
|
||||||
|
"channel name - reverse": "チャンネル名 - 逆順",
|
||||||
|
"Only show latest video from channel: ": "チャンネルの最新動画のみを表示: ",
|
||||||
|
"Only show latest unwatched video from channel: ": "チャンネルの最新未視聴動画のみを表示: ",
|
||||||
|
"Only show unwatched: ": "未視聴のみを表示: ",
|
||||||
|
"Only show notifications (if there are any): ": "通知のみを表示 (ある場合): ",
|
||||||
|
"Enable web notifications": "ウェブ通知を有効化",
|
||||||
|
"`x` uploaded a video": "`x` が動画を投稿しました",
|
||||||
|
"`x` is live": "`x` がライブ中です",
|
||||||
|
"Data preferences": "データ設定",
|
||||||
|
"Clear watch history": "再生履歴の削除",
|
||||||
|
"Import/export data": "データのインポート/エクスポート",
|
||||||
|
"Change password": "パスワードを変更",
|
||||||
|
"Manage subscriptions": "登録チャンネルを管理",
|
||||||
|
"Manage tokens": "トークンを管理",
|
||||||
|
"Watch history": "再生履歴",
|
||||||
|
"Delete account": "アカウントを削除",
|
||||||
|
"Administrator preferences": "管理者設定",
|
||||||
|
"Default homepage: ": "デフォルトのホーム: ",
|
||||||
|
"Feed menu: ": "フィードメニュー: ",
|
||||||
|
"Top enabled: ": "Top enabled: ",
|
||||||
|
"CAPTCHA enabled: ": "CAPTCHA を有効化: ",
|
||||||
|
"Login enabled: ": "ログインを有効化: ",
|
||||||
|
"Registration enabled: ": "登録を有効化: ",
|
||||||
|
"Report statistics: ": "統計を報告: ",
|
||||||
|
"Save preferences": "設定を保存",
|
||||||
|
"Subscription manager": "登録チャンネルマネージャー",
|
||||||
|
"Token manager": "トークンマネージャー",
|
||||||
|
"Token": "トークン",
|
||||||
|
"`x` subscriptions": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` 個の登録チャンネル",
|
||||||
|
"": "`x` 個の登録チャンネル"
|
||||||
|
},
|
||||||
|
"`x` tokens": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` 個のトークン",
|
||||||
|
"": "`x` 個のトークン"
|
||||||
|
},
|
||||||
|
"Import/export": "インポート/エクスポート",
|
||||||
|
"unsubscribe": "登録解除",
|
||||||
|
"revoke": "revoke",
|
||||||
|
"Subscriptions": "登録チャンネル",
|
||||||
|
"`x` unseen notifications": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` 個の未読通知",
|
||||||
|
"": "`x` 個の未読通知"
|
||||||
|
},
|
||||||
|
"search": "検索",
|
||||||
|
"Log out": "ログアウト",
|
||||||
|
"Released under the AGPLv3 by Omar Roth.": "Omar Roth によって AGPLv3 でリリースされています。",
|
||||||
|
"Source available here.": "ソースはここで閲覧可能です。",
|
||||||
|
"View JavaScript license information.": "JavaScript ライセンス情報を見る。",
|
||||||
|
"View privacy policy.": "プライバシーポリシーを見る。",
|
||||||
|
"Trending": "急上昇",
|
||||||
|
"Public": "公開",
|
||||||
|
"Unlisted": "限定公開",
|
||||||
|
"Private": "非公開",
|
||||||
|
"View all playlists": "再生リストをすべて見る",
|
||||||
|
"Updated `x` ago": "`x`前に更新",
|
||||||
|
"Delete playlist `x`?": "再生リスト `x` を削除しますか?",
|
||||||
|
"Delete playlist": "再生リストを削除",
|
||||||
|
"Create playlist": "再生リストを作成",
|
||||||
|
"Title": "タイトル",
|
||||||
|
"Playlist privacy": "再生リストのプライバシー",
|
||||||
|
"Editing playlist `x`": "再生リスト `x` を編集中",
|
||||||
|
"Watch on YouTube": "YouTube で視聴",
|
||||||
|
"Hide annotations": "アノテーションを隠す",
|
||||||
|
"Show annotations": "アノテーションを表示",
|
||||||
|
"Genre: ": "ジャンル: ",
|
||||||
|
"License: ": "ライセンス: ",
|
||||||
|
"Family friendly? ": "家族向け? ",
|
||||||
|
"Wilson score: ": "ウィルソンスコア: ",
|
||||||
|
"Engagement: ": "エンゲージメント: ",
|
||||||
|
"Whitelisted regions: ": "ホワイトリストの地域: ",
|
||||||
|
"Blacklisted regions: ": "ブラックリストの地域: ",
|
||||||
|
"Shared `x`": "`x`に共有",
|
||||||
|
"`x` views": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` 回視聴",
|
||||||
|
"": "`x` 回視聴"
|
||||||
|
},
|
||||||
|
"Premieres in `x`": "Premieres in `x`",
|
||||||
|
"Premieres `x`": "Premieres `x`",
|
||||||
|
"Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.": "やあ!君は JavaScript を無効にしているのかな?ここをクリックしてコメントを見れるけど、読み込みには少し時間がかかることがあるのを覚えておいてね。",
|
||||||
|
"View YouTube comments": "YouTube のコメントを見る",
|
||||||
|
"View more comments on Reddit": "Reddit でコメントをもっと見る",
|
||||||
|
"View `x` comments": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` 件のコメントを見る",
|
||||||
|
"": "`x` 件のコメントを見る"
|
||||||
|
},
|
||||||
|
"View Reddit comments": "Reddit のコメントを見る",
|
||||||
|
"Hide replies": "返信を非表示",
|
||||||
|
"Show replies": "返信を表示",
|
||||||
|
"Incorrect password": "パスワードが間違っています",
|
||||||
|
"Quota exceeded, try again in a few hours": "試行を制限中です。数時間後にやり直してください",
|
||||||
|
"Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.": "ログインできませんでした。2段階認証 (認証アプリまたは SMS) が有効になっていることを確認してください。",
|
||||||
|
"Invalid TFA code": "TFA (2段階認証) コードが無効です",
|
||||||
|
"Login failed. This may be because two-factor authentication is not turned on for your account.": "ログインに失敗しました。あなたのアカウントで2段階認証が有効になっていない可能性があります。",
|
||||||
|
"Wrong answer": "回答が間違っています",
|
||||||
|
"Erroneous CAPTCHA": "CAPTCHA が間違っています",
|
||||||
|
"CAPTCHA is a required field": "CAPTCHA は必須項目です",
|
||||||
|
"User ID is a required field": "ユーザー ID は必須項目です",
|
||||||
|
"Password is a required field": "パスワードは必須項目です",
|
||||||
|
"Wrong username or password": "ユーザー名またはパスワードが間違っています",
|
||||||
|
"Please sign in using 'Log in with Google'": "'Google でログイン' を使用してログインしてください",
|
||||||
|
"Password cannot be empty": "パスワードを空にすることはできません",
|
||||||
|
"Password cannot be longer than 55 characters": "パスワードは55文字より長くできません",
|
||||||
|
"Please log in": "ログインをしてください",
|
||||||
|
"Invidious Private Feed for `x`": "`x` の Invidious プライベートフィード",
|
||||||
|
"channel:`x`": "チャンネル:`x`",
|
||||||
|
"Deleted or invalid channel": "削除済みまたは無効なチャンネルです",
|
||||||
|
"This channel does not exist.": "このチャンネルは存在していません",
|
||||||
|
"Could not get channel info.": "チャンネル情報を取得できませんでした。",
|
||||||
|
"Could not fetch comments": "コメントを取得できませんでした",
|
||||||
|
"View `x` replies": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` 件の返信を見る",
|
||||||
|
"": "`x` 件の返信を見る"
|
||||||
|
},
|
||||||
|
"`x` ago": "`x`前",
|
||||||
|
"Load more": "もっと読み込む",
|
||||||
|
"`x` points": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` ポイント",
|
||||||
|
"": "`x` ポイント"
|
||||||
|
},
|
||||||
|
"Could not create mix.": "ミックスを作成できませんでした。",
|
||||||
|
"Empty playlist": "空の再生リスト",
|
||||||
|
"Not a playlist.": "再生リストではありません。",
|
||||||
|
"Playlist does not exist.": "再生リストが存在していません・",
|
||||||
|
"Could not pull trending pages.": "急上昇ページを取得できませんでした。",
|
||||||
|
"Hidden field \"challenge\" is a required field": "非表示項目 \"challenge\" は必須項目です",
|
||||||
|
"Hidden field \"token\" is a required field": "非表示項目 \"token\" は必須項目です",
|
||||||
|
"Erroneous challenge": "チャレンジが間違っています",
|
||||||
|
"Erroneous token": "トークンが間違っています",
|
||||||
|
"No such user": "ユーザーが存在しません",
|
||||||
|
"Token is expired, please try again": "トークンが期限切れです。再度試してください",
|
||||||
|
"English": "英語",
|
||||||
|
"English (auto-generated)": "英語 (自動生成)",
|
||||||
|
"Afrikaans": "アフリカーンス語",
|
||||||
|
"Albanian": "アルバニア語",
|
||||||
|
"Amharic": "アムハラ語",
|
||||||
|
"Arabic": "アラビア語",
|
||||||
|
"Armenian": "アルメニア語",
|
||||||
|
"Azerbaijani": "アゼルバイジャン語",
|
||||||
|
"Bangla": "ベンガル語",
|
||||||
|
"Basque": "バスク語",
|
||||||
|
"Belarusian": "ベラルーシ語",
|
||||||
|
"Bosnian": "ボスニア語",
|
||||||
|
"Bulgarian": "ブルガリア語",
|
||||||
|
"Burmese": "ビルマ語",
|
||||||
|
"Catalan": "カタルーニャ語",
|
||||||
|
"Cebuano": "セブアノ語",
|
||||||
|
"Chinese (Simplified)": "中国語 (簡体字)",
|
||||||
|
"Chinese (Traditional)": "中国語 (繁体字)",
|
||||||
|
"Corsican": "コルシカ語",
|
||||||
|
"Croatian": "クロアチア語",
|
||||||
|
"Czech": "チェコ語",
|
||||||
|
"Danish": "デンマーク語",
|
||||||
|
"Dutch": "オランダ語",
|
||||||
|
"Esperanto": "エスペラント語",
|
||||||
|
"Estonian": "エストニア語",
|
||||||
|
"Filipino": "フィリピン語",
|
||||||
|
"Finnish": "フィンランド語",
|
||||||
|
"French": "フランス語",
|
||||||
|
"Galician": "ガルシア語",
|
||||||
|
"Georgian": "グルジア語",
|
||||||
|
"German": "ドイツ語",
|
||||||
|
"Greek": "ギリシャ語",
|
||||||
|
"Gujarati": "グジャラート語",
|
||||||
|
"Haitian Creole": "ハイチ語",
|
||||||
|
"Hausa": "ハウサ語",
|
||||||
|
"Hawaiian": "ハワイ語",
|
||||||
|
"Hebrew": "ヘブライ語",
|
||||||
|
"Hindi": "ヒンディー語",
|
||||||
|
"Hmong": "ミャオ語",
|
||||||
|
"Hungarian": "ハンガリー語",
|
||||||
|
"Icelandic": "アイスランド語",
|
||||||
|
"Igbo": "イボ語",
|
||||||
|
"Indonesian": "インドネシア語",
|
||||||
|
"Irish": "アイルランド語",
|
||||||
|
"Italian": "イタリア語",
|
||||||
|
"Japanese": "日本語",
|
||||||
|
"Javanese": "ジャワ語",
|
||||||
|
"Kannada": "カンナダ語",
|
||||||
|
"Kazakh": "カザフ語",
|
||||||
|
"Khmer": "クメール語",
|
||||||
|
"Korean": "韓国語",
|
||||||
|
"Kurdish": "クルド語",
|
||||||
|
"Kyrgyz": "キルギス語",
|
||||||
|
"Lao": "ラーオ語",
|
||||||
|
"Latin": "ラテン語",
|
||||||
|
"Latvian": "ラトビア語",
|
||||||
|
"Lithuanian": "リトアニア語",
|
||||||
|
"Luxembourgish": "ルクセンブルク語",
|
||||||
|
"Macedonian": "マケドニア語",
|
||||||
|
"Malagasy": "マダガスカル語",
|
||||||
|
"Malay": "マレー語",
|
||||||
|
"Malayalam": "マラヤーラム語",
|
||||||
|
"Maltese": "マルタ語",
|
||||||
|
"Maori": "マオリ語",
|
||||||
|
"Marathi": "マラーティー語",
|
||||||
|
"Mongolian": "モンゴル語",
|
||||||
|
"Nepali": "ネパール語",
|
||||||
|
"Norwegian Bokmål": "ノルウェー語",
|
||||||
|
"Nyanja": "チェワ語",
|
||||||
|
"Pashto": "パシュトー語",
|
||||||
|
"Persian": "ペルシア語",
|
||||||
|
"Polish": "ポーランド語",
|
||||||
|
"Portuguese": "ポルトガル語",
|
||||||
|
"Punjabi": "パンジャーブ語",
|
||||||
|
"Romanian": "ルーマニア語",
|
||||||
|
"Russian": "ロシア語",
|
||||||
|
"Samoan": "サモア語",
|
||||||
|
"Scottish Gaelic": "スコットランド・ゲール語",
|
||||||
|
"Serbian": "セルビア語",
|
||||||
|
"Shona": "ショナ語",
|
||||||
|
"Sindhi": "シンド語",
|
||||||
|
"Sinhala": "シンハラ語",
|
||||||
|
"Slovak": "スロバキア語",
|
||||||
|
"Slovenian": "スロベニア語",
|
||||||
|
"Somali": "ソマリ語",
|
||||||
|
"Southern Sotho": "南ソト語",
|
||||||
|
"Spanish": "スペイン語",
|
||||||
|
"Spanish (Latin America)": "スペイン語 (ラテンアメリカ)",
|
||||||
|
"Sundanese": "スンダ語",
|
||||||
|
"Swahili": "スワヒリ語",
|
||||||
|
"Swedish": "スウェーデン語",
|
||||||
|
"Tajik": "タジク語",
|
||||||
|
"Tamil": "タミル語",
|
||||||
|
"Telugu": "テルグ語",
|
||||||
|
"Thai": "タイ語",
|
||||||
|
"Turkish": "トルコ語",
|
||||||
|
"Ukrainian": "ウクライナ語",
|
||||||
|
"Urdu": "ウルドゥー語",
|
||||||
|
"Uzbek": "ウズベク語",
|
||||||
|
"Vietnamese": "ベトナム語",
|
||||||
|
"Welsh": "ウェールズ語",
|
||||||
|
"Western Frisian": "西フリジア語",
|
||||||
|
"Xhosa": "コサ語",
|
||||||
|
"Yiddish": "イディッシュ語",
|
||||||
|
"Yoruba": "ヨルバ語",
|
||||||
|
"Zulu": "ズール語",
|
||||||
|
"`x` years": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x`年",
|
||||||
|
"": "`x`年"
|
||||||
|
},
|
||||||
|
"`x` months": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x`月",
|
||||||
|
"": "`x`月"
|
||||||
|
},
|
||||||
|
"`x` weeks": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x`週",
|
||||||
|
"": "`x`週"
|
||||||
|
},
|
||||||
|
"`x` days": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x`日",
|
||||||
|
"": "`x`日"
|
||||||
|
},
|
||||||
|
"`x` hours": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x`時間",
|
||||||
|
"": "`x`時間"
|
||||||
|
},
|
||||||
|
"`x` minutes": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x`分",
|
||||||
|
"": "`x`分"
|
||||||
|
},
|
||||||
|
"`x` seconds": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x`秒",
|
||||||
|
"": "`x`秒"
|
||||||
|
},
|
||||||
|
"Fallback comments: ": "フォールバック時のコメント: ",
|
||||||
|
"Popular": "人気",
|
||||||
|
"Top": "トップ",
|
||||||
|
"About": "このサービスについて",
|
||||||
|
"Rating: ": "評価: ",
|
||||||
|
"Language: ": "言語: ",
|
||||||
|
"View as playlist": "再生リストで見る",
|
||||||
|
"Default": "デフォルト",
|
||||||
|
"Music": "音楽",
|
||||||
|
"Gaming": "ゲーム",
|
||||||
|
"News": "ニュース",
|
||||||
|
"Movies": "映画",
|
||||||
|
"Download": "ダウンロード",
|
||||||
|
"Download as: ": "ダウンロード: ",
|
||||||
|
"%A %B %-d, %Y": "%Y %B %-d %A",
|
||||||
|
"(edited)": "(編集済み)",
|
||||||
|
"YouTube comment permalink": "YouTube コメントのパーマリンク",
|
||||||
|
"permalink": "パーマリンク",
|
||||||
|
"`x` marked it with a ❤": "`x` が❤を込めてマークしました",
|
||||||
|
"Audio mode": "オーディオモード",
|
||||||
|
"Video mode": "ビデオモード",
|
||||||
|
"Videos": "動画",
|
||||||
|
"Playlists": "プレイリスト",
|
||||||
|
"Community": "コミュニティ",
|
||||||
|
"Current version: ": "現在のバージョン: "
|
||||||
|
}
|
||||||
336
locales/nb-NO.json
Normal file
336
locales/nb-NO.json
Normal file
@@ -0,0 +1,336 @@
|
|||||||
|
{
|
||||||
|
"`x` subscribers": "`x` abonnenter",
|
||||||
|
"`x` videos": "`x` videoer",
|
||||||
|
"`x` playlists": "`x` spillelister",
|
||||||
|
"LIVE": "SANNTIDSVISNING",
|
||||||
|
"Shared `x` ago": "Delt for `x` siden",
|
||||||
|
"Unsubscribe": "Opphev abonnement",
|
||||||
|
"Subscribe": "Abonner",
|
||||||
|
"View channel on YouTube": "Vis kanal på YouTube",
|
||||||
|
"View playlist on YouTube": "Vis spilleliste på YouTube",
|
||||||
|
"newest": "nyeste",
|
||||||
|
"oldest": "eldste",
|
||||||
|
"popular": "populært",
|
||||||
|
"last": "siste",
|
||||||
|
"Next page": "Neste side",
|
||||||
|
"Previous page": "Forrige side",
|
||||||
|
"Clear watch history?": "Tøm visningshistorikk?",
|
||||||
|
"New password": "Nytt passord",
|
||||||
|
"New passwords must match": "Nye passordfelter må stemme overens",
|
||||||
|
"Cannot change password for Google accounts": "Kan ikke endre passord for Google-kontoer",
|
||||||
|
"Authorize token?": "Identitetsbekreft symbol?",
|
||||||
|
"Authorize token for `x`?": "Identitetsbekreft symbol for `x`?",
|
||||||
|
"Yes": "Ja",
|
||||||
|
"No": "Nei",
|
||||||
|
"Import and Export Data": "Importer- og eksporter data",
|
||||||
|
"Import": "Importer",
|
||||||
|
"Import Invidious data": "Importer Invidious-data",
|
||||||
|
"Import YouTube subscriptions": "Importer YouTube-abonnementer",
|
||||||
|
"Import FreeTube subscriptions (.db)": "Importer FreeTube-abonnementer (.db)",
|
||||||
|
"Import NewPipe subscriptions (.json)": "Importer NewPipe-abonnementer (.json)",
|
||||||
|
"Import NewPipe data (.zip)": "Importer NewPipe-data (.zip)",
|
||||||
|
"Export": "Eksporter",
|
||||||
|
"Export subscriptions as OPML": "Eksporter abonnementer som OPML",
|
||||||
|
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Eksporter abonnementer som OPML (for NewPipe og FreeTube)",
|
||||||
|
"Export data as JSON": "Eksporter data som JSON",
|
||||||
|
"Delete account?": "Slett konto?",
|
||||||
|
"History": "Historikk",
|
||||||
|
"An alternative front-end to YouTube": "En alternativ grenseflate for YouTube",
|
||||||
|
"JavaScript license information": "JavaScript-lisensinformasjon",
|
||||||
|
"source": "kilde",
|
||||||
|
"Log in": "Logg inn",
|
||||||
|
"Log in/register": "Logg inn/registrer",
|
||||||
|
"Log in with Google": "Logg inn med Google",
|
||||||
|
"User ID": "Bruker-ID",
|
||||||
|
"Password": "Passord",
|
||||||
|
"Time (h:mm:ss):": "Tid (h:mm:ss):",
|
||||||
|
"Text CAPTCHA": "Tekst-CAPTCHA",
|
||||||
|
"Image CAPTCHA": "Bilde-CAPTCHA",
|
||||||
|
"Sign In": "Innlogging",
|
||||||
|
"Register": "Registrer",
|
||||||
|
"E-mail": "E-post",
|
||||||
|
"Google verification code": "Google-bekreftelseskode",
|
||||||
|
"Preferences": "Innstillinger",
|
||||||
|
"Player preferences": "Avspillerinnstillinger",
|
||||||
|
"Always loop: ": "Alltid gjenta: ",
|
||||||
|
"Autoplay: ": "Autoavspilling: ",
|
||||||
|
"Play next by default: ": "Spill neste som forvalg: ",
|
||||||
|
"Autoplay next video: ": "Autospill neste video: ",
|
||||||
|
"Listen by default: ": "Lytt som forvalg: ",
|
||||||
|
"Proxy videos: ": "Mellomtjen videoer? ",
|
||||||
|
"Default speed: ": "Forvalgt hastighet: ",
|
||||||
|
"Preferred video quality: ": "Foretrukket videokvalitet: ",
|
||||||
|
"Player volume: ": "Avspillerlydstyrke: ",
|
||||||
|
"Default comments: ": "Forvalgte kommentarer: ",
|
||||||
|
"youtube": "YouTube",
|
||||||
|
"reddit": "Reddit",
|
||||||
|
"Default captions: ": "Forvalgte undertitler: ",
|
||||||
|
"Fallback captions: ": "Tilbakefallsundertitler: ",
|
||||||
|
"Show related videos: ": "Vis relaterte videoer? ",
|
||||||
|
"Show annotations by default: ": "Vis merknader som forvalg? ",
|
||||||
|
"Visual preferences": "Visuelle innstillinger",
|
||||||
|
"Player style: ": "Avspillerstil: ",
|
||||||
|
"Dark mode: ": "Mørk drakt: ",
|
||||||
|
"Theme: ": "Drakt: ",
|
||||||
|
"dark": "Mørk",
|
||||||
|
"light": "Lys",
|
||||||
|
"Thin mode: ": "Tynt modus: ",
|
||||||
|
"Subscription preferences": "Abonnementsinnstillinger",
|
||||||
|
"Show annotations by default for subscribed channels: ": "Vis merknader som forvalg for kanaler det abonneres på? ",
|
||||||
|
"Redirect homepage to feed: ": "Videresend hjemmeside til flyt: ",
|
||||||
|
"Number of videos shown in feed: ": "Antall videoer å vise i flyt: ",
|
||||||
|
"Sort videos by: ": "Sorter videoer etter: ",
|
||||||
|
"published": "publisert",
|
||||||
|
"published - reverse": "publisert - motsatt",
|
||||||
|
"alphabetically": "alfabetisk",
|
||||||
|
"alphabetically - reverse": "alfabetisk - motsatt",
|
||||||
|
"channel name": "kanalnavn",
|
||||||
|
"channel name - reverse": "kanalnavn - motsatt",
|
||||||
|
"Only show latest video from channel: ": "Kun vis siste video fra kanal: ",
|
||||||
|
"Only show latest unwatched video from channel: ": "Kun vis siste usette video fra kanal: ",
|
||||||
|
"Only show unwatched: ": "Kun vis usette: ",
|
||||||
|
"Only show notifications (if there are any): ": "Kun vis merknader (hvis det er noen): ",
|
||||||
|
"Enable web notifications": "Skru på nettmerknader",
|
||||||
|
"`x` uploaded a video": "`x` lastet opp en video",
|
||||||
|
"`x` is live": "`x` er pålogget",
|
||||||
|
"Data preferences": "Datainnstillinger",
|
||||||
|
"Clear watch history": "Tøm visningshistorikk",
|
||||||
|
"Import/export data": "Importer/eksporter data",
|
||||||
|
"Change password": "Endre passord",
|
||||||
|
"Manage subscriptions": "Behandle abonnementer",
|
||||||
|
"Manage tokens": "Behandle symboler",
|
||||||
|
"Watch history": "Visningshistorikk",
|
||||||
|
"Delete account": "Slett konto",
|
||||||
|
"Administrator preferences": "Administratorinnstillinger",
|
||||||
|
"Default homepage: ": "Forvalgt hjemmeside: ",
|
||||||
|
"Feed menu: ": "Flyt-meny: ",
|
||||||
|
"Top enabled: ": "Topp påskrudd? ",
|
||||||
|
"CAPTCHA enabled: ": "CAPTCHA påskrudd? ",
|
||||||
|
"Login enabled: ": "Innlogging påskrudd? ",
|
||||||
|
"Registration enabled: ": "Registrering påskrudd? ",
|
||||||
|
"Report statistics: ": "Innrapporter statistikk? ",
|
||||||
|
"Save preferences": "Lagre innstillinger",
|
||||||
|
"Subscription manager": "Abonnementsbehandler",
|
||||||
|
"Token manager": "Symbolbehandler",
|
||||||
|
"Token": "Symbol",
|
||||||
|
"`x` subscriptions": "`x` abonnementer",
|
||||||
|
"`x` tokens": "`x` symboler",
|
||||||
|
"Import/export": "Importer/eksporter",
|
||||||
|
"unsubscribe": "opphev abonnement",
|
||||||
|
"revoke": "tilbakekall",
|
||||||
|
"Subscriptions": "Abonnement",
|
||||||
|
"`x` unseen notifications": "`x` usette merknader",
|
||||||
|
"search": "søk",
|
||||||
|
"Log out": "Logg ut",
|
||||||
|
"Released under the AGPLv3 by Omar Roth.": "Utgitt med AGPLv3+lisens av Omar Roth.",
|
||||||
|
"Source available here.": "Kildekode tilgjengelig her.",
|
||||||
|
"View JavaScript license information.": "Vis JavaScript-lisensinfo.",
|
||||||
|
"View privacy policy.": "Vis personvernspraksis.",
|
||||||
|
"Trending": "Trendsettende",
|
||||||
|
"Public": "Offentlig",
|
||||||
|
"Unlisted": "Ulistet",
|
||||||
|
"Private": "Privat",
|
||||||
|
"View all playlists": "Vis alle spillelister",
|
||||||
|
"Updated `x` ago": "Oppdatert `x` siden",
|
||||||
|
"Delete playlist `x`?": "Slett spillelisten `x`?",
|
||||||
|
"Delete playlist": "Slett spilleliste",
|
||||||
|
"Create playlist": "Opprett spilleliste",
|
||||||
|
"Title": "Tittel",
|
||||||
|
"Playlist privacy": "Vern av spilleliste",
|
||||||
|
"Editing playlist `x`": "Redigerer spillelisten `x`",
|
||||||
|
"Watch on YouTube": "Vis video på YouTube",
|
||||||
|
"Hide annotations": "Skjul merknader",
|
||||||
|
"Show annotations": "Vis merknader",
|
||||||
|
"Genre: ": "Sjanger: ",
|
||||||
|
"License: ": "Lisens: ",
|
||||||
|
"Family friendly? ": "Familievennlig? ",
|
||||||
|
"Wilson score: ": "Wilson-poengsum: ",
|
||||||
|
"Engagement: ": "Engasjement: ",
|
||||||
|
"Whitelisted regions: ": "Hvitlistede regioner: ",
|
||||||
|
"Blacklisted regions: ": "Svartelistede regioner: ",
|
||||||
|
"Shared `x`": "Delt `x`",
|
||||||
|
"`x` views": "`x` visninger",
|
||||||
|
"Premieres in `x`": "Premiere om `x`",
|
||||||
|
"Premieres `x`": "Première `x`",
|
||||||
|
"Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.": "Hei. Det ser ut til at du har JavaScript avslått. Klikk her for å vise kommentarer, ha i minnet at innlasting tar lengre tid.",
|
||||||
|
"View YouTube comments": "Vis YouTube-kommentarer",
|
||||||
|
"View more comments on Reddit": "Vis flere kommenterer på Reddit",
|
||||||
|
"View `x` comments": "Vis `x` kommentarer",
|
||||||
|
"View Reddit comments": "Vis Reddit-kommentarer",
|
||||||
|
"Hide replies": "Skjul svar",
|
||||||
|
"Show replies": "Vis svar",
|
||||||
|
"Incorrect password": "Feil passord",
|
||||||
|
"Quota exceeded, try again in a few hours": "Kvote overskredet, prøv igjen om et par timer",
|
||||||
|
"Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.": "Kunne ikke logge inn, forsikre deg om at tofaktor-identitetsbekreftelse (Authenticator eller SMS) er skrudd på.",
|
||||||
|
"Invalid TFA code": "Ugyldig tofaktorkode",
|
||||||
|
"Login failed. This may be because two-factor authentication is not turned on for your account.": "Innlogging mislyktes. Dette kan være fordi tofaktor-identitetsbekreftelse er skrudd av på kontoen din.",
|
||||||
|
"Wrong answer": "Ugyldig svar",
|
||||||
|
"Erroneous CAPTCHA": "Ugyldig CAPTCHA",
|
||||||
|
"CAPTCHA is a required field": "CAPTCHA er et påkrevd felt",
|
||||||
|
"User ID is a required field": "Bruker-ID er et påkrevd felt",
|
||||||
|
"Password is a required field": "Passord er et påkrevd felt",
|
||||||
|
"Wrong username or password": "Ugyldig brukernavn eller passord",
|
||||||
|
"Please sign in using 'Log in with Google'": "Logg inn ved bruk av \"Google-innlogging\"",
|
||||||
|
"Password cannot be empty": "Passordet kan ikke være tomt",
|
||||||
|
"Password cannot be longer than 55 characters": "Passordet kan ikke være lengre enn 55 tegn",
|
||||||
|
"Please log in": "Logg inn",
|
||||||
|
"Invidious Private Feed for `x`": "Ugyldig privat flyt for `x`",
|
||||||
|
"channel:`x`": "kanal `x`",
|
||||||
|
"Deleted or invalid channel": "Slettet eller ugyldig kanal",
|
||||||
|
"This channel does not exist.": "Denne kanalen finnes ikke.",
|
||||||
|
"Could not get channel info.": "Kunne ikke innhente kanalinfo.",
|
||||||
|
"Could not fetch comments": "Kunne ikke hente kommentarer",
|
||||||
|
"View `x` replies": "Vis `x` svar",
|
||||||
|
"`x` ago": "`x` siden",
|
||||||
|
"Load more": "Last inn flere",
|
||||||
|
"`x` points": "`x` poeng",
|
||||||
|
"Could not create mix.": "Kunne ikke opprette miks.",
|
||||||
|
"Empty playlist": "Spillelisten er tom",
|
||||||
|
"Not a playlist.": "Ugyldig spilleliste.",
|
||||||
|
"Playlist does not exist.": "Spillelisten finnes ikke.",
|
||||||
|
"Could not pull trending pages.": "Kunne ikke hente trendsettende sider.",
|
||||||
|
"Hidden field \"challenge\" is a required field": "Skjult felt \"utfordring\" er et påkrevd felt",
|
||||||
|
"Hidden field \"token\" is a required field": "Skjult felt \"symbol\" er et påkrevd felt",
|
||||||
|
"Erroneous challenge": "Ugyldig utfordring",
|
||||||
|
"Erroneous token": "Ugyldig symbol",
|
||||||
|
"No such user": "Ugyldig bruker",
|
||||||
|
"Token is expired, please try again": "Symbol utløpt, prøv igjen",
|
||||||
|
"English": "Engelsk",
|
||||||
|
"English (auto-generated)": "Engelsk (auto-generert)",
|
||||||
|
"Afrikaans": "Afrikansk",
|
||||||
|
"Albanian": "Albansk",
|
||||||
|
"Amharic": "Amharisk",
|
||||||
|
"Arabic": "Arabisk",
|
||||||
|
"Armenian": "Armensk",
|
||||||
|
"Azerbaijani": "Aserbajdsjansk",
|
||||||
|
"Bangla": "",
|
||||||
|
"Basque": "",
|
||||||
|
"Belarusian": "Hviterussisk",
|
||||||
|
"Bosnian": "Bosnisk",
|
||||||
|
"Bulgarian": "Bulgarsk",
|
||||||
|
"Burmese": "Burmesisk",
|
||||||
|
"Catalan": "Katalansk",
|
||||||
|
"Cebuano": "",
|
||||||
|
"Chinese (Simplified)": "",
|
||||||
|
"Chinese (Traditional)": "",
|
||||||
|
"Corsican": "",
|
||||||
|
"Croatian": "",
|
||||||
|
"Czech": "Tsjekkisk",
|
||||||
|
"Danish": "Dansk",
|
||||||
|
"Dutch": "Nederlandsk",
|
||||||
|
"Esperanto": "Esperanto",
|
||||||
|
"Estonian": "Estisk",
|
||||||
|
"Filipino": "Filippinsk",
|
||||||
|
"Finnish": "Finsk",
|
||||||
|
"French": "Fransk",
|
||||||
|
"Galician": "",
|
||||||
|
"Georgian": "",
|
||||||
|
"German": "Tysk",
|
||||||
|
"Greek": "Gresk",
|
||||||
|
"Gujarati": "",
|
||||||
|
"Haitian Creole": "",
|
||||||
|
"Hausa": "",
|
||||||
|
"Hawaiian": "",
|
||||||
|
"Hebrew": "",
|
||||||
|
"Hindi": "",
|
||||||
|
"Hmong": "",
|
||||||
|
"Hungarian": "Ungarsk",
|
||||||
|
"Icelandic": "Islandsk",
|
||||||
|
"Igbo": "",
|
||||||
|
"Indonesian": "Indonesisk",
|
||||||
|
"Irish": "Irsk",
|
||||||
|
"Italian": "Italiensk",
|
||||||
|
"Japanese": "Japansk",
|
||||||
|
"Javanese": "",
|
||||||
|
"Kannada": "",
|
||||||
|
"Kazakh": "",
|
||||||
|
"Khmer": "",
|
||||||
|
"Korean": "",
|
||||||
|
"Kurdish": "",
|
||||||
|
"Kyrgyz": "",
|
||||||
|
"Lao": "",
|
||||||
|
"Latin": "",
|
||||||
|
"Latvian": "",
|
||||||
|
"Lithuanian": "",
|
||||||
|
"Luxembourgish": "",
|
||||||
|
"Macedonian": "",
|
||||||
|
"Malagasy": "",
|
||||||
|
"Malay": "",
|
||||||
|
"Malayalam": "",
|
||||||
|
"Maltese": "",
|
||||||
|
"Maori": "",
|
||||||
|
"Marathi": "",
|
||||||
|
"Mongolian": "",
|
||||||
|
"Nepali": "",
|
||||||
|
"Norwegian Bokmål": "Norsk bokmål",
|
||||||
|
"Nyanja": "",
|
||||||
|
"Pashto": "",
|
||||||
|
"Persian": "",
|
||||||
|
"Polish": "",
|
||||||
|
"Portuguese": "",
|
||||||
|
"Punjabi": "",
|
||||||
|
"Romanian": "",
|
||||||
|
"Russian": "Russisk",
|
||||||
|
"Samoan": "",
|
||||||
|
"Scottish Gaelic": "",
|
||||||
|
"Serbian": "Serbisk",
|
||||||
|
"Shona": "",
|
||||||
|
"Sindhi": "",
|
||||||
|
"Sinhala": "",
|
||||||
|
"Slovak": "Slovakisk",
|
||||||
|
"Slovenian": "Slovensk",
|
||||||
|
"Somali": "Somali",
|
||||||
|
"Southern Sotho": "",
|
||||||
|
"Spanish": "Spansk",
|
||||||
|
"Spanish (Latin America)": "",
|
||||||
|
"Sundanese": "",
|
||||||
|
"Swahili": "",
|
||||||
|
"Swedish": "Svensk",
|
||||||
|
"Tajik": "",
|
||||||
|
"Tamil": "",
|
||||||
|
"Telugu": "",
|
||||||
|
"Thai": "",
|
||||||
|
"Turkish": "Tyrkisk",
|
||||||
|
"Ukrainian": "Ukrainsk",
|
||||||
|
"Urdu": "",
|
||||||
|
"Uzbek": "",
|
||||||
|
"Vietnamese": "Vietnamesisk",
|
||||||
|
"Welsh": "",
|
||||||
|
"Western Frisian": "",
|
||||||
|
"Xhosa": "",
|
||||||
|
"Yiddish": "",
|
||||||
|
"Yoruba": "",
|
||||||
|
"Zulu": "",
|
||||||
|
"`x` years": "`x` år",
|
||||||
|
"`x` months": "`x` måneder",
|
||||||
|
"`x` weeks": "`x` uker",
|
||||||
|
"`x` days": "`x` dager",
|
||||||
|
"`x` hours": "`x` timer",
|
||||||
|
"`x` minutes": "`x` minutter",
|
||||||
|
"`x` seconds": "`x` sekunder",
|
||||||
|
"Fallback comments: ": "Tilbakefallskommentarer: ",
|
||||||
|
"Popular": "Populært",
|
||||||
|
"Top": "Topp",
|
||||||
|
"About": "Om",
|
||||||
|
"Rating: ": "Vurdering: ",
|
||||||
|
"Language: ": "Språk: ",
|
||||||
|
"View as playlist": "Vis som spilleliste",
|
||||||
|
"Default": "Forvalg",
|
||||||
|
"Music": "Musikk",
|
||||||
|
"Gaming": "Spill",
|
||||||
|
"News": "Nyheter",
|
||||||
|
"Movies": "Filmer",
|
||||||
|
"Download": "Last ned",
|
||||||
|
"Download as: ": "Last ned som: ",
|
||||||
|
"%A %B %-d, %Y": "",
|
||||||
|
"(edited)": "(redigert)",
|
||||||
|
"YouTube comment permalink": "Permanent YouTube-lenke til innholdet",
|
||||||
|
"permalink": "permanent lenke",
|
||||||
|
"`x` marked it with a ❤": "`x` levnet et ❤",
|
||||||
|
"Audio mode": "Lydmodus",
|
||||||
|
"Video mode": "Video-modus",
|
||||||
|
"Videos": "Videoer",
|
||||||
|
"Playlists": "Spillelister",
|
||||||
|
"Community": "Gemenskap",
|
||||||
|
"Current version: ": "Nåværende versjon: "
|
||||||
|
}
|
||||||
@@ -1,288 +0,0 @@
|
|||||||
{
|
|
||||||
"`x` subscribers": "`x` abonnenter",
|
|
||||||
"`x` videos": "`x` videoer",
|
|
||||||
"LIVE": "SANNTIDSVISNING",
|
|
||||||
"Shared `x` ago": "Delt for `x` siden",
|
|
||||||
"Unsubscribe": "Opphev abonnement",
|
|
||||||
"Subscribe": "Abonner",
|
|
||||||
"Login to subscribe to `x`": "Logg inn for å abonnere på `x`",
|
|
||||||
"View channel on YouTube": "Vis kanal på YouTube",
|
|
||||||
"newest": "nyeste",
|
|
||||||
"oldest": "eldste",
|
|
||||||
"popular": "populært",
|
|
||||||
"Preview page": "Forhåndsvis side",
|
|
||||||
"Next page": "Neste side",
|
|
||||||
"Clear watch history?": "Tøm visningshistorikk?",
|
|
||||||
"Yes": "Ja",
|
|
||||||
"No": "Nei",
|
|
||||||
"Import and Export Data": "Importer- og eksporter data",
|
|
||||||
"Import": "Importer",
|
|
||||||
"Import Invidious data": "Importer Invidious-data",
|
|
||||||
"Import YouTube subscriptions": "Importer YouTube-abonnenter",
|
|
||||||
"Import FreeTube subscriptions (.db)": "Importer FreeTube-abonnenter (.db)",
|
|
||||||
"Import NewPipe subscriptions (.json)": "Importer NewPipe-abonnenter (.json)",
|
|
||||||
"Import NewPipe data (.zip)": "Importer NewPipe-data (.zip)",
|
|
||||||
"Export": "Eksporter",
|
|
||||||
"Export subscriptions as OPML": "Eksporter abonnenter som OPML",
|
|
||||||
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Eksporter abonnenter som OPML (for NewPipe og FreeTube)",
|
|
||||||
"Export data as JSON": "Eksporter data som JSON",
|
|
||||||
"Delete account?": "Slett konto?",
|
|
||||||
"History": "Historikk",
|
|
||||||
"Previous page": "Forrige side",
|
|
||||||
"An alternative front-end to YouTube": "En alternativ grenseflate for YouTube",
|
|
||||||
"JavaScript license information": "JavaScript-lisensinformasjon",
|
|
||||||
"source": "kilde",
|
|
||||||
"Login": "Logg inn",
|
|
||||||
"Login/Register": "Logg inn/registrer",
|
|
||||||
"Login to Google": "Logg inn med Google",
|
|
||||||
"User ID:": "Bruker-ID:",
|
|
||||||
"Password:": "Passord:",
|
|
||||||
"Time (h:mm:ss):": "Tid (h:mm:ss):",
|
|
||||||
"Text CAPTCHA": "Tekst-CAPTCHA",
|
|
||||||
"Image CAPTCHA": "Bilde-CAPTCHA",
|
|
||||||
"Sign In": "Innlogging",
|
|
||||||
"Register": "Registrer",
|
|
||||||
"Email:": "E-post:",
|
|
||||||
"Google verification code:": "Google-bekreftelseskode:",
|
|
||||||
"Preferences": "Innstillinger",
|
|
||||||
"Player preferences": "Avspillerinnstillinger",
|
|
||||||
"Always loop: ": "Alltid gjenta: ",
|
|
||||||
"Autoplay: ": "Autoavspilling: ",
|
|
||||||
"Autoplay next video: ": "Autospill neste video: ",
|
|
||||||
"Listen by default: ": "Lytt som forvalg: ",
|
|
||||||
"Default speed: ": "Forvalgt hastighet: ",
|
|
||||||
"Preferred video quality: ": "Foretrukket videokvalitet: ",
|
|
||||||
"Player volume: ": "Avspillerlydstyrke: ",
|
|
||||||
"Default comments: ": "Forvalgte kommentarer: ",
|
|
||||||
"Default captions: ": "Forvalgte undertitler: ",
|
|
||||||
"Fallback captions: ": "Tilbakefallsundertitler: ",
|
|
||||||
"Show related videos? ": "Vis relaterte videoer? ",
|
|
||||||
"Visual preferences": "Visuelle innstillinger",
|
|
||||||
"Dark mode: ": "Mørk drakt: ",
|
|
||||||
"Thin mode: ": "Tynt modus: ",
|
|
||||||
"Subscription preferences": "Abonnementsinnstillinger",
|
|
||||||
"Redirect homepage to feed: ": "Videresend hjemmeside til flyt: ",
|
|
||||||
"Number of videos shown in feed: ": "Antall videoer å vise i flyt: ",
|
|
||||||
"Sort videos by: ": "Sorter videoer etter: ",
|
|
||||||
"published": "publisert",
|
|
||||||
"published - reverse": "publisert - motsatt",
|
|
||||||
"alphabetically": "alfabetisk",
|
|
||||||
"alphabetically - reverse": "alfabetisk - motsatt",
|
|
||||||
"channel name": "kanalnavn",
|
|
||||||
"channel name - reverse": "kanalnavn - motsatt",
|
|
||||||
"Only show latest video from channel: ": "Kun vis siste video fra kanal: ",
|
|
||||||
"Only show latest unwatched video from channel: ": "Kun vis siste usette video fra kanal: ",
|
|
||||||
"Only show unwatched: ": "Kun vis usette: ",
|
|
||||||
"Only show notifications (if there are any): ": "Kun vis merknader (hvis det er noen): ",
|
|
||||||
"Data preferences": "Datainnstillinger",
|
|
||||||
"Clear watch history": "Tøm visningshistorikk",
|
|
||||||
"Import/Export data": "Importer/eksporter data",
|
|
||||||
"Manage subscriptions": "Behandle abonnementer",
|
|
||||||
"Watch history": "Visningshistorikk",
|
|
||||||
"Delete account": "Slett konto",
|
|
||||||
"Administrator preferences": "Administratorinnstillinger",
|
|
||||||
"Default homepage: ": "Forvalgt hjemmeside: ",
|
|
||||||
"Feed menu: ": "Flyt-meny: ",
|
|
||||||
"Top enabled? ": "",
|
|
||||||
"CAPTCHA enabled? ": "CAPTCHA påskrudd? ",
|
|
||||||
"Login enabled? ": "Innlogging påskrudd? ",
|
|
||||||
"Registration enabled? ": "Registrering påskrudd? ",
|
|
||||||
"Report statistics? ": "",
|
|
||||||
"Save preferences": "Lagre innstillinger",
|
|
||||||
"Subscription manager": "Abonnementsbehandler",
|
|
||||||
"`x` subscriptions": "`x` abonnementer",
|
|
||||||
"Import/Export": "Importer/eksporter",
|
|
||||||
"unsubscribe": "opphev abonnement",
|
|
||||||
"Subscriptions": "Abonnement",
|
|
||||||
"`x` unseen notifications": "`x` usette merknader",
|
|
||||||
"search": "søk",
|
|
||||||
"Sign out": "Logg ut",
|
|
||||||
"Released under the AGPLv3 by Omar Roth.": "Utgitt med AGPLv3+lisens av Omar Roth.",
|
|
||||||
"Source available here.": "Kildekode tilgjengelig her.",
|
|
||||||
"View JavaScript license information.": "Vis JavaScript-lisensinfo.",
|
|
||||||
"Trending": "Trendsettende",
|
|
||||||
"Watch video on Youtube": "Vis video på YouTube",
|
|
||||||
"Genre: ": "Sjanger: ",
|
|
||||||
"License: ": "Lisens: ",
|
|
||||||
"Family friendly? ": "Familievennlig? ",
|
|
||||||
"Wilson score: ": "Wilson-poengsum: ",
|
|
||||||
"Engagement: ": "Engasjement: ",
|
|
||||||
"Whitelisted regions: ": "Hvitlistede regioner: ",
|
|
||||||
"Blacklisted regions: ": "Svartelistede regioner: ",
|
|
||||||
"Shared `x`": "Delt `x`",
|
|
||||||
"Hi! Looks like you have JavaScript disabled. Click here to view comments, keep in mind it may take a bit longer to load.": "Hei. Det ser ut til at du har JavaScript avslått. Klikk her for å vise kommentarer, ha i minnet at innlasting tar lengre tid.",
|
|
||||||
"View YouTube comments": "Vis YouTube-kommentarer",
|
|
||||||
"View more comments on Reddit": "Vis flere kommenterer på Reddit",
|
|
||||||
"View `x` comments": "Vis `x` kommentarer",
|
|
||||||
"View Reddit comments": "Vis Reddit-kommentarer",
|
|
||||||
"Hide replies": "Skjul svar",
|
|
||||||
"Show replies": "Vis svar",
|
|
||||||
"Incorrect password": "Feil passord",
|
|
||||||
"Quota exceeded, try again in a few hours": "Kvote overskredet, prøv igjen om et par timer",
|
|
||||||
"Unable to login, make sure two-factor authentication (Authenticator or SMS) is enabled.": "Kunne ikke logge inn, forsikre deg om at tofaktor-identitetsbekreftelse (Authenticator eller SMS) er skrudd på.",
|
|
||||||
"Invalid TFA code": "Ugyldig tofaktorkode",
|
|
||||||
"Login failed. This may be because two-factor authentication is not enabled on your account.": "Innlogging mislyktes. Dette kan være fordi tofaktor-identitetsbekreftelse er skrudd av på kontoen din.",
|
|
||||||
"Invalid answer": "Ugyldig svar",
|
|
||||||
"Invalid CAPTCHA": "Ugyldig CAPTCHA",
|
|
||||||
"CAPTCHA is a required field": "CAPTCHA er et påkrevd felt",
|
|
||||||
"User ID is a required field": "Bruker-ID er et påkrevd felt",
|
|
||||||
"Password is a required field": "Passord er et påkrevd felt",
|
|
||||||
"Invalid username or password": "Ugyldig brukernavn eller passord",
|
|
||||||
"Please sign in using 'Sign in with Google'": "Logg inn ved bruk av \"Google-innlogging\"",
|
|
||||||
"Password cannot be empty": "Passordet kan ikke være tomt",
|
|
||||||
"Password cannot be longer than 55 characters": "Passordet kan ikke være lengre enn 55 tegn",
|
|
||||||
"Please sign in": "Logg inn",
|
|
||||||
"Invidious Private Feed for `x`": "Ugyldig privat flyt for `x`",
|
|
||||||
"channel:`x`": "kanal `x`",
|
|
||||||
"Deleted or invalid channel": "Slettet eller ugyldig kanal",
|
|
||||||
"This channel does not exist.": "Denne kanalen finnes ikke.",
|
|
||||||
"Could not get channel info.": "Kunne ikke innhente kanalinfo.",
|
|
||||||
"Could not fetch comments": "Kunne ikke hente kommentarer",
|
|
||||||
"View `x` replies": "Vis `x` svar",
|
|
||||||
"`x` ago": "`x` siden",
|
|
||||||
"Load more": "Last inn flere",
|
|
||||||
"`x` points": "`x` poeng",
|
|
||||||
"Could not create mix.": "Kunne ikke opprette miks.",
|
|
||||||
"Playlist is empty": "Spillelisten er tom",
|
|
||||||
"Invalid playlist.": "Ugyldig spilleliste.",
|
|
||||||
"Playlist does not exist.": "Spillelisten finnes ikke.",
|
|
||||||
"Could not pull trending pages.": "Kunne ikke hente trendsettende sider.",
|
|
||||||
"Hidden field \"challenge\" is a required field": "Skjult felt \"utfordring\" er et påkrevd felt",
|
|
||||||
"Hidden field \"token\" is a required field": "Skjult felt \"symbol\" er et påkrevd felt",
|
|
||||||
"Invalid challenge": "Ugyldig utfordring",
|
|
||||||
"Invalid token": "Ugyldig symbol",
|
|
||||||
"Invalid user": "Ugyldig bruker",
|
|
||||||
"Token is expired, please try again": "Symbol utløpt, prøv igjen",
|
|
||||||
"English": "Engelsk",
|
|
||||||
"English (auto-generated)": "Engelsk (auto-generert)",
|
|
||||||
"Afrikaans": "",
|
|
||||||
"Albanian": "Albansk",
|
|
||||||
"Amharic": "",
|
|
||||||
"Arabic": "Arabisk",
|
|
||||||
"Armenian": "Armensk",
|
|
||||||
"Azerbaijani": "",
|
|
||||||
"Bangla": "",
|
|
||||||
"Basque": "",
|
|
||||||
"Belarusian": "Hviterussisk",
|
|
||||||
"Bosnian": "Bosnisk",
|
|
||||||
"Bulgarian": "Bulgarsk",
|
|
||||||
"Burmese": "Burmesisk",
|
|
||||||
"Catalan": "Katalansk",
|
|
||||||
"Cebuano": "",
|
|
||||||
"Chinese (Simplified)": "",
|
|
||||||
"Chinese (Traditional)": "",
|
|
||||||
"Corsican": "",
|
|
||||||
"Croatian": "",
|
|
||||||
"Czech": "Tsjekkisk",
|
|
||||||
"Danish": "Dansk",
|
|
||||||
"Dutch": "",
|
|
||||||
"Esperanto": "Esperanto",
|
|
||||||
"Estonian": "",
|
|
||||||
"Filipino": "",
|
|
||||||
"Finnish": "Finsk",
|
|
||||||
"French": "Fransk",
|
|
||||||
"Galician": "",
|
|
||||||
"Georgian": "",
|
|
||||||
"German": "",
|
|
||||||
"Greek": "",
|
|
||||||
"Gujarati": "",
|
|
||||||
"Haitian Creole": "",
|
|
||||||
"Hausa": "",
|
|
||||||
"Hawaiian": "",
|
|
||||||
"Hebrew": "",
|
|
||||||
"Hindi": "",
|
|
||||||
"Hmong": "",
|
|
||||||
"Hungarian": "Ungarsk",
|
|
||||||
"Icelandic": "Islandsk",
|
|
||||||
"Igbo": "",
|
|
||||||
"Indonesian": "Indonesisk",
|
|
||||||
"Irish": "Irsk",
|
|
||||||
"Italian": "Italiensk",
|
|
||||||
"Japanese": "Japansk",
|
|
||||||
"Javanese": "",
|
|
||||||
"Kannada": "",
|
|
||||||
"Kazakh": "",
|
|
||||||
"Khmer": "",
|
|
||||||
"Korean": "",
|
|
||||||
"Kurdish": "",
|
|
||||||
"Kyrgyz": "",
|
|
||||||
"Lao": "",
|
|
||||||
"Latin": "",
|
|
||||||
"Latvian": "",
|
|
||||||
"Lithuanian": "",
|
|
||||||
"Luxembourgish": "",
|
|
||||||
"Macedonian": "",
|
|
||||||
"Malagasy": "",
|
|
||||||
"Malay": "",
|
|
||||||
"Malayalam": "",
|
|
||||||
"Maltese": "",
|
|
||||||
"Maori": "",
|
|
||||||
"Marathi": "",
|
|
||||||
"Mongolian": "",
|
|
||||||
"Nepali": "",
|
|
||||||
"Norwegian": "Norsk bokmål",
|
|
||||||
"Nyanja": "",
|
|
||||||
"Pashto": "",
|
|
||||||
"Persian": "",
|
|
||||||
"Polish": "",
|
|
||||||
"Portuguese": "",
|
|
||||||
"Punjabi": "",
|
|
||||||
"Romanian": "",
|
|
||||||
"Russian": "Russisk",
|
|
||||||
"Samoan": "",
|
|
||||||
"Scottish Gaelic": "",
|
|
||||||
"Serbian": "Serbisk",
|
|
||||||
"Shona": "",
|
|
||||||
"Sindhi": "",
|
|
||||||
"Sinhala": "",
|
|
||||||
"Slovak": "Slovakisk",
|
|
||||||
"Slovenian": "Slovensk",
|
|
||||||
"Somali": "Somali",
|
|
||||||
"Southern Sotho": "",
|
|
||||||
"Spanish": "Spansk",
|
|
||||||
"Spanish (Latin America)": "",
|
|
||||||
"Sundanese": "",
|
|
||||||
"Swahili": "",
|
|
||||||
"Swedish": "Svensk",
|
|
||||||
"Tajik": "",
|
|
||||||
"Tamil": "",
|
|
||||||
"Telugu": "",
|
|
||||||
"Thai": "",
|
|
||||||
"Turkish": "Tyrkisk",
|
|
||||||
"Ukrainian": "Ukrainsk",
|
|
||||||
"Urdu": "",
|
|
||||||
"Uzbek": "",
|
|
||||||
"Vietnamese": "Vietnamesisk",
|
|
||||||
"Welsh": "",
|
|
||||||
"Western Frisian": "",
|
|
||||||
"Xhosa": "",
|
|
||||||
"Yiddish": "",
|
|
||||||
"Yoruba": "",
|
|
||||||
"Zulu": "",
|
|
||||||
"`x` years": "`x` år",
|
|
||||||
"`x` months": "`x` måneder",
|
|
||||||
"`x` weeks": "`x` uker",
|
|
||||||
"`x` days": "`x` dager",
|
|
||||||
"`x` hours": "`x` timer",
|
|
||||||
"`x` minutes": "`x` minutter",
|
|
||||||
"`x` seconds": "`x` sekunder",
|
|
||||||
"Fallback comments: ": "Tilbakefallskommentarer: ",
|
|
||||||
"Popular": "Pupulært",
|
|
||||||
"Top": "Topp",
|
|
||||||
"About": "Om",
|
|
||||||
"Rating: ": "Vurdering: ",
|
|
||||||
"Language: ": "Språk: ",
|
|
||||||
"Default": "Forvalg",
|
|
||||||
"Music": "Musikk",
|
|
||||||
"Gaming": "Spill",
|
|
||||||
"News": "Nyheter",
|
|
||||||
"Movies": "Filmer",
|
|
||||||
"Download": "Last ned",
|
|
||||||
"Download as: ": "Last ned som: ",
|
|
||||||
"%A %B %-d, %Y": "",
|
|
||||||
"(edited)": "(redigert)",
|
|
||||||
"Youtube permalink of the comment": "Permanent YouTube-lenke til innholdet",
|
|
||||||
"`x` marked it with a ❤": "`x` levnet et ❤",
|
|
||||||
"Audio mode": "Lydmodus",
|
|
||||||
"Video mode": "Video-modus"
|
|
||||||
}
|
|
||||||
623
locales/nl.json
623
locales/nl.json
@@ -1,288 +1,337 @@
|
|||||||
{
|
{
|
||||||
"`x` subscribers": "`x` abonnees",
|
"`x` subscribers": "`x` abonnees",
|
||||||
"`x` videos": "`x` videos",
|
"`x` videos": "`x` video's",
|
||||||
"LIVE": "LIVE",
|
"`x` playlists": "`x` afspeellijsten",
|
||||||
"Shared `x` ago": "Gedeeld `x` geleden",
|
"LIVE": "LIVE",
|
||||||
"Unsubscribe": "Abonnement opzeggen",
|
"Shared `x` ago": "Gedeeld: `x` geleden",
|
||||||
"Subscribe": "Abonneren",
|
"Unsubscribe": "Deabonneren",
|
||||||
"Login to subscribe to `x`": "Log in om te abonneren op `x`",
|
"Subscribe": "Abonneren",
|
||||||
"View channel on YouTube": "Bekijk kanaal op Youtube",
|
"View channel on YouTube": "Bekijk kanaal op YouTube",
|
||||||
"newest": "nieuwste",
|
"View playlist on YouTube": "Bekijk afspeellijst op YouTube",
|
||||||
"oldest": "oudste",
|
"newest": "nieuwste",
|
||||||
"popular": "populair",
|
"oldest": "oudste",
|
||||||
"Preview page": "Pagina voorvertonen",
|
"popular": "populair",
|
||||||
"Next page": "Volgende pagina",
|
"last": "laatste",
|
||||||
"Clear watch history?": "Kijk geschiedenis wissen?",
|
"Next page": "Volgende pagina",
|
||||||
"Yes": "Ja",
|
"Previous page": "Vorige pagina",
|
||||||
"No": "Nee",
|
"Clear watch history?": "Wil je de kijkgeschiedenis wissen?",
|
||||||
"Import and Export Data": "Importeer en Exporteer Gegevens",
|
"New password": "Nieuw wachtwoord",
|
||||||
"Import": "Importeren",
|
"New passwords must match": "De nieuwe wachtwoorden moeten overeenkomen",
|
||||||
"Import Invidious data": "Importeer Invidious gegevens",
|
"Cannot change password for Google accounts": "Kan het wachtwoord van Google-accounts niet wijzigen",
|
||||||
"Import YouTube subscriptions": "Importeer Youtube abonnees",
|
"Authorize token?": "Wil je de toegangssleutel machtigen?",
|
||||||
"Import FreeTube subscriptions (.db)": "Importeer FreeTube abonnees (.db)",
|
"Authorize token for `x`?": "Wil je de toegangssleutel machtigen voor `x`?",
|
||||||
"Import NewPipe subscriptions (.json)": "Importeer NewPipe abonnees (.json)",
|
"Yes": "Ja",
|
||||||
"Import NewPipe data (.zip)": "Importeer NewPipe gegevens (.zip)",
|
"No": "Nee",
|
||||||
"Export": "Exporteren",
|
"Import and Export Data": "Gegevens im- en exporteren",
|
||||||
"Export subscriptions as OPML": "Exporteer abonnees als OPML",
|
"Import": "Importeren",
|
||||||
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Exporteer abonnees als OPML (voor NewPipe & FreeTube)",
|
"Import Invidious data": "Invidious-gegevens importeren",
|
||||||
"Export data as JSON": "Exporteer gegevens als JSON",
|
"Import YouTube subscriptions": "YouTube-abonnementen importeren",
|
||||||
"Delete account?": "Verwijder account?",
|
"Import FreeTube subscriptions (.db)": "FreeTube-abonnementen importeren (.db)",
|
||||||
"History": "Geschiedenis",
|
"Import NewPipe subscriptions (.json)": "NewPipe-abonnementen importeren (.json)",
|
||||||
"Previous page": "Vorige pagina",
|
"Import NewPipe data (.zip)": "NewPipe-gegevens importeren (.zip)",
|
||||||
"An alternative front-end to YouTube": "Een alternatieve front-end voor YouTube",
|
"Export": "Exporteren",
|
||||||
"JavaScript license information": "JavaScript licentie informatie",
|
"Export subscriptions as OPML": "Abonnementen exporteren als OPML",
|
||||||
"source": "bron",
|
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Abonnementen exporteren als OPML (voor NewPipe en FreeTube)",
|
||||||
"Login": "Inloggen",
|
"Export data as JSON": "Gegevens exporteren als JSON",
|
||||||
"Login/Register": "Inloggen/Registreren",
|
"Delete account?": "Wil je je account verwijderen?",
|
||||||
"Login to Google": "Inloggen op Google",
|
"History": "Geschiedenis",
|
||||||
"User ID:": "Gebruiker ID:",
|
"An alternative front-end to YouTube": "Een alternatief front-end voor YouTube",
|
||||||
"Password:": "Wachtwoord:",
|
"JavaScript license information": "JavaScript-licentieinformatie",
|
||||||
"Time (h:mm:ss):": "Tijd (h:mm:ss):",
|
"source": "bron",
|
||||||
"Text CAPTCHA": "Tekst CAPTCHA",
|
"Log in": "Inloggen",
|
||||||
"Image CAPTCHA": "Afbeelding CAPTCHA",
|
"Log in/register": "Inloggen/Registreren",
|
||||||
"Sign In": "Aanmelden",
|
"Log in with Google": "Inloggen met Google",
|
||||||
"Register": "Registreren",
|
"User ID": "Gebruikers-id",
|
||||||
"Email:": "Email:",
|
"Password": "Wachtwoord",
|
||||||
"Google verification code:": "Google verificatie code:",
|
"Time (h:mm:ss):": "Tijd (h:mm:ss):",
|
||||||
"Preferences": "Voorkeuren",
|
"Text CAPTCHA": "Tekst-CAPTCHA",
|
||||||
"Player preferences": "Afspeler voorkeuren",
|
"Image CAPTCHA": "Afbeelding-CAPTCHA",
|
||||||
"Always loop: ": "Altijd herhalen: ",
|
"Sign In": "Inloggen",
|
||||||
"Autoplay: ": "Automatisch afspelen: ",
|
"Register": "Registreren",
|
||||||
"Autoplay next video: ": "Automatisch volgende video afspelen: ",
|
"E-mail": "E-mailadres",
|
||||||
"Listen by default: ": "Standaard luisteren: ",
|
"Google verification code": "Google-verificatiecode",
|
||||||
"Default speed: ": "Standaard snelheid: ",
|
"Preferences": "Instellingen",
|
||||||
"Preferred video quality: ": "Video kwaliteit voorkeur: ",
|
"Player preferences": "Spelerinstellingen",
|
||||||
"Player volume: ": "Afspeler volume: ",
|
"Always loop: ": "Altijd herhalen: ",
|
||||||
"Default comments: ": "Standaard reacties: ",
|
"Autoplay: ": "Automatisch afspelen: ",
|
||||||
"Default captions: ": "Standaard ondertitels: ",
|
"Play next by default: ": "Standaard volgende video afspelen: ",
|
||||||
"Fallback captions: ": "Alternatieve ondertitels: ",
|
"Autoplay next video: ": "Volgende video automatisch afspelen: ",
|
||||||
"Show related videos? ": "Laat gerelateerde videos zien? ",
|
"Listen by default: ": "Standaard luisteren: ",
|
||||||
"Visual preferences": "Visuele voorkeuren",
|
"Proxy videos: ": "Video's afspelen via proxy? ",
|
||||||
"Dark mode: ": "Donkere modus: ",
|
"Default speed: ": "Standaard afspeelsnelheid: ",
|
||||||
"Thin mode: ": "Smalle modus: ",
|
"Preferred video quality: ": "Voorkeurskwaliteit: ",
|
||||||
"Subscription preferences": "Abonnement voorkeuren",
|
"Player volume: ": "Spelervolume: ",
|
||||||
"Redirect homepage to feed: ": "Startpagina omleiden naar feed: ",
|
"Default comments: ": "Reacties tonen van: ",
|
||||||
"Number of videos shown in feed: ": "Aantal videos te zien in feed: ",
|
"youtube": "YouTube",
|
||||||
"Sort videos by: ": "Sorteer videos op: ",
|
"reddit": "Reddit",
|
||||||
"published": "gepubliceerd",
|
"Default captions: ": "Standaard ondertiteling: ",
|
||||||
"published - reverse": "gepubliceerd - omgekeerd",
|
"Fallback captions: ": "Alternatieve ondertiteling: ",
|
||||||
"alphabetically": "alfabetische volgorde",
|
"Show related videos: ": "Gerelateerde video's tonen? ",
|
||||||
"alphabetically - reverse": "alfabetisch - omgekeerd",
|
"Show annotations by default: ": "Standaard annotaties tonen? ",
|
||||||
"channel name": "kanaal naam",
|
"Visual preferences": "Visuele instellingen",
|
||||||
"channel name - reverse": "kanaal naam - omgekeerd",
|
"Player style: ": "Speler vormgeving",
|
||||||
"Only show latest video from channel: ": "Laat alleen laatste video van kanaal zien: ",
|
"Dark mode: ": "Donkere modus: ",
|
||||||
"Only show latest unwatched video from channel: ": "Laat alleen de laatste onbekeken video zien van kanaal: ",
|
"Theme: ": "Thema: ",
|
||||||
"Only show unwatched: ": "Laat alleen onbekeken videos zien: ",
|
"dark": "donker",
|
||||||
"Only show notifications (if there are any): ": "Laat alleen notificaties zien (als die er zijn): ",
|
"light": "licht",
|
||||||
"Data preferences": "Gegevens voorkeuren",
|
"Thin mode: ": "Smalle modus: ",
|
||||||
"Clear watch history": "Kijkgeschiedenis wissen",
|
"Subscription preferences": "Abonnementsinstellingen",
|
||||||
"Import/Export data": "Importeer/Exporteer gegevens",
|
"Show annotations by default for subscribed channels: ": "Standaard annotaties tonen voor geabonneerde kanalen? ",
|
||||||
"Manage subscriptions": "Abonnees beheren",
|
"Redirect homepage to feed: ": "Startpagina omleiden naar feed: ",
|
||||||
"Watch history": "Kijkgeschiedenis",
|
"Number of videos shown in feed: ": "Aantal te tonen video's in feed: ",
|
||||||
"Delete account": "Account verwijderen",
|
"Sort videos by: ": "Video's sorteren op: ",
|
||||||
"Administrator preferences": "",
|
"published": "publicatiedatum",
|
||||||
"Default homepage: ": "",
|
"published - reverse": "publicatiedatum - omgekeerd",
|
||||||
"Feed menu: ": "",
|
"alphabetically": "alfabetische volgorde",
|
||||||
"Top enabled? ": "",
|
"alphabetically - reverse": "alfabetische volgorde - omgekeerd",
|
||||||
"CAPTCHA enabled? ": "",
|
"channel name": "kanaalnaam",
|
||||||
"Login enabled? ": "",
|
"channel name - reverse": "kanaalnaam - omgekeerd",
|
||||||
"Registration enabled? ": "",
|
"Only show latest video from channel: ": "Alleen nieuwste video van kanaal tonen: ",
|
||||||
"Report statistics? ": "",
|
"Only show latest unwatched video from channel: ": "Alleen nieuwste niet-bekeken video van kanaal tonen: ",
|
||||||
"Save preferences": "Opslaan voorkeuren",
|
"Only show unwatched: ": "Alleen niet-bekeken videos tonen: ",
|
||||||
"Subscription manager": "Abonnees beheerder",
|
"Only show notifications (if there are any): ": "Alleen meldingen tonen (als die er zijn): ",
|
||||||
"`x` subscriptions": "`x` abonnees",
|
"Enable web notifications": "Systemmeldingen inschakelen",
|
||||||
"Import/Export": "Importeer/Exporteer",
|
"`x` uploaded a video": "`x` heeft een video geüpload",
|
||||||
"unsubscribe": "abonnement opzeggen",
|
"`x` is live": "`x` zendt nu live uit",
|
||||||
"Subscriptions": "Abonnees",
|
"Data preferences": "Gegevensinstellingen",
|
||||||
"`x` unseen notifications": "`x` onbekeken notificaties",
|
"Clear watch history": "Kijkgeschiedenis wissen",
|
||||||
"search": "zoeken",
|
"Import/export data": "Gegevens im-/exporteren",
|
||||||
"Sign out": "Afmelden",
|
"Change password": "Wachtwoord wijzigen",
|
||||||
"Released under the AGPLv3 by Omar Roth.": "Uitgegeven onder AGPLv3 door Omar Roth.",
|
"Manage subscriptions": "Abonnementen beheren",
|
||||||
"Source available here.": "Bron beschikbaar hier.",
|
"Manage tokens": "Toegangssleutels beheren",
|
||||||
"View JavaScript license information.": "Bekijk JavaScript licentie informatie.",
|
"Watch history": "Kijkgeschiedenis",
|
||||||
"Trending": "Trending",
|
"Delete account": "Account verwijderen",
|
||||||
"Watch video on Youtube": "Bekijk video op Youtube",
|
"Administrator preferences": "Beheerdersinstellingen",
|
||||||
"Genre: ": "Genre: ",
|
"Default homepage: ": "Standaard startpagina: ",
|
||||||
"License: ": "Licentie: ",
|
"Feed menu: ": "Feedmenu:",
|
||||||
"Family friendly? ": "Gezinsvriendelijk? ",
|
"Top enabled: ": "Bovenkant inschakelen? ",
|
||||||
"Wilson score: ": "Wilson score: ",
|
"CAPTCHA enabled: ": "CAPTCHA gebruiken? ",
|
||||||
"Engagement: ": "Betrokkenheid: ",
|
"Login enabled: ": "Inloggen toestaan? ",
|
||||||
"Whitelisted regions: ": "Toegestane regio's: ",
|
"Registration enabled: ": "Registratie toestaan? ",
|
||||||
"Blacklisted regions: ": "Geblokkeerde regio's: ",
|
"Report statistics: ": "Statistieken bijhouden? ",
|
||||||
"Shared `x`": "`x` gedeeld",
|
"Save preferences": "Instellingen opslaan",
|
||||||
"Hi! Looks like you have JavaScript disabled. Click here to view comments, keep in mind it may take a bit longer to load.": "Hoi! Het lijkt erop dat je JavaScript uit hebt staan. Klik hier om de reacties te bekijken, hou er rekening mee dat het wat langer duurt om te laden.",
|
"Subscription manager": "Abonnementen beheren",
|
||||||
"View YouTube comments": "Bekijk YouTube reacties",
|
"Token manager": "Toegangssleutels beheren",
|
||||||
"View more comments on Reddit": "Bekijk meer reacties op Reddit",
|
"Token": "Toegangssleutel",
|
||||||
"View `x` comments": "`x` reacties zien",
|
"`x` subscriptions": "`x` abonnementen",
|
||||||
"View Reddit comments": "Bekijk Reddit reacties",
|
"`x` tokens": "`x` toegangssleutels",
|
||||||
"Hide replies": "Verberg antwoorden",
|
"Import/export": "Importeren/Exporteren",
|
||||||
"Show replies": "Laat antwoorden zien",
|
"unsubscribe": "Deabonneren",
|
||||||
"Incorrect password": "Onjuist wachtwoord",
|
"revoke": "Intrekken",
|
||||||
"Quota exceeded, try again in a few hours": "Quota overschreden, probeer het over een paar uur opnieuw",
|
"Subscriptions": "Abonnementen",
|
||||||
"Unable to login, make sure two-factor authentication (Authenticator or SMS) is enabled.": "Niet in staat om in te loggen, zorg ervoor dat two-factor authentication (Authenticator of SMS) is ingeschakeld.",
|
"`x` unseen notifications": "`x` ongelezen meldingen",
|
||||||
"Invalid TFA code": "Onjuiste TFA code",
|
"search": "zoeken",
|
||||||
"Login failed. This may be because two-factor authentication is not enabled on your account.": "Aanmelden mislukt. Dit kan zijn omdat two-factor authentication niet is ingeschakeld voor uw account.",
|
"Log out": "Uitloggen",
|
||||||
"Invalid answer": "Onjuist antwoord",
|
"Released under the AGPLv3 by Omar Roth.": "Uitgebracht onder de AGPLv3-licentie, door Omar Roth.",
|
||||||
"Invalid CAPTCHA": "Onjuiste CAPTCHA",
|
"Source available here.": "De broncode is hier beschikbaar.",
|
||||||
"CAPTCHA is a required field": "CAPTCHA is een vereist veld",
|
"View JavaScript license information.": "JavaScript-licentieinformatie tonen.",
|
||||||
"User ID is a required field": "Gebruiker ID is een vereist veld",
|
"View privacy policy.": "Privacybeleid tonen",
|
||||||
"Password is a required field": "Wachtwoord is een vereist veld",
|
"Trending": "Uitgelicht",
|
||||||
"Invalid username or password": "Ongeldige gebruikersnaam of wachtwoord",
|
"Public": "Publiek",
|
||||||
"Please sign in using 'Sign in with Google'": "Meld u aan met 'Aanmelden met Google'",
|
"Unlisted": "Verborgen",
|
||||||
"Password cannot be empty": "Wachtwoord mag niet leeg zijn",
|
"Private": "Privé",
|
||||||
"Password cannot be longer than 55 characters": "Wachtwoord mag niet langer dan 55 tekens zijn",
|
"View all playlists": "Bekijk alle afspeellijsten",
|
||||||
"Please sign in": "Meld u aan",
|
"Updated `x` ago": "`x` geleden aangepast",
|
||||||
"Invidious Private Feed for `x`": "Invidious Privé Feed voor `x`",
|
"Delete playlist `x`?": "Afspeellijst `x` verwijderen?",
|
||||||
"channel:`x`": "kanaal:`x`",
|
"Delete playlist": "Verwijder afspeellijst",
|
||||||
"Deleted or invalid channel": "Verwijderd of ongeldig kanaal",
|
"Create playlist": "Nieuwe afspeellijst",
|
||||||
"This channel does not exist.": "Dit kanaal bestaat niet.",
|
"Title": "Titel",
|
||||||
"Could not get channel info.": "Kan kanaal informatie niet verkrijgen.",
|
"Playlist privacy": "Afspeellijst privacy",
|
||||||
"Could not fetch comments": "Kan reacties niet verkrijgen",
|
"Editing playlist `x`": "Afspeellijst `x` wijzigen",
|
||||||
"View `x` replies": "`x` antwoorden zien",
|
"Watch on YouTube": "Video bekijken op YouTube",
|
||||||
"`x` ago": "`x` geleden",
|
"Hide annotations": "Annotaties verbergen",
|
||||||
"Load more": "Meer laden",
|
"Show annotations": "Annotaties tonen",
|
||||||
"`x` points": "`x` punten",
|
"Genre: ": "Genre: ",
|
||||||
"Could not create mix.": "Kon mix niet maken.",
|
"License: ": "Licentie: ",
|
||||||
"Playlist is empty": "Afspeellijst is leeg",
|
"Family friendly? ": "Gezinsvriendelijk? ",
|
||||||
"Invalid playlist.": "Ongeldige afspeellijst.",
|
"Wilson score: ": "Wilson-score: ",
|
||||||
"Playlist does not exist.": "Afspeellijst bestaat niet.",
|
"Engagement: ": "Betrokkenheid: ",
|
||||||
"Could not pull trending pages.": "Kon trending paginas niet verkrijgen.",
|
"Whitelisted regions: ": "Toegestane regio's: ",
|
||||||
"Hidden field \"challenge\" is a required field": "Verborgen veld \"uitdaging\" is een vereist veld",
|
"Blacklisted regions: ": "Geblokkeerde regio's: ",
|
||||||
"Hidden field \"token\" is a required field": "Verborgen veld \"token\" is een vereist veld",
|
"Shared `x`": "`x` gedeeld",
|
||||||
"Invalid challenge": "Ongeldige uitdaging",
|
"`x` views": "`x` weergaven",
|
||||||
"Invalid token": "Ongeldige token",
|
"Premieres in `x`": "Verschijnt over `x`",
|
||||||
"Invalid user": "Ongeldige gebruiker",
|
"Premieres `x`": "",
|
||||||
"Token is expired, please try again": "Token is verlopen, probeer het opnieuw",
|
"Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.": "Hoi! Het lijkt erop dat je JavaScript hebt uitgeschakeld. Klik hier om de reacties te bekijken. Let op: het laden duurt wat langer.",
|
||||||
"English": "",
|
"View YouTube comments": "YouTube-reacties tonen",
|
||||||
"English (auto-generated)": "",
|
"View more comments on Reddit": "Meer reacties bekijken op Reddit",
|
||||||
"Afrikaans": "",
|
"View `x` comments": "`x` reacties tonen",
|
||||||
"Albanian": "",
|
"View Reddit comments": "Reddit-reacties tonen",
|
||||||
"Amharic": "",
|
"Hide replies": "Antwoorden verbergen",
|
||||||
"Arabic": "",
|
"Show replies": "Antwoorden tonen",
|
||||||
"Armenian": "",
|
"Incorrect password": "Wachtwoord is onjuist",
|
||||||
"Azerbaijani": "",
|
"Quota exceeded, try again in a few hours": "Quota overschreden; probeer het over een paar uur opnieuw",
|
||||||
"Bangla": "",
|
"Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.": "Kan niet inloggen. Zorg ervoor dat authenticatie in twee stappen (Authenticator of sms) is ingeschakeld.",
|
||||||
"Basque": "",
|
"Invalid TFA code": "Onjuiste TFA-code",
|
||||||
"Belarusian": "",
|
"Login failed. This may be because two-factor authentication is not turned on for your account.": "Inloggen mislukt. Wellicht is authenticatie in twee stappen niet ingeschakeld op je account.",
|
||||||
"Bosnian": "",
|
"Wrong answer": "Onjuist antwoord",
|
||||||
"Bulgarian": "",
|
"Erroneous CAPTCHA": "Onjuiste CAPTCHA",
|
||||||
"Burmese": "",
|
"CAPTCHA is a required field": "CAPTCHA is vereist",
|
||||||
"Catalan": "",
|
"User ID is a required field": "Gebruikers-id is vereist",
|
||||||
"Cebuano": "",
|
"Password is a required field": "Wachtwoord is vereist",
|
||||||
"Chinese (Simplified)": "",
|
"Wrong username or password": "Onjuiste gebruikersnaam of wachtwoord",
|
||||||
"Chinese (Traditional)": "",
|
"Please sign in using 'Log in with Google'": "Log in via 'Inloggen met Google'",
|
||||||
"Corsican": "",
|
"Password cannot be empty": "Het wachtwoordveld mag niet leeg zijn",
|
||||||
"Croatian": "",
|
"Password cannot be longer than 55 characters": "Het wachtwoord mag niet langer dan 55 tekens zijn",
|
||||||
"Czech": "",
|
"Please log in": "Log in",
|
||||||
"Danish": "",
|
"Invidious Private Feed for `x`": "Invidious-privéfeed van `x`",
|
||||||
"Dutch": "",
|
"channel:`x`": "kanaal:`x`",
|
||||||
"Esperanto": "",
|
"Deleted or invalid channel": "Verwijderd of niet-bestaand kanaal",
|
||||||
"Estonian": "",
|
"This channel does not exist.": "Dit kanaal bestaat niet.",
|
||||||
"Filipino": "",
|
"Could not get channel info.": "Kan geen kanaalinformatie ophalen.",
|
||||||
"Finnish": "",
|
"Could not fetch comments": "Kan reacties niet ophalen",
|
||||||
"French": "",
|
"View `x` replies": "`x` antwoorden tonen",
|
||||||
"Galician": "",
|
"`x` ago": "`x` geleden",
|
||||||
"Georgian": "",
|
"Load more": "Meer laden",
|
||||||
"German": "",
|
"`x` points": "`x` punten",
|
||||||
"Greek": "",
|
"Could not create mix.": "Kan geen mix maken.",
|
||||||
"Gujarati": "",
|
"Empty playlist": "Lege afspeellijst",
|
||||||
"Haitian Creole": "",
|
"Not a playlist.": "Ongeldige afspeellijst.",
|
||||||
"Hausa": "",
|
"Playlist does not exist.": "Afspeellijst bestaat niet.",
|
||||||
"Hawaiian": "",
|
"Could not pull trending pages.": "Kan uitgelichte pagina's niet ophalen.",
|
||||||
"Hebrew": "",
|
"Hidden field \"challenge\" is a required field": "Verborgen veld \"uitdaging\" is vereist",
|
||||||
"Hindi": "",
|
"Hidden field \"token\" is a required field": "Verborgen veld \"toegangssleutel\" is vereist",
|
||||||
"Hmong": "",
|
"Erroneous challenge": "Ongeldige uitdaging",
|
||||||
"Hungarian": "",
|
"Erroneous token": "Ongeldige toegangssleutel",
|
||||||
"Icelandic": "",
|
"No such user": "Gebruiker bestaat niet",
|
||||||
"Igbo": "",
|
"Token is expired, please try again": "Toegangssleutel verlopen; probeer het opnieuw",
|
||||||
"Indonesian": "",
|
"English": "Engels",
|
||||||
"Irish": "",
|
"English (auto-generated)": "Engels (automatisch gegenereerd)",
|
||||||
"Italian": "",
|
"Afrikaans": "Afrikaans",
|
||||||
"Japanese": "",
|
"Albanian": "Albanees",
|
||||||
"Javanese": "",
|
"Amharic": "Amhaars",
|
||||||
"Kannada": "",
|
"Arabic": "Arabisch",
|
||||||
"Kazakh": "",
|
"Armenian": "Armeens",
|
||||||
"Khmer": "",
|
"Azerbaijani": "Azerbeidzjaans",
|
||||||
"Korean": "",
|
"Bangla": "Bangla",
|
||||||
"Kurdish": "",
|
"Basque": "Baskisch",
|
||||||
"Kyrgyz": "",
|
"Belarusian": "Wit-Rrussisch",
|
||||||
"Lao": "",
|
"Bosnian": "Bosnisch",
|
||||||
"Latin": "",
|
"Bulgarian": "Bulgaars",
|
||||||
"Latvian": "",
|
"Burmese": "Birmaans",
|
||||||
"Lithuanian": "",
|
"Catalan": "Catalaans",
|
||||||
"Luxembourgish": "",
|
"Cebuano": "Cebuano",
|
||||||
"Macedonian": "",
|
"Chinese (Simplified)": "Chinees (Veereenvoudigd)",
|
||||||
"Malagasy": "",
|
"Chinese (Traditional)": "Chinees (Traditioneel)",
|
||||||
"Malay": "",
|
"Corsican": "Corsicaans",
|
||||||
"Malayalam": "",
|
"Croatian": "Kroatisch",
|
||||||
"Maltese": "",
|
"Czech": "Tsjechisch",
|
||||||
"Maori": "",
|
"Danish": "Deens",
|
||||||
"Marathi": "",
|
"Dutch": "Nederlands",
|
||||||
"Mongolian": "",
|
"Esperanto": "Esperanto",
|
||||||
"Nepali": "",
|
"Estonian": "Ests",
|
||||||
"Norwegian": "",
|
"Filipino": "Filipijns",
|
||||||
"Nyanja": "",
|
"Finnish": "Fins",
|
||||||
"Pashto": "",
|
"French": "Frans",
|
||||||
"Persian": "",
|
"Galician": "Galicisch",
|
||||||
"Polish": "",
|
"Georgian": "Georgisch",
|
||||||
"Portuguese": "",
|
"German": "Duits",
|
||||||
"Punjabi": "",
|
"Greek": "Grieks",
|
||||||
"Romanian": "",
|
"Gujarati": "Gujarati",
|
||||||
"Russian": "",
|
"Haitian Creole": "Creools",
|
||||||
"Samoan": "",
|
"Hausa": "Hausa",
|
||||||
"Scottish Gaelic": "",
|
"Hawaiian": "Hawaïaans",
|
||||||
"Serbian": "",
|
"Hebrew": "Heebreeuws",
|
||||||
"Shona": "",
|
"Hindi": "Hindi",
|
||||||
"Sindhi": "",
|
"Hmong": "Hmong",
|
||||||
"Sinhala": "",
|
"Hungarian": "Hongaars",
|
||||||
"Slovak": "",
|
"Icelandic": "IJslands",
|
||||||
"Slovenian": "",
|
"Igbo": "Igbo",
|
||||||
"Somali": "",
|
"Indonesian": "Indonesisch",
|
||||||
"Southern Sotho": "",
|
"Irish": "Iers",
|
||||||
"Spanish": "",
|
"Italian": "Italiaans",
|
||||||
"Spanish (Latin America)": "",
|
"Japanese": "Japans",
|
||||||
"Sundanese": "",
|
"Javanese": "Javaans",
|
||||||
"Swahili": "",
|
"Kannada": "Kannada",
|
||||||
"Swedish": "",
|
"Kazakh": "Kazachs",
|
||||||
"Tajik": "",
|
"Khmer": "Khmer",
|
||||||
"Tamil": "",
|
"Korean": "Koreaans",
|
||||||
"Telugu": "",
|
"Kurdish": "Koerdisch",
|
||||||
"Thai": "",
|
"Kyrgyz": "Kirgizisch",
|
||||||
"Turkish": "",
|
"Lao": "Laotiaans",
|
||||||
"Ukrainian": "",
|
"Latin": "Latijns",
|
||||||
"Urdu": "",
|
"Latvian": "Lets",
|
||||||
"Uzbek": "",
|
"Lithuanian": "Litouws",
|
||||||
"Vietnamese": "",
|
"Luxembourgish": "Luxemburgs",
|
||||||
"Welsh": "",
|
"Macedonian": "Macedonisch",
|
||||||
"Western Frisian": "",
|
"Malagasy": "Malagassisch",
|
||||||
"Xhosa": "",
|
"Malay": "Maleisisch",
|
||||||
"Yiddish": "",
|
"Malayalam": "Malayalam",
|
||||||
"Yoruba": "",
|
"Maltese": "Maltees",
|
||||||
"Zulu": "",
|
"Maori": "Maorisch",
|
||||||
"`x` years": "`x` jaar",
|
"Marathi": "Marathi",
|
||||||
"`x` months": "`x` maanden",
|
"Mongolian": "Mongools",
|
||||||
"`x` weeks": "`x` weken",
|
"Nepali": "Nepalees",
|
||||||
"`x` days": "`x` dagen",
|
"Norwegian Bokmål": "Noors (Bokmål)",
|
||||||
"`x` hours": "`x` uur",
|
"Nyanja": "Nyanja",
|
||||||
"`x` minutes": "`x` minuten",
|
"Pashto": "Pashto",
|
||||||
"`x` seconds": "`x` seconden",
|
"Persian": "Perzisch",
|
||||||
"Fallback comments: ": "",
|
"Polish": "Pools",
|
||||||
"Popular": "",
|
"Portuguese": "Portugees",
|
||||||
"Top": "",
|
"Punjabi": "Punjabi",
|
||||||
"About": "",
|
"Romanian": "Roemeens",
|
||||||
"Rating: ": "",
|
"Russian": "Russisch",
|
||||||
"Language: ": "",
|
"Samoan": "Samoaans",
|
||||||
"Default": "",
|
"Scottish Gaelic": "Schots-Gaelisch",
|
||||||
"Music": "",
|
"Serbian": "Servisch",
|
||||||
"Gaming": "",
|
"Shona": "Shona",
|
||||||
"News": "",
|
"Sindhi": "Sindhi",
|
||||||
"Movies": "",
|
"Sinhala": "Sinhala",
|
||||||
"Download": "",
|
"Slovak": "Slowaaks",
|
||||||
"Download as: ": "",
|
"Slovenian": "Sloveens",
|
||||||
"%A %B %-d, %Y": "",
|
"Somali": "Somalisch",
|
||||||
"(edited)": "",
|
"Southern Sotho": "Zuid-Sotho",
|
||||||
"Youtube permalink of the comment": "",
|
"Spanish": "Spaans",
|
||||||
"`x` marked it with a ❤": "",
|
"Spanish (Latin America)": "Spaans (Latijns-Amerika)",
|
||||||
"Audio mode": "",
|
"Sundanese": "Soedanees",
|
||||||
"Video mode": ""
|
"Swahili": "Swahili",
|
||||||
}
|
"Swedish": "Zweeds",
|
||||||
|
"Tajik": "Tajik",
|
||||||
|
"Tamil": "Tamil",
|
||||||
|
"Telugu": "Telugu",
|
||||||
|
"Thai": "Thaïs",
|
||||||
|
"Turkish": "Turks",
|
||||||
|
"Ukrainian": "Oekraïens",
|
||||||
|
"Urdu": "Urdu",
|
||||||
|
"Uzbek": "Oezbeeks",
|
||||||
|
"Vietnamese": "Vietnamees",
|
||||||
|
"Welsh": "Welsh",
|
||||||
|
"Western Frisian": "Fries",
|
||||||
|
"Xhosa": "Xhosa",
|
||||||
|
"Yiddish": "Joods",
|
||||||
|
"Yoruba": "Yoruba",
|
||||||
|
"Zulu": "Zulu",
|
||||||
|
"`x` years": "`x` jaar",
|
||||||
|
"`x` months": "`x` maanden",
|
||||||
|
"`x` weeks": "`x` weken",
|
||||||
|
"`x` days": "`x` dagen",
|
||||||
|
"`x` hours": "`x` uur",
|
||||||
|
"`x` minutes": "`x` minuten",
|
||||||
|
"`x` seconds": "`x` seconden",
|
||||||
|
"Fallback comments: ": "Terugvallen op",
|
||||||
|
"Popular": "Populair",
|
||||||
|
"Top": "Top",
|
||||||
|
"About": "Over",
|
||||||
|
"Rating: ": "Waardering",
|
||||||
|
"Language: ": "Taal",
|
||||||
|
"View as playlist": "Tonen als afspeellijst",
|
||||||
|
"Default": "Standaard",
|
||||||
|
"Music": "Muziek",
|
||||||
|
"Gaming": "Gaming",
|
||||||
|
"News": "Nieuws",
|
||||||
|
"Movies": "Films",
|
||||||
|
"Download": "Downloaden",
|
||||||
|
"Download as: ": "Downloaden als: ",
|
||||||
|
"%A %B %-d, %Y": "%A %B %-d, %Y",
|
||||||
|
"(edited)": "(bewerkt)",
|
||||||
|
"YouTube comment permalink": "Link naar YouTube-reactie",
|
||||||
|
"permalink": "",
|
||||||
|
"`x` marked it with a ❤": "`x` heeft dit gemarkeerd met ❤",
|
||||||
|
"Audio mode": "Audiomodus",
|
||||||
|
"Video mode": "Videomodus",
|
||||||
|
"Videos": "Video's",
|
||||||
|
"Playlists": "Afspeellijsten",
|
||||||
|
"Community": "Gemeenschap",
|
||||||
|
"Current version: ": "Huidige versie: ",
|
||||||
|
"Download is disabled.": "Downloaden is uitgeschakeld."
|
||||||
|
}
|
||||||
622
locales/pl.json
622
locales/pl.json
@@ -1,288 +1,336 @@
|
|||||||
{
|
{
|
||||||
"`x` subscribers": "`x` subskrybcji",
|
"`x` subscribers": "`x` subskrybcji",
|
||||||
"`x` videos": "`x` filmów",
|
"`x` videos": "`x` filmów",
|
||||||
"LIVE": "NA ŻYWO",
|
"`x` playlists": "`x` playlist",
|
||||||
"Shared `x` ago": "Udostępniono `x` temu",
|
"LIVE": "NA ŻYWO",
|
||||||
"Unsubscribe": "Odsubskrybuj",
|
"Shared `x` ago": "Udostępniono `x` temu",
|
||||||
"Subscribe": "Subskrybuj",
|
"Unsubscribe": "Odsubskrybuj",
|
||||||
"Login to subscribe to `x`": "Zaloguj się, aby subskrybować `x`",
|
"Subscribe": "Subskrybuj",
|
||||||
"View channel on YouTube": "Wyświetl kanał na YouTube",
|
"View channel on YouTube": "Wyświetl kanał na YouTube",
|
||||||
"newest": "najnowsze",
|
"View playlist on YouTube": "Zobacz playlistę na YouTube",
|
||||||
"oldest": "najstarsze",
|
"newest": "najnowsze",
|
||||||
"popular": "popularne",
|
"oldest": "najstarsze",
|
||||||
"Preview page": "Podgląd strony",
|
"popular": "popularne",
|
||||||
"Next page": "Następna strona",
|
"last": "ostatnie",
|
||||||
"Clear watch history?": "Wyczyścić historię?",
|
"Next page": "Następna strona",
|
||||||
"Yes": "Tak",
|
"Previous page": "Poprzednia strona",
|
||||||
"No": "Nie",
|
"Clear watch history?": "Wyczyścić historię?",
|
||||||
"Import and Export Data": "Import i eksport danych",
|
"New password": "Nowe hasło",
|
||||||
"Import": "Import",
|
"New passwords must match": "Nowe hasła muszą być identyczne",
|
||||||
"Import Invidious data": "Importuj dane Invidious",
|
"Cannot change password for Google accounts": "Nie można zmienić hasła do konta Google",
|
||||||
"Import YouTube subscriptions": "Importuj subskrybcje z YouTube",
|
"Authorize token?": "Autoryzować token?",
|
||||||
"Import FreeTube subscriptions (.db)": "Importuj subskrybcje z FreeTube (.db)",
|
"Authorize token for `x`?": "Autoryzować token dla `x`?",
|
||||||
"Import NewPipe subscriptions (.json)": "Importuj subskrybcje z NewPipe (.json)",
|
"Yes": "Tak",
|
||||||
"Import NewPipe data (.zip)": "Importuj dane NewPipe (.zip)",
|
"No": "Nie",
|
||||||
"Export": "Eksport",
|
"Import and Export Data": "Import i eksport danych",
|
||||||
"Export subscriptions as OPML": "Eksportuj subskrybcje jako OPML",
|
"Import": "Import",
|
||||||
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Eksportuj subskrybcje jako OPML (dla NewPipe i FreeTube)",
|
"Import Invidious data": "Importuj dane Invidious",
|
||||||
"Export data as JSON": "Eksportuj dane jako JSON",
|
"Import YouTube subscriptions": "Importuj subskrybcje z YouTube",
|
||||||
"Delete account?": "Usunąć konto?",
|
"Import FreeTube subscriptions (.db)": "Importuj subskrybcje z FreeTube (.db)",
|
||||||
"History": "Historia",
|
"Import NewPipe subscriptions (.json)": "Importuj subskrybcje z NewPipe (.json)",
|
||||||
"Previous page": "Poprzednia strona",
|
"Import NewPipe data (.zip)": "Importuj dane NewPipe (.zip)",
|
||||||
"An alternative front-end to YouTube": "Alternatywny front-end dla YouTube",
|
"Export": "Eksport",
|
||||||
"JavaScript license information": "Informacja o licencji JavaScript",
|
"Export subscriptions as OPML": "Eksportuj subskrybcje jako OPML",
|
||||||
"source": "źródło",
|
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Eksportuj subskrybcje jako OPML (dla NewPipe i FreeTube)",
|
||||||
"Login": "Zaloguj",
|
"Export data as JSON": "Eksportuj dane jako JSON",
|
||||||
"Login/Register": "Zaloguj/Zarejestruj",
|
"Delete account?": "Usunąć konto?",
|
||||||
"Login to Google": "Zaloguj do Google",
|
"History": "Historia",
|
||||||
"User ID:": "ID użytkownika:",
|
"An alternative front-end to YouTube": "Alternatywny front-end dla YouTube",
|
||||||
"Password:": "Hasło:",
|
"JavaScript license information": "Informacja o licencji JavaScript",
|
||||||
"Time (h:mm:ss):": "Godzina (h:mm:ss):",
|
"source": "źródło",
|
||||||
"Text CAPTCHA": "Tekst CAPTCHA",
|
"Log in": "Zaloguj",
|
||||||
"Image CAPTCHA": "Obraz CAPTCHA",
|
"Log in/register": "Zaloguj/Zarejestruj",
|
||||||
"Sign In": "Zaloguj się",
|
"Log in with Google": "Zaloguj do Google",
|
||||||
"Register": "Zarejestruj się",
|
"User ID": "ID użytkownika",
|
||||||
"Email:": "Email:",
|
"Password": "Hasło",
|
||||||
"Google verification code:": "Kod weryfikacyjny Google:",
|
"Time (h:mm:ss):": "Godzina (h:mm:ss):",
|
||||||
"Preferences": "Preferencje",
|
"Text CAPTCHA": "Tekst CAPTCHA",
|
||||||
"Player preferences": "Ustawienia odtwarzacza",
|
"Image CAPTCHA": "Obraz CAPTCHA",
|
||||||
"Always loop: ": "Zawsze zapętlaj: ",
|
"Sign In": "Zaloguj się",
|
||||||
"Autoplay: ": "Autoodtwarzanie: ",
|
"Register": "Zarejestruj się",
|
||||||
"Autoplay next video: ": "Odtwórz następny film: ",
|
"E-mail": "Email",
|
||||||
"Listen by default: ": "Tryb dźwiękowy: ",
|
"Google verification code": "Kod weryfikacyjny Google",
|
||||||
"Default speed: ": "Domyślna prędkość: ",
|
"Preferences": "Preferencje",
|
||||||
"Preferred video quality: ": "Preferowana jakość filmów: ",
|
"Player preferences": "Ustawienia odtwarzacza",
|
||||||
"Player volume: ": "Głośność odtwarzacza: ",
|
"Always loop: ": "Zawsze zapętlaj: ",
|
||||||
"Default comments: ": "Domyślne komentarze: ",
|
"Autoplay: ": "Autoodtwarzanie: ",
|
||||||
"Default captions: ": "Domyślne napisy: ",
|
"Play next by default: ": "Domyślnie odtwarzaj następny: ",
|
||||||
"Fallback captions: ": "Rezerwowe napisy: ",
|
"Autoplay next video: ": "Odtwórz następny film: ",
|
||||||
"Show related videos? ": "Pokaż powiązane filmy? ",
|
"Listen by default: ": "Tryb dźwiękowy: ",
|
||||||
"Visual preferences": "Preferencje Wizualne",
|
"Proxy videos: ": "Filmy przez proxy? ",
|
||||||
"Dark mode: ": "Ciemny motyw: ",
|
"Default speed: ": "Domyślna prędkość: ",
|
||||||
"Thin mode: ": "Tryb minimalny: ",
|
"Preferred video quality: ": "Preferowana jakość filmów: ",
|
||||||
"Subscription preferences": "Preferencje subskrybcji",
|
"Player volume: ": "Głośność odtwarzacza: ",
|
||||||
"Redirect homepage to feed: ": "Przekieruj stronę główną do subskrybcji: ",
|
"Default comments: ": "Domyślne komentarze: ",
|
||||||
"Number of videos shown in feed: ": "Liczba filmów widoczna na stronie subskrybcji: ",
|
"youtube": "youtube",
|
||||||
"Sort videos by: ": "Sortuj filmy po: ",
|
"reddit": "reddit",
|
||||||
"published": "czasie publikacji",
|
"Default captions: ": "Domyślne napisy: ",
|
||||||
"published - reverse": "czasie publikacji od najstarszych",
|
"Fallback captions: ": "Zastępcze napisy: ",
|
||||||
"alphabetically": "alfabetycznie",
|
"Show related videos: ": "Pokaż powiązane filmy? ",
|
||||||
"alphabetically - reverse": "alfabetycznie od tyłu",
|
"Show annotations by default: ": "Domyślnie pokazuj adnotacje: ",
|
||||||
"channel name": "nazwie kanału",
|
"Visual preferences": "Preferencje Wizualne",
|
||||||
"channel name - reverse": "nazwie kanału od tyłu",
|
"Player style: ": "Styl odtwarzacza: ",
|
||||||
"Only show latest video from channel: ": "Pokazuj tylko najnowszy film z kanału: ",
|
"Dark mode: ": "Ciemny motyw: ",
|
||||||
"Only show latest unwatched video from channel: ": "Pokazuj tylko najnowszy nie obejrzany film z kanału: ",
|
"Theme: ": "Motyw: ",
|
||||||
"Only show unwatched: ": "Pokazuj tylko nie obejrzane: ",
|
"dark": "ciemny",
|
||||||
"Only show notifications (if there are any): ": "Pokazuj tylko powiadomienia (jeśli są): ",
|
"light": "jasny",
|
||||||
"Data preferences": "Preferencje danych",
|
"Thin mode: ": "Tryb minimalny: ",
|
||||||
"Clear watch history": "Wyczyść historię",
|
"Subscription preferences": "Preferencje subskrybcji",
|
||||||
"Import/Export data": "Import/Eksport danych",
|
"Show annotations by default for subscribed channels: ": "Domyślnie wyświetlaj adnotacje dla subskrybowanych kanałów: ",
|
||||||
"Manage subscriptions": "Organizuj subskrybcje",
|
"Redirect homepage to feed: ": "Przekieruj stronę główną do subskrybcji: ",
|
||||||
"Watch history": "Historia",
|
"Number of videos shown in feed: ": "Liczba filmów widoczna na stronie subskrybcji: ",
|
||||||
"Delete account": "Usuń konto",
|
"Sort videos by: ": "Sortuj filmy: ",
|
||||||
"Administrator preferences": "",
|
"published": "po czasie publikacji",
|
||||||
"Default homepage: ": "",
|
"published - reverse": "po czasie publikacji od najstarszych",
|
||||||
"Feed menu: ": "",
|
"alphabetically": "alfabetycznie",
|
||||||
"Top enabled? ": "",
|
"alphabetically - reverse": "alfabetycznie od tyłu",
|
||||||
"CAPTCHA enabled? ": "",
|
"channel name": "po nazwie kanału",
|
||||||
"Login enabled? ": "",
|
"channel name - reverse": "po nazwie kanału od tyłu",
|
||||||
"Registration enabled? ": "",
|
"Only show latest video from channel: ": "Pokazuj tylko najnowszy film z kanału: ",
|
||||||
"Report statistics? ": "",
|
"Only show latest unwatched video from channel: ": "Pokazuj tylko najnowszy nie obejrzany film z kanału: ",
|
||||||
"Save preferences": "Zapisz preferencje",
|
"Only show unwatched: ": "Pokazuj tylko nie obejrzane: ",
|
||||||
"Subscription manager": "Manager subskrybcji",
|
"Only show notifications (if there are any): ": "Pokazuj tylko powiadomienia (jeśli są): ",
|
||||||
"`x` subscriptions": "`x` subskrybcji",
|
"Enable web notifications": "Włącz powiadomienia",
|
||||||
"Import/Export": "Import/Eksport",
|
"`x` uploaded a video": "`x` dodał film",
|
||||||
"unsubscribe": "odsubskrybuj",
|
"`x` is live": "'x ' jest na żywo",
|
||||||
"Subscriptions": "Subskrybcje",
|
"Data preferences": "Preferencje danych",
|
||||||
"`x` unseen notifications": "`x` niewidzianych powiadomień",
|
"Clear watch history": "Wyczyść historię",
|
||||||
"search": "szukaj",
|
"Import/export data": "Import/Eksport danych",
|
||||||
"Sign out": "Wyloguj",
|
"Change password": "Zmień hasło",
|
||||||
"Released under the AGPLv3 by Omar Roth.": "Wydano na licencji AGPLv3 przez Omar Roth.",
|
"Manage subscriptions": "Organizuj subskrybcje",
|
||||||
"Source available here.": "Kod źródłowy dostępny tutaj.",
|
"Manage tokens": "Zarządzaj tokenami",
|
||||||
"View JavaScript license information.": "Wyświetl informację o licencji JavaScript.",
|
"Watch history": "Historia",
|
||||||
"Trending": "Na czasie",
|
"Delete account": "Usuń konto",
|
||||||
"Watch video on Youtube": "Zobacz film na YouTube",
|
"Administrator preferences": "Preferencje administratora",
|
||||||
"Genre: ": "Gatunek: ",
|
"Default homepage: ": "Domyślna strona główna: ",
|
||||||
"License: ": "Licencja: ",
|
"Feed menu: ": "",
|
||||||
"Family friendly? ": "Przyjazny rodzinie? ",
|
"Top enabled: ": "\"Top\" aktywne: ",
|
||||||
"Wilson score: ": "Punktacja Wilsona: ",
|
"CAPTCHA enabled: ": "CAPTCHA aktywna? ",
|
||||||
"Engagement: ": "Zaangażowanie: ",
|
"Login enabled: ": "Logowanie włączone? ",
|
||||||
"Whitelisted regions: ": "Dostępny na obszarach: ",
|
"Registration enabled: ": "Rejestracja włączona? ",
|
||||||
"Blacklisted regions: ": "Niedostępny na obszarach: ",
|
"Report statistics: ": "Raportować statystyki? ",
|
||||||
"Shared `x`": "Udostępniono `x`",
|
"Save preferences": "Zapisz preferencje",
|
||||||
"Hi! Looks like you have JavaScript disabled. Click here to view comments, keep in mind it may take a bit longer to load.": "Cześć! Wygląda na to, że masz wyłączoną obsługę JavaScriptu. Kliknij tutaj, żeby zobaczyć komentarze. Pamiętaj, że wczytywanie może potrwać dłużej.",
|
"Subscription manager": "Manager subskrybcji",
|
||||||
"View YouTube comments": "Wyświetl komentarze z YouTube",
|
"Token manager": "Menedżer tokenów",
|
||||||
"View more comments on Reddit": "Wyświetl więcej komentarzy na Reddicie",
|
"Token": "Token",
|
||||||
"View `x` comments": "Wyświetl `x` komentarzy",
|
"`x` subscriptions": "`x` subskrybcji",
|
||||||
"View Reddit comments": "Wyświetl komentarze z Redditta",
|
"`x` tokens": "",
|
||||||
"Hide replies": "Ukryj odpowiedzi",
|
"Import/export": "Import/Eksport",
|
||||||
"Show replies": "Pokaż odpowiedzi",
|
"unsubscribe": "odsubskrybuj",
|
||||||
"Incorrect password": "Niepoprawne hasło",
|
"revoke": "cofnij",
|
||||||
"Quota exceeded, try again in a few hours": "Przekroczony limit zapytań, spróbuj ponownie za kilka godzin",
|
"Subscriptions": "Subskrybcje",
|
||||||
"Unable to login, make sure two-factor authentication (Authenticator or SMS) is enabled.": "Nie udało się zalogować, upewnij się, że dwuetapowe uwierzytelnianie (Autentykator lub SMS) jest aktywne.",
|
"`x` unseen notifications": "`x` nowych powiadomień",
|
||||||
"Invalid TFA code": "Niepoprawny kod TFA",
|
"search": "szukaj",
|
||||||
"Login failed. This may be because two-factor authentication is not enabled on your account.": "Nie udało się zalogować. To może być spowodowane wyłączoną dwustopniową autoryzacją na twoim koncie.",
|
"Log out": "Wyloguj",
|
||||||
"Invalid answer": "Niepoprawna odpowiedź",
|
"Released under the AGPLv3 by Omar Roth.": "Wydano na licencji AGPLv3 przez Omar Roth.",
|
||||||
"Invalid CAPTCHA": "CAPTCHA wykonane błędnie",
|
"Source available here.": "Kod źródłowy dostępny tutaj.",
|
||||||
"CAPTCHA is a required field": "CAPTCHA jest polem wymaganym",
|
"View JavaScript license information.": "Wyświetl informację o licencji JavaScript.",
|
||||||
"User ID is a required field": "ID użytkownika jest polem wymaganym",
|
"View privacy policy.": "Polityka prywatności.",
|
||||||
"Password is a required field": "Hasło jest polem wymaganym",
|
"Trending": "Na czasie",
|
||||||
"Invalid username or password": "Niepoprawny login lub hasło",
|
"Public": "Publiczne",
|
||||||
"Please sign in using 'Sign in with Google'": "Zaloguj się używając \"Zaloguj się przez Google\"",
|
"Unlisted": "Niewidoczne",
|
||||||
"Password cannot be empty": "Hasło nie może być puste",
|
"Private": "Prywatne",
|
||||||
"Password cannot be longer than 55 characters": "Hasło nie może być dłuższe niż 55 znaków",
|
"View all playlists": "Pokaż wszystkie playlisty",
|
||||||
"Please sign in": "Proszę się zalogować",
|
"Updated `x` ago": "Zaktualizowano `x` temu",
|
||||||
"Invidious Private Feed for `x`": "",
|
"Delete playlist `x`?": "Usunąć playlistę 'x '?",
|
||||||
"channel:`x`": "kanał:`x",
|
"Delete playlist": "Usuń playlistę",
|
||||||
"Deleted or invalid channel": "Usunięty lub niepoprawny kanał",
|
"Create playlist": "Utwórz playlistę",
|
||||||
"This channel does not exist.": "Ten kanał nie istnieje.",
|
"Title": "Tytuł",
|
||||||
"Could not get channel info.": "Nie udało się uzyskać informacji o kanale.",
|
"Playlist privacy": "Widoczność playlisty",
|
||||||
"Could not fetch comments": "Nie udało się pobrać komentarzy",
|
"Editing playlist `x`": "Edycja playlisty `x`",
|
||||||
"View `x` replies": "Wyświetl `x` odpowiedzi",
|
"Watch on YouTube": "Zobacz film na YouTube",
|
||||||
"`x` ago": "`x` temu",
|
"Hide annotations": "Ukryj adnotacje",
|
||||||
"Load more": "Wczytaj więcej",
|
"Show annotations": "Pokaż adnotacje",
|
||||||
"`x` points": "`x` punktów",
|
"Genre: ": "Gatunek: ",
|
||||||
"Could not create mix.": "Nie udało się utworzyć miksu.",
|
"License: ": "Licencja: ",
|
||||||
"Playlist is empty": "Lista odtwarzania jest pusta",
|
"Family friendly? ": "Przyjazny rodzinie? ",
|
||||||
"Invalid playlist.": "Niepoprawna lista.",
|
"Wilson score: ": "Punktacja Wilsona: ",
|
||||||
"Playlist does not exist.": "Lista odtwarzania nie istnieje.",
|
"Engagement: ": "Zaangażowanie: ",
|
||||||
"Could not pull trending pages.": "Nie udało się pobrać strony na czasie.",
|
"Whitelisted regions: ": "Dostępny na obszarach: ",
|
||||||
"Hidden field \"challenge\" is a required field": "Ukryte pole \"wyzwanie\" jest polem wymaganym",
|
"Blacklisted regions: ": "Niedostępny na obszarach: ",
|
||||||
"Hidden field \"token\" is a required field": "Ukryte pole \"token\" jest polem wymaganym",
|
"Shared `x`": "Udostępniono `x`",
|
||||||
"Invalid challenge": "Niepoprawne wyzwanie",
|
"`x` views": "`x` wyświetleń",
|
||||||
"Invalid token": "Niepoprawny token",
|
"Premieres in `x`": "Publikacja za `x`",
|
||||||
"Invalid user": "Niepoprawny użytkownik",
|
"Premieres `x`": "Publikacja za `x`",
|
||||||
"Token is expired, please try again": "Token wygasł, spróbuj ponownie",
|
"Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.": "Cześć! Wygląda na to, że masz wyłączoną obsługę JavaScriptu. Kliknij tutaj, żeby zobaczyć komentarze. Pamiętaj, że wczytywanie może potrwać dłużej.",
|
||||||
"English": "angielski",
|
"View YouTube comments": "Wyświetl komentarze z YouTube",
|
||||||
"English (auto-generated)": "angielski (automatycznie generowane)",
|
"View more comments on Reddit": "Wyświetl więcej komentarzy na Reddicie",
|
||||||
"Afrikaans": "",
|
"View `x` comments": "Wyświetl `x` komentarzy",
|
||||||
"Albanian": "albański",
|
"View Reddit comments": "Wyświetl komentarze z Redditta",
|
||||||
"Amharic": "",
|
"Hide replies": "Ukryj odpowiedzi",
|
||||||
"Arabic": "arabski",
|
"Show replies": "Pokaż odpowiedzi",
|
||||||
"Armenian": "",
|
"Incorrect password": "Niepoprawne hasło",
|
||||||
"Azerbaijani": "",
|
"Quota exceeded, try again in a few hours": "Przekroczony limit zapytań, spróbuj ponownie za kilka godzin",
|
||||||
"Bangla": "",
|
"Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.": "Nie udało się zalogować, upewnij się, że dwuetapowe uwierzytelnianie (Autentykator lub SMS) jest aktywne.",
|
||||||
"Basque": "",
|
"Invalid TFA code": "Niepoprawny kod TFA",
|
||||||
"Belarusian": "białoruski",
|
"Login failed. This may be because two-factor authentication is not turned on for your account.": "Nie udało się zalogować. To może być spowodowane wyłączoną dwustopniową autoryzacją na twoim koncie.",
|
||||||
"Bosnian": "bośniacki",
|
"Wrong answer": "Niepoprawna odpowiedź",
|
||||||
"Bulgarian": "bułgarski",
|
"Erroneous CAPTCHA": "CAPTCHA wykonane błędnie",
|
||||||
"Burmese": "birmański",
|
"CAPTCHA is a required field": "CAPTCHA jest polem wymaganym",
|
||||||
"Catalan": "kataloński",
|
"User ID is a required field": "ID użytkownika jest polem wymaganym",
|
||||||
"Cebuano": "",
|
"Password is a required field": "Hasło jest polem wymaganym",
|
||||||
"Chinese (Simplified)": "chiński (uproszczony)",
|
"Wrong username or password": "Niepoprawny login lub hasło",
|
||||||
"Chinese (Traditional)": "chiński (tradycyjny)",
|
"Please sign in using 'Log in with Google'": "Zaloguj się używając \"Zaloguj się przez Google\"",
|
||||||
"Corsican": "korsykański",
|
"Password cannot be empty": "Hasło nie może być puste",
|
||||||
"Croatian": "chorwacki",
|
"Password cannot be longer than 55 characters": "Hasło nie może być dłuższe niż 55 znaków",
|
||||||
"Czech": "czeski",
|
"Please log in": "Proszę się zalogować",
|
||||||
"Danish": "duński",
|
"Invidious Private Feed for `x`": "",
|
||||||
"Dutch": "holenderski",
|
"channel:`x`": "kanał:`x",
|
||||||
"Esperanto": "esperanto",
|
"Deleted or invalid channel": "Usunięty lub niepoprawny kanał",
|
||||||
"Estonian": "estoński",
|
"This channel does not exist.": "Ten kanał nie istnieje.",
|
||||||
"Filipino": "filipiński",
|
"Could not get channel info.": "Nie udało się uzyskać informacji o kanale.",
|
||||||
"Finnish": "fiński",
|
"Could not fetch comments": "Nie udało się pobrać komentarzy",
|
||||||
"French": "francuski",
|
"View `x` replies": "Wyświetl `x` odpowiedzi",
|
||||||
"Galician": "galicyjski",
|
"`x` ago": "`x` temu",
|
||||||
"Georgian": "gruziński",
|
"Load more": "Wczytaj więcej",
|
||||||
"German": "niemiecki",
|
"`x` points": "`x` punktów",
|
||||||
"Greek": "grecki",
|
"Could not create mix.": "Nie udało się utworzyć miksu.",
|
||||||
"Gujarati": "",
|
"Empty playlist": "Lista odtwarzania jest pusta",
|
||||||
"Haitian Creole": "",
|
"Not a playlist.": "Niepoprawna lista.",
|
||||||
"Hausa": "",
|
"Playlist does not exist.": "Lista odtwarzania nie istnieje.",
|
||||||
"Hawaiian": "hawajski",
|
"Could not pull trending pages.": "Nie udało się pobrać strony na czasie.",
|
||||||
"Hebrew": "hebrajski",
|
"Hidden field \"challenge\" is a required field": "Ukryte pole \"wyzwanie\" jest polem wymaganym",
|
||||||
"Hindi": "hindi",
|
"Hidden field \"token\" is a required field": "Ukryte pole \"token\" jest polem wymaganym",
|
||||||
"Hmong": "",
|
"Erroneous challenge": "Niepoprawne wyzwanie",
|
||||||
"Hungarian": "węgierski",
|
"Erroneous token": "Niepoprawny token",
|
||||||
"Icelandic": "islandzki",
|
"No such user": "Niepoprawny użytkownik",
|
||||||
"Igbo": "",
|
"Token is expired, please try again": "Token wygasł, spróbuj ponownie",
|
||||||
"Indonesian": "indonezyjski",
|
"English": "angielski",
|
||||||
"Irish": "irlandzki",
|
"English (auto-generated)": "angielski (automatycznie generowane)",
|
||||||
"Italian": "włoski",
|
"Afrikaans": "afrykanerski",
|
||||||
"Japanese": "japoński",
|
"Albanian": "albański",
|
||||||
"Javanese": "jawajski",
|
"Amharic": "amharski",
|
||||||
"Kannada": "",
|
"Arabic": "arabski",
|
||||||
"Kazakh": "kazachski",
|
"Armenian": "armeński",
|
||||||
"Khmer": "",
|
"Azerbaijani": "azerski",
|
||||||
"Korean": "koreański",
|
"Bangla": "bengalski",
|
||||||
"Kurdish": "kurdyjski",
|
"Basque": "baskijski",
|
||||||
"Kyrgyz": "kirgiski",
|
"Belarusian": "białoruski",
|
||||||
"Lao": "",
|
"Bosnian": "bośniacki",
|
||||||
"Latin": "łaciński",
|
"Bulgarian": "bułgarski",
|
||||||
"Latvian": "łotewski",
|
"Burmese": "birmański",
|
||||||
"Lithuanian": "litewski",
|
"Catalan": "kataloński",
|
||||||
"Luxembourgish": "luksemburski",
|
"Cebuano": "cebuański",
|
||||||
"Macedonian": "macedoński",
|
"Chinese (Simplified)": "chiński (uproszczony)",
|
||||||
"Malagasy": "malgaski",
|
"Chinese (Traditional)": "chiński (tradycyjny)",
|
||||||
"Malay": "malajski",
|
"Corsican": "korsykański",
|
||||||
"Malayalam": "",
|
"Croatian": "chorwacki",
|
||||||
"Maltese": "maltański",
|
"Czech": "czeski",
|
||||||
"Maori": "",
|
"Danish": "duński",
|
||||||
"Marathi": "",
|
"Dutch": "holenderski",
|
||||||
"Mongolian": "mongolski",
|
"Esperanto": "esperanto",
|
||||||
"Nepali": "nepalski",
|
"Estonian": "estoński",
|
||||||
"Norwegian": "norweski",
|
"Filipino": "filipiński",
|
||||||
"Nyanja": "",
|
"Finnish": "fiński",
|
||||||
"Pashto": "",
|
"French": "francuski",
|
||||||
"Persian": "perski",
|
"Galician": "galicyjski",
|
||||||
"Polish": "polski",
|
"Georgian": "gruziński",
|
||||||
"Portuguese": "portugalski",
|
"German": "niemiecki",
|
||||||
"Punjabi": "",
|
"Greek": "grecki",
|
||||||
"Romanian": "rumuński",
|
"Gujarati": "gudźarati",
|
||||||
"Russian": "rosyjski",
|
"Haitian Creole": "kreolski haitański",
|
||||||
"Samoan": "",
|
"Hausa": "hausa",
|
||||||
"Scottish Gaelic": "",
|
"Hawaiian": "hawajski",
|
||||||
"Serbian": "serbski",
|
"Hebrew": "hebrajski",
|
||||||
"Shona": "",
|
"Hindi": "hindi",
|
||||||
"Sindhi": "",
|
"Hmong": "hmong",
|
||||||
"Sinhala": "",
|
"Hungarian": "węgierski",
|
||||||
"Slovak": "słowacki",
|
"Icelandic": "islandzki",
|
||||||
"Slovenian": "słoweński",
|
"Igbo": "ibo",
|
||||||
"Somali": "somalijski",
|
"Indonesian": "indonezyjski",
|
||||||
"Southern Sotho": "",
|
"Irish": "irlandzki",
|
||||||
"Spanish": "hiszpański",
|
"Italian": "włoski",
|
||||||
"Spanish (Latin America)": "hiszpański (ameryka łacińska)",
|
"Japanese": "japoński",
|
||||||
"Sundanese": "",
|
"Javanese": "jawajski",
|
||||||
"Swahili": "",
|
"Kannada": "kannada",
|
||||||
"Swedish": "szwedzki",
|
"Kazakh": "kazachski",
|
||||||
"Tajik": "",
|
"Khmer": "khmerski",
|
||||||
"Tamil": "",
|
"Korean": "koreański",
|
||||||
"Telugu": "",
|
"Kurdish": "kurdyjski",
|
||||||
"Thai": "tajski",
|
"Kyrgyz": "kirgiski",
|
||||||
"Turkish": "turecki",
|
"Lao": "laotański",
|
||||||
"Ukrainian": "ukraiński",
|
"Latin": "łaciński",
|
||||||
"Urdu": "",
|
"Latvian": "łotewski",
|
||||||
"Uzbek": "uzbecki",
|
"Lithuanian": "litewski",
|
||||||
"Vietnamese": "wietnamski",
|
"Luxembourgish": "luksemburski",
|
||||||
"Welsh": "walijski",
|
"Macedonian": "macedoński",
|
||||||
"Western Frisian": "",
|
"Malagasy": "malgaski",
|
||||||
"Xhosa": "",
|
"Malay": "malajski",
|
||||||
"Yiddish": "",
|
"Malayalam": "malajalam",
|
||||||
"Yoruba": "",
|
"Maltese": "maltański",
|
||||||
"Zulu": "",
|
"Maori": "maoryski",
|
||||||
"`x` years": "`x` lat",
|
"Marathi": "marathi",
|
||||||
"`x` months": "`x` miesięcy",
|
"Mongolian": "mongolski",
|
||||||
"`x` weeks": "`x` tygodni",
|
"Nepali": "nepalski",
|
||||||
"`x` days": "`x` dni",
|
"Norwegian Bokmål": "norweski",
|
||||||
"`x` hours": "`x` godzin",
|
"Nyanja": "njandża",
|
||||||
"`x` minutes": "`x` minut",
|
"Pashto": "paszto",
|
||||||
"`x` seconds": "`x` sekund",
|
"Persian": "perski",
|
||||||
"Fallback comments: ": "Zastępcze komentarze: ",
|
"Polish": "polski",
|
||||||
"Popular": "Popularne",
|
"Portuguese": "portugalski",
|
||||||
"Top": "Na czasie",
|
"Punjabi": "pendżabski",
|
||||||
"About": "Informacje",
|
"Romanian": "rumuński",
|
||||||
"Rating: ": "Ocena: ",
|
"Russian": "rosyjski",
|
||||||
"Language: ": "Język: ",
|
"Samoan": "samoański",
|
||||||
"Default": "",
|
"Scottish Gaelic": "gaelicki szkocki",
|
||||||
"Music": "Muzyka",
|
"Serbian": "serbski",
|
||||||
"Gaming": "Gry",
|
"Shona": "shona",
|
||||||
"News": "Wiadomości",
|
"Sindhi": "sindhi",
|
||||||
"Movies": "Filmy",
|
"Sinhala": "syngaleski",
|
||||||
"Download": "Pobierz",
|
"Slovak": "słowacki",
|
||||||
"Download as: ": "Pobierz jako: ",
|
"Slovenian": "słoweński",
|
||||||
"%A %B %-d, %Y": "",
|
"Somali": "somalijski",
|
||||||
"(edited)": "(edytowany)",
|
"Southern Sotho": "sotho południowy",
|
||||||
"Youtube permalink of the comment": "Odnośnik bezpośredni do komentarza na YouTube",
|
"Spanish": "hiszpański",
|
||||||
"`x` marked it with a ❤": "",
|
"Spanish (Latin America)": "hiszpański (ameryka łacińska)",
|
||||||
"Audio mode": "Tryb audio",
|
"Sundanese": "sundajski",
|
||||||
"Video mode": "Tryb wideo"
|
"Swahili": "suahili",
|
||||||
}
|
"Swedish": "szwedzki",
|
||||||
|
"Tajik": "tadżycki",
|
||||||
|
"Tamil": "tamilski",
|
||||||
|
"Telugu": "telugu",
|
||||||
|
"Thai": "tajski",
|
||||||
|
"Turkish": "turecki",
|
||||||
|
"Ukrainian": "ukraiński",
|
||||||
|
"Urdu": "urdu",
|
||||||
|
"Uzbek": "uzbecki",
|
||||||
|
"Vietnamese": "wietnamski",
|
||||||
|
"Welsh": "walijski",
|
||||||
|
"Western Frisian": "zachodniofryzyjski",
|
||||||
|
"Xhosa": "xhosa",
|
||||||
|
"Yiddish": "jidysz",
|
||||||
|
"Yoruba": "joruba",
|
||||||
|
"Zulu": "zuluski",
|
||||||
|
"`x` years": "`x` lat",
|
||||||
|
"`x` months": "`x` miesięcy",
|
||||||
|
"`x` weeks": "`x` tygodni",
|
||||||
|
"`x` days": "`x` dni",
|
||||||
|
"`x` hours": "`x` godzin",
|
||||||
|
"`x` minutes": "`x` minut",
|
||||||
|
"`x` seconds": "`x` sekund",
|
||||||
|
"Fallback comments: ": "Zastępcze komentarze: ",
|
||||||
|
"Popular": "Popularne",
|
||||||
|
"Top": "Top",
|
||||||
|
"About": "Informacje",
|
||||||
|
"Rating: ": "Ocena: ",
|
||||||
|
"Language: ": "Język: ",
|
||||||
|
"View as playlist": "Obejrzyj w playliście",
|
||||||
|
"Default": "Domyślnie",
|
||||||
|
"Music": "Muzyka",
|
||||||
|
"Gaming": "Gry",
|
||||||
|
"News": "Wiadomości",
|
||||||
|
"Movies": "Filmy",
|
||||||
|
"Download": "Pobierz",
|
||||||
|
"Download as: ": "Pobierz jako: ",
|
||||||
|
"%A %B %-d, %Y": "",
|
||||||
|
"(edited)": "(edytowany)",
|
||||||
|
"YouTube comment permalink": "Odnośnik bezpośredni do komentarza na YouTube",
|
||||||
|
"permalink": "bezpośredni odnośnik",
|
||||||
|
"`x` marked it with a ❤": "`x` oznaczonych ❤",
|
||||||
|
"Audio mode": "Tryb audio",
|
||||||
|
"Video mode": "Tryb wideo",
|
||||||
|
"Videos": "Filmy",
|
||||||
|
"Playlists": "Playlisty",
|
||||||
|
"Community": "Społeczność",
|
||||||
|
"Current version: ": "Aktualna wersja: "
|
||||||
|
}
|
||||||
336
locales/pt-BR.json
Normal file
336
locales/pt-BR.json
Normal file
@@ -0,0 +1,336 @@
|
|||||||
|
{
|
||||||
|
"`x` subscribers": "`x` inscritos",
|
||||||
|
"`x` videos": "`x` videos",
|
||||||
|
"`x` playlists": "`x` lista de reprodução",
|
||||||
|
"LIVE": "AO VIVO",
|
||||||
|
"Shared `x` ago": "Compartilhado `x` atrás",
|
||||||
|
"Unsubscribe": "Desinscrever-se",
|
||||||
|
"Subscribe": "Inscrever-se",
|
||||||
|
"View channel on YouTube": "Ver canal no YouTube",
|
||||||
|
"View playlist on YouTube": "Ver lista de reprodução no YouTube",
|
||||||
|
"newest": "mais recentes",
|
||||||
|
"oldest": "mais antigos",
|
||||||
|
"popular": "populares",
|
||||||
|
"last": "último",
|
||||||
|
"Next page": "Próxima página",
|
||||||
|
"Previous page": "Página anterior",
|
||||||
|
"Clear watch history?": "Limpar histórico de reprodução?",
|
||||||
|
"New password": "Nova senha",
|
||||||
|
"New passwords must match": "Nova senha deve ser igual",
|
||||||
|
"Cannot change password for Google accounts": "Não é possível alterar sua senha da conta Google",
|
||||||
|
"Authorize token?": "Autorizar o token?",
|
||||||
|
"Authorize token for `x`?": "Autorizar o token para `x`?",
|
||||||
|
"Yes": "Sim",
|
||||||
|
"No": "Não",
|
||||||
|
"Import and Export Data": "Importar e Exportar Dados",
|
||||||
|
"Import": "Importar",
|
||||||
|
"Import Invidious data": "Importar datos do Invidious",
|
||||||
|
"Import YouTube subscriptions": "Importar inscrições do YouTube",
|
||||||
|
"Import FreeTube subscriptions (.db)": "Importar inscrições do FreeTube (.db)",
|
||||||
|
"Import NewPipe subscriptions (.json)": "Importar inscrições do NewPipe (.json)",
|
||||||
|
"Import NewPipe data (.zip)": "Importar dados do NewPipe (.zip)",
|
||||||
|
"Export": "Exportar",
|
||||||
|
"Export subscriptions as OPML": "Exportar inscrições como OPML",
|
||||||
|
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Exportar inscrições como OPML (para NewPipe e FreeTube)",
|
||||||
|
"Export data as JSON": "Exportar dados como JSON",
|
||||||
|
"Delete account?": "Deletar conta?",
|
||||||
|
"History": "Histórico",
|
||||||
|
"An alternative front-end to YouTube": "Uma interface alternativa para o YouTube",
|
||||||
|
"JavaScript license information": "Informação de licença do JavaScript",
|
||||||
|
"source": "código fonte",
|
||||||
|
"Log in": "Entrar",
|
||||||
|
"Log in/register": "Entrar/Registrar",
|
||||||
|
"Log in with Google": "Entrar com conta Google",
|
||||||
|
"User ID": "Usuário",
|
||||||
|
"Password": "Senha",
|
||||||
|
"Time (h:mm:ss):": "Hora (h:mm:ss):",
|
||||||
|
"Text CAPTCHA": "CAPTCHA em texto",
|
||||||
|
"Image CAPTCHA": "CAPTCHA em imagen",
|
||||||
|
"Sign In": "Entrar",
|
||||||
|
"Register": "Registrar",
|
||||||
|
"E-mail": "E-mail",
|
||||||
|
"Google verification code": "Código de verificação do Google",
|
||||||
|
"Preferences": "Preferências",
|
||||||
|
"Player preferences": "Preferências do reprodutor",
|
||||||
|
"Always loop: ": "Repetir sempre: ",
|
||||||
|
"Autoplay: ": "Reprodução automática: ",
|
||||||
|
"Play next by default: ": "Sempre reproduzir próximo: ",
|
||||||
|
"Autoplay next video: ": "Reproduzir próximo video automaticamente: ",
|
||||||
|
"Listen by default: ": "Sempre ativar som: ",
|
||||||
|
"Proxy videos: ": "Usar proxy nos videos: ",
|
||||||
|
"Default speed: ": "Velocidade preferida: ",
|
||||||
|
"Preferred video quality: ": "Qualidade de video preferida: ",
|
||||||
|
"Player volume: ": "Volume de reprodução: ",
|
||||||
|
"Default comments: ": "Preferência de comentários: ",
|
||||||
|
"youtube": "youtube",
|
||||||
|
"reddit": "reddit",
|
||||||
|
"Default captions: ": "Preferência de legendas: ",
|
||||||
|
"Fallback captions: ": "Legendas alternativas: ",
|
||||||
|
"Show related videos: ": "Ver videos relacionados: ",
|
||||||
|
"Show annotations by default: ": "Sempre mostrar anotações: ",
|
||||||
|
"Visual preferences": "Preferências visuais",
|
||||||
|
"Player style: ": "Estilo do reprodutor",
|
||||||
|
"Dark mode: ": "Modo escuro: ",
|
||||||
|
"Theme: ": "Tema",
|
||||||
|
"dark": "escuro",
|
||||||
|
"light": "claro",
|
||||||
|
"Thin mode: ": "Modo compacto: ",
|
||||||
|
"Subscription preferences": "Preferências de inscrições",
|
||||||
|
"Show annotations by default for subscribed channels: ": "Sempre mostrar anotações nos videos de canais inscritos ",
|
||||||
|
"Redirect homepage to feed: ": "Redirecionar página inicial para o feed: ",
|
||||||
|
"Number of videos shown in feed: ": "Número de videos no feed: ",
|
||||||
|
"Sort videos by: ": "Ordenar videos por: ",
|
||||||
|
"published": "publicado",
|
||||||
|
"published - reverse": "publicado - ordem inversa",
|
||||||
|
"alphabetically": "alfabética",
|
||||||
|
"alphabetically - reverse": "alfabética - ordem inversa",
|
||||||
|
"channel name": "nome do canal",
|
||||||
|
"channel name - reverse": "nome do canal - ordem inversa",
|
||||||
|
"Only show latest video from channel: ": "Mostrar apenas o video mais recente do canal: ",
|
||||||
|
"Only show latest unwatched video from channel: ": "Mostrar apenas o video mais recente não visualizados do canal: ",
|
||||||
|
"Only show unwatched: ": "Mostrar apenas videos não visualizados: ",
|
||||||
|
"Only show notifications (if there are any): ": "Mostrar apenas notificações (se existentes): ",
|
||||||
|
"Enable web notifications": "Ativar notificações pela web",
|
||||||
|
"`x` uploaded a video": "`x` publicou um novo video",
|
||||||
|
"`x` is live": "`x` está ao vivo",
|
||||||
|
"Data preferences": "Preferências de dados",
|
||||||
|
"Clear watch history": "Limpar histórico de reprodução",
|
||||||
|
"Import/export data": "Importar/Exportar dados",
|
||||||
|
"Change password": "Alterar senha",
|
||||||
|
"Manage subscriptions": "Gerenciar inscrições",
|
||||||
|
"Manage tokens": "Gerenciar tokens",
|
||||||
|
"Watch history": "Histórico de reprodução",
|
||||||
|
"Delete account": "Apagar sua conta",
|
||||||
|
"Administrator preferences": "Preferências de administrador",
|
||||||
|
"Default homepage: ": "Página de inicio padrão: ",
|
||||||
|
"Feed menu: ": "Menú do feed: ",
|
||||||
|
"Top enabled: ": "Habilitar destaques: ",
|
||||||
|
"CAPTCHA enabled: ": "Habilitar CAPTCHA: ",
|
||||||
|
"Login enabled: ": "Habilitar login: ",
|
||||||
|
"Registration enabled: ": "Habilitar registro: ",
|
||||||
|
"Report statistics: ": "Habilitar estatísticas: ",
|
||||||
|
"Save preferences": "Salvar preferências",
|
||||||
|
"Subscription manager": "Gerenciador de inscrições",
|
||||||
|
"Token manager": "Gerenciador de tokens",
|
||||||
|
"Token": "Token",
|
||||||
|
"`x` subscriptions": "`x` inscrições",
|
||||||
|
"`x` tokens": "`x` tokens",
|
||||||
|
"Import/export": "Importar/Exportar",
|
||||||
|
"unsubscribe": "desinscrever-se",
|
||||||
|
"revoke": "revogar",
|
||||||
|
"Subscriptions": "Inscrições",
|
||||||
|
"`x` unseen notifications": "`x` notificações não visualizadas",
|
||||||
|
"search": "procurar",
|
||||||
|
"Log out": "Sair",
|
||||||
|
"Released under the AGPLv3 by Omar Roth.": "Publicado sob a licença AGPLv3, por Omar Roth.",
|
||||||
|
"Source available here.": "Código fonte disponível aqui.",
|
||||||
|
"View JavaScript license information.": "Ver informações da licença do JavaScript.",
|
||||||
|
"View privacy policy.": "Ver a política de privacidade",
|
||||||
|
"Trending": "Trending",
|
||||||
|
"Public": "Público",
|
||||||
|
"Unlisted": "No listado",
|
||||||
|
"Private": "Privado",
|
||||||
|
"View all playlists": "Mostrar todas listas de reprodução",
|
||||||
|
"Updated `x` ago": "Enviado `x` atrás",
|
||||||
|
"Delete playlist `x`?": "Apagar a playlist `x`?",
|
||||||
|
"Delete playlist": "Apagar playlist",
|
||||||
|
"Create playlist": "Criar playlist",
|
||||||
|
"Title": "Título",
|
||||||
|
"Playlist privacy": "Privacidade da playlist",
|
||||||
|
"Editing playlist `x`": "Editando playlist",
|
||||||
|
"Watch on YouTube": "Assistir vídeo no YouTube",
|
||||||
|
"Hide annotations": "Ocultar anotações",
|
||||||
|
"Show annotations": "Mostrar anotações",
|
||||||
|
"Genre: ": "Gênero: ",
|
||||||
|
"License: ": "Licença: ",
|
||||||
|
"Family friendly? ": "Fistrar conteúdo impróprio: ",
|
||||||
|
"Wilson score: ": "Pontuação de Wilson: ",
|
||||||
|
"Engagement: ": "Engagement: ",
|
||||||
|
"Whitelisted regions: ": "Regiões permitidas: ",
|
||||||
|
"Blacklisted regions: ": "Regiões bloqueadas: ",
|
||||||
|
"Shared `x`": "Compartilhado `x`",
|
||||||
|
"`x` views": "`x` visualizações",
|
||||||
|
"Premieres in `x`": "Estreias em `x`",
|
||||||
|
"Premieres `x`": "Estreia `x`",
|
||||||
|
"Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.": "Oi! Parece que seu JavaScript está desativado. Clique aqui para ver os comentários, entretanto eles podem levar um pouco mais de tempo para carregar.",
|
||||||
|
"View YouTube comments": "Ver comentários do YouTube",
|
||||||
|
"View more comments on Reddit": "Ver mais comentários do Reddit",
|
||||||
|
"View `x` comments": "Ver `x` comentários",
|
||||||
|
"View Reddit comments": "Ver comentários do Reddit",
|
||||||
|
"Hide replies": "Ocultar respostas",
|
||||||
|
"Show replies": "Mostrar respostas",
|
||||||
|
"Incorrect password": "Senha incorreta",
|
||||||
|
"Quota exceeded, try again in a few hours": "Cota excedida, tente novamente em algumas horas",
|
||||||
|
"Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.": "Não foi possível fazer login, sua autenticação por dois passos (app autenticador ou sms) deve estar ativada.",
|
||||||
|
"Invalid TFA code": "Código TFA inválido",
|
||||||
|
"Login failed. This may be because two-factor authentication is not turned on for your account.": "Falha no login. Isso pode acontecer pois a autenticação por dois passos está desativada para sua conta.",
|
||||||
|
"Wrong answer": "Respuesta inválida",
|
||||||
|
"Erroneous CAPTCHA": "CAPTCHA inválido",
|
||||||
|
"CAPTCHA is a required field": "O CAPTCHA é um campo obrigatório",
|
||||||
|
"User ID is a required field": "O nome de usuário é um campo obrigatório",
|
||||||
|
"Password is a required field": "A senha é um campo obrigatório",
|
||||||
|
"Wrong username or password": "Nome de usuário ou senha inválidos",
|
||||||
|
"Please sign in using 'Log in with Google'": "Por favor, entre usando 'Entrar com conta Google'",
|
||||||
|
"Password cannot be empty": "A senha não pode estar vazia",
|
||||||
|
"Password cannot be longer than 55 characters": "A senha não pode ter mais que 55 caracteres",
|
||||||
|
"Please log in": "Por favor, inicie sua seção",
|
||||||
|
"Invidious Private Feed for `x`": "Feed Privado do Invidious para `x`",
|
||||||
|
"channel:`x`": "canal: `x`",
|
||||||
|
"Deleted or invalid channel": "Este canal foi apagado ou é inválido",
|
||||||
|
"This channel does not exist.": "Este canal não existe.",
|
||||||
|
"Could not get channel info.": "Não foi possível obter as informações do canal.",
|
||||||
|
"Could not fetch comments": "Não foi possível obter os comentários",
|
||||||
|
"View `x` replies": "Ver `x` respostas",
|
||||||
|
"`x` ago": "`x` atrás",
|
||||||
|
"Load more": "Carregar mais",
|
||||||
|
"`x` points": "`x` pontos",
|
||||||
|
"Could not create mix.": "Não foi possível criar o mix.",
|
||||||
|
"Empty playlist": "A lista de reprodução está vazia",
|
||||||
|
"Not a playlist.": "Lista de reprodução inválida.",
|
||||||
|
"Playlist does not exist.": "A lista de reprodução não existe.",
|
||||||
|
"Could not pull trending pages.": "Não foi possível oberter as páginas dos videos em alta.",
|
||||||
|
"Hidden field \"challenge\" is a required field": "O campo oculto \"desafio\" é obrigatório",
|
||||||
|
"Hidden field \"token\" is a required field": "O campo oculto \"token\" é obrigatório",
|
||||||
|
"Erroneous challenge": "Desafío inválido",
|
||||||
|
"Erroneous token": "Símbolo inválido",
|
||||||
|
"No such user": "Usuario inválido",
|
||||||
|
"Token is expired, please try again": "Token expirou, tente novamente",
|
||||||
|
"English": "Inglês",
|
||||||
|
"English (auto-generated)": "Inglês (gerado automaticamente)",
|
||||||
|
"Afrikaans": "Africâner",
|
||||||
|
"Albanian": "Albanês",
|
||||||
|
"Amharic": "Amárico",
|
||||||
|
"Arabic": "Árabe",
|
||||||
|
"Armenian": "Armênio",
|
||||||
|
"Azerbaijani": "Azeri",
|
||||||
|
"Bangla": "Bengalês",
|
||||||
|
"Basque": "Basco",
|
||||||
|
"Belarusian": "Bielorrusso",
|
||||||
|
"Bosnian": "Língua Bósnia",
|
||||||
|
"Bulgarian": "Búlgaro",
|
||||||
|
"Burmese": "Birmanês",
|
||||||
|
"Catalan": "Catalão",
|
||||||
|
"Cebuano": "Cebuano",
|
||||||
|
"Chinese (Simplified)": "Chinês Simplificado",
|
||||||
|
"Chinese (Traditional)": "Chinês Tradicional",
|
||||||
|
"Corsican": "Corso",
|
||||||
|
"Croatian": "Croata",
|
||||||
|
"Czech": "Checo",
|
||||||
|
"Danish": "Dinamarquês",
|
||||||
|
"Dutch": "Holandês",
|
||||||
|
"Esperanto": "Esperanto",
|
||||||
|
"Estonian": "Estoniano",
|
||||||
|
"Filipino": "Filipino",
|
||||||
|
"Finnish": "Finlandês",
|
||||||
|
"French": "Francês",
|
||||||
|
"Galician": "Galego",
|
||||||
|
"Georgian": "Georgiano",
|
||||||
|
"German": "Alemão",
|
||||||
|
"Greek": "Grego",
|
||||||
|
"Gujarati": "Guzerate",
|
||||||
|
"Haitian Creole": "Crioulo Haitiano",
|
||||||
|
"Hausa": "Hauçá",
|
||||||
|
"Hawaiian": "Havaiano",
|
||||||
|
"Hebrew": "Hebraico",
|
||||||
|
"Hindi": "Hindi",
|
||||||
|
"Hmong": "Hmong",
|
||||||
|
"Hungarian": "Húngaro",
|
||||||
|
"Icelandic": "Islandês",
|
||||||
|
"Igbo": "Igbo",
|
||||||
|
"Indonesian": "Indonésio",
|
||||||
|
"Irish": "Irlandês",
|
||||||
|
"Italian": "Italiano",
|
||||||
|
"Japanese": "Japonês",
|
||||||
|
"Javanese": "Javanês",
|
||||||
|
"Kannada": "Canarẽs",
|
||||||
|
"Kazakh": "Cazaque",
|
||||||
|
"Khmer": "Khmer",
|
||||||
|
"Korean": "Coreano",
|
||||||
|
"Kurdish": "Curdo",
|
||||||
|
"Kyrgyz": "Quirguiz",
|
||||||
|
"Lao": "Laosiano",
|
||||||
|
"Latin": "Latim",
|
||||||
|
"Latvian": "Letão",
|
||||||
|
"Lithuanian": "Lituano",
|
||||||
|
"Luxembourgish": "Luxemburguês",
|
||||||
|
"Macedonian": "Macedônio",
|
||||||
|
"Malagasy": "Malgaxe",
|
||||||
|
"Malay": "Malaia",
|
||||||
|
"Malayalam": "Malaiala",
|
||||||
|
"Maltese": "Maltês",
|
||||||
|
"Maori": "Maori",
|
||||||
|
"Marathi": "Marathi",
|
||||||
|
"Mongolian": "Mongol",
|
||||||
|
"Nepali": "Nepalês",
|
||||||
|
"Norwegian Bokmål": "Bokmål Norueguês",
|
||||||
|
"Nyanja": "Nianja",
|
||||||
|
"Pashto": "Pachto",
|
||||||
|
"Persian": "Persa",
|
||||||
|
"Polish": "Polaco",
|
||||||
|
"Portuguese": "Português",
|
||||||
|
"Punjabi": "Panjábi",
|
||||||
|
"Romanian": "Língua Romena",
|
||||||
|
"Russian": "Russo",
|
||||||
|
"Samoan": "Samoano",
|
||||||
|
"Scottish Gaelic": "Ânglico Escocês",
|
||||||
|
"Serbian": "Língua Sérvia",
|
||||||
|
"Shona": "Xona",
|
||||||
|
"Sindhi": "Sindi",
|
||||||
|
"Sinhala": "Cingalês",
|
||||||
|
"Slovak": "Eslovaco",
|
||||||
|
"Slovenian": "Esloveno",
|
||||||
|
"Somali": "Língua Somalí",
|
||||||
|
"Southern Sotho": "Sesoto",
|
||||||
|
"Spanish": "Espanhol",
|
||||||
|
"Spanish (Latin America)": "Espanhol (América)",
|
||||||
|
"Sundanese": "Sondanese",
|
||||||
|
"Swahili": "Suaíli",
|
||||||
|
"Swedish": "Suéco",
|
||||||
|
"Tajik": "Tajiques",
|
||||||
|
"Tamil": "Tâmil",
|
||||||
|
"Telugu": "Telugo",
|
||||||
|
"Thai": "Tailandês",
|
||||||
|
"Turkish": "Turco",
|
||||||
|
"Ukrainian": "Ucraniano",
|
||||||
|
"Urdu": "Urdu",
|
||||||
|
"Uzbek": "Uzbeque",
|
||||||
|
"Vietnamese": "Vietnamita",
|
||||||
|
"Welsh": "Galês",
|
||||||
|
"Western Frisian": "Língua Frísia",
|
||||||
|
"Xhosa": "Xhosa",
|
||||||
|
"Yiddish": "Iídiche",
|
||||||
|
"Yoruba": "Iorubá",
|
||||||
|
"Zulu": "Língua Zulú",
|
||||||
|
"`x` years": "`x` anos",
|
||||||
|
"`x` months": "`x` meses",
|
||||||
|
"`x` weeks": "`x` semanas",
|
||||||
|
"`x` days": "`x` dias",
|
||||||
|
"`x` hours": "`x` horas",
|
||||||
|
"`x` minutes": "`x` minutos",
|
||||||
|
"`x` seconds": "`x` segundos",
|
||||||
|
"Fallback comments: ": "Comentários alternativos: ",
|
||||||
|
"Popular": "Populares",
|
||||||
|
"Top": "No topo",
|
||||||
|
"About": "Sobre",
|
||||||
|
"Rating: ": "Avaliação: ",
|
||||||
|
"Language: ": "Idioma: ",
|
||||||
|
"View as playlist": "Ver como lista de reprodução",
|
||||||
|
"Default": "Configuração padrão",
|
||||||
|
"Music": "Música",
|
||||||
|
"Gaming": "Video Games",
|
||||||
|
"News": "Notícias",
|
||||||
|
"Movies": "Filmes",
|
||||||
|
"Download": "Baixar",
|
||||||
|
"Download as: ": "Baixar como: ",
|
||||||
|
"%A %B %-d, %Y": "%A %-d %B %Y",
|
||||||
|
"(edited)": "(editado)",
|
||||||
|
"YouTube comment permalink": "Link permanente do comentário do YouTube",
|
||||||
|
"permalink": "Link permanente",
|
||||||
|
"`x` marked it with a ❤": "`x` foi marcado como ❤",
|
||||||
|
"Audio mode": "Modo de audio",
|
||||||
|
"Video mode": "Modo de video",
|
||||||
|
"Videos": "Vídeos",
|
||||||
|
"Playlists": "Listas de reprodução",
|
||||||
|
"Community": "Comunidade",
|
||||||
|
"Current version: ": "Versão atual: "
|
||||||
|
}
|
||||||
387
locales/pt-PT.json
Normal file
387
locales/pt-PT.json
Normal file
@@ -0,0 +1,387 @@
|
|||||||
|
{
|
||||||
|
"`x` subscribers.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` subscritores.",
|
||||||
|
"": "`x` subscritores."
|
||||||
|
},
|
||||||
|
"`x` videos.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` vídeos.",
|
||||||
|
"": "`x` vídeos."
|
||||||
|
},
|
||||||
|
"`x` playlists.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` listas de reprodução.",
|
||||||
|
"": "`x` listas de reprodução."
|
||||||
|
},
|
||||||
|
"LIVE": "Em direto",
|
||||||
|
"Shared `x` ago": "Partilhado `x` atrás",
|
||||||
|
"Unsubscribe": "Anular subscrição",
|
||||||
|
"Subscribe": "Subscrever",
|
||||||
|
"View channel on YouTube": "Ver canal no YouTube",
|
||||||
|
"View playlist on YouTube": "Ver lista de reprodução no YouTube",
|
||||||
|
"newest": "mais recentes",
|
||||||
|
"oldest": "mais antigos",
|
||||||
|
"popular": "popular",
|
||||||
|
"last": "últimos",
|
||||||
|
"Next page": "Próxima página",
|
||||||
|
"Previous page": "Página anterior",
|
||||||
|
"Clear watch history?": "Limpar histórico de reprodução?",
|
||||||
|
"New password": "Nova palavra-chave",
|
||||||
|
"New passwords must match": "As novas palavra-chaves devem corresponder",
|
||||||
|
"Cannot change password for Google accounts": "Não é possível alterar palavra-chave para contas do Google",
|
||||||
|
"Authorize token?": "Autorizar token?",
|
||||||
|
"Authorize token for `x`?": "Autorizar token para `x`?",
|
||||||
|
"Yes": "Sim",
|
||||||
|
"No": "Não",
|
||||||
|
"Import and Export Data": "Importar e Exportar Dados",
|
||||||
|
"Import": "Importar",
|
||||||
|
"Import Invidious data": "Importar dados do Invidious",
|
||||||
|
"Import YouTube subscriptions": "Importar subscrições do YouTube",
|
||||||
|
"Import FreeTube subscriptions (.db)": "Importar subscrições do FreeTube (.db)",
|
||||||
|
"Import NewPipe subscriptions (.json)": "Importar subscrições do NewPipe (.json)",
|
||||||
|
"Import NewPipe data (.zip)": "Importar dados do NewPipe (.zip)",
|
||||||
|
"Export": "Exportar",
|
||||||
|
"Export subscriptions as OPML": "Exportar subscrições como OPML",
|
||||||
|
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Exportar subscrições como OPML (para NewPipe e FreeTube)",
|
||||||
|
"Export data as JSON": "Exportar dados como JSON",
|
||||||
|
"Delete account?": "Eliminar conta?",
|
||||||
|
"History": "Histórico",
|
||||||
|
"An alternative front-end to YouTube": "Uma interface alternativa para o YouTube",
|
||||||
|
"JavaScript license information": "Informação de licença do JavaScript",
|
||||||
|
"source": "código-fonte",
|
||||||
|
"Log in": "Iniciar sessão",
|
||||||
|
"Log in/register": "Iniciar sessão/Registar",
|
||||||
|
"Log in with Google": "Iniciar sessão com o Google",
|
||||||
|
"User ID": "Utilizador",
|
||||||
|
"Password": "Palavra-chave",
|
||||||
|
"Time (h:mm:ss):": "Tempo (h:mm:ss):",
|
||||||
|
"Text CAPTCHA": "Texto CAPTCHA",
|
||||||
|
"Image CAPTCHA": "Imagem CAPTCHA",
|
||||||
|
"Sign In": "Iniciar Sessão",
|
||||||
|
"Register": "Registar",
|
||||||
|
"E-mail": "E-mail",
|
||||||
|
"Google verification code": "Código de verificação do Google",
|
||||||
|
"Preferences": "Preferências",
|
||||||
|
"Player preferences": "Preferências do reprodutor",
|
||||||
|
"Always loop: ": "Repetir sempre: ",
|
||||||
|
"Autoplay: ": "Reprodução automática: ",
|
||||||
|
"Play next by default: ": "Sempre reproduzir próximo: ",
|
||||||
|
"Autoplay next video: ": "Reproduzir próximo vídeo automaticamente: ",
|
||||||
|
"Listen by default: ": "Apenas áudio: ",
|
||||||
|
"Proxy videos: ": "Usar proxy nos vídeos: ",
|
||||||
|
"Default speed: ": "Velocidade preferida: ",
|
||||||
|
"Preferred video quality: ": "Qualidade de vídeo preferida: ",
|
||||||
|
"Player volume: ": "Volume da reprodução: ",
|
||||||
|
"Default comments: ": "Preferência dos comentários: ",
|
||||||
|
"youtube": "youtube",
|
||||||
|
"reddit": "reddit",
|
||||||
|
"Default captions: ": "Legendas predefinidas: ",
|
||||||
|
"Fallback captions: ": "Legendas alternativas: ",
|
||||||
|
"Show related videos: ": "Mostrar vídeos relacionados: ",
|
||||||
|
"Show annotations by default: ": "Mostrar sempre anotações: ",
|
||||||
|
"Visual preferences": "Preferências visuais",
|
||||||
|
"Player style: ": "Estilo do reprodutor: ",
|
||||||
|
"Dark mode: ": "Modo escuro: ",
|
||||||
|
"Theme: ": "Tema: ",
|
||||||
|
"dark": "escuro",
|
||||||
|
"light": "claro",
|
||||||
|
"Thin mode: ": "Modo compacto: ",
|
||||||
|
"Subscription preferences": "Preferências de subscrições",
|
||||||
|
"Show annotations by default for subscribed channels: ": "Mostrar sempre anotações para os canais subscritos: ",
|
||||||
|
"Redirect homepage to feed: ": "Redirecionar página inicial para subscrições: ",
|
||||||
|
"Number of videos shown in feed: ": "Número de vídeos nas subscrições: ",
|
||||||
|
"Sort videos by: ": "Ordenar vídeos por: ",
|
||||||
|
"published": "publicado",
|
||||||
|
"published - reverse": "publicado - inverso",
|
||||||
|
"alphabetically": "alfabeticamente",
|
||||||
|
"alphabetically - reverse": "alfabeticamente - inverso",
|
||||||
|
"channel name": "nome do canal",
|
||||||
|
"channel name - reverse": "nome do canal - inverso",
|
||||||
|
"Only show latest video from channel: ": "Mostrar apenas o vídeo mais recente do canal: ",
|
||||||
|
"Only show latest unwatched video from channel: ": "Mostrar apenas vídeos mais recentes não visualizados do canal: ",
|
||||||
|
"Only show unwatched: ": "Mostrar apenas vídeos não visualizados: ",
|
||||||
|
"Only show notifications (if there are any): ": "Mostrar apenas notificações (se existirem): ",
|
||||||
|
"Enable web notifications": "Ativar notificações pela web",
|
||||||
|
"`x` uploaded a video": "`x` publicou um novo vídeo",
|
||||||
|
"`x` is live": "`x` está em direto",
|
||||||
|
"Data preferences": "Preferências de dados",
|
||||||
|
"Clear watch history": "Limpar histórico de reprodução",
|
||||||
|
"Import/export data": "Importar/Exportar dados",
|
||||||
|
"Change password": "Alterar palavra-chave",
|
||||||
|
"Manage subscriptions": "Gerir as subscrições",
|
||||||
|
"Manage tokens": "Gerir tokens",
|
||||||
|
"Watch history": "Histórico de reprodução",
|
||||||
|
"Delete account": "Eliminar conta",
|
||||||
|
"Administrator preferences": "Preferências de administrador",
|
||||||
|
"Default homepage: ": "Página inicial padrão: ",
|
||||||
|
"Feed menu: ": "Menu de subscrições: ",
|
||||||
|
"Top enabled: ": "Top ativado: ",
|
||||||
|
"CAPTCHA enabled: ": "CAPTCHA ativado: ",
|
||||||
|
"Login enabled: ": "Iniciar sessão ativado: ",
|
||||||
|
"Registration enabled: ": "Registar ativado: ",
|
||||||
|
"Report statistics: ": "Relatório de estatísticas: ",
|
||||||
|
"Save preferences": "Gravar preferências",
|
||||||
|
"Subscription manager": "Gerir subscrições",
|
||||||
|
"Token manager": "Gerir tokens",
|
||||||
|
"Token": "Token",
|
||||||
|
"`x` subscriptions.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` subscrições.",
|
||||||
|
"": "`x` subscrições."
|
||||||
|
},
|
||||||
|
"`x` tokens.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` tokens.",
|
||||||
|
"": "`x` tokens."
|
||||||
|
},
|
||||||
|
"Import/export": "Importar/Exportar",
|
||||||
|
"unsubscribe": "Anular subscrição",
|
||||||
|
"revoke": "revogar",
|
||||||
|
"Subscriptions": "Subscrições",
|
||||||
|
"`x` unseen notifications.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` notificações não vistas.",
|
||||||
|
"": "`x` notificações não vistas."
|
||||||
|
},
|
||||||
|
"search": "Pesquisar",
|
||||||
|
"Log out": "Terminar sessão",
|
||||||
|
"Released under the AGPLv3 by Omar Roth.": "Publicado sob a licença AGPLv3, por Omar Roth.",
|
||||||
|
"Source available here.": "Código-fonte disponível aqui.",
|
||||||
|
"View JavaScript license information.": "Ver informações da licença do JavaScript.",
|
||||||
|
"View privacy policy.": "Ver a política de privacidade.",
|
||||||
|
"Trending": "Tendências",
|
||||||
|
"Public": "Público",
|
||||||
|
"Unlisted": "Não listado",
|
||||||
|
"Private": "Privado",
|
||||||
|
"View all playlists": "Ver todas as listas de reprodução",
|
||||||
|
"Updated `x` ago": "Atualizado `x` atrás",
|
||||||
|
"Delete playlist `x`?": "Eliminar a lista de reprodução 'x'?",
|
||||||
|
"Delete playlist": "Eliminar lista de reprodução",
|
||||||
|
"Create playlist": "Criar lista de reprodução",
|
||||||
|
"Title": "Título",
|
||||||
|
"Playlist privacy": "Privacidade da lista de reprodução",
|
||||||
|
"Editing playlist `x`": "A editar lista de reprodução 'x'",
|
||||||
|
"Watch on YouTube": "Ver no YouTube",
|
||||||
|
"Hide annotations": "Ocultar anotações",
|
||||||
|
"Show annotations": "Mostrar anotações",
|
||||||
|
"Genre: ": "Género: ",
|
||||||
|
"License: ": "Licença: ",
|
||||||
|
"Family friendly? ": "Filtrar conteúdo impróprio: ",
|
||||||
|
"Wilson score: ": "Pontuação de Wilson: ",
|
||||||
|
"Engagement: ": "Compromisso: ",
|
||||||
|
"Whitelisted regions: ": "Regiões permitidas: ",
|
||||||
|
"Blacklisted regions: ": "Regiões bloqueadas: ",
|
||||||
|
"Shared `x`": "Partilhado `x`",
|
||||||
|
"`x` views.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` visualizações.",
|
||||||
|
"": "`x` visualizações."
|
||||||
|
},
|
||||||
|
"Premieres in `x`": "Estreias em 'x'",
|
||||||
|
"Premieres `x`": "Estreias 'x'",
|
||||||
|
"Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.": "Oi! Parece que JavaScript está desativado. Clique aqui para ver os comentários, entretanto eles podem levar mais tempo para carregar.",
|
||||||
|
"View YouTube comments": "Ver comentários do YouTube",
|
||||||
|
"View more comments on Reddit": "Ver mais comentários no Reddit",
|
||||||
|
"View `x` comments.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "Ver `x` comentários.",
|
||||||
|
"": "Ver `x` comentários."
|
||||||
|
},
|
||||||
|
"View Reddit comments": "Ver comentários do Reddit",
|
||||||
|
"Hide replies": "Ocultar respostas",
|
||||||
|
"Show replies": "Mostrar respostas",
|
||||||
|
"Incorrect password": "Palavra-chave incorreta",
|
||||||
|
"Quota exceeded, try again in a few hours": "Cota excedida. Tente novamente dentro de algumas horas",
|
||||||
|
"Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.": "Não é possível iniciar sessão, certifique-se de que a autenticação de dois fatores (Autenticador ou SMS) está ativada.",
|
||||||
|
"Invalid TFA code": "Código TFA inválido",
|
||||||
|
"Login failed. This may be because two-factor authentication is not turned on for your account.": "Falhou o início de sessão. Isto pode ser devido a dois fatores de autenticação não está ativado para sua conta.",
|
||||||
|
"Wrong answer": "Resposta errada",
|
||||||
|
"Erroneous CAPTCHA": "CAPTCHA inválido",
|
||||||
|
"CAPTCHA is a required field": "CAPTCHA é um campo obrigatório",
|
||||||
|
"User ID is a required field": "O nome de utilizador é um campo obrigatório",
|
||||||
|
"Password is a required field": "Palavra-chave é um campo obrigatório",
|
||||||
|
"Wrong username or password": "Nome de utilizador ou palavra-chave incorreto",
|
||||||
|
"Please sign in using 'Log in with Google'": "Por favor, inicie sessão usando 'Iniciar sessão com o Google'",
|
||||||
|
"Password cannot be empty": "A palavra-chave não pode estar vazia",
|
||||||
|
"Password cannot be longer than 55 characters": "A palavra-chave não pode ser superior a 55 caracteres",
|
||||||
|
"Please log in": "Por favor, inicie sessão",
|
||||||
|
"Invidious Private Feed for `x`": "Feed Privado do Invidious para `x`",
|
||||||
|
"channel:`x`": "canal:'x'",
|
||||||
|
"Deleted or invalid channel": "Canal apagado ou inválido",
|
||||||
|
"This channel does not exist.": "Este canal não existe.",
|
||||||
|
"Could not get channel info.": "Não foi possível obter as informações do canal.",
|
||||||
|
"Could not fetch comments": "Não foi possível obter os comentários",
|
||||||
|
"View `x` replies.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "Ver `x` respostas.",
|
||||||
|
"": "Ver `x` respostas."
|
||||||
|
},
|
||||||
|
"`x` ago": "`x` atrás",
|
||||||
|
"Load more": "Carregar mais",
|
||||||
|
"`x` points.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "'x' pontos.",
|
||||||
|
"": "'x' pontos."
|
||||||
|
},
|
||||||
|
"Could not create mix.": "Não foi possível criar mistura.",
|
||||||
|
"Empty playlist": "Lista de reprodução vazia",
|
||||||
|
"Not a playlist.": "Não é uma lista de reprodução.",
|
||||||
|
"Playlist does not exist.": "A lista de reprodução não existe.",
|
||||||
|
"Could not pull trending pages.": "Não foi possível obter páginas de tendências.",
|
||||||
|
"Hidden field \"challenge\" is a required field": "O campo oculto \"desafio\" é obrigatório",
|
||||||
|
"Hidden field \"token\" is a required field": "O campo oculto \"token\" é um campo obrigatório",
|
||||||
|
"Erroneous challenge": "Desafio inválido",
|
||||||
|
"Erroneous token": "Token inválido",
|
||||||
|
"No such user": "Utilizador inválido",
|
||||||
|
"Token is expired, please try again": "Token expirou, tente novamente",
|
||||||
|
"English": "Inglês",
|
||||||
|
"English (auto-generated)": "Inglês (auto-gerado)",
|
||||||
|
"Afrikaans": "Africano",
|
||||||
|
"Albanian": "Albanês",
|
||||||
|
"Amharic": "Amárico",
|
||||||
|
"Arabic": "Árabe",
|
||||||
|
"Armenian": "Arménio",
|
||||||
|
"Azerbaijani": "Azerbaijano",
|
||||||
|
"Bangla": "Bangla",
|
||||||
|
"Basque": "Basco",
|
||||||
|
"Belarusian": "Bielorrusso",
|
||||||
|
"Bosnian": "Bósnio",
|
||||||
|
"Bulgarian": "Búlgaro",
|
||||||
|
"Burmese": "Birmanês",
|
||||||
|
"Catalan": "Catalão",
|
||||||
|
"Cebuano": "Cebuano",
|
||||||
|
"Chinese (Simplified)": "Chinês (Simplificado)",
|
||||||
|
"Chinese (Traditional)": "Chinês (Tradicional)",
|
||||||
|
"Corsican": "Corso",
|
||||||
|
"Croatian": "Croata",
|
||||||
|
"Czech": "Checo",
|
||||||
|
"Danish": "Dinamarquês",
|
||||||
|
"Dutch": "Holandês",
|
||||||
|
"Esperanto": "Esperanto",
|
||||||
|
"Estonian": "Estónio",
|
||||||
|
"Filipino": "Filipino",
|
||||||
|
"Finnish": "Finlandês",
|
||||||
|
"French": "Francês",
|
||||||
|
"Galician": "Galego",
|
||||||
|
"Georgian": "Georgiano",
|
||||||
|
"German": "Alemão",
|
||||||
|
"Greek": "Grego",
|
||||||
|
"Gujarati": "Guzerate",
|
||||||
|
"Haitian Creole": "Crioulo haitiano",
|
||||||
|
"Hausa": "Hauçá",
|
||||||
|
"Hawaiian": "Havaiano",
|
||||||
|
"Hebrew": "Hebraico",
|
||||||
|
"Hindi": "Hindi",
|
||||||
|
"Hmong": "Hmong",
|
||||||
|
"Hungarian": "Húngaro",
|
||||||
|
"Icelandic": "Islandês",
|
||||||
|
"Igbo": "Igbo",
|
||||||
|
"Indonesian": "Indonésio",
|
||||||
|
"Irish": "Irlandês",
|
||||||
|
"Italian": "Italiano",
|
||||||
|
"Japanese": "Japonês",
|
||||||
|
"Javanese": "Javanês",
|
||||||
|
"Kannada": "Canarim",
|
||||||
|
"Kazakh": "Cazaque",
|
||||||
|
"Khmer": "Khmer",
|
||||||
|
"Korean": "Coreano",
|
||||||
|
"Kurdish": "Curdo",
|
||||||
|
"Kyrgyz": "Quirguiz",
|
||||||
|
"Lao": "Laosiano",
|
||||||
|
"Latin": "Latim",
|
||||||
|
"Latvian": "Letão",
|
||||||
|
"Lithuanian": "Lituano",
|
||||||
|
"Luxembourgish": "Luxemburguês",
|
||||||
|
"Macedonian": "Macedónio",
|
||||||
|
"Malagasy": "Malgaxe",
|
||||||
|
"Malay": "Malaio",
|
||||||
|
"Malayalam": "Malaiala",
|
||||||
|
"Maltese": "Maltês",
|
||||||
|
"Maori": "Maori",
|
||||||
|
"Marathi": "Marathi",
|
||||||
|
"Mongolian": "Mongol",
|
||||||
|
"Nepali": "Nepalês",
|
||||||
|
"Norwegian Bokmål": "Bokmål norueguês",
|
||||||
|
"Nyanja": "Nyanja",
|
||||||
|
"Pashto": "Pashto",
|
||||||
|
"Persian": "Persa",
|
||||||
|
"Polish": "Polaco",
|
||||||
|
"Portuguese": "Português",
|
||||||
|
"Punjabi": "Punjabi",
|
||||||
|
"Romanian": "Romeno",
|
||||||
|
"Russian": "Russo",
|
||||||
|
"Samoan": "Samoano",
|
||||||
|
"Scottish Gaelic": "Gaélico escocês",
|
||||||
|
"Serbian": "Sérvio",
|
||||||
|
"Shona": "Shona",
|
||||||
|
"Sindhi": "Sindhi",
|
||||||
|
"Sinhala": "Cingalês",
|
||||||
|
"Slovak": "Eslovaco",
|
||||||
|
"Slovenian": "Esloveno",
|
||||||
|
"Somali": "Somali",
|
||||||
|
"Southern Sotho": "Sotho do Sul",
|
||||||
|
"Spanish": "Espanhol",
|
||||||
|
"Spanish (Latin America)": "Espanhol (América Latina)",
|
||||||
|
"Sundanese": "Sudanês",
|
||||||
|
"Swahili": "Suaíli",
|
||||||
|
"Swedish": "Sueco",
|
||||||
|
"Tajik": "Tajique",
|
||||||
|
"Tamil": "Tâmil",
|
||||||
|
"Telugu": "Telugu",
|
||||||
|
"Thai": "Tailandês",
|
||||||
|
"Turkish": "Turco",
|
||||||
|
"Ukrainian": "Ucraniano",
|
||||||
|
"Urdu": "Urdu",
|
||||||
|
"Uzbek": "Uzbeque",
|
||||||
|
"Vietnamese": "Vietnamita",
|
||||||
|
"Welsh": "Galês",
|
||||||
|
"Western Frisian": "Frísio Ocidental",
|
||||||
|
"Xhosa": "Xhosa",
|
||||||
|
"Yiddish": "Iídiche",
|
||||||
|
"Yoruba": "Ioruba",
|
||||||
|
"Zulu": "Zulu",
|
||||||
|
"`x` years.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` anos.",
|
||||||
|
"": "`x` anos."
|
||||||
|
},
|
||||||
|
"`x` months.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` meses.",
|
||||||
|
"": "`x` meses."
|
||||||
|
},
|
||||||
|
"`x` weeks.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` semanas.",
|
||||||
|
"": "`x` semanas."
|
||||||
|
},
|
||||||
|
"`x` days.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` dias.",
|
||||||
|
"": "`x` dias."
|
||||||
|
},
|
||||||
|
"`x` hours.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` horas.",
|
||||||
|
"": "`x` horas."
|
||||||
|
},
|
||||||
|
"`x` minutes.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` minutos.",
|
||||||
|
"": "`x` minutos."
|
||||||
|
},
|
||||||
|
"`x` seconds.": {
|
||||||
|
"([^.,0-9]|^)1([^.,0-9]|$)": "`x` segundos.",
|
||||||
|
"": "`x` segundos."
|
||||||
|
},
|
||||||
|
"Fallback comments: ": "Comentários alternativos: ",
|
||||||
|
"Popular": "Popular",
|
||||||
|
"Top": "Top",
|
||||||
|
"About": "Sobre",
|
||||||
|
"Rating: ": "Avaliação: ",
|
||||||
|
"Language: ": "Idioma: ",
|
||||||
|
"View as playlist": "Ver como lista de reprodução",
|
||||||
|
"Default": "Predefinição",
|
||||||
|
"Music": "Música",
|
||||||
|
"Gaming": "Jogos",
|
||||||
|
"News": "Notícias",
|
||||||
|
"Movies": "Filmes",
|
||||||
|
"Download": "Transferir",
|
||||||
|
"Download as: ": "Transferir como: ",
|
||||||
|
"%A %B %-d, %Y": "%A %B %-d, %Y",
|
||||||
|
"(edited)": "(editado)",
|
||||||
|
"YouTube comment permalink": "Link permanente do comentário do YouTube",
|
||||||
|
"permalink": "ligação permanente",
|
||||||
|
"`x` marked it with a ❤": "`x` foi marcado como ❤",
|
||||||
|
"Audio mode": "Modo de áudio",
|
||||||
|
"Video mode": "Modo de vídeo",
|
||||||
|
"Videos": "Vídeos",
|
||||||
|
"Playlists": "Listas de reprodução",
|
||||||
|
"Community": "Comunidade",
|
||||||
|
"Current version: ": "Versão atual: "
|
||||||
|
}
|
||||||
336
locales/ro.json
Normal file
336
locales/ro.json
Normal file
@@ -0,0 +1,336 @@
|
|||||||
|
{
|
||||||
|
"`x` subscribers": "`x` abonați",
|
||||||
|
"`x` videos": "`x` videoclipuri",
|
||||||
|
"`x` playlists": "`x` liste de redare",
|
||||||
|
"LIVE": "ÎN DIRECT",
|
||||||
|
"Shared `x` ago": "Adăugat acum `x`",
|
||||||
|
"Unsubscribe": "Dezabonați-vă",
|
||||||
|
"Subscribe": "Abonați-vă",
|
||||||
|
"View channel on YouTube": "Vedeți canalul pe YouTube",
|
||||||
|
"View playlist on YouTube": "Vedeți lista de redare pe YouTube",
|
||||||
|
"newest": "Data adăugării (cea mai recentă)",
|
||||||
|
"oldest": "Data adăugării (cea mai veche)",
|
||||||
|
"popular": "Cele mai populare",
|
||||||
|
"last": "Ultimele",
|
||||||
|
"Next page": "Pagina următoare",
|
||||||
|
"Previous page": "Pagina precedentă",
|
||||||
|
"Clear watch history?": "Doriți să ștergeți istoricul?",
|
||||||
|
"New password": "Parola nouă",
|
||||||
|
"New passwords must match": "Câmpurile \"Parolă nouă\" trebuie să fie identice",
|
||||||
|
"Cannot change password for Google accounts": "Parola pentru un cont Google nu poate fi schimbată de pe Invidious",
|
||||||
|
"Authorize token?": "Autorizați token-ul?",
|
||||||
|
"Authorize token for `x`?": "Autorizați token-ul pentru `x` ?",
|
||||||
|
"Yes": "Da",
|
||||||
|
"No": "Nu",
|
||||||
|
"Import and Export Data": "Importați și Exportați Datele",
|
||||||
|
"Import": "Importați",
|
||||||
|
"Import Invidious data": "Importați Datele de pe Invidious",
|
||||||
|
"Import YouTube subscriptions": "Importați abonamentele de pe YouTube",
|
||||||
|
"Import FreeTube subscriptions (.db)": "Importați abonamentele de pe FreeTube (.db)",
|
||||||
|
"Import NewPipe subscriptions (.json)": "Importați abonamentele de pe NewPipe (.json)",
|
||||||
|
"Import NewPipe data (.zip)": "Importați datele de pe NewPipe (.zip)",
|
||||||
|
"Export": "Exportați",
|
||||||
|
"Export subscriptions as OPML": "Exportați abonamentele în format OPML",
|
||||||
|
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Exportați abonamentele în format OPML (pentru NewPipe și FreeTube)",
|
||||||
|
"Export data as JSON": "Exportați datele în format JSON",
|
||||||
|
"Delete account?": "Sunteți siguri că doriți să vă ștergeți contul?",
|
||||||
|
"History": "Istoric",
|
||||||
|
"An alternative front-end to YouTube": "O alternativă front-end pentru YouTube",
|
||||||
|
"JavaScript license information": "Informații despre licențele JavaScript",
|
||||||
|
"source": "sursă",
|
||||||
|
"Log in": "Conectați-vă",
|
||||||
|
"Log in/register": "Conectați-vă/Creați-vă un cont",
|
||||||
|
"Log in with Google": "Conectați-vă cu Google",
|
||||||
|
"User ID": "ID Utilizator",
|
||||||
|
"Password": "Parolă",
|
||||||
|
"Time (h:mm:ss):": "Ora (h:mm:ss) :",
|
||||||
|
"Text CAPTCHA": "Text CAPTCHA",
|
||||||
|
"Image CAPTCHA": "Imagine CAPTCHA",
|
||||||
|
"Sign In": "Conectați-vă",
|
||||||
|
"Register": "Înregistrați-vă",
|
||||||
|
"E-mail": "E-mail",
|
||||||
|
"Google verification code": "Cod de verificare Google",
|
||||||
|
"Preferences": "Preferințe",
|
||||||
|
"Player preferences": "Setări de redare",
|
||||||
|
"Always loop: ": "Reluați videoclipul la nesfârșit: ",
|
||||||
|
"Autoplay: ": "Porniți videoclipurile automat: ",
|
||||||
|
"Play next by default: ": "Vizionați următoarele videoclipuri în mod implicit: ",
|
||||||
|
"Autoplay next video: ": "Porniți următorul videoclip automat: ",
|
||||||
|
"Listen by default: ": "Numai audio: ",
|
||||||
|
"Proxy videos: ": "Redați videoclipurile printr-un proxy: ",
|
||||||
|
"Default speed: ": "Viteza de redare implicită: ",
|
||||||
|
"Preferred video quality: ": "Calitatea videoclipurilor: ",
|
||||||
|
"Player volume: ": "Volumul videoclipurilor: ",
|
||||||
|
"Default comments: ": "Sursa comentariilor: ",
|
||||||
|
"youtube": "YouTube",
|
||||||
|
"reddit": "Reddit",
|
||||||
|
"Default captions: ": "Subtitrări implicite: ",
|
||||||
|
"Fallback captions: ": "Subtitrări alternative: ",
|
||||||
|
"Show related videos: ": "Afișați videoclipurile asemănătoare: ",
|
||||||
|
"Show annotations by default: ": "Afișați adnotările în mod implicit: ",
|
||||||
|
"Visual preferences": "Preferințele site-ului",
|
||||||
|
"Player style: ": "Stilul player-ului : ",
|
||||||
|
"Dark mode: ": "Modul întunecat : ",
|
||||||
|
"Theme: ": "Tema : ",
|
||||||
|
"dark": "întunecat",
|
||||||
|
"light": "luminos",
|
||||||
|
"Thin mode: ": "Mod lejer: ",
|
||||||
|
"Subscription preferences": "Preferințele paginii de abonamente",
|
||||||
|
"Show annotations by default for subscribed channels: ": "Afișați adnotările în mod implicit pentru canalele la care v-ați abonat: ",
|
||||||
|
"Redirect homepage to feed: ": "Redirecționați pagina principală la pagina de abonamente: ",
|
||||||
|
"Number of videos shown in feed: ": "Numărul de videoclipuri afișate pe pagina de abonamente: ",
|
||||||
|
"Sort videos by: ": "Sortați videoclipurile în funcție de: ",
|
||||||
|
"published": "data publicării",
|
||||||
|
"published - reverse": "data publicării - inversată",
|
||||||
|
"alphabetically": "în ordine alfabetică",
|
||||||
|
"alphabetically - reverse": "în ordine alfabetică - inversată",
|
||||||
|
"channel name": "numele canalului",
|
||||||
|
"channel name - reverse": "numele canalului - inversat",
|
||||||
|
"Only show latest video from channel: ": "Afișați numai cel mai recent videoclip publicat de canalele la care v-ați abonat: ",
|
||||||
|
"Only show latest unwatched video from channel: ": "Afișați numai cel mai recent videoclip nevizionat publicat de canalele la care v-ați abonat: ",
|
||||||
|
"Only show unwatched: ": "Afișați numai videoclipurile nevizionate: ",
|
||||||
|
"Only show notifications (if there are any): ": "Afișați numai notificările (dacă există): ",
|
||||||
|
"Enable web notifications": "Activați notificările web",
|
||||||
|
"`x` uploaded a video": "`x` a publicat un videoclip",
|
||||||
|
"`x` is live": "`x` este în direct",
|
||||||
|
"Data preferences": "Preferințe legate de date",
|
||||||
|
"Clear watch history": "Ștergeți istoricul videoclipurilor vizionate",
|
||||||
|
"Import/export data": "Importați/exportați datele",
|
||||||
|
"Change password": "Schimbați parola",
|
||||||
|
"Manage subscriptions": "Gestionați abonamentele",
|
||||||
|
"Manage tokens": "Gestionați tokenele",
|
||||||
|
"Watch history": "Istoricul videoclipurilor vizionate",
|
||||||
|
"Delete account": "Ștergeți contul",
|
||||||
|
"Administrator preferences": "Preferințele Administratorului",
|
||||||
|
"Default homepage: ": "Pagina principală implicită: ",
|
||||||
|
"Feed menu: ": "Preferințe legate de pagina de abonamente: ",
|
||||||
|
"Top enabled: ": "Top activat: ",
|
||||||
|
"CAPTCHA enabled: ": "CAPTCHA activat : ",
|
||||||
|
"Login enabled: ": "Autentificare activată : ",
|
||||||
|
"Registration enabled: ": "Înregistrate activată: ",
|
||||||
|
"Report statistics: ": "Raportarea statisticilor: ",
|
||||||
|
"Save preferences": "Salvați preferințele",
|
||||||
|
"Subscription manager": "Gestionați abonamentele",
|
||||||
|
"Token manager": "Manager de Tokene",
|
||||||
|
"Token": "Token",
|
||||||
|
"`x` subscriptions": "`x` abonamente",
|
||||||
|
"`x` tokens": "`x` tokens",
|
||||||
|
"Import/export": "Importați/Exportați",
|
||||||
|
"unsubscribe": "dezabonați-vă",
|
||||||
|
"revoke": "revocați",
|
||||||
|
"Subscriptions": "Abonamente",
|
||||||
|
"`x` unseen notifications": "`x` notificări nevăzute",
|
||||||
|
"search": "căutați",
|
||||||
|
"Log out": "Deconectați-vă",
|
||||||
|
"Released under the AGPLv3 by Omar Roth.": "Publicat sub licența AGPLv3 de Omar Roth.",
|
||||||
|
"Source available here.": "Codul sursă este disponibil aici.",
|
||||||
|
"View JavaScript license information.": "Informații legate de licența JavaScript.",
|
||||||
|
"View privacy policy.": "Politica de confidențialitate.",
|
||||||
|
"Trending": "Tendințe",
|
||||||
|
"Public": "Public",
|
||||||
|
"Unlisted": "Necatalogat",
|
||||||
|
"Private": "Privat",
|
||||||
|
"View all playlists": "Afișați toate listele de redare",
|
||||||
|
"Updated `x` ago": "Actualizat acum `x`",
|
||||||
|
"Delete playlist `x`?": "Sigur doriți să ștergeți lista de redare?",
|
||||||
|
"Delete playlist": "Ștergeți lista de redare",
|
||||||
|
"Create playlist": "Creați o listă de redare",
|
||||||
|
"Title": "Titlu",
|
||||||
|
"Playlist privacy": "Parametrii de confidențialitate ai listei de redare",
|
||||||
|
"Editing playlist `x`": "Modificați lista de redare `x`",
|
||||||
|
"Watch on YouTube": "Urmăriți videoclipul pe YouTube",
|
||||||
|
"Hide annotations": "Ascundeți adnotările",
|
||||||
|
"Show annotations": "Afișați adnotările",
|
||||||
|
"Genre: ": "Categorie: ",
|
||||||
|
"License: ": "Licență: ",
|
||||||
|
"Family friendly? ": "Adecvat pentru întreaga familie? ",
|
||||||
|
"Wilson score: ": "Scor Wilson: ",
|
||||||
|
"Engagement: ": "Procentul celor care au apăsat pe \"Îmi place\" sau \"Nu îmi place\" : ",
|
||||||
|
"Whitelisted regions: ": "Regiunile de pe lista albă: ",
|
||||||
|
"Blacklisted regions: ": "Regiunile de pe lista neagră: ",
|
||||||
|
"Shared `x`": "Publicat pe `x`",
|
||||||
|
"`x` views": "`x` vizionări",
|
||||||
|
"Premieres in `x`": "Premiera în `x`",
|
||||||
|
"Premieres `x`": "Premiera pe `x`",
|
||||||
|
"Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.": "Se pare că ați dezactivat JavaScript. Apăsați aici pentru a vizualiza comentariile. Țineți minte faptul că încărcarea lor ar putea să dureze puțin mai mult.",
|
||||||
|
"View YouTube comments": "Vedeți comentariile de pe YouTube",
|
||||||
|
"View more comments on Reddit": "Vedeți mai multe comentarii pe Reddit",
|
||||||
|
"View `x` comments": "Afișați `x` comentarii",
|
||||||
|
"View Reddit comments": "Afișați comentariile de pe Reddit",
|
||||||
|
"Hide replies": "Ascundeți replicile",
|
||||||
|
"Show replies": "Afișați replicile",
|
||||||
|
"Incorrect password": "Parolă incorectă",
|
||||||
|
"Quota exceeded, try again in a few hours": "Numărul de tentative de conectare a fost depășit. Va rugăm să încercați din nou în câteva ore.",
|
||||||
|
"Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.": "Conectare eșuată. Dacă nu reușiți să vă conectați, verificați dacă ați activat autentificarea cu doi factori (Autentificator sau SMS).",
|
||||||
|
"Invalid TFA code": "Codul de autentificare cu doi factori este invalid",
|
||||||
|
"Login failed. This may be because two-factor authentication is not turned on for your account.": "Conectare eșuată. Acest lucru ar putea fi cauzat de faptul că nu ați activat autentificarea cu doi factori.",
|
||||||
|
"Wrong answer": "Răspuns invalid",
|
||||||
|
"Erroneous CAPTCHA": "CAPTCHA invalid",
|
||||||
|
"CAPTCHA is a required field": "Câmpul CAPTCHA este obligatoriu",
|
||||||
|
"User ID is a required field": "Câmpul ID Utilizator este obligatoriu",
|
||||||
|
"Password is a required field": "Câmpul Parolă este obligatoriu",
|
||||||
|
"Wrong username or password": "Nume de utilizator sau parolă invalidă",
|
||||||
|
"Please sign in using 'Log in with Google'": "Vă rog conectați-vă folosind \"Conectați-vă cu Google\"",
|
||||||
|
"Password cannot be empty": "Parola nu poate fi goală",
|
||||||
|
"Password cannot be longer than 55 characters": "Parola nu poate să conțină mai mult de 55 de caractere",
|
||||||
|
"Please log in": "Vă rog conectați-vă",
|
||||||
|
"Invidious Private Feed for `x`": "Feed RSS privat pentru `x`",
|
||||||
|
"channel:`x`": "canal:`x`",
|
||||||
|
"Deleted or invalid channel": "Canal șters sau invalid",
|
||||||
|
"This channel does not exist.": "Acest canal nu există.",
|
||||||
|
"Could not get channel info.": "Nu am putut primi informații despre acest canal.",
|
||||||
|
"Could not fetch comments": "Încărcarea comentariilor a eșuat.",
|
||||||
|
"View `x` replies": "Afișați `x` replici",
|
||||||
|
"`x` ago": "acum `x`",
|
||||||
|
"Load more": "Vedeți mai mult",
|
||||||
|
"`x` points": "`x` puncte",
|
||||||
|
"Could not create mix.": "Nu am putut crea această listă de redare.",
|
||||||
|
"Empty playlist": "Lista de redare este goală",
|
||||||
|
"Not a playlist.": "Lista de redare este invalidă.",
|
||||||
|
"Playlist does not exist.": "Această listă de redare nu există.",
|
||||||
|
"Could not pull trending pages.": "Încărcarea paginilor de tendințe a eșuat.",
|
||||||
|
"Hidden field \"challenge\" is a required field": "Câmpul ascuns \"challenge\" este un câmp obligatoriu",
|
||||||
|
"Hidden field \"token\" is a required field": "Câmpul ascuns \"token\" este un câmp obligatoriu",
|
||||||
|
"Erroneous challenge": "Challenge invalid",
|
||||||
|
"Erroneous token": "Token invalid",
|
||||||
|
"No such user": "Acest utilizator nu există",
|
||||||
|
"Token is expired, please try again": "Token-ul este expirat, vă rugăm să reîncercați.",
|
||||||
|
"English": "Engleză",
|
||||||
|
"English (auto-generated)": "Engleză (generată automat)",
|
||||||
|
"Afrikaans": "Afrikaans",
|
||||||
|
"Albanian": "Albaneză",
|
||||||
|
"Amharic": "Amharică",
|
||||||
|
"Arabic": "Arabă",
|
||||||
|
"Armenian": "Arméniană",
|
||||||
|
"Azerbaijani": "Azeră",
|
||||||
|
"Bangla": "Bangla",
|
||||||
|
"Basque": "Basque",
|
||||||
|
"Belarusian": "Belarusă",
|
||||||
|
"Bosnian": "Bosniacă",
|
||||||
|
"Bulgarian": "Bulgară",
|
||||||
|
"Burmese": "Birmană",
|
||||||
|
"Catalan": "Catalană",
|
||||||
|
"Cebuano": "Cebuano",
|
||||||
|
"Chinese (Simplified)": "Chineză (Simplificată)",
|
||||||
|
"Chinese (Traditional)": "Chinois (Tradițională)",
|
||||||
|
"Corsican": "Corsicană",
|
||||||
|
"Croatian": "Croată",
|
||||||
|
"Czech": "Cehă",
|
||||||
|
"Danish": "Daneză",
|
||||||
|
"Dutch": "Olandeză",
|
||||||
|
"Esperanto": "Esperanto",
|
||||||
|
"Estonian": "Estoniană",
|
||||||
|
"Filipino": "Filipineză",
|
||||||
|
"Finnish": "Finlandeză",
|
||||||
|
"French": "Franceză",
|
||||||
|
"Galician": "Galiciană",
|
||||||
|
"Georgian": "Georgiană",
|
||||||
|
"German": "Germană",
|
||||||
|
"Greek": "Greacă",
|
||||||
|
"Gujarati": "Gujarati",
|
||||||
|
"Haitian Creole": "Creola Haitiană",
|
||||||
|
"Hausa": "Haousa",
|
||||||
|
"Hawaiian": "Hawaiană",
|
||||||
|
"Hebrew": "Ebraică",
|
||||||
|
"Hindi": "Hindi",
|
||||||
|
"Hmong": "Hmong",
|
||||||
|
"Hungarian": "Ungară",
|
||||||
|
"Icelandic": "Islandeză",
|
||||||
|
"Igbo": "Igbo",
|
||||||
|
"Indonesian": "Indoneziană",
|
||||||
|
"Irish": "Irlandeză",
|
||||||
|
"Italian": "Italiană",
|
||||||
|
"Japanese": "Japoneză",
|
||||||
|
"Javanese": "Javaneză",
|
||||||
|
"Kannada": "Kannada",
|
||||||
|
"Kazakh": "Kazakh",
|
||||||
|
"Khmer": "Khmer",
|
||||||
|
"Korean": "Coreană",
|
||||||
|
"Kurdish": "Kurdă",
|
||||||
|
"Kyrgyz": "Kirghize",
|
||||||
|
"Lao": "Lao",
|
||||||
|
"Latin": "Latină",
|
||||||
|
"Latvian": "Letonă",
|
||||||
|
"Lithuanian": "Lituaniană",
|
||||||
|
"Luxembourgish": "Luxemburgheză",
|
||||||
|
"Macedonian": "Macedoniană",
|
||||||
|
"Malagasy": "Malgașă",
|
||||||
|
"Malay": "Malaieză",
|
||||||
|
"Malayalam": "Malayalam",
|
||||||
|
"Maltese": "Malteză",
|
||||||
|
"Maori": "Maori",
|
||||||
|
"Marathi": "Marathi",
|
||||||
|
"Mongolian": "Mongoliană",
|
||||||
|
"Nepali": "Nepaleză",
|
||||||
|
"Norwegian Bokmål": "Norvegiană",
|
||||||
|
"Nyanja": "Nyanja",
|
||||||
|
"Pashto": "Pachtou",
|
||||||
|
"Persian": "Persană",
|
||||||
|
"Polish": "Poloneză",
|
||||||
|
"Portuguese": "Portugheză",
|
||||||
|
"Punjabi": "Punjabi",
|
||||||
|
"Romanian": "Română",
|
||||||
|
"Russian": "Rusă",
|
||||||
|
"Samoan": "Samoan",
|
||||||
|
"Scottish Gaelic": "Galic Scoțian",
|
||||||
|
"Serbian": "Sârbă",
|
||||||
|
"Shona": "Shona",
|
||||||
|
"Sindhi": "Sindhi",
|
||||||
|
"Sinhala": "Sinhala",
|
||||||
|
"Slovak": "Slovacă",
|
||||||
|
"Slovenian": "Slovenă",
|
||||||
|
"Somali": "Somaleză",
|
||||||
|
"Southern Sotho": "Sotho de Sud",
|
||||||
|
"Spanish": "Spaniolă",
|
||||||
|
"Spanish (Latin America)": "Spaniolă (America Latină)",
|
||||||
|
"Sundanese": "Sundaneză",
|
||||||
|
"Swahili": "Swahili",
|
||||||
|
"Swedish": "Suedeză",
|
||||||
|
"Tajik": "Tajik",
|
||||||
|
"Tamil": "Tamil",
|
||||||
|
"Telugu": "Telugu",
|
||||||
|
"Thai": "Tailandeză",
|
||||||
|
"Turkish": "Turcă",
|
||||||
|
"Ukrainian": "Ucrainiană",
|
||||||
|
"Urdu": "Urdu",
|
||||||
|
"Uzbek": "Uzbek",
|
||||||
|
"Vietnamese": "Vietnameză",
|
||||||
|
"Welsh": "Galeză",
|
||||||
|
"Western Frisian": "Frisiană de Vest",
|
||||||
|
"Xhosa": "Xhosa",
|
||||||
|
"Yiddish": "Yiddish",
|
||||||
|
"Yoruba": "Yoruba",
|
||||||
|
"Zulu": "Zoulou",
|
||||||
|
"`x` years": "`x` ani",
|
||||||
|
"`x` months": "`x` luni",
|
||||||
|
"`x` weeks": "`x` săptămâni",
|
||||||
|
"`x` days": "`x` zile",
|
||||||
|
"`x` hours": "`x` ore",
|
||||||
|
"`x` minutes": "`x` minute",
|
||||||
|
"`x` seconds": "`x` secunde",
|
||||||
|
"Fallback comments: ": "Comentarii alternative: ",
|
||||||
|
"Popular": "Popular",
|
||||||
|
"Top": "Top",
|
||||||
|
"About": "Despre",
|
||||||
|
"Rating: ": "Evaluare: ",
|
||||||
|
"Language: ": "Limbă: ",
|
||||||
|
"View as playlist": "Vizualizați ca listă de redare",
|
||||||
|
"Default": "Implicit",
|
||||||
|
"Music": "Muzică",
|
||||||
|
"Gaming": "Jocuri Video",
|
||||||
|
"News": "Noutăți",
|
||||||
|
"Movies": "Filme",
|
||||||
|
"Download": "Descărcați",
|
||||||
|
"Download as: ": "Descărcați ca: ",
|
||||||
|
"%A %B %-d, %Y": "%A %-d %B %Y",
|
||||||
|
"(edited)": "(editat)",
|
||||||
|
"YouTube comment permalink": "Permalink pentru comentariul de pe YouTube",
|
||||||
|
"permalink": "permalink",
|
||||||
|
"`x` marked it with a ❤": "`x` l-a marcat cu o ❤",
|
||||||
|
"Audio mode": "Mod audio",
|
||||||
|
"Video mode": "Mod video",
|
||||||
|
"Videos": "Videoclipuri",
|
||||||
|
"Playlists": "Liste de redare",
|
||||||
|
"Community": "Comunitate",
|
||||||
|
"Current version: ": "Versiunea actuală: "
|
||||||
|
}
|
||||||
628
locales/ru.json
628
locales/ru.json
@@ -1,294 +1,336 @@
|
|||||||
{
|
{
|
||||||
"`x` subscribers": "`x` подписчиков",
|
"`x` subscribers": "`x` подписчиков",
|
||||||
"`x` videos": "`x` видео",
|
"`x` videos": "`x` видео",
|
||||||
"LIVE": "ПРЯМОЙ ЭФИР",
|
"`x` playlists": "`x` плейлистов",
|
||||||
"Shared `x` ago": "Опубликовано `x` назад",
|
"LIVE": "ПРЯМОЙ ЭФИР",
|
||||||
"Unsubscribe": "Отписаться",
|
"Shared `x` ago": "Опубликовано `x` назад",
|
||||||
"Subscribe": "Подписаться",
|
"Unsubscribe": "Отписаться",
|
||||||
"Login to subscribe to `x`": "Войти, чтобы подписаться на `x`",
|
"Subscribe": "Подписаться",
|
||||||
"View channel on YouTube": "Канал на YouTube",
|
"View channel on YouTube": "Смотреть канал на YouTube",
|
||||||
"newest": "новые",
|
"View playlist on YouTube": "Посмотреть плейлист на YouTube",
|
||||||
"oldest": "старые",
|
"newest": "самые свежие",
|
||||||
"popular": "популярные",
|
"oldest": "самые старые",
|
||||||
"Preview page": "Предварительный просмотр",
|
"popular": "популярные",
|
||||||
"Next page": "Следующая страница",
|
"last": "недавние",
|
||||||
"Clear watch history?": "Очистить историю просмотров?",
|
"Next page": "Следующая страница",
|
||||||
"Yes": "Да",
|
"Previous page": "Предыдущая страница",
|
||||||
"No": "Нет",
|
"Clear watch history?": "Очистить историю просмотров?",
|
||||||
"Import and Export Data": "Импорт и экспорт данных",
|
"New password": "Новый пароль",
|
||||||
"Import": "Импорт",
|
"New passwords must match": "Новые пароли не совпадают",
|
||||||
"Import Invidious data": "Импортировать данные Invidious",
|
"Cannot change password for Google accounts": "Изменить пароль аккаунта Google невозможно",
|
||||||
"Import YouTube subscriptions": "Импортировать YouTube подписки",
|
"Authorize token?": "Авторизовать токен?",
|
||||||
"Import FreeTube subscriptions (.db)": "Импортировать FreeTube подписки (.db)",
|
"Authorize token for `x`?": "Авторизовать токен для `x`?",
|
||||||
"Import NewPipe subscriptions (.json)": "Импортировать NewPipe подписки (.json)",
|
"Yes": "Да",
|
||||||
"Import NewPipe data (.zip)": "Импортировать данные NewPipe (.zip)",
|
"No": "Нет",
|
||||||
"Export": "Экспорт",
|
"Import and Export Data": "Импорт и экспорт данных",
|
||||||
"Export subscriptions as OPML": "Экспортировать подписки в OPML",
|
"Import": "Импорт",
|
||||||
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Экспортировать подписки в OPML (для NewPipe и FreeTube)",
|
"Import Invidious data": "Импортировать данные Invidious",
|
||||||
"Export data as JSON": "Экспортировать данные в JSON",
|
"Import YouTube subscriptions": "Импортировать подписки из YouTube",
|
||||||
"Delete account?": "Удалить аккаунт?",
|
"Import FreeTube subscriptions (.db)": "Импортировать подписки из FreeTube (.db)",
|
||||||
"History": "История",
|
"Import NewPipe subscriptions (.json)": "Импортировать подписки из NewPipe (.json)",
|
||||||
"Previous page": "Предыдущая страница",
|
"Import NewPipe data (.zip)": "Импортировать данные из NewPipe (.zip)",
|
||||||
"An alternative front-end to YouTube": "Альтернативный фронтенд для YouTube",
|
"Export": "Экспорт",
|
||||||
"JavaScript license information": "Лицензии JavaScript",
|
"Export subscriptions as OPML": "Экспортировать подписки в формате OPML",
|
||||||
"source": "источник",
|
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Экспортировать подписки в формате OPML (для NewPipe и FreeTube)",
|
||||||
"Login": "Войти",
|
"Export data as JSON": "Экспортировать данные в формате JSON",
|
||||||
"Login/Register": "Войти/Регистрация",
|
"Delete account?": "Удалить аккаунт?",
|
||||||
"Login to Google": "Войти через Google",
|
"History": "История",
|
||||||
"User ID:": "ID пользователя:",
|
"An alternative front-end to YouTube": "Альтернативный фронтенд для YouTube",
|
||||||
"Password:": "Пароль:",
|
"JavaScript license information": "Информация о лицензиях JavaScript",
|
||||||
"Time (h:mm:ss):": "Время (ч:мм:сс):",
|
"source": "источник",
|
||||||
"Text CAPTCHA": "Текст капчи",
|
"Log in": "Войти",
|
||||||
"Image CAPTCHA": "Изображение капчи",
|
"Log in/register": "Войти или зарегистрироваться",
|
||||||
"Sign In": "Войти",
|
"Log in with Google": "Войти через Google",
|
||||||
"Register": "Регистрация",
|
"User ID": "ID пользователя",
|
||||||
"Email:": "Эл. почта:",
|
"Password": "Пароль",
|
||||||
"Google verification code:": "Код подтверждения Google:",
|
"Time (h:mm:ss):": "Время (ч:мм:сс):",
|
||||||
"Preferences": "Настройки",
|
"Text CAPTCHA": "Текст капчи",
|
||||||
"Player preferences": "Настройки проигрывателя",
|
"Image CAPTCHA": "Изображение капчи",
|
||||||
"Always loop: ": "Всегда повторять: ",
|
"Sign In": "Войти",
|
||||||
"Autoplay: ": "Автовоспроизведение: ",
|
"Register": "Зарегистрироваться",
|
||||||
"Autoplay next video: ": "Автовоспроизведение следующего видео: ",
|
"E-mail": "Электронная почта",
|
||||||
"Listen by default: ": "Режим \"только аудио\" по-умолчанию: ",
|
"Google verification code": "Код подтверждения Google",
|
||||||
"Default speed: ": "Скорость по-умолчанию: ",
|
"Preferences": "Настройки",
|
||||||
"Preferred video quality: ": "Предпочтительное качество видео: ",
|
"Player preferences": "Настройки проигрывателя",
|
||||||
"Player volume: ": "Громкость воспроизведения: ",
|
"Always loop: ": "Всегда повторять: ",
|
||||||
"Default comments: ": "Источник комментариев: ",
|
"Autoplay: ": "Автовоспроизведение: ",
|
||||||
"youtube": "YouTube",
|
"Play next by default: ": "Всегда включать следующее видео? ",
|
||||||
"reddit": "Reddit",
|
"Autoplay next video: ": "Автопроигрывание следующего видео: ",
|
||||||
"Default captions: ": "Субтитры по-умолчанию: ",
|
"Listen by default: ": "Режим «только аудио» по умолчанию: ",
|
||||||
"Fallback captions: ": "Резервные субтитры: ",
|
"Proxy videos: ": "Проигрывать видео через прокси? ",
|
||||||
"Show related videos? ": "Показывать похожие видео? ",
|
"Default speed: ": "Скорость видео по умолчанию: ",
|
||||||
"Visual preferences": "Визуальные настройки",
|
"Preferred video quality: ": "Предпочтительное качество видео: ",
|
||||||
"Dark mode: ": "Темная тема: ",
|
"Player volume: ": "Громкость видео: ",
|
||||||
"Thin mode: ": "Облегченный режим: ",
|
"Default comments: ": "Источник комментариев: ",
|
||||||
"Subscription preferences": "Настройки подписок",
|
"youtube": "YouTube",
|
||||||
"Redirect homepage to feed: ": "Отображать ленту вместо главной страницы: ",
|
"reddit": "Reddit",
|
||||||
"Number of videos shown in feed: ": "Число видео в ленте: ",
|
"Default captions: ": "Основной язык субтитров: ",
|
||||||
"Sort videos by: ": "Сортировать видео по: ",
|
"Fallback captions: ": "Дополнительный язык субтитров: ",
|
||||||
"published": "дате публикации",
|
"Show related videos: ": "Показывать похожие видео? ",
|
||||||
"published - reverse": "дате - обратный порядок",
|
"Show annotations by default: ": "Всегда показывать аннотации? ",
|
||||||
"alphabetically": "алфавиту",
|
"Visual preferences": "Настройки сайта",
|
||||||
"alphabetically - reverse": "алфавиту - обратный порядок",
|
"Player style: ": "Стиль проигрывателя: ",
|
||||||
"channel name": "имени канала",
|
"Dark mode: ": "Тёмное оформление: ",
|
||||||
"channel name - reverse": "имени канала - обратный порядок",
|
"Theme: ": "Тема: ",
|
||||||
"Only show latest video from channel: ": "Отображать только последние видео с каждого канала: ",
|
"dark": "темная",
|
||||||
"Only show latest unwatched video from channel: ": "Отображать только непросмотренные видео с каждого канала: ",
|
"light": "светлая",
|
||||||
"Only show unwatched: ": "Отображать только непросмотренные видео: ",
|
"Thin mode: ": "Облегчённое оформление: ",
|
||||||
"Only show notifications (if there are any): ": "Отображать только оповещения (если есть): ",
|
"Subscription preferences": "Настройки подписок",
|
||||||
"Data preferences": "Настройки данных",
|
"Show annotations by default for subscribed channels: ": "Всегда показывать аннотации в видео каналов, на которые вы подписаны? ",
|
||||||
"Clear watch history": "Очистить историю просмотра",
|
"Redirect homepage to feed: ": "Отображать видео с каналов, на которые вы подписаны, как главную страницу: ",
|
||||||
"Import/Export data": "Импорт/Экспорт данных",
|
"Number of videos shown in feed: ": "Число видео, на которые вы подписаны, в ленте: ",
|
||||||
"Manage subscriptions": "Управление подписками",
|
"Sort videos by: ": "Сортировать видео: ",
|
||||||
"Watch history": "История просмотров",
|
"published": "по дате публикации",
|
||||||
"Delete account": "Удалить аккаунт",
|
"published - reverse": "по дате публикации в обратном порядке",
|
||||||
"Administrator preferences": "",
|
"alphabetically": "по алфавиту",
|
||||||
"Default homepage: ": "",
|
"alphabetically - reverse": "по алфавиту в обратном порядке",
|
||||||
"Feed menu: ": "",
|
"channel name": "по названию канала",
|
||||||
"Top enabled? ": "",
|
"channel name - reverse": "по названию канала в обратном порядке",
|
||||||
"CAPTCHA enabled? ": "",
|
"Only show latest video from channel: ": "Показывать только последние видео с каналов: ",
|
||||||
"Login enabled? ": "",
|
"Only show latest unwatched video from channel: ": "Показывать только непросмотренные видео с каналов: ",
|
||||||
"Registration enabled? ": "",
|
"Only show unwatched: ": "Показывать только непросмотренные видео: ",
|
||||||
"Report statistics? ": "",
|
"Only show notifications (if there are any): ": "Показывать только оповещения, если они есть: ",
|
||||||
"Save preferences": "Сохранить настройки",
|
"Enable web notifications": "Включить уведомления в браузере",
|
||||||
"Subscription manager": "Менеджер подписок",
|
"`x` uploaded a video": "`x` разместил видео",
|
||||||
"`x` subscriptions": "`x` подписок",
|
"`x` is live": "`x` в прямом эфире",
|
||||||
"Import/Export": "Импорт/Экспорт",
|
"Data preferences": "Настройки данных",
|
||||||
"unsubscribe": "отписаться",
|
"Clear watch history": "Очистить историю просмотров",
|
||||||
"Subscriptions": "Подписки",
|
"Import/export data": "Импорт/Экспорт данных",
|
||||||
"`x` unseen notifications": "`x` новых оповещений",
|
"Change password": "Изменить пароль",
|
||||||
"search": "поиск",
|
"Manage subscriptions": "Управлять подписками",
|
||||||
"Sign out": "Выйти",
|
"Manage tokens": "Управлять токенами",
|
||||||
"Released under the AGPLv3 by Omar Roth.": "Распространяется Omar Roth по AGPLv3.",
|
"Watch history": "История просмотров",
|
||||||
"Source available here.": "Исходный код доступен здесь.",
|
"Delete account": "Удалить аккаунт",
|
||||||
"Liberapay: ": "Liberapay: ",
|
"Administrator preferences": "Администраторские настройки",
|
||||||
"Patreon: ": "Patreon: ",
|
"Default homepage: ": "Главная страница по умолчанию: ",
|
||||||
"BTC: ": "BTC: ",
|
"Feed menu: ": "Меню ленты видео: ",
|
||||||
"BCH: ": "BCH: ",
|
"Top enabled: ": "Включить топ видео? ",
|
||||||
"View JavaScript license information.": "Посмотреть лицензии JavaScript кода.",
|
"CAPTCHA enabled: ": "Включить капчу? ",
|
||||||
"Trending": "В тренде",
|
"Login enabled: ": "Включить авторизацию? ",
|
||||||
"Watch video on Youtube": "Смотреть на YouTube",
|
"Registration enabled: ": "Включить регистрацию? ",
|
||||||
"Genre: ": "Жанр: ",
|
"Report statistics: ": "Сообщать статистику? ",
|
||||||
"License: ": "Лицензия: ",
|
"Save preferences": "Сохранить настройки",
|
||||||
"Family friendly? ": "Семейный просмотр: ",
|
"Subscription manager": "Менеджер подписок",
|
||||||
"Wilson score: ": "Рейтинг Вильсона: ",
|
"Token manager": "Менеджер токенов",
|
||||||
"Engagement: ": "Вовлеченность: ",
|
"Token": "Токен",
|
||||||
"Whitelisted regions: ": "Доступно для: ",
|
"`x` subscriptions": "`x` подписок",
|
||||||
"Blacklisted regions: ": "Недоступно для: ",
|
"`x` tokens": "`x` токенов",
|
||||||
"Shared `x`": "Опубликовано `x`",
|
"Import/export": "Импорт и экспорт",
|
||||||
"Hi! Looks like you have JavaScript disabled. Click here to view comments, keep in mind it may take a bit longer to load.": "Похоже, что у Вас отключен JavaScript. Нажмите сюда, чтобы увидеть комментарии (учтите, что они могут загружаться дольше).",
|
"unsubscribe": "отписаться",
|
||||||
"View YouTube comments": "Смотреть комментарии с YouTube",
|
"revoke": "отозвать",
|
||||||
"View more comments on Reddit": "Больше комментариев на Reddit",
|
"Subscriptions": "Подписки",
|
||||||
"View `x` comments": "Показать `x` комментариев",
|
"`x` unseen notifications": "`x` непросмотренных оповещений",
|
||||||
"View Reddit comments": "Смотреть комментарии с Reddit",
|
"search": "поиск",
|
||||||
"Hide replies": "Скрыть ответы",
|
"Log out": "Выйти",
|
||||||
"Show replies": "Показать ответы",
|
"Released under the AGPLv3 by Omar Roth.": "Реализовано Омаром Ротом по лицензии AGPLv3.",
|
||||||
"Incorrect password": "Неправильный пароль",
|
"Source available here.": "Исходный код доступен здесь.",
|
||||||
"Quota exceeded, try again in a few hours": "Превышена квота, попробуйте снова через несколько часов",
|
"View JavaScript license information.": "Посмотреть информацию по лицензии JavaScript.",
|
||||||
"Unable to login, make sure two-factor authentication (Authenticator or SMS) is enabled.": "Вход не выполнен, проверьте, не включена ли двухфакторная аутентификация.",
|
"View privacy policy.": "Посмотреть политику конфиденциальности.",
|
||||||
"Invalid TFA code": "Неправильный TFA код",
|
"Trending": "В тренде",
|
||||||
"Login failed. This may be because two-factor authentication is not enabled on your account.": "Не удалось войти. Это может быть из-за того, что в вашем аккаунте не включена двухфакторная аутентификация.",
|
"Public": "Публичный",
|
||||||
"Invalid answer": "Неверный ответ",
|
"Unlisted": "Нет в списке",
|
||||||
"Invalid CAPTCHA": "Неверная капча",
|
"Private": "Приватный",
|
||||||
"CAPTCHA is a required field": "Необходимо ввести капчу",
|
"View all playlists": "Посмотреть все плейлисты",
|
||||||
"User ID is a required field": "Необходимо ввести идентификатор пользователя",
|
"Updated `x` ago": "Обновлено `x` назад",
|
||||||
"Password is a required field": "Необходимо ввести пароль",
|
"Delete playlist `x`?": "Удалить плейлист `x`?",
|
||||||
"Invalid username or password": "Недопустимый пароль или имя пользователя",
|
"Delete playlist": "Удалить плейлист",
|
||||||
"Please sign in using 'Sign in with Google'": "Пожалуйста войдите через Google",
|
"Create playlist": "Создать плейлист",
|
||||||
"Password cannot be empty": "Пароль не может быть пустым",
|
"Title": "Заголовок",
|
||||||
"Password cannot be longer than 55 characters": "Пароль не может быть длиннее 55 символов",
|
"Playlist privacy": "Конфиденциальность плейлиста",
|
||||||
"Please sign in": "Пожалуйста, войдите",
|
"Editing playlist `x`": "Редактирование плейлиста `x`",
|
||||||
"Invidious Private Feed for `x`": "Приватная лента Invidious для `x`",
|
"Watch on YouTube": "Смотреть на YouTube",
|
||||||
"channel:`x`": "канал: `x`",
|
"Hide annotations": "Скрыть аннотации",
|
||||||
"Deleted or invalid channel": "Канал удален или не найден",
|
"Show annotations": "Показать аннотации",
|
||||||
"This channel does not exist.": "Такой канал не существует.",
|
"Genre: ": "Жанр: ",
|
||||||
"Could not get channel info.": "Невозможно получить информацию о канале.",
|
"License: ": "Лицензия: ",
|
||||||
"Could not fetch comments": "Невозможно получить комментарии",
|
"Family friendly? ": "Семейный просмотр: ",
|
||||||
"View `x` replies": "Показать `x` ответов",
|
"Wilson score: ": "Рейтинг Уилсона: ",
|
||||||
"`x` ago": "`x` назад",
|
"Engagement: ": "Вовлечённость: ",
|
||||||
"Load more": "Загрузить больше",
|
"Whitelisted regions: ": "Доступно в регионах: ",
|
||||||
"`x` points": "`x` очков",
|
"Blacklisted regions: ": "Недоступно в регионах: ",
|
||||||
"Could not create mix.": "Невозможно создать \"микс\".",
|
"Shared `x`": "Опубликовано `x`",
|
||||||
"Playlist is empty": "Плейлист пуст",
|
"`x` views": "`x` просмотров",
|
||||||
"Invalid playlist.": "Некорректный плейлист.",
|
"Premieres in `x`": "Премьера через `x`",
|
||||||
"Playlist does not exist.": "Плейлист не существует.",
|
"Premieres `x`": "Премьера `x`",
|
||||||
"Could not pull trending pages.": "Невозможно получить страницы \"в тренде\".",
|
"Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.": "Похоже, у вас отключён JavaScript. Чтобы увидить комментарии, нажмите сюда, но учтите: они могут загружаться немного медленнее.",
|
||||||
"Hidden field \"challenge\" is a required field": "Необходимо заполнить скрытое поле \"challenge\"",
|
"View YouTube comments": "Смотреть комментарии с YouTube",
|
||||||
"Hidden field \"token\" is a required field": "Необходимо заполнить скрытое поле \"токен\"",
|
"View more comments on Reddit": "Посмотреть больше комментариев на Reddit",
|
||||||
"Invalid challenge": "Неправильный ответ в \"challenge\"",
|
"View `x` comments": "Показать `x` комментариев",
|
||||||
"Invalid token": "Неправильный токен",
|
"View Reddit comments": "Смотреть комментарии с Reddit",
|
||||||
"Invalid user": "Недопустимое имя пользователя",
|
"Hide replies": "Скрыть ответы",
|
||||||
"Token is expired, please try again": "Срок действия токена истек, попробуйте позже",
|
"Show replies": "Показать ответы",
|
||||||
"English": "Английский",
|
"Incorrect password": "Неправильный пароль",
|
||||||
"English (auto-generated)": "Английский (созданы автоматически)",
|
"Quota exceeded, try again in a few hours": "Лимит превышен, попробуйте снова через несколько часов",
|
||||||
"Afrikaans": "Африкаанс",
|
"Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.": "Войти не удаётся. Проверьте, не включена ли двухфакторная аутентификация (по коду или смс).",
|
||||||
"Albanian": "Албанский",
|
"Invalid TFA code": "Неправильный код двухфакторной аутентификации",
|
||||||
"Amharic": "Амхарский",
|
"Login failed. This may be because two-factor authentication is not turned on for your account.": "Не удаётся войти. Это может быть из-за того, что в вашем аккаунте не включена двухфакторная аутентификация.",
|
||||||
"Arabic": "Арабский",
|
"Wrong answer": "Неправильный ответ",
|
||||||
"Armenian": "Армянский",
|
"Erroneous CAPTCHA": "Неправильная капча",
|
||||||
"Azerbaijani": "Азербайджанский",
|
"CAPTCHA is a required field": "Необходимо пройти капчу",
|
||||||
"Bangla": "Бенгальский",
|
"User ID is a required field": "Необходимо ввести ID пользователя",
|
||||||
"Basque": "Баскский",
|
"Password is a required field": "Необходимо ввести пароль",
|
||||||
"Belarusian": "Белорусский",
|
"Wrong username or password": "Неправильный логин или пароль",
|
||||||
"Bosnian": "Боснийский",
|
"Please sign in using 'Log in with Google'": "Пожалуйста, нажмите «Войти через Google»",
|
||||||
"Bulgarian": "Болгарский",
|
"Password cannot be empty": "Пароль не может быть пустым",
|
||||||
"Burmese": "Бирманский",
|
"Password cannot be longer than 55 characters": "Пароль не может быть длиннее 55 символов",
|
||||||
"Catalan": "Каталонский",
|
"Please log in": "Пожалуйста, войдите",
|
||||||
"Cebuano": "Себуанский",
|
"Invidious Private Feed for `x`": "Приватная лента Invidious для `x`",
|
||||||
"Chinese (Simplified)": "Китайский (упрощенный)",
|
"channel:`x`": "канал: `x`",
|
||||||
"Chinese (Traditional)": "Китайский (традиционный)",
|
"Deleted or invalid channel": "Канал удалён или не найден",
|
||||||
"Corsican": "Корсиканский",
|
"This channel does not exist.": "Такого канала не существует.",
|
||||||
"Croatian": "Хорватский",
|
"Could not get channel info.": "Не удаётся получить информацию об этом канале.",
|
||||||
"Czech": "Чешский",
|
"Could not fetch comments": "Не удаётся загрузить комментарии",
|
||||||
"Danish": "Датский",
|
"View `x` replies": "Показать `x` ответов",
|
||||||
"Dutch": "Нидерландский",
|
"`x` ago": "`x` назад",
|
||||||
"Esperanto": "Эсперанто",
|
"Load more": "Загрузить больше",
|
||||||
"Estonian": "Эстонский",
|
"`x` points": "`x` очков",
|
||||||
"Filipino": "Филиппинский",
|
"Could not create mix.": "Не удаётся создать микс.",
|
||||||
"Finnish": "Финский",
|
"Empty playlist": "Плейлист пуст",
|
||||||
"French": "Французский",
|
"Not a playlist.": "Некорректный плейлист.",
|
||||||
"Galician": "Галисийский",
|
"Playlist does not exist.": "Плейлист не существует.",
|
||||||
"Georgian": "Грузинский",
|
"Could not pull trending pages.": "Не удаётся загрузить страницы «в тренде».",
|
||||||
"German": "Немецкий",
|
"Hidden field \"challenge\" is a required field": "Необходимо заполнить скрытое поле «challenge»",
|
||||||
"Greek": "Греческий",
|
"Hidden field \"token\" is a required field": "Необходимо заполнить скрытое поле «токен»",
|
||||||
"Gujarati": "Гуджаратский",
|
"Erroneous challenge": "Неправильный ответ в «challenge»",
|
||||||
"Haitian Creole": "Гаит. креольский",
|
"Erroneous token": "Неправильный токен",
|
||||||
"Hausa": "Хауса",
|
"No such user": "Недопустимое имя пользователя",
|
||||||
"Hawaiian": "Гавайский",
|
"Token is expired, please try again": "Срок действия токена истёк, попробуйте позже",
|
||||||
"Hebrew": "Иврит",
|
"English": "Английский",
|
||||||
"Hindi": "Хинди",
|
"English (auto-generated)": "Английский (созданы автоматически)",
|
||||||
"Hmong": "Хмонг (мяо)",
|
"Afrikaans": "Африкаанс",
|
||||||
"Hungarian": "Венгерский",
|
"Albanian": "Албанский",
|
||||||
"Icelandic": "Исландский",
|
"Amharic": "Амхарский",
|
||||||
"Igbo": "Игбо",
|
"Arabic": "Арабский",
|
||||||
"Indonesian": "Индонезийский",
|
"Armenian": "Армянский",
|
||||||
"Irish": "Ирландский",
|
"Azerbaijani": "Азербайджанский",
|
||||||
"Italian": "Итальянский",
|
"Bangla": "Бенгальский",
|
||||||
"Japanese": "Японский",
|
"Basque": "Баскский",
|
||||||
"Javanese": "Яванский",
|
"Belarusian": "Белорусский",
|
||||||
"Kannada": "Каннада",
|
"Bosnian": "Боснийский",
|
||||||
"Kazakh": "Казахский",
|
"Bulgarian": "Болгарский",
|
||||||
"Khmer": "Кхмерский",
|
"Burmese": "Бирманский",
|
||||||
"Korean": "Корейский",
|
"Catalan": "Каталонский",
|
||||||
"Kurdish": "Курдский",
|
"Cebuano": "Себуанский",
|
||||||
"Kyrgyz": "Киргизский",
|
"Chinese (Simplified)": "Китайский (упрощенный)",
|
||||||
"Lao": "Лаосский",
|
"Chinese (Traditional)": "Китайский (традиционный)",
|
||||||
"Latin": "Латинский",
|
"Corsican": "Корсиканский",
|
||||||
"Latvian": "Латышский",
|
"Croatian": "Хорватский",
|
||||||
"Lithuanian": "Литовский",
|
"Czech": "Чешский",
|
||||||
"Luxembourgish": "Люксембургский",
|
"Danish": "Датский",
|
||||||
"Macedonian": "Македонский",
|
"Dutch": "Нидерландский",
|
||||||
"Malagasy": "Малагасийский",
|
"Esperanto": "Эсперанто",
|
||||||
"Malay": "Малайский",
|
"Estonian": "Эстонский",
|
||||||
"Malayalam": "Малаялам",
|
"Filipino": "Филиппинский",
|
||||||
"Maltese": "Мальтийский",
|
"Finnish": "Финский",
|
||||||
"Maori": "Маори",
|
"French": "Французский",
|
||||||
"Marathi": "Маратхи",
|
"Galician": "Галисийский",
|
||||||
"Mongolian": "Монгольская",
|
"Georgian": "Грузинский",
|
||||||
"Nepali": "Непальский",
|
"German": "Немецкий",
|
||||||
"Norwegian": "Норвежский",
|
"Greek": "Греческий",
|
||||||
"Nyanja": "Ньянджа",
|
"Gujarati": "Гуджаратский",
|
||||||
"Pashto": "Пушту",
|
"Haitian Creole": "Гаит. креольский",
|
||||||
"Persian": "Персидский",
|
"Hausa": "Хауса",
|
||||||
"Polish": "Польский",
|
"Hawaiian": "Гавайский",
|
||||||
"Portuguese": "Португальский",
|
"Hebrew": "Иврит",
|
||||||
"Punjabi": "Панджаби",
|
"Hindi": "Хинди",
|
||||||
"Romanian": "Румынский",
|
"Hmong": "Хмонг (мяо)",
|
||||||
"Russian": "Русский",
|
"Hungarian": "Венгерский",
|
||||||
"Samoan": "Самоанский",
|
"Icelandic": "Исландский",
|
||||||
"Scottish Gaelic": "Шотландский (гэльский)",
|
"Igbo": "Игбо",
|
||||||
"Serbian": "Сербский",
|
"Indonesian": "Индонезийский",
|
||||||
"Shona": "Шона",
|
"Irish": "Ирландский",
|
||||||
"Sindhi": "Синдхи",
|
"Italian": "Итальянский",
|
||||||
"Sinhala": "Сингальский",
|
"Japanese": "Японский",
|
||||||
"Slovak": "Словацкий",
|
"Javanese": "Яванский",
|
||||||
"Slovenian": "Словенский",
|
"Kannada": "Каннада",
|
||||||
"Somali": "Сомалийский",
|
"Kazakh": "Казахский",
|
||||||
"Southern Sotho": "Сесото (южный сото)",
|
"Khmer": "Кхмерский",
|
||||||
"Spanish": "Испанский",
|
"Korean": "Корейский",
|
||||||
"Spanish (Latin America)": "Испанский (Латинская Америка)",
|
"Kurdish": "Курдский",
|
||||||
"Sundanese": "Сунданский",
|
"Kyrgyz": "Киргизский",
|
||||||
"Swahili": "Суахили",
|
"Lao": "Лаосский",
|
||||||
"Swedish": "Шведский",
|
"Latin": "Латинский",
|
||||||
"Tajik": "Таджикский",
|
"Latvian": "Латышский",
|
||||||
"Tamil": "Тамильский",
|
"Lithuanian": "Литовский",
|
||||||
"Telugu": "Телугу",
|
"Luxembourgish": "Люксембургский",
|
||||||
"Thai": "Тайский",
|
"Macedonian": "Македонский",
|
||||||
"Turkish": "Турецкий",
|
"Malagasy": "Малагасийский",
|
||||||
"Ukrainian": "Украинский",
|
"Malay": "Малайский",
|
||||||
"Urdu": "Урду",
|
"Malayalam": "Малаялам",
|
||||||
"Uzbek": "Узбекский",
|
"Maltese": "Мальтийский",
|
||||||
"Vietnamese": "Вьетнамский",
|
"Maori": "Маори",
|
||||||
"Welsh": "Валлийский",
|
"Marathi": "Маратхи",
|
||||||
"Western Frisian": "Западнофризский",
|
"Mongolian": "Монгольская",
|
||||||
"Xhosa": "Коса",
|
"Nepali": "Непальский",
|
||||||
"Yiddish": "Идиш",
|
"Norwegian Bokmål": "Норвежский",
|
||||||
"Yoruba": "Йоруба",
|
"Nyanja": "Ньянджа",
|
||||||
"Zulu": "Зулусский",
|
"Pashto": "Пушту",
|
||||||
"`x` years": "`x` лет",
|
"Persian": "Персидский",
|
||||||
"`x` months": "`x` месяцев",
|
"Polish": "Польский",
|
||||||
"`x` weeks": "`x` недель",
|
"Portuguese": "Португальский",
|
||||||
"`x` days": "`x` дней",
|
"Punjabi": "Панджаби",
|
||||||
"`x` hours": "`x` часов",
|
"Romanian": "Румынский",
|
||||||
"`x` minutes": "`x` минут",
|
"Russian": "Русский",
|
||||||
"`x` seconds": "`x` секунд",
|
"Samoan": "Самоанский",
|
||||||
"Fallback comments: ": "Резервные комментарии: ",
|
"Scottish Gaelic": "Шотландский (гэльский)",
|
||||||
"Popular": "Популярное",
|
"Serbian": "Сербский",
|
||||||
"Top": "Топ",
|
"Shona": "Шона",
|
||||||
"About": "О сайте",
|
"Sindhi": "Синдхи",
|
||||||
"Rating: ": "Рейтинг: ",
|
"Sinhala": "Сингальский",
|
||||||
"Language: ": "Язык: ",
|
"Slovak": "Словацкий",
|
||||||
"Default": "По-умолчанию",
|
"Slovenian": "Словенский",
|
||||||
"Music": "Музыка",
|
"Somali": "Сомалийский",
|
||||||
"Gaming": "Игры",
|
"Southern Sotho": "Сесото (южный сото)",
|
||||||
"News": "Новости",
|
"Spanish": "Испанский",
|
||||||
"Movies": "Фильмы",
|
"Spanish (Latin America)": "Испанский (Латинская Америка)",
|
||||||
"Download": "Скачать",
|
"Sundanese": "Сунданский",
|
||||||
"Download as: ": "Скачать как: ",
|
"Swahili": "Суахили",
|
||||||
"%A %B %-d, %Y": "%-d %B %Y, %A",
|
"Swedish": "Шведский",
|
||||||
"(edited)": "(изменено)",
|
"Tajik": "Таджикский",
|
||||||
"Youtube permalink of the comment": "Прямая ссылка на YouTube",
|
"Tamil": "Тамильский",
|
||||||
"`x` marked it with a ❤": "❤ от автора канала \"`x`\"",
|
"Telugu": "Телугу",
|
||||||
"Audio mode": "Аудио режим",
|
"Thai": "Тайский",
|
||||||
"Video mode": "Видео режим"
|
"Turkish": "Турецкий",
|
||||||
}
|
"Ukrainian": "Украинский",
|
||||||
|
"Urdu": "Урду",
|
||||||
|
"Uzbek": "Узбекский",
|
||||||
|
"Vietnamese": "Вьетнамский",
|
||||||
|
"Welsh": "Валлийский",
|
||||||
|
"Western Frisian": "Западнофризский",
|
||||||
|
"Xhosa": "Коса",
|
||||||
|
"Yiddish": "Идиш",
|
||||||
|
"Yoruba": "Йоруба",
|
||||||
|
"Zulu": "Зулусский",
|
||||||
|
"`x` years": "`x` лет",
|
||||||
|
"`x` months": "`x` месяцев",
|
||||||
|
"`x` weeks": "`x` недель",
|
||||||
|
"`x` days": "`x` дней",
|
||||||
|
"`x` hours": "`x` часов",
|
||||||
|
"`x` minutes": "`x` минут",
|
||||||
|
"`x` seconds": "`x` секунд",
|
||||||
|
"Fallback comments: ": "Резервные комментарии: ",
|
||||||
|
"Popular": "Популярное",
|
||||||
|
"Top": "Топ",
|
||||||
|
"About": "О сайте",
|
||||||
|
"Rating: ": "Рейтинг: ",
|
||||||
|
"Language: ": "Язык: ",
|
||||||
|
"View as playlist": "Смотреть как плейлист",
|
||||||
|
"Default": "По-умолчанию",
|
||||||
|
"Music": "Музыка",
|
||||||
|
"Gaming": "Игры",
|
||||||
|
"News": "Новости",
|
||||||
|
"Movies": "Фильмы",
|
||||||
|
"Download": "Скачать",
|
||||||
|
"Download as: ": "Скачать как: ",
|
||||||
|
"%A %B %-d, %Y": "%-d %B %Y, %A",
|
||||||
|
"(edited)": "(изменено)",
|
||||||
|
"YouTube comment permalink": "Прямая ссылка на YouTube",
|
||||||
|
"permalink": "постоянная ссылка",
|
||||||
|
"`x` marked it with a ❤": "❤ от автора канала \"`x`\"",
|
||||||
|
"Audio mode": "Аудио режим",
|
||||||
|
"Video mode": "Видео режим",
|
||||||
|
"Videos": "Видео",
|
||||||
|
"Playlists": "Плейлисты",
|
||||||
|
"Community": "Сообщество",
|
||||||
|
"Current version: ": "Текущая версия: "
|
||||||
|
}
|
||||||
336
locales/sr_Cyrl.json
Normal file
336
locales/sr_Cyrl.json
Normal file
@@ -0,0 +1,336 @@
|
|||||||
|
{
|
||||||
|
"`x` subscribers.": "",
|
||||||
|
"`x` videos.": "",
|
||||||
|
"`x` playlists.": "",
|
||||||
|
"LIVE": "",
|
||||||
|
"Shared `x` ago": "",
|
||||||
|
"Unsubscribe": "",
|
||||||
|
"Subscribe": "Пратите",
|
||||||
|
"View channel on YouTube": "Погледајте канал на YouTube-у",
|
||||||
|
"View playlist on YouTube": "Погледајте плејлисту на YouTube-у",
|
||||||
|
"newest": "",
|
||||||
|
"oldest": "",
|
||||||
|
"popular": "",
|
||||||
|
"last": "",
|
||||||
|
"Next page": "",
|
||||||
|
"Previous page": "",
|
||||||
|
"Clear watch history?": "",
|
||||||
|
"New password": "",
|
||||||
|
"New passwords must match": "",
|
||||||
|
"Cannot change password for Google accounts": "",
|
||||||
|
"Authorize token?": "",
|
||||||
|
"Authorize token for `x`?": "",
|
||||||
|
"Yes": "",
|
||||||
|
"No": "",
|
||||||
|
"Import and Export Data": "",
|
||||||
|
"Import": "",
|
||||||
|
"Import Invidious data": "",
|
||||||
|
"Import YouTube subscriptions": "",
|
||||||
|
"Import FreeTube subscriptions (.db)": "",
|
||||||
|
"Import NewPipe subscriptions (.json)": "",
|
||||||
|
"Import NewPipe data (.zip)": "",
|
||||||
|
"Export": "",
|
||||||
|
"Export subscriptions as OPML": "",
|
||||||
|
"Export subscriptions as OPML (for NewPipe & FreeTube)": "",
|
||||||
|
"Export data as JSON": "",
|
||||||
|
"Delete account?": "",
|
||||||
|
"History": "",
|
||||||
|
"An alternative front-end to YouTube": "",
|
||||||
|
"JavaScript license information": "",
|
||||||
|
"source": "",
|
||||||
|
"Log in": "",
|
||||||
|
"Log in/register": "",
|
||||||
|
"Log in with Google": "",
|
||||||
|
"User ID": "",
|
||||||
|
"Password": "",
|
||||||
|
"Time (h:mm:ss):": "",
|
||||||
|
"Text CAPTCHA": "",
|
||||||
|
"Image CAPTCHA": "",
|
||||||
|
"Sign In": "",
|
||||||
|
"Register": "",
|
||||||
|
"E-mail": "",
|
||||||
|
"Google verification code": "",
|
||||||
|
"Preferences": "",
|
||||||
|
"Player preferences": "",
|
||||||
|
"Always loop: ": "",
|
||||||
|
"Autoplay: ": "",
|
||||||
|
"Play next by default: ": "",
|
||||||
|
"Autoplay next video: ": "",
|
||||||
|
"Listen by default: ": "",
|
||||||
|
"Proxy videos: ": "",
|
||||||
|
"Default speed: ": "",
|
||||||
|
"Preferred video quality: ": "",
|
||||||
|
"Player volume: ": "",
|
||||||
|
"Default comments: ": "",
|
||||||
|
"youtube": "",
|
||||||
|
"reddit": "",
|
||||||
|
"Default captions: ": "",
|
||||||
|
"Fallback captions: ": "",
|
||||||
|
"Show related videos: ": "",
|
||||||
|
"Show annotations by default: ": "",
|
||||||
|
"Visual preferences": "",
|
||||||
|
"Player style: ": "",
|
||||||
|
"Dark mode: ": "",
|
||||||
|
"Theme: ": "",
|
||||||
|
"dark": "",
|
||||||
|
"light": "",
|
||||||
|
"Thin mode: ": "",
|
||||||
|
"Subscription preferences": "",
|
||||||
|
"Show annotations by default for subscribed channels: ": "",
|
||||||
|
"Redirect homepage to feed: ": "",
|
||||||
|
"Number of videos shown in feed: ": "",
|
||||||
|
"Sort videos by: ": "",
|
||||||
|
"published": "",
|
||||||
|
"published - reverse": "",
|
||||||
|
"alphabetically": "",
|
||||||
|
"alphabetically - reverse": "",
|
||||||
|
"channel name": "",
|
||||||
|
"channel name - reverse": "",
|
||||||
|
"Only show latest video from channel: ": "",
|
||||||
|
"Only show latest unwatched video from channel: ": "",
|
||||||
|
"Only show unwatched: ": "",
|
||||||
|
"Only show notifications (if there are any): ": "",
|
||||||
|
"Enable web notifications": "",
|
||||||
|
"`x` uploaded a video": "",
|
||||||
|
"`x` is live": "",
|
||||||
|
"Data preferences": "",
|
||||||
|
"Clear watch history": "",
|
||||||
|
"Import/export data": "",
|
||||||
|
"Change password": "",
|
||||||
|
"Manage subscriptions": "",
|
||||||
|
"Manage tokens": "",
|
||||||
|
"Watch history": "",
|
||||||
|
"Delete account": "",
|
||||||
|
"Administrator preferences": "",
|
||||||
|
"Default homepage: ": "",
|
||||||
|
"Feed menu: ": "",
|
||||||
|
"Top enabled: ": "",
|
||||||
|
"CAPTCHA enabled: ": "",
|
||||||
|
"Login enabled: ": "",
|
||||||
|
"Registration enabled: ": "",
|
||||||
|
"Report statistics: ": "",
|
||||||
|
"Save preferences": "",
|
||||||
|
"Subscription manager": "",
|
||||||
|
"Token manager": "",
|
||||||
|
"Token": "",
|
||||||
|
"`x` subscriptions.": "",
|
||||||
|
"`x` tokens.": "",
|
||||||
|
"Import/export": "",
|
||||||
|
"unsubscribe": "",
|
||||||
|
"revoke": "",
|
||||||
|
"Subscriptions": "",
|
||||||
|
"`x` unseen notifications.": "",
|
||||||
|
"search": "",
|
||||||
|
"Log out": "",
|
||||||
|
"Released under the AGPLv3 by Omar Roth.": "",
|
||||||
|
"Source available here.": "",
|
||||||
|
"View JavaScript license information.": "",
|
||||||
|
"View privacy policy.": "",
|
||||||
|
"Trending": "",
|
||||||
|
"Public": "",
|
||||||
|
"Unlisted": "",
|
||||||
|
"Private": "",
|
||||||
|
"View all playlists": "",
|
||||||
|
"Updated `x` ago": "",
|
||||||
|
"Delete playlist `x`?": "",
|
||||||
|
"Delete playlist": "",
|
||||||
|
"Create playlist": "",
|
||||||
|
"Title": "",
|
||||||
|
"Playlist privacy": "",
|
||||||
|
"Editing playlist `x`": "",
|
||||||
|
"Watch on YouTube": "",
|
||||||
|
"Hide annotations": "",
|
||||||
|
"Show annotations": "",
|
||||||
|
"Genre: ": "",
|
||||||
|
"License: ": "",
|
||||||
|
"Family friendly? ": "",
|
||||||
|
"Wilson score: ": "",
|
||||||
|
"Engagement: ": "",
|
||||||
|
"Whitelisted regions: ": "",
|
||||||
|
"Blacklisted regions: ": "",
|
||||||
|
"Shared `x`": "",
|
||||||
|
"`x` views.": "",
|
||||||
|
"Premieres in `x`": "",
|
||||||
|
"Premieres `x`": "",
|
||||||
|
"Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.": "",
|
||||||
|
"View YouTube comments": "",
|
||||||
|
"View more comments on Reddit": "",
|
||||||
|
"View `x` comments.": "",
|
||||||
|
"View Reddit comments": "",
|
||||||
|
"Hide replies": "",
|
||||||
|
"Show replies": "",
|
||||||
|
"Incorrect password": "",
|
||||||
|
"Quota exceeded, try again in a few hours": "",
|
||||||
|
"Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.": "",
|
||||||
|
"Invalid TFA code": "",
|
||||||
|
"Login failed. This may be because two-factor authentication is not turned on for your account.": "",
|
||||||
|
"Wrong answer": "",
|
||||||
|
"Erroneous CAPTCHA": "",
|
||||||
|
"CAPTCHA is a required field": "",
|
||||||
|
"User ID is a required field": "",
|
||||||
|
"Password is a required field": "",
|
||||||
|
"Wrong username or password": "",
|
||||||
|
"Please sign in using 'Log in with Google'": "",
|
||||||
|
"Password cannot be empty": "",
|
||||||
|
"Password cannot be longer than 55 characters": "",
|
||||||
|
"Please log in": "",
|
||||||
|
"Invidious Private Feed for `x`": "",
|
||||||
|
"channel:`x`": "",
|
||||||
|
"Deleted or invalid channel": "",
|
||||||
|
"This channel does not exist.": "",
|
||||||
|
"Could not get channel info.": "",
|
||||||
|
"Could not fetch comments": "",
|
||||||
|
"View `x` replies.": "",
|
||||||
|
"`x` ago": "",
|
||||||
|
"Load more": "",
|
||||||
|
"`x` points.": "",
|
||||||
|
"Could not create mix.": "",
|
||||||
|
"Empty playlist": "",
|
||||||
|
"Not a playlist.": "",
|
||||||
|
"Playlist does not exist.": "",
|
||||||
|
"Could not pull trending pages.": "",
|
||||||
|
"Hidden field \"challenge\" is a required field": "",
|
||||||
|
"Hidden field \"token\" is a required field": "",
|
||||||
|
"Erroneous challenge": "",
|
||||||
|
"Erroneous token": "",
|
||||||
|
"No such user": "",
|
||||||
|
"Token is expired, please try again": "",
|
||||||
|
"English": "",
|
||||||
|
"English (auto-generated)": "",
|
||||||
|
"Afrikaans": "",
|
||||||
|
"Albanian": "",
|
||||||
|
"Amharic": "",
|
||||||
|
"Arabic": "",
|
||||||
|
"Armenian": "",
|
||||||
|
"Azerbaijani": "",
|
||||||
|
"Bangla": "",
|
||||||
|
"Basque": "",
|
||||||
|
"Belarusian": "",
|
||||||
|
"Bosnian": "",
|
||||||
|
"Bulgarian": "",
|
||||||
|
"Burmese": "",
|
||||||
|
"Catalan": "",
|
||||||
|
"Cebuano": "",
|
||||||
|
"Chinese (Simplified)": "",
|
||||||
|
"Chinese (Traditional)": "",
|
||||||
|
"Corsican": "",
|
||||||
|
"Croatian": "",
|
||||||
|
"Czech": "",
|
||||||
|
"Danish": "",
|
||||||
|
"Dutch": "",
|
||||||
|
"Esperanto": "",
|
||||||
|
"Estonian": "",
|
||||||
|
"Filipino": "",
|
||||||
|
"Finnish": "",
|
||||||
|
"French": "",
|
||||||
|
"Galician": "",
|
||||||
|
"Georgian": "",
|
||||||
|
"German": "",
|
||||||
|
"Greek": "",
|
||||||
|
"Gujarati": "",
|
||||||
|
"Haitian Creole": "",
|
||||||
|
"Hausa": "",
|
||||||
|
"Hawaiian": "",
|
||||||
|
"Hebrew": "",
|
||||||
|
"Hindi": "",
|
||||||
|
"Hmong": "",
|
||||||
|
"Hungarian": "",
|
||||||
|
"Icelandic": "",
|
||||||
|
"Igbo": "",
|
||||||
|
"Indonesian": "",
|
||||||
|
"Irish": "",
|
||||||
|
"Italian": "",
|
||||||
|
"Japanese": "",
|
||||||
|
"Javanese": "",
|
||||||
|
"Kannada": "",
|
||||||
|
"Kazakh": "",
|
||||||
|
"Khmer": "",
|
||||||
|
"Korean": "",
|
||||||
|
"Kurdish": "",
|
||||||
|
"Kyrgyz": "",
|
||||||
|
"Lao": "",
|
||||||
|
"Latin": "",
|
||||||
|
"Latvian": "",
|
||||||
|
"Lithuanian": "",
|
||||||
|
"Luxembourgish": "",
|
||||||
|
"Macedonian": "",
|
||||||
|
"Malagasy": "",
|
||||||
|
"Malay": "",
|
||||||
|
"Malayalam": "",
|
||||||
|
"Maltese": "",
|
||||||
|
"Maori": "",
|
||||||
|
"Marathi": "",
|
||||||
|
"Mongolian": "",
|
||||||
|
"Nepali": "",
|
||||||
|
"Norwegian Bokmål": "",
|
||||||
|
"Nyanja": "",
|
||||||
|
"Pashto": "",
|
||||||
|
"Persian": "",
|
||||||
|
"Polish": "",
|
||||||
|
"Portuguese": "",
|
||||||
|
"Punjabi": "",
|
||||||
|
"Romanian": "",
|
||||||
|
"Russian": "",
|
||||||
|
"Samoan": "",
|
||||||
|
"Scottish Gaelic": "",
|
||||||
|
"Serbian": "",
|
||||||
|
"Shona": "",
|
||||||
|
"Sindhi": "",
|
||||||
|
"Sinhala": "",
|
||||||
|
"Slovak": "",
|
||||||
|
"Slovenian": "",
|
||||||
|
"Somali": "",
|
||||||
|
"Southern Sotho": "",
|
||||||
|
"Spanish": "",
|
||||||
|
"Spanish (Latin America)": "",
|
||||||
|
"Sundanese": "",
|
||||||
|
"Swahili": "",
|
||||||
|
"Swedish": "",
|
||||||
|
"Tajik": "",
|
||||||
|
"Tamil": "",
|
||||||
|
"Telugu": "",
|
||||||
|
"Thai": "",
|
||||||
|
"Turkish": "",
|
||||||
|
"Ukrainian": "",
|
||||||
|
"Urdu": "",
|
||||||
|
"Uzbek": "",
|
||||||
|
"Vietnamese": "",
|
||||||
|
"Welsh": "",
|
||||||
|
"Western Frisian": "",
|
||||||
|
"Xhosa": "",
|
||||||
|
"Yiddish": "",
|
||||||
|
"Yoruba": "",
|
||||||
|
"Zulu": "",
|
||||||
|
"`x` years.": "",
|
||||||
|
"`x` months.": "",
|
||||||
|
"`x` weeks.": "",
|
||||||
|
"`x` days.": "",
|
||||||
|
"`x` hours.": "",
|
||||||
|
"`x` minutes.": "",
|
||||||
|
"`x` seconds.": "",
|
||||||
|
"Fallback comments: ": "",
|
||||||
|
"Popular": "",
|
||||||
|
"Top": "",
|
||||||
|
"About": "",
|
||||||
|
"Rating: ": "",
|
||||||
|
"Language: ": "",
|
||||||
|
"View as playlist": "",
|
||||||
|
"Default": "",
|
||||||
|
"Music": "",
|
||||||
|
"Gaming": "",
|
||||||
|
"News": "",
|
||||||
|
"Movies": "",
|
||||||
|
"Download": "",
|
||||||
|
"Download as: ": "",
|
||||||
|
"%A %B %-d, %Y": "",
|
||||||
|
"(edited)": "",
|
||||||
|
"YouTube comment permalink": "",
|
||||||
|
"permalink": "",
|
||||||
|
"`x` marked it with a ❤": "",
|
||||||
|
"Audio mode": "",
|
||||||
|
"Video mode": "",
|
||||||
|
"Videos": "",
|
||||||
|
"Playlists": "",
|
||||||
|
"Community": "",
|
||||||
|
"Current version: ": "Тренутна верзија: "
|
||||||
|
}
|
||||||
336
locales/sv-SE.json
Normal file
336
locales/sv-SE.json
Normal file
@@ -0,0 +1,336 @@
|
|||||||
|
{
|
||||||
|
"`x` subscribers": "`x` prenumeranter",
|
||||||
|
"`x` videos": "`x` videor",
|
||||||
|
"`x` playlists": "`x` spellistor",
|
||||||
|
"LIVE": "LIVE",
|
||||||
|
"Shared `x` ago": "Delad `x` sedan",
|
||||||
|
"Unsubscribe": "Avprenumerera",
|
||||||
|
"Subscribe": "Prenumerera",
|
||||||
|
"View channel on YouTube": "Visa kanalen på YouTube",
|
||||||
|
"View playlist on YouTube": "Visa spellistan på YouTube",
|
||||||
|
"newest": "nyaste",
|
||||||
|
"oldest": "äldsta",
|
||||||
|
"popular": "populärt",
|
||||||
|
"last": "sista",
|
||||||
|
"Next page": "Nästa sida",
|
||||||
|
"Previous page": "Tidigare sida",
|
||||||
|
"Clear watch history?": "Töm visningshistorik?",
|
||||||
|
"New password": "Nytt lösenord",
|
||||||
|
"New passwords must match": "Nya lösenord måste stämma överens",
|
||||||
|
"Cannot change password for Google accounts": "Kan inte ändra lösenord på Google-konton",
|
||||||
|
"Authorize token?": "Auktorisera åtkomsttoken?",
|
||||||
|
"Authorize token for `x`?": "Auktorisera åtkomsttoken för `x`?",
|
||||||
|
"Yes": "Ja",
|
||||||
|
"No": "Nej",
|
||||||
|
"Import and Export Data": "Importera och exportera data",
|
||||||
|
"Import": "Importera",
|
||||||
|
"Import Invidious data": "Importera Invidious-data",
|
||||||
|
"Import YouTube subscriptions": "Importera YouTube-prenumerationer",
|
||||||
|
"Import FreeTube subscriptions (.db)": "Importera FreeTube-prenumerationer (.db)",
|
||||||
|
"Import NewPipe subscriptions (.json)": "Importera NewPipe-prenumerationer (.json)",
|
||||||
|
"Import NewPipe data (.zip)": "Importera NewPipe-data (.zip)",
|
||||||
|
"Export": "Exportera",
|
||||||
|
"Export subscriptions as OPML": "Exportera prenumerationer som OPML",
|
||||||
|
"Export subscriptions as OPML (for NewPipe & FreeTube)": "Exportera prenumerationer som OPML (för NewPipe och FreeTube)",
|
||||||
|
"Export data as JSON": "Exportera data som JSON",
|
||||||
|
"Delete account?": "Radera konto?",
|
||||||
|
"History": "Historik",
|
||||||
|
"An alternative front-end to YouTube": "Ett alternativt gränssnitt till YouTube",
|
||||||
|
"JavaScript license information": "JavaScript-licensinformation",
|
||||||
|
"source": "källa",
|
||||||
|
"Log in": "Logga in",
|
||||||
|
"Log in/register": "Logga in/registrera",
|
||||||
|
"Log in with Google": "Logga in med Google",
|
||||||
|
"User ID": "Användar-ID",
|
||||||
|
"Password": "Lösenord",
|
||||||
|
"Time (h:mm:ss):": "Tid (h:mm:ss):",
|
||||||
|
"Text CAPTCHA": "Text-CAPTCHA",
|
||||||
|
"Image CAPTCHA": "Bild-CAPTCHA",
|
||||||
|
"Sign In": "Inloggning",
|
||||||
|
"Register": "Registrera",
|
||||||
|
"E-mail": "E-post",
|
||||||
|
"Google verification code": "Google-bekräftelsekod",
|
||||||
|
"Preferences": "Inställningar",
|
||||||
|
"Player preferences": "Spelarinställningar",
|
||||||
|
"Always loop: ": "Loopa alltid: ",
|
||||||
|
"Autoplay: ": "Autouppspelning: ",
|
||||||
|
"Play next by default: ": "Spela nästa som förval: ",
|
||||||
|
"Autoplay next video: ": "Autouppspela nästa video: ",
|
||||||
|
"Listen by default: ": "Lyssna som förval: ",
|
||||||
|
"Proxy videos: ": "Proxy:a videor: ",
|
||||||
|
"Default speed: ": "Förvald hastighet: ",
|
||||||
|
"Preferred video quality: ": "Föredragen videokvalitet: ",
|
||||||
|
"Player volume: ": "Volym: ",
|
||||||
|
"Default comments: ": "Förvalda kommentarer: ",
|
||||||
|
"youtube": "YouTube",
|
||||||
|
"reddit": "Reddit",
|
||||||
|
"Default captions: ": "Förvalda undertexter: ",
|
||||||
|
"Fallback captions: ": "Ersättningsundertexter: ",
|
||||||
|
"Show related videos: ": "Visa relaterade videor? ",
|
||||||
|
"Show annotations by default: ": "Visa länkar-i-videon som förval? ",
|
||||||
|
"Visual preferences": "Visuella inställningar",
|
||||||
|
"Player style: ": "Spelarstil: ",
|
||||||
|
"Dark mode: ": "Mörkt läge: ",
|
||||||
|
"Theme: ": "Tema: ",
|
||||||
|
"dark": "Mörkt",
|
||||||
|
"light": "Ljust",
|
||||||
|
"Thin mode: ": "Lättviktigt läge: ",
|
||||||
|
"Subscription preferences": "Prenumerationsinställningar",
|
||||||
|
"Show annotations by default for subscribed channels: ": "Visa länkar-i-videor som förval för kanaler som prenumereras på? ",
|
||||||
|
"Redirect homepage to feed: ": "Omdirigera hemsida till flöde: ",
|
||||||
|
"Number of videos shown in feed: ": "Antal videor att visa i flödet: ",
|
||||||
|
"Sort videos by: ": "Sortera videor: ",
|
||||||
|
"published": "publicering",
|
||||||
|
"published - reverse": "publicering - omvänd",
|
||||||
|
"alphabetically": "alfabetiskt",
|
||||||
|
"alphabetically - reverse": "alfabetiskt - omvänd",
|
||||||
|
"channel name": "kanalnamn",
|
||||||
|
"channel name - reverse": "kanalnamn - omvänd",
|
||||||
|
"Only show latest video from channel: ": "Visa bara senaste videon från kanal: ",
|
||||||
|
"Only show latest unwatched video from channel: ": "Visa bara senaste osedda videon från kanal: ",
|
||||||
|
"Only show unwatched: ": "Visa bara osedda: ",
|
||||||
|
"Only show notifications (if there are any): ": "Visa endast aviseringar (om det finns några): ",
|
||||||
|
"Enable web notifications": "Slå på aviseringar",
|
||||||
|
"`x` uploaded a video": "`x` laddade upp en video",
|
||||||
|
"`x` is live": "`x` sänder live",
|
||||||
|
"Data preferences": "Datainställningar",
|
||||||
|
"Clear watch history": "Töm visningshistorik",
|
||||||
|
"Import/export data": "Importera/Exportera data",
|
||||||
|
"Change password": "Byt lösenord",
|
||||||
|
"Manage subscriptions": "Hantera prenumerationer",
|
||||||
|
"Manage tokens": "Hantera åtkomst-tokens",
|
||||||
|
"Watch history": "Visningshistorik",
|
||||||
|
"Delete account": "Radera konto",
|
||||||
|
"Administrator preferences": "Administratörsinställningar",
|
||||||
|
"Default homepage: ": "Förvald hemsida: ",
|
||||||
|
"Feed menu: ": "Flödesmeny: ",
|
||||||
|
"Top enabled: ": "Topp påslaget? ",
|
||||||
|
"CAPTCHA enabled: ": "CAPTCHA påslaget? ",
|
||||||
|
"Login enabled: ": "Inloggning påslaget? ",
|
||||||
|
"Registration enabled: ": "Registrering påslaget? ",
|
||||||
|
"Report statistics: ": "Rapportera in statistik? ",
|
||||||
|
"Save preferences": "Spara inställningar",
|
||||||
|
"Subscription manager": "Prenumerationshanterare",
|
||||||
|
"Token manager": "Åtkomst-token-hanterare",
|
||||||
|
"Token": "Åtkomst-token",
|
||||||
|
"`x` subscriptions": "`x` prenumerationer",
|
||||||
|
"`x` tokens": "`x` åtkomst-token",
|
||||||
|
"Import/export": "Importera/exportera",
|
||||||
|
"unsubscribe": "avprenumerera",
|
||||||
|
"revoke": "återkalla",
|
||||||
|
"Subscriptions": "Prenumerationer",
|
||||||
|
"`x` unseen notifications": "`x` osedda aviseringar",
|
||||||
|
"search": "sök",
|
||||||
|
"Log out": "Logga ut",
|
||||||
|
"Released under the AGPLv3 by Omar Roth.": "Utgiven under AGPLv3-licens av Omar Roth.",
|
||||||
|
"Source available here.": "Källkod tillgänglig här.",
|
||||||
|
"View JavaScript license information.": "Visa JavaScript-licensinformation.",
|
||||||
|
"View privacy policy.": "Visa privatlivspolicy.",
|
||||||
|
"Trending": "Trendar",
|
||||||
|
"Public": "Offentlig",
|
||||||
|
"Unlisted": "Olistad",
|
||||||
|
"Private": "Privat",
|
||||||
|
"View all playlists": "Visa alla spellistor",
|
||||||
|
"Updated `x` ago": "Uppdaterad `x` sedan",
|
||||||
|
"Delete playlist `x`?": "Radera spellistan `x`?",
|
||||||
|
"Delete playlist": "Radera spellista",
|
||||||
|
"Create playlist": "Skapa spellista",
|
||||||
|
"Title": "Titel",
|
||||||
|
"Playlist privacy": "Privatläge på spellista",
|
||||||
|
"Editing playlist `x`": "Redigerer spellistan `x`",
|
||||||
|
"Watch on YouTube": "Titta på YouTube",
|
||||||
|
"Hide annotations": "Dölj länkar-i-video",
|
||||||
|
"Show annotations": "Visa länkar-i-video",
|
||||||
|
"Genre: ": "Genre: ",
|
||||||
|
"License: ": "Licens: ",
|
||||||
|
"Family friendly? ": "Familjevänlig? ",
|
||||||
|
"Wilson score: ": "Wilson-poängsumma: ",
|
||||||
|
"Engagement: ": "Engagement: ",
|
||||||
|
"Whitelisted regions: ": "Vitlistade regioner: ",
|
||||||
|
"Blacklisted regions: ": "Svartlistade regioner: ",
|
||||||
|
"Shared `x`": "Delade `x`",
|
||||||
|
"`x` views": "`x` visningar",
|
||||||
|
"Premieres in `x`": "Premiär om `x`",
|
||||||
|
"Premieres `x`": "Premiär av `x`",
|
||||||
|
"Hi! Looks like you have JavaScript turned off. Click here to view comments, keep in mind they may take a bit longer to load.": "Hej. Det ser ut som att du har JavaScript avstängt. Klicka här för att visa kommentarer, ha i åtanke att nedladdning tar längre tid.",
|
||||||
|
"View YouTube comments": "Visa YouTube-kommentarer",
|
||||||
|
"View more comments on Reddit": "Visa flera kommentarer på Reddit",
|
||||||
|
"View `x` comments": "Visa `x` kommentarer",
|
||||||
|
"View Reddit comments": "Visa Reddit-kommentarer",
|
||||||
|
"Hide replies": "Dölj svar",
|
||||||
|
"Show replies": "Visa svar",
|
||||||
|
"Incorrect password": "Fel lösenord",
|
||||||
|
"Quota exceeded, try again in a few hours": "Kvoten överskriden, försök igen om ett par timmar",
|
||||||
|
"Unable to log in, make sure two-factor authentication (Authenticator or SMS) is turned on.": "Kunde inte logga in, försäkra dig om att tvåfaktors-autentisering (Authenticator eller SMS) är påslagen.",
|
||||||
|
"Invalid TFA code": "Ogiltig tvåfaktor-kod",
|
||||||
|
"Login failed. This may be because two-factor authentication is not turned on for your account.": "Inloggning misslyckades. Detta kan vara för att tvåfaktors-autentisering inte är påslaget på ditt konto.",
|
||||||
|
"Wrong answer": "Fel svar",
|
||||||
|
"Erroneous CAPTCHA": "Ogiltig CAPTCHA",
|
||||||
|
"CAPTCHA is a required field": "CAPTCHA är ett obligatoriskt fält",
|
||||||
|
"User ID is a required field": "Användar-ID är ett obligatoriskt fält",
|
||||||
|
"Password is a required field": "Lösenord är ett obligatoriskt fält",
|
||||||
|
"Wrong username or password": "Ogiltigt användarnamn eller lösenord",
|
||||||
|
"Please sign in using 'Log in with Google'": "Logga in genom \"Google-inloggning\"",
|
||||||
|
"Password cannot be empty": "Lösenordet kan inte vara tomt",
|
||||||
|
"Password cannot be longer than 55 characters": "Lösenordet kan inte vara längre än 55 tecken",
|
||||||
|
"Please log in": "Logga in",
|
||||||
|
"Invidious Private Feed for `x`": "Ogiltig privat flöde för `x`",
|
||||||
|
"channel:`x`": "kanal `x`",
|
||||||
|
"Deleted or invalid channel": "Raderad eller ogiltig kanal",
|
||||||
|
"This channel does not exist.": "Denna kanal finns inte.",
|
||||||
|
"Could not get channel info.": "Kunde inte hämta kanalinfo.",
|
||||||
|
"Could not fetch comments": "Kunde inte hämta kommentarer",
|
||||||
|
"View `x` replies": "Visa `x` svar",
|
||||||
|
"`x` ago": "`x` sedan",
|
||||||
|
"Load more": "Ladda fler",
|
||||||
|
"`x` points": "`x` poäng",
|
||||||
|
"Could not create mix.": "Kunde inte skapa mix.",
|
||||||
|
"Empty playlist": "Spellistan är tom",
|
||||||
|
"Not a playlist.": "Ogiltig spellista.",
|
||||||
|
"Playlist does not exist.": "Spellistan finns inte.",
|
||||||
|
"Could not pull trending pages.": "Kunde inte hämta trendande sidor.",
|
||||||
|
"Hidden field \"challenge\" is a required field": "Dolt fält \"challenge\" är ett obligatoriskt fält",
|
||||||
|
"Hidden field \"token\" is a required field": "Dolt fält \"token\" är ett obligatoriskt fält",
|
||||||
|
"Erroneous challenge": "Felaktig challenge",
|
||||||
|
"Erroneous token": "Felaktig token",
|
||||||
|
"No such user": "Ogiltig användare",
|
||||||
|
"Token is expired, please try again": "Token föråldrad, försök igen",
|
||||||
|
"English": "",
|
||||||
|
"English (auto-generated)": "English (auto-genererat)",
|
||||||
|
"Afrikaans": "",
|
||||||
|
"Albanian": "",
|
||||||
|
"Amharic": "",
|
||||||
|
"Arabic": "",
|
||||||
|
"Armenian": "",
|
||||||
|
"Azerbaijani": "",
|
||||||
|
"Bangla": "",
|
||||||
|
"Basque": "",
|
||||||
|
"Belarusian": "",
|
||||||
|
"Bosnian": "",
|
||||||
|
"Bulgarian": "",
|
||||||
|
"Burmese": "",
|
||||||
|
"Catalan": "",
|
||||||
|
"Cebuano": "",
|
||||||
|
"Chinese (Simplified)": "",
|
||||||
|
"Chinese (Traditional)": "",
|
||||||
|
"Corsican": "",
|
||||||
|
"Croatian": "",
|
||||||
|
"Czech": "",
|
||||||
|
"Danish": "",
|
||||||
|
"Dutch": "",
|
||||||
|
"Esperanto": "",
|
||||||
|
"Estonian": "",
|
||||||
|
"Filipino": "",
|
||||||
|
"Finnish": "",
|
||||||
|
"French": "",
|
||||||
|
"Galician": "",
|
||||||
|
"Georgian": "",
|
||||||
|
"German": "",
|
||||||
|
"Greek": "",
|
||||||
|
"Gujarati": "",
|
||||||
|
"Haitian Creole": "",
|
||||||
|
"Hausa": "",
|
||||||
|
"Hawaiian": "",
|
||||||
|
"Hebrew": "",
|
||||||
|
"Hindi": "",
|
||||||
|
"Hmong": "",
|
||||||
|
"Hungarian": "",
|
||||||
|
"Icelandic": "",
|
||||||
|
"Igbo": "",
|
||||||
|
"Indonesian": "",
|
||||||
|
"Irish": "",
|
||||||
|
"Italian": "",
|
||||||
|
"Japanese": "",
|
||||||
|
"Javanese": "",
|
||||||
|
"Kannada": "",
|
||||||
|
"Kazakh": "",
|
||||||
|
"Khmer": "",
|
||||||
|
"Korean": "",
|
||||||
|
"Kurdish": "",
|
||||||
|
"Kyrgyz": "",
|
||||||
|
"Lao": "",
|
||||||
|
"Latin": "",
|
||||||
|
"Latvian": "",
|
||||||
|
"Lithuanian": "",
|
||||||
|
"Luxembourgish": "",
|
||||||
|
"Macedonian": "",
|
||||||
|
"Malagasy": "",
|
||||||
|
"Malay": "",
|
||||||
|
"Malayalam": "",
|
||||||
|
"Maltese": "",
|
||||||
|
"Maori": "",
|
||||||
|
"Marathi": "",
|
||||||
|
"Mongolian": "",
|
||||||
|
"Nepali": "",
|
||||||
|
"Norwegian Bokmål": "",
|
||||||
|
"Nyanja": "",
|
||||||
|
"Pashto": "",
|
||||||
|
"Persian": "",
|
||||||
|
"Polish": "",
|
||||||
|
"Portuguese": "",
|
||||||
|
"Punjabi": "",
|
||||||
|
"Romanian": "",
|
||||||
|
"Russian": "",
|
||||||
|
"Samoan": "",
|
||||||
|
"Scottish Gaelic": "",
|
||||||
|
"Serbian": "",
|
||||||
|
"Shona": "",
|
||||||
|
"Sindhi": "",
|
||||||
|
"Sinhala": "",
|
||||||
|
"Slovak": "",
|
||||||
|
"Slovenian": "",
|
||||||
|
"Somali": "",
|
||||||
|
"Southern Sotho": "",
|
||||||
|
"Spanish": "",
|
||||||
|
"Spanish (Latin America)": "",
|
||||||
|
"Sundanese": "",
|
||||||
|
"Swahili": "",
|
||||||
|
"Swedish": "",
|
||||||
|
"Tajik": "",
|
||||||
|
"Tamil": "",
|
||||||
|
"Telugu": "",
|
||||||
|
"Thai": "",
|
||||||
|
"Turkish": "",
|
||||||
|
"Ukrainian": "",
|
||||||
|
"Urdu": "",
|
||||||
|
"Uzbek": "",
|
||||||
|
"Vietnamese": "",
|
||||||
|
"Welsh": "",
|
||||||
|
"Western Frisian": "",
|
||||||
|
"Xhosa": "",
|
||||||
|
"Yiddish": "",
|
||||||
|
"Yoruba": "",
|
||||||
|
"Zulu": "",
|
||||||
|
"`x` years": "`x` år",
|
||||||
|
"`x` months": "`x` månader",
|
||||||
|
"`x` weeks": "`x` veckor",
|
||||||
|
"`x` days": "`x` dagar",
|
||||||
|
"`x` hours": "`x` timmar",
|
||||||
|
"`x` minutes": "`x` minuter",
|
||||||
|
"`x` seconds": "`x` sekunder",
|
||||||
|
"Fallback comments: ": "Fallback-kommentarer: ",
|
||||||
|
"Popular": "Populärt",
|
||||||
|
"Top": "Topp",
|
||||||
|
"About": "Om",
|
||||||
|
"Rating: ": "Betyg: ",
|
||||||
|
"Language: ": "Språk: ",
|
||||||
|
"View as playlist": "Visa som spellista",
|
||||||
|
"Default": "Förvalt",
|
||||||
|
"Music": "Musik",
|
||||||
|
"Gaming": "Spel",
|
||||||
|
"News": "Nyheter",
|
||||||
|
"Movies": "Filmer",
|
||||||
|
"Download": "Ladda ned",
|
||||||
|
"Download as: ": "Ladda ned som: ",
|
||||||
|
"%A %B %-d, %Y": "",
|
||||||
|
"(edited)": "(redigerad)",
|
||||||
|
"YouTube comment permalink": "Permanent YouTube-länk till innehållet",
|
||||||
|
"permalink": "permalänk",
|
||||||
|
"`x` marked it with a ❤": "`x` lämnade ett ❤",
|
||||||
|
"Audio mode": "Ljudläge",
|
||||||
|
"Video mode": "Videoläge",
|
||||||
|
"Videos": "Videor",
|
||||||
|
"Playlists": "Spellistor",
|
||||||
|
"Community": "Gemenskap",
|
||||||
|
"Current version: ": "Nuvarande version: "
|
||||||
|
}
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user