Compare commits
	
		
			670 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | e3ade148ca | ||
|   | 34c0eff89f | ||
|   | 40aba47a47 | ||
|   | 6736f51134 | ||
|   | 9d826d6e52 | ||
|   | 902d9bc7a5 | ||
|   | b6c86e2845 | ||
|   | 34dffdfc8f | ||
|   | a56f3f1d89 | ||
|   | 88dc4c83cb | ||
|   | 5a28dc0198 | ||
|   | 40d2650d49 | ||
|   | 545e83efb1 | ||
|   | d4b00a5482 | ||
|   | c2b1bbeec5 | ||
|   | 8c8f165a6e | ||
|   | 04553de230 | ||
|   | 2776934728 | ||
|   | 0064dbb010 | ||
|   | d52e671adf | ||
|   | 6017dc2dff | ||
|   | 937f7cbd60 | ||
|   | f8b3f66904 | ||
|   | 9d5701f35a | ||
|   | dff65810c6 | ||
|   | 6752cf1d64 | ||
|   | 8336910a59 | ||
|   | 957a1149e0 | ||
|   | e8719ff6e6 | ||
|   | 28b63298e5 | ||
|   | dd4dee8095 | ||
|   | c47818fed4 | ||
|   | e53c383908 | ||
|   | 55c9c0436b | ||
|   | 66b79e5e24 | ||
|   | 514b830910 | ||
|   | e4f799bf1d | ||
|   | b383427d3d | ||
|   | e969518139 | ||
|   | 113fe294bd | ||
|   | a4d92f781f | ||
|   | 414cac49c3 | ||
|   | 95b157ac3e | ||
|   | 8e3d884081 | ||
|   | 9def6fcadd | ||
|   | 7837bd44fc | ||
|   | a6c3663155 | ||
|   | 0b5afadbb8 | ||
|   | 43864f0da4 | ||
|   | 6a0d9d70ed | ||
|   | 63c6dce68e | ||
|   | 53422ffcb2 | ||
|   | 38ca514f53 | ||
|   | caea0f0376 | ||
|   | 25a8b26977 | ||
|   | bcaefe8d62 | ||
|   | 46f1e8c599 | ||
|   | 16230f320e | ||
|   | ace6419aef | ||
|   | 77fb9eb2be | ||
|   | aa7fc7c893 | ||
|   | 8fc170109f | ||
|   | ad12d00d7e | ||
|   | fa5ea45726 | ||
|   | 4b6c113251 | ||
|   | 3548290ff2 | ||
|   | b165b90c40 | ||
|   | 4ffe9c908b | ||
|   | a135f75e71 | ||
|   | cbc61ba03d | ||
|   | 5aa58da918 | ||
|   | b083430011 | ||
|   | a8946b0404 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 0303bccc61 | ||
|   | f3ce8564ea | ||
|   | 52c3f9e98c | ||
|   | 6c8b4184fe | ||
|   | a0979f8435 | ||
|   | faba21d003 | ||
|   | d82c5dff71 | ||
|   | 59fbc5b054 | ||
|   | 2c1a7f4392 | ||
|   | 769e6182d8 | ||
|   | 88176a17a3 | ||
|   | fc660e869f | ||
|   | dc04869650 | ||
|   | 93c3f34813 | ||
|   | 1282eed192 | ||
|   | 962b3ca78e | ||
|   | 62d17c9266 | ||
|   | f5b928a537 | ||
|   | c8811894b5 | ||
|   | e579b49228 | ||
|   | 9561908ad3 | ||
|   | fac7ebf4f6 | ||
|   | a0769d65e3 | ||
|   | d17aa4b24e | ||
|   | 310371658b | ||
|   | 7ca073aafd | ||
|   | 7216d0fb1f | ||
|   | 22a9e950c7 | ||
|   | 6683d50bae | ||
|   | 8f26176273 | ||
|   | 9ea7d446e8 | ||
|   | 757312ba52 | ||
|   | 1675c473d4 | ||
|   | 3a3a5d4bfb | ||
|   | 4a41499c95 | ||
|   | a1d1cb58e0 | ||
|   | acb82fe7b6 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | b25df24cea | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 39284eb9b2 | ||
|   | 31b0e552a2 | ||
|   | c4a2a31cf3 | ||
|   | 4497ddb3f3 | ||
|   | 5e0eda9526 | ||
|   | 72b85fc09f | ||
|   | 6c27412c9c | ||
|   | 46bddfc9c2 | ||
|   | 56275bcfcb | ||
|   | f35688bab8 | ||
|   | 93541f83c8 | ||
|   | ea0d114833 | ||
|   | 7f6a3ec828 | ||
|   | 732804b6fa | ||
|   | aba85b977d | ||
|   | e6612f610c | ||
|   | 5a28632af7 | ||
|   | 4099db0d42 | ||
|   | 9d50a06d9c | ||
|   | dd7bf9b2a3 | ||
|   | c463284c2f | ||
|   | c1d728a616 | ||
|   | e43c9c0e21 | ||
|   | 15cac10d7b | ||
|   | 49958ca03f | ||
|   | 280dbe9853 | ||
|   | bf964ee969 | ||
|   | 61dcd51888 | ||
|   | 5448c22031 | ||
|   | 27768081e2 | ||
|   | c3140f57b9 | ||
|   | 7275bc6d3b | ||
|   | 485f2f460e | ||
|   | 336912e442 | ||
|   | dd9c94e47e | ||
|   | 055863144d | ||
|   | 0bf602bae6 | ||
|   | 6fc28d1df7 | ||
|   | 2ef795aba8 | ||
|   | 1d2c50fc26 | ||
|   | cef8aa5e7a | ||
|   | edf3e75344 | ||
|   | 62835c6011 | ||
|   | 60fb22cb3c | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 20dea3a793 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | aba37ae701 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 2c6e6275aa | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 20ef362854 | ||
|   | 4692aa8d9b | ||
|   | f7b6dc08f7 | ||
|   | 7dfe7005e0 | ||
|   | b91de4ac12 | ||
|   | d5205d7328 | ||
|   | f44ce535fa | ||
|   | 7177fd27c8 | ||
|   | cf304f88d4 | ||
|   | dff1d84031 | ||
|   | 96bc17aa10 | ||
|   | 41ba06a5e6 | ||
|   | d7ac0418d7 | ||
|   | f4319a9c01 | ||
|   | f4c4d53bbb | ||
|   | 0ed43e1bdf | ||
|   | d25bd876cb | ||
|   | b9782397c2 | ||
|   | ea0abc9f71 | ||
|   | 27d16c6a12 | ||
|   | ede70d354e | ||
|   | 66fa583f6e | ||
|   | 77bcb58f12 | ||
|   | 61036e3a70 | ||
|   | bcd886c4f5 | ||
|   | 4d868aaf1f | ||
|   | 80ea747db6 | ||
|   | 960f29ce81 | ||
|   | 20ee57931f | ||
|   | 71ba72e796 | ||
|   | 9835945ee1 | ||
|   | 4f2d52697d | ||
|   | 46c258d77a | ||
|   | 3b5b3cf521 | ||
|   | 5e0bdd8a78 | ||
|   | b299988bb5 | ||
|   | e26bec6ab4 | ||
|   | e9955e01d6 | ||
|   | 1974d8f58b | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 08c0be11b2 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 87c7058494 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | b92addffa9 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | e8b49df842 | ||
|   | 18fd39b335 | ||
|   | 8a11322802 | ||
|   | 31929dad61 | ||
|   | 4a41d2fddc | ||
|   | 4c65b0cd6f | ||
|   | 3e89dc603d | ||
|   | 2a1def3cce | ||
|   | 938fe05fef | ||
|   | 5db5bbd1cd | ||
|   | ba7e05837c | ||
|   | 9dd06a7621 | ||
|   | 2f4434b0d8 | ||
|   | 350328770b | ||
|   | 17e1b49bff | ||
|   | 266c31981d | ||
|   | 803fb0898a | ||
|   | 01983da514 | ||
|   | 6f473aa64a | ||
|   | 574747b9d4 | ||
|   | dff1122bd5 | ||
|   | 43cb12930a | ||
|   | 8129d4dc23 | ||
|   | 9b780dff04 | ||
|   | 11a0ef485b | ||
|   | 83b2aa72b1 | ||
|   | c71b24987d | ||
|   | 78d22dbd22 | ||
|   | 8961dab137 | ||
|   | bcc549fd8e | ||
|   | 5a6c3fc11c | ||
|   | 7d730f676d | ||
|   | 6bda571660 | ||
|   | d3c7129e1f | ||
|   | 3709ba95cd | ||
|   | 4162981081 | ||
|   | 7b7359fbdc | ||
|   | 70c01c52a8 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 443006c868 | ||
|   | 7c1db1fea5 | ||
|   | 7c2b704bef | ||
|   | 368c3f1e29 | ||
|   | dd39d6ea37 | ||
|   | ef618b2431 | ||
|   | 861302f0fd | ||
|   | f014b7ae0e | ||
|   | 00b2d89f1a | ||
|   | 5410efe9ca | ||
|   | 1d814ba0e1 | ||
|   | c107333f56 | ||
|   | 9595a56346 | ||
|   | 06707705bf | ||
|   | 68ee9a008e | ||
|   | 3a035c481e | ||
|   | 23a0aead9f | ||
|   | 6cd41f9860 | ||
|   | baf861ac79 | ||
|   | 0ae1190c08 | ||
|   | d3b3426ebe | ||
|   | 4982ea8f14 | ||
|   | 3be89e9702 | ||
|   | 4275af2324 | ||
|   | 84d42be090 | ||
|   | c4c7783691 | ||
|   | d6dba7fd71 | ||
|   | 30b1b1a5ed | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 90b6688057 | ||
|   | b536ee4dcd | ||
|   | 11101a6aca | ||
|   | b4a3e5aa4f | ||
|   | 874c0eae6a | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 9950b6fbc6 | ||
|   | 42d6ed62f6 | ||
|   | c7e8c27ce6 | ||
|   | 67792fcb5e | ||
|   | 353fc18f19 | ||
|   | cf9e8ed39e | ||
|   | beb1b570d4 | ||
|   | ba1b5a8ede | ||
|   | 99d8d0a484 | ||
|   | 5891135ac1 | ||
|   | c4f7491322 | ||
|   | 206b57b962 | ||
|   | 1b0e03704e | ||
|   | 8b71006fbe | ||
|   | 8f2f4b6d2d | ||
|   | 6e0c055faf | ||
|   | 893a3b527d | ||
|   | fe13c17fcb | ||
|   | 5049870b6e | ||
|   | ce576dea8f | ||
|   | ceda3dd72a | ||
|   | 014b58cb40 | ||
|   | b4859be098 | ||
|   | df54da9510 | ||
|   | b97f788d71 | ||
|   | edd1baa9f4 | ||
|   | 4a23ebe534 | ||
|   | 64c1075b06 | ||
|   | 217e4ee39c | ||
|   | 7e2a7cdff8 | ||
|   | e1fb4f23f0 | ||
|   | 452fb8e496 | ||
|   | 6758b0f133 | ||
|   | 35e509850f | ||
|   | 0868c3517f | ||
|   | 1cd839215b | ||
|   | 42be09ad33 | ||
|   | bcb7ee8d2a | ||
|   | 3a5867b324 | ||
|   | efe2a6be14 | ||
|   | 11f30b0444 | ||
|   | 75558add17 | ||
|   | ca91709801 | ||
|   | 45b905df6a | ||
|   | 32a0cd4b13 | ||
|   | 0b2571858f | ||
|   | 08eb3851da | ||
|   | 0bd0fb9fbf | ||
|   | 9beab05a30 | ||
|   | 3b3ef20e0a | ||
|   | 3441acf56c | ||
|   | 189f9f6592 | ||
|   | 6071fc7077 | ||
|   | 2f215ea34c | ||
|   | c44c777976 | ||
|   | 7d2f0a1f31 | ||
|   | 15eca04bc4 | ||
|   | 238c6a428b | ||
|   | 110eeb89f1 | ||
|   | 278e43e9ba | ||
|   | d55277e57e | ||
|   | f53a93ea13 | ||
|   | a3e37294e5 | ||
|   | 05baa89508 | ||
|   | 80aa45372a | ||
|   | a91f95451a | ||
|   | 122ef23e0f | ||
|   | cd9d67389a | ||
|   | 52d6ec2138 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | a5725c1d04 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | db8ad3c035 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | a0957f2e50 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 301b8f5e13 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 7f6bb75f95 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 9be47df10e | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | bec014da4a | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | cefecd7903 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 52cb043185 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 3a440dd116 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 8ae1039c77 | ||
|   | 190eb0601f | ||
|   | 84931003ea | ||
|   | 2b0cb6d728 | ||
|   | 4ea7e711ce | ||
|   | 2a50997a75 | ||
|   | d692d531d1 | ||
|   | e325410649 | ||
|   | eea2b97ae5 | ||
|   | 6b53e9ed29 | ||
|   | 9ae3e7bdab | ||
|   | 3905129eae | ||
|   | 6b4e417cc7 | ||
|   | 3040700005 | ||
|   | 170b1bb4cc | ||
|   | da1a238be3 | ||
|   | 9c106022ae | ||
|   | bab1dc1d97 | ||
|   | 3b30ad5404 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 27268fd6b7 | ||
|   | 00f9c824d1 | ||
|   | 40e177fa96 | ||
|   | 2f72c38516 | ||
|   | 2dc4696b0a | ||
|   | 723d5baed5 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 341838b502 | ||
|   | 72efa278b3 | ||
|   | 5fe9f2baee | ||
|   | c7ebf6f990 | ||
|   | 9bf9519b8f | ||
|   | 6c57690359 | ||
|   | 3a03010ee2 | ||
|   | ba4dcc40da | ||
|   | 1b0601b421 | ||
|   | e2bf0067b2 | ||
|   | 6d004fde7c | ||
|   | f35547f3b8 | ||
|   | c34a278533 | ||
|   | 6d3408ae73 | ||
|   | a6e7bbc306 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | d140548784 | ||
|   | 76569bfb08 | ||
|   | bbcdf1bb8a | ||
|   | 6439a6c63f | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 76fe1c21c3 | ||
|   | 4f99b98ed8 | ||
|   | 7cb38f5525 | ||
|   | 734277d9f6 | ||
|   | 960d4e2e7b | ||
|   | 33eb91c0f0 | ||
|   | 6f1e47f0b3 | ||
|   | 0a8488a78c | ||
|   | 57ab640221 | ||
|   | 3c4682782c | ||
|   | dc820ffba6 | ||
|   | e4c745bccd | ||
|   | a05c94437c | ||
|   | fdcc994291 | ||
|   | f54363076c | ||
|   | ec016e5a95 | ||
|   | bbdb2496a4 | ||
|   | b515cc90e9 | ||
|   | bb92158dff | ||
|   | c652add16a | ||
|   | b8a7468c4a | ||
|   | e220ef3e75 | ||
|   | 4bb4903ee5 | ||
|   | 9487840ae3 | ||
|   | 7e3a8d56e6 | ||
|   | e909eac296 | ||
|   | 8dc7f28744 | ||
|   | a4b1e8ca26 | ||
|   | 79b0cc6785 | ||
|   | 00b134ce1e | ||
|   | b3fc4dc00f | ||
|   | d06fbbe3ea | ||
|   | 28bfb45426 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 1c60a49c96 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 3ae8ff083b | ||
|   | c12ccb2a15 | ||
|   | e3b1d00e4c | ||
|   | 98795aad9a | ||
|   | ca26edbfce | ||
|   | 3058e8f354 | ||
|   | 4c9b66b0f0 | ||
|   | 6eb9ba31bf | ||
|   | 5bbf4187e6 | ||
|   | f2425f71c2 | ||
|   | b0e00da2f7 | ||
|   | 215472cd17 | ||
|   | 072fd4455e | ||
|   | 2ed9e26a4f | ||
|   | 8a3e26cdb8 | ||
|   | 7301671962 | ||
|   | 0d0f25818e | ||
|   | 7850d68dc2 | ||
|   | f0f5b32300 | ||
|   | 1ca0976e85 | ||
|   | 7fbfd17896 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 3d04f7db62 | ||
|   | e301630c9d | ||
|   | afbccaae41 | ||
|   | 893c01c207 | ||
|   | 41c80097ce | ||
|   | 250933fff3 | ||
|   | bc9454f67c | ||
|   | 377a7fdf3e | ||
|   | 645f661911 | ||
|   | db7c83c8ff | ||
|   | 97385db5b5 | ||
|   | c69d57a064 | ||
|   | a488d6e2d6 | ||
|   | 85e8b1fbf4 | ||
|   | 78763116c3 | ||
|   | 103fe8b91d | ||
|   | 311e67047d | ||
|   | 62d41023e1 | ||
|   | 5fac7c1718 | ||
|   | ade01139ca | ||
|   | 5ea8e9c787 | ||
|   | e5cfdbf372 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | d2cc5c3b63 | ||
|   | 7cdd90db09 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | aad1b8c12e | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 2519abdd39 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | e8d0568a11 | ||
|   | 031287aebd | ||
|   | b24de13a37 | ||
|   | c113fdc20e | ||
|   | 1af1638e2b | ||
|   | 8c62aafa97 | ||
|   | 4de62220e3 | ||
|   | e5d9381503 | ||
|   | 5621113d1f | ||
|   | d906d90010 | ||
|   | b836528b51 | ||
|   | 4b191c7f68 | ||
|   | f9f70d5df4 | ||
|   | 50b809784f | ||
|   | 54ce19bd56 | ||
|   | 71210595d2 | ||
|   | 085325e65f | ||
|   | e4c0c8869e | ||
|   | 405f98d6d1 | ||
|   | 870ab3d3b6 | ||
|   | 9ac2913afc | ||
|   | 171651484a | ||
|   | bfadb4026d | ||
|   | 3940a9a447 | ||
|   | 714446fb46 | ||
|   | e806f33f9f | ||
|   | 65ee1711e5 | ||
|   | ef92578555 | ||
|   | 0352fd0acd | ||
|   | fffce73d3e | ||
|   | 717f66b4a6 | ||
|   | 7dcea49be7 | ||
|   | 7c91915e50 | ||
|   | 895e80d794 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | be5714a9f1 | ||
|   | 1ba8374292 | ||
|   | 94154a1aa2 | ||
|   | 5ae576bad1 | ||
|   | f9e6c84d00 | ||
|   | 3ab5d2e0e1 | ||
|   | b8f60527f6 | ||
|   | a83c3557fc | ||
|   | a45abf858f | ||
|   | a82eeb7e92 | ||
|   | 3781f07c49 | ||
|   | 990bc976de | ||
|   | ff2fc2267d | ||
|   | ec50240a03 | ||
|   | bf00b59339 | ||
|   | 456b01590b | ||
|   | 5eeec0becb | ||
|   | e5fcb2aea0 | ||
|   | d717b1d404 | ||
|   | 2334b41375 | ||
|   | 6f6974a6ae | ||
|   | 0854f2e180 | ||
|   | a0f8c7e94e | ||
|   | 1f5e3040ed | ||
|   | 6128e62751 | ||
|   | 7c6088b2b4 | ||
|   | 9450e567c6 | ||
|   | c9c2e36540 | ||
|   | fbfd3a60ed | ||
|   | 9b386fd50e | ||
|   | db5a404081 | ||
|   | 3bffe605f7 | ||
|   | 4e92eb55cd | ||
|   | 6667ddbc26 | ||
|   | 16e4bb7f79 | ||
|   | 821182cad5 | ||
|   | b3730e3373 | ||
|   | 741efa1a9a | ||
|   | de1a7b4364 | ||
|   | 85cd647946 | ||
|   | da7d1938c9 | ||
|   | 5a795c4ab2 | ||
|   | 95d4937e16 | ||
|   | 6bbc6a80b2 | ||
|   | 79d2374d8e | ||
|   | e4601962d0 | ||
|   | 4398651841 | ||
|   | 42cd7c8a75 | ||
|   | 501379c82c | ||
|   | 92b45d1a9d | ||
|   | 3330c3f548 | ||
|   | 3552b1c900 | ||
|   | 428d27a27b | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 4f6e387d49 | ||
|   | 01c0253c89 | ||
|   | 76fcf122f9 | ||
|   | 926ad23033 | ||
|   | b956d63c46 | ||
|   | 1970927b5e | ||
|   | 3995ae0957 | ||
|   | c2a840fa19 | ||
|   | c7a6321a08 | ||
|   | 0c42c54b7a | ||
|   | 8b775c85f6 | ||
|   | 5c14ff661f | ||
|   | 160c1a3022 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 7017d3ae07 | ||
|   | 5eca0a31f7 | ||
|   | 44d53488e0 | ||
|   | d731c7da13 | ||
|   | 225544e985 | ||
|   | e2f7e82cac | ||
|   | 0be7bf93d9 | ||
|   | 75f9e6bdf5 | ||
|   | 8f6ea13696 | ||
|   | f434b3a875 | ||
|   | 70b980d463 | ||
|   | a59cf87374 | ||
|   | c9a9d5dbfd | ||
|   | e0480f4e01 | ||
|   | d8cfd8f56d | ||
|   | 593d3e2d55 | ||
|   | a79901b441 | ||
|   | 4c526f2837 | ||
|   | 3c28dd92ec | ||
|   | d09af4754a | ||
|   | 44ab6cbc39 | ||
|   | 6c42db7589 | ||
|   | 20dfd2faca | ||
|   | 13696a85ee | ||
|   | 4632eecb76 | ||
|   | 44a3df0acf | ||
|   | 4ab96251f5 | ||
|   | b795379417 | ||
|   | aa9ba31675 | ||
|   | ad66c8478a | ||
|   | 4ec64b4c57 | ||
|   | 2f0b75a882 | ||
|   | 912ee60781 | ||
|   | 67dacb7725 | ||
|   | 82f1fc6cda | ||
|   | 4d24741d48 | ||
|   | 931f17c589 | ||
|   | ff898b4c20 | ||
|   | 7b507c8480 | ||
|   | bb688f78fc | ||
|   | a2a31236f6 | ||
|   | 0b191b4d0e | ||
|   | 2e97f29411 | ||
|   | eb1ad54427 | ||
|   | e4974392e5 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 4e0d43b45a | ||
|   | 78c185a05a | ||
|   | fa124abbe2 | ||
|   | f4fa3f031e | ||
|   | 3cc7a99d0f | ||
|   | 8bf9e87117 | ||
|   | 97e8ac1d27 | ||
|   | 45fb2ecb3a | ||
|   | d5e80caac8 | ||
|   | 7ceea61170 | ||
|   | a3ce65ee28 | ||
|   | d6b7a048e4 | ||
|   | f7c8e31b36 | ||
|   | 26c327145f | ||
|   | b7afd07d6a | ||
|   | eaff52548f | ||
|   | 76828adc54 | ||
|   | 198b0b3de3 | ||
|   | 3cdee2732a | ||
|   | 27a7bb7229 | ||
|   | cf38a6d0a0 | ||
|   | 02c88f9b3b | ||
|   | 3ac1077b36 | ||
|   | 2b4f6abc15 | ||
|   | 7bd24348d2 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | c49ae672f2 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 2eb2cc7880 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | f2f3d4beec | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 3fd1ea900a | ||
|   | c815d11ed2 | ||
|   | 350151ca5b | ||
|   | 4339f9af29 | ||
|   | b44227948d | ||
|   | 5dc8c8846d | ||
|   | e1bee8adf3 | ||
|   | b9ef750321 | ||
|   | e05c0e7d37 | ||
|   | a3eb0ddc4f | ||
|   | da6e71f2e0 | ||
|   | 09e08e829d | ||
|   | 1b78ae6290 | ||
|   | 97f5ba0bc5 | ||
|   | 8e29ccdc7f | ||
|   | 4e48214068 | ||
|   | 1bd128d507 | ||
|   | bfc1f8a25d | ||
|   | 6369d79aaf | ||
|   | 2df2cf0983 | ||
|   | c93fe423ea | ||
|   | ecac2990eb | 
| @@ -2,7 +2,7 @@ | ||||
| # __MISSKEY_BEARER_TOKEN= | ||||
| # __MISSKEY_CAMPAIGN_ID= | ||||
| # __MISSKEY_GITHUB_TOKEN= | ||||
| # __MISSKEY_HEAD=acid-chicken:patch-autogen | ||||
| # __MISSKEY_HEAD=syuilo:patch-autogen | ||||
| # __MISSKEY_REPO=syuilo/misskey | ||||
| # __MISSKEY_BRANCH=develop | ||||
| test "$(curl -LSs -w '\n' -- "https://api.github.com/repos/$REPO/pulls?access_token=$__MISSKEY_GITHUB_TOKEN" | jq -r -f check_pr.jq | grep $__MISSKEY_HEAD)" && exit 1 | ||||
|   | ||||
| @@ -2,6 +2,11 @@ version: 2.1 | ||||
|  | ||||
| executors: | ||||
|   default: | ||||
|     working_directory: /tmp/workspace | ||||
|     docker: | ||||
|       - image: misskey/ci:latest | ||||
|       - image: circleci/mongo:latest | ||||
|   with-redis: | ||||
|     working_directory: /tmp/workspace | ||||
|     docker: | ||||
|       - image: misskey/ci:latest | ||||
| @@ -24,28 +29,26 @@ jobs: | ||||
|           name: OK | ||||
|           command: | | ||||
|             echo -e '\033[0;32mOK\033[0;39m' | ||||
|  | ||||
|   build: | ||||
|     executor: default | ||||
|     steps: | ||||
|       - checkout | ||||
|       - run: | ||||
|           name: Ensure package-lock.json | ||||
|           name: Ensure yarn.lock | ||||
|           command: | | ||||
|             [ ! -e package-lock.json ] && echo '{}' > package-lock.json | ||||
|             touch yarn.lock | ||||
|       - restore_cache: | ||||
|           name: Restore npm package caches | ||||
|           keys: | ||||
|             - npm-v1-arch-{{ arch }}-env-{{ .Environment.variableName }}-package-{{ checksum "package.json" }}-lock-{{ checksum "package-lock.json" }}- | ||||
|             - npm-v1-arch-{{ arch }}-env-{{ .Environment.variableName }}-package-{{ checksum "package.json" }}- | ||||
|             - npm-v1-arch-{{ arch }}-env-{{ .Environment.variableName }}- | ||||
|             - npm-v1-arch-{{ arch }}- | ||||
|             - npm-v1- | ||||
|             - yarn-v1-arch-{{ arch }}-env-{{ .Environment.variableName }}-package-{{ checksum "package.json" }}-lock-{{ checksum "yarn.lock" }} | ||||
|             - yarn-v1-arch-{{ arch }}-env-{{ .Environment.variableName }}-package-{{ checksum "package.json" }}- | ||||
|             - yarn-v1-arch-{{ arch }}-env-{{ .Environment.variableName }}- | ||||
|             - yarn-v1-arch-{{ arch }}- | ||||
|             - yarn-v1- | ||||
|       - run: | ||||
|           name: Install Dependencies | ||||
|           command: | | ||||
|             npm install | ||||
|             npm prune | ||||
|             yarn install | ||||
|       - run: | ||||
|           name: Configure | ||||
|           command: | | ||||
| @@ -54,13 +57,11 @@ jobs: | ||||
|       - run: | ||||
|           name: Build | ||||
|           command: | | ||||
|             node-gyp configure | ||||
|             node-gyp build | ||||
|             npm run build || (echo -e '\033[0;34mRebuild modules\033[0;39m' && ls -1A node_modules | grep '^[^@]' | xargs npm rebuild && ls -1A node_modules | grep '^@' | xargs -I%1 sh -c 'ls -1A node_modules/'%1' | xargs -P0 -I%2 npm rebuild node_modules/'%1'/%2' && npm run build) | ||||
|             ls -1ARl node_modules > ls | ||||
|             yarn build | ||||
|             touch yarn.lock | ||||
|       - save_cache: | ||||
|           name: Cache npm packages | ||||
|           key: npm-v1-arch-{{ arch }}-env-{{ .Environment.variableName }}-package-{{ checksum "package.json" }}-lock-{{ checksum "package-lock.json" }}-ls-{{ checksum "ls" }} | ||||
|           key: yarn-v1-arch-{{ arch }}-env-{{ .Environment.variableName }}-package-{{ checksum "package.json" }}-lock-{{ checksum "yarn.lock" }} | ||||
|           paths: | ||||
|             - node_modules | ||||
| #      - store_artifacts: | ||||
| @@ -71,10 +72,13 @@ jobs: | ||||
|             - . | ||||
|   test: | ||||
|     parameters: | ||||
|       without_redis: | ||||
|       executor: | ||||
|         type: string | ||||
|         default: "" | ||||
|     executor: default | ||||
|         default: "default" | ||||
|       without_redis: | ||||
|         type: boolean | ||||
|         default: false | ||||
|     executor: <<parameters.executor>> | ||||
|     steps: | ||||
|       - attach_workspace: | ||||
|           at: /tmp/workspace | ||||
| @@ -90,19 +94,18 @@ jobs: | ||||
|       - run: | ||||
|           name: Test | ||||
|           command: | | ||||
|             npm run test | ||||
|             ls -1ARl node_modules > ls | ||||
|             yarn test | ||||
|             touch yarn.lock | ||||
|       - save_cache: | ||||
|           name: Cache npm packages | ||||
|           key: npm-v1-arch-{{ arch }}-env-{{ .Environment.variableName }}-package-{{ checksum "package.json" }}-lock-{{ checksum "package-lock.json" }}-ls-{{ checksum "ls" }} | ||||
|           key: yarn-v1-arch-{{ arch }}-env-{{ .Environment.variableName }}-package-{{ checksum "package.json" }}-lock-{{ checksum "yarn.lock" }} | ||||
|           paths: | ||||
|             - node_modules | ||||
|  | ||||
|   docker: | ||||
|     parameters: | ||||
|       with_deploy: | ||||
|         type: string | ||||
|         default: "" | ||||
|         type: boolean | ||||
|         default: false | ||||
|     executor: docker | ||||
|     steps: | ||||
|       - checkout | ||||
| @@ -129,7 +132,7 @@ jobs: | ||||
|  | ||||
| workflows: | ||||
|   version: 2 | ||||
|   build-and-test: | ||||
|   nodejs: | ||||
|     jobs: | ||||
|       - ok: | ||||
|           filters: | ||||
| @@ -137,13 +140,23 @@ workflows: | ||||
|               only: | ||||
|                 - l10n_develop | ||||
|                 - imgbot | ||||
|                 - patch-autogen | ||||
|       - hold: | ||||
|           type: approval | ||||
|           filters: | ||||
|             branches: | ||||
|               ignore: master | ||||
|       - build: | ||||
|           requires: | ||||
|             - hold | ||||
|           filters: | ||||
|             branches: | ||||
|               ignore: | ||||
|                 - l10n_develop | ||||
|                 - imgbot | ||||
|                 - patch-autogen | ||||
|       - test: | ||||
|           executor: with-redis | ||||
|           requires: | ||||
|             - build | ||||
|           filters: | ||||
| @@ -152,19 +165,35 @@ workflows: | ||||
| #                - master | ||||
|                 - l10n_develop | ||||
|                 - imgbot | ||||
|                 - patch-autogen | ||||
|       - test: | ||||
|           without_redis: "true" | ||||
|           without_redis: true | ||||
|           requires: | ||||
|             - build | ||||
|           filters: | ||||
|             branches: | ||||
|               only: master | ||||
| #      - docker: | ||||
| #          filters: | ||||
| #            branches: | ||||
| #              ignore: master | ||||
| #              only: master | ||||
|             branches: | ||||
|               ignore: | ||||
| #                - master | ||||
|                 - l10n_develop | ||||
|                 - imgbot | ||||
|                 - patch-autogen | ||||
|   docker: | ||||
|     jobs: | ||||
|       - hold: | ||||
|           type: approval | ||||
|           filters: | ||||
|             branches: | ||||
|               ignore: master | ||||
|       - docker: | ||||
|           with_deploy: "true" | ||||
|           requires: | ||||
|             - hold | ||||
|           filters: | ||||
|             branches: | ||||
|               ignore: master | ||||
|       - docker: | ||||
|           with_deploy: true | ||||
|           filters: | ||||
|             branches: | ||||
|               only: master | ||||
|   | ||||
| @@ -6,6 +6,8 @@ mongodb: | ||||
|   db: misskey | ||||
|   user: syuilo | ||||
|   pass: '' | ||||
| drive: | ||||
|   storage: 'db' | ||||
| redis: | ||||
|   host: localhost | ||||
|   port: 6379 | ||||
|   | ||||
| @@ -6,6 +6,8 @@ mongodb: | ||||
|   db: test-misskey | ||||
|   user: admin | ||||
|   pass: '' | ||||
| drive: | ||||
|   storage: 'db' | ||||
| # __REDIS__ | ||||
| redis: | ||||
|   host: localhost | ||||
|   | ||||
| @@ -108,5 +108,8 @@ autoAdmin: true | ||||
| #  port: 9200 | ||||
| #  pass: null | ||||
|  | ||||
| # Whether disable HSTS | ||||
| #disableHsts: true | ||||
|  | ||||
| # Clustering | ||||
| #clusterLimit: 1 | ||||
|   | ||||
							
								
								
									
										39
									
								
								.github/CODEOWNERS
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								.github/CODEOWNERS
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,39 @@ | ||||
| # PATH                                          OWNERS | ||||
| /.autogen/                                      @acid-chicken | ||||
| /.circleci/                                     @syuilo @acid-chicken | ||||
| /.config/                                       @syuilo @AyaMorisawa @mei23 @acid-chicken | ||||
| # /.config/mongo_initdb_example.js              @khws4v1 | ||||
| /.github/                                       @syuilo @AyaMorisawa @acid-chicken | ||||
| /.vscode/                                       @acid-chicken | ||||
| /assets/                                        @syuilo # @tamaina | ||||
| /cli/                                           @syuilo | ||||
| /docs/                                          @syuilo | ||||
| /docs/*.en.md                                   @AyaMorisawa # @skid9000 | ||||
| # /docs/*.fr.md                                 @BoFFire | ||||
| # /docs/docker.*.md                             @khws4v1 | ||||
| /locales/                                       @syuilo | ||||
| /src/                                           @syuilo @AyaMorisawa @mei23 @acid-chicken | ||||
| # /src/crypto_key.cc                            @akihikodaki | ||||
| # /src/crypto_key.d.ts                          @akihikodaki | ||||
| /.dockerignore                                  @syuilo # @khws4v1 | ||||
| /.editorconfig                                  @syuilo @AyaMorisawa | ||||
| /.eslintrc                                      @syuilo | ||||
| /.gitattributes                                 @syuilo | ||||
| /.gitignore                                     @syuilo | ||||
| /.npmrc                                         @syuilo | ||||
| /.vsls.json                                     @AyaMorisawa | ||||
| /CHANGELOG.md                                   @syuilo | ||||
| /CODE_OF_CONDUCT.md                             @syuilo | ||||
| /CONTRIBUTING.md                                @syuilo | ||||
| /Dockerfile                                     @syuilo @AyaMorisawa @acid-chicken # @khws4v1 | ||||
| /LICENSE                                        @syuilo | ||||
| /README.md                                      @syuilo @AyaMorisawa @acid-chicken # @nikhiljha | ||||
| # /binding.gyp                                  @akihikodaki | ||||
| /crowdin.yml                                    @syuilo | ||||
| # /docker-compose.yml                           @khws4v1 | ||||
| /gulpfile.ts                                    @syuilo @AyaMorisawa | ||||
| /jsconfig.json                                  @syuilo @AyaMorisawa | ||||
| /package.json                                   @syuilo @AyaMorisawa | ||||
| /tsconfig.json                                  @syuilo @AyaMorisawa | ||||
| /tslint.json                                    @syuilo @AyaMorisawa | ||||
| /webpack.config.ts                              @syuilo @AyaMorisawa | ||||
| @@ -1,22 +1,30 @@ | ||||
| --- | ||||
| name: Bug Report | ||||
| about: Create a report to help us improve | ||||
| title: '' | ||||
| labels: bug | ||||
| assignees: '' | ||||
| 
 | ||||
| --- | ||||
| 
 | ||||
| # Summary | ||||
| 
 | ||||
| <!-- Tell us what the bug is --> | ||||
| 
 | ||||
| # Expected Behavior | ||||
| 
 | ||||
| <!--- Tell us what should happen --> | ||||
| 
 | ||||
| # Actual Behavior | ||||
| 
 | ||||
| <!--- Tell us what happens instead of the expected behavior --> | ||||
| 
 | ||||
| # Steps to Reproduce | ||||
| 
 | ||||
| 1. | ||||
| 2. | ||||
| 3. | ||||
| 
 | ||||
| # Environment | ||||
| 
 | ||||
| <!-- Tell us where on the platform it happens --> | ||||
| <!-- e.g. desktop or mobile version, your browser, your OS --> | ||||
							
								
								
									
										31
									
								
								.github/ISSUE_TEMPLATE/02_client-side-bug-report.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								.github/ISSUE_TEMPLATE/02_client-side-bug-report.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| --- | ||||
| name: Client-side Bug Report | ||||
| about: Create a report to help us improve | ||||
| title: '' | ||||
| labels: bug, client-side | ||||
| assignees: '' | ||||
|  | ||||
| --- | ||||
|  | ||||
| # Summary | ||||
|  | ||||
| <!-- Tell us what the bug is --> | ||||
|  | ||||
| # Expected Behavior | ||||
|  | ||||
| <!--- Tell us what should happen --> | ||||
|  | ||||
| # Actual Behavior | ||||
|  | ||||
| <!--- Tell us what happens instead of the expected behavior --> | ||||
|  | ||||
| # Steps to Reproduce | ||||
|  | ||||
| 1. | ||||
| 2. | ||||
| 3. | ||||
|  | ||||
| # Environment | ||||
|  | ||||
| <!-- Tell us where on the platform it happens --> | ||||
| <!-- e.g. desktop or mobile version, your browser, your OS --> | ||||
							
								
								
									
										31
									
								
								.github/ISSUE_TEMPLATE/03_server-side-bug-report.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								.github/ISSUE_TEMPLATE/03_server-side-bug-report.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| --- | ||||
| name: Server-side Bug Report | ||||
| about: Create a report to help us improve | ||||
| title: '' | ||||
| labels: bug, server-side | ||||
| assignees: '' | ||||
|  | ||||
| --- | ||||
|  | ||||
| # Summary | ||||
|  | ||||
| <!-- Tell us what the bug is --> | ||||
|  | ||||
| # Expected Behavior | ||||
|  | ||||
| <!--- Tell us what should happen --> | ||||
|  | ||||
| # Actual Behavior | ||||
|  | ||||
| <!--- Tell us what happens instead of the expected behavior --> | ||||
|  | ||||
| # Steps to Reproduce | ||||
|  | ||||
| 1. | ||||
| 2. | ||||
| 3. | ||||
|  | ||||
| # Environment | ||||
|  | ||||
| <!-- Tell us where on the platform it happens --> | ||||
| <!-- e.g. your Node.js version, your OS --> | ||||
							
								
								
									
										12
									
								
								.github/ISSUE_TEMPLATE/11_feature-request.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								.github/ISSUE_TEMPLATE/11_feature-request.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | ||||
| --- | ||||
| name: Feature Request | ||||
| about: Suggest an idea for this project | ||||
| title: '' | ||||
| labels: feature | ||||
| assignees: '' | ||||
|  | ||||
| --- | ||||
|  | ||||
| # Summary | ||||
|  | ||||
| <!-- Tell us what the suggestion is --> | ||||
							
								
								
									
										12
									
								
								.github/ISSUE_TEMPLATE/12_client-side-feature-request.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								.github/ISSUE_TEMPLATE/12_client-side-feature-request.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | ||||
| --- | ||||
| name: Client-side Feature Request | ||||
| about: Suggest an idea for this project | ||||
| title: '' | ||||
| labels: client-side, feature | ||||
| assignees: '' | ||||
|  | ||||
| --- | ||||
|  | ||||
| # Summary | ||||
|  | ||||
| <!-- Tell us what the suggestion is --> | ||||
							
								
								
									
										12
									
								
								.github/ISSUE_TEMPLATE/13_server-side-feature-request.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								.github/ISSUE_TEMPLATE/13_server-side-feature-request.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | ||||
| --- | ||||
| name: Server-side Feature Request | ||||
| about: Suggest an idea for this project | ||||
| title: '' | ||||
| labels: feature, server-side | ||||
| assignees: '' | ||||
|  | ||||
| --- | ||||
|  | ||||
| # Summary | ||||
|  | ||||
| <!-- Tell us what the suggestion is --> | ||||
							
								
								
									
										11
									
								
								.github/ISSUE_TEMPLATE/feature_request.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										11
									
								
								.github/ISSUE_TEMPLATE/feature_request.md
									
									
									
									
										vendored
									
									
								
							| @@ -1,11 +0,0 @@ | ||||
| --- | ||||
| name: Feature Request | ||||
| about: Suggest an idea for this project | ||||
| --- | ||||
|  | ||||
| # Summary | ||||
| <!-- Tell us what the suggestion is --> | ||||
|  | ||||
| # Environment | ||||
| <!-- Tell us where on the platform it related --> | ||||
| <!-- e.g. desktop or mobile version, your browser, your OS --> | ||||
							
								
								
									
										149
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										149
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,6 +1,155 @@ | ||||
| ChangeLog | ||||
| ========= | ||||
|  | ||||
| 10.86.1 | ||||
| ---------- | ||||
| * ナビゲーションバーの「ホーム」を「タイムライン」に改称 | ||||
| * モバイル版でユーザーページが二重に描画される問題を修正 | ||||
| * ユーザー一覧の「もっと読み込む」の動作がおかしい問題を修正 | ||||
| * デザインの調整 | ||||
|  | ||||
| 10.86.0 | ||||
| ---------- | ||||
| * Exploreページを実装 | ||||
| * UIを改良 | ||||
| * その他細かな修正 | ||||
|  | ||||
| 10.85.2 | ||||
| ---------- | ||||
| * デッキから フォロー/フォロワー ページに行けるように | ||||
| * ナビゲーションが発生したときに最上部までスクロールように | ||||
| * 検索結果でページ遷移が発生する問題を修正 | ||||
| * デザインの調整 | ||||
|  | ||||
| 10.85.1 | ||||
| ---------- | ||||
| * ローカルのみ投稿をログイン画面のタイムラインに表示しないように | ||||
| * ナビゲーションバーを横にしてるとデッキに行けない問題を修正 | ||||
|  | ||||
| 10.85.0 | ||||
| ---------- | ||||
| * デスクトップ版のUIを改良 | ||||
| * 投稿ハイライトページを実装 | ||||
| * 無効化されているタイムラインのフォールバック | ||||
| * 既にフォローされている場合はフォローリクエストを生成しないように | ||||
| * その他細かな修正 | ||||
|  | ||||
| 10.84.2 | ||||
| ---------- | ||||
| * GIF画像にGIFバッジを表示 | ||||
| * よく話すユーザーからサスペンドされたユーザーを隠すなど | ||||
| * nodeinfoが重い問題を修正 | ||||
| * ハッシュタグクラウド取得が重い問題を軽減 | ||||
|  | ||||
| 10.84.1 | ||||
| ---------- | ||||
| * deckにフォローされていますマークを追加 | ||||
| * URLプレビューのサムネイルの調整 | ||||
| * 管理画面でサイレンスされているユーザーを一覧できるように | ||||
| * ドキュメントにアクセスできない問題を修正 | ||||
| * ジョブキューを無効化 | ||||
| * 軽微なバグ修正 | ||||
|  | ||||
| 10.84.0 | ||||
| ---------- | ||||
| * インスタンス管理の強化 | ||||
| * パフォーマンスの問題の修正 | ||||
| * バグ修正 | ||||
|  | ||||
| 10.83.0 | ||||
| ---------- | ||||
| * 特定のインスタンスをブロックをできるように | ||||
| * 特定のインスタンスからのフォローを全解除できるように | ||||
| * インスタンスごとのチャートを追加 | ||||
|  | ||||
| 10.82.4 | ||||
| ---------- | ||||
| * 10.82.3でオブジェクトストレージの設定をしていると起動しなくなるバグを修正 | ||||
|  | ||||
| 10.82.3 | ||||
| ---------- | ||||
| * フォロー/ミュート/ブロックデータをエクスポート可能に | ||||
| * バグ修正 | ||||
| * デザインの調整 | ||||
| * ジョブキューの動作を修正 | ||||
|  | ||||
| 10.82.2 | ||||
| ---------- | ||||
| * ジョブキューの動作を修正 | ||||
|  | ||||
| 10.82.1 | ||||
| ---------- | ||||
| * クラスタリング環境でのジョブキューの動作を修正 | ||||
| * その他の軽微な改善 | ||||
|  | ||||
| 10.82.0 | ||||
| ---------- | ||||
| * 自分の投稿情報をエクスポートできるように | ||||
| * アニメーションする画像を再生しないで表示するオプションを実装 | ||||
| * 個別に投稿のウォッチ/ウォッチ解除をできるように | ||||
|  | ||||
| 10.81.0 | ||||
| ---------- | ||||
| * 動画のサムネイルを作成するように | ||||
| * リモートの外部サービス認証情報を表示するように | ||||
| * public の Renote/Reply/Quote先 が public以外 だったら、public => homeに | ||||
| * ユーザーページから管理者/モデレーターがアカウントのサイレンス/凍結をできるように | ||||
| * 凍結されたユーザーをタイムライン等に表示しないように | ||||
| * おすすめのアンケートでミュートユーザーのものは表示しないように | ||||
| * おすすめのアンケートで凍結済みユーザーのものは表示しないように | ||||
| * 画像でないファイルのサムネイルとしてオリジナルファイルを返してしまうのを修正 | ||||
| * URLプレビューのサムネイルが表示されない場合がある問題を修正 | ||||
| * ダークモードで読みにくいボタンがあるのを修正 | ||||
|  | ||||
| 10.80.0 | ||||
| ---------- | ||||
| * サイレンス機能の追加 | ||||
| * リプライ/メンションされていれば非フォロワーへのフォロワー限定でも参照可能に | ||||
| * MFMの解析を強化 | ||||
| * Misskey以外のインスタンスからMisskeyの投稿を見たときに改行が多い問題を修正 | ||||
| * Misskey以外のインスタンスからMisskeyの投稿を見たときにメンションのURLが展開されるのを修正 | ||||
|  | ||||
| 10.79.1 | ||||
| ---------- | ||||
| * jump構文の追加 | ||||
| * MFMで左回転、往復回転を行えるように | ||||
| * MFMに関する制限を若干緩和 | ||||
| * シンタックスハイライトに関するバグ修正 | ||||
|  | ||||
| 10.79.0 | ||||
| ---------- | ||||
| * 返信するときにCWを維持するかどうか設定できるように | ||||
| * 外部サービス認証情報の配信 | ||||
| * 管理画面のモデレーションのUIを強化 | ||||
| * 管理画面からリモートユーザーの情報を更新できるように | ||||
| * 回転構文の追加 | ||||
| * 左右反転構文の追加 | ||||
| * 複数行の数式構文を追加 | ||||
| * シンタックスハイライトの強化 | ||||
| * 引用投稿を削除したとき単なるRenoteとしてタイムラインに残る問題を修正 | ||||
| * イタリック構文の判定の改善 | ||||
| * タイトル構文の判定の改善 | ||||
| * テーマが反映されないことがある問題を修正 | ||||
| * ホームにフォロワー限定投稿が表示されない問題を修正 | ||||
| * 返信一覧を取得すると非公開投稿も取得されてしまう問題を修正 | ||||
| * メンション一覧を取得すると非公開投稿も取得されてしまう問題を修正 | ||||
| * 通知に非公開投稿が表示される問題を修正 | ||||
| * ダイレクトで投稿すると100%の確率で表示が二重になる問題を修正 | ||||
| * ウィジットの投稿フォームで投稿するとデフォルトの公開範囲が適用されない問題を修正 | ||||
|  | ||||
| 10.78.5 | ||||
| ---------- | ||||
| * アンケートの選択肢にカスタム絵文字を使えるように | ||||
| * 投稿の返信を取得したときにミュートが適用されていない問題を修正 | ||||
| * ユーザビリティの強化 | ||||
|  | ||||
| 10.78.4 | ||||
| ---------- | ||||
| * フォロワー限定投稿がユーザータイムラインに含まれていない問題を修正 | ||||
| * データベースのインデックス設定を修正 | ||||
| * UIの修正 | ||||
| * など | ||||
|  | ||||
| 10.78.3 | ||||
| ---------- | ||||
| * 投票未対応インスタンス向けメッセージをわかりやすく | ||||
|   | ||||
| @@ -38,3 +38,37 @@ Stands for _**M**iss**k**ey_. | ||||
|  | ||||
| ### SW | ||||
| Stands for _**S**ervice**W**orker_. | ||||
|  | ||||
| ### Nyaize | ||||
| な を にゃ にすること | ||||
|  | ||||
| #### Denyaize | ||||
| Nyaizeを解除すること | ||||
|  | ||||
| ## Code style | ||||
| ### Don't use `export default` | ||||
| Bad: | ||||
| ``` ts | ||||
| export default function(foo: string): string { | ||||
| ``` | ||||
|  | ||||
| Good: | ||||
| ``` ts | ||||
| export function something(foo: string): string { | ||||
| ``` | ||||
|  | ||||
| ## Directory structure | ||||
| ``` | ||||
| src ... ソースコード | ||||
| 	@types ... 外部ライブラリなどの型定義 | ||||
| 	prelude ... Misskeyに関係ないかつ副作用なし | ||||
| 	misc ... 副作用なしのユーティリティ処理 | ||||
| 	service ... 副作用ありの共通処理 | ||||
| 	queue ... ジョブキューとジョブ | ||||
| 	server ... Webサーバー | ||||
| 	client ... クライアント | ||||
| 	mfm ... MFM | ||||
|  | ||||
| test ... テスト | ||||
|  | ||||
| ``` | ||||
|   | ||||
							
								
								
									
										16
									
								
								Dockerfile
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								Dockerfile
									
									
									
									
									
								
							| @@ -8,7 +8,6 @@ WORKDIR /misskey | ||||
|  | ||||
| FROM base AS builder | ||||
|  | ||||
| RUN unlink /usr/bin/free | ||||
| RUN apk add --no-cache \ | ||||
|     autoconf \ | ||||
|     automake \ | ||||
| @@ -20,22 +19,19 @@ RUN apk add --no-cache \ | ||||
|     make \ | ||||
|     nasm \ | ||||
|     pkgconfig \ | ||||
|     procps \ | ||||
|     python \ | ||||
|     zlib-dev | ||||
| RUN npm i -g node-gyp | ||||
|  | ||||
| COPY ./package.json ./ | ||||
| RUN npm i | ||||
| RUN npm i -g yarn | ||||
|  | ||||
| COPY . ./ | ||||
| RUN node-gyp configure \ | ||||
|  && node-gyp build \ | ||||
|  && npm run build | ||||
| RUN yarn install | ||||
| RUN yarn build | ||||
|  | ||||
| FROM base AS runner | ||||
|  | ||||
| RUN apk add --no-cache tini | ||||
| RUN apk add --no-cache \ | ||||
|     ffmpeg \ | ||||
|     tini | ||||
| ENTRYPOINT ["/sbin/tini", "--"] | ||||
|  | ||||
| COPY --from=builder /misskey/node_modules ./node_modules | ||||
|   | ||||
							
								
								
									
										28
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										28
									
								
								README.md
									
									
									
									
									
								
							| @@ -3,9 +3,9 @@ | ||||
| [](https://misskey.xyz/) | ||||
| ================================================================ | ||||
|  | ||||
| [](https://circleci.com/gh/syuilo/misskey) | ||||
| [](https://david-dm.org/syuilo/misskey) | ||||
| [](http://makeapullrequest.com) | ||||
| [](https://circleci.com/gh/syuilo/misskey) | ||||
| [](https://david-dm.org/syuilo/misskey) | ||||
| [](http://makeapullrequest.com) | ||||
|  | ||||
| **A forever evolving, sophisticated microblogging platform.** | ||||
|  | ||||
| @@ -13,7 +13,7 @@ | ||||
| <a href="https://misskey.xyz">Misskey</a> is a decentralized microblogging platform born on Earth. | ||||
| Since it exists within the Fediverse (a universe where various social media platforms are organized), | ||||
| it is mutually linked with other social media platforms. | ||||
| Why don't you take a short break from the hustle and bustle of the city, and dive into a new Internet? <a href="https://joinmisskey.github.io/">Find instance!</a> | ||||
| Why don't you take a short break from the hustle and bustle of the city, and dive into a new Internet? <a href="https://joinmisskey.github.io/">Find an instance!</a> | ||||
| </p> | ||||
|  | ||||
| <a href="https://www.patreon.com/syuilo"><img src="https://c5.patreon.com/external/logo/become_a_patron_button@2x.png" alt="Become a Patron!" width="160" /></a> | ||||
| @@ -61,7 +61,11 @@ Organize and store your files! Want to post a picture you have already uploaded? | ||||
|  | ||||
| ...and more! Experience Misskey with your own eyes at [misskey.xyz](https://misskey.xyz) or join one of the [other instances](https://joinmisskey.github.io/) that are available. | ||||
|  | ||||
| :package: Create Your Own Instance | ||||
| :new: What's new | ||||
| ---------------------------------------------------------------- | ||||
| Please see the [Release notes](./CHANGELOG.md). | ||||
|  | ||||
| :package: Create your own instance | ||||
| ---------------------------------------------------------------- | ||||
| Please see the [Setup and Installation Guide](./docs/setup.en.md). | ||||
|  | ||||
| @@ -85,22 +89,22 @@ Please see the [Contribution Guide](./CONTRIBUTING.md). | ||||
| 	</tr> | ||||
| </table> | ||||
|  | ||||
| :heart: Backers & Sponsors | ||||
| :heart: Backers | ||||
| ---------------------------------------------------------------- | ||||
| <!-- PATREON_START --> | ||||
| <table><tr> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/12190916/fb7fa7983c14425f890369535b1506a4/1?token-time=2145916800&token-hash=WeuDzzz24cRXJogyIkU-mxARqkdyms-rcZKbO-GpGjw%3D" alt="weep" width="100"></td> | ||||
| <td><img src="https://c8.patreon.com/2/200/12059069" alt="naga_rus" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/12731202/0995c46cdcb54153ab5f073f5869b70a/1?token-time=2145916800&token-hash=prtYqPOiSHBulhM7NU0VzMaWx39-9ntdq25b6kafDNA%3D" alt="negao" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/12913507/f7181eacafe8469a93033d85f5969c29/3?token-time=2145916800&token-hash=c8HeVqLtmdgH-gSBJg8i10gmOcwllM87MDHeznl3el0%3D" alt="Melilot" width="100"></td> | ||||
| <td><img src="https://c8.patreon.com/2/200/16869916" alt="見当かなみ" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/12999811/5f349fafcce44dd1824a8b1ebbec4564/3?token-time=2145916800&token-hash=LtV2lRi3L2jOWMLwccr9qWYfPrFlzIo2jYZHKzHEb6k%3D" alt="Xeltica" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/3384329/8b713330cb27404ea6e9fac50ff96efe/1?token-time=2145916800&token-hash=Ch3iF81ZGP0LMo894Y9ajpLisgtE91SnxtZE7fxsgrM%3D" alt="べすれい" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/12021162/963128bb8d14476dbd8407943db8f31a/1?token-time=2145916800&token-hash=1FlxS9MEgmNGH_RHUVHbO5hIXB5I1z0lvA33CTvYvjA%3D" alt="gutfuckllc" width="100"></td> | ||||
| </tr><tr> | ||||
| <td><a href="https://www.patreon.com/weepjp">weep</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=12059069">naga_rus</a></td> | ||||
| <td><a href="https://www.patreon.com/negao">negao</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=12913507">Melilot</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=16869916">見当かなみ</a></td> | ||||
| <td><a href="https://www.patreon.com/Xeltica">Xeltica</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=3384329">べすれい</a></td> | ||||
| <td><a href="https://www.patreon.com/gutfuckllc">gutfuckllc</a></td> | ||||
| @@ -111,20 +115,22 @@ Please see the [Contribution Guide](./CONTRIBUTING.md). | ||||
| <td><img src="https://c8.patreon.com/2/200/16542964" alt="Takumi Sugita" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/13039004/509d0c412eb14ae08d6a812a3054f7d6/1?token-time=2145916800&token-hash=2PsbFNw0tnubZzgSXD01R6hIgncfiElG7H7HX2Y3dyo%3D" alt="nemu" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5881381/6235ca5d3fb04c8e95ef5b4ff2abcc18/3?token-time=2145916800&token-hash=9JtETp0X8gI280Ne1E8bxn6j4Lw5o2k4mJkICx97V_k%3D" alt="YUKIMOCHI" width="100"></td> | ||||
| <td><img src="https://c8.patreon.com/2/200/17463605" alt="Sampot" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/17195955/be45e5e14c3e48b2bee0456c84e19df4/4?token-time=2145916800&token-hash=SbdZeN5SmsuT9stD6v0jN1z0hftg0FmRiCTxysU0Ihw%3D" alt="Damillora" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/8241184/39e18850e87a449e9c9a71acb3310ebd/3?token-time=2145916800&token-hash=gMq30aylxu5v3G8pRhWR5jeRBbYWEoRKjGbNeiCQz5g%3D" alt="Acid Chicken" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/4389829/9f709180ac714651a70f74a82f3ffdb9/2?token-time=2145916800&token-hash=zcwFxb2zopzWwksKVU1YpfAEjsl4yKT02aQ6yiAFRiQ%3D" alt="natalie" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/13034746/c711c7f58e204ecfbc2fd646bc8a4eee/1?token-time=2145916800&token-hash=5T8XcaAf9Zyzfg3QubR06s_kJZkArVEM2dwObrBVAU4%3D" alt="Hiratake" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/10789744/97175095d8f04c0f86225ff47cb98d40/1?token-time=2145916800&token-hash=ubVARikVOg3v7NW6LDhtG-ClE1LTU3I2TJ3js2-5xDs%3D" alt="Naoki Hirayama" width="100"></td> | ||||
| </tr><tr> | ||||
| <td><a href="https://www.patreon.com/mydarkstar">mydarkstar</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=12718187">Peter G.</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=16542964">Takumi Sugita</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=13039004">nemu</a></td> | ||||
| <td><a href="https://www.patreon.com/yukimochi">YUKIMOCHI</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=17463605">Sampot</a></td> | ||||
| <td><a href="https://www.patreon.com/damillora">Damillora</a></td> | ||||
| <td><a href="https://www.patreon.com/acid_chicken">Acid Chicken</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=4389829">natalie</a></td> | ||||
| <td><a href="https://www.patreon.com/hiratake">Hiratake</a></td> | ||||
| <td><a href="https://www.patreon.com/spinlock">Naoki Hirayama</a></td> | ||||
| </tr></table> | ||||
| <table><tr> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/4503830/ccf2cc867ea64de0b524bb2e24b9a1cb/1?token-time=2145916800&token-hash=Ksk_2l3gjPDbnzMUOCSW1E-hdPJsNs2tSR4_RAakRK8%3D" alt="dansup" width="100"></td> | ||||
| @@ -138,7 +144,7 @@ Please see the [Contribution Guide](./CONTRIBUTING.md). | ||||
| <td><a href="https://www.patreon.com/user?u=12531784">Takashi Shibuya</a></td> | ||||
| </tr></table> | ||||
|  | ||||
| **Last updated:** Mon, 21 Jan 2019 06:45:06 UTC | ||||
| **Last updated:** Fri, 15 Feb 2019 19:12:06 UTC | ||||
| <!-- PATREON_END --> | ||||
|  | ||||
| :four_leaf_clover: Copyright | ||||
|   | ||||
| @@ -29,15 +29,15 @@ Please install and setup these softwares: | ||||
| * [Redis](https://redis.io/) | ||||
|   * Redis is optional, but we strongly recommended to install it | ||||
| * [Elasticsearch](https://www.elastic.co/) - required to enable the search feature | ||||
| * [FFmpeg](https://www.ffmpeg.org/) | ||||
|  | ||||
| *3.* Setup MongoDB | ||||
| ---------------------------------------------------------------- | ||||
| As root: | ||||
| 1. `mongo` Go to the mongo shell | ||||
| 2. `use misskey` Use the misskey database | ||||
| 3. `db.users.save( {dummy:"dummy"} )` Write dummy data to initialize the db. | ||||
| 4. `db.createUser( { user: "misskey", pwd: "<password>", roles: [ { role: "readWrite", db: "misskey" } ] } )` Create the misskey user. | ||||
| 5. `exit` You're done ! | ||||
| 3. `db.createUser( { user: "misskey", pwd: "<password>", roles: [ { role: "readWrite", db: "misskey" } ] } )` Create the misskey user. | ||||
| 4. `exit` You're done! | ||||
|  | ||||
| *4.* Install Misskey | ||||
| ---------------------------------------------------------------- | ||||
| @@ -55,6 +55,11 @@ As root: | ||||
| *6.* Build Misskey | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| Before build, you need to set `NODE_ENV` to `production`. like this: | ||||
| * Linux: `export NODE_ENV=production` | ||||
| * Windows (PowerShell): `$env:NODE_ENV="production"` | ||||
| * Windows (CMD): `set NODE_ENV=production` | ||||
|  | ||||
| Build misskey with the following: | ||||
|  | ||||
| `npm run build` | ||||
|   | ||||
| @@ -29,15 +29,15 @@ Installez les paquets suivants : | ||||
| * [Redis](https://redis.io/) | ||||
|   * Redis est optionnel mais nous vous recommandons vivement de l'installer | ||||
| * [Elasticsearch](https://www.elastic.co/) - requis pour pouvoir activer la fonctionnalité de recherche | ||||
| * [FFmpeg](https://www.ffmpeg.org/) | ||||
|  | ||||
| *3.* Paramètrage de MongoDB | ||||
| ---------------------------------------------------------------- | ||||
| En root : | ||||
| 1. `mongo` Ouvrez le shell mongo | ||||
| 2. `use misskey` Utilisez la base de données misskey | ||||
| 3. `db.users.save( {dummy:"dummy"} )` Écrivez une donnée factice pour initialiser la base de données. | ||||
| 4. `db.createUser( { user: "misskey", pwd: "<password>", roles: [ { role: "readWrite", db: "misskey" } ] } )` Créez l'utilisateur misskey. | ||||
| 5. `exit` Vous avez terminé ! | ||||
| 3. `db.createUser( { user: "misskey", pwd: "<password>", roles: [ { role: "readWrite", db: "misskey" } ] } )` Créez l'utilisateur misskey. | ||||
| 4. `exit` Vous avez terminé ! | ||||
|  | ||||
| *4.* Installation de Misskey | ||||
| ---------------------------------------------------------------- | ||||
|   | ||||
| @@ -32,18 +32,19 @@ adduser --disabled-password --disabled-login misskey | ||||
| 	* 具体的には、Redisをインストールしないと、次の事が出来なくなります: | ||||
| 		* Misskeyプロセスを複数起動しての負荷分散 | ||||
| 		* レートリミット | ||||
| 		* ジョブキュー | ||||
| 		* Twitter連携 | ||||
| * [Elasticsearch](https://www.elastic.co/) | ||||
| 	* 検索機能を有効にするためにはインストールが必要です。 | ||||
| * [FFmpeg](https://www.ffmpeg.org/) | ||||
|  | ||||
| *3.* MongoDBの設定 | ||||
| ---------------------------------------------------------------- | ||||
| ルートで: | ||||
| 1. `mongo` mongoシェルを起動 | ||||
| 2. `use misskey` misskeyデータベースを使用 | ||||
| 3. `db.users.save( {dummy:"dummy"} )` ダミーデータを書き込みDBを初期化 | ||||
| 4. `db.createUser( { user: "misskey", pwd: "<password>", roles: [ { role: "readWrite", db: "misskey" } ] } )` misskeyユーザーを作成 | ||||
| 5. `exit` mongoシェルを終了 | ||||
| 3. `db.createUser( { user: "misskey", pwd: "<password>", roles: [ { role: "readWrite", db: "misskey" } ] } )` misskeyユーザーを作成 | ||||
| 4. `exit` mongoシェルを終了 | ||||
|  | ||||
| *4.* Misskeyのインストール | ||||
| ---------------------------------------------------------------- | ||||
| @@ -61,6 +62,11 @@ adduser --disabled-password --disabled-login misskey | ||||
| *6.* Misskeyのビルド | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| ビルドする前に、`NODE_ENV`を`production`にする必要があります。例: | ||||
| * Linux: `export NODE_ENV=production` | ||||
| * Windows (PowerShell): `$env:NODE_ENV="production"` | ||||
| * Windows (CMD): `set NODE_ENV=production` | ||||
|  | ||||
| 次のコマンドでMisskeyをビルドしてください: | ||||
|  | ||||
| `npm run build` | ||||
| @@ -116,6 +122,8 @@ CentOSで1024以下のポートを使用してMisskeyを使用する場合は`Ex | ||||
| 4. `npm run build` | ||||
| 5. [ChangeLog](../CHANGELOG.md)でマイグレーション情報を確認する | ||||
|  | ||||
| なにか問題が発生した場合は、`npm run clean`すると直る場合があります。 | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| なにかお困りのことがありましたらお気軽にご連絡ください。 | ||||
|   | ||||
							
								
								
									
										50
									
								
								gulpfile.ts
									
									
									
									
									
								
							
							
						
						
									
										50
									
								
								gulpfile.ts
									
									
									
									
									
								
							| @@ -32,14 +32,6 @@ if (isDebug) { | ||||
| 	console.warn(chalk.yellow.bold('         built script will not be compressed.')); | ||||
| } | ||||
|  | ||||
| gulp.task('build', [ | ||||
| 	'build:ts', | ||||
| 	'build:copy', | ||||
| 	'build:client', | ||||
| 	'locales', | ||||
| 	'doc' | ||||
| ]); | ||||
|  | ||||
| gulp.task('build:ts', () => { | ||||
| 	const tsProject = ts.createProject('./tsconfig.json'); | ||||
|  | ||||
| @@ -47,6 +39,7 @@ gulp.task('build:ts', () => { | ||||
| 		.src() | ||||
| 		.pipe(sourcemaps.init()) | ||||
| 		.pipe(tsProject()) | ||||
| 		.on('error', () => {}) | ||||
| 		.pipe(sourcemaps.write('.', { includeContent: false, sourceRoot: '../built' })) | ||||
| 		.pipe(gulp.dest('./built/')); | ||||
| }); | ||||
| @@ -55,7 +48,7 @@ gulp.task('build:copy:views', () => | ||||
| 	gulp.src('./src/server/web/views/**/*').pipe(gulp.dest('./built/server/web/views')) | ||||
| ); | ||||
|  | ||||
| gulp.task('build:copy', ['build:copy:views'], () => | ||||
| gulp.task('build:copy', gulp.parallel('build:copy:views', () => | ||||
| 	gulp.src([ | ||||
| 		'./build/Release/crypto_key.node', | ||||
| 		'./src/const.json', | ||||
| @@ -63,9 +56,7 @@ gulp.task('build:copy', ['build:copy:views'], () => | ||||
| 		'./src/**/assets/**/*', | ||||
| 		'!./src/client/app/**/assets/**/*' | ||||
| 	]).pipe(gulp.dest('./built/')) | ||||
| ); | ||||
|  | ||||
| gulp.task('test', ['mocha']); | ||||
| )); | ||||
|  | ||||
| gulp.task('lint', () => | ||||
| 	gulp.src('./src/**/*.ts') | ||||
| @@ -92,22 +83,15 @@ gulp.task('mocha', () => | ||||
| 		} as any)) | ||||
| ); | ||||
|  | ||||
| gulp.task('test', gulp.task('mocha')); | ||||
|  | ||||
| gulp.task('clean', cb => | ||||
| 	rimraf('./built', cb) | ||||
| ); | ||||
|  | ||||
| gulp.task('cleanall', ['clean'], cb => | ||||
| gulp.task('cleanall', gulp.parallel('clean', cb => | ||||
| 	rimraf('./node_modules', cb) | ||||
| ); | ||||
|  | ||||
| gulp.task('default', ['build']); | ||||
|  | ||||
| gulp.task('build:client', [ | ||||
| 	'build:ts', | ||||
| 	'build:client:script', | ||||
| 	'build:client:styles', | ||||
| 	'copy:client' | ||||
| ]); | ||||
| )); | ||||
|  | ||||
| gulp.task('build:client:script', () => { | ||||
| 	const client = require('./built/client/meta.json'); | ||||
| @@ -129,9 +113,7 @@ gulp.task('build:client:styles', () => | ||||
| 		.pipe(gulp.dest('./built/client/assets/')) | ||||
| ); | ||||
|  | ||||
| gulp.task('copy:client', [ | ||||
| 	'build:client:script' | ||||
| ], () => | ||||
| gulp.task('copy:client', () => | ||||
| 		gulp.src([ | ||||
| 			'./assets/**/*', | ||||
| 			'./src/client/assets/**/*', | ||||
| @@ -156,3 +138,19 @@ gulp.task('doc', () => | ||||
| 		.pipe((cssnano as any)()) | ||||
| 		.pipe(gulp.dest('./built/docs/assets/')) | ||||
| ); | ||||
|  | ||||
| gulp.task('build:client', gulp.parallel( | ||||
| 	'build:client:script', | ||||
| 	'build:client:styles', | ||||
| 	'copy:client' | ||||
| )); | ||||
|  | ||||
| gulp.task('build', gulp.parallel( | ||||
| 	'build:ts', | ||||
| 	'build:copy', | ||||
| 	'build:client', | ||||
| 	'locales', | ||||
| 	'doc' | ||||
| )); | ||||
|  | ||||
| gulp.task('default', gulp.task('build')); | ||||
|   | ||||
| @@ -113,6 +113,7 @@ common: | ||||
|   use-avatar-reversi-stones: "リバーシの石にアバターを使う" | ||||
|   verified-user: "公式アカウント" | ||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||
|   disable-showing-animated-images: "アニメーション画像を再生しない" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
| @@ -129,7 +130,7 @@ common: | ||||
|   show-password: "パスワードを表示する" | ||||
|   do-not-use-in-production: "これは開発ビルドです。本番環境で使用しないでください。" | ||||
|   user-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-user: "このユーザー情報は不正確な可能性があります。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|   renoted-by: "{user}がRenote" | ||||
| @@ -344,6 +345,8 @@ common/views/components/note-menu.vue: | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   unfavorite: "お気に入り解除" | ||||
|   watch: "ウォッチ" | ||||
|   unwatch: "ウォッチ解除" | ||||
|   pin: "ピン留め" | ||||
|   unpin: "ピン留め解除" | ||||
|   delete: "削除" | ||||
| @@ -357,10 +360,13 @@ common/views/components/user-menu.vue: | ||||
|   unblock: "ブロック解除" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
|   report-abuse: "スパムを報告" | ||||
|   report-abuse-detail: "どのような迷惑行為を行っていますか?" | ||||
|   report-abuse-reported: "管理者に報告されました。ご協力ありがとうございました。" | ||||
|   silence: "サイレンス" | ||||
|   unsilence: "サイレンス解除" | ||||
|   suspend: "凍結" | ||||
|   unsuspend: "凍結解除" | ||||
| common/views/components/poll.vue: | ||||
|   vote-to: "「{}」に投票する" | ||||
|   vote-count: "{}票" | ||||
| @@ -483,6 +489,7 @@ common/views/components/profile-editor.vue: | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   you-can-include-hashtags: "ハッシュタグを含めることができます。" | ||||
|   language: "言語" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
| @@ -502,6 +509,13 @@ common/views/components/profile-editor.vue: | ||||
|   email-address: "メールアドレス" | ||||
|   email-verified: "メールアドレスが確認されました" | ||||
|   email-not-verified: "メールアドレスが確認されていません。メールボックスをご確認ください。" | ||||
|   export: "エクスポート" | ||||
|   export-targets: | ||||
|     all-notes: "すべての投稿データ" | ||||
|     following-list: "フォロー" | ||||
|     mute-list: "ミュート" | ||||
|     blocking-list: "ブロック" | ||||
|   export-requested: "エクスポートをリクエストしました。これには時間がかかる場合があります。エクスポートが終わると、ドライブにファイルが追加されます。" | ||||
| common/views/components/user-list-editor.vue: | ||||
|   users: "ユーザー" | ||||
|   rename: "リスト名を変更" | ||||
| @@ -659,9 +673,6 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "フォルダーを作成" | ||||
|     upload: "ファイルをアップロード" | ||||
|     url-upload: "URLからアップロード" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -789,6 +800,8 @@ desktop/views/components/settings.vue: | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   keep-cw: "CW保持" | ||||
|   keep-cw-desc: "投稿にリプライする際、リプライ元の投稿にCWが設定されていたとき、デフォルトで同じCWを設定するようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "デザインと表示" | ||||
|   customize: "ホームをカスタマイズ" | ||||
| @@ -874,6 +887,9 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "設定が完了しました!" | ||||
|   failed: "設定に失敗しました。トークンに誤りがないかご確認ください。" | ||||
|   info: "次回サインインからは、同様にパスワードに加えてデバイスに表示されているトークンを入力します。" | ||||
| common/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
| @@ -991,6 +1007,7 @@ admin/views/index.vue: | ||||
|   announcements: "お知らせ" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   abuse: "スパム報告" | ||||
|   queue: "ジョブキュー" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
| @@ -1000,6 +1017,9 @@ admin/views/dashboard.vue: | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "このインスタンス" | ||||
|   federated: "連合" | ||||
| admin/views/queue.vue: | ||||
|   operation: "操作" | ||||
|   remove-all-jobs: "すべてのジョブをクリア" | ||||
| admin/views/abuse.vue: | ||||
|   title: "スパム報告" | ||||
|   target: "対象" | ||||
| @@ -1133,15 +1153,24 @@ admin/views/users.vue: | ||||
|   user-not-found: "ユーザーが見つかりません" | ||||
|   lookup: "照会" | ||||
|   reset-password: "パスワードをリセット" | ||||
|   reset-password-confirm: "パスワードをリセットしますか?" | ||||
|   password-updated: "パスワードは現在「{password}」です" | ||||
|   suspend: "凍結" | ||||
|   suspend-confirm: "凍結しますか?" | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspend-confirm: "凍結を解除しますか?" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   make-silence: "サイレンス" | ||||
|   unmake-silence: "サイレンスの解除" | ||||
|   verify: "公式アカウントにする" | ||||
|   verify-confirm: "公式アカウントにしますか?" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverify-confirm: "公式アカウントを解除しますか?" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|   update-remote-user: "リモートユーザー情報の更新" | ||||
|   remote-user-updated: "リモートユーザー情報を更新しました" | ||||
|   users: | ||||
|     title: "ユーザー" | ||||
|     sort: | ||||
| @@ -1157,6 +1186,7 @@ admin/views/users.vue: | ||||
|       moderator: "モデレーター" | ||||
|       adminOrModerator: "管理者+モデレーター" | ||||
|       verified: "公式アカウント" | ||||
|       silenced: "サイレンス済み" | ||||
|       suspended: "凍結済み" | ||||
|     origin: | ||||
|       title: "オリジン" | ||||
| @@ -1204,6 +1234,64 @@ admin/views/announcements.vue: | ||||
|     removed: "削除しました" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| admin/views/federation.vue: | ||||
|   federation: "連合" | ||||
|   host: "ホスト" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   following: "フォロー中" | ||||
|   followers: "フォロワー" | ||||
|   status: "ステータス" | ||||
|   latest-request-sent-at: "直近のリクエスト送信" | ||||
|   latest-request-received-at: "直近のリクエスト受信" | ||||
|   remove-all-following: "フォローを全解除" | ||||
|   remove-all-following-info: "{host}からのフォローをすべて解除します。そのインスタンスがもう存在しなくなった場合などに実行してください。" | ||||
|   block: "ブロック" | ||||
|   marked-as-closed: "閉鎖されているとマーク" | ||||
|   lookup: "照会" | ||||
|   instances: "インスタンス" | ||||
|   instance-not-registered: "そのインスタンスは登録されていません" | ||||
|   sort: "ソート" | ||||
|   sorts: | ||||
|     caughtAtAsc: "登録日時が古い順" | ||||
|     caughtAtDesc: "登録日時が新しい順" | ||||
|     lastCommunicatedAtAsc: "最後にやり取りした日時が古い順" | ||||
|     lastCommunicatedAtDesc: "最後にやり取りした日時が新しい順" | ||||
|     notesAsc: "投稿が少ない順" | ||||
|     notesDesc: "投稿が多い順" | ||||
|     usersAsc: "ユーザーが少ない順" | ||||
|     usersDesc: "ユーザーが多い順" | ||||
|     followingAsc: "フォローが少ない順" | ||||
|     followingDesc: "フォローが多い順" | ||||
|     followersAsc: "フォロワーが少ない順" | ||||
|     followersDesc: "フォロワーが多い順" | ||||
|     driveUsageAsc: "ドライブ使用量が少ない順" | ||||
|     driveUsageDesc: "ドライブ使用量が多い順" | ||||
|     driveFilesAsc: "ドライブのファイル数が少ない順" | ||||
|     driveFilesDesc: "ドライブのファイル数が多い順" | ||||
|   state: "状態" | ||||
|   states: | ||||
|     all: "すべて" | ||||
|     blocked: "ブロック" | ||||
|     not-responding: "応答なし" | ||||
|     marked-as-closed: "閉鎖とマーク済み" | ||||
|   result-is-truncated: "上位{n}件を表示しています。" | ||||
|   charts: "チャート" | ||||
|   chart-srcs: | ||||
|     requests: "リクエスト" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     notes: "投稿の増減" | ||||
|     notes-total: "投稿の積算" | ||||
|     ff: "フォロー/フォロワーの増減" | ||||
|     ff-total: "フォロー/フォロワーの積算" | ||||
|     drive-usage: "ドライブ使用量の増減" | ||||
|     drive-usage-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブファイル数の増減" | ||||
|     drive-files-total: "ドライブファイル数の積算" | ||||
|   chart-spans: | ||||
|     hour: "1時間ごと" | ||||
|     day: "1日ごと" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "詳しく..." | ||||
|   gotit: "わかった" | ||||
| @@ -1321,9 +1409,6 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   nsfw: "閲覧注意" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -1468,6 +1553,7 @@ mobile/views/pages/settings.vue: | ||||
|   notification-position-top: "上" | ||||
|   behavior: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   keep-cw: "CW保持" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
| @@ -1505,13 +1591,13 @@ mobile/views/pages/user/home.vue: | ||||
|   activity: "アクティビティ" | ||||
|   keywords: "キーワード" | ||||
|   domains: "頻出ドメイン" | ||||
|   frequently-replied-users: "よく会話するユーザー" | ||||
|   frequently-replied-users: "よく話すユーザー" | ||||
|   followers-you-know: "知り合いのフォロワー" | ||||
|   last-used-at: "最終ログイン" | ||||
| mobile/views/pages/user/home.followers-you-know.vue: | ||||
|   no-users: "知り合いのユーザーはいません" | ||||
| mobile/views/pages/user/home.friends.vue: | ||||
|   no-users: "よく会話するユーザーはいません" | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| mobile/views/pages/user/home.notes.vue: | ||||
|   no-notes: "投稿はありません" | ||||
| mobile/views/pages/user/home.photos.vue: | ||||
| @@ -1541,6 +1627,7 @@ deck/deck.tl-column.vue: | ||||
|   is-media-view: "メディアビュー" | ||||
|   edit: "オプション" | ||||
| deck/deck.user-column.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   | ||||
| @@ -5,7 +5,7 @@ meta: | ||||
| common: | ||||
|   misskey: "Ein ⭐ des Fediversums" | ||||
|   about-title: "Ein ⭐ des Fediversums." | ||||
|   about: "Misskeyを見つけていただき、ありがとうございます。Misskeyは、地球で生まれた<b>分散マイクロブログSNS</b>です。Fediverse(様々なSNSで構成される宇宙)の中に存在するため、他のSNSと相互に繋がっています。暫し都会の喧騒から離れて、新しいインターネットにダイブしてみませんか。" | ||||
|   about: "Danke, dass Du Misskey gefunden hast. Misskey ist eine <b>dezentralisierte Microblogging-Plattform</b>, welche auf der ganzen Welt verteilt ist. Da es innerhalb es Fediversums existiert (ein Universum, in dem verschiedene Soziale Netzwerke organisiert sind), ist es unmittelbar mit anderen sozialen Netzwerken verbunden. Warum nimmst du dir nicht einmal eine Auszeit von dem Trubel der Stadt und tauchst in das neue Internet hinein?" | ||||
|   intro: | ||||
|     title: "Was ist Misskey?" | ||||
|     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" | ||||
| @@ -25,9 +25,9 @@ common: | ||||
|   application-authorization: "Autorisierte Anwendungen" | ||||
|   close: "Schließen" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   load-more: "もっと読み込む" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   2fa: "二段階認証" | ||||
|   load-more: "Mehr laden" | ||||
|   enter-password: "Bitte Passwort eingeben" | ||||
|   2fa: "Zwei-Faktor-Authentifizierung" | ||||
|   got-it: "Verstanden!" | ||||
|   customization-tips: | ||||
|     title: "Anpassung-Tipps" | ||||
| @@ -54,8 +54,8 @@ common: | ||||
|     years_ago: "vor {} Jahr(en)" | ||||
|   month-and-day: "{day}/{month}" | ||||
|   trash: "Papierkorb" | ||||
|   drive: "ドライブ" | ||||
|   messaging: "トーク" | ||||
|   drive: "Drive" | ||||
|   messaging: "Unterhaltungen" | ||||
|   weekday-short: | ||||
|     sunday: "So" | ||||
|     monday: "Mo" | ||||
| @@ -91,9 +91,9 @@ common: | ||||
|     followers-desc: "Nur für diejenigen sichtbar, die dir folgen" | ||||
|     specified: "Direkt" | ||||
|     specified-desc: "Nur für bestimmte Benutzer posten" | ||||
|     local-public: "公開 (ローカルのみ)" | ||||
|     local-home: "ホーム (ローカルのみ)" | ||||
|     local-followers: "フォロワー (ローカルのみ)" | ||||
|     local-public: "Öffentlich (nur lokal)" | ||||
|     local-home: "Home (nur lokal)" | ||||
|     local-followers: "Follower (nur lokal)" | ||||
|   note-placeholders: | ||||
|     a: "Was machst du gerade?" | ||||
|     b: "Was ist so passiert?" | ||||
| @@ -113,6 +113,7 @@ common: | ||||
|   use-avatar-reversi-stones: "リバーシの石にアバターを使う" | ||||
|   verified-user: "Verifizierter Benutzer" | ||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||
|   disable-showing-animated-images: "アニメーション画像を再生しない" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
| @@ -129,7 +130,7 @@ common: | ||||
|   show-password: "パスワードを表示する" | ||||
|   do-not-use-in-production: "Dies ist eine Entwicklungsversion. Nicht in einer Produktionsumgebung verwenden." | ||||
|   user-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-user: "このユーザー情報は不正確な可能性があります。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|   renoted-by: "{user}がRenote" | ||||
| @@ -171,18 +172,18 @@ common: | ||||
|     hashtags: "Hashtags" | ||||
|   dev: "Fehler beim Erstellen der Applikation. Bitte versuche es erneut." | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
|   you: "あなた" | ||||
|   you: "Du" | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{name}</i>があなたのアカウントにアクセスすることを許可しますか?" | ||||
|   permission-ask: "このアプリは次の権限を要求しています:" | ||||
|   account-read: "アカウントの情報を見る。" | ||||
|   account-write: "アカウントの情報を操作する。" | ||||
|   share-access: "Erlaubst Du <i>{name}</i> auf deinen Account zuzugreifen?" | ||||
|   permission-ask: "Diese Applikation benötigt folgende Berechtigungen:" | ||||
|   account-read: "Accountinformationen anzeigen." | ||||
|   account-write: "Accountinformationen bearbeiten." | ||||
|   note-write: "Senden." | ||||
|   like-write: "いいねしたりいいね解除する。" | ||||
|   following-write: "フォローしたりフォロー解除する。" | ||||
|   like-write: "Auf Beiträge reagieren." | ||||
|   following-write: "Folgen oder entfolgen." | ||||
|   drive-read: "ドライブを見る。" | ||||
|   drive-write: "ドライブを操作する。" | ||||
|   notification-read: "通知を見る。" | ||||
|   notification-read: "Siehe deine Benachrichtigungen." | ||||
|   notification-write: "Benachrichtigungen verwalten." | ||||
|   cancel: "Abbrechen" | ||||
|   accept: "Zugriff erlauben." | ||||
| @@ -344,6 +345,8 @@ common/views/components/note-menu.vue: | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "Diese Notiz favorisieren" | ||||
|   unfavorite: "Aus Favoriten entfernen" | ||||
|   watch: "ウォッチ" | ||||
|   unwatch: "ウォッチ解除" | ||||
|   pin: "An die Profilseite pinnen" | ||||
|   unpin: "ピン留め解除" | ||||
|   delete: "Löschen" | ||||
| @@ -357,10 +360,13 @@ common/views/components/user-menu.vue: | ||||
|   unblock: "ブロック解除" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
|   report-abuse: "スパムを報告" | ||||
|   report-abuse-detail: "どのような迷惑行為を行っていますか?" | ||||
|   report-abuse-reported: "管理者に報告されました。ご協力ありがとうございました。" | ||||
|   silence: "サイレンス" | ||||
|   unsilence: "サイレンス解除" | ||||
|   suspend: "凍結" | ||||
|   unsuspend: "凍結解除" | ||||
| common/views/components/poll.vue: | ||||
|   vote-to: "Stimme für '{}'" | ||||
|   vote-count: "{} Stimmen" | ||||
| @@ -483,6 +489,7 @@ common/views/components/profile-editor.vue: | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   you-can-include-hashtags: "ハッシュタグを含めることができます。" | ||||
|   language: "言語" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
| @@ -502,6 +509,13 @@ common/views/components/profile-editor.vue: | ||||
|   email-address: "メールアドレス" | ||||
|   email-verified: "メールアドレスが確認されました" | ||||
|   email-not-verified: "メールアドレスが確認されていません。メールボックスをご確認ください。" | ||||
|   export: "エクスポート" | ||||
|   export-targets: | ||||
|     all-notes: "すべての投稿データ" | ||||
|     following-list: "フォロー" | ||||
|     mute-list: "ミュート" | ||||
|     blocking-list: "ブロック" | ||||
|   export-requested: "エクスポートをリクエストしました。これには時間がかかる場合があります。エクスポートが終わると、ドライブにファイルが追加されます。" | ||||
| common/views/components/user-list-editor.vue: | ||||
|   users: "ユーザー" | ||||
|   rename: "リスト名を変更" | ||||
| @@ -659,9 +673,6 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "Ein Verzeichnis erstellen" | ||||
|     upload: "Eine Datei hochladen" | ||||
|     url-upload: "Von einer URL hochladen" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -789,6 +800,8 @@ desktop/views/components/settings.vue: | ||||
|   auto-popout-desc: "Pop-out ein offenes Fenster wenn möglich. Diese Einstellung wird im Browser gespeichert." | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   keep-cw: "CW保持" | ||||
|   keep-cw-desc: "投稿にリプライする際、リプライ元の投稿にCWが設定されていたとき、デフォルトで同じCWを設定するようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "Erscheinungsbild und Anzeige" | ||||
|   customize: "Startseite anpassen" | ||||
| @@ -874,6 +887,9 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "設定が完了しました!" | ||||
|   failed: "設定に失敗しました。トークンに誤りがないかご確認ください。" | ||||
|   info: "次回サインインからは、同様にパスワードに加えてデバイスに表示されているトークンを入力します。" | ||||
| common/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
| @@ -991,6 +1007,7 @@ admin/views/index.vue: | ||||
|   announcements: "お知らせ" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   abuse: "スパム報告" | ||||
|   queue: "ジョブキュー" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
| @@ -1000,6 +1017,9 @@ admin/views/dashboard.vue: | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "このインスタンス" | ||||
|   federated: "連合" | ||||
| admin/views/queue.vue: | ||||
|   operation: "操作" | ||||
|   remove-all-jobs: "すべてのジョブをクリア" | ||||
| admin/views/abuse.vue: | ||||
|   title: "スパム報告" | ||||
|   target: "対象" | ||||
| @@ -1133,15 +1153,24 @@ admin/views/users.vue: | ||||
|   user-not-found: "ユーザーが見つかりません" | ||||
|   lookup: "照会" | ||||
|   reset-password: "パスワードをリセット" | ||||
|   reset-password-confirm: "パスワードをリセットしますか?" | ||||
|   password-updated: "パスワードは現在「{password}」です" | ||||
|   suspend: "凍結" | ||||
|   suspend-confirm: "凍結しますか?" | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspend-confirm: "凍結を解除しますか?" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   make-silence: "サイレンス" | ||||
|   unmake-silence: "サイレンスの解除" | ||||
|   verify: "公式アカウントにする" | ||||
|   verify-confirm: "公式アカウントにしますか?" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverify-confirm: "公式アカウントを解除しますか?" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|   update-remote-user: "リモートユーザー情報の更新" | ||||
|   remote-user-updated: "リモートユーザー情報を更新しました" | ||||
|   users: | ||||
|     title: "ユーザー" | ||||
|     sort: | ||||
| @@ -1157,6 +1186,7 @@ admin/views/users.vue: | ||||
|       moderator: "モデレーター" | ||||
|       adminOrModerator: "管理者+モデレーター" | ||||
|       verified: "公式アカウント" | ||||
|       silenced: "サイレンス済み" | ||||
|       suspended: "凍結済み" | ||||
|     origin: | ||||
|       title: "オリジン" | ||||
| @@ -1204,6 +1234,64 @@ admin/views/announcements.vue: | ||||
|     removed: "削除しました" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| admin/views/federation.vue: | ||||
|   federation: "連合" | ||||
|   host: "ホスト" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   following: "フォロー中" | ||||
|   followers: "フォロワー" | ||||
|   status: "ステータス" | ||||
|   latest-request-sent-at: "直近のリクエスト送信" | ||||
|   latest-request-received-at: "直近のリクエスト受信" | ||||
|   remove-all-following: "フォローを全解除" | ||||
|   remove-all-following-info: "{host}からのフォローをすべて解除します。そのインスタンスがもう存在しなくなった場合などに実行してください。" | ||||
|   block: "ブロック" | ||||
|   marked-as-closed: "閉鎖されているとマーク" | ||||
|   lookup: "照会" | ||||
|   instances: "インスタンス" | ||||
|   instance-not-registered: "そのインスタンスは登録されていません" | ||||
|   sort: "ソート" | ||||
|   sorts: | ||||
|     caughtAtAsc: "登録日時が古い順" | ||||
|     caughtAtDesc: "登録日時が新しい順" | ||||
|     lastCommunicatedAtAsc: "最後にやり取りした日時が古い順" | ||||
|     lastCommunicatedAtDesc: "最後にやり取りした日時が新しい順" | ||||
|     notesAsc: "投稿が少ない順" | ||||
|     notesDesc: "投稿が多い順" | ||||
|     usersAsc: "ユーザーが少ない順" | ||||
|     usersDesc: "ユーザーが多い順" | ||||
|     followingAsc: "フォローが少ない順" | ||||
|     followingDesc: "フォローが多い順" | ||||
|     followersAsc: "フォロワーが少ない順" | ||||
|     followersDesc: "フォロワーが多い順" | ||||
|     driveUsageAsc: "ドライブ使用量が少ない順" | ||||
|     driveUsageDesc: "ドライブ使用量が多い順" | ||||
|     driveFilesAsc: "ドライブのファイル数が少ない順" | ||||
|     driveFilesDesc: "ドライブのファイル数が多い順" | ||||
|   state: "状態" | ||||
|   states: | ||||
|     all: "すべて" | ||||
|     blocked: "ブロック" | ||||
|     not-responding: "応答なし" | ||||
|     marked-as-closed: "閉鎖とマーク済み" | ||||
|   result-is-truncated: "上位{n}件を表示しています。" | ||||
|   charts: "チャート" | ||||
|   chart-srcs: | ||||
|     requests: "リクエスト" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     notes: "投稿の増減" | ||||
|     notes-total: "投稿の積算" | ||||
|     ff: "フォロー/フォロワーの増減" | ||||
|     ff-total: "フォロー/フォロワーの積算" | ||||
|     drive-usage: "ドライブ使用量の増減" | ||||
|     drive-usage-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブファイル数の増減" | ||||
|     drive-files-total: "ドライブファイル数の積算" | ||||
|   chart-spans: | ||||
|     hour: "1時間ごと" | ||||
|     day: "1日ごと" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "詳しく..." | ||||
|   gotit: "わかった" | ||||
| @@ -1321,9 +1409,6 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   nsfw: "閲覧注意" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -1468,6 +1553,7 @@ mobile/views/pages/settings.vue: | ||||
|   notification-position-top: "上" | ||||
|   behavior: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   keep-cw: "CW保持" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
| @@ -1505,13 +1591,13 @@ mobile/views/pages/user/home.vue: | ||||
|   activity: "アクティビティ" | ||||
|   keywords: "Schlagwörter" | ||||
|   domains: "頻出ドメイン" | ||||
|   frequently-replied-users: "よく会話するユーザー" | ||||
|   frequently-replied-users: "よく話すユーザー" | ||||
|   followers-you-know: "知り合いのフォロワー" | ||||
|   last-used-at: "最終ログイン" | ||||
| mobile/views/pages/user/home.followers-you-know.vue: | ||||
|   no-users: "知り合いのユーザーはいません" | ||||
| mobile/views/pages/user/home.friends.vue: | ||||
|   no-users: "よく会話するユーザーはいません" | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| mobile/views/pages/user/home.notes.vue: | ||||
|   no-notes: "投稿はありません" | ||||
| mobile/views/pages/user/home.photos.vue: | ||||
| @@ -1541,6 +1627,7 @@ deck/deck.tl-column.vue: | ||||
|   is-media-view: "メディアビュー" | ||||
|   edit: "オプション" | ||||
| deck/deck.user-column.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   | ||||
| @@ -8,10 +8,10 @@ common: | ||||
|   about: "Thank you for finding Misskey. Misskey is a <b>decentralized microblogging platform</b> born on Earth. Since it exists within the Fediverse (a universe where various social media platforms are organized), it is mutually linked with other social media platforms. Why don't you take a short break from the hustle and bustle of the city, and dive into a new Internet?" | ||||
|   intro: | ||||
|     title: "What is Misskey?" | ||||
|     about: "Misskey is an open-source <b>decentralized microblogging service</b>. Sophisticated fully customizable UI, varieties of reactions for posts, free file storage providing an integrated management system and other advanced functions are available. In addition, Misskey connects to a network system called the “Fediverse” enables us to communicate with users on other SNSs. For example, when you post something it will be sent not only to Misskey but also Mastodon and Pleroma. Just imagine that the planet is sending a radio transmission to other planet to communicate." | ||||
|     about: "Misskey is an open-source, <b>decentralized microblogging service</b>. Sophisticated, fully customizable UI, varieties of reactions for posts, free file storage providing an integrated management system and other advanced features are available. In addition, Misskey connects to a network system called the “Fediverse”, that enables us to communicate with users on other SNSs. For example, when you post something, it will be sent not only to Misskey, but also to Mastodon, Osada and Pleroma. Just imagine that the planet is sending a radio transmission to another planet to communicate." | ||||
|     features: "Features" | ||||
|     rich-contents: "Post" | ||||
|     rich-contents-desc: "Just post your idea, hot topics and anything you want to share. You may want to decorate your words, attach your favorite pictures, send files including movies and create a poll - those are the things you can do on Misskey!" | ||||
|     rich-contents-desc: "Just post your idea, hot topics, and anything you want to share. You may want to decorate your words, attach your favorite pictures, send files, including videos, or create a poll - those are some of the things you can do with Misskey!" | ||||
|     reaction: "Reactions" | ||||
|     reaction-desc: "Easiest way to tell your emotions. Misskey allows you to add various type of reactions to other’s post. The emotional experience on Misskey will never be on other SNSs which only able to push “likes”." | ||||
|     ui: "Interface" | ||||
| @@ -113,6 +113,7 @@ common: | ||||
|   use-avatar-reversi-stones: "Use avatar as a stone in reversi" | ||||
|   verified-user: "Verified account" | ||||
|   disable-animated-mfm: "Disable animated texts in a post" | ||||
|   disable-showing-animated-images: "Do not play animated images" | ||||
|   suggest-recent-hashtags: "Suggest recently used hashtags within the post composition area" | ||||
|   always-show-nsfw: "Always show NSFW contents" | ||||
|   always-mark-nsfw: "Always mark posts with media attachments as NSFW" | ||||
| @@ -129,7 +130,7 @@ common: | ||||
|   show-password: "Show Password" | ||||
|   do-not-use-in-production: "This is a development build. Do not use in production." | ||||
|   user-suspended: "This user has been suspended." | ||||
|   is-remote-user: "This user's information is mirrored." | ||||
|   is-remote-user: "The information about this user may not be entirely complete." | ||||
|   is-remote-post: "These post contents are mirrored." | ||||
|   view-on-remote: "For completion, view it remotely." | ||||
|   renoted-by: "Renoted by {user}" | ||||
| @@ -344,6 +345,8 @@ common/views/components/note-menu.vue: | ||||
|   copy-link: "Copy link" | ||||
|   favorite: "Favorite this note" | ||||
|   unfavorite: "Unfavorite" | ||||
|   watch: "Watch" | ||||
|   unwatch: "Unwatch" | ||||
|   pin: "Pin to your profile" | ||||
|   unpin: "Unpin" | ||||
|   delete: "Delete" | ||||
| @@ -357,10 +360,13 @@ common/views/components/user-menu.vue: | ||||
|   unblock: "Unblock" | ||||
|   push-to-list: "Add to list" | ||||
|   select-list: "Select a list" | ||||
|   list-pushed: "Successfully added {user} to {list}." | ||||
|   report-abuse: "Report abuse" | ||||
|   report-abuse-detail: "どのような迷惑行為を行っていますか?" | ||||
|   report-abuse-reported: "管理者に報告されました。ご協力ありがとうございました。" | ||||
|   report-abuse-detail: "What kind of nuisance did you encounter?" | ||||
|   report-abuse-reported: "The issue has been reported to the administrator. Your cooperation is much appreciated." | ||||
|   silence: "Mute" | ||||
|   unsilence: "Unmute" | ||||
|   suspend: "Suspend" | ||||
|   unsuspend: "Unsuspend" | ||||
| common/views/components/poll.vue: | ||||
|   vote-to: "Vote for '{}'" | ||||
|   vote-count: "{} votes" | ||||
| @@ -483,6 +489,7 @@ common/views/components/profile-editor.vue: | ||||
|   account: "Account" | ||||
|   location: "Location" | ||||
|   description: "About me" | ||||
|   you-can-include-hashtags: "You can also include hashtags in your profile description." | ||||
|   language: "Language" | ||||
|   birthday: "Birthday" | ||||
|   avatar: "Icon" | ||||
| @@ -502,6 +509,13 @@ common/views/components/profile-editor.vue: | ||||
|   email-address: "Email Address" | ||||
|   email-verified: "Your email has been verified." | ||||
|   email-not-verified: "Email address is not confirmed. Please check your inbox." | ||||
|   export: "Export" | ||||
|   export-targets: | ||||
|     all-notes: "All posted Notes" | ||||
|     following-list: "List of followers" | ||||
|     mute-list: "List of muted accounts" | ||||
|     blocking-list: "List of blocked accounts" | ||||
|   export-requested: "You have requested an export. This may take a while. After the export is complete, the resulting file will be added to the drive." | ||||
| common/views/components/user-list-editor.vue: | ||||
|   users: "User" | ||||
|   rename: "Rename list" | ||||
| @@ -659,9 +673,6 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "Create a folder" | ||||
|     upload: "Upload a file" | ||||
|     url-upload: "Upload from a URL" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "NSFW" | ||||
|   click-to-show: "Click to show" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "The content is NSFW" | ||||
|   click-to-show: "Click to show" | ||||
| @@ -789,7 +800,9 @@ desktop/views/components/settings.vue: | ||||
|   auto-popout-desc: "If it's possible, pop-out display will be used instead of opening a new window. This setting is stored in your browser." | ||||
|   deck-nav: "Transitionless deck navigation" | ||||
|   deck-nav-desc: "You get a temporary column without page transitions during navigation when using the deck." | ||||
|   deck-default: "Use Deck as default UI" | ||||
|   keep-cw: "Preserve content warning" | ||||
|   keep-cw-desc: "When replying to a post, the same content warning is set by default to the reply, as has been set by the original post." | ||||
|   deck-default: "Use Deck view as the default UI" | ||||
|   display: "Design and display" | ||||
|   customize: "Customize home layout" | ||||
|   wallpaper: "Wallpaper" | ||||
| @@ -806,8 +819,8 @@ desktop/views/components/settings.vue: | ||||
|   timeline: "Timeline" | ||||
|   show-my-renotes: "Show my renotes in the timeline" | ||||
|   show-renoted-my-notes: "Show renoted posts of mine in timelines" | ||||
|   show-local-renotes: "Show renoted local posts in timelines" | ||||
|   show-maps: "Display a map to show the location" | ||||
|   show-local-renotes: "Show renoted local posts in the timelines" | ||||
|   show-maps: "Display a map to show location" | ||||
|   remain-deleted-note: "Continue to show deleted posts" | ||||
|   deck-column-align: "Deck column alignment" | ||||
|   deck-column-align-center: "Center" | ||||
| @@ -874,6 +887,9 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "Settings saved!" | ||||
|   failed: "Failed to setup. Please ensure that the token is correct." | ||||
|   info: "From the next time you sign in to Misskey, the token displayed on your device will be necessary too, as well as the password." | ||||
| common/views/components/media-image.vue: | ||||
|   sensitive: "NSFW" | ||||
|   click-to-show: "Click to show" | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "To access the API, set this token as the key 'i' of request parameters." | ||||
|   caution: "Do not enter this token to any apps nor tell this token to others otherwise your account may get compromised." | ||||
| @@ -991,6 +1007,7 @@ admin/views/index.vue: | ||||
|   announcements: "Announcements" | ||||
|   hashtags: "Hashtags" | ||||
|   abuse: "Abuse" | ||||
|   queue: "Job Queue" | ||||
|   back-to-misskey: "Back to Misskey" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "Dashboard" | ||||
| @@ -1000,6 +1017,9 @@ admin/views/dashboard.vue: | ||||
|   instances: "Instances" | ||||
|   this-instance: "This instance" | ||||
|   federated: "Federated" | ||||
| admin/views/queue.vue: | ||||
|   operation: "Action(s)" | ||||
|   remove-all-jobs: "Clear all queued jobs" | ||||
| admin/views/abuse.vue: | ||||
|   title: "Abuse" | ||||
|   target: "Target" | ||||
| @@ -1011,7 +1031,6 @@ admin/views/instance.vue: | ||||
|   instance-name: "Instance name" | ||||
|   instance-description: "Instance description" | ||||
|   host: "Host" | ||||
|   logo-url: "Logo image URL" | ||||
|   banner-url: "Banner image URL" | ||||
|   error-image-url: "Error image URL" | ||||
|   languages: "Language of this instance" | ||||
| @@ -1054,7 +1073,7 @@ admin/views/instance.vue: | ||||
|   disable-registration: "Disable new user registration" | ||||
|   disable-local-timeline: "Disable the Local Timeline" | ||||
|   disable-global-timeline: "Disable global timeline" | ||||
|   disabling-timelines-info: "これらのタイムラインを無効にしても、管理者およびモデレーターは引き続き利用できます。" | ||||
|   disabling-timelines-info: "Even if you disable these timelines, the administrator as well as moderators can use them continually." | ||||
|   invite: "Invite" | ||||
|   save: "Save" | ||||
|   saved: "Saved" | ||||
| @@ -1099,7 +1118,7 @@ admin/views/charts.vue: | ||||
|     users: "The number of users: increase/decrease" | ||||
|     users-total: "Total users" | ||||
|     active-users: "Active users" | ||||
|     drive: "Capacity used as the storage: increase/decrease" | ||||
|     drive: "Increase and decrease in storage capacity use" | ||||
|     drive-total: "Total usage of Drive" | ||||
|     drive-files: "The number of files on the storage: increase/decrease" | ||||
|     drive-files-total: "Total number of files on Drive" | ||||
| @@ -1126,23 +1145,32 @@ admin/views/drive.vue: | ||||
|   deleted: "Deleted successfully" | ||||
|   mark-as-sensitive: "Mark as 'sensitive'" | ||||
|   unmark-as-sensitive: "Unmark as 'sensitive'" | ||||
|   marked-as-sensitive: "閲覧注意に設定しました" | ||||
|   unmarked-as-sensitive: "閲覧注意を解除しました" | ||||
|   marked-as-sensitive: "Set a sensitive content notice" | ||||
|   unmarked-as-sensitive: "Remove the sensitive content notice" | ||||
| admin/views/users.vue: | ||||
|   operation: "Operations" | ||||
|   username-or-userid: "Username or user ID" | ||||
|   user-not-found: "User not found" | ||||
|   lookup: "Look up" | ||||
|   reset-password: "Reset password" | ||||
|   reset-password-confirm: "Do you want to reset your password?" | ||||
|   password-updated: "The password is now \"{password}\"" | ||||
|   suspend: "Suspend" | ||||
|   suspend-confirm: "Do you want to suspend this account?" | ||||
|   suspended: "Successfully suspended." | ||||
|   unsuspend: "Unsuspend" | ||||
|   unsuspend-confirm: "Are you sure you want to unsuspend this account?" | ||||
|   unsuspended: "The user has successfully unsuspended." | ||||
|   make-silence: "Mute" | ||||
|   unmake-silence: "Unmute" | ||||
|   verify: "Verify account" | ||||
|   verify-confirm: "Do you want this to be a verified account?" | ||||
|   verified: "The account is now being verified" | ||||
|   unverify: "Unverify account" | ||||
|   unverify-confirm: "Do you want to remove the 'verified account' designation?" | ||||
|   unverified: "The account is now being unverified" | ||||
|   update-remote-user: "Update information about remote user" | ||||
|   remote-user-updated: "The information regarding the remote user has been updated." | ||||
|   users: | ||||
|     title: "Users" | ||||
|     sort: | ||||
| @@ -1158,6 +1186,7 @@ admin/views/users.vue: | ||||
|       moderator: "Moderator" | ||||
|       adminOrModerator: "Admin/Moderator" | ||||
|       verified: "Verified account" | ||||
|       silenced: "Already silenced" | ||||
|       suspended: "Suspended" | ||||
|     origin: | ||||
|       title: "Origin" | ||||
| @@ -1205,6 +1234,64 @@ admin/views/announcements.vue: | ||||
|     removed: "Deleted" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| admin/views/federation.vue: | ||||
|   federation: "Federation" | ||||
|   host: "Host" | ||||
|   notes: "Notes" | ||||
|   users: "Users" | ||||
|   following: "Following" | ||||
|   followers: "Followers" | ||||
|   status: "Status" | ||||
|   latest-request-sent-at: "Time of last request sent" | ||||
|   latest-request-received-at: "Last request received at" | ||||
|   remove-all-following: "Withold all followers" | ||||
|   remove-all-following-info: "Unfollow all accounts from {host}. Please run this if the instance no longer exists." | ||||
|   block: "Block" | ||||
|   marked-as-closed: "Marked as closed" | ||||
|   lookup: "Look up" | ||||
|   instances: "Instances" | ||||
|   instance-not-registered: "The instance has not been discovered" | ||||
|   sort: "Sort by" | ||||
|   sorts: | ||||
|     caughtAtAsc: "Date of discovery (Ascending)" | ||||
|     caughtAtDesc: "Date of discovery (Descending)" | ||||
|     lastCommunicatedAtAsc: "The date and time of the older interactions" | ||||
|     lastCommunicatedAtDesc: "The date and time of the newer interactions" | ||||
|     notesAsc: "Order by least Notes posted" | ||||
|     notesDesc: "Order by most Notes posted" | ||||
|     usersAsc: "Less followers" | ||||
|     usersDesc: "More followers" | ||||
|     followingAsc: "Least followed" | ||||
|     followingDesc: "Has more followers" | ||||
|     followersAsc: "Sort by having less followers" | ||||
|     followersDesc: "Sort by the larger number of followers" | ||||
|     driveUsageAsc: "Least storage used" | ||||
|     driveUsageDesc: "Most storage used" | ||||
|     driveFilesAsc: "By the smallest number of files stored on Drive" | ||||
|     driveFilesDesc: "By the largest number of files stored on Drive" | ||||
|   state: "Status" | ||||
|   states: | ||||
|     all: "All" | ||||
|     blocked: "Blocked" | ||||
|     not-responding: "Without response" | ||||
|     marked-as-closed: "Marked as closed" | ||||
|   result-is-truncated: "Displaying the top {n} items." | ||||
|   charts: "Charts" | ||||
|   chart-srcs: | ||||
|     requests: "Requests" | ||||
|     users: "Increase, or decrease in the number of users" | ||||
|     users-total: "Total number of users" | ||||
|     notes: "Increase, or decrease in the number of notes" | ||||
|     notes-total: "Total number of notes" | ||||
|     ff: "Increase of followers" | ||||
|     ff-total: "Total number of follows accumulated" | ||||
|     drive-usage: "Increase and decrease in storage use" | ||||
|     drive-usage-total: "Total usage of the Drive" | ||||
|     drive-files: "Increase, or decrease in the number of files stored on Drive" | ||||
|     drive-files-total: "The number of files accumulated on Drive" | ||||
|   chart-spans: | ||||
|     hour: "Hourly" | ||||
|     day: "Daily" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "More details..." | ||||
|   gotit: "Got it!" | ||||
| @@ -1322,9 +1409,6 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   nsfw: "NSFW" | ||||
|   mark-as-sensitive: "Mark as 'sensitive'" | ||||
|   unmark-as-sensitive: "Unmark as 'sensitive'" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "NSFW" | ||||
|   click-to-show: "Click to show" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "The content is NSFW" | ||||
|   click-to-show: "Click to show" | ||||
| @@ -1469,6 +1553,7 @@ mobile/views/pages/settings.vue: | ||||
|   notification-position-top: "Top" | ||||
|   behavior: "Behavior" | ||||
|   fetch-on-scroll: "Endless loading on scroll" | ||||
|   keep-cw: "Preserve content warning" | ||||
|   note-visibility: "Post visibility" | ||||
|   default-note-visibility: "Default visibility" | ||||
|   remember-note-visibility: "Remember post visibility" | ||||
| @@ -1542,6 +1627,7 @@ deck/deck.tl-column.vue: | ||||
|   is-media-view: "Media view" | ||||
|   edit: "Options" | ||||
| deck/deck.user-column.vue: | ||||
|   follows-you: "Follows you" | ||||
|   posts: "Posts" | ||||
|   following: "Following" | ||||
|   followers: "Followers" | ||||
|   | ||||
| @@ -5,18 +5,18 @@ meta: | ||||
| common: | ||||
|   misskey: "Una ⭐️ del fediverso" | ||||
|   about-title: "Una ⭐️ del fediverso" | ||||
|   about: "Gracias por encontrae Misskey. Misskey es una <b>plataforma descentralizada de microblogging</b> nacida en la Tierra. Gracias a existir dentro del Fediverso (un universo donde se organizan varias plataformas sociales) se encuentra enlazada mutuamente con otras plataformas sociales. ¿Por què no te tomas un respiro del caos de la ciudad y te sumerges es una nueva manera de entender Internet?" | ||||
|   about: "Gracias por encontrar Misskey. Misskey es una <b>plataforma descentralizada de microblogging</b> nacida en la Tierra. Porque el servicio existe dentro del Fediverso (un universo donde se organizan varias plataformas sociales), se encuentra enlazado mutuamente con otras plataformas sociales. ¿Por qué no te tomas un respiro del caos de la ciudad y te sumerges es una nueva manera de entender Internet?" | ||||
|   intro: | ||||
|     title: "Misskeyって?" | ||||
|     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" | ||||
|     features: "特徴" | ||||
|     rich-contents: "投稿" | ||||
|     rich-contents-desc: "自分の考え、話題の出来事、皆と共有したいことについて発信してください。必要であれば、様々な構文を使って投稿を装飾したり、好きな画像、動画などのファイルやアンケートを添付することもできます。" | ||||
|     reaction: "リアクション" | ||||
|     title: "¿Misskey?" | ||||
|     about: "Misskey es un <b>Servicio de red social descentralizada de microblogging</b> de código abierto. Contiene una interfaz de usuario altamente personalizable, reacciones a posts, almacenamiento para poder manejar archivos y otras funciones avanzadas. Además de conectarse con la red llamada Fediverso, puede intercambiar mensajes con otras redes sociales. Por ejemplo, si contribuyes con algo, esa contribución es transmitida no sólo a Misskey sino a otras redes sociales. Imagina que se parece a transmitir una onda de radio de un planeta a otro." | ||||
|     features: "Características" | ||||
|     rich-contents: "Posts" | ||||
|     rich-contents-desc: "Escribe sobre tus pensamientos, eventos, todo lo que quieras compartir. Si es necesario, puedes usar varias sintaxis, decorar tus posts y añadir tus imágenes favoritas, archivos de viddeo y encuestas." | ||||
|     reaction: "Reacciones" | ||||
|     reaction-desc: "あなたの気持ちを伝える最も簡単な方法です。Misskeyは、他のユーザーの投稿に様々なリアクションを付けることができます。いちどMisskeyのリアクション機能を体験してしまうと、もう「いいね」の概念しか存在しないSNSには戻れなくなるかもしれません。" | ||||
|     ui: "インターフェース" | ||||
|     ui: "Interfaz" | ||||
|     ui-desc: "どのようなUIが使いやすいかは人それぞれです。だから、Misskeyは自由度の高いUIを持っています。レイアウトやデザインを調整したり、カスタマイズ可能な様々なウィジェットを配置したりして、自分だけのホームを作ってください。" | ||||
|     drive: "ドライブ" | ||||
|     drive: "Drive" | ||||
|     drive-desc: "以前投稿したことのある画像をまた投稿したくなったことはありませんか?もしくは、アップロードしたファイルをフォルダ分けして整理したくなったことはありませんか?Misskeyの根幹に組み込まれたドライブ機能によってそれらが解決します。ファイルの共有も簡単です。" | ||||
|     outro: "他にもMisskeyにしかない機能はまだまだあるので、ぜひあなた自身の目で確かめてください。Misskeyは分散型SNSなので、このインスタンスが気に入らなければ他のインスタンスを試すこともできます。それでは、GLHF!" | ||||
|   adblock: | ||||
| @@ -27,7 +27,7 @@ common: | ||||
|   do-not-copy-paste: "Por favor no copies código aquí. Tu cuenta puede resultar comprometida." | ||||
|   load-more: "もっと読み込む" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   2fa: "二段階認証" | ||||
|   2fa: "Autenticación de dos factores" | ||||
|   got-it: "¡Listo!" | ||||
|   customization-tips: | ||||
|     title: "Consejos de personalización" | ||||
| @@ -54,8 +54,8 @@ common: | ||||
|     years_ago: "Hace {} año(s)" | ||||
|   month-and-day: "{day} de {month}" | ||||
|   trash: "Papelera" | ||||
|   drive: "ドライブ" | ||||
|   messaging: "トーク" | ||||
|   drive: "Drive" | ||||
|   messaging: "Conversación" | ||||
|   weekday-short: | ||||
|     sunday: "domingo" | ||||
|     monday: "lunes" | ||||
| @@ -84,16 +84,16 @@ common: | ||||
|     rip: "RIP" | ||||
|     pudding: "Chafado" | ||||
|   note-visibility: | ||||
|     public: "公開" | ||||
|     home: "ホーム" | ||||
|     home-desc: "ホームタイムラインにのみ公開" | ||||
|     followers: "フォロワー" | ||||
|     followers-desc: "自分のフォロワーにのみ公開" | ||||
|     specified: "ダイレクト" | ||||
|     specified-desc: "指定したユーザーにのみ公開" | ||||
|     local-public: "公開 (ローカルのみ)" | ||||
|     local-home: "ホーム (ローカルのみ)" | ||||
|     local-followers: "フォロワー (ローカルのみ)" | ||||
|     public: "Público" | ||||
|     home: "Inicio" | ||||
|     home-desc: "Sólo en el timeline de inicio" | ||||
|     followers: "Seguidores" | ||||
|     followers-desc: "Sólo para tus seguidores" | ||||
|     specified: "Mensaje directo" | ||||
|     specified-desc: "Sólo para ciertos usuarios" | ||||
|     local-public: "Público (sólo local)" | ||||
|     local-home: "Inicio (sólo local)" | ||||
|     local-followers: "Seguidores (sólo local)" | ||||
|   note-placeholders: | ||||
|     a: "¿Qué haces?" | ||||
|     b: "¿Qué está pasando?" | ||||
| @@ -113,6 +113,7 @@ common: | ||||
|   use-avatar-reversi-stones: "リバーシの石にアバターを使う" | ||||
|   verified-user: "Cuenta verificada" | ||||
|   disable-animated-mfm: "Desactivar texto animado en una publicación" | ||||
|   disable-showing-animated-images: "アニメーション画像を再生しない" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
| @@ -122,14 +123,14 @@ common: | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   use-os-default-emojis: "OS標準の絵文字を使用" | ||||
|   line-width: "線の太さ" | ||||
|   line-width-thin: "細い" | ||||
|   line-width-thin: "Fino" | ||||
|   line-width-normal: "普通" | ||||
|   line-width-thick: "太い" | ||||
|   line-width-thick: "Grueso" | ||||
|   hide-password: "パスワードを隠す" | ||||
|   show-password: "パスワードを表示する" | ||||
|   do-not-use-in-production: "Esto está en desarrollo, no usarlo para producción." | ||||
|   user-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-user: "このユーザー情報は不正確な可能性があります。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|   renoted-by: "{user}がRenote" | ||||
| @@ -171,7 +172,7 @@ common: | ||||
|     hashtags: "Etiquetas" | ||||
|   dev: "アプリの作成に失敗しました。再度お試しください。" | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
|   you: "あなた" | ||||
|   you: "Tú" | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{name}</i>があなたのアカウントにアクセスすることを許可しますか?" | ||||
|   permission-ask: "La aplicación requiere los siguientes permisos:" | ||||
| @@ -267,48 +268,48 @@ common/views/components/media-banner.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| common/views/components/theme.vue: | ||||
|   theme: "テーマ" | ||||
|   theme: "Tema" | ||||
|   light-theme: "非ダークモード時に使用するテーマ" | ||||
|   dark-theme: "ダークモード時に使用するテーマ" | ||||
|   light-themes: "明るいテーマ" | ||||
|   dark-themes: "暗いテーマ" | ||||
|   install-a-theme: "テーマのインストール" | ||||
|   theme-code: "テーマコード" | ||||
|   install: "インストール" | ||||
|   light-themes: "Tema claro" | ||||
|   dark-themes: "Tema oscuro" | ||||
|   install-a-theme: "Instalar tema" | ||||
|   theme-code: "Código del tema" | ||||
|   install: "Instalación" | ||||
|   installed: "「{}」をインストールしました" | ||||
|   create-a-theme: "テーマの作成" | ||||
|   save-created-theme: "テーマを保存" | ||||
|   primary-color: "プライマリ カラー" | ||||
|   secondary-color: "セカンダリ カラー" | ||||
|   primary-color: "Color primario" | ||||
|   secondary-color: "Color secundario" | ||||
|   text-color: "文字色" | ||||
|   base-theme: "ベーステーマ" | ||||
|   base-theme-light: "Light" | ||||
|   base-theme-dark: "Dark" | ||||
|   base-theme: "Tema base" | ||||
|   base-theme-light: "Claro" | ||||
|   base-theme-dark: "Oscuro" | ||||
|   find-more-theme: "その他のテーマを入手" | ||||
|   theme-name: "テーマ名" | ||||
|   preview-created-theme: "プレビュー" | ||||
|   theme-name: "Nombre del tema" | ||||
|   preview-created-theme: "Vista previa" | ||||
|   invalid-theme: "テーマが正しくありません。" | ||||
|   already-installed: "既にそのテーマはインストールされています。" | ||||
|   saved: "保存しました" | ||||
|   manage-themes: "テーマの管理" | ||||
|   builtin-themes: "標準テーマ" | ||||
|   my-themes: "マイテーマ" | ||||
|   installed-themes: "インストールされたテーマ" | ||||
|   my-themes: "Mis temas" | ||||
|   installed-themes: "Temas instalados" | ||||
|   select-theme: "テーマを選択してください" | ||||
|   uninstall: "アンインストール" | ||||
|   uninstall: "Desinstalar" | ||||
|   uninstalled: "「{}」をアンインストールしました" | ||||
|   author: "作者" | ||||
|   desc: "説明" | ||||
|   export: "エクスポート" | ||||
|   import: "インポート" | ||||
|   export: "Exportar" | ||||
|   import: "Importar" | ||||
|   import-by-code: "またはコードをペースト" | ||||
|   theme-name-required: "テーマ名は必須です。" | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "隠す" | ||||
|   show: "もっと見る" | ||||
|   chars: "{count}文字" | ||||
|   files: "{count}ファイル" | ||||
|   poll: "アンケート" | ||||
|   show: "Mostrar" | ||||
|   chars: "{count} letras" | ||||
|   files: "{count} archivos" | ||||
|   poll: "Encuesta" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "Encuentra un usuario" | ||||
|   you: "Tu" | ||||
| @@ -338,29 +339,34 @@ common/views/components/nav.vue: | ||||
|   develop: "Desarrolladores" | ||||
|   feedback: "Opiniones" | ||||
| common/views/components/note-menu.vue: | ||||
|   mention: "メンション" | ||||
|   mention: "Menciones" | ||||
|   detail: "Detalles" | ||||
|   copy-content: "内容をコピー" | ||||
|   copy-link: "Copiar enlace" | ||||
|   favorite: "Me gusta esta nota" | ||||
|   unfavorite: "お気に入り解除" | ||||
|   watch: "ウォッチ" | ||||
|   unwatch: "ウォッチ解除" | ||||
|   pin: "Fijar en el perfil" | ||||
|   unpin: "ピン留め解除" | ||||
|   delete: "Borrar" | ||||
|   delete-confirm: "¿Seguro que quieres borrar la publicación?" | ||||
|   remote: "Ver el original" | ||||
| common/views/components/user-menu.vue: | ||||
|   mention: "メンション" | ||||
|   mute: "ミュート" | ||||
|   mention: "Menciones" | ||||
|   mute: "Silenciar" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロック" | ||||
|   block: "Bloquear" | ||||
|   unblock: "ブロック解除" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
|   report-abuse: "スパムを報告" | ||||
|   report-abuse-detail: "どのような迷惑行為を行っていますか?" | ||||
|   report-abuse-reported: "管理者に報告されました。ご協力ありがとうございました。" | ||||
|   silence: "サイレンス" | ||||
|   unsilence: "サイレンス解除" | ||||
|   suspend: "凍結" | ||||
|   unsuspend: "凍結解除" | ||||
| common/views/components/poll.vue: | ||||
|   vote-to: "'{}' para votar" | ||||
|   vote-count: "{} votos" | ||||
| @@ -377,15 +383,15 @@ common/views/components/poll-editor.vue: | ||||
| common/views/components/reaction-picker.vue: | ||||
|   choose-reaction: "Escoge una reacción" | ||||
| common/views/components/emoji-picker.vue: | ||||
|   custom-emoji: "カスタム絵文字" | ||||
|   people: "人" | ||||
|   animals-and-nature: "動物&自然" | ||||
|   food-and-drink: "食べ物&飲み物" | ||||
|   activity: "アクティビティ" | ||||
|   travel-and-places: "場所" | ||||
|   objects: "物" | ||||
|   symbols: "記号" | ||||
|   flags: "旗" | ||||
|   custom-emoji: "Personalizados" | ||||
|   people: "Gente" | ||||
|   animals-and-nature: "Naturaleza" | ||||
|   food-and-drink: "Comida y bebida" | ||||
|   activity: "Actividad" | ||||
|   travel-and-places: "Viajes y lugares" | ||||
|   objects: "Objetos" | ||||
|   symbols: "Símbolos" | ||||
|   flags: "Países" | ||||
| common/views/components/signin.vue: | ||||
|   username: "Usuario" | ||||
|   password: "Contraseña" | ||||
| @@ -394,8 +400,8 @@ common/views/components/signin.vue: | ||||
|   signin: "Entra" | ||||
|   or: "O" | ||||
|   signin-with-twitter: "Ingresar con Twitter" | ||||
|   signin-with-github: "GitHubでログイン" | ||||
|   signin-with-discord: "Discordでログイン" | ||||
|   signin-with-github: "Ingresar con Github" | ||||
|   signin-with-discord: "Ingresar con Discord" | ||||
|   login-failed: "Autenticación fallida. Asegúrate de haber usado el nombre de usuario y contraseña correctos." | ||||
| common/views/components/signup.vue: | ||||
|   invitation-code: "Código de invitación" | ||||
| @@ -478,17 +484,18 @@ common/views/components/language-settings.vue: | ||||
|   specify-language: "言語を指定" | ||||
|   info: "変更はページの再度読み込み後に反映されます。" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   title: "Perfil" | ||||
|   name: "Nombre" | ||||
|   account: "Cuenta" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   you-can-include-hashtags: "ハッシュタグを含めることができます。" | ||||
|   language: "言語" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   avatar: "Avatar" | ||||
|   banner: "Banner" | ||||
|   is-cat: "Esta cuenta es un gato" | ||||
|   is-bot: "Esta cuenta es un bot" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   careful-bot: "Botからのフォローだけ承認制にする" | ||||
|   auto-accept-followed: "フォローしているユーザーからのフォローを自動承認する" | ||||
| @@ -499,11 +506,18 @@ common/views/components/profile-editor.vue: | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
|   email: "メール設定" | ||||
|   email-address: "メールアドレス" | ||||
|   email-address: "Correo electrónico" | ||||
|   email-verified: "メールアドレスが確認されました" | ||||
|   email-not-verified: "メールアドレスが確認されていません。メールボックスをご確認ください。" | ||||
|   export: "エクスポート" | ||||
|   export-targets: | ||||
|     all-notes: "すべての投稿データ" | ||||
|     following-list: "フォロー" | ||||
|     mute-list: "ミュート" | ||||
|     blocking-list: "ブロック" | ||||
|   export-requested: "エクスポートをリクエストしました。これには時間がかかる場合があります。エクスポートが終わると、ドライブにファイルが追加されます。" | ||||
| common/views/components/user-list-editor.vue: | ||||
|   users: "ユーザー" | ||||
|   users: "Usuarios" | ||||
|   rename: "リスト名を変更" | ||||
|   delete: "リストを削除" | ||||
|   remove-user: "このリストから削除" | ||||
| @@ -568,7 +582,7 @@ common/views/pages/follow.vue: | ||||
|   following: "Siguiendo" | ||||
|   follow: "Seguir" | ||||
|   request-pending: "Solicitud pendiente" | ||||
|   follow-processing: "フォロー処理中" | ||||
|   follow-processing: "Solicitud en proceso" | ||||
|   follow-request: "Solicitar suscripción" | ||||
| desktop: | ||||
|   banner-crop-title: "Corta la parte que aparece como un banner" | ||||
| @@ -591,7 +605,7 @@ desktop/views/components/activity.vue: | ||||
|   title: "Actividad" | ||||
|   toggle: "Alternar vistas" | ||||
| desktop/views/components/calendar.vue: | ||||
|   title: "{year}年 {month}月" | ||||
|   title: "{year} / {month}" | ||||
|   prev: "Mes anterior" | ||||
|   next: "Próximo mes" | ||||
|   go: "Click para navegar" | ||||
| @@ -659,9 +673,6 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "Crear una carpeta" | ||||
|     upload: "Subir fichero" | ||||
|     url-upload: "Subir desde una URL" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "El contenido es NSFW (no seguro para ver en el trabajo, 'not safe for work')" | ||||
|   click-to-show: "Click para mostrar" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "Este contenido no es apropiado para ver en el trabajo" | ||||
|   click-to-show: "Click para mostrar" | ||||
| @@ -702,7 +713,7 @@ desktop/views/components/note-detail.vue: | ||||
| desktop/views/components/note.vue: | ||||
|   reply: "返信" | ||||
|   renote: "Renote" | ||||
|   add-reaction: "リアクション" | ||||
|   add-reaction: "Reacción" | ||||
|   undo-reaction: "リアクション解除" | ||||
|   detail: "詳細" | ||||
|   private: "この投稿は非公開です" | ||||
| @@ -760,23 +771,23 @@ desktop/views/components/renote-form.vue: | ||||
| desktop/views/components/renote-form-window.vue: | ||||
|   title: "¿Seguro qué quieres volver a publicarlo?" | ||||
| desktop/views/pages/user-following-or-followers.vue: | ||||
|   following: "{user}のフォロー" | ||||
|   followers: "{user}のフォロワー" | ||||
|   following: "{user} sigue a" | ||||
|   followers: "Seguidores de {user}" | ||||
| desktop/views/components/settings-window.vue: | ||||
|   settings: "Configuración" | ||||
| desktop/views/components/settings.vue: | ||||
|   profile: "Perfil" | ||||
|   notification: "Notificación" | ||||
|   apps: "Aplicaciones" | ||||
|   tags: "ハッシュタグ" | ||||
|   mute-and-block: "ミュート/ブロック" | ||||
|   blocking: "ブロック" | ||||
|   tags: "Hashtags" | ||||
|   mute-and-block: "Silenciar/Bloquear" | ||||
|   blocking: "Bloquear" | ||||
|   security: "Seguridad" | ||||
|   signin: "Historial de inicios de sesión" | ||||
|   password: "Contraseña" | ||||
|   other: "Otros" | ||||
|   license: "Licencia" | ||||
|   theme: "テーマ" | ||||
|   theme: "Tema" | ||||
|   behaviour: "Acciones" | ||||
|   fetch-on-scroll: "Desplazamiento infinito" | ||||
|   fetch-on-scroll-desc: "Cuando te deslizas al final de la página nuevo contenido se carga automáticamente." | ||||
| @@ -789,6 +800,8 @@ desktop/views/components/settings.vue: | ||||
|   auto-popout-desc: "Muestra una ventana emergente si es posible. Esta configuración depende del navegador." | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   keep-cw: "CW保持" | ||||
|   keep-cw-desc: "投稿にリプライする際、リプライ元の投稿にCWが設定されていたとき、デフォルトで同じCWを設定するようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "Diseño y pantalla" | ||||
|   customize: "Personaliza la página principal" | ||||
| @@ -811,30 +824,30 @@ desktop/views/components/settings.vue: | ||||
|   remain-deleted-note: "削除された投稿を表示し続ける" | ||||
|   deck-column-align: "デッキのカラムの配置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   deck-column-align-flexible: "フレキシブル" | ||||
|   deck-column-align-left: "Izquierda" | ||||
|   deck-column-align-flexible: "Flexible" | ||||
|   deck-column-width: "デッキのカラムの幅" | ||||
|   deck-column-width-narrow: "狭" | ||||
|   deck-column-width-narrower: "やや狭" | ||||
|   deck-column-width-normal: "普通" | ||||
|   deck-column-width-wider: "やや広" | ||||
|   deck-column-width-wide: "広" | ||||
|   sound: "サウンド" | ||||
|   sound: "Sonidos" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||
|   volume: "ボリューム" | ||||
|   test: "テスト" | ||||
|   cache: "キャッシュ" | ||||
|   clean-cache: "クリーンアップ" | ||||
|   volume: "Volúmen" | ||||
|   test: "Prueba" | ||||
|   cache: "Caché" | ||||
|   clean-cache: "Borrar caché" | ||||
|   cache-warn: "クリーンアップを行うと、ブラウザに記憶されたアカウント情報のキャッシュ、書きかけの投稿・返信・メッセージ、およびその他のデータ(設定情報含む)が削除されます。クリーンアップを行った後はページを再度読み込みする必要があります。" | ||||
|   cache-cleared: "キャッシュを削除しました" | ||||
|   cache-cleared-desc: "ページを再度読み込みしてください。" | ||||
|   about: "Misskeyについて" | ||||
|   operator: "このサーバーの運営者" | ||||
|   update: "Misskey Update" | ||||
|   version: "バージョン:" | ||||
|   latest-version: "最新のバージョン:" | ||||
|   update-checking: "アップデートを確認中" | ||||
|   update: "Actualizar Misskey" | ||||
|   version: "Versión" | ||||
|   latest-version: "Última versión" | ||||
|   update-checking: "Chequeando actualización" | ||||
|   do-update: "Chequear por actualizaciones" | ||||
|   update-settings: "Configuración avanzada" | ||||
|   prevent-update: "Posponer actualizaciones (no recomendado)" | ||||
| @@ -852,9 +865,9 @@ desktop/views/components/settings.vue: | ||||
|   task-manager: "Navegador de tareas" | ||||
|   third-parties: "Servicios externos" | ||||
|   navbar-position: "ナビゲーションバーの位置" | ||||
|   navbar-position-top: "上" | ||||
|   navbar-position-left: "左" | ||||
|   navbar-position-right: "右" | ||||
|   navbar-position-top: "Arriba" | ||||
|   navbar-position-left: "Izquierda" | ||||
|   navbar-position-right: "Derecha" | ||||
| desktop/views/components/settings.2fa.vue: | ||||
|   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" | ||||
|   detail: "Ver detalles..." | ||||
| @@ -867,13 +880,16 @@ desktop/views/components/settings.2fa.vue: | ||||
|   enter-password: "Escribe una contraseña" | ||||
|   authenticator: "Primero, necesitas instalar Google Authenticator en tu dispositivo:" | ||||
|   howtoinstall: "Cómo instalar" | ||||
|   token: "トークン" | ||||
|   token: "Token" | ||||
|   scan: "Luego, escanea el código QR:" | ||||
|   done: "Por favor ingresa el token mostrado en tu dispositivo:" | ||||
|   submit: "Enviar" | ||||
|   success: "¡Configuraciones guardadas!" | ||||
|   failed: "Error al configurar. Por favor asegúrate de que el token es correcto." | ||||
|   info: "Desde ahora, ingresa el token que se muestra en tu dispositivo adicionalmente a tu contraseña cuando inicies sesión en Misskey" | ||||
| common/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
| @@ -882,7 +898,7 @@ common/views/components/api-settings.vue: | ||||
|   token: "Token:" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   console: | ||||
|     title: "APIコンソール" | ||||
|     title: "Consola API" | ||||
|     endpoint: "エンドポイント" | ||||
|     parameter: "パラメータ" | ||||
|     credential-info: "「i」パラメータは自動で付与されます。" | ||||
| @@ -896,9 +912,9 @@ common/views/components/drive-settings.vue: | ||||
|   in-use: "使用中" | ||||
|   stats: "統計" | ||||
| common/views/components/mute-and-block.vue: | ||||
|   mute-and-block: "ミュートとブロック" | ||||
|   mute: "ミュート" | ||||
|   block: "ブロック" | ||||
|   mute-and-block: "Silenciar y bloquear" | ||||
|   mute: "Silenciar" | ||||
|   block: "Bloquear" | ||||
|   no-muted-users: "ミュートしているユーザーはいません" | ||||
|   no-blocked-users: "ブロックしているユーザーはいません" | ||||
|   word-mute: "ワードミュート" | ||||
| @@ -917,26 +933,26 @@ desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   media-count: "{}つのメディア" | ||||
|   poll: "アンケート" | ||||
|   poll: "Encuesta" | ||||
| desktop/views/components/settings.tags.vue: | ||||
|   title: "タグ" | ||||
|   title: "Etiqueta" | ||||
|   query: "クエリ (省略可)" | ||||
|   add: "追加" | ||||
|   save: "保存" | ||||
| desktop/views/components/taskmanager.vue: | ||||
|   title: "タスクマネージャ" | ||||
| desktop/views/components/timeline.vue: | ||||
|   home: "ホーム" | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   home: "Inicio" | ||||
|   local: "Local" | ||||
|   hybrid: "Social" | ||||
|   global: "Global" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
|   list: "リスト" | ||||
|   hashtag: "ハッシュタグ" | ||||
|   list: "Listas" | ||||
|   hashtag: "Hashtags" | ||||
|   add-tag-timeline: "ハッシュタグを追加" | ||||
|   add-list: "リストを追加" | ||||
|   list-name: "リスト名" | ||||
|   list-name: "Nombre de lista" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "Bienvenido/a de vuelta," | ||||
|   adjective: "-san" | ||||
| @@ -970,36 +986,40 @@ desktop/views/components/user-lists-window.vue: | ||||
|   list-name: "Nombre de lista" | ||||
| desktop/views/components/user-preview.vue: | ||||
|   notes: "Publicaciones" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   following: "Sigue" | ||||
|   followers: "Seguidores" | ||||
| desktop/views/components/users-list.vue: | ||||
|   all: "すべて" | ||||
|   all: "Todo" | ||||
|   iknow: "知り合い" | ||||
|   fetching: "読み込んでいます" | ||||
| desktop/views/components/users-list-item.vue: | ||||
|   followed: "フォローされています" | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "閉じる" | ||||
|   close: "Cerrar" | ||||
| admin/views/index.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   instance: "インスタンス" | ||||
|   dashboard: "Panel de control" | ||||
|   instance: "Instancia" | ||||
|   emoji: "カスタム絵文字" | ||||
|   moderators: "モデレーター" | ||||
|   users: "ユーザー" | ||||
|   moderators: "Moderadores" | ||||
|   users: "Usuarios" | ||||
|   federation: "連合" | ||||
|   announcements: "お知らせ" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   hashtags: "Hashtags" | ||||
|   abuse: "スパム報告" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
|   queue: "ジョブキュー" | ||||
|   back-to-misskey: "Volver a Misskey" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   accounts: "アカウント" | ||||
|   dashboard: "Panel de Control" | ||||
|   accounts: "Cuenta" | ||||
|   notes: "投稿" | ||||
|   drive: "ドライブ" | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "このインスタンス" | ||||
|   drive: "Drive" | ||||
|   instances: "Instancias" | ||||
|   this-instance: "Esta instancia" | ||||
|   federated: "連合" | ||||
| admin/views/queue.vue: | ||||
|   operation: "操作" | ||||
|   remove-all-jobs: "すべてのジョブをクリア" | ||||
| admin/views/abuse.vue: | ||||
|   title: "スパム報告" | ||||
|   target: "対象" | ||||
| @@ -1007,10 +1027,10 @@ admin/views/abuse.vue: | ||||
|   details: "詳細" | ||||
|   remove-report: "削除" | ||||
| admin/views/instance.vue: | ||||
|   instance: "インスタンス" | ||||
|   instance-name: "インスタンス名" | ||||
|   instance: "Instancia" | ||||
|   instance-name: "Nombre de la instancia" | ||||
|   instance-description: "インスタンスの紹介" | ||||
|   host: "ホスト" | ||||
|   host: "Host" | ||||
|   banner-url: "バナー画像URL" | ||||
|   error-image-url: "エラー画像URL" | ||||
|   languages: "インスタンスの対象言語" | ||||
| @@ -1028,7 +1048,7 @@ admin/views/instance.vue: | ||||
|   recaptcha-info: "reCAPTCHAを有効にする場合、reCAPTCHAトークンを取得する必要があります。https://www.google.com/recaptcha/intro/ にアクセスしてトークンを取得してください。" | ||||
|   enable-recaptcha: "reCAPTCHAを有効にする" | ||||
|   recaptcha-site-key: "reCAPTCHA site key" | ||||
|   recaptcha-secret-key: "reCAPTCHA secret key" | ||||
|   recaptcha-secret-key: "clave secreta reCAPTCHA" | ||||
|   twitter-integration-config: "Twitter連携の設定" | ||||
|   twitter-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-twitter-integration: "Twitter連携を有効にする" | ||||
| @@ -1061,7 +1081,7 @@ admin/views/instance.vue: | ||||
|   enable-external-user-recommendation: "外部ユーザーレコメンデーションを有効にする" | ||||
|   external-user-recommendation-engine: "エンジン" | ||||
|   external-user-recommendation-engine-desc: "例: https://vinayaka.distsn.org/cgi-bin/vinayaka-user-match-misskey-api.cgi?{{host}}+{{user}}+{{limit}}+{{offset}}" | ||||
|   external-user-recommendation-timeout: "タイムアウト" | ||||
|   external-user-recommendation-timeout: "Tiempo de espera" | ||||
|   external-user-recommendation-timeout-desc: "ミリ秒単位 (例: 300000)" | ||||
|   email-config: "メールサーバーの設定" | ||||
|   email-config-info: "メールアドレス確認やパスワードリセットの際に使われます。" | ||||
| @@ -1069,10 +1089,10 @@ admin/views/instance.vue: | ||||
|   email: "メールアドレス" | ||||
|   smtp-secure: "SMTP接続に暗黙的なSSL/TLSを使用する" | ||||
|   smtp-secure-info: "STARTTLS使用時はオフにします。" | ||||
|   smtp-host: "SMTPホスト" | ||||
|   smtp-port: "SMTPポート" | ||||
|   smtp-user: "SMTPユーザー" | ||||
|   smtp-pass: "SMTPパスワード" | ||||
|   smtp-host: "Host SMTP" | ||||
|   smtp-port: "Puerto SMTP" | ||||
|   smtp-user: "Usuario SMTP" | ||||
|   smtp-pass: "Contraseña SMTP" | ||||
|   serviceworker-config: "ServiceWorker" | ||||
|   enable-serviceworker: "ServiceWorkerを有効にする" | ||||
|   serviceworker-info: "プッシュ通知を行うには有効する必要があります。" | ||||
| @@ -1080,14 +1100,14 @@ admin/views/instance.vue: | ||||
|   vapid-privatekey: "VAPID秘密鍵" | ||||
|   vapid-info: "ServiceWorkerを有効にする場合、VAPIDキーペアを生成する必要があります。シェルで次のようにします:" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   title: "Gráficos" | ||||
|   per-day: "Por día" | ||||
|   per-hour: "Por hora" | ||||
|   federation: "Federación" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   users: "Usuarios" | ||||
|   drive: "Drive" | ||||
|   network: "Red" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
| @@ -1111,16 +1131,16 @@ admin/views/drive.vue: | ||||
|   file-not-found: "ファイルが見つかりません" | ||||
|   lookup: "照会" | ||||
|   sort: | ||||
|     title: "ソート" | ||||
|     title: "Ordenar" | ||||
|     createdAtAsc: "アップロード日時が古い順" | ||||
|     createdAtDesc: "アップロード日時が新しい順" | ||||
|     sizeAsc: "サイズが小さい順" | ||||
|     sizeDesc: "サイズが大きい順" | ||||
|   origin: | ||||
|     title: "オリジン" | ||||
|     combined: "ローカル+リモート" | ||||
|     local: "ローカル" | ||||
|     remote: "リモート" | ||||
|     combined: "Local+Remoto" | ||||
|     local: "Local" | ||||
|     remote: "Remoto" | ||||
|   delete: "削除" | ||||
|   deleted: "削除しました" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
| @@ -1133,15 +1153,24 @@ admin/views/users.vue: | ||||
|   user-not-found: "ユーザーが見つかりません" | ||||
|   lookup: "照会" | ||||
|   reset-password: "パスワードをリセット" | ||||
|   reset-password-confirm: "パスワードをリセットしますか?" | ||||
|   password-updated: "パスワードは現在「{password}」です" | ||||
|   suspend: "凍結" | ||||
|   suspend-confirm: "凍結しますか?" | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspend-confirm: "凍結を解除しますか?" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   make-silence: "サイレンス" | ||||
|   unmake-silence: "サイレンスの解除" | ||||
|   verify: "公式アカウントにする" | ||||
|   verify-confirm: "公式アカウントにしますか?" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverify-confirm: "公式アカウントを解除しますか?" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|   update-remote-user: "リモートユーザー情報の更新" | ||||
|   remote-user-updated: "リモートユーザー情報を更新しました" | ||||
|   users: | ||||
|     title: "ユーザー" | ||||
|     sort: | ||||
| @@ -1157,6 +1186,7 @@ admin/views/users.vue: | ||||
|       moderator: "モデレーター" | ||||
|       adminOrModerator: "管理者+モデレーター" | ||||
|       verified: "公式アカウント" | ||||
|       silenced: "サイレンス済み" | ||||
|       suspended: "凍結済み" | ||||
|     origin: | ||||
|       title: "オリジン" | ||||
| @@ -1204,6 +1234,64 @@ admin/views/announcements.vue: | ||||
|     removed: "削除しました" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| admin/views/federation.vue: | ||||
|   federation: "連合" | ||||
|   host: "ホスト" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   following: "フォロー中" | ||||
|   followers: "フォロワー" | ||||
|   status: "ステータス" | ||||
|   latest-request-sent-at: "直近のリクエスト送信" | ||||
|   latest-request-received-at: "直近のリクエスト受信" | ||||
|   remove-all-following: "フォローを全解除" | ||||
|   remove-all-following-info: "{host}からのフォローをすべて解除します。そのインスタンスがもう存在しなくなった場合などに実行してください。" | ||||
|   block: "ブロック" | ||||
|   marked-as-closed: "閉鎖されているとマーク" | ||||
|   lookup: "照会" | ||||
|   instances: "インスタンス" | ||||
|   instance-not-registered: "そのインスタンスは登録されていません" | ||||
|   sort: "ソート" | ||||
|   sorts: | ||||
|     caughtAtAsc: "登録日時が古い順" | ||||
|     caughtAtDesc: "登録日時が新しい順" | ||||
|     lastCommunicatedAtAsc: "最後にやり取りした日時が古い順" | ||||
|     lastCommunicatedAtDesc: "最後にやり取りした日時が新しい順" | ||||
|     notesAsc: "投稿が少ない順" | ||||
|     notesDesc: "投稿が多い順" | ||||
|     usersAsc: "ユーザーが少ない順" | ||||
|     usersDesc: "ユーザーが多い順" | ||||
|     followingAsc: "フォローが少ない順" | ||||
|     followingDesc: "フォローが多い順" | ||||
|     followersAsc: "フォロワーが少ない順" | ||||
|     followersDesc: "フォロワーが多い順" | ||||
|     driveUsageAsc: "ドライブ使用量が少ない順" | ||||
|     driveUsageDesc: "ドライブ使用量が多い順" | ||||
|     driveFilesAsc: "ドライブのファイル数が少ない順" | ||||
|     driveFilesDesc: "ドライブのファイル数が多い順" | ||||
|   state: "状態" | ||||
|   states: | ||||
|     all: "すべて" | ||||
|     blocked: "ブロック" | ||||
|     not-responding: "応答なし" | ||||
|     marked-as-closed: "閉鎖とマーク済み" | ||||
|   result-is-truncated: "上位{n}件を表示しています。" | ||||
|   charts: "チャート" | ||||
|   chart-srcs: | ||||
|     requests: "リクエスト" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     notes: "投稿の増減" | ||||
|     notes-total: "投稿の積算" | ||||
|     ff: "フォロー/フォロワーの増減" | ||||
|     ff-total: "フォロー/フォロワーの積算" | ||||
|     drive-usage: "ドライブ使用量の増減" | ||||
|     drive-usage-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブファイル数の増減" | ||||
|     drive-files-total: "ドライブファイル数の積算" | ||||
|   chart-spans: | ||||
|     hour: "1時間ごと" | ||||
|     day: "1日ごと" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "詳しく..." | ||||
|   gotit: "わかった" | ||||
| @@ -1321,9 +1409,6 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   nsfw: "閲覧注意" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -1468,6 +1553,7 @@ mobile/views/pages/settings.vue: | ||||
|   notification-position-top: "上" | ||||
|   behavior: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   keep-cw: "CW保持" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
| @@ -1505,13 +1591,13 @@ mobile/views/pages/user/home.vue: | ||||
|   activity: "アクティビティ" | ||||
|   keywords: "キーワード" | ||||
|   domains: "頻出ドメイン" | ||||
|   frequently-replied-users: "よく会話するユーザー" | ||||
|   frequently-replied-users: "よく話すユーザー" | ||||
|   followers-you-know: "知り合いのフォロワー" | ||||
|   last-used-at: "最終ログイン" | ||||
| mobile/views/pages/user/home.followers-you-know.vue: | ||||
|   no-users: "知り合いのユーザーはいません" | ||||
| mobile/views/pages/user/home.friends.vue: | ||||
|   no-users: "よく会話するユーザーはいません" | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| mobile/views/pages/user/home.notes.vue: | ||||
|   no-notes: "投稿はありません" | ||||
| mobile/views/pages/user/home.photos.vue: | ||||
| @@ -1541,6 +1627,7 @@ deck/deck.tl-column.vue: | ||||
|   is-media-view: "メディアビュー" | ||||
|   edit: "オプション" | ||||
| deck/deck.user-column.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   | ||||
| @@ -113,6 +113,7 @@ common: | ||||
|   use-avatar-reversi-stones: "Utiliser l’avatar comme pion dans Reversi" | ||||
|   verified-user: "Compte vérifié" | ||||
|   disable-animated-mfm: "Désactiver les textes animés dans les publications" | ||||
|   disable-showing-animated-images: "アニメーション画像を再生しない" | ||||
|   suggest-recent-hashtags: "Suggérer les hashtags récemment utilisés dans le champs de saisie" | ||||
|   always-show-nsfw: "Toujours afficher les contenus sensibles" | ||||
|   always-mark-nsfw: "Toujours marquer les notes ayant des attachements comme sensibles" | ||||
| @@ -129,7 +130,7 @@ common: | ||||
|   show-password: "Afficher le mot de passe" | ||||
|   do-not-use-in-production: "Il s’agit d’une version de développement. Ne pas utiliser dans un environnement de production." | ||||
|   user-suspended: "Cet·te utilisateur·trice a été suspendu·e" | ||||
|   is-remote-user: "Ces informations appartiennent à un utilisateur distant." | ||||
|   is-remote-user: "このユーザー情報は不正確な可能性があります。" | ||||
|   is-remote-post: "Ceci est une publication distante." | ||||
|   view-on-remote: " Consulter le profil complet" | ||||
|   renoted-by: "Renoté par {user}" | ||||
| @@ -333,7 +334,7 @@ common/views/components/nav.vue: | ||||
|   stats: "Statistiques" | ||||
|   status: "Statut" | ||||
|   wiki: "Wiki" | ||||
|   donors: "Donateurs" | ||||
|   donors: "Donateur·rice·s" | ||||
|   repository: "Dépôt" | ||||
|   develop: "Développeurs" | ||||
|   feedback: "Suggestions" | ||||
| @@ -344,27 +345,32 @@ common/views/components/note-menu.vue: | ||||
|   copy-link: "Copier le lien" | ||||
|   favorite: "Mettre cette note en favoris" | ||||
|   unfavorite: "Retirer des favoris" | ||||
|   watch: "Surveiller" | ||||
|   unwatch: "Ne plus surveiller" | ||||
|   pin: "Épingler sur votre profil" | ||||
|   unpin: "Désépingler" | ||||
|   delete: "Supprimer" | ||||
|   delete-confirm: "Supprimer cette publication ?" | ||||
|   remote: "Afficher la note originale" | ||||
| common/views/components/user-menu.vue: | ||||
|   mention: "メンション" | ||||
|   mute: "ミュート" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
|   report-abuse: "スパムを報告" | ||||
|   report-abuse-detail: "どのような迷惑行為を行っていますか?" | ||||
|   report-abuse-reported: "管理者に報告されました。ご協力ありがとうございました。" | ||||
|   mention: "Mention" | ||||
|   mute: "Silencier" | ||||
|   unmute: "Enlever la sourdine" | ||||
|   block: "Bloquer" | ||||
|   unblock: "Débloquer" | ||||
|   push-to-list: "Ajouter à une liste" | ||||
|   select-list: "Sélectionnez une liste" | ||||
|   report-abuse: "Signaler un abus" | ||||
|   report-abuse-detail: "Détail du signalement" | ||||
|   report-abuse-reported: "Transmit à l’administrateur. Merci de votre collaboration." | ||||
|   silence: "Mettre en sourdine" | ||||
|   unsilence: "Enlever la sourdine" | ||||
|   suspend: "Suspendre" | ||||
|   unsuspend: "Ne plus suspendre" | ||||
| common/views/components/poll.vue: | ||||
|   vote-to: "Voter pour '{}'" | ||||
|   vote-count: "{} votes" | ||||
|   total-users: "{} utilisateurs ont voté" | ||||
|   total-users: "{} utilisateur·rice·s ont voté" | ||||
|   vote: "Vote" | ||||
|   show-result: "Montrer les résultats" | ||||
|   voted: "Voté" | ||||
| @@ -387,7 +393,7 @@ common/views/components/emoji-picker.vue: | ||||
|   symbols: "Symboles" | ||||
|   flags: "Drapeaux" | ||||
| common/views/components/signin.vue: | ||||
|   username: "Nom d'utilisateur" | ||||
|   username: "Nom d'utilisateur·rice" | ||||
|   password: "Mot de passe" | ||||
|   token: "Jeton" | ||||
|   signing-in: "Connexion…" | ||||
| @@ -400,7 +406,7 @@ common/views/components/signin.vue: | ||||
| common/views/components/signup.vue: | ||||
|   invitation-code: "Code d’invitation" | ||||
|   invitation-info: "Si vous n’avez pas de code d’invitation, contactez un <a href=\"{}\">administrateur</a>." | ||||
|   username: "Nom d'utilisateur" | ||||
|   username: "Nom d'utilisateur·rice" | ||||
|   checking: "Vérification…" | ||||
|   available: "Disponible" | ||||
|   unavailable: "Non disponible" | ||||
| @@ -433,7 +439,7 @@ common/views/components/notification-settings.vue: | ||||
|   mark-as-read-all-unread-notes: "Marquer toutes les notes comme lues" | ||||
|   mark-as-read-all-talk-messages: "Marquer toutes les conversations comme lues" | ||||
|   auto-watch: "投稿の自動ウォッチ" | ||||
|   auto-watch-desc: "リアクションしたり返信したりした投稿に関する通知を自動的に受け取るようにします。" | ||||
|   auto-watch-desc: "Recevoir automatiquement des notifications à propos des publications auxquelles vous avez réagi ou répondu" | ||||
| common/views/components/integration-settings.vue: | ||||
|   title: "Intégrations" | ||||
|   connect: "Connecter" | ||||
| @@ -459,8 +465,8 @@ common/views/components/visibility-chooser.vue: | ||||
|   public: "Public" | ||||
|   home: "Accueil" | ||||
|   home-desc: "Publier sur le fil d’Accueil uniquement" | ||||
|   followers: "Abonnés" | ||||
|   followers-desc: "Publier à vos abonnés uniquement" | ||||
|   followers: "Abonné·e·s" | ||||
|   followers-desc: "Publier à vos abonné·e·s uniquement" | ||||
|   specified: "Direct" | ||||
|   specified-desc: "Publier uniquement aux utilisateurs mentionnés" | ||||
|   local-public: "Local (Public)" | ||||
| @@ -483,6 +489,7 @@ common/views/components/profile-editor.vue: | ||||
|   account: "Compte" | ||||
|   location: "Lieu" | ||||
|   description: "À propos de moi" | ||||
|   you-can-include-hashtags: "Vous pouvez également inclure un hashtag sur votre description de profile." | ||||
|   language: "Langue" | ||||
|   birthday: "Date de naissance" | ||||
|   avatar: "Avatar" | ||||
| @@ -491,7 +498,7 @@ common/views/components/profile-editor.vue: | ||||
|   is-bot: "Ce compte est un Bot" | ||||
|   is-locked: "Demandes d’abonnements requièrent l’approbation" | ||||
|   careful-bot: "Les demandes d’abonnements venant de Bots requièrent l’approbation" | ||||
|   auto-accept-followed: "フォローしているユーザーからのフォローを自動承認する" | ||||
|   auto-accept-followed: "Accepter automatiquement les demandes d’abonnement venant des gens que vous suivez" | ||||
|   advanced: "Avancé" | ||||
|   privacy: "Vie privée" | ||||
|   save: "Mettre à jour le profil" | ||||
| @@ -502,8 +509,15 @@ common/views/components/profile-editor.vue: | ||||
|   email-address: "Adresse de courrier électronique" | ||||
|   email-verified: "L’adresse du courrier électronique a été vérifiée." | ||||
|   email-not-verified: "Adresse de courriel n’est pas confirmée. Veuillez vérifier votre boite de réception." | ||||
|   export: "Exporter" | ||||
|   export-targets: | ||||
|     all-notes: "Toutes les notes publiées" | ||||
|     following-list: "Liste des abonnements" | ||||
|     mute-list: "Liste des comptes mis en sourdine" | ||||
|     blocking-list: "Liste des comptes bloqués" | ||||
|   export-requested: "エクスポートをリクエストしました。これには時間がかかる場合があります。エクスポートが終わると、ドライブにファイルが追加されます。" | ||||
| common/views/components/user-list-editor.vue: | ||||
|   users: "Utilisateur" | ||||
|   users: "Utilisateur·rice" | ||||
|   rename: "Renommer la liste" | ||||
|   delete: "Supprimer la liste" | ||||
|   remove-user: "Retirer de cette liste" | ||||
| @@ -659,23 +673,20 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "Créer un dossier" | ||||
|     upload: "Téléverser un fichier" | ||||
|     url-upload: "Téléverser à partir d’une URL" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "Le contenu est NSFW" | ||||
|   click-to-show: "Cliquer pour afficher" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "Le contenu est NSFW" | ||||
|   click-to-show: "Cliquer pour afficher" | ||||
| desktop/views/components/followers-window.vue: | ||||
|   followers: "{} abonnés" | ||||
|   followers: "{} abonné·e·s" | ||||
| desktop/views/components/followers.vue: | ||||
|   empty: "Il semble que vous n'avez pas encore d'abonnés." | ||||
|   empty: "Il semble que vous n’avez pas encore d’abonné·e·s." | ||||
| desktop/views/components/following-window.vue: | ||||
|   following: "Suit {}" | ||||
| desktop/views/components/following.vue: | ||||
|   empty: "Vous ne suivez aucun compte." | ||||
| desktop/views/components/friends-maker.vue: | ||||
|   title: "Utilisateurs recommandés :" | ||||
|   empty: "Impossible de trouver des utilisateurs à recommander." | ||||
|   title: "Utilisateur·rice·s recommandé·e·s :" | ||||
|   empty: "Impossible de trouver des utilisateur·trice·s à recommander." | ||||
|   fetching: "Chargement" | ||||
|   refresh: "Plus" | ||||
|   close: "Fermer" | ||||
| @@ -789,6 +800,8 @@ desktop/views/components/settings.vue: | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   deck-nav: "Deck sans tansitions" | ||||
|   deck-nav-desc: "Vous obtenez une colonne temporaire sans transitions dans la page pendant la navigation, lors de l’utilisation du Deck." | ||||
|   keep-cw: "Maintenir l'avertissement de contenu" | ||||
|   keep-cw-desc: "投稿にリプライする際、リプライ元の投稿にCWが設定されていたとき、デフォルトで同じCWを設定するようにします。" | ||||
|   deck-default: "Utiliser le Deck comme IU par défaut" | ||||
|   display: "Affichage et design" | ||||
|   customize: "Personnaliser l'Accueil" | ||||
| @@ -874,6 +887,9 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "Sauvegarde des paramètres avec succès !" | ||||
|   failed: "L’opération a échoué. Veuillez vous assurer que le jeton a été saisi correctement." | ||||
|   info: "À partir de maintenant, à chaque fois que vous vous connectez entrez votre mot de passe ainsi que le jeton généré sur votre appareil." | ||||
| common/views/components/media-image.vue: | ||||
|   sensitive: "Contenu sensible" | ||||
|   click-to-show: "Cliquer pour afficher" | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "Pour accéder à l'API, définissez ce jeton comme la clé de « i » dans les paramètres de requête." | ||||
|   caution: "Merci de ne pas introduire ce jeton dans aucune application ou le divulguer à quiconque. Ceci risque de compromettre votre compte." | ||||
| @@ -971,7 +987,7 @@ desktop/views/components/user-lists-window.vue: | ||||
| desktop/views/components/user-preview.vue: | ||||
|   notes: "Publications" | ||||
|   following: "Abonné à" | ||||
|   followers: "Abonnés" | ||||
|   followers: "Abonné·e·s" | ||||
| desktop/views/components/users-list.vue: | ||||
|   all: "Tout" | ||||
|   iknow: "Vous connaissez" | ||||
| @@ -990,7 +1006,8 @@ admin/views/index.vue: | ||||
|   federation: "Fédération" | ||||
|   announcements: "Annonces" | ||||
|   hashtags: "Hashtags" | ||||
|   abuse: "スパム報告" | ||||
|   abuse: "Abus" | ||||
|   queue: "File d’attente" | ||||
|   back-to-misskey: "Retour vers Misskey" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "Tableau de bord" | ||||
| @@ -1000,12 +1017,15 @@ admin/views/dashboard.vue: | ||||
|   instances: "Instances" | ||||
|   this-instance: "Cette instance" | ||||
|   federated: "Fédérées" | ||||
| admin/views/queue.vue: | ||||
|   operation: "Action(s)" | ||||
|   remove-all-jobs: "すべてのジョブをクリア" | ||||
| admin/views/abuse.vue: | ||||
|   title: "スパム報告" | ||||
|   target: "対象" | ||||
|   reporter: "報告者" | ||||
|   details: "詳細" | ||||
|   remove-report: "削除" | ||||
|   title: "Abus" | ||||
|   target: "Cible" | ||||
|   reporter: "Signalé par" | ||||
|   details: "Détails" | ||||
|   remove-report: "Supprimer" | ||||
| admin/views/instance.vue: | ||||
|   instance: "Instance" | ||||
|   instance-name: "Nom de l’instance" | ||||
| @@ -1052,7 +1072,7 @@ admin/views/instance.vue: | ||||
|   max-note-text-length: "Nombre maximal de caractères pour les messages" | ||||
|   disable-registration: "Désactiver les inscriptions" | ||||
|   disable-local-timeline: "Désactiver le fil local" | ||||
|   disable-global-timeline: "グローバルタイムラインを無効にする" | ||||
|   disable-global-timeline: "Désactiver le fil global" | ||||
|   disabling-timelines-info: "これらのタイムラインを無効にしても、管理者およびモデレーターは引き続き利用できます。" | ||||
|   invite: "Inviter" | ||||
|   save: "Sauvegarder" | ||||
| @@ -1106,10 +1126,10 @@ admin/views/charts.vue: | ||||
|     network-time: "Temps de réponse" | ||||
|     network-usage: "Traffic" | ||||
| admin/views/drive.vue: | ||||
|   operation: "操作" | ||||
|   fileid-or-url: "ファイルIDまたはファイルURL" | ||||
|   file-not-found: "ファイルが見つかりません" | ||||
|   lookup: "照会" | ||||
|   operation: "Actions" | ||||
|   fileid-or-url: "ID du fichier ou URL" | ||||
|   file-not-found: "Fichier non trouvé" | ||||
|   lookup: "Recherche" | ||||
|   sort: | ||||
|     title: "Tri" | ||||
|     createdAtAsc: "Âge - Du plus ancien" | ||||
| @@ -1125,23 +1145,32 @@ admin/views/drive.vue: | ||||
|   deleted: "Supprimé" | ||||
|   mark-as-sensitive: "Marquer comme sensible" | ||||
|   unmark-as-sensitive: "Ne pas marquer comme sensible" | ||||
|   marked-as-sensitive: "閲覧注意に設定しました" | ||||
|   unmarked-as-sensitive: "閲覧注意を解除しました" | ||||
|   marked-as-sensitive: "Marqué comme sensible" | ||||
|   unmarked-as-sensitive: "Marqué comme non sensible" | ||||
| admin/views/users.vue: | ||||
|   operation: "Actions" | ||||
|   username-or-userid: "Nom d’utilisateur·rice ou ID utilisateur" | ||||
|   user-not-found: "Utilisateur non trouvé" | ||||
|   lookup: "Recherche" | ||||
|   reset-password: "Réinitialiser mot de passe" | ||||
|   reset-password-confirm: "Souhaitez-vous réinitialiser votre mot de passe ?" | ||||
|   password-updated: "Le mot de passe est « {password} »" | ||||
|   suspend: "Suspendre" | ||||
|   suspend-confirm: "Désirez-vous suspendre ce compte ?" | ||||
|   suspended: "Suspendu avec succès." | ||||
|   unsuspend: "Suspension levée" | ||||
|   unsuspend-confirm: "Souhaiteriez-vous ne plus suspendre ce compte ?" | ||||
|   unsuspended: "La suspension de l’utilisateur a été levée avec succès" | ||||
|   make-silence: "Mettre en sourdine" | ||||
|   unmake-silence: "Enlever la sourdine" | ||||
|   verify: "Vérification du compte" | ||||
|   verify-confirm: "Souhaiteriez-vous rendre votre compte comme étant un compte vérifié ?" | ||||
|   verified: "Le compte a été vérifié" | ||||
|   unverify: "Enlever la vérification du compte" | ||||
|   unverify-confirm: "公式アカウントを解除しますか?" | ||||
|   unverified: "Ce compte n'est plus vérifié" | ||||
|   update-remote-user: "Mettre à jour les informations de l’utilisateur·rice distant·e" | ||||
|   remote-user-updated: "Les informations de l’utilisateur·rice distant·e ont étés mis à jour" | ||||
|   users: | ||||
|     title: "Utilisateurs" | ||||
|     sort: | ||||
| @@ -1157,6 +1186,7 @@ admin/views/users.vue: | ||||
|       moderator: "Modérateur" | ||||
|       adminOrModerator: "Administrateur/Modérateur" | ||||
|       verified: "Compte vérifié" | ||||
|       silenced: "サイレンス済み" | ||||
|       suspended: "Suspendu" | ||||
|     origin: | ||||
|       title: "Origine" | ||||
| @@ -1204,6 +1234,64 @@ admin/views/announcements.vue: | ||||
|     removed: "Supprimé" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Tags cachés" | ||||
| admin/views/federation.vue: | ||||
|   federation: "Fédération" | ||||
|   host: "Hôte" | ||||
|   notes: "Notes" | ||||
|   users: "Utilisateur·rice·s" | ||||
|   following: "Abonnements" | ||||
|   followers: "Abonné·e·s" | ||||
|   status: "Statuts" | ||||
|   latest-request-sent-at: "Dernière requête envoyée" | ||||
|   latest-request-received-at: "Dernière requête reçue" | ||||
|   remove-all-following: "フォローを全解除" | ||||
|   remove-all-following-info: "{host}からのフォローをすべて解除します。そのインスタンスがもう存在しなくなった場合などに実行してください。" | ||||
|   block: "ブロック" | ||||
|   marked-as-closed: "閉鎖されているとマーク" | ||||
|   lookup: "照会" | ||||
|   instances: "Instances" | ||||
|   instance-not-registered: "そのインスタンスは登録されていません" | ||||
|   sort: "Trier par" | ||||
|   sorts: | ||||
|     caughtAtAsc: "Date d’inscription (Ascendant)" | ||||
|     caughtAtDesc: "Date d’inscription (Descendant)" | ||||
|     lastCommunicatedAtAsc: "最後にやり取りした日時が古い順" | ||||
|     lastCommunicatedAtDesc: "最後にやり取りした日時が新しい順" | ||||
|     notesAsc: "投稿が少ない順" | ||||
|     notesDesc: "Description des notes" | ||||
|     usersAsc: "ユーザーが少ない順" | ||||
|     usersDesc: "ユーザーが多い順" | ||||
|     followingAsc: "Les moins suivies" | ||||
|     followingDesc: "フォローが多い順" | ||||
|     followersAsc: "Ayant le moins d'abonné·e·s" | ||||
|     followersDesc: "Ayant le plus d'abonné·e·s" | ||||
|     driveUsageAsc: "ドライブ使用量が少ない順" | ||||
|     driveUsageDesc: "ドライブ使用量が多い順" | ||||
|     driveFilesAsc: "ドライブのファイル数が少ない順" | ||||
|     driveFilesDesc: "ドライブのファイル数が多い順" | ||||
|   state: "状態" | ||||
|   states: | ||||
|     all: "すべて" | ||||
|     blocked: "ブロック" | ||||
|     not-responding: "応答なし" | ||||
|     marked-as-closed: "閉鎖とマーク済み" | ||||
|   result-is-truncated: "上位{n}件を表示しています。" | ||||
|   charts: "チャート" | ||||
|   chart-srcs: | ||||
|     requests: "リクエスト" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     notes: "投稿の増減" | ||||
|     notes-total: "投稿の積算" | ||||
|     ff: "フォロー/フォロワーの増減" | ||||
|     ff-total: "フォロー/フォロワーの積算" | ||||
|     drive-usage: "ドライブ使用量の増減" | ||||
|     drive-usage-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブファイル数の増減" | ||||
|     drive-files-total: "ドライブファイル数の積算" | ||||
|   chart-spans: | ||||
|     hour: "1時間ごと" | ||||
|     day: "1日ごと" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "à propos" | ||||
|   gotit: "J'ai compris !" | ||||
| @@ -1236,11 +1324,11 @@ desktop/views/pages/share.vue: | ||||
| desktop/views/pages/tag.vue: | ||||
|   no-posts-found: "Aucune publication contenant « {q} » n’a été trouvée." | ||||
| desktop/views/pages/user-list.users.vue: | ||||
|   users: "Utilisateurs" | ||||
|   users: "Utilisateur·rice·s" | ||||
|   add-user: "Ajouter un utilisateur" | ||||
|   username: "Nom d'utilisateur" | ||||
| desktop/views/pages/user/user.followers-you-know.vue: | ||||
|   title: "Abonnés que vous connaissez" | ||||
|   title: "Abonné·e·s que vous connaissez" | ||||
|   loading: "Chargement en cours" | ||||
|   no-users: "Aucun abonné connu" | ||||
| desktop/views/pages/user/user.friends.vue: | ||||
| @@ -1253,11 +1341,11 @@ desktop/views/pages/user/user.photos.vue: | ||||
|   no-photos: "Pas de photos" | ||||
| desktop/views/pages/user/user.profile.vue: | ||||
|   follows-you: "Vous suit" | ||||
|   menu: "メニュー" | ||||
|   menu: "Menu" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
|   posts: "Notes" | ||||
|   following: "Suit" | ||||
|   followers: "Abonnés" | ||||
|   followers: "Abonné·e·s" | ||||
|   is-bot: "Ce compte est un Bot" | ||||
|   years-old: "{age} ans" | ||||
|   year: "/" | ||||
| @@ -1289,7 +1377,7 @@ desktop/views/widgets/trends.vue: | ||||
|   refresh: "Afficher d'autres" | ||||
|   nothing: "Rien" | ||||
| desktop/views/widgets/users.vue: | ||||
|   title: "Utilisateurs" | ||||
|   title: "Utilisateurs·rices" | ||||
|   refresh: "Afficher d'autres" | ||||
|   no-one: "Personne" | ||||
| mobile/views/components/drive.vue: | ||||
| @@ -1321,9 +1409,6 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   nsfw: "CW" | ||||
|   mark-as-sensitive: "Marquer comme sensible" | ||||
|   unmark-as-sensitive: "Ne pas marquer comme sensible" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "Le contenu est NSFW" | ||||
|   click-to-show: "Cliquer pour afficher" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "Le contenu est NSFW" | ||||
|   click-to-show: "Cliquer pour afficher" | ||||
| @@ -1335,7 +1420,7 @@ common/views/components/follow-button.vue: | ||||
|   follow-request: "Demande d’abonnement" | ||||
| mobile/views/components/friends-maker.vue: | ||||
|   title: "Abonnez-vous à" | ||||
|   empty: "Impossible de trouver des utilisateurs à recommander." | ||||
|   empty: "Impossible de trouver des utilisateurs·trices à recommander." | ||||
|   fetching: "Chargement" | ||||
|   refresh: "Voir plus" | ||||
|   close: "Fermer" | ||||
| @@ -1449,7 +1534,7 @@ mobile/views/pages/search.vue: | ||||
| mobile/views/pages/selectdrive.vue: | ||||
|   select-file: "Choisissez un fichier" | ||||
| mobile/views/pages/settings.vue: | ||||
|   signed-in-as: "Connecté en tant que {}" | ||||
|   signed-in-as: "Connecté·e en tant que {}" | ||||
|   design: "Affichage et design" | ||||
|   dark-mode: "Mode nuit" | ||||
|   i-am-under-limited-internet: "J'ai un accès Internet limité" | ||||
| @@ -1468,6 +1553,7 @@ mobile/views/pages/settings.vue: | ||||
|   notification-position-top: "en haut" | ||||
|   behavior: "Comportement" | ||||
|   fetch-on-scroll: "Chargement lors du défilement" | ||||
|   keep-cw: "Garder l'avertissement de contenu" | ||||
|   note-visibility: "Visibilité de la publication" | ||||
|   default-note-visibility: "Visibilité par défaut" | ||||
|   remember-note-visibility: "Se souvenir du mode de visibilité de la publication" | ||||
| @@ -1493,7 +1579,7 @@ mobile/views/pages/settings.vue: | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "Vous suit" | ||||
|   following: "Abonnements" | ||||
|   followers: "Abonnés" | ||||
|   followers: "Abonné·e·s" | ||||
|   notes: "Notes" | ||||
|   overview: "Aperçu" | ||||
|   timeline: "Fil d’actualité" | ||||
| @@ -1506,10 +1592,10 @@ mobile/views/pages/user/home.vue: | ||||
|   keywords: "Mot clés" | ||||
|   domains: "Domaines" | ||||
|   frequently-replied-users: "Utilisateurs mentionnés souvent" | ||||
|   followers-you-know: "Abonnés que vous connaissez" | ||||
|   followers-you-know: "Abonné·e·s que vous connaissez" | ||||
|   last-used-at: "Dernière connexion il y a" | ||||
| mobile/views/pages/user/home.followers-you-know.vue: | ||||
|   no-users: "Aucun utilisateur connu" | ||||
|   no-users: "Aucun utilisateur·rice connu·e" | ||||
| mobile/views/pages/user/home.friends.vue: | ||||
|   no-users: "Aucun utilisateur connu" | ||||
| mobile/views/pages/user/home.notes.vue: | ||||
| @@ -1541,6 +1627,7 @@ deck/deck.tl-column.vue: | ||||
|   is-media-view: "Vue média" | ||||
|   edit: "Option" | ||||
| deck/deck.user-column.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   posts: "Notes" | ||||
|   following: "Suit" | ||||
|   followers: "Abonnés" | ||||
|   | ||||
							
								
								
									
										3
									
								
								locales/index.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								locales/index.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | ||||
| declare const locales: { [lang: string]: any }; | ||||
|  | ||||
| export = locales; | ||||
| @@ -113,6 +113,7 @@ common: | ||||
|   use-avatar-reversi-stones: "リバーシの石にアバターを使う" | ||||
|   verified-user: "公式アカウント" | ||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||
|   disable-showing-animated-images: "アニメーション画像を再生しない" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
| @@ -129,7 +130,7 @@ common: | ||||
|   show-password: "パスワードを表示する" | ||||
|   do-not-use-in-production: "これは開発ビルドです。本番環境で使用しないでください。" | ||||
|   user-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-user: "このユーザー情報は不正確な可能性があります。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|   renoted-by: "{user}がRenote" | ||||
| @@ -344,6 +345,8 @@ common/views/components/note-menu.vue: | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   unfavorite: "お気に入り解除" | ||||
|   watch: "ウォッチ" | ||||
|   unwatch: "ウォッチ解除" | ||||
|   pin: "ピン留め" | ||||
|   unpin: "ピン留め解除" | ||||
|   delete: "削除" | ||||
| @@ -357,10 +360,13 @@ common/views/components/user-menu.vue: | ||||
|   unblock: "ブロック解除" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
|   report-abuse: "スパムを報告" | ||||
|   report-abuse-detail: "どのような迷惑行為を行っていますか?" | ||||
|   report-abuse-reported: "管理者に報告されました。ご協力ありがとうございました。" | ||||
|   silence: "サイレンス" | ||||
|   unsilence: "サイレンス解除" | ||||
|   suspend: "凍結" | ||||
|   unsuspend: "凍結解除" | ||||
| common/views/components/poll.vue: | ||||
|   vote-to: "「{}」に投票する" | ||||
|   vote-count: "{}票" | ||||
| @@ -483,6 +489,7 @@ common/views/components/profile-editor.vue: | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   you-can-include-hashtags: "ハッシュタグを含めることができます。" | ||||
|   language: "言語" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
| @@ -502,6 +509,13 @@ common/views/components/profile-editor.vue: | ||||
|   email-address: "メールアドレス" | ||||
|   email-verified: "メールアドレスが確認されました" | ||||
|   email-not-verified: "メールアドレスが確認されていません。メールボックスをご確認ください。" | ||||
|   export: "エクスポート" | ||||
|   export-targets: | ||||
|     all-notes: "すべての投稿データ" | ||||
|     following-list: "フォロー" | ||||
|     mute-list: "ミュート" | ||||
|     blocking-list: "ブロック" | ||||
|   export-requested: "エクスポートをリクエストしました。これには時間がかかる場合があります。エクスポートが終わると、ドライブにファイルが追加されます。" | ||||
| common/views/components/user-list-editor.vue: | ||||
|   users: "ユーザー" | ||||
|   rename: "リスト名を変更" | ||||
| @@ -659,9 +673,6 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "フォルダーを作成" | ||||
|     upload: "ファイルをアップロード" | ||||
|     url-upload: "URLからアップロード" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -789,6 +800,8 @@ desktop/views/components/settings.vue: | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   keep-cw: "CW保持" | ||||
|   keep-cw-desc: "投稿にリプライする際、リプライ元の投稿にCWが設定されていたとき、デフォルトで同じCWを設定するようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "デザインと表示" | ||||
|   customize: "ホームをカスタマイズ" | ||||
| @@ -874,6 +887,9 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "設定が完了しました!" | ||||
|   failed: "設定に失敗しました。トークンに誤りがないかご確認ください。" | ||||
|   info: "次回サインインからは、同様にパスワードに加えてデバイスに表示されているトークンを入力します。" | ||||
| common/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
| @@ -991,6 +1007,7 @@ admin/views/index.vue: | ||||
|   announcements: "お知らせ" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   abuse: "スパム報告" | ||||
|   queue: "ジョブキュー" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
| @@ -1000,6 +1017,9 @@ admin/views/dashboard.vue: | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "このインスタンス" | ||||
|   federated: "連合" | ||||
| admin/views/queue.vue: | ||||
|   operation: "操作" | ||||
|   remove-all-jobs: "すべてのジョブをクリア" | ||||
| admin/views/abuse.vue: | ||||
|   title: "スパム報告" | ||||
|   target: "対象" | ||||
| @@ -1133,15 +1153,24 @@ admin/views/users.vue: | ||||
|   user-not-found: "ユーザーが見つかりません" | ||||
|   lookup: "照会" | ||||
|   reset-password: "パスワードをリセット" | ||||
|   reset-password-confirm: "パスワードをリセットしますか?" | ||||
|   password-updated: "パスワードは現在「{password}」です" | ||||
|   suspend: "凍結" | ||||
|   suspend-confirm: "凍結しますか?" | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspend-confirm: "凍結を解除しますか?" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   make-silence: "サイレンス" | ||||
|   unmake-silence: "サイレンスの解除" | ||||
|   verify: "公式アカウントにする" | ||||
|   verify-confirm: "公式アカウントにしますか?" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverify-confirm: "公式アカウントを解除しますか?" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|   update-remote-user: "リモートユーザー情報の更新" | ||||
|   remote-user-updated: "リモートユーザー情報を更新しました" | ||||
|   users: | ||||
|     title: "ユーザー" | ||||
|     sort: | ||||
| @@ -1157,6 +1186,7 @@ admin/views/users.vue: | ||||
|       moderator: "モデレーター" | ||||
|       adminOrModerator: "管理者+モデレーター" | ||||
|       verified: "公式アカウント" | ||||
|       silenced: "サイレンス済み" | ||||
|       suspended: "凍結済み" | ||||
|     origin: | ||||
|       title: "オリジン" | ||||
| @@ -1204,6 +1234,64 @@ admin/views/announcements.vue: | ||||
|     removed: "削除しました" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| admin/views/federation.vue: | ||||
|   federation: "連合" | ||||
|   host: "ホスト" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   following: "フォロー中" | ||||
|   followers: "フォロワー" | ||||
|   status: "ステータス" | ||||
|   latest-request-sent-at: "直近のリクエスト送信" | ||||
|   latest-request-received-at: "直近のリクエスト受信" | ||||
|   remove-all-following: "フォローを全解除" | ||||
|   remove-all-following-info: "{host}からのフォローをすべて解除します。そのインスタンスがもう存在しなくなった場合などに実行してください。" | ||||
|   block: "ブロック" | ||||
|   marked-as-closed: "閉鎖されているとマーク" | ||||
|   lookup: "照会" | ||||
|   instances: "インスタンス" | ||||
|   instance-not-registered: "そのインスタンスは登録されていません" | ||||
|   sort: "ソート" | ||||
|   sorts: | ||||
|     caughtAtAsc: "登録日時が古い順" | ||||
|     caughtAtDesc: "登録日時が新しい順" | ||||
|     lastCommunicatedAtAsc: "最後にやり取りした日時が古い順" | ||||
|     lastCommunicatedAtDesc: "最後にやり取りした日時が新しい順" | ||||
|     notesAsc: "投稿が少ない順" | ||||
|     notesDesc: "投稿が多い順" | ||||
|     usersAsc: "ユーザーが少ない順" | ||||
|     usersDesc: "ユーザーが多い順" | ||||
|     followingAsc: "フォローが少ない順" | ||||
|     followingDesc: "フォローが多い順" | ||||
|     followersAsc: "フォロワーが少ない順" | ||||
|     followersDesc: "フォロワーが多い順" | ||||
|     driveUsageAsc: "ドライブ使用量が少ない順" | ||||
|     driveUsageDesc: "ドライブ使用量が多い順" | ||||
|     driveFilesAsc: "ドライブのファイル数が少ない順" | ||||
|     driveFilesDesc: "ドライブのファイル数が多い順" | ||||
|   state: "状態" | ||||
|   states: | ||||
|     all: "すべて" | ||||
|     blocked: "ブロック" | ||||
|     not-responding: "応答なし" | ||||
|     marked-as-closed: "閉鎖とマーク済み" | ||||
|   result-is-truncated: "上位{n}件を表示しています。" | ||||
|   charts: "チャート" | ||||
|   chart-srcs: | ||||
|     requests: "リクエスト" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     notes: "投稿の増減" | ||||
|     notes-total: "投稿の積算" | ||||
|     ff: "フォロー/フォロワーの増減" | ||||
|     ff-total: "フォロー/フォロワーの積算" | ||||
|     drive-usage: "ドライブ使用量の増減" | ||||
|     drive-usage-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブファイル数の増減" | ||||
|     drive-files-total: "ドライブファイル数の積算" | ||||
|   chart-spans: | ||||
|     hour: "1時間ごと" | ||||
|     day: "1日ごと" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "詳しく..." | ||||
|   gotit: "わかった" | ||||
| @@ -1321,9 +1409,6 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   nsfw: "閲覧注意" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -1468,6 +1553,7 @@ mobile/views/pages/settings.vue: | ||||
|   notification-position-top: "上" | ||||
|   behavior: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   keep-cw: "CW保持" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
| @@ -1505,13 +1591,13 @@ mobile/views/pages/user/home.vue: | ||||
|   activity: "アクティビティ" | ||||
|   keywords: "キーワード" | ||||
|   domains: "頻出ドメイン" | ||||
|   frequently-replied-users: "よく会話するユーザー" | ||||
|   frequently-replied-users: "よく話すユーザー" | ||||
|   followers-you-know: "知り合いのフォロワー" | ||||
|   last-used-at: "最終ログイン" | ||||
| mobile/views/pages/user/home.followers-you-know.vue: | ||||
|   no-users: "知り合いのユーザーはいません" | ||||
| mobile/views/pages/user/home.friends.vue: | ||||
|   no-users: "よく会話するユーザーはいません" | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| mobile/views/pages/user/home.notes.vue: | ||||
|   no-notes: "投稿はありません" | ||||
| mobile/views/pages/user/home.photos.vue: | ||||
| @@ -1541,6 +1627,7 @@ deck/deck.tl-column.vue: | ||||
|   is-media-view: "メディアビュー" | ||||
|   edit: "オプション" | ||||
| deck/deck.user-column.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   | ||||
| @@ -28,6 +28,8 @@ common: | ||||
|   load-more: "もっと読み込む" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   2fa: "二段階認証" | ||||
|   customize-home: "ホームをカスタマイズ" | ||||
|   featured-notes: "ハイライト" | ||||
|  | ||||
|   got-it: "わかった" | ||||
|   customization-tips: | ||||
| @@ -58,6 +60,11 @@ common: | ||||
|   trash: "ゴミ箱" | ||||
|   drive: "ドライブ" | ||||
|   messaging: "トーク" | ||||
|   deck: "デッキ" | ||||
|   timeline: "タイムライン" | ||||
|   explore: "みつける" | ||||
|   following: "フォロー中" | ||||
|   followers: "フォロワー" | ||||
|  | ||||
|   weekday-short: | ||||
|     sunday: "日" | ||||
| @@ -121,6 +128,7 @@ common: | ||||
|   use-avatar-reversi-stones: "リバーシの石にアバターを使う" | ||||
|   verified-user: "公式アカウント" | ||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||
|   disable-showing-animated-images: "アニメーション画像を再生しない" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
| @@ -138,7 +146,7 @@ common: | ||||
|  | ||||
|   do-not-use-in-production: "これは開発ビルドです。本番環境で使用しないでください。" | ||||
|   user-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-user: "このユーザー情報は不正確な可能性があります。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|   renoted-by: "{user}がRenote" | ||||
| @@ -374,6 +382,8 @@ common/views/components/note-menu.vue: | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   unfavorite: "お気に入り解除" | ||||
|   watch: "ウォッチ" | ||||
|   unwatch: "ウォッチ解除" | ||||
|   pin: "ピン留め" | ||||
|   unpin: "ピン留め解除" | ||||
|   delete: "削除" | ||||
| @@ -388,10 +398,13 @@ common/views/components/user-menu.vue: | ||||
|   unblock: "ブロック解除" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
|   report-abuse: "スパムを報告" | ||||
|   report-abuse-detail: "どのような迷惑行為を行っていますか?" | ||||
|   report-abuse-reported: "管理者に報告されました。ご協力ありがとうございました。" | ||||
|   silence: "サイレンス" | ||||
|   unsilence: "サイレンス解除" | ||||
|   suspend: "凍結" | ||||
|   unsuspend: "凍結解除" | ||||
|  | ||||
| common/views/components/poll.vue: | ||||
|   vote-to: "「{}」に投票する" | ||||
| @@ -531,6 +544,7 @@ common/views/components/profile-editor.vue: | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   you-can-include-hashtags: "ハッシュタグを含めることができます。" | ||||
|   language: "言語" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
| @@ -550,6 +564,13 @@ common/views/components/profile-editor.vue: | ||||
|   email-address: "メールアドレス" | ||||
|   email-verified: "メールアドレスが確認されました" | ||||
|   email-not-verified: "メールアドレスが確認されていません。メールボックスをご確認ください。" | ||||
|   export: "エクスポート" | ||||
|   export-targets: | ||||
|     all-notes: "すべての投稿データ" | ||||
|     following-list: "フォロー" | ||||
|     mute-list: "ミュート" | ||||
|     blocking-list: "ブロック" | ||||
|   export-requested: "エクスポートをリクエストしました。これには時間がかかる場合があります。エクスポートが終わると、ドライブにファイルが追加されます。" | ||||
|  | ||||
| common/views/components/user-list-editor.vue: | ||||
|   users: "ユーザー" | ||||
| @@ -731,10 +752,6 @@ desktop/views/components/drive.vue: | ||||
|     upload: "ファイルをアップロード" | ||||
|     url-upload: "URLからアップロード" | ||||
|  | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
|  | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -852,6 +869,9 @@ desktop/views/components/renote-form.vue: | ||||
| desktop/views/components/renote-form-window.vue: | ||||
|   title: "この投稿をRenoteしますか?" | ||||
|  | ||||
| desktop/views/components/timeline.core.vue: | ||||
|   empty: "投稿がありません" | ||||
|  | ||||
| desktop/views/pages/user-following-or-followers.vue: | ||||
|   following: "{user}のフォロー" | ||||
|   followers: "{user}のフォロワー" | ||||
| @@ -883,12 +903,10 @@ desktop/views/components/settings.vue: | ||||
|   web-search-engine-desc: "例: https://www.google.com/?#q={{query}}" | ||||
|   auto-popout: "ウィンドウの自動ポップアウト" | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   keep-cw: "CW保持" | ||||
|   keep-cw-desc: "投稿にリプライする際、リプライ元の投稿にCWが設定されていたとき、デフォルトで同じCWを設定するようにします。" | ||||
|  | ||||
|   display: "デザインと表示" | ||||
|   customize: "ホームをカスタマイズ" | ||||
|   wallpaper: "壁紙" | ||||
|   choose-wallpaper: "壁紙を選択" | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
| @@ -979,6 +997,10 @@ desktop/views/components/settings.2fa.vue: | ||||
|   failed: "設定に失敗しました。トークンに誤りがないかご確認ください。" | ||||
|   info: "次回サインインからは、同様にパスワードに加えてデバイスに表示されているトークンを入力します。" | ||||
|  | ||||
| common/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
|  | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
| @@ -1060,15 +1082,12 @@ desktop/views/components/ui.header.account.vue: | ||||
|   favorites: "お気に入り" | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
|   customize: "ホームのカスタマイズ" | ||||
|   admin: "管理" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   dark: "闇に飲まれる" | ||||
|  | ||||
| desktop/views/components/ui.header.nav.vue: | ||||
|   home: "ホーム" | ||||
|   deck: "デッキ" | ||||
|   game: "ゲーム" | ||||
|  | ||||
| desktop/views/components/ui.header.notifications.vue: | ||||
| @@ -1117,6 +1136,7 @@ admin/views/index.vue: | ||||
|   announcements: "お知らせ" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   abuse: "スパム報告" | ||||
|   queue: "ジョブキュー" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
|  | ||||
| admin/views/dashboard.vue: | ||||
| @@ -1128,6 +1148,10 @@ admin/views/dashboard.vue: | ||||
|   this-instance: "このインスタンス" | ||||
|   federated: "連合" | ||||
|  | ||||
| admin/views/queue.vue: | ||||
|   operation: "操作" | ||||
|   remove-all-jobs: "すべてのジョブをクリア" | ||||
|  | ||||
| admin/views/abuse.vue: | ||||
|   title: "スパム報告" | ||||
|   target: "対象" | ||||
| @@ -1265,15 +1289,24 @@ admin/views/users.vue: | ||||
|   user-not-found: "ユーザーが見つかりません" | ||||
|   lookup: "照会" | ||||
|   reset-password: "パスワードをリセット" | ||||
|   reset-password-confirm: "パスワードをリセットしますか?" | ||||
|   password-updated: "パスワードは現在「{password}」です" | ||||
|   suspend: "凍結" | ||||
|   suspend-confirm: "凍結しますか?" | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspend-confirm: "凍結を解除しますか?" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   make-silence: "サイレンス" | ||||
|   unmake-silence: "サイレンスの解除" | ||||
|   verify: "公式アカウントにする" | ||||
|   verify-confirm: "公式アカウントにしますか?" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverify-confirm: "公式アカウントを解除しますか?" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|   update-remote-user: "リモートユーザー情報の更新" | ||||
|   remote-user-updated: "リモートユーザー情報を更新しました" | ||||
|   users: | ||||
|     title: "ユーザー" | ||||
|     sort: | ||||
| @@ -1289,6 +1322,7 @@ admin/views/users.vue: | ||||
|       moderator: "モデレーター" | ||||
|       adminOrModerator: "管理者+モデレーター" | ||||
|       verified: "公式アカウント" | ||||
|       silenced: "サイレンス済み" | ||||
|       suspended: "凍結済み" | ||||
|     origin: | ||||
|       title: "オリジン" | ||||
| @@ -1341,6 +1375,65 @@ admin/views/announcements.vue: | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
|  | ||||
| admin/views/federation.vue: | ||||
|   federation: "連合" | ||||
|   host: "ホスト" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   following: "フォロー中" | ||||
|   followers: "フォロワー" | ||||
|   status: "ステータス" | ||||
|   latest-request-sent-at: "直近のリクエスト送信" | ||||
|   latest-request-received-at: "直近のリクエスト受信" | ||||
|   remove-all-following: "フォローを全解除" | ||||
|   remove-all-following-info: "{host}からのフォローをすべて解除します。そのインスタンスがもう存在しなくなった場合などに実行してください。" | ||||
|   block: "ブロック" | ||||
|   marked-as-closed: "閉鎖されているとマーク" | ||||
|   lookup: "照会" | ||||
|   instances: "インスタンス" | ||||
|   instance-not-registered: "そのインスタンスは登録されていません" | ||||
|   sort: "ソート" | ||||
|   sorts: | ||||
|     caughtAtAsc: "登録日時が古い順" | ||||
|     caughtAtDesc: "登録日時が新しい順" | ||||
|     lastCommunicatedAtAsc: "最後にやり取りした日時が古い順" | ||||
|     lastCommunicatedAtDesc: "最後にやり取りした日時が新しい順" | ||||
|     notesAsc: "投稿が少ない順" | ||||
|     notesDesc: "投稿が多い順" | ||||
|     usersAsc: "ユーザーが少ない順" | ||||
|     usersDesc: "ユーザーが多い順" | ||||
|     followingAsc: "フォローが少ない順" | ||||
|     followingDesc: "フォローが多い順" | ||||
|     followersAsc: "フォロワーが少ない順" | ||||
|     followersDesc: "フォロワーが多い順" | ||||
|     driveUsageAsc: "ドライブ使用量が少ない順" | ||||
|     driveUsageDesc: "ドライブ使用量が多い順" | ||||
|     driveFilesAsc: "ドライブのファイル数が少ない順" | ||||
|     driveFilesDesc: "ドライブのファイル数が多い順" | ||||
|   state: "状態" | ||||
|   states: | ||||
|     all: "すべて" | ||||
|     blocked: "ブロック" | ||||
|     not-responding: "応答なし" | ||||
|     marked-as-closed: "閉鎖とマーク済み" | ||||
|   result-is-truncated: "上位{n}件を表示しています。" | ||||
|   charts: "チャート" | ||||
|   chart-srcs: | ||||
|     requests: "リクエスト" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     notes: "投稿の増減" | ||||
|     notes-total: "投稿の積算" | ||||
|     ff: "フォロー/フォロワーの増減" | ||||
|     ff-total: "フォロー/フォロワーの積算" | ||||
|     drive-usage: "ドライブ使用量の増減" | ||||
|     drive-usage-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブファイル数の増減" | ||||
|     drive-files-total: "ドライブファイル数の積算" | ||||
|   chart-spans: | ||||
|     hour: "1時間ごと" | ||||
|     day: "1日ごと" | ||||
|  | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "詳しく..." | ||||
|   gotit: "わかった" | ||||
| @@ -1357,9 +1450,6 @@ desktop/views/pages/welcome.vue: | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Misskey Drive" | ||||
|  | ||||
| desktop/views/pages/home-customize.vue: | ||||
|   title: "ホームのカスタマイズ" | ||||
|  | ||||
| desktop/views/pages/note.vue: | ||||
|   prev: "前の投稿" | ||||
|   next: "次の投稿" | ||||
| @@ -1400,10 +1490,6 @@ desktop/views/pages/user/user.photos.vue: | ||||
|   loading: "読み込み中" | ||||
|   no-photos: "写真はありません" | ||||
|  | ||||
| desktop/views/pages/user/user.profile.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   menu: "メニュー" | ||||
|  | ||||
| desktop/views/pages/user/user.header.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
| @@ -1413,6 +1499,7 @@ desktop/views/pages/user/user.header.vue: | ||||
|   year: "年" | ||||
|   month: "月" | ||||
|   day: "日" | ||||
|   follows-you: "フォローされています" | ||||
|  | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "投稿" | ||||
| @@ -1485,10 +1572,6 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
|  | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
|  | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -1575,10 +1658,6 @@ mobile/views/components/user-timeline.vue: | ||||
|   no-notes: "このユーザーは投稿していないようです。" | ||||
|   no-notes-with-media: "メディア付き投稿はありません。" | ||||
|  | ||||
| mobile/views/components/users-list.vue: | ||||
|   all: "すべて" | ||||
|   known: "知り合い" | ||||
|  | ||||
| mobile/views/pages/favorites.vue: | ||||
|   title: "お気に入り" | ||||
|  | ||||
| @@ -1603,6 +1682,9 @@ mobile/views/pages/home.vue: | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
|  | ||||
| mobile/views/pages/home.timeline.vue: | ||||
|   empty: "投稿がありません" | ||||
|  | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{q}」が付けられた投稿は見つかりませんでした。" | ||||
|  | ||||
| @@ -1665,6 +1747,7 @@ mobile/views/pages/settings.vue: | ||||
|   notification-position-top: "上" | ||||
|   behavior: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   keep-cw: "CW保持" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
| @@ -1704,7 +1787,7 @@ mobile/views/pages/user/home.vue: | ||||
|   activity: "アクティビティ" | ||||
|   keywords: "キーワード" | ||||
|   domains: "頻出ドメイン" | ||||
|   frequently-replied-users: "よく会話するユーザー" | ||||
|   frequently-replied-users: "よく話すユーザー" | ||||
|   followers-you-know: "知り合いのフォロワー" | ||||
|   last-used-at: "最終ログイン" | ||||
|  | ||||
| @@ -1712,7 +1795,7 @@ mobile/views/pages/user/home.followers-you-know.vue: | ||||
|   no-users: "知り合いのユーザーはいません" | ||||
|  | ||||
| mobile/views/pages/user/home.friends.vue: | ||||
|   no-users: "よく会話するユーザーはいません" | ||||
|   no-users: "よく話すユーザーはいません" | ||||
|  | ||||
| mobile/views/pages/user/home.notes.vue: | ||||
|   no-notes: "投稿はありません" | ||||
| @@ -1747,6 +1830,7 @@ deck/deck.tl-column.vue: | ||||
|   edit: "オプション" | ||||
|  | ||||
| deck/deck.user-column.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   | ||||
| @@ -113,6 +113,7 @@ common: | ||||
|   use-avatar-reversi-stones: "リバーシの石にアバターを使う" | ||||
|   verified-user: "アメちゃん付きアカウント" | ||||
|   disable-animated-mfm: "投稿内のちょろちょろ動いてんのを止める" | ||||
|   disable-showing-animated-images: "アニメーション画像を再生しない" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "閲覧注意?見せたらあかん?そんなん知らんわ、見せろや!" | ||||
|   always-mark-nsfw: "わからんからとりあえずメディアは見せたらあかん" | ||||
| @@ -129,7 +130,7 @@ common: | ||||
|   show-password: "パスワードを表示する" | ||||
|   do-not-use-in-production: "開発ビルドや。本番環境で使わんといて!知らんで!" | ||||
|   user-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-user: "このユーザー情報は不正確な可能性があります。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "ちゃんとした情報見せてや!" | ||||
|   renoted-by: "{user}がRenote" | ||||
| @@ -344,6 +345,8 @@ common/views/components/note-menu.vue: | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   unfavorite: "お気に入りやめる" | ||||
|   watch: "ウォッチ" | ||||
|   unwatch: "ウォッチ解除" | ||||
|   pin: "ピン留め" | ||||
|   unpin: "ピン留めやめる" | ||||
|   delete: "ほかす" | ||||
| @@ -357,10 +360,13 @@ common/views/components/user-menu.vue: | ||||
|   unblock: "ブロック解除" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
|   report-abuse: "スパムを報告" | ||||
|   report-abuse-detail: "どのような迷惑行為を行っていますか?" | ||||
|   report-abuse-reported: "管理者に報告されました。ご協力ありがとうございました。" | ||||
|   silence: "サイレンス" | ||||
|   unsilence: "サイレンス解除" | ||||
|   suspend: "凍結" | ||||
|   unsuspend: "凍結解除" | ||||
| common/views/components/poll.vue: | ||||
|   vote-to: "「{}」に投票や!" | ||||
|   vote-count: "{}票" | ||||
| @@ -483,6 +489,7 @@ common/views/components/profile-editor.vue: | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   you-can-include-hashtags: "ハッシュタグを含めることができます。" | ||||
|   language: "言語" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
| @@ -502,6 +509,13 @@ common/views/components/profile-editor.vue: | ||||
|   email-address: "メールアドレス" | ||||
|   email-verified: "このメールアドレスOKや!" | ||||
|   email-not-verified: "メールアドレスが確認されとらん。メールボックスもっぺん見てくれへん?" | ||||
|   export: "エクスポート" | ||||
|   export-targets: | ||||
|     all-notes: "すべての投稿データ" | ||||
|     following-list: "フォロー" | ||||
|     mute-list: "ミュート" | ||||
|     blocking-list: "ブロック" | ||||
|   export-requested: "エクスポートをリクエストしました。これには時間がかかる場合があります。エクスポートが終わると、ドライブにファイルが追加されます。" | ||||
| common/views/components/user-list-editor.vue: | ||||
|   users: "ユーザー" | ||||
|   rename: "リスト名を変更" | ||||
| @@ -659,9 +673,6 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "フォルダー作る" | ||||
|     upload: "ファイル上げる" | ||||
|     url-upload: "URLつこうて上げる" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "ちょっと見せられへんわ" | ||||
|   click-to-show: "クリックして見せるで" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "ちょっと見せられへんわ" | ||||
|   click-to-show: "クリックして見せるで" | ||||
| @@ -789,6 +800,8 @@ desktop/views/components/settings.vue: | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトすんで。この設定はブラウザに記憶されんで。" | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使うとるとき、ナビゲーションが発生するときにページ移動せんで、一時的なカラムで受けれるようにするで" | ||||
|   keep-cw: "CW保持" | ||||
|   keep-cw-desc: "投稿にリプライする際、リプライ元の投稿にCWが設定されていたとき、デフォルトで同じCWを設定するようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "見た感じ" | ||||
|   customize: "ホームをカスタマイズ" | ||||
| @@ -874,6 +887,9 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "設定が完了したで!" | ||||
|   failed: "なんか設定に失敗したで。トークンを間違えとらんか確認してや。" | ||||
|   info: "次のサインインからは、パスワードに加えてデバイスに出とるトークンを入力してな。" | ||||
| common/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "API使うんやったらこのトークンを「i」っちゅうパラメータにくっつけてリクエストできるで。" | ||||
|   caution: "アカウント勝手にいじられるかも知れんから、このトークンは教えたらあかんし、アプリにも書いたらあかんで(これはフリちゃうで)" | ||||
| @@ -991,6 +1007,7 @@ admin/views/index.vue: | ||||
|   announcements: "知っといてや" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   abuse: "スパム報告" | ||||
|   queue: "ジョブキュー" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
| @@ -1000,6 +1017,9 @@ admin/views/dashboard.vue: | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "ワイのインスタンス" | ||||
|   federated: "連合" | ||||
| admin/views/queue.vue: | ||||
|   operation: "操作" | ||||
|   remove-all-jobs: "すべてのジョブをクリア" | ||||
| admin/views/abuse.vue: | ||||
|   title: "スパム報告" | ||||
|   target: "対象" | ||||
| @@ -1133,15 +1153,24 @@ admin/views/users.vue: | ||||
|   user-not-found: "ユーザーが見つからへん!" | ||||
|   lookup: "照会" | ||||
|   reset-password: "パスワードをリセット" | ||||
|   reset-password-confirm: "パスワードをリセットしますか?" | ||||
|   password-updated: "パスワードは現在「{password} 」やで" | ||||
|   suspend: "凍結" | ||||
|   suspend-confirm: "凍結しますか?" | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspend-confirm: "凍結を解除しますか?" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   make-silence: "サイレンス" | ||||
|   unmake-silence: "サイレンスの解除" | ||||
|   verify: "公式アカウントにする" | ||||
|   verify-confirm: "公式アカウントにしますか?" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverify-confirm: "公式アカウントを解除しますか?" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|   update-remote-user: "リモートユーザー情報の更新" | ||||
|   remote-user-updated: "リモートユーザー情報を更新しました" | ||||
|   users: | ||||
|     title: "ユーザー" | ||||
|     sort: | ||||
| @@ -1157,6 +1186,7 @@ admin/views/users.vue: | ||||
|       moderator: "モデレーター" | ||||
|       adminOrModerator: "管理者+モデレーター" | ||||
|       verified: "公式アカウント" | ||||
|       silenced: "サイレンス済み" | ||||
|       suspended: "凍結済み" | ||||
|     origin: | ||||
|       title: "オリジン" | ||||
| @@ -1204,6 +1234,64 @@ admin/views/announcements.vue: | ||||
|     removed: "削除しました" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| admin/views/federation.vue: | ||||
|   federation: "連合" | ||||
|   host: "ホスト" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   following: "フォロー中" | ||||
|   followers: "フォロワー" | ||||
|   status: "ステータス" | ||||
|   latest-request-sent-at: "直近のリクエスト送信" | ||||
|   latest-request-received-at: "直近のリクエスト受信" | ||||
|   remove-all-following: "フォローを全解除" | ||||
|   remove-all-following-info: "{host}からのフォローをすべて解除します。そのインスタンスがもう存在しなくなった場合などに実行してください。" | ||||
|   block: "ブロック" | ||||
|   marked-as-closed: "閉鎖されているとマーク" | ||||
|   lookup: "照会" | ||||
|   instances: "インスタンス" | ||||
|   instance-not-registered: "そのインスタンスは登録されていません" | ||||
|   sort: "ソート" | ||||
|   sorts: | ||||
|     caughtAtAsc: "登録日時が古い順" | ||||
|     caughtAtDesc: "登録日時が新しい順" | ||||
|     lastCommunicatedAtAsc: "最後にやり取りした日時が古い順" | ||||
|     lastCommunicatedAtDesc: "最後にやり取りした日時が新しい順" | ||||
|     notesAsc: "投稿が少ない順" | ||||
|     notesDesc: "投稿が多い順" | ||||
|     usersAsc: "ユーザーが少ない順" | ||||
|     usersDesc: "ユーザーが多い順" | ||||
|     followingAsc: "フォローが少ない順" | ||||
|     followingDesc: "フォローが多い順" | ||||
|     followersAsc: "フォロワーが少ない順" | ||||
|     followersDesc: "フォロワーが多い順" | ||||
|     driveUsageAsc: "ドライブ使用量が少ない順" | ||||
|     driveUsageDesc: "ドライブ使用量が多い順" | ||||
|     driveFilesAsc: "ドライブのファイル数が少ない順" | ||||
|     driveFilesDesc: "ドライブのファイル数が多い順" | ||||
|   state: "状態" | ||||
|   states: | ||||
|     all: "すべて" | ||||
|     blocked: "ブロック" | ||||
|     not-responding: "応答なし" | ||||
|     marked-as-closed: "閉鎖とマーク済み" | ||||
|   result-is-truncated: "上位{n}件を表示しています。" | ||||
|   charts: "チャート" | ||||
|   chart-srcs: | ||||
|     requests: "リクエスト" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     notes: "投稿の増減" | ||||
|     notes-total: "投稿の積算" | ||||
|     ff: "フォロー/フォロワーの増減" | ||||
|     ff-total: "フォロー/フォロワーの積算" | ||||
|     drive-usage: "ドライブ使用量の増減" | ||||
|     drive-usage-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブファイル数の増減" | ||||
|     drive-files-total: "ドライブファイル数の積算" | ||||
|   chart-spans: | ||||
|     hour: "1時間ごと" | ||||
|     day: "1日ごと" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "もうちょい……" | ||||
|   gotit: "ほい" | ||||
| @@ -1321,9 +1409,6 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   nsfw: "ちょっと見せられへんわ" | ||||
|   mark-as-sensitive: "見たらあかん感じにしとく" | ||||
|   unmark-as-sensitive: "やっぱ見せたるわ" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "見たらあかんで" | ||||
|   click-to-show: "押してみ、見せたるわ" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "ちょっと見せられへんわ" | ||||
|   click-to-show: "押してみ、見せたるわ" | ||||
| @@ -1468,6 +1553,7 @@ mobile/views/pages/settings.vue: | ||||
|   notification-position-top: "キタの方" | ||||
|   behavior: "動き" | ||||
|   fetch-on-scroll: "スクロールしたらもっと見せてや" | ||||
|   keep-cw: "CW保持" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "もとからの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲おぼえといて" | ||||
| @@ -1541,6 +1627,7 @@ deck/deck.tl-column.vue: | ||||
|   is-media-view: "メディアビュー" | ||||
|   edit: "オプション" | ||||
| deck/deck.user-column.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   | ||||
| @@ -27,7 +27,7 @@ common: | ||||
|   do-not-copy-paste: "여기에 코드를 입력하거나 붙여넣지 마십시오. 계정이 무단으로 사용될 수 있습니다." | ||||
|   load-more: "더보기" | ||||
|   enter-password: "비밀번호를 입력하여 주십시오" | ||||
|   2fa: "二段階認証" | ||||
|   2fa: "2단계 인증" | ||||
|   got-it: "알겠습니다" | ||||
|   customization-tips: | ||||
|     title: "커스터마이징 도움말" | ||||
| @@ -113,6 +113,7 @@ common: | ||||
|   use-avatar-reversi-stones: "리버시의 돌로 아바타를 사용" | ||||
|   verified-user: "공식 계정" | ||||
|   disable-animated-mfm: "글의 문자 애니메이션을 비활성화" | ||||
|   disable-showing-animated-images: "움직이는 이미지를 자동으로 재생하지 않음" | ||||
|   suggest-recent-hashtags: "최근 해시태그를 글 작성란에 표시" | ||||
|   always-show-nsfw: "항상 열람주의 미디어를 표시" | ||||
|   always-mark-nsfw: "항상 미디어를 열람주의로 설정하여 게시" | ||||
| @@ -129,7 +130,7 @@ common: | ||||
|   show-password: "비밀번호 표시" | ||||
|   do-not-use-in-production: "이것은 개발 빌드입니다. 프로덕션 환경에서 사용하지 마십시오." | ||||
|   user-suspended: "이 사용자는 정지된 상태입니다." | ||||
|   is-remote-user: "이 유저 정보는 복사본입니다." | ||||
|   is-remote-user: "이 사용자 정보는 정확하지 않을 수 있습니다." | ||||
|   is-remote-post: "이 글 정보는 복사본입니다." | ||||
|   view-on-remote: "정확한 정보 보기" | ||||
|   renoted-by: "{user}이(가) 리노트" | ||||
| @@ -344,23 +345,28 @@ common/views/components/note-menu.vue: | ||||
|   copy-link: "링크 복사" | ||||
|   favorite: "이 노트 즐겨찾기" | ||||
|   unfavorite: "즐겨찾기에서 제거" | ||||
|   watch: "지켜보기" | ||||
|   unwatch: "지켜보기 해제" | ||||
|   pin: "프로필에 고정" | ||||
|   unpin: "프로필에서 고정 해제" | ||||
|   delete: "삭제" | ||||
|   delete-confirm: "이 글을 삭제하시겠습니까?" | ||||
|   remote: "글 원본 보기" | ||||
| common/views/components/user-menu.vue: | ||||
|   mention: "メンション" | ||||
|   mute: "ミュート" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
|   report-abuse: "スパムを報告" | ||||
|   report-abuse-detail: "どのような迷惑行為を行っていますか?" | ||||
|   report-abuse-reported: "管理者に報告されました。ご協力ありがとうございました。" | ||||
|   mention: "멘션" | ||||
|   mute: "뮤트" | ||||
|   unmute: "뮤트 해제" | ||||
|   block: "차단" | ||||
|   unblock: "차단 해제" | ||||
|   push-to-list: "리스트에 추가" | ||||
|   select-list: "리스트를 선택하여 주십시오" | ||||
|   report-abuse: "스팸 신고" | ||||
|   report-abuse-detail: "어떤 스팸 행위를 하고 있습니까?" | ||||
|   report-abuse-reported: "관리자에게 보고되었습니다. 협조해주셔서 감사합니다." | ||||
|   silence: "침묵" | ||||
|   unsilence: "침묵 해제" | ||||
|   suspend: "정지" | ||||
|   unsuspend: "정지 해제" | ||||
| common/views/components/poll.vue: | ||||
|   vote-to: "\"{}\"에 투표하기" | ||||
|   vote-count: "{}표" | ||||
| @@ -483,6 +489,7 @@ common/views/components/profile-editor.vue: | ||||
|   account: "계정" | ||||
|   location: "장소" | ||||
|   description: "자기소개" | ||||
|   you-can-include-hashtags: "해시 태그를 포함할 수 있습니다." | ||||
|   language: "언어" | ||||
|   birthday: "생일" | ||||
|   avatar: "아바타" | ||||
| @@ -502,6 +509,13 @@ common/views/components/profile-editor.vue: | ||||
|   email-address: "메일 주소" | ||||
|   email-verified: "매일 주소가 확인되었습니다" | ||||
|   email-not-verified: "메일 주소가 확인되지 않았습니다. 받은 편지함을 확인하여 주시기 바랍니다." | ||||
|   export: "내보내기" | ||||
|   export-targets: | ||||
|     all-notes: "모든 글 데이터" | ||||
|     following-list: "팔로잉" | ||||
|     mute-list: "뮤트" | ||||
|     blocking-list: "차단" | ||||
|   export-requested: "내보내기를 요청하였습니다. 이 작업은 시간이 걸릴 수 있습니다. 내보내기가 완료되면 드라이브에 파일이 추가됩니다." | ||||
| common/views/components/user-list-editor.vue: | ||||
|   users: "사용자" | ||||
|   rename: "리스트 이름 바꾸기" | ||||
| @@ -594,7 +608,7 @@ desktop/views/components/calendar.vue: | ||||
|   title: "{year}년 {month}월" | ||||
|   prev: "이전 달" | ||||
|   next: "다음 달" | ||||
|   go: "클릭 하 여 시간 회귀" | ||||
|   go: "클릭하여 시간역행" | ||||
| desktop/views/components/choose-file-from-drive-window.vue: | ||||
|   chosen-files: "{count} 파일 선택중" | ||||
|   upload: "PC에서 드라이브에 파일을 업로드" | ||||
| @@ -659,9 +673,6 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "폴더 만들기" | ||||
|     upload: "파일 업로드" | ||||
|     url-upload: "URL에서 업로드" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "열람주의" | ||||
|   click-to-show: "클릭하여 표시" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "열람주의" | ||||
|   click-to-show: "클릭하여 표시" | ||||
| @@ -789,6 +800,8 @@ desktop/views/components/settings.vue: | ||||
|   auto-popout-desc: "창이 열릴 때 팝아웃 (브라우저 밖으로 분리) 이 가능한 경우 자동으로 팝아웃합니다. 이 설정은 브라우저에 저장됩니다." | ||||
|   deck-nav: "덱 내 탐색" | ||||
|   deck-nav-desc: "덱을 사용중일 때, 내비게이션이 발생하였을 경우 페이지를 이동하지 않고 일시적으로 임시 칼럼을 생성하도록 합니다." | ||||
|   keep-cw: "CW 유지" | ||||
|   keep-cw-desc: "글에 답글을 달 때, 답글할 글에 CW가 설정되어 있는 경우 기본값으로 동일한 CW를 설정하도록 합니다." | ||||
|   deck-default: "덱을 기본 UI로 설정" | ||||
|   display: "디자인 및 표시" | ||||
|   customize: "홈 커스터마이징" | ||||
| @@ -874,6 +887,9 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "설정이 완료되었습니다!" | ||||
|   failed: "설정에 실패했습니다. 토큰이 잘못되었는지 확인해주십시오." | ||||
|   info: "다음 로그인부터는 이와 동일하게 비밀번호에 더해 장치에 표시된 토큰을 입력합니다." | ||||
| common/views/components/media-image.vue: | ||||
|   sensitive: "열람주의" | ||||
|   click-to-show: "클릭하여 보기" | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "API를 사용하려면 위의 토큰을 \"i\" 라는 키의 값으로 매개변수를 추가하여 요청합니다." | ||||
|   caution: "계정을 부정 사용할 가능성이 있으므로, 이 토큰은 제 3자에게 알려주지 마십시오 (앱 등에 붙여넣지 마십시오)." | ||||
| @@ -990,7 +1006,8 @@ admin/views/index.vue: | ||||
|   federation: "연합" | ||||
|   announcements: "공지사항" | ||||
|   hashtags: "해시태그" | ||||
|   abuse: "スパム報告" | ||||
|   abuse: "스팸 신고" | ||||
|   queue: "작업 대기열" | ||||
|   back-to-misskey: "Misskey로 돌아가기" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "대시보드" | ||||
| @@ -1000,12 +1017,15 @@ admin/views/dashboard.vue: | ||||
|   instances: "인스턴스" | ||||
|   this-instance: "이 인스턴스" | ||||
|   federated: "연합" | ||||
| admin/views/queue.vue: | ||||
|   operation: "동작" | ||||
|   remove-all-jobs: "모든 작업 제거" | ||||
| admin/views/abuse.vue: | ||||
|   title: "スパム報告" | ||||
|   target: "対象" | ||||
|   reporter: "報告者" | ||||
|   details: "詳細" | ||||
|   remove-report: "削除" | ||||
|   title: "스팸 신고" | ||||
|   target: "대상" | ||||
|   reporter: "신고자" | ||||
|   details: "상세" | ||||
|   remove-report: "삭제" | ||||
| admin/views/instance.vue: | ||||
|   instance: "인스턴스" | ||||
|   instance-name: "인스턴스 이름" | ||||
| @@ -1053,7 +1073,7 @@ admin/views/instance.vue: | ||||
|   disable-registration: "사용자 등록 비활성화" | ||||
|   disable-local-timeline: "로컬 타임라인 비활성화" | ||||
|   disable-global-timeline: "글로벌 타임라인 비활성화" | ||||
|   disabling-timelines-info: "これらのタイムラインを無効にしても、管理者およびモデレーターは引き続き利用できます。" | ||||
|   disabling-timelines-info: "이 타임라인들을 비활성화해도 관리자 및 모더레이터는 계속 사용할 수 있습니다." | ||||
|   invite: "초대" | ||||
|   save: "저장" | ||||
|   saved: "저장하였습니다" | ||||
| @@ -1064,7 +1084,7 @@ admin/views/instance.vue: | ||||
|   external-user-recommendation-timeout: "타임 아웃" | ||||
|   external-user-recommendation-timeout-desc: "밀리초 (예: 300000)" | ||||
|   email-config: "메일 서버 설정" | ||||
|   email-config-info: "메일 주소 확인 혹은 암호 재설정에 사용 됩니다." | ||||
|   email-config-info: "메일 주소 확인 혹은 비밀번호 재설정에 사용 됩니다." | ||||
|   enable-email: "메일 발신 활성화" | ||||
|   email: "메일 주소" | ||||
|   smtp-secure: "SMTP 연결에 암시적으로 SSL/TLS를 사용" | ||||
| @@ -1094,10 +1114,10 @@ admin/views/charts.vue: | ||||
|     notes: "글 증감 (통합)" | ||||
|     local-notes: "글 증감 (로컬)" | ||||
|     remote-notes: "글 증감 (원격)" | ||||
|     notes-total: "글 누적 수" | ||||
|     notes-total: "글 누적" | ||||
|     users: "사용자 증감" | ||||
|     users-total: "사용자 누적" | ||||
|     active-users: "アクティブユーザー数" | ||||
|     active-users: "활성 사용자 수" | ||||
|     drive: "드라이브 사용량 증감" | ||||
|     drive-total: "드라이브 사용량 누적" | ||||
|     drive-files: "드라이브 파일 수 증감" | ||||
| @@ -1106,10 +1126,10 @@ admin/views/charts.vue: | ||||
|     network-time: "응답시간" | ||||
|     network-usage: "통신량" | ||||
| admin/views/drive.vue: | ||||
|   operation: "操作" | ||||
|   fileid-or-url: "ファイルIDまたはファイルURL" | ||||
|   file-not-found: "ファイルが見つかりません" | ||||
|   lookup: "照会" | ||||
|   operation: "작업" | ||||
|   fileid-or-url: "파일 ID 또는 파일 URL" | ||||
|   file-not-found: "파일을 찾을 수 없습니다" | ||||
|   lookup: "조회" | ||||
|   sort: | ||||
|     title: "정렬" | ||||
|     createdAtAsc: "업로드 날짜 오랜 순" | ||||
| @@ -1125,23 +1145,32 @@ admin/views/drive.vue: | ||||
|   deleted: "삭제하였습니다" | ||||
|   mark-as-sensitive: "열람주의로 설정" | ||||
|   unmark-as-sensitive: "열람주의 해제" | ||||
|   marked-as-sensitive: "閲覧注意に設定しました" | ||||
|   unmarked-as-sensitive: "閲覧注意を解除しました" | ||||
|   marked-as-sensitive: "열람주의로 설정하였습니다" | ||||
|   unmarked-as-sensitive: "열람주의를 제거하였습니다" | ||||
| admin/views/users.vue: | ||||
|   operation: "작업" | ||||
|   username-or-userid: "사용자명 혹은 사용자 ID" | ||||
|   user-not-found: "사용자를 찾을 수 없습니다" | ||||
|   lookup: "조회" | ||||
|   reset-password: "암호 재설정" | ||||
|   password-updated: "암호는 현재 \"{password}\" 입니다" | ||||
|   reset-password: "비밀번호 재설정" | ||||
|   reset-password-confirm: "비밀번호를 재설정하시겠습니까?" | ||||
|   password-updated: "비밀번호는 현재 \"{password}\" 입니다" | ||||
|   suspend: "정지" | ||||
|   suspend-confirm: "정지하시겠습니까?" | ||||
|   suspended: "정지하였습니다" | ||||
|   unsuspend: "정지 해제" | ||||
|   unsuspend-confirm: "정지를 해제하시겠습니까?" | ||||
|   unsuspended: "정지를 해제하였습니다" | ||||
|   make-silence: "침묵" | ||||
|   unmake-silence: "침묵 해제" | ||||
|   verify: "공식 계정으로 설정" | ||||
|   verify-confirm: "공식 계정으로 설정하시겠습니까?" | ||||
|   verified: "공식 계정으로 설정하였습니다" | ||||
|   unverify: "공식 계정 해제" | ||||
|   unverify-confirm: "공식 계정을 해제하시겠습니까?" | ||||
|   unverified: "공식 계정을 해제하였습니다" | ||||
|   update-remote-user: "원격 사용자 정보 갱신" | ||||
|   remote-user-updated: "원격 사용자 정보를 갱신하였습니다" | ||||
|   users: | ||||
|     title: "사용자" | ||||
|     sort: | ||||
| @@ -1157,6 +1186,7 @@ admin/views/users.vue: | ||||
|       moderator: "모더레이터" | ||||
|       adminOrModerator: "관리자+모더레이터" | ||||
|       verified: "공식 계정" | ||||
|       silenced: "침묵됨" | ||||
|       suspended: "정지됨" | ||||
|     origin: | ||||
|       title: "위치 (오리진)" | ||||
| @@ -1204,6 +1234,64 @@ admin/views/announcements.vue: | ||||
|     removed: "삭제하였습니다" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| admin/views/federation.vue: | ||||
|   federation: "연합" | ||||
|   host: "호스트" | ||||
|   notes: "글" | ||||
|   users: "사용자" | ||||
|   following: "팔로우 중" | ||||
|   followers: "팔로워" | ||||
|   status: "상태" | ||||
|   latest-request-sent-at: "마지막으로 요청을 전송한 시간" | ||||
|   latest-request-received-at: "마지막으로 요청을 받은 시간" | ||||
|   remove-all-following: "모든 팔로잉 해제" | ||||
|   remove-all-following-info: "{host}(으)로부터 모든 팔로잉을 해제합니다. 해당 인스턴스가 더 이상 존재하지 않게 된 경우 등에 실행하십시오." | ||||
|   block: "차단" | ||||
|   marked-as-closed: "폐쇄된 것으로 표시" | ||||
|   lookup: "조회" | ||||
|   instances: "인스턴스" | ||||
|   instance-not-registered: "해당 인스턴스가 등록되어 있지 않습니다" | ||||
|   sort: "정렬" | ||||
|   sorts: | ||||
|     caughtAtAsc: "등록일이 오래된 순" | ||||
|     caughtAtDesc: "등록일이 최신인 순" | ||||
|     lastCommunicatedAtAsc: "마지막으로 요청을 주고받은 일시가 오래된 순" | ||||
|     lastCommunicatedAtDesc: "마지막으로 요청을 주고받은 일시가 빠른 순" | ||||
|     notesAsc: "글이 적은 순" | ||||
|     notesDesc: "글이 많은 순" | ||||
|     usersAsc: "사용자가 적은 순" | ||||
|     usersDesc: "사용자가 많은 순" | ||||
|     followingAsc: "팔로잉이 적은 순" | ||||
|     followingDesc: "팔로잉이 많은 순" | ||||
|     followersAsc: "팔로워가 적은 순" | ||||
|     followersDesc: "팔로워가 많은 순" | ||||
|     driveUsageAsc: "드라이브 사용량이 적은 순" | ||||
|     driveUsageDesc: "드라이브 사용량이 많은 순" | ||||
|     driveFilesAsc: "드라이브 파일 수가 적은 순" | ||||
|     driveFilesDesc: "드라이브 파일 수가 많은 순" | ||||
|   state: "상태" | ||||
|   states: | ||||
|     all: "모두" | ||||
|     blocked: "차단됨" | ||||
|     not-responding: "응답 없음" | ||||
|     marked-as-closed: "폐쇄된 것으로 표시됨" | ||||
|   result-is-truncated: "상위 {n}개를 표시하고 있습니다." | ||||
|   charts: "차트" | ||||
|   chart-srcs: | ||||
|     requests: "요청" | ||||
|     users: "사용자 증감" | ||||
|     users-total: "사용자 누적" | ||||
|     notes: "글 증감" | ||||
|     notes-total: "글 누적" | ||||
|     ff: "팔로잉/팔로워 증감" | ||||
|     ff-total: "팔로잉/팔로워 누적" | ||||
|     drive-usage: "드라이브 사용량 증감" | ||||
|     drive-usage-total: "드라이브 사용량 누적" | ||||
|     drive-files: "드라이브 파일 수 증감" | ||||
|     drive-files-total: "드라이브 파일 수 누적" | ||||
|   chart-spans: | ||||
|     hour: "1시간마다" | ||||
|     day: "1일마다" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "자세히..." | ||||
|   gotit: "알겠습니다" | ||||
| @@ -1253,7 +1341,7 @@ desktop/views/pages/user/user.photos.vue: | ||||
|   no-photos: "사진이 없습니다" | ||||
| desktop/views/pages/user/user.profile.vue: | ||||
|   follows-you: "당신을 팔로우합니다" | ||||
|   menu: "メニュー" | ||||
|   menu: "메뉴" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
|   posts: "글" | ||||
|   following: "팔로잉" | ||||
| @@ -1321,9 +1409,6 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   nsfw: "열람주의" | ||||
|   mark-as-sensitive: "열람주의로 설정" | ||||
|   unmark-as-sensitive: "열람주의 해제" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "열람주의" | ||||
|   click-to-show: "클릭하여 표시" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "열람주의" | ||||
|   click-to-show: "클릭하여 표시" | ||||
| @@ -1468,6 +1553,7 @@ mobile/views/pages/settings.vue: | ||||
|   notification-position-top: "위" | ||||
|   behavior: "동작" | ||||
|   fetch-on-scroll: "스크롤하여 자동으로 불러오기" | ||||
|   keep-cw: "CW 유지" | ||||
|   note-visibility: "게시물의 공개 범위" | ||||
|   default-note-visibility: "기본 공개 범위" | ||||
|   remember-note-visibility: "글의 공개 범위를 기억하기" | ||||
| @@ -1541,6 +1627,7 @@ deck/deck.tl-column.vue: | ||||
|   is-media-view: "미디어 보기" | ||||
|   edit: "옵션" | ||||
| deck/deck.user-column.vue: | ||||
|   follows-you: "당신을 팔로우합니다" | ||||
|   posts: "글" | ||||
|   following: "팔로잉" | ||||
|   followers: "팔로워" | ||||
|   | ||||
| @@ -113,6 +113,7 @@ common: | ||||
|   use-avatar-reversi-stones: "リバーシの石にアバターを使う" | ||||
|   verified-user: "公式アカウント" | ||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||
|   disable-showing-animated-images: "アニメーション画像を再生しない" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
| @@ -129,7 +130,7 @@ common: | ||||
|   show-password: "パスワードを表示する" | ||||
|   do-not-use-in-production: "これは開発ビルドです。本番環境で使用しないでください。" | ||||
|   user-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-user: "このユーザー情報は不正確な可能性があります。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|   renoted-by: "{user}がRenote" | ||||
| @@ -344,6 +345,8 @@ common/views/components/note-menu.vue: | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "Deze notitie toevoegen aan favorieten" | ||||
|   unfavorite: "お気に入り解除" | ||||
|   watch: "ウォッチ" | ||||
|   unwatch: "ウォッチ解除" | ||||
|   pin: "Vastmaken aan profielpagina" | ||||
|   unpin: "ピン留め解除" | ||||
|   delete: "削除" | ||||
| @@ -357,10 +360,13 @@ common/views/components/user-menu.vue: | ||||
|   unblock: "ブロック解除" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
|   report-abuse: "スパムを報告" | ||||
|   report-abuse-detail: "どのような迷惑行為を行っていますか?" | ||||
|   report-abuse-reported: "管理者に報告されました。ご協力ありがとうございました。" | ||||
|   silence: "サイレンス" | ||||
|   unsilence: "サイレンス解除" | ||||
|   suspend: "凍結" | ||||
|   unsuspend: "凍結解除" | ||||
| common/views/components/poll.vue: | ||||
|   vote-to: "Stemmen op '{}'" | ||||
|   vote-count: "{} stemmen" | ||||
| @@ -483,6 +489,7 @@ common/views/components/profile-editor.vue: | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   you-can-include-hashtags: "ハッシュタグを含めることができます。" | ||||
|   language: "言語" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
| @@ -502,6 +509,13 @@ common/views/components/profile-editor.vue: | ||||
|   email-address: "メールアドレス" | ||||
|   email-verified: "メールアドレスが確認されました" | ||||
|   email-not-verified: "メールアドレスが確認されていません。メールボックスをご確認ください。" | ||||
|   export: "エクスポート" | ||||
|   export-targets: | ||||
|     all-notes: "すべての投稿データ" | ||||
|     following-list: "フォロー" | ||||
|     mute-list: "ミュート" | ||||
|     blocking-list: "ブロック" | ||||
|   export-requested: "エクスポートをリクエストしました。これには時間がかかる場合があります。エクスポートが終わると、ドライブにファイルが追加されます。" | ||||
| common/views/components/user-list-editor.vue: | ||||
|   users: "ユーザー" | ||||
|   rename: "リスト名を変更" | ||||
| @@ -659,9 +673,6 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "Map creëren" | ||||
|     upload: "Bestand uploaden" | ||||
|     url-upload: "Uploaden via URL" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -789,6 +800,8 @@ desktop/views/components/settings.vue: | ||||
|   auto-popout-desc: "Venster uitvouwen, indien mogelijk. Deze instelling wordt opgeslagen in je browser." | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   keep-cw: "CW保持" | ||||
|   keep-cw-desc: "投稿にリプライする際、リプライ元の投稿にCWが設定されていたとき、デフォルトで同じCWを設定するようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "Ontwerp en weergave" | ||||
|   customize: "Startpagina aanpassen" | ||||
| @@ -874,6 +887,9 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "Instellen voltooid!" | ||||
|   failed: "Instellen mislukt. Zorg ervoor dat de sleutel juist is." | ||||
|   info: "Vanaf nu moet je ook de op je apparaat getoonde sleutel tonen bij het inloggen op Misskey." | ||||
| common/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
| @@ -991,6 +1007,7 @@ admin/views/index.vue: | ||||
|   announcements: "お知らせ" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   abuse: "スパム報告" | ||||
|   queue: "ジョブキュー" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
| @@ -1000,6 +1017,9 @@ admin/views/dashboard.vue: | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "このインスタンス" | ||||
|   federated: "連合" | ||||
| admin/views/queue.vue: | ||||
|   operation: "操作" | ||||
|   remove-all-jobs: "すべてのジョブをクリア" | ||||
| admin/views/abuse.vue: | ||||
|   title: "スパム報告" | ||||
|   target: "対象" | ||||
| @@ -1133,15 +1153,24 @@ admin/views/users.vue: | ||||
|   user-not-found: "ユーザーが見つかりません" | ||||
|   lookup: "照会" | ||||
|   reset-password: "パスワードをリセット" | ||||
|   reset-password-confirm: "パスワードをリセットしますか?" | ||||
|   password-updated: "パスワードは現在「{password}」です" | ||||
|   suspend: "凍結" | ||||
|   suspend-confirm: "凍結しますか?" | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspend-confirm: "凍結を解除しますか?" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   make-silence: "サイレンス" | ||||
|   unmake-silence: "サイレンスの解除" | ||||
|   verify: "公式アカウントにする" | ||||
|   verify-confirm: "公式アカウントにしますか?" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverify-confirm: "公式アカウントを解除しますか?" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|   update-remote-user: "リモートユーザー情報の更新" | ||||
|   remote-user-updated: "リモートユーザー情報を更新しました" | ||||
|   users: | ||||
|     title: "ユーザー" | ||||
|     sort: | ||||
| @@ -1157,6 +1186,7 @@ admin/views/users.vue: | ||||
|       moderator: "モデレーター" | ||||
|       adminOrModerator: "管理者+モデレーター" | ||||
|       verified: "公式アカウント" | ||||
|       silenced: "サイレンス済み" | ||||
|       suspended: "凍結済み" | ||||
|     origin: | ||||
|       title: "オリジン" | ||||
| @@ -1204,6 +1234,64 @@ admin/views/announcements.vue: | ||||
|     removed: "削除しました" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| admin/views/federation.vue: | ||||
|   federation: "連合" | ||||
|   host: "ホスト" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   following: "フォロー中" | ||||
|   followers: "フォロワー" | ||||
|   status: "ステータス" | ||||
|   latest-request-sent-at: "直近のリクエスト送信" | ||||
|   latest-request-received-at: "直近のリクエスト受信" | ||||
|   remove-all-following: "フォローを全解除" | ||||
|   remove-all-following-info: "{host}からのフォローをすべて解除します。そのインスタンスがもう存在しなくなった場合などに実行してください。" | ||||
|   block: "ブロック" | ||||
|   marked-as-closed: "閉鎖されているとマーク" | ||||
|   lookup: "照会" | ||||
|   instances: "インスタンス" | ||||
|   instance-not-registered: "そのインスタンスは登録されていません" | ||||
|   sort: "ソート" | ||||
|   sorts: | ||||
|     caughtAtAsc: "登録日時が古い順" | ||||
|     caughtAtDesc: "登録日時が新しい順" | ||||
|     lastCommunicatedAtAsc: "最後にやり取りした日時が古い順" | ||||
|     lastCommunicatedAtDesc: "最後にやり取りした日時が新しい順" | ||||
|     notesAsc: "投稿が少ない順" | ||||
|     notesDesc: "投稿が多い順" | ||||
|     usersAsc: "ユーザーが少ない順" | ||||
|     usersDesc: "ユーザーが多い順" | ||||
|     followingAsc: "フォローが少ない順" | ||||
|     followingDesc: "フォローが多い順" | ||||
|     followersAsc: "フォロワーが少ない順" | ||||
|     followersDesc: "フォロワーが多い順" | ||||
|     driveUsageAsc: "ドライブ使用量が少ない順" | ||||
|     driveUsageDesc: "ドライブ使用量が多い順" | ||||
|     driveFilesAsc: "ドライブのファイル数が少ない順" | ||||
|     driveFilesDesc: "ドライブのファイル数が多い順" | ||||
|   state: "状態" | ||||
|   states: | ||||
|     all: "すべて" | ||||
|     blocked: "ブロック" | ||||
|     not-responding: "応答なし" | ||||
|     marked-as-closed: "閉鎖とマーク済み" | ||||
|   result-is-truncated: "上位{n}件を表示しています。" | ||||
|   charts: "チャート" | ||||
|   chart-srcs: | ||||
|     requests: "リクエスト" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     notes: "投稿の増減" | ||||
|     notes-total: "投稿の積算" | ||||
|     ff: "フォロー/フォロワーの増減" | ||||
|     ff-total: "フォロー/フォロワーの積算" | ||||
|     drive-usage: "ドライブ使用量の増減" | ||||
|     drive-usage-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブファイル数の増減" | ||||
|     drive-files-total: "ドライブファイル数の積算" | ||||
|   chart-spans: | ||||
|     hour: "1時間ごと" | ||||
|     day: "1日ごと" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "詳しく..." | ||||
|   gotit: "わかった" | ||||
| @@ -1321,9 +1409,6 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   nsfw: "閲覧注意" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -1468,6 +1553,7 @@ mobile/views/pages/settings.vue: | ||||
|   notification-position-top: "上" | ||||
|   behavior: "Gedrag" | ||||
|   fetch-on-scroll: "Ophalen bij scrollen" | ||||
|   keep-cw: "CW保持" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
| @@ -1541,6 +1627,7 @@ deck/deck.tl-column.vue: | ||||
|   is-media-view: "メディアビュー" | ||||
|   edit: "オプション" | ||||
| deck/deck.user-column.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   | ||||
| @@ -113,6 +113,7 @@ common: | ||||
|   use-avatar-reversi-stones: "リバーシの石にアバターを使う" | ||||
|   verified-user: "公式アカウント" | ||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||
|   disable-showing-animated-images: "アニメーション画像を再生しない" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
| @@ -129,7 +130,7 @@ common: | ||||
|   show-password: "パスワードを表示する" | ||||
|   do-not-use-in-production: "これは開発ビルドです。本番環境で使用しないでください。" | ||||
|   user-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-user: "このユーザー情報は不正確な可能性があります。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|   renoted-by: "{user}がRenote" | ||||
| @@ -344,6 +345,8 @@ common/views/components/note-menu.vue: | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "Merket som favoritt" | ||||
|   unfavorite: "お気に入り解除" | ||||
|   watch: "ウォッチ" | ||||
|   unwatch: "ウォッチ解除" | ||||
|   pin: "Fest til profilen din" | ||||
|   unpin: "ピン留め解除" | ||||
|   delete: "Slett" | ||||
| @@ -357,10 +360,13 @@ common/views/components/user-menu.vue: | ||||
|   unblock: "ブロック解除" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
|   report-abuse: "スパムを報告" | ||||
|   report-abuse-detail: "どのような迷惑行為を行っていますか?" | ||||
|   report-abuse-reported: "管理者に報告されました。ご協力ありがとうございました。" | ||||
|   silence: "サイレンス" | ||||
|   unsilence: "サイレンス解除" | ||||
|   suspend: "凍結" | ||||
|   unsuspend: "凍結解除" | ||||
| common/views/components/poll.vue: | ||||
|   vote-to: "「{}」に投票する" | ||||
|   vote-count: "{} stemmer" | ||||
| @@ -483,6 +489,7 @@ common/views/components/profile-editor.vue: | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   you-can-include-hashtags: "ハッシュタグを含めることができます。" | ||||
|   language: "言語" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
| @@ -502,6 +509,13 @@ common/views/components/profile-editor.vue: | ||||
|   email-address: "メールアドレス" | ||||
|   email-verified: "メールアドレスが確認されました" | ||||
|   email-not-verified: "メールアドレスが確認されていません。メールボックスをご確認ください。" | ||||
|   export: "エクスポート" | ||||
|   export-targets: | ||||
|     all-notes: "すべての投稿データ" | ||||
|     following-list: "フォロー" | ||||
|     mute-list: "ミュート" | ||||
|     blocking-list: "ブロック" | ||||
|   export-requested: "エクスポートをリクエストしました。これには時間がかかる場合があります。エクスポートが終わると、ドライブにファイルが追加されます。" | ||||
| common/views/components/user-list-editor.vue: | ||||
|   users: "ユーザー" | ||||
|   rename: "リスト名を変更" | ||||
| @@ -659,9 +673,6 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "フォルダーを作成" | ||||
|     upload: "ファイルをアップロード" | ||||
|     url-upload: "URLからアップロード" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "NSFW" | ||||
|   click-to-show: "クリックして表示" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "Innholdet er NSFW" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -789,6 +800,8 @@ desktop/views/components/settings.vue: | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   keep-cw: "CW保持" | ||||
|   keep-cw-desc: "投稿にリプライする際、リプライ元の投稿にCWが設定されていたとき、デフォルトで同じCWを設定するようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "デザインと表示" | ||||
|   customize: "ホームをカスタマイズ" | ||||
| @@ -874,6 +887,9 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "設定が完了しました!" | ||||
|   failed: "設定に失敗しました。トークンに誤りがないかご確認ください。" | ||||
|   info: "次回サインインからは、同様にパスワードに加えてデバイスに表示されているトークンを入力します。" | ||||
| common/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
| @@ -991,6 +1007,7 @@ admin/views/index.vue: | ||||
|   announcements: "お知らせ" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   abuse: "スパム報告" | ||||
|   queue: "ジョブキュー" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
| @@ -1000,6 +1017,9 @@ admin/views/dashboard.vue: | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "このインスタンス" | ||||
|   federated: "連合" | ||||
| admin/views/queue.vue: | ||||
|   operation: "操作" | ||||
|   remove-all-jobs: "すべてのジョブをクリア" | ||||
| admin/views/abuse.vue: | ||||
|   title: "スパム報告" | ||||
|   target: "対象" | ||||
| @@ -1133,15 +1153,24 @@ admin/views/users.vue: | ||||
|   user-not-found: "ユーザーが見つかりません" | ||||
|   lookup: "照会" | ||||
|   reset-password: "パスワードをリセット" | ||||
|   reset-password-confirm: "パスワードをリセットしますか?" | ||||
|   password-updated: "パスワードは現在「{password}」です" | ||||
|   suspend: "凍結" | ||||
|   suspend-confirm: "凍結しますか?" | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspend-confirm: "凍結を解除しますか?" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   make-silence: "サイレンス" | ||||
|   unmake-silence: "サイレンスの解除" | ||||
|   verify: "公式アカウントにする" | ||||
|   verify-confirm: "公式アカウントにしますか?" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverify-confirm: "公式アカウントを解除しますか?" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|   update-remote-user: "リモートユーザー情報の更新" | ||||
|   remote-user-updated: "リモートユーザー情報を更新しました" | ||||
|   users: | ||||
|     title: "ユーザー" | ||||
|     sort: | ||||
| @@ -1157,6 +1186,7 @@ admin/views/users.vue: | ||||
|       moderator: "モデレーター" | ||||
|       adminOrModerator: "管理者+モデレーター" | ||||
|       verified: "公式アカウント" | ||||
|       silenced: "サイレンス済み" | ||||
|       suspended: "凍結済み" | ||||
|     origin: | ||||
|       title: "オリジン" | ||||
| @@ -1204,6 +1234,64 @@ admin/views/announcements.vue: | ||||
|     removed: "削除しました" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| admin/views/federation.vue: | ||||
|   federation: "連合" | ||||
|   host: "ホスト" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   following: "フォロー中" | ||||
|   followers: "フォロワー" | ||||
|   status: "ステータス" | ||||
|   latest-request-sent-at: "直近のリクエスト送信" | ||||
|   latest-request-received-at: "直近のリクエスト受信" | ||||
|   remove-all-following: "フォローを全解除" | ||||
|   remove-all-following-info: "{host}からのフォローをすべて解除します。そのインスタンスがもう存在しなくなった場合などに実行してください。" | ||||
|   block: "ブロック" | ||||
|   marked-as-closed: "閉鎖されているとマーク" | ||||
|   lookup: "照会" | ||||
|   instances: "インスタンス" | ||||
|   instance-not-registered: "そのインスタンスは登録されていません" | ||||
|   sort: "ソート" | ||||
|   sorts: | ||||
|     caughtAtAsc: "登録日時が古い順" | ||||
|     caughtAtDesc: "登録日時が新しい順" | ||||
|     lastCommunicatedAtAsc: "最後にやり取りした日時が古い順" | ||||
|     lastCommunicatedAtDesc: "最後にやり取りした日時が新しい順" | ||||
|     notesAsc: "投稿が少ない順" | ||||
|     notesDesc: "投稿が多い順" | ||||
|     usersAsc: "ユーザーが少ない順" | ||||
|     usersDesc: "ユーザーが多い順" | ||||
|     followingAsc: "フォローが少ない順" | ||||
|     followingDesc: "フォローが多い順" | ||||
|     followersAsc: "フォロワーが少ない順" | ||||
|     followersDesc: "フォロワーが多い順" | ||||
|     driveUsageAsc: "ドライブ使用量が少ない順" | ||||
|     driveUsageDesc: "ドライブ使用量が多い順" | ||||
|     driveFilesAsc: "ドライブのファイル数が少ない順" | ||||
|     driveFilesDesc: "ドライブのファイル数が多い順" | ||||
|   state: "状態" | ||||
|   states: | ||||
|     all: "すべて" | ||||
|     blocked: "ブロック" | ||||
|     not-responding: "応答なし" | ||||
|     marked-as-closed: "閉鎖とマーク済み" | ||||
|   result-is-truncated: "上位{n}件を表示しています。" | ||||
|   charts: "チャート" | ||||
|   chart-srcs: | ||||
|     requests: "リクエスト" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     notes: "投稿の増減" | ||||
|     notes-total: "投稿の積算" | ||||
|     ff: "フォロー/フォロワーの増減" | ||||
|     ff-total: "フォロー/フォロワーの積算" | ||||
|     drive-usage: "ドライブ使用量の増減" | ||||
|     drive-usage-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブファイル数の増減" | ||||
|     drive-files-total: "ドライブファイル数の積算" | ||||
|   chart-spans: | ||||
|     hour: "1時間ごと" | ||||
|     day: "1日ごと" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "詳しく..." | ||||
|   gotit: "Skjønner!" | ||||
| @@ -1321,9 +1409,6 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   nsfw: "NSFW" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "NSFW" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "Innholdet er NSFW" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -1468,6 +1553,7 @@ mobile/views/pages/settings.vue: | ||||
|   notification-position-top: "Topp" | ||||
|   behavior: "Oppførsel" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   keep-cw: "CW保持" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
| @@ -1505,13 +1591,13 @@ mobile/views/pages/user/home.vue: | ||||
|   activity: "アクティビティ" | ||||
|   keywords: "Nøkkelord" | ||||
|   domains: "頻出ドメイン" | ||||
|   frequently-replied-users: "よく会話するユーザー" | ||||
|   frequently-replied-users: "よく話すユーザー" | ||||
|   followers-you-know: "知り合いのフォロワー" | ||||
|   last-used-at: "最終ログイン" | ||||
| mobile/views/pages/user/home.followers-you-know.vue: | ||||
|   no-users: "知り合いのユーザーはいません" | ||||
| mobile/views/pages/user/home.friends.vue: | ||||
|   no-users: "よく会話するユーザーはいません" | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| mobile/views/pages/user/home.notes.vue: | ||||
|   no-notes: "投稿はありません" | ||||
| mobile/views/pages/user/home.photos.vue: | ||||
| @@ -1541,6 +1627,7 @@ deck/deck.tl-column.vue: | ||||
|   is-media-view: "メディアビュー" | ||||
|   edit: "オプション" | ||||
| deck/deck.user-column.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   | ||||
| @@ -27,7 +27,7 @@ common: | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   load-more: "Załaduj więcej" | ||||
|   enter-password: "Wprowadź Hasło" | ||||
|   2fa: "二段階認証" | ||||
|   2fa: "Uwierzytelnienie dwuetapowe" | ||||
|   got-it: "Rozumiem!" | ||||
|   customization-tips: | ||||
|     title: "Wskazówki o dostosowywaniu" | ||||
| @@ -113,6 +113,7 @@ common: | ||||
|   use-avatar-reversi-stones: "リバーシの石にアバターを使う" | ||||
|   verified-user: "Zweryfikowane konto" | ||||
|   disable-animated-mfm: "Wyłącz animowany tekst we wpisach" | ||||
|   disable-showing-animated-images: "アニメーション画像を再生しない" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "Zawszę pokazuj zawartość NSFW" | ||||
|   always-mark-nsfw: "Zawsze oznaczaj posty z multimediami jako NSFW" | ||||
| @@ -129,7 +130,7 @@ common: | ||||
|   show-password: "Pokaż hasło" | ||||
|   do-not-use-in-production: "これは開発ビルドです。本番環境で使用しないでください。" | ||||
|   user-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote-user: "Informacje o użytkowniku są kopiowane." | ||||
|   is-remote-user: "このユーザー情報は不正確な可能性があります。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "Dla dopełnienia, zobacz to zdalnie." | ||||
|   renoted-by: "{user} udostępnił(a)" | ||||
| @@ -344,23 +345,28 @@ common/views/components/note-menu.vue: | ||||
|   copy-link: "Skopiuj adres" | ||||
|   favorite: "Dodaj do ulubionych" | ||||
|   unfavorite: "Usuń z ulubionych" | ||||
|   watch: "ウォッチ" | ||||
|   unwatch: "ウォッチ解除" | ||||
|   pin: "Przypnij do profilu" | ||||
|   unpin: "Odepnij" | ||||
|   delete: "Usuń" | ||||
|   delete-confirm: "Czy na pewno chcesz usunąć ten wpis?" | ||||
|   remote: "Pokaż oryginał" | ||||
| common/views/components/user-menu.vue: | ||||
|   mention: "メンション" | ||||
|   mute: "ミュート" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
|   report-abuse: "スパムを報告" | ||||
|   mention: "Wspomnij" | ||||
|   mute: "Wycisz" | ||||
|   unmute: "Cofnij wyciszenie" | ||||
|   block: "Zablokuj" | ||||
|   unblock: "Odblokuj" | ||||
|   push-to-list: "Dodaj do listy" | ||||
|   select-list: "Wybierz listę" | ||||
|   report-abuse: "Zgłoś nadużycie" | ||||
|   report-abuse-detail: "どのような迷惑行為を行っていますか?" | ||||
|   report-abuse-reported: "管理者に報告されました。ご協力ありがとうございました。" | ||||
|   silence: "サイレンス" | ||||
|   unsilence: "サイレンス解除" | ||||
|   suspend: "凍結" | ||||
|   unsuspend: "凍結解除" | ||||
| common/views/components/poll.vue: | ||||
|   vote-to: "Zagłosuj na '{}'" | ||||
|   vote-count: "{} głosów" | ||||
| @@ -392,11 +398,11 @@ common/views/components/signin.vue: | ||||
|   token: "Token" | ||||
|   signing-in: "Logowanie…" | ||||
|   signin: "Zaloguj" | ||||
|   or: "または" | ||||
|   or: "lub" | ||||
|   signin-with-twitter: "Zaloguj się za pomocą Twittera" | ||||
|   signin-with-github: "Zaloguj się za pomocą GitHuba" | ||||
|   signin-with-discord: "Zaloguj się za pomocą Discorda" | ||||
|   login-failed: "ログインできませんでした。ユーザー名とパスワードを確認してください。" | ||||
|   login-failed: "Logowanie nie powiodło się. Upewnij się, że podałeś prawidłową nazwę użytkownika i hasło." | ||||
| common/views/components/signup.vue: | ||||
|   invitation-code: "Kod zaproszenia" | ||||
|   invitation-info: "招待コードをお持ちでない方は、<a href=\"{}\">管理者</a>までご連絡ください。" | ||||
| @@ -469,13 +475,13 @@ common/views/components/visibility-chooser.vue: | ||||
|   local-followers: "Dla śledzących (tylko lokalnie)" | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
|   empty: "Brak popularnych hashtagów" | ||||
| common/views/components/language-settings.vue: | ||||
|   title: "Język" | ||||
|   pick-language: "Wybierz język" | ||||
|   recommended: "Zalecane" | ||||
|   auto: "Automatyczny" | ||||
|   specify-language: "言語を指定" | ||||
|   specify-language: "Wybierz język" | ||||
|   info: "Musisz odświeżyć stronę, aby zmiany zostały uwzględnione." | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "Twój profil" | ||||
| @@ -483,6 +489,7 @@ common/views/components/profile-editor.vue: | ||||
|   account: "Konto" | ||||
|   location: "Lokalizacja" | ||||
|   description: "O mnie" | ||||
|   you-can-include-hashtags: "ハッシュタグを含めることができます。" | ||||
|   language: "Język" | ||||
|   birthday: "Data urodzenia" | ||||
|   avatar: "Awatar" | ||||
| @@ -500,15 +507,22 @@ common/views/components/profile-editor.vue: | ||||
|   upload-failed: "Wysyłanie nie powiodło się" | ||||
|   email: "Ustawienia e-mail" | ||||
|   email-address: "Adres e-mail" | ||||
|   email-verified: "メールアドレスが確認されました" | ||||
|   email-verified: "Twój adres e-mail został zweryfikowany." | ||||
|   email-not-verified: "メールアドレスが確認されていません。メールボックスをご確認ください。" | ||||
|   export: "エクスポート" | ||||
|   export-targets: | ||||
|     all-notes: "すべての投稿データ" | ||||
|     following-list: "フォロー" | ||||
|     mute-list: "ミュート" | ||||
|     blocking-list: "ブロック" | ||||
|   export-requested: "エクスポートをリクエストしました。これには時間がかかる場合があります。エクスポートが終わると、ドライブにファイルが追加されます。" | ||||
| common/views/components/user-list-editor.vue: | ||||
|   users: "Użytkownicy" | ||||
|   rename: "Zmień nazwę listy" | ||||
|   delete: "Usuń listę" | ||||
|   remove-user: "Usuń z tej listy" | ||||
|   delete-are-you-sure: "リスト「$1」を削除しますか?" | ||||
|   deleted: "削除しました" | ||||
|   delete-are-you-sure: "Usunąć listę \"$1\"?" | ||||
|   deleted: "Usunięto" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "Sprawdzanie" | ||||
|   no-broadcasts: "Brak transmisji" | ||||
| @@ -591,7 +605,7 @@ desktop/views/components/activity.vue: | ||||
|   title: "Aktywność" | ||||
|   toggle: "Przełącz widok" | ||||
| desktop/views/components/calendar.vue: | ||||
|   title: "{year}年 {month}月" | ||||
|   title: "{year} / {month}" | ||||
|   prev: "Poprzedni miesiąc" | ||||
|   next: "Następny miesiąc" | ||||
|   go: "Naciśnij, aby przejść" | ||||
| @@ -659,9 +673,6 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "Utwórz katalog" | ||||
|     upload: "Wyślij plik" | ||||
|     url-upload: "Wyślij z adresu URL" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "To jest zawartość NSFW" | ||||
|   click-to-show: "Naciśnij aby wyświetlić" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "To jest zawartość NSFW" | ||||
|   click-to-show: "Naciśnij aby wyświetlić" | ||||
| @@ -705,7 +716,7 @@ desktop/views/components/note.vue: | ||||
|   add-reaction: "Dodaj reakcję" | ||||
|   undo-reaction: "リアクション解除" | ||||
|   detail: "Szczegóły" | ||||
|   private: "この投稿は非公開です" | ||||
|   private: "Ten wpis jest prywatny" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "Ładowanie nie powiodło się." | ||||
| @@ -789,6 +800,8 @@ desktop/views/components/settings.vue: | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   keep-cw: "CW保持" | ||||
|   keep-cw-desc: "投稿にリプライする際、リプライ元の投稿にCWが設定されていたとき、デフォルトで同じCWを設定するようにします。" | ||||
|   deck-default: "Użyj Talię jako domyślne UI" | ||||
|   display: "Wygląd i wyświetlanie" | ||||
|   customize: "Dostosuj stronę główną" | ||||
| @@ -867,13 +880,16 @@ desktop/views/components/settings.2fa.vue: | ||||
|   enter-password: "Wprowadź hasło" | ||||
|   authenticator: "Na początek musisz zainstalować Google Authenticator na swoim urządzeniu:" | ||||
|   howtoinstall: "Jak zainstalować" | ||||
|   token: "トークン" | ||||
|   token: "Token" | ||||
|   scan: "Później, zeskanuje ten kod QR:" | ||||
|   done: "Wprowadź token wyświetlony na Twoim urządzeniu:" | ||||
|   submit: "Wyślij" | ||||
|   success: "Pomyślnie ukończono konfigurację!" | ||||
|   failed: "Nie udało się skonfigurować uwierzytelniania dwuetapowego, upewnij się że wprowadziłeś prawidłowy token." | ||||
|   info: "Od teraz, wprowadzaj token wyświetlany na urządzeniu przy każdym logowaniu do Misskey." | ||||
| common/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "Aby uzyskać dostęp do API, ustaw ten token jako klucz 'i' parametrów żądań." | ||||
|   caution: "Nie pokazuj tego tokenu osobom trzecim (nie wprowadzaj go nigdzie indziej), aby konto nie trafiło w niepowołane ręce." | ||||
| @@ -991,6 +1007,7 @@ admin/views/index.vue: | ||||
|   announcements: "Ogłoszenia" | ||||
|   hashtags: "Hashtagi" | ||||
|   abuse: "スパム報告" | ||||
|   queue: "ジョブキュー" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
| @@ -1000,12 +1017,15 @@ admin/views/dashboard.vue: | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "このインスタンス" | ||||
|   federated: "連合" | ||||
| admin/views/queue.vue: | ||||
|   operation: "操作" | ||||
|   remove-all-jobs: "すべてのジョブをクリア" | ||||
| admin/views/abuse.vue: | ||||
|   title: "スパム報告" | ||||
|   target: "対象" | ||||
|   reporter: "報告者" | ||||
|   details: "詳細" | ||||
|   remove-report: "削除" | ||||
|   remove-report: "Usuń" | ||||
| admin/views/instance.vue: | ||||
|   instance: "インスタンス" | ||||
|   instance-name: "インスタンス名" | ||||
| @@ -1133,15 +1153,24 @@ admin/views/users.vue: | ||||
|   user-not-found: "Nie znaleziono użytkownika" | ||||
|   lookup: "照会" | ||||
|   reset-password: "パスワードをリセット" | ||||
|   reset-password-confirm: "パスワードをリセットしますか?" | ||||
|   password-updated: "パスワードは現在「{password}」です" | ||||
|   suspend: "凍結" | ||||
|   suspend-confirm: "凍結しますか?" | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspend-confirm: "凍結を解除しますか?" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   make-silence: "サイレンス" | ||||
|   unmake-silence: "サイレンスの解除" | ||||
|   verify: "公式アカウントにする" | ||||
|   verify-confirm: "公式アカウントにしますか?" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverify-confirm: "公式アカウントを解除しますか?" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|   update-remote-user: "リモートユーザー情報の更新" | ||||
|   remote-user-updated: "リモートユーザー情報を更新しました" | ||||
|   users: | ||||
|     title: "Użytkownicy" | ||||
|     sort: | ||||
| @@ -1157,6 +1186,7 @@ admin/views/users.vue: | ||||
|       moderator: "モデレーター" | ||||
|       adminOrModerator: "管理者+モデレーター" | ||||
|       verified: "公式アカウント" | ||||
|       silenced: "サイレンス済み" | ||||
|       suspended: "凍結済み" | ||||
|     origin: | ||||
|       title: "Źródło" | ||||
| @@ -1204,6 +1234,64 @@ admin/views/announcements.vue: | ||||
|     removed: "Usunięto" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| admin/views/federation.vue: | ||||
|   federation: "連合" | ||||
|   host: "ホスト" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   following: "フォロー中" | ||||
|   followers: "フォロワー" | ||||
|   status: "ステータス" | ||||
|   latest-request-sent-at: "直近のリクエスト送信" | ||||
|   latest-request-received-at: "直近のリクエスト受信" | ||||
|   remove-all-following: "フォローを全解除" | ||||
|   remove-all-following-info: "{host}からのフォローをすべて解除します。そのインスタンスがもう存在しなくなった場合などに実行してください。" | ||||
|   block: "ブロック" | ||||
|   marked-as-closed: "閉鎖されているとマーク" | ||||
|   lookup: "照会" | ||||
|   instances: "インスタンス" | ||||
|   instance-not-registered: "そのインスタンスは登録されていません" | ||||
|   sort: "ソート" | ||||
|   sorts: | ||||
|     caughtAtAsc: "登録日時が古い順" | ||||
|     caughtAtDesc: "登録日時が新しい順" | ||||
|     lastCommunicatedAtAsc: "最後にやり取りした日時が古い順" | ||||
|     lastCommunicatedAtDesc: "最後にやり取りした日時が新しい順" | ||||
|     notesAsc: "投稿が少ない順" | ||||
|     notesDesc: "投稿が多い順" | ||||
|     usersAsc: "ユーザーが少ない順" | ||||
|     usersDesc: "ユーザーが多い順" | ||||
|     followingAsc: "フォローが少ない順" | ||||
|     followingDesc: "フォローが多い順" | ||||
|     followersAsc: "フォロワーが少ない順" | ||||
|     followersDesc: "フォロワーが多い順" | ||||
|     driveUsageAsc: "ドライブ使用量が少ない順" | ||||
|     driveUsageDesc: "ドライブ使用量が多い順" | ||||
|     driveFilesAsc: "ドライブのファイル数が少ない順" | ||||
|     driveFilesDesc: "ドライブのファイル数が多い順" | ||||
|   state: "状態" | ||||
|   states: | ||||
|     all: "すべて" | ||||
|     blocked: "ブロック" | ||||
|     not-responding: "応答なし" | ||||
|     marked-as-closed: "閉鎖とマーク済み" | ||||
|   result-is-truncated: "上位{n}件を表示しています。" | ||||
|   charts: "チャート" | ||||
|   chart-srcs: | ||||
|     requests: "リクエスト" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     notes: "投稿の増減" | ||||
|     notes-total: "投稿の積算" | ||||
|     ff: "フォロー/フォロワーの増減" | ||||
|     ff-total: "フォロー/フォロワーの積算" | ||||
|     drive-usage: "ドライブ使用量の増減" | ||||
|     drive-usage-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブファイル数の増減" | ||||
|     drive-files-total: "ドライブファイル数の積算" | ||||
|   chart-spans: | ||||
|     hour: "1時間ごと" | ||||
|     day: "1日ごと" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "O Misskey" | ||||
|   gotit: "Rozumiem!" | ||||
| @@ -1253,7 +1341,7 @@ desktop/views/pages/user/user.photos.vue: | ||||
|   no-photos: "Brak zdjęć" | ||||
| desktop/views/pages/user/user.profile.vue: | ||||
|   follows-you: "Śledzi Cię" | ||||
|   menu: "メニュー" | ||||
|   menu: "Menu" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
|   posts: "Wpisy" | ||||
|   following: "Śledzeni" | ||||
| @@ -1321,9 +1409,6 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   nsfw: "NSFW" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "To jest zawartość NSFW" | ||||
|   click-to-show: "Naciśnij aby wyświetlić" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "To jest zawartość NSFW" | ||||
|   click-to-show: "Naciśnij aby wyświetlić" | ||||
| @@ -1468,6 +1553,7 @@ mobile/views/pages/settings.vue: | ||||
|   notification-position-top: "Góra" | ||||
|   behavior: "Zachowanie" | ||||
|   fetch-on-scroll: "Automatycznie ładuj po przeciągnięciu w dół" | ||||
|   keep-cw: "CW保持" | ||||
|   note-visibility: "Widoczność wpisów" | ||||
|   default-note-visibility: "Domyślna widoczność" | ||||
|   remember-note-visibility: "Zapamiętaj widoczność wpisów" | ||||
| @@ -1541,6 +1627,7 @@ deck/deck.tl-column.vue: | ||||
|   is-media-view: "Widok multimediów" | ||||
|   edit: "Opcje" | ||||
| deck/deck.user-column.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   posts: "Wpisy" | ||||
|   following: "Śledzeni" | ||||
|   followers: "Śledzący" | ||||
|   | ||||
| @@ -113,6 +113,7 @@ common: | ||||
|   use-avatar-reversi-stones: "リバーシの石にアバターを使う" | ||||
|   verified-user: "Conta verificada" | ||||
|   disable-animated-mfm: "Desativar texto animado nas publicações" | ||||
|   disable-showing-animated-images: "アニメーション画像を再生しない" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
| @@ -129,7 +130,7 @@ common: | ||||
|   show-password: "パスワードを表示する" | ||||
|   do-not-use-in-production: "これは開発ビルドです。本番環境で使用しないでください。" | ||||
|   user-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-user: "このユーザー情報は不正確な可能性があります。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|   renoted-by: "{user}がRenote" | ||||
| @@ -344,6 +345,8 @@ common/views/components/note-menu.vue: | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   unfavorite: "お気に入り解除" | ||||
|   watch: "ウォッチ" | ||||
|   unwatch: "ウォッチ解除" | ||||
|   pin: "ピン留め" | ||||
|   unpin: "ピン留め解除" | ||||
|   delete: "削除" | ||||
| @@ -357,10 +360,13 @@ common/views/components/user-menu.vue: | ||||
|   unblock: "ブロック解除" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
|   report-abuse: "スパムを報告" | ||||
|   report-abuse-detail: "どのような迷惑行為を行っていますか?" | ||||
|   report-abuse-reported: "管理者に報告されました。ご協力ありがとうございました。" | ||||
|   silence: "サイレンス" | ||||
|   unsilence: "サイレンス解除" | ||||
|   suspend: "凍結" | ||||
|   unsuspend: "凍結解除" | ||||
| common/views/components/poll.vue: | ||||
|   vote-to: "「{}」に投票する" | ||||
|   vote-count: "{}票" | ||||
| @@ -483,6 +489,7 @@ common/views/components/profile-editor.vue: | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   you-can-include-hashtags: "ハッシュタグを含めることができます。" | ||||
|   language: "言語" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
| @@ -502,6 +509,13 @@ common/views/components/profile-editor.vue: | ||||
|   email-address: "メールアドレス" | ||||
|   email-verified: "メールアドレスが確認されました" | ||||
|   email-not-verified: "メールアドレスが確認されていません。メールボックスをご確認ください。" | ||||
|   export: "エクスポート" | ||||
|   export-targets: | ||||
|     all-notes: "すべての投稿データ" | ||||
|     following-list: "フォロー" | ||||
|     mute-list: "ミュート" | ||||
|     blocking-list: "ブロック" | ||||
|   export-requested: "エクスポートをリクエストしました。これには時間がかかる場合があります。エクスポートが終わると、ドライブにファイルが追加されます。" | ||||
| common/views/components/user-list-editor.vue: | ||||
|   users: "ユーザー" | ||||
|   rename: "リスト名を変更" | ||||
| @@ -659,9 +673,6 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "フォルダーを作成" | ||||
|     upload: "ファイルをアップロード" | ||||
|     url-upload: "URLからアップロード" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -789,6 +800,8 @@ desktop/views/components/settings.vue: | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   keep-cw: "CW保持" | ||||
|   keep-cw-desc: "投稿にリプライする際、リプライ元の投稿にCWが設定されていたとき、デフォルトで同じCWを設定するようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "デザインと表示" | ||||
|   customize: "ホームをカスタマイズ" | ||||
| @@ -874,6 +887,9 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "設定が完了しました!" | ||||
|   failed: "設定に失敗しました。トークンに誤りがないかご確認ください。" | ||||
|   info: "次回サインインからは、同様にパスワードに加えてデバイスに表示されているトークンを入力します。" | ||||
| common/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
| @@ -991,6 +1007,7 @@ admin/views/index.vue: | ||||
|   announcements: "お知らせ" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   abuse: "スパム報告" | ||||
|   queue: "ジョブキュー" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
| @@ -1000,6 +1017,9 @@ admin/views/dashboard.vue: | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "このインスタンス" | ||||
|   federated: "連合" | ||||
| admin/views/queue.vue: | ||||
|   operation: "操作" | ||||
|   remove-all-jobs: "すべてのジョブをクリア" | ||||
| admin/views/abuse.vue: | ||||
|   title: "スパム報告" | ||||
|   target: "対象" | ||||
| @@ -1133,15 +1153,24 @@ admin/views/users.vue: | ||||
|   user-not-found: "ユーザーが見つかりません" | ||||
|   lookup: "照会" | ||||
|   reset-password: "パスワードをリセット" | ||||
|   reset-password-confirm: "パスワードをリセットしますか?" | ||||
|   password-updated: "パスワードは現在「{password}」です" | ||||
|   suspend: "凍結" | ||||
|   suspend-confirm: "凍結しますか?" | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspend-confirm: "凍結を解除しますか?" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   make-silence: "サイレンス" | ||||
|   unmake-silence: "サイレンスの解除" | ||||
|   verify: "公式アカウントにする" | ||||
|   verify-confirm: "公式アカウントにしますか?" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverify-confirm: "公式アカウントを解除しますか?" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|   update-remote-user: "リモートユーザー情報の更新" | ||||
|   remote-user-updated: "リモートユーザー情報を更新しました" | ||||
|   users: | ||||
|     title: "ユーザー" | ||||
|     sort: | ||||
| @@ -1157,6 +1186,7 @@ admin/views/users.vue: | ||||
|       moderator: "モデレーター" | ||||
|       adminOrModerator: "管理者+モデレーター" | ||||
|       verified: "公式アカウント" | ||||
|       silenced: "サイレンス済み" | ||||
|       suspended: "凍結済み" | ||||
|     origin: | ||||
|       title: "オリジン" | ||||
| @@ -1204,6 +1234,64 @@ admin/views/announcements.vue: | ||||
|     removed: "削除しました" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| admin/views/federation.vue: | ||||
|   federation: "連合" | ||||
|   host: "ホスト" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   following: "フォロー中" | ||||
|   followers: "フォロワー" | ||||
|   status: "ステータス" | ||||
|   latest-request-sent-at: "直近のリクエスト送信" | ||||
|   latest-request-received-at: "直近のリクエスト受信" | ||||
|   remove-all-following: "フォローを全解除" | ||||
|   remove-all-following-info: "{host}からのフォローをすべて解除します。そのインスタンスがもう存在しなくなった場合などに実行してください。" | ||||
|   block: "ブロック" | ||||
|   marked-as-closed: "閉鎖されているとマーク" | ||||
|   lookup: "照会" | ||||
|   instances: "インスタンス" | ||||
|   instance-not-registered: "そのインスタンスは登録されていません" | ||||
|   sort: "ソート" | ||||
|   sorts: | ||||
|     caughtAtAsc: "登録日時が古い順" | ||||
|     caughtAtDesc: "登録日時が新しい順" | ||||
|     lastCommunicatedAtAsc: "最後にやり取りした日時が古い順" | ||||
|     lastCommunicatedAtDesc: "最後にやり取りした日時が新しい順" | ||||
|     notesAsc: "投稿が少ない順" | ||||
|     notesDesc: "投稿が多い順" | ||||
|     usersAsc: "ユーザーが少ない順" | ||||
|     usersDesc: "ユーザーが多い順" | ||||
|     followingAsc: "フォローが少ない順" | ||||
|     followingDesc: "フォローが多い順" | ||||
|     followersAsc: "フォロワーが少ない順" | ||||
|     followersDesc: "フォロワーが多い順" | ||||
|     driveUsageAsc: "ドライブ使用量が少ない順" | ||||
|     driveUsageDesc: "ドライブ使用量が多い順" | ||||
|     driveFilesAsc: "ドライブのファイル数が少ない順" | ||||
|     driveFilesDesc: "ドライブのファイル数が多い順" | ||||
|   state: "状態" | ||||
|   states: | ||||
|     all: "すべて" | ||||
|     blocked: "ブロック" | ||||
|     not-responding: "応答なし" | ||||
|     marked-as-closed: "閉鎖とマーク済み" | ||||
|   result-is-truncated: "上位{n}件を表示しています。" | ||||
|   charts: "チャート" | ||||
|   chart-srcs: | ||||
|     requests: "リクエスト" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     notes: "投稿の増減" | ||||
|     notes-total: "投稿の積算" | ||||
|     ff: "フォロー/フォロワーの増減" | ||||
|     ff-total: "フォロー/フォロワーの積算" | ||||
|     drive-usage: "ドライブ使用量の増減" | ||||
|     drive-usage-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブファイル数の増減" | ||||
|     drive-files-total: "ドライブファイル数の積算" | ||||
|   chart-spans: | ||||
|     hour: "1時間ごと" | ||||
|     day: "1日ごと" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "詳しく..." | ||||
|   gotit: "わかった" | ||||
| @@ -1321,9 +1409,6 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   nsfw: "閲覧注意" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -1468,6 +1553,7 @@ mobile/views/pages/settings.vue: | ||||
|   notification-position-top: "上" | ||||
|   behavior: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   keep-cw: "CW保持" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
| @@ -1511,7 +1597,7 @@ mobile/views/pages/user/home.vue: | ||||
| mobile/views/pages/user/home.followers-you-know.vue: | ||||
|   no-users: "知り合いのユーザーはいません" | ||||
| mobile/views/pages/user/home.friends.vue: | ||||
|   no-users: "よく会話するユーザーはいません" | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| mobile/views/pages/user/home.notes.vue: | ||||
|   no-notes: "Nenhuma mensagem" | ||||
| mobile/views/pages/user/home.photos.vue: | ||||
| @@ -1541,6 +1627,7 @@ deck/deck.tl-column.vue: | ||||
|   is-media-view: "メディアビュー" | ||||
|   edit: "オプション" | ||||
| deck/deck.user-column.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   | ||||
| @@ -113,6 +113,7 @@ common: | ||||
|   use-avatar-reversi-stones: "リバーシの石にアバターを使う" | ||||
|   verified-user: "公式アカウント" | ||||
|   disable-animated-mfm: "Отключить анимированный текст в постах" | ||||
|   disable-showing-animated-images: "アニメーション画像を再生しない" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "Всегда показывать NSFW контент" | ||||
|   always-mark-nsfw: "Всегда помечать посты с медиафайлами как NSFW" | ||||
| @@ -129,7 +130,7 @@ common: | ||||
|   show-password: "パスワードを表示する" | ||||
|   do-not-use-in-production: "Эта сборка для разработчиков. Не используйте в продакшне." | ||||
|   user-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-user: "このユーザー情報は不正確な可能性があります。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|   renoted-by: "{user}がRenote" | ||||
| @@ -344,6 +345,8 @@ common/views/components/note-menu.vue: | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   unfavorite: "お気に入り解除" | ||||
|   watch: "ウォッチ" | ||||
|   unwatch: "ウォッチ解除" | ||||
|   pin: "ピン留め" | ||||
|   unpin: "ピン留め解除" | ||||
|   delete: "削除" | ||||
| @@ -357,10 +360,13 @@ common/views/components/user-menu.vue: | ||||
|   unblock: "ブロック解除" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
|   report-abuse: "スパムを報告" | ||||
|   report-abuse-detail: "どのような迷惑行為を行っていますか?" | ||||
|   report-abuse-reported: "管理者に報告されました。ご協力ありがとうございました。" | ||||
|   silence: "サイレンス" | ||||
|   unsilence: "サイレンス解除" | ||||
|   suspend: "凍結" | ||||
|   unsuspend: "凍結解除" | ||||
| common/views/components/poll.vue: | ||||
|   vote-to: "「{}」に投票する" | ||||
|   vote-count: "{}票" | ||||
| @@ -483,6 +489,7 @@ common/views/components/profile-editor.vue: | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   you-can-include-hashtags: "ハッシュタグを含めることができます。" | ||||
|   language: "言語" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
| @@ -502,6 +509,13 @@ common/views/components/profile-editor.vue: | ||||
|   email-address: "メールアドレス" | ||||
|   email-verified: "メールアドレスが確認されました" | ||||
|   email-not-verified: "メールアドレスが確認されていません。メールボックスをご確認ください。" | ||||
|   export: "エクスポート" | ||||
|   export-targets: | ||||
|     all-notes: "すべての投稿データ" | ||||
|     following-list: "フォロー" | ||||
|     mute-list: "ミュート" | ||||
|     blocking-list: "ブロック" | ||||
|   export-requested: "エクスポートをリクエストしました。これには時間がかかる場合があります。エクスポートが終わると、ドライブにファイルが追加されます。" | ||||
| common/views/components/user-list-editor.vue: | ||||
|   users: "ユーザー" | ||||
|   rename: "リスト名を変更" | ||||
| @@ -659,9 +673,6 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "フォルダーを作成" | ||||
|     upload: "ファイルをアップロード" | ||||
|     url-upload: "URLからアップロード" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -789,6 +800,8 @@ desktop/views/components/settings.vue: | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   keep-cw: "CW保持" | ||||
|   keep-cw-desc: "投稿にリプライする際、リプライ元の投稿にCWが設定されていたとき、デフォルトで同じCWを設定するようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "デザインと表示" | ||||
|   customize: "ホームをカスタマイズ" | ||||
| @@ -874,6 +887,9 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "設定が完了しました!" | ||||
|   failed: "設定に失敗しました。トークンに誤りがないかご確認ください。" | ||||
|   info: "次回サインインからは、同様にパスワードに加えてデバイスに表示されているトークンを入力します。" | ||||
| common/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
| @@ -991,6 +1007,7 @@ admin/views/index.vue: | ||||
|   announcements: "お知らせ" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   abuse: "スパム報告" | ||||
|   queue: "ジョブキュー" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
| @@ -1000,6 +1017,9 @@ admin/views/dashboard.vue: | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "このインスタンス" | ||||
|   federated: "連合" | ||||
| admin/views/queue.vue: | ||||
|   operation: "操作" | ||||
|   remove-all-jobs: "すべてのジョブをクリア" | ||||
| admin/views/abuse.vue: | ||||
|   title: "スパム報告" | ||||
|   target: "対象" | ||||
| @@ -1133,15 +1153,24 @@ admin/views/users.vue: | ||||
|   user-not-found: "ユーザーが見つかりません" | ||||
|   lookup: "照会" | ||||
|   reset-password: "パスワードをリセット" | ||||
|   reset-password-confirm: "パスワードをリセットしますか?" | ||||
|   password-updated: "パスワードは現在「{password}」です" | ||||
|   suspend: "凍結" | ||||
|   suspend-confirm: "凍結しますか?" | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspend-confirm: "凍結を解除しますか?" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   make-silence: "サイレンス" | ||||
|   unmake-silence: "サイレンスの解除" | ||||
|   verify: "公式アカウントにする" | ||||
|   verify-confirm: "公式アカウントにしますか?" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverify-confirm: "公式アカウントを解除しますか?" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|   update-remote-user: "リモートユーザー情報の更新" | ||||
|   remote-user-updated: "リモートユーザー情報を更新しました" | ||||
|   users: | ||||
|     title: "ユーザー" | ||||
|     sort: | ||||
| @@ -1157,6 +1186,7 @@ admin/views/users.vue: | ||||
|       moderator: "モデレーター" | ||||
|       adminOrModerator: "管理者+モデレーター" | ||||
|       verified: "公式アカウント" | ||||
|       silenced: "サイレンス済み" | ||||
|       suspended: "凍結済み" | ||||
|     origin: | ||||
|       title: "オリジン" | ||||
| @@ -1204,6 +1234,64 @@ admin/views/announcements.vue: | ||||
|     removed: "削除しました" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| admin/views/federation.vue: | ||||
|   federation: "連合" | ||||
|   host: "ホスト" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   following: "フォロー中" | ||||
|   followers: "フォロワー" | ||||
|   status: "ステータス" | ||||
|   latest-request-sent-at: "直近のリクエスト送信" | ||||
|   latest-request-received-at: "直近のリクエスト受信" | ||||
|   remove-all-following: "フォローを全解除" | ||||
|   remove-all-following-info: "{host}からのフォローをすべて解除します。そのインスタンスがもう存在しなくなった場合などに実行してください。" | ||||
|   block: "ブロック" | ||||
|   marked-as-closed: "閉鎖されているとマーク" | ||||
|   lookup: "照会" | ||||
|   instances: "インスタンス" | ||||
|   instance-not-registered: "そのインスタンスは登録されていません" | ||||
|   sort: "ソート" | ||||
|   sorts: | ||||
|     caughtAtAsc: "登録日時が古い順" | ||||
|     caughtAtDesc: "登録日時が新しい順" | ||||
|     lastCommunicatedAtAsc: "最後にやり取りした日時が古い順" | ||||
|     lastCommunicatedAtDesc: "最後にやり取りした日時が新しい順" | ||||
|     notesAsc: "投稿が少ない順" | ||||
|     notesDesc: "投稿が多い順" | ||||
|     usersAsc: "ユーザーが少ない順" | ||||
|     usersDesc: "ユーザーが多い順" | ||||
|     followingAsc: "フォローが少ない順" | ||||
|     followingDesc: "フォローが多い順" | ||||
|     followersAsc: "フォロワーが少ない順" | ||||
|     followersDesc: "フォロワーが多い順" | ||||
|     driveUsageAsc: "ドライブ使用量が少ない順" | ||||
|     driveUsageDesc: "ドライブ使用量が多い順" | ||||
|     driveFilesAsc: "ドライブのファイル数が少ない順" | ||||
|     driveFilesDesc: "ドライブのファイル数が多い順" | ||||
|   state: "状態" | ||||
|   states: | ||||
|     all: "すべて" | ||||
|     blocked: "ブロック" | ||||
|     not-responding: "応答なし" | ||||
|     marked-as-closed: "閉鎖とマーク済み" | ||||
|   result-is-truncated: "上位{n}件を表示しています。" | ||||
|   charts: "チャート" | ||||
|   chart-srcs: | ||||
|     requests: "リクエスト" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     notes: "投稿の増減" | ||||
|     notes-total: "投稿の積算" | ||||
|     ff: "フォロー/フォロワーの増減" | ||||
|     ff-total: "フォロー/フォロワーの積算" | ||||
|     drive-usage: "ドライブ使用量の増減" | ||||
|     drive-usage-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブファイル数の増減" | ||||
|     drive-files-total: "ドライブファイル数の積算" | ||||
|   chart-spans: | ||||
|     hour: "1時間ごと" | ||||
|     day: "1日ごと" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "詳しく..." | ||||
|   gotit: "わかった" | ||||
| @@ -1321,9 +1409,6 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   nsfw: "閲覧注意" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -1468,6 +1553,7 @@ mobile/views/pages/settings.vue: | ||||
|   notification-position-top: "上" | ||||
|   behavior: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   keep-cw: "CW保持" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
| @@ -1505,13 +1591,13 @@ mobile/views/pages/user/home.vue: | ||||
|   activity: "アクティビティ" | ||||
|   keywords: "キーワード" | ||||
|   domains: "頻出ドメイン" | ||||
|   frequently-replied-users: "よく会話するユーザー" | ||||
|   frequently-replied-users: "よく話すユーザー" | ||||
|   followers-you-know: "知り合いのフォロワー" | ||||
|   last-used-at: "最終ログイン" | ||||
| mobile/views/pages/user/home.followers-you-know.vue: | ||||
|   no-users: "知り合いのユーザーはいません" | ||||
| mobile/views/pages/user/home.friends.vue: | ||||
|   no-users: "よく会話するユーザーはいません" | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| mobile/views/pages/user/home.notes.vue: | ||||
|   no-notes: "投稿はありません" | ||||
| mobile/views/pages/user/home.photos.vue: | ||||
| @@ -1541,6 +1627,7 @@ deck/deck.tl-column.vue: | ||||
|   is-media-view: "メディアビュー" | ||||
|   edit: "オプション" | ||||
| deck/deck.user-column.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										114
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										114
									
								
								package.json
									
									
									
									
									
								
							| @@ -1,14 +1,18 @@ | ||||
| { | ||||
| 	"name": "misskey", | ||||
| 	"author": "syuilo <i@syuilo.com>", | ||||
| 	"version": "10.78.3", | ||||
| 	"clientVersion": "2.0.13657", | ||||
| 	"version": "10.86.1", | ||||
| 	"clientVersion": "2.0.14327", | ||||
| 	"codename": "nighthike", | ||||
| 	"main": "./built/index.js", | ||||
| 	"repository": { | ||||
| 		"type": "git", | ||||
| 		"url": "https://github.com/syuilo/misskey.git" | ||||
| 	}, | ||||
| 	"main": "./index.js", | ||||
| 	"private": true, | ||||
| 	"scripts": { | ||||
| 		"start": "node ./built", | ||||
| 		"debug": "DEBUG=misskey:* node ./built", | ||||
| 		"start": "node ./index.js", | ||||
| 		"debug": "DEBUG=misskey:* node ./index.js", | ||||
| 		"build": "webpack && gulp build", | ||||
| 		"webpack": "webpack", | ||||
| 		"watch": "webpack --watch", | ||||
| @@ -20,10 +24,10 @@ | ||||
| 		"format": "gulp format" | ||||
| 	}, | ||||
| 	"dependencies": { | ||||
| 		"@fortawesome/fontawesome-svg-core": "1.2.12", | ||||
| 		"@fortawesome/free-brands-svg-icons": "5.6.3", | ||||
| 		"@fortawesome/free-regular-svg-icons": "5.5.0", | ||||
| 		"@fortawesome/free-solid-svg-icons": "5.6.3", | ||||
| 		"@fortawesome/fontawesome-svg-core": "1.2.14", | ||||
| 		"@fortawesome/free-brands-svg-icons": "5.7.1", | ||||
| 		"@fortawesome/free-regular-svg-icons": "5.7.0", | ||||
| 		"@fortawesome/free-solid-svg-icons": "5.7.1", | ||||
| 		"@fortawesome/vue-fontawesome": "0.1.5", | ||||
| 		"@koa/cors": "2.2.3", | ||||
| 		"@prezzemolo/rap": "0.1.2", | ||||
| @@ -31,12 +35,11 @@ | ||||
| 		"@types/bcryptjs": "2.4.2", | ||||
| 		"@types/chai-http": "3.0.5", | ||||
| 		"@types/dateformat": "3.0.0", | ||||
| 		"@types/debug": "0.0.31", | ||||
| 		"@types/deep-equal": "1.0.1", | ||||
| 		"@types/double-ended-queue": "2.1.0", | ||||
| 		"@types/elasticsearch": "5.0.30", | ||||
| 		"@types/file-type": "10.6.0", | ||||
| 		"@types/gulp": "3.8.36", | ||||
| 		"@types/gulp": "4.0.5", | ||||
| 		"@types/gulp-mocha": "0.0.32", | ||||
| 		"@types/gulp-rename": "0.0.33", | ||||
| 		"@types/gulp-replace": "0.0.31", | ||||
| @@ -45,27 +48,30 @@ | ||||
| 		"@types/is-root": "1.0.0", | ||||
| 		"@types/is-svg": "3.0.0", | ||||
| 		"@types/is-url": "1.2.28", | ||||
| 		"@types/js-yaml": "3.11.4", | ||||
| 		"@types/js-yaml": "3.12.0", | ||||
| 		"@types/jsdom": "12.2.1", | ||||
| 		"@types/katex": "0.5.0", | ||||
| 		"@types/koa": "2.0.48", | ||||
| 		"@types/koa-bodyparser": "5.0.2", | ||||
| 		"@types/koa-compress": "2.0.8", | ||||
| 		"@types/koa-cors": "0.0.0", | ||||
| 		"@types/koa-favicon": "2.0.19", | ||||
| 		"@types/koa-logger": "3.1.1", | ||||
| 		"@types/koa-mount": "3.0.1", | ||||
| 		"@types/koa-multer": "1.0.0", | ||||
| 		"@types/koa-router": "7.0.35", | ||||
| 		"@types/koa-router": "7.0.39", | ||||
| 		"@types/koa-send": "4.1.1", | ||||
| 		"@types/koa-views": "2.0.3", | ||||
| 		"@types/koa__cors": "2.2.3", | ||||
| 		"@types/minio": "7.0.1", | ||||
| 		"@types/mkdirp": "0.5.2", | ||||
| 		"@types/mocha": "5.2.5", | ||||
| 		"@types/mongodb": "3.1.18", | ||||
| 		"@types/ms": "0.7.30", | ||||
| 		"@types/node": "10.12.18", | ||||
| 		"@types/mongodb": "3.1.19", | ||||
| 		"@types/node": "10.12.21", | ||||
| 		"@types/nodemailer": "4.6.5", | ||||
| 		"@types/nprogress": "0.0.29", | ||||
| 		"@types/oauth": "0.9.1", | ||||
| 		"@types/parse5": "5.0.0", | ||||
| 		"@types/parsimmon": "1.10.0", | ||||
| 		"@types/portscanner": "2.1.0", | ||||
| 		"@types/pug": "2.0.4", | ||||
| @@ -74,54 +80,54 @@ | ||||
| 		"@types/redis": "2.8.10", | ||||
| 		"@types/request": "2.48.1", | ||||
| 		"@types/request-promise-native": "1.0.15", | ||||
| 		"@types/request-stats": "3.0.0", | ||||
| 		"@types/rimraf": "2.0.2", | ||||
| 		"@types/seedrandom": "2.4.27", | ||||
| 		"@types/sharp": "0.21.0", | ||||
| 		"@types/sharp": "0.21.1", | ||||
| 		"@types/showdown": "1.9.2", | ||||
| 		"@types/speakeasy": "2.0.3", | ||||
| 		"@types/systeminformation": "3.23.1", | ||||
| 		"@types/tinycolor2": "1.4.1", | ||||
| 		"@types/tmp": "0.0.33", | ||||
| 		"@types/uuid": "3.4.4", | ||||
| 		"@types/webpack": "4.4.21", | ||||
| 		"@types/web-push": "3.3.0", | ||||
| 		"@types/webpack": "4.4.24", | ||||
| 		"@types/webpack-stream": "3.2.10", | ||||
| 		"@types/websocket": "0.0.40", | ||||
| 		"@types/ws": "6.0.1", | ||||
| 		"animejs": "3.0.1", | ||||
| 		"apexcharts": "2.5.1", | ||||
| 		"apexcharts": "3.3.0", | ||||
| 		"autobind-decorator": "2.4.0", | ||||
| 		"autosize": "4.0.2", | ||||
| 		"autwh": "0.1.0", | ||||
| 		"bcryptjs": "2.4.3", | ||||
| 		"bee-queue": "1.2.2", | ||||
| 		"bootstrap-vue": "2.0.0-rc.11", | ||||
| 		"cafy": "12.0.0", | ||||
| 		"cafy": "14.0.1", | ||||
| 		"chai": "4.2.0", | ||||
| 		"chalk": "2.4.2", | ||||
| 		"chai-http": "4.2.1", | ||||
| 		"chalk": "2.4.2", | ||||
| 		"commander": "2.19.0", | ||||
| 		"crc-32": "1.2.0", | ||||
| 		"css-loader": "1.0.1", | ||||
| 		"css-loader": "2.1.0", | ||||
| 		"cssnano": "4.1.8", | ||||
| 		"dateformat": "3.0.3", | ||||
| 		"debug": "4.1.0", | ||||
| 		"deep-equal": "1.0.1", | ||||
| 		"deepcopy": "0.6.3", | ||||
| 		"diskusage": "1.0.0", | ||||
| 		"double-ended-queue": "2.1.0-0", | ||||
| 		"elasticsearch": "15.3.0", | ||||
| 		"elasticsearch": "15.3.1", | ||||
| 		"emojilib": "2.4.0", | ||||
| 		"escape-regexp": "0.0.1", | ||||
| 		"eslint": "5.12.0", | ||||
| 		"eslint-plugin-vue": "5.1.0", | ||||
| 		"eventemitter3": "3.1.0", | ||||
| 		"feed": "2.0.2", | ||||
| 		"file-loader": "2.0.0", | ||||
| 		"file-type": "10.7.0", | ||||
| 		"file-type": "10.7.1", | ||||
| 		"fuckadblock": "3.2.1", | ||||
| 		"gulp": "3.9.1", | ||||
| 		"gulp": "4.0.0", | ||||
| 		"gulp-cssnano": "2.1.3", | ||||
| 		"gulp-imagemin": "4.1.0", | ||||
| 		"gulp-imagemin": "5.0.3", | ||||
| 		"gulp-mocha": "6.0.0", | ||||
| 		"gulp-rename": "1.4.0", | ||||
| 		"gulp-replace": "1.0.0", | ||||
| @@ -131,20 +137,19 @@ | ||||
| 		"gulp-typescript": "5.0.0", | ||||
| 		"gulp-uglify": "3.0.1", | ||||
| 		"gulp-util": "3.0.8", | ||||
| 		"gulp-yaml": "2.0.2", | ||||
| 		"gulp-yaml": "2.0.3", | ||||
| 		"hard-source-webpack-plugin": "0.13.1", | ||||
| 		"html-minifier": "3.5.21", | ||||
| 		"http-signature": "1.2.0", | ||||
| 		"insert-text-at-cursor": "0.1.1", | ||||
| 		"insert-text-at-cursor": "0.1.2", | ||||
| 		"is-root": "2.0.0", | ||||
| 		"is-svg": "3.0.0", | ||||
| 		"is-url": "1.2.4", | ||||
| 		"js-yaml": "3.12.1", | ||||
| 		"jsdom": "13.1.0", | ||||
| 		"jsdom": "13.2.0", | ||||
| 		"json5": "2.1.0", | ||||
| 		"json5-loader": "1.0.1", | ||||
| 		"katex": "0.10.0", | ||||
| 		"koa": "2.6.2", | ||||
| 		"koa": "2.7.0", | ||||
| 		"koa-bodyparser": "4.2.1", | ||||
| 		"koa-compress": "3.0.0", | ||||
| 		"koa-favicon": "2.0.1", | ||||
| @@ -155,21 +160,21 @@ | ||||
| 		"koa-router": "7.4.0", | ||||
| 		"koa-send": "5.0.0", | ||||
| 		"koa-slow": "2.1.0", | ||||
| 		"koa-views": "6.1.4", | ||||
| 		"koa-views": "6.1.5", | ||||
| 		"langmap": "0.0.16", | ||||
| 		"loader-utils": "1.2.3", | ||||
| 		"lookup-dns-cache": "2.1.0", | ||||
| 		"minio": "7.0.3", | ||||
| 		"minio": "7.0.5", | ||||
| 		"mkdirp": "0.5.1", | ||||
| 		"mocha": "5.2.0", | ||||
| 		"moji": "0.5.1", | ||||
| 		"moment": "2.23.0", | ||||
| 		"mongodb": "3.1.10", | ||||
| 		"moment": "2.24.0", | ||||
| 		"mongodb": "3.1.13", | ||||
| 		"monk": "6.0.6", | ||||
| 		"ms": "2.1.1", | ||||
| 		"nan": "2.12.1", | ||||
| 		"nested-property": "0.0.7", | ||||
| 		"nodemailer": "5.0.0", | ||||
| 		"nodemailer": "5.1.1", | ||||
| 		"nprogress": "0.2.0", | ||||
| 		"object-assign-deep": "0.4.0", | ||||
| 		"on-build-webpack": "0.1.0", | ||||
| @@ -178,13 +183,14 @@ | ||||
| 		"parsimmon": "1.12.0", | ||||
| 		"portscanner": "2.2.0", | ||||
| 		"postcss-loader": "3.0.0", | ||||
| 		"progress-bar-webpack-plugin": "1.11.0", | ||||
| 		"prismjs": "1.15.0", | ||||
| 		"progress-bar-webpack-plugin": "1.12.1", | ||||
| 		"promise-any": "0.2.0", | ||||
| 		"promise-limit": "2.7.0", | ||||
| 		"promise-sequential": "1.1.1", | ||||
| 		"pug": "2.0.3", | ||||
| 		"punycode": "2.1.1", | ||||
| 		"qrcode": "1.3.2", | ||||
| 		"qrcode": "1.3.3", | ||||
| 		"randomcolor": "0.5.3", | ||||
| 		"ratelimiter": "3.2.0", | ||||
| 		"recaptcha-promise": "0.1.3", | ||||
| @@ -197,7 +203,7 @@ | ||||
| 		"rndstr": "1.0.0", | ||||
| 		"s-age": "1.1.2", | ||||
| 		"seedrandom": "2.4.4", | ||||
| 		"sharp": "0.21.1", | ||||
| 		"sharp": "0.21.3", | ||||
| 		"showdown": "1.9.0", | ||||
| 		"showdown-highlightjs-extension": "0.1.2", | ||||
| 		"speakeasy": "2.0.0", | ||||
| @@ -206,45 +212,47 @@ | ||||
| 		"stylus": "0.54.5", | ||||
| 		"stylus-loader": "3.0.2", | ||||
| 		"summaly": "2.2.0", | ||||
| 		"systeminformation": "3.52.2", | ||||
| 		"systeminformation": "3.54.0", | ||||
| 		"syuilo-password-strength": "0.0.1", | ||||
| 		"terser-webpack-plugin": "1.2.1", | ||||
| 		"terser-webpack-plugin": "1.2.2", | ||||
| 		"textarea-caret": "3.1.0", | ||||
| 		"tinycolor2": "1.4.1", | ||||
| 		"tmp": "0.0.33", | ||||
| 		"ts-loader": "5.3.3", | ||||
| 		"ts-node": "7.0.1", | ||||
| 		"tslint": "5.12.0", | ||||
| 		"tslint-sonarts": "1.8.0", | ||||
| 		"typescript": "3.2.2", | ||||
| 		"tslint": "5.12.1", | ||||
| 		"tslint-sonarts": "1.9.0", | ||||
| 		"typescript": "3.2.4", | ||||
| 		"typescript-eslint-parser": "21.0.2", | ||||
| 		"uglify-es": "3.3.9", | ||||
| 		"url-loader": "1.1.2", | ||||
| 		"uuid": "3.3.2", | ||||
| 		"v-animate-css": "0.0.3", | ||||
| 		"vue": "2.5.17", | ||||
| 		"video-thumbnail-generator": "1.1.3", | ||||
| 		"vue": "2.6.6", | ||||
| 		"vue-color": "2.7.0", | ||||
| 		"vue-content-loading": "1.5.3", | ||||
| 		"vue-cropperjs": "3.0.0", | ||||
| 		"vue-i18n": "8.7.0", | ||||
| 		"vue-i18n": "8.8.1", | ||||
| 		"vue-js-modal": "1.3.28", | ||||
| 		"vue-loader": "15.4.2", | ||||
| 		"vue-loader": "15.6.2", | ||||
| 		"vue-marquee-text-component": "1.1.1", | ||||
| 		"vue-prism-component": "1.1.1", | ||||
| 		"vue-router": "3.0.2", | ||||
| 		"vue-sequential-entrance": "1.1.3", | ||||
| 		"vue-style-loader": "4.1.2", | ||||
| 		"vue-svg-inline-loader": "1.2.7", | ||||
| 		"vue-template-compiler": "2.5.17", | ||||
| 		"vue-svg-inline-loader": "1.2.10", | ||||
| 		"vue-template-compiler": "2.6.6", | ||||
| 		"vuedraggable": "2.17.0", | ||||
| 		"vuewordcloud": "18.7.11", | ||||
| 		"vuex": "3.0.1", | ||||
| 		"vuex": "3.1.0", | ||||
| 		"vuex-persistedstate": "2.5.4", | ||||
| 		"web-push": "3.3.3", | ||||
| 		"webfinger.js": "2.7.0", | ||||
| 		"webpack": "4.28.4", | ||||
| 		"webpack-cli": "3.2.1", | ||||
| 		"websocket": "1.0.28", | ||||
| 		"ws": "6.1.2", | ||||
| 		"ws": "6.1.3", | ||||
| 		"xev": "2.0.1" | ||||
| 	} | ||||
| } | ||||
|   | ||||
							
								
								
									
										3
									
								
								src/@types/const.json.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								src/@types/const.json.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | ||||
| declare module '*/const.json' { | ||||
| 	const copyright: string; | ||||
| } | ||||
							
								
								
									
										17
									
								
								src/@types/deepcopy.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								src/@types/deepcopy.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | ||||
| declare module 'deepcopy'; | ||||
|  | ||||
| declare namespace deepcopy { | ||||
| 	type DeepcopyCustomizerValueType = 'Object'; | ||||
|  | ||||
| 	type DeepcopyCustomizer<T> = ( | ||||
| 		value: T, | ||||
| 		valueType: DeepcopyCustomizerValueType) => T; | ||||
|  | ||||
| 	interface DeepcopyOptions<T> { | ||||
| 		customizer: DeepcopyCustomizer<T>; | ||||
| 	} | ||||
|  | ||||
| 	export function deepcopy<T>( | ||||
| 		value: T, | ||||
| 		options?: DeepcopyOptions<T> | DeepcopyCustomizer<T>): T; | ||||
| } | ||||
							
								
								
									
										7
									
								
								src/@types/escape-regexp.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								src/@types/escape-regexp.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| declare module 'escape-regexp' { | ||||
| 	function escapeRegExp(str: string): string; | ||||
|  | ||||
| 	namespace escapeRegExp {} // Hack | ||||
|  | ||||
| 	export = escapeRegExp; | ||||
| } | ||||
							
								
								
									
										75
									
								
								src/@types/http-signature.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								src/@types/http-signature.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,75 @@ | ||||
| declare module 'http-signature' { | ||||
| 	import { IncomingMessage, ClientRequest } from 'http'; | ||||
|  | ||||
| 	interface ISignature { | ||||
| 		keyId: string; | ||||
| 		algorithm: string; | ||||
| 		headers: string[]; | ||||
| 		signature: string; | ||||
| 	} | ||||
|  | ||||
| 	interface IOptions { | ||||
| 		headers?: string[]; | ||||
| 		algorithm?: string; | ||||
| 		strict?: boolean; | ||||
| 		authorizationHeaderName?: string; | ||||
| 	} | ||||
|  | ||||
| 	interface IParseRequestOptions extends IOptions { | ||||
| 		clockSkew?: number; | ||||
| 	} | ||||
|  | ||||
| 	interface IParsedSignature  { | ||||
| 		scheme: string; | ||||
| 		params: ISignature; | ||||
| 		signingString: string; | ||||
| 	} | ||||
|  | ||||
| 	type RequestSignerConstructorOptions = | ||||
| 		IRequestSignerConstructorOptionsFromProperties | | ||||
| 		IRequestSignerConstructorOptionsFromFunction; | ||||
|  | ||||
| 	interface IRequestSignerConstructorOptionsFromProperties { | ||||
| 		keyId: string; | ||||
| 		key: string | Buffer; | ||||
| 		algorithm?: string; | ||||
| 	} | ||||
|  | ||||
| 	interface IRequestSignerConstructorOptionsFromFunction { | ||||
| 		sign?: (data: string, cb: (err: any, sig: ISignature) => void) => void; | ||||
| 	} | ||||
|  | ||||
| 	class RequestSigner { | ||||
| 		constructor(options: RequestSignerConstructorOptions); | ||||
|  | ||||
| 		public writeHeader(header: string, value: string): string; | ||||
|  | ||||
| 		public writeDateHeader(): string; | ||||
|  | ||||
| 		public writeTarget(method: string, path: string): void; | ||||
|  | ||||
| 		public sign(cb: (err: any, authz: string) => void): void; | ||||
| 	} | ||||
|  | ||||
| 	interface ISignRequestOptions extends IOptions { | ||||
| 		keyId: string; | ||||
| 		key: string; | ||||
| 		httpVersion?: string; | ||||
| 	} | ||||
|  | ||||
| 	export function parse(request: IncomingMessage, options?: IParseRequestOptions): IParsedSignature; | ||||
| 	export function parseRequest(request: IncomingMessage, options?: IParseRequestOptions): IParsedSignature; | ||||
|  | ||||
| 	export function sign(request: ClientRequest, options: ISignRequestOptions): boolean; | ||||
| 	export function signRequest(request: ClientRequest, options: ISignRequestOptions): boolean; | ||||
| 	export function createSigner(): RequestSigner; | ||||
| 	export function isSigner(obj: any): obj is RequestSigner; | ||||
|  | ||||
| 	export function sshKeyToPEM(key: string): string; | ||||
| 	export function sshKeyFingerprint(key: string): string; | ||||
| 	export function pemToRsaSSHKey(pem: string, comment: string): string; | ||||
|  | ||||
| 	export function verify(parsedSignature: IParsedSignature, pubkey: string | Buffer): boolean; | ||||
| 	export function verifySignature(parsedSignature: IParsedSignature, pubkey: string | Buffer): boolean; | ||||
| 	export function verifyHMAC(parsedSignature: IParsedSignature, secret: string): boolean; | ||||
| } | ||||
							
								
								
									
										7
									
								
								src/@types/is-root.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								src/@types/is-root.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| declare module 'is-root' { | ||||
| 	function isRoot(): boolean; | ||||
|  | ||||
| 	namespace isRoot {} // Hack | ||||
|  | ||||
| 	export = isRoot; | ||||
| } | ||||
							
								
								
									
										15
									
								
								src/@types/koa-json-body.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								src/@types/koa-json-body.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | ||||
| declare module 'koa-json-body' { | ||||
| 	import { Middleware } from 'koa'; | ||||
|  | ||||
| 	interface IKoaJsonBodyOptions { | ||||
| 		strict: boolean; | ||||
| 		limit: string; | ||||
| 		fallback: boolean; | ||||
| 	} | ||||
|  | ||||
| 	function koaJsonBody(opt?: IKoaJsonBodyOptions): Middleware; | ||||
|  | ||||
| 	namespace koaJsonBody {} // Hack | ||||
|  | ||||
| 	export = koaJsonBody; | ||||
| } | ||||
							
								
								
									
										14
									
								
								src/@types/koa-slow.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								src/@types/koa-slow.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| declare module 'koa-slow' { | ||||
| 	import { Middleware } from 'koa'; | ||||
|  | ||||
| 	interface ISlowOptions { | ||||
| 		url?: RegExp; | ||||
| 		delay?: number; | ||||
| 	} | ||||
|  | ||||
| 	function slow(options?: ISlowOptions): Middleware; | ||||
|  | ||||
| 	namespace slow { } // Hack | ||||
|  | ||||
| 	export = slow; | ||||
| } | ||||
							
								
								
									
										10
									
								
								src/@types/langmap.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								src/@types/langmap.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | ||||
| declare module 'langmap' { | ||||
| 	type Lang = { | ||||
| 		nativeName: string; | ||||
| 		englishName: string; | ||||
| 	}; | ||||
|  | ||||
| 	const langmap: { [lang: string]: Lang }; | ||||
|  | ||||
| 	export = langmap; | ||||
| } | ||||
							
								
								
									
										17
									
								
								src/@types/lookup-dns-cache.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								src/@types/lookup-dns-cache.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | ||||
| declare module 'lookup-dns-cache' { | ||||
| 	type IPv4 = 4; | ||||
|  | ||||
| 	type IPv6 = 6; | ||||
|  | ||||
| 	type Family = IPv4 | IPv6 | undefined; | ||||
|  | ||||
| 	interface IRunOptions { | ||||
| 		family?: Family; | ||||
| 		all?: boolean; | ||||
| 	} | ||||
|  | ||||
| 	type RunCallback = (error: Error | null, address?: string | string[], family?: Family) => void; | ||||
|  | ||||
| 	export function lookup(hostname: string, options: IRunOptions | Family, callback: RunCallback): {} | undefined; | ||||
| 	export function lookup(hostname: string, callback: RunCallback): {} | undefined; | ||||
| } | ||||
							
								
								
									
										3
									
								
								src/@types/meta.json.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								src/@types/meta.json.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | ||||
| declare module '*/meta.json' { | ||||
| 	const version: string; | ||||
| } | ||||
							
								
								
									
										12
									
								
								src/@types/ms.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								src/@types/ms.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | ||||
| declare module 'ms' { | ||||
| 	interface IMSOptions { | ||||
| 		long: boolean; | ||||
| 	} | ||||
|  | ||||
| 	function ms(value: string): number; | ||||
| 	function ms(value: number, options?: IMSOptions): string; | ||||
|  | ||||
| 	namespace ms {} // Hack | ||||
|  | ||||
| 	export = ms; | ||||
| } | ||||
							
								
								
									
										21
									
								
								src/@types/nested-property.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								src/@types/nested-property.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | ||||
| type Obj = { [key: string]: any }; | ||||
|  | ||||
| declare module 'nested-property' { | ||||
| 	interface IHasNestedPropertyOptions { | ||||
| 		own?: boolean; | ||||
| 	} | ||||
|  | ||||
| 	interface IIsInNestedPropertyOptions { | ||||
| 		validPath?: boolean; | ||||
| 	} | ||||
|  | ||||
| 	export function set<T>(object: T, property: string, value: any): T; | ||||
|  | ||||
| 	export function get(object: Obj, property: string): any; | ||||
|  | ||||
| 	export function has(object: Obj, property: string, options?: IHasNestedPropertyOptions): boolean; | ||||
|  | ||||
| 	export function hasOwn(object: Obj, property: string, options?: IHasNestedPropertyOptions): boolean; | ||||
|  | ||||
| 	export function isIn(object: Obj, property: string, objectInPath: Obj, options?: IIsInNestedPropertyOptions): boolean; | ||||
| } | ||||
							
								
								
									
										30
									
								
								src/@types/os-utils.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								src/@types/os-utils.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | ||||
| declare module 'os-utils' { | ||||
| 	type FreeCommandCallback = (usedmem: number) => void; | ||||
|  | ||||
| 	type HarddriveCallback = (total: number, free: number, used: number) => void; | ||||
|  | ||||
| 	type GetProcessesCallback = (result: string) => void; | ||||
|  | ||||
| 	type CPUCallback = (perc: number) => void; | ||||
|  | ||||
| 	export function platform(): NodeJS.Platform; | ||||
| 	export function cpuCount(): number; | ||||
| 	export function sysUptime(): number; | ||||
| 	export function processUptime(): number; | ||||
|  | ||||
| 	export function freemem(): number; | ||||
| 	export function totalmem(): number; | ||||
| 	export function freememPercentage(): number; | ||||
| 	export function freeCommand(callback: FreeCommandCallback): void; | ||||
|  | ||||
| 	export function harddrive(callback: HarddriveCallback): void; | ||||
|  | ||||
| 	export function getProcesses(callback: GetProcessesCallback): void; | ||||
| 	export function getProcesses(nProcess: number, callback: GetProcessesCallback): void; | ||||
|  | ||||
| 	export function allLoadavg(): string; | ||||
| 	export function loadavg(_time?: number): number; | ||||
|  | ||||
| 	export function cpuFree(callback: CPUCallback): void; | ||||
| 	export function cpuUsage(callback: CPUCallback): void; | ||||
| } | ||||
							
								
								
									
										10
									
								
								src/@types/package.json.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								src/@types/package.json.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | ||||
| declare module '*/package.json' { | ||||
| 	interface IRepository { | ||||
| 		type: string; | ||||
| 		url: string; | ||||
| 	} | ||||
|  | ||||
| 	export const name: string; | ||||
| 	export const version: string; | ||||
| 	export const repository: IRepository; | ||||
| } | ||||
							
								
								
									
										7
									
								
								src/@types/promise-any.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								src/@types/promise-any.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| declare module 'promise-any' { | ||||
| 	function promiseAny<T>(iterable: Iterable<T | PromiseLike<T>>): Promise<T>; | ||||
|  | ||||
| 	namespace promiseAny {} // Hack | ||||
|  | ||||
| 	export = promiseAny; | ||||
| } | ||||
							
								
								
									
										16
									
								
								src/@types/recaptcha-promise.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								src/@types/recaptcha-promise.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | ||||
| declare module 'recaptcha-promise' { | ||||
| 	interface IVerifyOptions { | ||||
| 		secret_key?: string; | ||||
| 	} | ||||
|  | ||||
| 	interface IVerify { | ||||
| 		(response: string, remoteAddress?: string): Promise<boolean>; | ||||
| 		init(options: IVerifyOptions): IVerify; | ||||
| 	} | ||||
|  | ||||
| 	namespace recaptchaPromise {} // Hack | ||||
|  | ||||
| 	const verify: IVerify; | ||||
|  | ||||
| 	export = verify; | ||||
| } | ||||
							
								
								
									
										65
									
								
								src/@types/webfinger.js.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								src/@types/webfinger.js.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,65 @@ | ||||
| declare module 'webfinger.js' { | ||||
| 	interface IWebFingerConstructorConfig { | ||||
| 		tls_only?: boolean; | ||||
| 		webfist_fallback?: boolean; | ||||
| 		uri_fallback?: boolean; | ||||
| 		request_timeout?: number; | ||||
| 	} | ||||
|  | ||||
| 	type JRDProperties = { [type: string]: string }; | ||||
|  | ||||
| 	interface IJRDLink { | ||||
| 		rel: string; | ||||
| 		type?: string; | ||||
| 		href?: string; | ||||
| 		template?: string; | ||||
| 		titles?: { [lang: string]: string }; | ||||
| 		properties?: JRDProperties; | ||||
| 	} | ||||
|  | ||||
| 	interface IJRD { | ||||
| 		subject?: string; | ||||
| 		expires?: Date; | ||||
| 		aliases?: string[]; | ||||
| 		properties?: JRDProperties; | ||||
| 		links?: IJRDLink[]; | ||||
| 	} | ||||
|  | ||||
| 	interface IIDXLinks { | ||||
|     'avatar': IJRDLink[]; | ||||
|     'remotestorage': IJRDLink[]; | ||||
|     'blog': IJRDLink[]; | ||||
|     'vcard': IJRDLink[]; | ||||
|     'updates': IJRDLink[]; | ||||
|     'share': IJRDLink[]; | ||||
|     'profile': IJRDLink[]; | ||||
|     'webfist': IJRDLink[]; | ||||
| 		'camlistore': IJRDLink[]; | ||||
| 		[type: string]: IJRDLink[]; | ||||
| 	} | ||||
|  | ||||
| 	interface IIDXProperties { | ||||
| 		'name': string; | ||||
| 		[type: string]: string; | ||||
| 	} | ||||
|  | ||||
| 	interface IIDX { | ||||
| 		links: IIDXLinks; | ||||
| 		properties: IIDXProperties; | ||||
| 	} | ||||
|  | ||||
| 	interface ILookupCallbackResult { | ||||
| 		object: IJRD; | ||||
| 		json: string; | ||||
| 		idx: IIDX; | ||||
| 	} | ||||
|  | ||||
| 	type LookupCallback = (err: Error | string, result?: ILookupCallbackResult) => void; | ||||
|  | ||||
| 	export class WebFinger { | ||||
| 		constructor(config?: IWebFingerConstructorConfig); | ||||
|  | ||||
| 		public lookup(address: string, cb: LookupCallback): NodeJS.Timeout; | ||||
| 		public lookupLink(address: string, rel: string, cb: IJRDLink): void; | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										21
									
								
								src/argv.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								src/argv.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | ||||
| import * as program from 'commander'; | ||||
| import * as pkg from '../package.json'; | ||||
|  | ||||
| program | ||||
| 	.version(pkg.version) | ||||
| 	.option('--no-daemons', 'Disable daemon processes (for debbuging)') | ||||
| 	.option('--disable-clustering', 'Disable clustering') | ||||
| 	.option('--disable-queue', 'Disable job queue processing') | ||||
| 	.option('--only-server', 'Run server only (without job queue)') | ||||
| 	.option('--only-queue', 'Pocessing job queue only (without server)') | ||||
| 	.option('--quiet', 'Suppress all logs') | ||||
| 	.option('--verbose', 'Enable all logs') | ||||
| 	.option('--with-log-time', 'Include timestamp for each logs') | ||||
| 	.option('--slow', 'Delay all requests (for debbuging)') | ||||
| 	.option('--color', 'This option is a dummy for some external program\'s (e.g. forever) issue.') | ||||
| 	.parse(process.argv); | ||||
|  | ||||
| /*if (process.env.MK_DISABLE_QUEUE)*/ program.disableQueue = true; | ||||
| if (process.env.MK_ONLY_QUEUE) program.onlyQueue = true; | ||||
|  | ||||
| export { program }; | ||||
| @@ -6,10 +6,10 @@ | ||||
| 			<sequential-entrance animation="entranceFromTop" delay="25"> | ||||
| 				<div v-for="report in userReports" :key="report.id" class="haexwsjc"> | ||||
| 					<ui-horizon-group inputs> | ||||
| 						<ui-input :value="report.user | acct" type="text"> | ||||
| 						<ui-input :value="report.user | acct" type="text" readonly> | ||||
| 							<span>{{ $t('target') }}</span> | ||||
| 						</ui-input> | ||||
| 						<ui-input :value="report.reporter | acct" type="text"> | ||||
| 						<ui-input :value="report.reporter | acct" type="text" readonly> | ||||
| 							<span>{{ $t('reporter') }}</span> | ||||
| 						</ui-input> | ||||
| 					</ui-horizon-group> | ||||
|   | ||||
| @@ -42,7 +42,7 @@ | ||||
| import Vue from 'vue'; | ||||
| import i18n from '../../i18n'; | ||||
| import * as tinycolor from 'tinycolor2'; | ||||
| import * as ApexCharts from 'apexcharts'; | ||||
| import ApexCharts from 'apexcharts'; | ||||
|  | ||||
| const limit = 90; | ||||
|  | ||||
|   | ||||
| @@ -19,7 +19,7 @@ | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import * as ApexCharts from 'apexcharts'; | ||||
| import ApexCharts from 'apexcharts'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: ['connection'], | ||||
|   | ||||
| @@ -124,7 +124,7 @@ export default Vue.extend({ | ||||
| 			this.meta = meta; | ||||
| 		}); | ||||
|  | ||||
| 		this.$root.api('instances', { | ||||
| 		this.$root.api('federation/instances', { | ||||
| 			sort: '+notes' | ||||
| 		}).then(instances => { | ||||
| 			for (const i of instances) { | ||||
|   | ||||
							
								
								
									
										488
									
								
								src/client/app/admin/views/federation.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										488
									
								
								src/client/app/admin/views/federation.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,488 @@ | ||||
| <template> | ||||
| <div> | ||||
| 	<ui-card> | ||||
| 		<div slot="title"><fa :icon="faTerminal"/> {{ $t('federation') }}</div> | ||||
| 		<section class="fit-top"> | ||||
| 			<ui-input class="target" v-model="target" type="text" @enter="showInstance()"> | ||||
| 				<span>{{ $t('host') }}</span> | ||||
| 			</ui-input> | ||||
| 			<ui-button @click="showInstance()"><fa :icon="faSearch"/> {{ $t('lookup') }}</ui-button> | ||||
|  | ||||
| 			<div class="instance" v-if="instance"> | ||||
| 				<ui-input :value="instance.host" type="text" readonly> | ||||
| 					<span>{{ $t('host') }}</span> | ||||
| 				</ui-input> | ||||
| 				<ui-horizon-group inputs> | ||||
| 					<ui-input :value="instance.notesCount | number" type="text" readonly> | ||||
| 						<span>{{ $t('notes') }}</span> | ||||
| 					</ui-input> | ||||
| 					<ui-input :value="instance.usersCount | number" type="text" readonly> | ||||
| 						<span>{{ $t('users') }}</span> | ||||
| 					</ui-input> | ||||
| 				</ui-horizon-group> | ||||
| 				<ui-horizon-group inputs> | ||||
| 					<ui-input :value="instance.followingCount | number" type="text" readonly> | ||||
| 						<span>{{ $t('following') }}</span> | ||||
| 					</ui-input> | ||||
| 					<ui-input :value="instance.followersCount | number" type="text" readonly> | ||||
| 						<span>{{ $t('followers') }}</span> | ||||
| 					</ui-input> | ||||
| 				</ui-horizon-group> | ||||
| 				<ui-horizon-group inputs> | ||||
| 					<ui-input :value="instance.latestRequestSentAt" type="text" readonly> | ||||
| 						<span>{{ $t('latest-request-sent-at') }}</span> | ||||
| 					</ui-input> | ||||
| 					<ui-input :value="instance.latestStatus" type="text" readonly> | ||||
| 						<span>{{ $t('status') }}</span> | ||||
| 					</ui-input> | ||||
| 				</ui-horizon-group> | ||||
| 				<ui-input :value="instance.latestRequestReceivedAt" type="text" readonly> | ||||
| 					<span>{{ $t('latest-request-received-at') }}</span> | ||||
| 				</ui-input> | ||||
| 				<ui-switch v-model="instance.isBlocked" @change="updateInstance()">{{ $t('block') }}</ui-switch> | ||||
| 				<ui-switch v-model="instance.isMarkedAsClosed" @change="updateInstance()">{{ $t('marked-as-closed') }}</ui-switch> | ||||
| 				<details> | ||||
| 					<summary>{{ $t('charts') }}</summary> | ||||
| 					<ui-horizon-group inputs> | ||||
| 						<ui-select v-model="chartSrc"> | ||||
| 							<option value="requests">{{ $t('chart-srcs.requests') }}</option> | ||||
| 							<option value="users">{{ $t('chart-srcs.users') }}</option> | ||||
| 							<option value="users-total">{{ $t('chart-srcs.users-total') }}</option> | ||||
| 							<option value="notes">{{ $t('chart-srcs.notes') }}</option> | ||||
| 							<option value="notes-total">{{ $t('chart-srcs.notes-total') }}</option> | ||||
| 							<option value="ff">{{ $t('chart-srcs.ff') }}</option> | ||||
| 							<option value="ff-total">{{ $t('chart-srcs.ff-total') }}</option> | ||||
| 							<option value="drive-usage">{{ $t('chart-srcs.drive-usage') }}</option> | ||||
| 							<option value="drive-usage-total">{{ $t('chart-srcs.drive-usage-total') }}</option> | ||||
| 							<option value="drive-files">{{ $t('chart-srcs.drive-files') }}</option> | ||||
| 							<option value="drive-files-total">{{ $t('chart-srcs.drive-files-total') }}</option> | ||||
| 						</ui-select> | ||||
| 						<ui-select v-model="chartSpan"> | ||||
| 							<option value="hour">{{ $t('chart-spans.hour') }}</option> | ||||
| 							<option value="day">{{ $t('chart-spans.day') }}</option> | ||||
| 						</ui-select> | ||||
| 					</ui-horizon-group> | ||||
| 					<div ref="chart"></div> | ||||
| 				</details> | ||||
| 				<details> | ||||
| 					<summary>{{ $t('remove-all-following') }}</summary> | ||||
| 					<ui-button @click="removeAllFollowing()" style="margin-top: 16px;"><fa :icon="faMinusCircle"/> {{ $t('remove-all-following') }}</ui-button> | ||||
| 					<ui-info warn>{{ $t('remove-all-following-info', { host: instance.host }) }}</ui-info> | ||||
| 				</details> | ||||
| 			</div> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
|  | ||||
| 	<ui-card> | ||||
| 		<div slot="title"><fa :icon="faServer"/> {{ $t('instances') }}</div> | ||||
| 		<section class="fit-top"> | ||||
| 			<ui-horizon-group inputs> | ||||
| 				<ui-select v-model="sort"> | ||||
| 					<span slot="label">{{ $t('sort') }}</span> | ||||
| 					<option value="-caughtAt">{{ $t('sorts.caughtAtAsc') }}</option> | ||||
| 					<option value="+caughtAt">{{ $t('sorts.caughtAtDesc') }}</option> | ||||
| 					<option value="-lastCommunicatedAt">{{ $t('sorts.lastCommunicatedAtAsc') }}</option> | ||||
| 					<option value="+lastCommunicatedAt">{{ $t('sorts.lastCommunicatedAtDesc') }}</option> | ||||
| 					<option value="-notes">{{ $t('sorts.notesAsc') }}</option> | ||||
| 					<option value="+notes">{{ $t('sorts.notesDesc') }}</option> | ||||
| 					<option value="-users">{{ $t('sorts.usersAsc') }}</option> | ||||
| 					<option value="+users">{{ $t('sorts.usersDesc') }}</option> | ||||
| 					<option value="-following">{{ $t('sorts.followingAsc') }}</option> | ||||
| 					<option value="+following">{{ $t('sorts.followingDesc') }}</option> | ||||
| 					<option value="-followers">{{ $t('sorts.followersAsc') }}</option> | ||||
| 					<option value="+followers">{{ $t('sorts.followersDesc') }}</option> | ||||
| 					<option value="-driveUsage">{{ $t('sorts.driveUsageAsc') }}</option> | ||||
| 					<option value="+driveUsage">{{ $t('sorts.driveUsageDesc') }}</option> | ||||
| 					<option value="-driveFiles">{{ $t('sorts.driveFilesAsc') }}</option> | ||||
| 					<option value="+driveFiles">{{ $t('sorts.driveFilesDesc') }}</option> | ||||
| 				</ui-select> | ||||
| 				<ui-select v-model="state"> | ||||
| 					<span slot="label">{{ $t('state') }}</span> | ||||
| 					<option value="all">{{ $t('states.all') }}</option> | ||||
| 					<option value="blocked">{{ $t('states.blocked') }}</option> | ||||
| 					<option value="notResponding">{{ $t('states.not-responding') }}</option> | ||||
| 					<option value="markedAsClosed">{{ $t('states.marked-as-closed') }}</option> | ||||
| 				</ui-select> | ||||
| 			</ui-horizon-group> | ||||
|  | ||||
| 			<div class="instances"> | ||||
| 				<header> | ||||
| 					<span>{{ $t('host') }}</span> | ||||
| 					<span>{{ $t('notes') }}</span> | ||||
| 					<span>{{ $t('users') }}</span> | ||||
| 					<span>{{ $t('following') }}</span> | ||||
| 					<span>{{ $t('followers') }}</span> | ||||
| 					<span>{{ $t('status') }}</span> | ||||
| 				</header> | ||||
| 				<div v-for="instance in instances" :style="{ opacity: instance.isNotResponding ? 0.5 : 1 }"> | ||||
| 					<a @click.prevent="showInstance(instance.host)" target="_blank" :href="`https://${instance.host}`" :style="{ textDecoration: instance.isMarkedAsClosed ? 'line-through' : 'none' }">{{ instance.host }}</a> | ||||
| 					<span>{{ instance.notesCount | number }}</span> | ||||
| 					<span>{{ instance.usersCount | number }}</span> | ||||
| 					<span>{{ instance.followingCount | number }}</span> | ||||
| 					<span>{{ instance.followersCount | number }}</span> | ||||
| 					<span>{{ instance.latestStatus }}</span> | ||||
| 				</div> | ||||
| 			</div> | ||||
|  | ||||
| 			<ui-info v-if="instances.length == limit">{{ $t('result-is-truncated', { n: limit }) }}</ui-info> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import i18n from '../../i18n'; | ||||
| import { faGlobe, faTerminal, faSearch, faMinusCircle, faServer } from '@fortawesome/free-solid-svg-icons'; | ||||
| import ApexCharts from 'apexcharts'; | ||||
| import * as tinycolor from 'tinycolor2'; | ||||
|  | ||||
| const chartLimit = 90; | ||||
| const sum = (...arr) => arr.reduce((r, a) => r.map((b, i) => a[i] + b)); | ||||
| const negate = arr => arr.map(x => -x); | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n: i18n('admin/views/federation.vue'), | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			instance: null, | ||||
| 			target: null, | ||||
| 			sort: '+lastCommunicatedAt', | ||||
| 			state: 'all', | ||||
| 			limit: 50, | ||||
| 			instances: [], | ||||
| 			chart: null, | ||||
| 			chartSrc: 'requests', | ||||
| 			chartSpan: 'hour', | ||||
| 			chartInstance: null, | ||||
| 			faGlobe, faTerminal, faSearch, faMinusCircle, faServer | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	computed: { | ||||
| 		data(): any { | ||||
| 			if (this.chart == null) return null; | ||||
| 			switch (this.chartSrc) { | ||||
| 				case 'requests': return this.requestsChart(); | ||||
| 				case 'users': return this.usersChart(false); | ||||
| 				case 'users-total': return this.usersChart(true); | ||||
| 				case 'notes': return this.notesChart(false); | ||||
| 				case 'notes-total': return this.notesChart(true); | ||||
| 				case 'ff': return this.ffChart(false); | ||||
| 				case 'ff-total': return this.ffChart(true); | ||||
| 				case 'drive-usage': return this.driveUsageChart(false); | ||||
| 				case 'drive-usage-total': return this.driveUsageChart(true); | ||||
| 				case 'drive-files': return this.driveFilesChart(false); | ||||
| 				case 'drive-files-total': return this.driveFilesChart(true); | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
| 		stats(): any[] { | ||||
| 			const stats = | ||||
| 				this.chartSpan == 'day' ? this.chart.perDay : | ||||
| 				this.chartSpan == 'hour' ? this.chart.perHour : | ||||
| 				null; | ||||
|  | ||||
| 			return stats; | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	watch: { | ||||
| 		sort() { | ||||
| 			this.fetchInstances(); | ||||
| 		}, | ||||
|  | ||||
| 		state() { | ||||
| 			this.fetchInstances(); | ||||
| 		}, | ||||
|  | ||||
| 		async instance() { | ||||
| 			this.now = new Date(); | ||||
|  | ||||
| 			const [perHour, perDay] = await Promise.all([ | ||||
| 				this.$root.api('charts/instance', { host: this.instance.host, limit: chartLimit, span: 'hour' }), | ||||
| 				this.$root.api('charts/instance', { host: this.instance.host, limit: chartLimit, span: 'day' }), | ||||
| 			]); | ||||
|  | ||||
| 			const chart = { | ||||
| 				perHour: perHour, | ||||
| 				perDay: perDay | ||||
| 			}; | ||||
|  | ||||
| 			this.chart = chart; | ||||
|  | ||||
| 			this.renderChart(); | ||||
| 		}, | ||||
|  | ||||
| 		chartSrc() { | ||||
| 			this.renderChart(); | ||||
| 		}, | ||||
|  | ||||
| 		chartSpan() { | ||||
| 			this.renderChart(); | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	mounted() { | ||||
| 		this.fetchInstances(); | ||||
| 	}, | ||||
|  | ||||
| 	beforeDestroy() { | ||||
| 		this.chartInstance.destroy(); | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		showInstance(target?: string) { | ||||
| 			this.$root.api('federation/show-instance', { | ||||
| 				host: target || this.target | ||||
| 			}).then(instance => { | ||||
| 				if (instance == null) { | ||||
| 					this.$root.dialog({ | ||||
| 						type: 'error', | ||||
| 						text: this.$t('instance-not-registered') | ||||
| 					}); | ||||
| 				} else { | ||||
| 					this.instance = instance; | ||||
| 					this.target = ''; | ||||
| 				} | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		fetchInstances() { | ||||
| 			this.instances = []; | ||||
| 			this.$root.api('federation/instances', { | ||||
| 				blocked: this.state === 'blocked' ? true : null, | ||||
| 				notResponding: this.state === 'notResponding' ? true : null, | ||||
| 				markedAsClosed: this.state === 'markedAsClosed' ? true : null, | ||||
| 				sort: this.sort, | ||||
| 				limit: this.limit | ||||
| 			}).then(instances => { | ||||
| 				this.instances = instances; | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		removeAllFollowing() { | ||||
| 			this.$root.api('admin/federation/remove-all-following', { | ||||
| 				host: this.instance.host | ||||
| 			}).then(() => { | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					splash: true | ||||
| 				}); | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		updateInstance() { | ||||
| 			this.$root.api('admin/federation/update-instance', { | ||||
| 				host: this.instance.host, | ||||
| 				isBlocked: this.instance.isBlocked || false, | ||||
| 				isClosed: this.instance.isMarkedAsClosed || false | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		setSrc(src) { | ||||
| 			this.chartSrc = src; | ||||
| 		}, | ||||
|  | ||||
| 		renderChart() { | ||||
| 			if (this.chartInstance) { | ||||
| 				this.chartInstance.destroy(); | ||||
| 			} | ||||
|  | ||||
| 			this.chartInstance = new ApexCharts(this.$refs.chart, { | ||||
| 				chart: { | ||||
| 					type: 'area', | ||||
| 					height: 300, | ||||
| 					animations: { | ||||
| 						dynamicAnimation: { | ||||
| 							enabled: false | ||||
| 						} | ||||
| 					}, | ||||
| 					toolbar: { | ||||
| 						show: false | ||||
| 					}, | ||||
| 					zoom: { | ||||
| 						enabled: false | ||||
| 					} | ||||
| 				}, | ||||
| 				dataLabels: { | ||||
| 					enabled: false | ||||
| 				}, | ||||
| 				grid: { | ||||
| 					clipMarkers: false, | ||||
| 					borderColor: 'rgba(0, 0, 0, 0.1)' | ||||
| 				}, | ||||
| 				stroke: { | ||||
| 					curve: 'straight', | ||||
| 					width: 2 | ||||
| 				}, | ||||
| 				tooltip: { | ||||
| 					theme: this.$store.state.device.darkmode ? 'dark' : 'light' | ||||
| 				}, | ||||
| 				legend: { | ||||
| 					labels: { | ||||
| 						colors: tinycolor(getComputedStyle(document.documentElement).getPropertyValue('--text')).toRgbString() | ||||
| 					}, | ||||
| 				}, | ||||
| 				xaxis: { | ||||
| 					type: 'datetime', | ||||
| 					labels: { | ||||
| 						style: { | ||||
| 							colors: tinycolor(getComputedStyle(document.documentElement).getPropertyValue('--text')).toRgbString() | ||||
| 						} | ||||
| 					}, | ||||
| 					axisBorder: { | ||||
| 						color: 'rgba(0, 0, 0, 0.1)' | ||||
| 					}, | ||||
| 					axisTicks: { | ||||
| 						color: 'rgba(0, 0, 0, 0.1)' | ||||
| 					}, | ||||
| 				}, | ||||
| 				yaxis: { | ||||
| 					labels: { | ||||
| 						formatter: this.data.bytes ? v => Vue.filter('bytes')(v, 0) : v => Vue.filter('number')(v), | ||||
| 						style: { | ||||
| 							color: tinycolor(getComputedStyle(document.documentElement).getPropertyValue('--text')).toRgbString() | ||||
| 						} | ||||
| 					} | ||||
| 				}, | ||||
| 				series: this.data.series | ||||
| 			}); | ||||
|  | ||||
| 			this.chartInstance.render(); | ||||
| 		}, | ||||
|  | ||||
| 		getDate(i: number) { | ||||
| 			const y = this.now.getFullYear(); | ||||
| 			const m = this.now.getMonth(); | ||||
| 			const d = this.now.getDate(); | ||||
| 			const h = this.now.getHours(); | ||||
|  | ||||
| 			return ( | ||||
| 				this.chartSpan == 'day' ? new Date(y, m, d - i) : | ||||
| 				this.chartSpan == 'hour' ? new Date(y, m, d, h - i) : | ||||
| 				null | ||||
| 			); | ||||
| 		}, | ||||
|  | ||||
| 		format(arr) { | ||||
| 			return arr.map((v, i) => ({ x: this.getDate(i).getTime(), y: v })); | ||||
| 		}, | ||||
|  | ||||
| 		requestsChart(): any { | ||||
| 			return { | ||||
| 				series: [{ | ||||
| 					name: 'Incoming', | ||||
| 					data: this.format(this.stats.requests.received) | ||||
| 				}, { | ||||
| 					name: 'Outgoing (succeeded)', | ||||
| 					data: this.format(this.stats.requests.succeeded) | ||||
| 				}, { | ||||
| 					name: 'Outgoing (failed)', | ||||
| 					data: this.format(this.stats.requests.failed) | ||||
| 				}] | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		usersChart(total: boolean): any { | ||||
| 			return { | ||||
| 				series: [{ | ||||
| 					name: 'Users', | ||||
| 					type: 'area', | ||||
| 					data: this.format(total | ||||
| 						? this.stats.users.total | ||||
| 						: sum(this.stats.users.inc, negate(this.stats.users.dec)) | ||||
| 					) | ||||
| 				}] | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		notesChart(total: boolean): any { | ||||
| 			return { | ||||
| 				series: [{ | ||||
| 					name: 'Notes', | ||||
| 					type: 'area', | ||||
| 					data: this.format(total | ||||
| 						? this.stats.notes.total | ||||
| 						: sum(this.stats.notes.inc, negate(this.stats.notes.dec)) | ||||
| 					) | ||||
| 				}] | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		ffChart(total: boolean): any { | ||||
| 			return { | ||||
| 				series: [{ | ||||
| 					name: 'Following', | ||||
| 					type: 'area', | ||||
| 					data: this.format(total | ||||
| 						? this.stats.following.total | ||||
| 						: sum(this.stats.following.inc, negate(this.stats.following.dec)) | ||||
| 					) | ||||
| 				}, { | ||||
| 					name: 'Followers', | ||||
| 					type: 'area', | ||||
| 					data: this.format(total | ||||
| 						? this.stats.followers.total | ||||
| 						: sum(this.stats.followers.inc, negate(this.stats.followers.dec)) | ||||
| 					) | ||||
| 				}] | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		driveUsageChart(total: boolean): any { | ||||
| 			return { | ||||
| 				bytes: true, | ||||
| 				series: [{ | ||||
| 					name: 'Drive usage', | ||||
| 					type: 'area', | ||||
| 					data: this.format(total | ||||
| 						? this.stats.drive.totalUsage | ||||
| 						: sum(this.stats.drive.incUsage, negate(this.stats.drive.decUsage)) | ||||
| 					) | ||||
| 				}] | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		driveFilesChart(total: boolean): any { | ||||
| 			return { | ||||
| 				series: [{ | ||||
| 					name: 'Drive files', | ||||
| 					type: 'area', | ||||
| 					data: this.format(total | ||||
| 						? this.stats.drive.totalFiles | ||||
| 						: sum(this.stats.drive.incFiles, negate(this.stats.drive.decFiles)) | ||||
| 					) | ||||
| 				}] | ||||
| 			}; | ||||
| 		}, | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .target | ||||
| 	margin-bottom 16px !important | ||||
|  | ||||
| .instances | ||||
| 	width 100% | ||||
|  | ||||
| 	> header | ||||
| 		display flex | ||||
|  | ||||
| 		> * | ||||
| 			color var(--text) | ||||
| 			font-weight bold | ||||
|  | ||||
| 	> div | ||||
| 		display flex | ||||
|  | ||||
| 	> * > * | ||||
| 		flex 1 | ||||
| 		overflow auto | ||||
|  | ||||
| 		&:first-child | ||||
| 			min-width 200px | ||||
|  | ||||
| </style> | ||||
| @@ -20,10 +20,11 @@ | ||||
| 		<ul> | ||||
| 			<li @click="nav('dashboard')" :class="{ active: page == 'dashboard' }"><fa icon="home" fixed-width/>{{ $t('dashboard') }}</li> | ||||
| 			<li @click="nav('instance')" :class="{ active: page == 'instance' }"><fa icon="cog" fixed-width/>{{ $t('instance') }}</li> | ||||
| 			<li @click="nav('queue')" :class="{ active: page == 'queue' }"><fa :icon="faTasks" fixed-width/>{{ $t('queue') }}</li> | ||||
| 			<li @click="nav('moderators')" :class="{ active: page == 'moderators' }"><fa :icon="faHeadset" fixed-width/>{{ $t('moderators') }}</li> | ||||
| 			<li @click="nav('users')" :class="{ active: page == 'users' }"><fa icon="users" fixed-width/>{{ $t('users') }}</li> | ||||
| 			<li @click="nav('drive')" :class="{ active: page == 'drive' }"><fa icon="cloud" fixed-width/>{{ $t('@.drive') }}</li> | ||||
| 			<!-- <li @click="nav('federation')" :class="{ active: page == 'federation' }"><fa :icon="faShareAlt" fixed-width/>{{ $t('federation') }}</li> --> | ||||
| 			<li @click="nav('federation')" :class="{ active: page == 'federation' }"><fa :icon="faGlobe" fixed-width/>{{ $t('federation') }}</li> | ||||
| 			<li @click="nav('emoji')" :class="{ active: page == 'emoji' }"><fa :icon="faGrin" fixed-width/>{{ $t('emoji') }}</li> | ||||
| 			<li @click="nav('announcements')" :class="{ active: page == 'announcements' }"><fa icon="broadcast-tower" fixed-width/>{{ $t('announcements') }}</li> | ||||
| 			<li @click="nav('hashtags')" :class="{ active: page == 'hashtags' }"><fa icon="hashtag" fixed-width/>{{ $t('hashtags') }}</li> | ||||
| @@ -40,12 +41,14 @@ | ||||
| 		<div class="page"> | ||||
| 			<div v-if="page == 'dashboard'"><x-dashboard/></div> | ||||
| 			<div v-if="page == 'instance'"><x-instance/></div> | ||||
| 			<div v-if="page == 'queue'"><x-queue/></div> | ||||
| 			<div v-if="page == 'moderators'"><x-moderators/></div> | ||||
| 			<div v-if="page == 'users'"><x-users/></div> | ||||
| 			<div v-if="page == 'emoji'"><x-emoji/></div> | ||||
| 			<div v-if="page == 'announcements'"><x-announcements/></div> | ||||
| 			<div v-if="page == 'hashtags'"><x-hashtags/></div> | ||||
| 			<div v-if="page == 'drive'"><x-drive/></div> | ||||
| 			<div v-if="page == 'federation'"><x-federation/></div> | ||||
| 			<div v-if="page == 'abuse'"><x-abuse/></div> | ||||
| 		</div> | ||||
| 	</main> | ||||
| @@ -58,6 +61,7 @@ import i18n from '../../i18n'; | ||||
| import { version } from '../../config'; | ||||
| import XDashboard from "./dashboard.vue"; | ||||
| import XInstance from "./instance.vue"; | ||||
| import XQueue from "./queue.vue"; | ||||
| import XModerators from "./moderators.vue"; | ||||
| import XEmoji from "./emoji.vue"; | ||||
| import XAnnouncements from "./announcements.vue"; | ||||
| @@ -65,7 +69,9 @@ import XHashtags from "./hashtags.vue"; | ||||
| import XUsers from "./users.vue"; | ||||
| import XDrive from "./drive.vue"; | ||||
| import XAbuse from "./abuse.vue"; | ||||
| import { faHeadset, faArrowLeft, faShareAlt, faExclamationCircle } from '@fortawesome/free-solid-svg-icons'; | ||||
| import XFederation from "./federation.vue"; | ||||
|  | ||||
| import { faHeadset, faArrowLeft, faGlobe, faExclamationCircle, faTasks } from '@fortawesome/free-solid-svg-icons'; | ||||
| import { faGrin } from '@fortawesome/free-regular-svg-icons'; | ||||
|  | ||||
| // Detect the user agent | ||||
| @@ -77,6 +83,7 @@ export default Vue.extend({ | ||||
| 	components: { | ||||
| 		XDashboard, | ||||
| 		XInstance, | ||||
| 		XQueue, | ||||
| 		XModerators, | ||||
| 		XEmoji, | ||||
| 		XAnnouncements, | ||||
| @@ -84,6 +91,7 @@ export default Vue.extend({ | ||||
| 		XUsers, | ||||
| 		XDrive, | ||||
| 		XAbuse, | ||||
| 		XFederation, | ||||
| 	}, | ||||
| 	provide: { | ||||
| 		isMobile | ||||
| @@ -97,8 +105,9 @@ export default Vue.extend({ | ||||
| 			faGrin, | ||||
| 			faArrowLeft, | ||||
| 			faHeadset, | ||||
| 			faShareAlt, | ||||
| 			faExclamationCircle | ||||
| 			faGlobe, | ||||
| 			faExclamationCircle, | ||||
| 			faTasks | ||||
| 		}; | ||||
| 	}, | ||||
| 	methods: { | ||||
|   | ||||
| @@ -6,8 +6,10 @@ | ||||
| 			<ui-input v-model="username" type="text"> | ||||
| 				<span slot="prefix">@</span> | ||||
| 			</ui-input> | ||||
| 			<ui-button @click="add" :disabled="changing">{{ $t('add-moderator.add') }}</ui-button> | ||||
| 			<ui-button @click="remove" :disabled="changing">{{ $t('add-moderator.remove') }}</ui-button> | ||||
| 			<ui-horizon-group> | ||||
| 				<ui-button @click="add" :disabled="changing">{{ $t('add-moderator.add') }}</ui-button> | ||||
| 				<ui-button @click="remove" :disabled="changing">{{ $t('add-moderator.remove') }}</ui-button> | ||||
| 			</ui-horizon-group> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
| </div> | ||||
|   | ||||
							
								
								
									
										43
									
								
								src/client/app/admin/views/queue.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								src/client/app/admin/views/queue.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,43 @@ | ||||
| <template> | ||||
| <div> | ||||
| 	<ui-card> | ||||
| 		<div slot="title">{{ $t('operation') }}</div> | ||||
| 		<section> | ||||
| 			<ui-button @click="removeAllJobs">{{ $t('remove-all-jobs') }}</ui-button> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import i18n from '../../i18n'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n: i18n('admin/views/queue.vue'), | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		async removeAllJobs() { | ||||
| 			const process = async () => { | ||||
| 				await this.$root.api('admin/queue/clear'); | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					splash: true | ||||
| 				}); | ||||
| 			}; | ||||
|  | ||||
| 			await process().catch(e => { | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'error', | ||||
| 					text: e.toString() | ||||
| 				}); | ||||
| 			}); | ||||
| 		}, | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
							
								
								
									
										85
									
								
								src/client/app/admin/views/users.user.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										85
									
								
								src/client/app/admin/views/users.user.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,85 @@ | ||||
| <template> | ||||
| <div class="kofvwchc"> | ||||
| 	<div> | ||||
| 		<a :href="user | userPage(null, true)"> | ||||
| 			<mk-avatar class="avatar" :user="user" :disable-link="true"/> | ||||
| 		</a> | ||||
| 	</div> | ||||
| 	<div> | ||||
| 		<header> | ||||
| 			<b><mk-user-name :user="user"/></b> | ||||
| 			<span class="username">@{{ user | acct }}</span> | ||||
| 			<span class="is-admin" v-if="user.isAdmin">admin</span> | ||||
| 			<span class="is-moderator" v-if="user.isModerator">moderator</span> | ||||
| 			<span class="is-verified" v-if="user.isVerified" :title="$t('@.verified-user')"><fa icon="star"/></span> | ||||
| 			<span class="is-silenced" v-if="user.isSilenced" :title="$t('@.silenced-user')"><fa :icon="faMicrophoneSlash"/></span> | ||||
| 			<span class="is-suspended" v-if="user.isSuspended" :title="$t('@.suspended-user')"><fa :icon="faSnowflake"/></span> | ||||
| 		</header> | ||||
| 		<div> | ||||
| 			<span>{{ $t('users.updatedAt') }}: <mk-time :time="user.updatedAt" mode="detail"/></span> | ||||
| 		</div> | ||||
| 		<div> | ||||
| 			<span>{{ $t('users.createdAt') }}: <mk-time :time="user.createdAt" mode="detail"/></span> | ||||
| 		</div> | ||||
| 	</div> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import i18n from '../../i18n'; | ||||
| import { faMicrophoneSlash } from '@fortawesome/free-solid-svg-icons'; | ||||
| import { faSnowflake } from '@fortawesome/free-regular-svg-icons'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n: i18n('admin/views/users.vue'), | ||||
| 	props: ['user'], | ||||
| 	data() { | ||||
| 		return { | ||||
| 			faSnowflake, faMicrophoneSlash | ||||
| 		}; | ||||
| 	}, | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .kofvwchc | ||||
| 	display flex | ||||
| 	padding 16px 0 | ||||
| 	border-top solid 1px var(--faceDivider) | ||||
|  | ||||
| 	> div:first-child | ||||
| 		> a | ||||
| 			> .avatar | ||||
| 				width 64px | ||||
| 				height 64px | ||||
|  | ||||
| 	> div:last-child | ||||
| 		flex 1 | ||||
| 		padding-left 16px | ||||
|  | ||||
| 		@media (max-width 500px) | ||||
| 			font-size 14px | ||||
|  | ||||
| 		> header | ||||
| 			> .username | ||||
| 				margin-left 8px | ||||
| 				opacity 0.7 | ||||
|  | ||||
| 			> .is-admin | ||||
| 			> .is-moderator | ||||
| 				flex-shrink 0 | ||||
| 				align-self center | ||||
| 				margin 0 0 0 .5em | ||||
| 				padding 1px 6px | ||||
| 				font-size 80% | ||||
| 				border-radius 3px | ||||
| 				background var(--noteHeaderAdminBg) | ||||
| 				color var(--noteHeaderAdminFg) | ||||
|  | ||||
| 			> .is-verified | ||||
| 			> .is-silenced | ||||
| 			> .is-suspended | ||||
| 				margin 0 0 0 .5em | ||||
| 				color #4dabf7 | ||||
| </style> | ||||
| @@ -3,20 +3,31 @@ | ||||
| 	<ui-card> | ||||
| 		<div slot="title"><fa :icon="faTerminal"/> {{ $t('operation') }}</div> | ||||
| 		<section class="fit-top"> | ||||
| 			<ui-input v-model="target" type="text"> | ||||
| 			<ui-input class="target" v-model="target" type="text" @enter="showUser"> | ||||
| 				<span>{{ $t('username-or-userid') }}</span> | ||||
| 			</ui-input> | ||||
| 			<ui-button @click="resetPassword"><fa :icon="faKey"/> {{ $t('reset-password') }}</ui-button> | ||||
| 			<ui-horizon-group> | ||||
| 				<ui-button @click="verifyUser" :disabled="verifying"><fa :icon="faCertificate"/> {{ $t('verify') }}</ui-button> | ||||
| 				<ui-button @click="unverifyUser" :disabled="unverifying">{{ $t('unverify') }}</ui-button> | ||||
| 			</ui-horizon-group> | ||||
| 			<ui-horizon-group> | ||||
| 				<ui-button @click="suspendUser" :disabled="suspending"><fa :icon="faSnowflake"/> {{ $t('suspend') }}</ui-button> | ||||
| 				<ui-button @click="unsuspendUser" :disabled="unsuspending">{{ $t('unsuspend') }}</ui-button> | ||||
| 			</ui-horizon-group> | ||||
| 			<ui-button @click="showUser"><fa :icon="faSearch"/> {{ $t('lookup') }}</ui-button> | ||||
| 			<ui-textarea v-if="user" :value="user | json5" readonly tall style="margin-top:16px;"></ui-textarea> | ||||
|  | ||||
| 			<div class="user" v-if="user"> | ||||
| 				<x-user :user='user'/> | ||||
| 				<div class="actions"> | ||||
| 					<ui-button @click="resetPassword"><fa :icon="faKey"/> {{ $t('reset-password') }}</ui-button> | ||||
| 					<ui-horizon-group> | ||||
| 						<ui-button @click="verifyUser" :disabled="verifying"><fa :icon="faCertificate"/> {{ $t('verify') }}</ui-button> | ||||
| 						<ui-button @click="unverifyUser" :disabled="unverifying">{{ $t('unverify') }}</ui-button> | ||||
| 					</ui-horizon-group> | ||||
| 					<ui-horizon-group> | ||||
| 						<ui-button @click="silenceUser"><fa :icon="faMicrophoneSlash"/> {{ $t('make-silence') }}</ui-button> | ||||
| 						<ui-button @click="unsilenceUser">{{ $t('unmake-silence') }}</ui-button> | ||||
| 					</ui-horizon-group> | ||||
| 					<ui-horizon-group> | ||||
| 						<ui-button @click="suspendUser" :disabled="suspending"><fa :icon="faSnowflake"/> {{ $t('suspend') }}</ui-button> | ||||
| 						<ui-button @click="unsuspendUser" :disabled="unsuspending">{{ $t('unsuspend') }}</ui-button> | ||||
| 					</ui-horizon-group> | ||||
| 					<ui-button v-if="user.host != null" @click="updateRemoteUser"><fa :icon="faSync"/> {{ $t('update-remote-user') }}</ui-button> | ||||
| 					<ui-textarea v-if="user" :value="user | json5" readonly tall style="margin-top:16px;"></ui-textarea> | ||||
| 				</div> | ||||
| 			</div> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
|  | ||||
| @@ -37,6 +48,7 @@ | ||||
| 					<option value="admin">{{ $t('users.state.admin') }}</option> | ||||
| 					<option value="moderator">{{ $t('users.state.moderator') }}</option> | ||||
| 					<option value="verified">{{ $t('users.state.verified') }}</option> | ||||
| 					<option value="silenced">{{ $t('users.state.silenced') }}</option> | ||||
| 					<option value="suspended">{{ $t('users.state.suspended') }}</option> | ||||
| 				</ui-select> | ||||
| 				<ui-select v-model="origin"> | ||||
| @@ -47,29 +59,7 @@ | ||||
| 				</ui-select> | ||||
| 			</ui-horizon-group> | ||||
| 			<sequential-entrance animation="entranceFromTop" delay="25"> | ||||
| 				<div class="kofvwchc" v-for="user in users" :key="user.id"> | ||||
| 					<div> | ||||
| 						<a :href="user | userPage(null, true)"> | ||||
| 							<mk-avatar class="avatar" :user="user" :disable-link="true"/> | ||||
| 						</a> | ||||
| 					</div> | ||||
| 					<div> | ||||
| 						<header> | ||||
| 							<b><mk-user-name :user="user"/></b> | ||||
| 							<span class="username">@{{ user | acct }}</span> | ||||
| 							<span class="is-admin" v-if="user.isAdmin">admin</span> | ||||
| 							<span class="is-moderator" v-if="user.isModerator">moderator</span> | ||||
| 							<span class="is-verified" v-if="user.isVerified" :title="$t('@.verified-user')"><fa icon="star"/></span> | ||||
| 							<span class="is-suspended" v-if="user.isSuspended" :title="$t('@.suspended-user')"><fa :icon="faSnowflake"/></span> | ||||
| 						</header> | ||||
| 						<div> | ||||
| 							<span>{{ $t('users.updatedAt') }}: <mk-time :time="user.updatedAt" mode="detail"/></span> | ||||
| 						</div> | ||||
| 						<div> | ||||
| 							<span>{{ $t('users.createdAt') }}: <mk-time :time="user.createdAt" mode="detail"/></span> | ||||
| 						</div> | ||||
| 					</div> | ||||
| 				</div> | ||||
| 				<x-user v-for="user in users" :user='user' :key="user.id"/> | ||||
| 			</sequential-entrance> | ||||
| 			<ui-button v-if="existMore" @click="fetchUsers">{{ $t('@.load-more') }}</ui-button> | ||||
| 		</section> | ||||
| @@ -81,12 +71,15 @@ | ||||
| import Vue from 'vue'; | ||||
| import i18n from '../../i18n'; | ||||
| import parseAcct from "../../../../misc/acct/parse"; | ||||
| import { faCertificate, faUsers, faTerminal, faSearch, faKey } from '@fortawesome/free-solid-svg-icons'; | ||||
| import { faCertificate, faUsers, faTerminal, faSearch, faKey, faSync, faMicrophoneSlash } from '@fortawesome/free-solid-svg-icons'; | ||||
| import { faSnowflake } from '@fortawesome/free-regular-svg-icons'; | ||||
| import XUser from './users.user.vue'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n: i18n('admin/views/users.vue'), | ||||
|  | ||||
| 	components: { | ||||
| 		XUser | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| 			user: null, | ||||
| @@ -97,12 +90,12 @@ export default Vue.extend({ | ||||
| 			unsuspending: false, | ||||
| 			sort: '+createdAt', | ||||
| 			state: 'all', | ||||
| 			origin: 'combined', | ||||
| 			origin: 'local', | ||||
| 			limit: 10, | ||||
| 			offset: 0, | ||||
| 			users: [], | ||||
| 			existMore: false, | ||||
| 			faTerminal, faCertificate, faUsers, faSnowflake, faSearch, faKey | ||||
| 			faTerminal, faCertificate, faUsers, faSnowflake, faSearch, faKey, faSync, faMicrophoneSlash | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| @@ -131,34 +124,56 @@ export default Vue.extend({ | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		async fetchUser() { | ||||
| 			try { | ||||
| 				return await this.$root.api('users/show', this.target.startsWith('@') ? parseAcct(this.target) : { userId: this.target }); | ||||
| 			} catch (e) { | ||||
| 				if (e == 'user not found') { | ||||
| 					this.$root.dialog({ | ||||
| 						type: 'error', | ||||
| 						text: this.$t('user-not-found') | ||||
| 					}); | ||||
| 				} else { | ||||
| 					this.$root.dialog({ | ||||
| 						type: 'error', | ||||
| 						text: e.toString() | ||||
| 					}); | ||||
| 				} | ||||
| 			} | ||||
| 		/** テキストエリアのユーザーを解決する */ | ||||
| 		fetchUser() { | ||||
| 			return new Promise((res) => { | ||||
| 				const usernamePromise = this.$root.api('users/show', parseAcct(this.target)); | ||||
| 				const idPromise = this.$root.api('users/show', { userId: this.target }); | ||||
|  | ||||
| 				let _notFound = false; | ||||
| 				const notFound = () => { | ||||
| 					if (_notFound) { | ||||
| 						this.$root.dialog({ | ||||
| 							type: 'error', | ||||
| 							text: this.$t('user-not-found') | ||||
| 						}); | ||||
| 					} else { | ||||
| 						_notFound = true; | ||||
| 					} | ||||
| 				}; | ||||
|  | ||||
| 				usernamePromise.then(res).catch(e => { | ||||
| 					if (e == 'user not found') { | ||||
| 						notFound(); | ||||
| 					} | ||||
| 				}); | ||||
| 				idPromise.then(res).catch(e => { | ||||
| 					notFound(); | ||||
| 				}); | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		/** テキストエリアから処理対象ユーザーを設定する */ | ||||
| 		async showUser() { | ||||
| 			this.user = null; | ||||
| 			const user = await this.fetchUser(); | ||||
| 			this.$root.api('admin/show-user', { userId: user.id }).then(info => { | ||||
| 				this.user = info; | ||||
| 			}); | ||||
| 			this.target = ''; | ||||
| 		}, | ||||
|  | ||||
| 		/** 処理対象ユーザーの情報を更新する */ | ||||
| 		async refreshUser() { | ||||
| 			this.$root.api('admin/show-user', { userId: this.user._id }).then(info => { | ||||
| 				this.user = info; | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		async resetPassword() { | ||||
| 			const user = await this.fetchUser(); | ||||
| 			this.$root.api('admin/reset-password', { userId: user.id }).then(res => { | ||||
| 			if (!await this.getConfirmed(this.$t('reset-password-confirm'))) return; | ||||
|  | ||||
| 			this.$root.api('admin/reset-password', { userId: this.user._id }).then(res => { | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					text: this.$t('password-updated', { password: res.password }) | ||||
| @@ -167,11 +182,12 @@ export default Vue.extend({ | ||||
| 		}, | ||||
|  | ||||
| 		async verifyUser() { | ||||
| 			if (!await this.getConfirmed(this.$t('verify-confirm'))) return; | ||||
|  | ||||
| 			this.verifying = true; | ||||
|  | ||||
| 			const process = async () => { | ||||
| 				const user = await this.fetchUser(); | ||||
| 				await this.$root.api('admin/verify-user', { userId: user.id }); | ||||
| 				await this.$root.api('admin/verify-user', { userId: this.user._id }); | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					text: this.$t('verified') | ||||
| @@ -186,14 +202,17 @@ export default Vue.extend({ | ||||
| 			}); | ||||
|  | ||||
| 			this.verifying = false; | ||||
|  | ||||
| 			this.refreshUser(); | ||||
| 		}, | ||||
|  | ||||
| 		async unverifyUser() { | ||||
| 			if (!await this.getConfirmed(this.$t('unverify-confirm'))) return; | ||||
|  | ||||
| 			this.unverifying = true; | ||||
|  | ||||
| 			const process = async () => { | ||||
| 				const user = await this.fetchUser(); | ||||
| 				await this.$root.api('admin/unverify-user', { userId: user.id }); | ||||
| 				await this.$root.api('admin/unverify-user', { userId: this.user._id }); | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					text: this.$t('unverified') | ||||
| @@ -208,14 +227,55 @@ export default Vue.extend({ | ||||
| 			}); | ||||
|  | ||||
| 			this.unverifying = false; | ||||
|  | ||||
| 			this.refreshUser(); | ||||
| 		}, | ||||
|  | ||||
| 		async silenceUser() { | ||||
| 			const process = async () => { | ||||
| 				await this.$root.api('admin/silence-user', { userId: this.user._id }); | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					splash: true | ||||
| 				}); | ||||
| 			}; | ||||
|  | ||||
| 			await process().catch(e => { | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'error', | ||||
| 					text: e.toString() | ||||
| 				}); | ||||
| 			}); | ||||
|  | ||||
| 			this.refreshUser(); | ||||
| 		}, | ||||
|  | ||||
| 		async unsilenceUser() { | ||||
| 			const process = async () => { | ||||
| 				await this.$root.api('admin/unsilence-user', { userId: this.user._id }); | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					splash: true | ||||
| 				}); | ||||
| 			}; | ||||
|  | ||||
| 			await process().catch(e => { | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'error', | ||||
| 					text: e.toString() | ||||
| 				}); | ||||
| 			}); | ||||
|  | ||||
| 			this.refreshUser(); | ||||
| 		}, | ||||
|  | ||||
| 		async suspendUser() { | ||||
| 			if (!await this.getConfirmed(this.$t('suspend-confirm'))) return; | ||||
|  | ||||
| 			this.suspending = true; | ||||
|  | ||||
| 			const process = async () => { | ||||
| 				const user = await this.fetchUser(); | ||||
| 				await this.$root.api('admin/suspend-user', { userId: user.id }); | ||||
| 				await this.$root.api('admin/suspend-user', { userId: this.user._id }); | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					text: this.$t('suspended') | ||||
| @@ -230,14 +290,17 @@ export default Vue.extend({ | ||||
| 			}); | ||||
|  | ||||
| 			this.suspending = false; | ||||
|  | ||||
| 			this.refreshUser(); | ||||
| 		}, | ||||
|  | ||||
| 		async unsuspendUser() { | ||||
| 			if (!await this.getConfirmed(this.$t('unsuspend-confirm'))) return; | ||||
|  | ||||
| 			this.unsuspending = true; | ||||
|  | ||||
| 			const process = async () => { | ||||
| 				const user = await this.fetchUser(); | ||||
| 				await this.$root.api('admin/unsuspend-user', { userId: user.id }); | ||||
| 				await this.$root.api('admin/unsuspend-user', { userId: this.user._id }); | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					text: this.$t('unsuspended') | ||||
| @@ -252,6 +315,30 @@ export default Vue.extend({ | ||||
| 			}); | ||||
|  | ||||
| 			this.unsuspending = false; | ||||
|  | ||||
| 			this.refreshUser(); | ||||
| 		}, | ||||
|  | ||||
| 		async updateRemoteUser() { | ||||
| 			this.$root.api('admin/update-remote-user', { userId: this.user._id }).then(res => { | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					text: this.$t('remote-user-updated') | ||||
| 				}); | ||||
| 			}); | ||||
|  | ||||
| 			this.refreshUser(); | ||||
| 		}, | ||||
|  | ||||
| 		async getConfirmed(text: string): Promise<Boolean> { | ||||
| 			const confirm = await this.$root.dialog({ | ||||
| 				type: 'warning', | ||||
| 				showCancelButton: true, | ||||
| 				title: 'confirm', | ||||
| 				text, | ||||
| 			}); | ||||
|  | ||||
| 			return !confirm.canceled; | ||||
| 		}, | ||||
|  | ||||
| 		fetchUsers() { | ||||
| @@ -277,42 +364,12 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .kofvwchc | ||||
| 	display flex | ||||
| 	padding 16px 0 | ||||
| 	border-top solid 1px var(--faceDivider) | ||||
| .target | ||||
| 	margin-bottom 16px !important | ||||
|  | ||||
| 	> div:first-child | ||||
| 		> a | ||||
| 			> .avatar | ||||
| 				width 64px | ||||
| 				height 64px | ||||
| .user | ||||
| 	margin-top 32px | ||||
|  | ||||
| 	> div:last-child | ||||
| 		flex 1 | ||||
| 		padding-left 16px | ||||
|  | ||||
| 		@media (max-width 500px) | ||||
| 			font-size 14px | ||||
|  | ||||
| 		> header | ||||
| 			> .username | ||||
| 				margin-left 8px | ||||
| 				opacity 0.7 | ||||
|  | ||||
| 			> .is-admin | ||||
| 			> .is-moderator | ||||
| 				flex-shrink 0 | ||||
| 				align-self center | ||||
| 				margin 0 0 0 .5em | ||||
| 				padding 1px 6px | ||||
| 				font-size 80% | ||||
| 				border-radius 3px | ||||
| 				background var(--noteHeaderAdminBg) | ||||
| 				color var(--noteHeaderAdminFg) | ||||
|  | ||||
| 			> .is-verified | ||||
| 			> .is-suspended | ||||
| 				margin 0 0 0 .5em | ||||
| 				color #4dabf7 | ||||
| 	> .actions | ||||
| 		margin-left 80px | ||||
| </style> | ||||
|   | ||||
| @@ -26,3 +26,16 @@ | ||||
| 		transform: translateY(0); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| @keyframes spin { | ||||
| 	0% { transform: rotate(0deg); } | ||||
| 	100% { transform: rotate(360deg); } | ||||
| } | ||||
|  | ||||
| @keyframes jump { | ||||
| 	0% { transform: translateY(0); } | ||||
| 	25% { transform: translateY(-16px); } | ||||
| 	50% { transform: translateY(0); } | ||||
| 	75% { transform: translateY(-8px); } | ||||
| 	100% { transform: translateY(0); } | ||||
| } | ||||
|   | ||||
| @@ -72,47 +72,6 @@ body | ||||
| code | ||||
| 	font-family Consolas, 'Courier New', Courier, Monaco, monospace | ||||
|  | ||||
| 	.comment | ||||
| 		opacity 0.5 | ||||
|  | ||||
| 	.string | ||||
| 		color #e96900 | ||||
|  | ||||
| 	.regexp | ||||
| 		color #e9003f | ||||
|  | ||||
| 	.keyword | ||||
| 		color #2973b7 | ||||
|  | ||||
| 		&.true | ||||
| 		&.false | ||||
| 		&.null | ||||
| 		&.nil | ||||
| 		&.undefined | ||||
| 			color #ae81ff | ||||
|  | ||||
| 	.symbol | ||||
| 		color #42b983 | ||||
|  | ||||
| 	.number | ||||
| 	.nan | ||||
| 		color #ae81ff | ||||
|  | ||||
| 	.var:not(.keyword) | ||||
| 		font-weight bold | ||||
| 		font-style italic | ||||
| 		//text-decoration underline | ||||
|  | ||||
| 	.method | ||||
| 		font-style italic | ||||
| 		color #8964c1 | ||||
|  | ||||
| 	.property | ||||
| 		color #a71d5d | ||||
|  | ||||
| 	.label | ||||
| 		color #e9003f | ||||
|  | ||||
| pre | ||||
| 	display block | ||||
|  | ||||
|   | ||||
| @@ -62,23 +62,26 @@ | ||||
| 	} | ||||
|  | ||||
| 	if (settings && settings.device.lang && | ||||
| 		langs.includes(settings.device.lang)) { | ||||
| 		langs.includes(settings.device.lang)) | ||||
| 	{ | ||||
| 		lang = settings.device.lang; | ||||
| 	} | ||||
|  | ||||
| 	window.lang = lang; | ||||
| 	localStorage.setItem('lang', lang); | ||||
| 	//#endregion | ||||
|  | ||||
| 	let locale = localStorage.getItem('locale'); | ||||
| 	//#region Fetch locale data | ||||
| 	const cachedLocale = localStorage.getItem('locale'); | ||||
| 	const localeKey = localStorage.getItem('localeKey'); | ||||
|  | ||||
| 	if (locale == null || localeKey != `${ver}.${lang}`) { | ||||
| 	if (cachedLocale == null || localeKey != `${ver}.${lang}`) { | ||||
| 		const locale = await fetch(`/assets/locales/${lang}.json?ver=${ver}`) | ||||
| 			.then(response => response.json()); | ||||
|  | ||||
| 			localStorage.setItem('locale', JSON.stringify(locale)); | ||||
| 			localStorage.setItem('localeKey', `${ver}.${lang}`); | ||||
| 		localStorage.setItem('locale', JSON.stringify(locale)); | ||||
| 		localStorage.setItem('localeKey', `${ver}.${lang}`); | ||||
| 	} | ||||
| 	//#endregion | ||||
|  | ||||
| 	// Detect the user agent | ||||
| 	const ua = navigator.userAgent.toLowerCase(); | ||||
|   | ||||
| @@ -2,12 +2,32 @@ | ||||
|  * Clipboardに値をコピー(TODO: 文字列以外も対応) | ||||
|  */ | ||||
| export default val => { | ||||
| 	const form = document.createElement('textarea'); | ||||
| 	form.textContent = val; | ||||
| 	document.body.appendChild(form); | ||||
| 	form.select(); | ||||
| 	// 空div 生成 | ||||
| 	const tmp = document.createElement('div'); | ||||
| 	// 選択用のタグ生成 | ||||
| 	const pre = document.createElement('pre'); | ||||
|  | ||||
| 	// 親要素のCSSで user-select: none だとコピーできないので書き換える | ||||
| 	pre.style.webkitUserSelect = 'auto'; | ||||
| 	pre.style.userSelect = 'auto'; | ||||
|  | ||||
| 	tmp.appendChild(pre).textContent = val; | ||||
|  | ||||
| 	// 要素を画面外へ | ||||
| 	const s = tmp.style; | ||||
| 	s.position = 'fixed'; | ||||
| 	s.right = '200%'; | ||||
|  | ||||
| 	// body に追加 | ||||
| 	document.body.appendChild(tmp); | ||||
| 	// 要素を選択 | ||||
| 	document.getSelection().selectAllChildren(tmp); | ||||
|  | ||||
| 	// クリップボードにコピー | ||||
| 	const result = document.execCommand('copy'); | ||||
| 	document.body.removeChild(form); | ||||
|  | ||||
| 	// 要素削除 | ||||
| 	document.body.removeChild(tmp); | ||||
|  | ||||
| 	return result; | ||||
| }; | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| // スクリプトサイズがデカい | ||||
| //const crypto = require('crypto'); | ||||
| //import * as crypto from 'crypto'; | ||||
|  | ||||
| export default (data: ArrayBuffer) => { | ||||
| 	//const buf = new Buffer(data); | ||||
|   | ||||
							
								
								
									
										11
									
								
								src/client/app/common/scripts/get-static-image-url.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								src/client/app/common/scripts/get-static-image-url.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | ||||
| import { url as instanceUrl } from '../../config'; | ||||
| import * as url from '../../../../prelude/url'; | ||||
|  | ||||
| export function getStaticImageUrl(baseUrl: string): string { | ||||
| 	const u = new URL(baseUrl); | ||||
| 	const dummy = `${u.host}${u.pathname}`;	// 拡張子がないとキャッシュしてくれないCDNがあるので | ||||
| 	return `${instanceUrl}/proxy/${dummy}?${url.query({ | ||||
| 		url: u.href, | ||||
| 		static: '1' | ||||
| 	})}`; | ||||
| } | ||||
| @@ -1,4 +1,4 @@ | ||||
| const NProgress = require('nprogress'); | ||||
| import * as NProgress from 'nprogress'; | ||||
| NProgress.configure({ | ||||
| 	trickleSpeed: 500, | ||||
| 	showSpinner: false | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| import parse from '../../../../mfm/parse'; | ||||
| import { parse } from '../../../../mfm/parse'; | ||||
| import { sum, unique } from '../../../../prelude/array'; | ||||
| import shouldMuteNote from './should-mute-note'; | ||||
| import MkNoteMenu from '../views/components/note-menu.vue'; | ||||
|   | ||||
| @@ -133,6 +133,7 @@ export default prop => ({ | ||||
|  | ||||
| 				case 'deleted': { | ||||
| 					Vue.set(this.$_ns_target, 'deletedAt', body.deletedAt); | ||||
| 					Vue.set(this.$_ns_target, 'renote', null); | ||||
| 					this.$_ns_target.text = null; | ||||
| 					this.$_ns_target.tags = []; | ||||
| 					this.$_ns_target.fileIds = []; | ||||
|   | ||||
							
								
								
									
										18
									
								
								src/client/app/common/size.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								src/client/app/common/size.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | ||||
| export default { | ||||
| 	install(Vue) { | ||||
| 		Vue.directive('size', { | ||||
| 			inserted(el, binding) { | ||||
| 				const query = binding.value; | ||||
| 				const width = el.clientWidth; | ||||
| 				for (const q of query) { | ||||
| 					if (q.lt && (width <= q.lt)) { | ||||
| 						el.classList.add(q.class); | ||||
| 					} | ||||
| 					if (q.gt && (width >= q.gt)) { | ||||
| 						el.classList.add(q.class); | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 		}); | ||||
| 	} | ||||
| }; | ||||
| @@ -1,15 +1,25 @@ | ||||
| <template> | ||||
| <div class="mk-activity"> | ||||
| <div> | ||||
| 	<div ref="chart"></div> | ||||
| </div> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import * as ApexCharts from 'apexcharts'; | ||||
| import ApexCharts from 'apexcharts'; | ||||
| 
 | ||||
| export default Vue.extend({ | ||||
| 	props: ['user'], | ||||
| 	props: { | ||||
| 		user: { | ||||
| 			type: Object, | ||||
| 			required: true | ||||
| 		}, | ||||
| 		limit: { | ||||
| 			type: Number, | ||||
| 			required: false, | ||||
| 			default: 21 | ||||
| 		} | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| 			fetching: true, | ||||
| @@ -21,7 +31,7 @@ export default Vue.extend({ | ||||
| 		this.$root.api('charts/user/notes', { | ||||
| 			userId: this.user.id, | ||||
| 			span: 'day', | ||||
| 			limit: 21 | ||||
| 			limit: this.limit | ||||
| 		}).then(stats => { | ||||
| 			const normal = []; | ||||
| 			const reply = []; | ||||
| @@ -32,7 +42,7 @@ export default Vue.extend({ | ||||
| 			const m = now.getMonth(); | ||||
| 			const d = now.getDate(); | ||||
| 
 | ||||
| 			for (let i = 0; i < 21; i++) { | ||||
| 			for (let i = 0; i < this.limit; i++) { | ||||
| 				const x = new Date(y, m, d - i); | ||||
| 				normal.push([ | ||||
| 					x, | ||||
| @@ -99,10 +109,3 @@ export default Vue.extend({ | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
| 
 | ||||
| <style lang="stylus" scoped> | ||||
| .mk-activity | ||||
| 	max-width 600px | ||||
| 	margin 0 auto | ||||
| 
 | ||||
| </style> | ||||
| @@ -15,6 +15,7 @@ | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { getStaticImageUrl } from '../../../common/scripts/get-static-image-url'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: { | ||||
| @@ -47,6 +48,11 @@ export default Vue.extend({ | ||||
| 				borderRadius: this.$store.state.settings.circleIcons ? '100%' : null | ||||
| 			}; | ||||
| 		}, | ||||
| 		url(): string { | ||||
| 			return this.$store.state.device.disableShowingAnimatedImages | ||||
| 				? getStaticImageUrl(this.user.avatarUrl) | ||||
| 				: this.user.avatarUrl; | ||||
| 		}, | ||||
| 		icon(): any { | ||||
| 			return { | ||||
| 				backgroundColor: this.lightmode | ||||
| @@ -54,7 +60,7 @@ export default Vue.extend({ | ||||
| 					: this.user.avatarColor && this.user.avatarColor.length == 3 | ||||
| 						? `rgb(${this.user.avatarColor.join(',')})` | ||||
| 						: null, | ||||
| 				backgroundImage: this.lightmode ? null : `url(${this.user.avatarUrl})`, | ||||
| 				backgroundImage: this.lightmode ? null : `url(${this.url})`, | ||||
| 				borderRadius: this.$store.state.settings.circleIcons ? '100%' : null | ||||
| 			}; | ||||
| 		} | ||||
|   | ||||
							
								
								
									
										30
									
								
								src/client/app/common/views/components/code-core.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								src/client/app/common/views/components/code-core.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | ||||
| <template> | ||||
| <prism :inline="inline" :language="lang || 'js'">{{ code }}</prism> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import 'prismjs'; | ||||
| import 'prismjs/themes/prism-okaidia.css'; | ||||
| import Prism from 'vue-prism-component'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	components: { | ||||
| 		Prism | ||||
| 	}, | ||||
| 	props: { | ||||
| 		code: { | ||||
| 			type: String, | ||||
| 			required: true | ||||
| 		}, | ||||
| 		lang: { | ||||
| 			type: String, | ||||
| 			required: false | ||||
| 		}, | ||||
| 		inline: { | ||||
| 			type: Boolean, | ||||
| 			required: false | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
							
								
								
									
										28
									
								
								src/client/app/common/views/components/code.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								src/client/app/common/views/components/code.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,28 @@ | ||||
| <template> | ||||
| <x-code :code="code" :lang="lang" :inline="inline"/> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	components: { | ||||
| 		XCode: () => import('./code-core.vue').then(m => m.default) | ||||
| 	}, | ||||
|  | ||||
| 	props: { | ||||
| 		code: { | ||||
| 			type: String, | ||||
| 			required: true | ||||
| 		}, | ||||
| 		lang: { | ||||
| 			type: String, | ||||
| 			required: false | ||||
| 		}, | ||||
| 		inline: { | ||||
| 			type: Boolean, | ||||
| 			required: false | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
| @@ -18,7 +18,7 @@ | ||||
| import Vue from 'vue'; | ||||
| import i18n from '../../../i18n'; | ||||
| import * as tinycolor from 'tinycolor2'; | ||||
| import * as ApexCharts from 'apexcharts'; | ||||
| import ApexCharts from 'apexcharts'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n: i18n('common/views/components/drive-settings.vue'), | ||||
|   | ||||
							
								
								
									
										11
									
								
								src/client/app/common/views/components/dummy.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								src/client/app/common/views/components/dummy.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | ||||
| <template> | ||||
| <div> | ||||
| 	<slot></slot> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| export default Vue.extend({ | ||||
| }); | ||||
| </script> | ||||
| @@ -9,6 +9,7 @@ | ||||
| import Vue from 'vue'; | ||||
| // スクリプトサイズがデカい | ||||
| //import { lib } from 'emojilib'; | ||||
| import { getStaticImageUrl } from '../../../common/scripts/get-static-image-url'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: { | ||||
| @@ -54,7 +55,9 @@ export default Vue.extend({ | ||||
| 			const customEmoji = this.customEmojis.find(x => x.name == this.name); | ||||
| 			if (customEmoji) { | ||||
| 				this.customEmoji = customEmoji; | ||||
| 				this.url = customEmoji.url; | ||||
| 				this.url = this.$store.state.device.disableShowingAnimatedImages | ||||
| 					? getStaticImageUrl(customEmoji.url) | ||||
| 					: customEmoji.url; | ||||
| 			} else { | ||||
| 				//const emoji = lib[this.name]; | ||||
| 				//if (emoji) { | ||||
|   | ||||
| @@ -1,8 +1,9 @@ | ||||
| <template> | ||||
| <button class="wfliddvnhxvyusikowhxozkyxyenqxqr" | ||||
| 	:class="{ wait, block, mini, active: isFollowing || hasPendingFollowRequestFromYou }" | ||||
| 	:class="{ wait, block, inline, mini, active: isFollowing || hasPendingFollowRequestFromYou }" | ||||
| 	@click="onClick" | ||||
| 	:disabled="wait" | ||||
| 	:inline="inline" | ||||
| > | ||||
| 	<template v-if="!wait"> | ||||
| 		<fa :icon="iconAndText[0]"/> <template v-if="!mini">{{ iconAndText[1] }}</template> | ||||
| @@ -28,6 +29,11 @@ export default Vue.extend({ | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		}, | ||||
| 		inline: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		}, | ||||
| 		mini: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| @@ -128,6 +134,9 @@ export default Vue.extend({ | ||||
| 	border solid 1px var(--primary) | ||||
| 	border-radius 36px | ||||
|  | ||||
| 	&.inline | ||||
| 		display inline-block | ||||
|  | ||||
| 	&.mini | ||||
| 		padding 0 | ||||
| 		min-width 0 | ||||
|   | ||||
| @@ -1,5 +1,6 @@ | ||||
| <template> | ||||
| <span v-html="compiledFormula"></span> | ||||
| <div v-if="block" v-html="compiledFormula"></div> | ||||
| <span v-else v-html="compiledFormula"></span> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| @@ -11,6 +12,10 @@ export default Vue.extend({ | ||||
| 		formula: { | ||||
| 			type: String, | ||||
| 			required: true | ||||
| 		}, | ||||
| 		block: { | ||||
| 			type: Boolean, | ||||
| 			required: true | ||||
| 		} | ||||
| 	}, | ||||
| 	computed: { | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| <template> | ||||
| <x-formula :formula="formula"/> | ||||
| <x-formula :formula="formula" :block="block" /> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| @@ -14,6 +14,10 @@ export default Vue.extend({ | ||||
| 		formula: { | ||||
| 			type: String, | ||||
| 			required: true | ||||
| 		}, | ||||
| 		block: { | ||||
| 			type: Boolean, | ||||
| 			required: true | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
|   | ||||
| @@ -1,5 +1,6 @@ | ||||
| import Vue from 'vue'; | ||||
|  | ||||
| import dummy from './dummy.vue'; | ||||
| import userName from './user-name.vue'; | ||||
| import followButton from './follow-button.vue'; | ||||
| import error from './error.vue'; | ||||
| @@ -32,6 +33,7 @@ import urlPreview from './url-preview.vue'; | ||||
| import fileTypeIcon from './file-type-icon.vue'; | ||||
| import emoji from './emoji.vue'; | ||||
| import welcomeTimeline from './welcome-timeline.vue'; | ||||
| import userList from './user-list.vue'; | ||||
| import uiInput from './ui/input.vue'; | ||||
| import uiButton from './ui/button.vue'; | ||||
| import uiHorizonGroup from './ui/horizon-group.vue'; | ||||
| @@ -46,6 +48,7 @@ import formButton from './ui/form/button.vue'; | ||||
| import formRadio from './ui/form/radio.vue'; | ||||
|  | ||||
| Vue.component('mfm', misskeyFlavoredMarkdown); | ||||
| Vue.component('mk-dummy', dummy); | ||||
| Vue.component('mk-user-name', userName); | ||||
| Vue.component('mk-follow-button', followButton); | ||||
| Vue.component('mk-error', error); | ||||
| @@ -77,6 +80,7 @@ Vue.component('mk-url-preview', urlPreview); | ||||
| Vue.component('mk-file-type-icon', fileTypeIcon); | ||||
| Vue.component('mk-emoji', emoji); | ||||
| Vue.component('mk-welcome-timeline', welcomeTimeline); | ||||
| Vue.component('mk-user-list', userList); | ||||
| Vue.component('ui-input', uiInput); | ||||
| Vue.component('ui-button', uiButton); | ||||
| Vue.component('ui-horizon-group', uiHorizonGroup); | ||||
|   | ||||
| @@ -11,6 +11,7 @@ | ||||
| 			:title="media.name" | ||||
| 			controls | ||||
| 			ref="audio" | ||||
| 			@volumechange="volumechange" | ||||
| 			preload="metadata" /> | ||||
| 	</div> | ||||
| 	<a class="download" v-else | ||||
| @@ -40,7 +41,17 @@ export default Vue.extend({ | ||||
| 		return { | ||||
| 			hide: true | ||||
| 		}; | ||||
| 	} | ||||
| 	}, | ||||
| 	mounted() { | ||||
| 		const audioTag = this.$refs.audio as HTMLAudioElement; | ||||
| 		audioTag.volume = this.$store.state.device.mediaVolume; | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		volumechange() { | ||||
| 			const audioTag = this.$refs.audio as HTMLAudioElement; | ||||
| 			this.$store.commit('device/set', { key: 'mediaVolume', value: audioTag.volume }); | ||||
| 		}, | ||||
| 	}, | ||||
| }) | ||||
| </script> | ||||
|  | ||||
|   | ||||
| @@ -5,16 +5,24 @@ | ||||
| 		<span>{{ $t('click-to-show') }}</span> | ||||
| 	</div> | ||||
| </div> | ||||
| <a class="gqnyydlzavusgskkfvwvjiattxdzsqlf" v-else :href="image.url" target="_blank" :style="style" :title="image.name" @click.prevent="onClick"></a> | ||||
| <a class="gqnyydlzavusgskkfvwvjiattxdzsqlf" v-else | ||||
| 	:href="image.url" | ||||
| 	:style="style" | ||||
| 	:title="image.name" | ||||
| 	@click.prevent="onClick" | ||||
| > | ||||
| 	<div v-if="image.type === 'image/gif'">GIF</div> | ||||
| </a> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import i18n from '../../../i18n'; | ||||
| import ImageViewer from '../../../common/views/components/image-viewer.vue'; | ||||
| import ImageViewer from './image-viewer.vue'; | ||||
| import { getStaticImageUrl } from '../../../common/scripts/get-static-image-url'; | ||||
| 
 | ||||
| export default Vue.extend({ | ||||
| 	i18n: i18n('mobile/views/components/media-image.vue'), | ||||
| 	i18n: i18n('common/views/components/media-image.vue'), | ||||
| 	props: { | ||||
| 		image: { | ||||
| 			type: Object, | ||||
| @@ -31,7 +39,11 @@ export default Vue.extend({ | ||||
| 	} | ||||
| 	computed: { | ||||
| 		style(): any { | ||||
| 			let url = `url(${this.image.thumbnailUrl})`; | ||||
| 			let url = `url(${ | ||||
| 				this.$store.state.device.disableShowingAnimatedImages | ||||
| 					? getStaticImageUrl(this.image.thumbnailUrl) | ||||
| 					: this.image.thumbnailUrl | ||||
| 			})`; | ||||
| 
 | ||||
| 			if (this.$store.state.device.loadRemoteMedia || this.$store.state.device.lightmode) { | ||||
| 				url = null; | ||||
| @@ -58,6 +70,7 @@ export default Vue.extend({ | ||||
| <style lang="stylus" scoped> | ||||
| .gqnyydlzavusgskkfvwvjiattxdzsqlf | ||||
| 	display block | ||||
| 	cursor zoom-in | ||||
| 	overflow hidden | ||||
| 	width 100% | ||||
| 	height 100% | ||||
| @@ -65,6 +78,20 @@ export default Vue.extend({ | ||||
| 	background-size contain | ||||
| 	background-repeat no-repeat | ||||
| 
 | ||||
| 	> div | ||||
| 		background-color var(--text) | ||||
| 		border-radius var(--round) | ||||
| 		color var(--secondary) | ||||
| 		display inline-block | ||||
| 		font-size 14px | ||||
| 		font-weight bold | ||||
| 		left 12px | ||||
| 		opacity .5 | ||||
| 		padding 0 6px | ||||
| 		text-align center | ||||
| 		top 12px | ||||
| 		pointer-events none | ||||
| 
 | ||||
| .qjewsnkgzzxlxtzncydssfbgjibiehcy | ||||
| 	display flex | ||||
| 	justify-content center | ||||
| @@ -7,7 +7,7 @@ | ||||
| 		<div :data-count="mediaList.filter(media => previewable(media)).length" ref="grid"> | ||||
| 			<template v-for="media in mediaList"> | ||||
| 				<mk-media-video :video="media" :key="media.id" v-if="media.type.startsWith('video')"/> | ||||
| 				<mk-media-image :image="media" :key="media.id" v-else-if="media.type.startsWith('image')" :raw="raw"/> | ||||
| 				<x-image :image="media" :key="media.id" v-else-if="media.type.startsWith('image')" :raw="raw"/> | ||||
| 			</template> | ||||
| 		</div> | ||||
| 	</div> | ||||
| @@ -17,10 +17,12 @@ | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import XBanner from './media-banner.vue'; | ||||
| import XImage from './media-image.vue'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	components: { | ||||
| 		XBanner | ||||
| 		XBanner, | ||||
| 		XImage | ||||
| 	}, | ||||
| 	props: { | ||||
| 		mediaList: { | ||||
|   | ||||
| @@ -34,7 +34,7 @@ | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import i18n from '../../../i18n'; | ||||
| import parse from '../../../../../mfm/parse'; | ||||
| import { parse } from '../../../../../mfm/parse'; | ||||
| import { unique } from '../../../../../prelude/array'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
|   | ||||
| @@ -420,7 +420,7 @@ export default Vue.extend({ | ||||
| 		margin 0 | ||||
| 		padding 16px | ||||
| 		text-align center | ||||
| 		color #aaa | ||||
| 		color var(--text) | ||||
|  | ||||
| 		> [data-icon] | ||||
| 			margin-right 4px | ||||
|   | ||||
| @@ -1,13 +1,13 @@ | ||||
| import Vue, { VNode } from 'vue'; | ||||
| import { length } from 'stringz'; | ||||
| import { MfmForest } from '../../../../../mfm/parser'; | ||||
| import parse from '../../../../../mfm/parse'; | ||||
| import { MfmForest } from '../../../../../mfm/types'; | ||||
| import { parse, parsePlain } from '../../../../../mfm/parse'; | ||||
| import MkUrl from './url.vue'; | ||||
| import MkMention from './mention.vue'; | ||||
| import { concat, sum } from '../../../../../prelude/array'; | ||||
| import MkFormula from './formula.vue'; | ||||
| import MkCode from './code.vue'; | ||||
| import MkGoogle from './google.vue'; | ||||
| import syntaxHighlight from '../../../../../mfm/syntax-highlight'; | ||||
| import { host } from '../../../config'; | ||||
| import { preorderF, countNodesF } from '../../../../../prelude/tree'; | ||||
|  | ||||
| @@ -46,7 +46,7 @@ export default Vue.component('misskey-flavored-markdown', { | ||||
| 	render(createElement) { | ||||
| 		if (this.text == null || this.text == '') return; | ||||
|  | ||||
| 		const ast = parse(this.text, this.plainText); | ||||
| 		const ast = (this.plainText ? parsePlain : parse)(this.text); | ||||
|  | ||||
| 		let bigCount = 0; | ||||
| 		let motionCount = 0; | ||||
| @@ -84,7 +84,7 @@ export default Vue.component('misskey-flavored-markdown', { | ||||
|  | ||||
| 				case 'big': { | ||||
| 					bigCount++; | ||||
| 					const isLong = sumTextsLength(token.children) > 10 || countNodesF(token.children) > 5; | ||||
| 					const isLong = sumTextsLength(token.children) > 15 || countNodesF(token.children) > 5; | ||||
| 					const isMany = bigCount > 3; | ||||
| 					return (createElement as any)('strong', { | ||||
| 						attrs: { | ||||
| @@ -98,7 +98,11 @@ export default Vue.component('misskey-flavored-markdown', { | ||||
| 				} | ||||
|  | ||||
| 				case 'small': { | ||||
| 					return [createElement('small', genEl(token.children))]; | ||||
| 					return [createElement('small', { | ||||
| 						attrs: { | ||||
| 							style: 'opacity: 0.7;' | ||||
| 						}, | ||||
| 					}, genEl(token.children))]; | ||||
| 				} | ||||
|  | ||||
| 				case 'center': { | ||||
| @@ -111,8 +115,8 @@ export default Vue.component('misskey-flavored-markdown', { | ||||
|  | ||||
| 				case 'motion': { | ||||
| 					motionCount++; | ||||
| 					const isLong = sumTextsLength(token.children) > 10 || countNodesF(token.children) > 5; | ||||
| 					const isMany = motionCount > 3; | ||||
| 					const isLong = sumTextsLength(token.children) > 15 || countNodesF(token.children) > 5; | ||||
| 					const isMany = motionCount > 5; | ||||
| 					return (createElement as any)('span', { | ||||
| 						attrs: { | ||||
| 							style: 'display: inline-block;' | ||||
| @@ -124,6 +128,43 @@ export default Vue.component('misskey-flavored-markdown', { | ||||
| 					}, genEl(token.children)); | ||||
| 				} | ||||
|  | ||||
| 				case 'spin': { | ||||
| 					motionCount++; | ||||
| 					const isLong = sumTextsLength(token.children) > 10 || countNodesF(token.children) > 5; | ||||
| 					const isMany = motionCount > 5; | ||||
| 					const direction = | ||||
| 						token.node.props.attr == 'left' ? 'reverse' : | ||||
| 						token.node.props.attr == 'alternate' ? 'alternate' : | ||||
| 						'normal'; | ||||
| 					const style = (this.$store.state.settings.disableAnimatedMfm || isLong || isMany) | ||||
| 						? '' | ||||
| 						: `animation: spin 1.5s linear infinite; animation-direction: ${direction};`; | ||||
| 					return (createElement as any)('span', { | ||||
| 						attrs: { | ||||
| 							style: 'display: inline-block;' + style | ||||
| 						}, | ||||
| 					}, genEl(token.children)); | ||||
| 				} | ||||
|  | ||||
| 				case 'jump': { | ||||
| 					motionCount++; | ||||
| 					const isLong = sumTextsLength(token.children) > 30 || countNodesF(token.children) > 5; | ||||
| 					const isMany = motionCount > 5; | ||||
| 					return (createElement as any)('span', { | ||||
| 						attrs: { | ||||
| 							style: (this.$store.state.settings.disableAnimatedMfm || isLong || isMany) ? 'display: inline-block;' : 'display: inline-block; animation: jump 0.75s linear infinite;' | ||||
| 						}, | ||||
| 					}, genEl(token.children)); | ||||
| 				} | ||||
|  | ||||
| 				case 'flip': { | ||||
| 					return (createElement as any)('span', { | ||||
| 						attrs: { | ||||
| 							style: 'display: inline-block; transform: scaleX(-1);' | ||||
| 						}, | ||||
| 					}, genEl(token.children)); | ||||
| 				} | ||||
|  | ||||
| 				case 'url': { | ||||
| 					return [createElement(MkUrl, { | ||||
| 						key: Math.random(), | ||||
| @@ -170,21 +211,22 @@ export default Vue.component('misskey-flavored-markdown', { | ||||
| 				} | ||||
|  | ||||
| 				case 'blockCode': { | ||||
| 					return [createElement('pre', { | ||||
| 						class: 'code' | ||||
| 					}, [ | ||||
| 						createElement('code', { | ||||
| 							domProps: { | ||||
| 								innerHTML: syntaxHighlight(token.node.props.code) | ||||
| 							} | ||||
| 						}) | ||||
| 					])]; | ||||
| 					return [createElement(MkCode, { | ||||
| 						key: Math.random(), | ||||
| 						props: { | ||||
| 							code: token.node.props.code, | ||||
| 							lang: token.node.props.lang, | ||||
| 						} | ||||
| 					})]; | ||||
| 				} | ||||
|  | ||||
| 				case 'inlineCode': { | ||||
| 					return [createElement('code', { | ||||
| 						domProps: { | ||||
| 							innerHTML: syntaxHighlight(token.node.props.code) | ||||
| 					return [createElement(MkCode, { | ||||
| 						key: Math.random(), | ||||
| 						props: { | ||||
| 							code: token.node.props.code, | ||||
| 							lang: token.node.props.lang, | ||||
| 							inline: true | ||||
| 						} | ||||
| 					})]; | ||||
| 				} | ||||
| @@ -228,12 +270,24 @@ export default Vue.component('misskey-flavored-markdown', { | ||||
| 					})]; | ||||
| 				} | ||||
|  | ||||
| 				case 'math': { | ||||
| 				case 'mathInline': { | ||||
| 					//const MkFormula = () => import('./formula.vue').then(m => m.default); | ||||
| 					return [createElement(MkFormula, { | ||||
| 						key: Math.random(), | ||||
| 						props: { | ||||
| 							formula: token.node.props.formula | ||||
| 							formula: token.node.props.formula, | ||||
| 							block: false | ||||
| 						} | ||||
| 					})]; | ||||
| 				} | ||||
|  | ||||
| 				case 'mathBlock': { | ||||
| 					//const MkFormula = () => import('./formula.vue').then(m => m.default); | ||||
| 					return [createElement(MkFormula, { | ||||
| 						key: Math.random(), | ||||
| 						props: { | ||||
| 							formula: token.node.props.formula, | ||||
| 							block: true | ||||
| 						} | ||||
| 					})]; | ||||
| 				} | ||||
|   | ||||
| @@ -24,34 +24,13 @@ export default Vue.extend({ | ||||
| 		background var(--mfmTitleBg) | ||||
| 		border-radius 4px | ||||
|  | ||||
| 	>>> .code | ||||
| 		margin 8px 0 | ||||
|  | ||||
| 	>>> .quote | ||||
| 		margin 8px | ||||
| 		padding 6px 0 6px 12px | ||||
| 		color var(--mfmQuote) | ||||
| 		border-left solid 3px var(--mfmQuoteLine) | ||||
|  | ||||
| 	>>> code | ||||
| 		padding 4px 8px | ||||
| 		margin 0 0.5em | ||||
| 	>>> pre code | ||||
| 		font-size 80% | ||||
| 		color #525252 | ||||
| 		background rgba(0, 0, 0, 0.05) | ||||
| 		border-radius 2px | ||||
|  | ||||
| 	>>> pre > code | ||||
| 		padding 16px | ||||
| 		margin 0 | ||||
|  | ||||
| 	>>> [data-is-me]:after | ||||
| 		content "you" | ||||
| 		padding 0 4px | ||||
| 		margin-left 4px | ||||
| 		font-size 80% | ||||
| 		color var(--primaryForeground) | ||||
| 		background var(--primary) | ||||
| 		border-radius 4px | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -10,72 +10,91 @@ import i18n from '../../../i18n'; | ||||
| import { url } from '../../../config'; | ||||
| import copyToClipboard from '../../../common/scripts/copy-to-clipboard'; | ||||
| import { concat, intersperse } from '../../../../../prelude/array'; | ||||
| import { faCopy, faEye, faEyeSlash } from '@fortawesome/free-regular-svg-icons'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n: i18n('common/views/components/note-menu.vue'), | ||||
| 	props: ['note', 'source'], | ||||
| 	data() { | ||||
| 		return { | ||||
| 			isFavorited: false, | ||||
| 			isWatching: false | ||||
| 		}; | ||||
| 	}, | ||||
| 	computed: { | ||||
| 		items(): any[] { | ||||
| 			return concat(intersperse([null], [ | ||||
| 				[ | ||||
| 					[{ | ||||
| 						icon: 'at', | ||||
| 						text: this.$t('mention'), | ||||
| 						action: this.mention | ||||
| 					}] | ||||
| 				], | ||||
| 				[ | ||||
| 					[{ | ||||
| 						icon: 'info-circle', | ||||
| 						text: this.$t('detail'), | ||||
| 						action: this.detail | ||||
| 					}], [{ | ||||
| 						icon: 'align-left', | ||||
| 						text: this.$t('copy-content'), | ||||
| 						action: this.copyContent | ||||
| 					}], [{ | ||||
| 						icon: 'link', | ||||
| 						text: this.$t('copy-link'), | ||||
| 						action: this.copyLink | ||||
| 					}], this.note.uri ? [{ | ||||
| 						icon: 'external-link-square-alt', | ||||
| 						text: this.$t('remote'), | ||||
| 						action: () => { | ||||
| 							window.open(this.note.uri, '_blank'); | ||||
| 						} | ||||
| 					}] : [] | ||||
| 				], | ||||
| 				[ | ||||
| 					this.note.isFavorited ? [{ | ||||
| 						icon: 'star', | ||||
| 						text: this.$t('unfavorite'), | ||||
| 						action: this.unfavorite | ||||
| 					}] : [{ | ||||
| 						icon: 'star', | ||||
| 						text: this.$t('favorite'), | ||||
| 						action: this.favorite | ||||
| 					}], this.note.userId == this.$store.state.i.id ? [ | ||||
| 						(this.$store.state.i.pinnedNoteIds || []).includes(this.note.id) ? { | ||||
| 							icon: 'thumbtack', | ||||
| 							text: this.$t('unpin'), | ||||
| 							action: this.unpin | ||||
| 						} : { | ||||
| 								icon: 'thumbtack', | ||||
| 								text: this.$t('pin'), | ||||
| 								action: this.pin | ||||
| 							} | ||||
| 					] : [] | ||||
| 				], [ | ||||
| 					this.note.userId == this.$store.state.i.id || this.$store.state.i.isAdmin || this.$store.state.i.isModerator ? [{ | ||||
| 						icon: ['far', 'trash-alt'], | ||||
| 						text: this.$t('delete'), | ||||
| 						action: this.del | ||||
| 					}] : [] | ||||
| 				] | ||||
| 			].map(concat).filter(x => x.length > 0))); | ||||
| 			return [{ | ||||
| 				icon: 'at', | ||||
| 				text: this.$t('mention'), | ||||
| 				action: this.mention | ||||
| 			}, null, { | ||||
| 				icon: 'info-circle', | ||||
| 				text: this.$t('detail'), | ||||
| 				action: this.detail | ||||
| 			}, { | ||||
| 				icon: faCopy, | ||||
| 				text: this.$t('copy-content'), | ||||
| 				action: this.copyContent | ||||
| 			}, { | ||||
| 				icon: 'link', | ||||
| 				text: this.$t('copy-link'), | ||||
| 				action: this.copyLink | ||||
| 			}, this.note.uri ? { | ||||
| 				icon: 'external-link-square-alt', | ||||
| 				text: this.$t('remote'), | ||||
| 				action: () => { | ||||
| 					window.open(this.note.uri, '_blank'); | ||||
| 				} | ||||
| 			} : undefined, | ||||
| 			null, | ||||
| 			this.isFavorited ? { | ||||
| 				icon: 'star', | ||||
| 				text: this.$t('unfavorite'), | ||||
| 				action: () => this.toggleFavorite(false) | ||||
| 			} : { | ||||
| 				icon: 'star', | ||||
| 				text: this.$t('favorite'), | ||||
| 				action: () => this.toggleFavorite(true) | ||||
| 			}, | ||||
| 			this.note.userId != this.$store.state.i.id ? this.isWatching ? { | ||||
| 				icon: faEyeSlash, | ||||
| 				text: this.$t('unwatch'), | ||||
| 				action: () => this.toggleWatch(false) | ||||
| 			} : { | ||||
| 				icon: faEye, | ||||
| 				text: this.$t('watch'), | ||||
| 				action: () => this.toggleWatch(true) | ||||
| 			} : undefined, | ||||
| 			this.note.userId == this.$store.state.i.id ? (this.$store.state.i.pinnedNoteIds || []).includes(this.note.id) ? { | ||||
| 				icon: 'thumbtack', | ||||
| 				text: this.$t('unpin'), | ||||
| 				action: () => this.togglePin(false) | ||||
| 			} : { | ||||
| 				icon: 'thumbtack', | ||||
| 				text: this.$t('pin'), | ||||
| 				action: () => this.togglePin(true) | ||||
| 			} : undefined, | ||||
| 			...(this.note.userId == this.$store.state.i.id || this.$store.state.i.isAdmin || this.$store.state.i.isModerator ? [ | ||||
| 				null, { | ||||
| 					icon: ['far', 'trash-alt'], | ||||
| 					text: this.$t('delete'), | ||||
| 					action: this.del | ||||
| 				}] | ||||
| 				: [] | ||||
| 			)] | ||||
| 			.filter(x => x !== undefined) | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	created() { | ||||
| 		this.$root.api('notes/state', { | ||||
| 			noteId: this.note.id | ||||
| 		}).then(state => { | ||||
| 			this.isFavorited = state.isFavorited; | ||||
| 			this.isWatching = state.isWatching; | ||||
| 		}); | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		mention() { | ||||
| 			this.$post({ mention: this.note.user }); | ||||
| @@ -87,14 +106,22 @@ export default Vue.extend({ | ||||
|  | ||||
| 		copyContent() { | ||||
| 			copyToClipboard(this.note.text); | ||||
| 			this.$root.dialog({ | ||||
| 				type: 'success', | ||||
| 				splash: true | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		copyLink() { | ||||
| 			copyToClipboard(`${url}/notes/${this.note.id}`); | ||||
| 			this.$root.dialog({ | ||||
| 				type: 'success', | ||||
| 				splash: true | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		pin() { | ||||
| 			this.$root.api('i/pin', { | ||||
| 		togglePin(pin: boolean) { | ||||
| 			this.$root.api(pin ? 'i/pin' : 'i/unpin', { | ||||
| 				noteId: this.note.id | ||||
| 			}).then(() => { | ||||
| 				this.$root.dialog({ | ||||
| @@ -105,14 +132,6 @@ export default Vue.extend({ | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		unpin() { | ||||
| 			this.$root.api('i/unpin', { | ||||
| 				noteId: this.note.id | ||||
| 			}).then(() => { | ||||
| 				this.destroyDom(); | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		del() { | ||||
| 			this.$root.dialog({ | ||||
| 				type: 'warning', | ||||
| @@ -129,8 +148,8 @@ export default Vue.extend({ | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		favorite() { | ||||
| 			this.$root.api('notes/favorites/create', { | ||||
| 		toggleFavorite(favorite: boolean) { | ||||
| 			this.$root.api(favorite ? 'notes/favorites/create' : 'notes/favorites/delete', { | ||||
| 				noteId: this.note.id | ||||
| 			}).then(() => { | ||||
| 				this.$root.dialog({ | ||||
| @@ -141,8 +160,8 @@ export default Vue.extend({ | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		unfavorite() { | ||||
| 			this.$root.api('notes/favorites/delete', { | ||||
| 		toggleWatch(watch: boolean) { | ||||
| 			this.$root.api(watch ? 'notes/watching/create' : 'notes/watching/delete', { | ||||
| 				noteId: this.note.id | ||||
| 			}).then(() => { | ||||
| 				this.$root.dialog({ | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
| 			<div class="backdrop" :style="{ 'width': (showResult ? (choice.votes / total * 100) : 0) + '%' }"></div> | ||||
| 			<span> | ||||
| 				<template v-if="choice.isVoted"><fa icon="check"/></template> | ||||
| 				<span>{{ choice.text }}</span> | ||||
| 				<mfm :text="choice.text" :should-break="false" :plain-text="true" :custom-emojis="note.emojis"/> | ||||
| 				<span class="votes" v-if="showResult">({{ $t('vote-count').replace('{}', choice.votes) }})</span> | ||||
| 			</span> | ||||
| 		</li> | ||||
|   | ||||
| @@ -30,6 +30,7 @@ | ||||
|  | ||||
| 			<ui-textarea v-model="description" :max="500"> | ||||
| 				<span>{{ $t('description') }}</span> | ||||
| 				<span slot="desc">{{ $t('you-can-include-hashtags') }}</span> | ||||
| 			</ui-textarea> | ||||
|  | ||||
| 			<ui-select v-model="lang"> | ||||
| @@ -86,6 +87,20 @@ | ||||
| 			<ui-button @click="updateEmail()">{{ $t('save') }}</ui-button> | ||||
| 		</div> | ||||
| 	</section> | ||||
|  | ||||
| 	<section> | ||||
| 		<header>{{ $t('export') }}</header> | ||||
|  | ||||
| 		<div> | ||||
| 			<ui-select v-model="exportTarget"> | ||||
| 				<option value="notes">{{ $t('export-targets.all-notes') }}</option> | ||||
| 				<option value="following">{{ $t('export-targets.following-list') }}</option> | ||||
| 				<option value="mute">{{ $t('export-targets.mute-list') }}</option> | ||||
| 				<option value="blocking">{{ $t('export-targets.blocking-list') }}</option> | ||||
| 			</ui-select> | ||||
| 			<ui-button @click="doExport()"><fa :icon="faDownload"/> {{ $t('export') }}</ui-button> | ||||
| 		</div> | ||||
| 	</section> | ||||
| </ui-card> | ||||
| </template> | ||||
|  | ||||
| @@ -96,6 +111,7 @@ import { apiUrl, host } from '../../../config'; | ||||
| import { toUnicode } from 'punycode'; | ||||
| import langmap from 'langmap'; | ||||
| import { unique } from '../../../../../prelude/array'; | ||||
| import { faDownload } from '@fortawesome/free-solid-svg-icons'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n: i18n('common/views/components/profile-editor.vue'), | ||||
| @@ -122,7 +138,9 @@ export default Vue.extend({ | ||||
| 			autoAcceptFollowed: false, | ||||
| 			saving: false, | ||||
| 			avatarUploading: false, | ||||
| 			bannerUploading: false | ||||
| 			bannerUploading: false, | ||||
| 			exportTarget: 'notes', | ||||
| 			faDownload | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| @@ -251,6 +269,20 @@ export default Vue.extend({ | ||||
| 					email: this.email == '' ? null : this.email | ||||
| 				}); | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		doExport() { | ||||
| 			this.$root.api( | ||||
| 				this.exportTarget == 'notes' ? 'i/export-notes' : | ||||
| 				this.exportTarget == 'following' ? 'i/export-following' : | ||||
| 				this.exportTarget == 'mute' ? 'i/export-mute' : | ||||
| 				this.exportTarget == 'blocking' ? 'i/export-blocking' : | ||||
| 				null, {}); | ||||
|  | ||||
| 			this.$root.dialog({ | ||||
| 				type: 'info', | ||||
| 				text: this.$t('export-requested') | ||||
| 			}); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
|   | ||||
| @@ -0,0 +1,147 @@ | ||||
| <template> | ||||
| <span | ||||
| 	class="reaction" | ||||
| 	:class="{ reacted: note.myReaction == reaction }" | ||||
| 	@click="toggleReaction(reaction)" | ||||
| 	v-if="count > 0" | ||||
| 	v-particle="!isMe" | ||||
| > | ||||
| 	<mk-reaction-icon :reaction="reaction" ref="icon"/> | ||||
| 	<span>{{ count }}</span> | ||||
| </span> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import Icon from './reaction-icon.vue'; | ||||
| import anime from 'animejs'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: { | ||||
| 		reaction: { | ||||
| 			type: String, | ||||
| 			required: true, | ||||
| 		}, | ||||
| 		count: { | ||||
| 			type: Number, | ||||
| 			required: true, | ||||
| 		}, | ||||
| 		note: { | ||||
| 			type: Object, | ||||
| 			required: true, | ||||
| 		}, | ||||
| 		canToggle: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: true, | ||||
| 		}, | ||||
| 	}, | ||||
| 	computed: { | ||||
| 		isMe(): boolean { | ||||
| 			return this.$store.getters.isSignedIn && this.$store.state.i.id === this.note.userId; | ||||
| 		}, | ||||
| 	}, | ||||
| 	watch: { | ||||
| 		count() { | ||||
| 			this.anime(); | ||||
| 		}, | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		toggleReaction() { | ||||
| 			if (this.isMe) return; | ||||
| 			if (!this.canToggle) return; | ||||
|  | ||||
| 			const oldReaction = this.note.myReaction; | ||||
| 			if (oldReaction) { | ||||
| 				this.$root.api('notes/reactions/delete', { | ||||
| 					noteId: this.note.id | ||||
| 				}).then(() => { | ||||
| 					if (oldReaction !== this.reaction) { | ||||
| 						this.$root.api('notes/reactions/create', { | ||||
| 							noteId: this.note.id, | ||||
| 							reaction: this.reaction | ||||
| 						}); | ||||
| 					} | ||||
| 				}); | ||||
| 			} else { | ||||
| 				this.$root.api('notes/reactions/create', { | ||||
| 					noteId: this.note.id, | ||||
| 					reaction: this.reaction | ||||
| 				}); | ||||
| 			} | ||||
| 		}, | ||||
| 		anime() { | ||||
| 			if (this.$store.state.device.reduceMotion) return; | ||||
| 			if (document.hidden) return; | ||||
|  | ||||
| 			this.$nextTick(() => { | ||||
| 				const rect = this.$refs.icon.$el.getBoundingClientRect(); | ||||
|  | ||||
| 				const x = rect.left; | ||||
| 				const y = rect.top; | ||||
|  | ||||
| 				const icon = new Icon({ | ||||
| 					parent: this, | ||||
| 					propsData: { | ||||
| 						reaction: this.reaction | ||||
| 					} | ||||
| 				}).$mount(); | ||||
|  | ||||
| 				icon.$el.style.position = 'absolute'; | ||||
| 				icon.$el.style.zIndex = 100; | ||||
| 				icon.$el.style.top = (y + window.scrollY) + 'px'; | ||||
| 				icon.$el.style.left = (x + window.scrollX) + 'px'; | ||||
| 				icon.$el.style.fontSize = window.getComputedStyle(this.$refs.icon.$el).fontSize; | ||||
|  | ||||
| 				document.body.appendChild(icon.$el); | ||||
|  | ||||
| 				anime({ | ||||
| 					targets: icon.$el, | ||||
| 					opacity: [1, 0], | ||||
| 					translateY: [0, -64], | ||||
| 					duration: 1000, | ||||
| 					easing: 'linear', | ||||
| 					complete: () => { | ||||
| 						icon.destroyDom(); | ||||
| 					} | ||||
| 				}); | ||||
| 			}); | ||||
| 		}, | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .reaction | ||||
| 	display inline-block | ||||
| 	height 32px | ||||
| 	margin 2px | ||||
| 	padding 0 6px | ||||
| 	border-radius 4px | ||||
| 	cursor pointer | ||||
|  | ||||
| 	* | ||||
| 		user-select none | ||||
| 		pointer-events none | ||||
|  | ||||
| 	&.reacted | ||||
| 		background var(--primary) | ||||
|  | ||||
| 		> span | ||||
| 			color var(--primaryForeground) | ||||
|  | ||||
| 	&:not(.reacted) | ||||
| 		background var(--reactionViewerButtonBg) | ||||
|  | ||||
| 		&:hover | ||||
| 			background var(--reactionViewerButtonHoverBg) | ||||
|  | ||||
| 	> .mk-reaction-icon | ||||
| 		font-size 1.4em | ||||
|  | ||||
| 	> span | ||||
| 		font-size 1.1em | ||||
| 		line-height 32px | ||||
| 		vertical-align middle | ||||
| 		color var(--text) | ||||
| </style> | ||||
| @@ -1,139 +1,37 @@ | ||||
| <template> | ||||
| <div class="mk-reactions-viewer" :class="{ isMe }"> | ||||
| 	<template v-if="reactions"> | ||||
| 		<span :class="{ reacted: note.myReaction == 'like' }" @click="toggleReaction('like')" v-if="reactions.like" v-particle="!isMe"><mk-reaction-icon reaction="like" ref="like"/><span>{{ reactions.like }}</span></span> | ||||
| 		<span :class="{ reacted: note.myReaction == 'love' }" @click="toggleReaction('love')" v-if="reactions.love" v-particle="!isMe"><mk-reaction-icon reaction="love" ref="love"/><span>{{ reactions.love }}</span></span> | ||||
| 		<span :class="{ reacted: note.myReaction == 'laugh' }" @click="toggleReaction('laugh')" v-if="reactions.laugh" v-particle="!isMe"><mk-reaction-icon reaction="laugh" ref="laugh"/><span>{{ reactions.laugh }}</span></span> | ||||
| 		<span :class="{ reacted: note.myReaction == 'hmm' }" @click="toggleReaction('hmm')" v-if="reactions.hmm" v-particle="!isMe"><mk-reaction-icon reaction="hmm" ref="hmm"/><span>{{ reactions.hmm }}</span></span> | ||||
| 		<span :class="{ reacted: note.myReaction == 'surprise' }" @click="toggleReaction('surprise')" v-if="reactions.surprise" v-particle="!isMe"><mk-reaction-icon reaction="surprise" ref="surprise"/><span>{{ reactions.surprise }}</span></span> | ||||
| 		<span :class="{ reacted: note.myReaction == 'congrats' }" @click="toggleReaction('congrats')" v-if="reactions.congrats" v-particle="!isMe"><mk-reaction-icon reaction="congrats" ref="congrats"/><span>{{ reactions.congrats }}</span></span> | ||||
| 		<span :class="{ reacted: note.myReaction == 'angry' }" @click="toggleReaction('angry')" v-if="reactions.angry" v-particle="!isMe"><mk-reaction-icon reaction="angry" ref="angry"/><span>{{ reactions.angry }}</span></span> | ||||
| 		<span :class="{ reacted: note.myReaction == 'confused' }" @click="toggleReaction('confused')" v-if="reactions.confused" v-particle="!isMe"><mk-reaction-icon reaction="confused" ref="confused"/><span>{{ reactions.confused }}</span></span> | ||||
| 		<span :class="{ reacted: note.myReaction == 'rip' }" @click="toggleReaction('rip')" v-if="reactions.rip" v-particle="!isMe"><mk-reaction-icon reaction="rip" ref="rip"/><span>{{ reactions.rip }}</span></span> | ||||
| 		<span :class="{ reacted: note.myReaction == 'pudding' }" @click="toggleReaction('pudding')" v-if="reactions.pudding" v-particle="!isMe"><mk-reaction-icon reaction="pudding" ref="pudding"/><span>{{ reactions.pudding }}</span></span> | ||||
| 	</template> | ||||
| 	<x-reaction v-for="(count, reaction) in reactions" :reaction="reaction" :count="count" :note="note" :key="reaction"/> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import Icon from './reaction-icon.vue'; | ||||
| import anime from 'animejs'; | ||||
| import XReaction from './reactions-viewer.reaction.vue'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	components: { | ||||
| 		XReaction | ||||
| 	}, | ||||
| 	props: { | ||||
| 		note: { | ||||
| 			type: Object, | ||||
| 			required: true | ||||
| 		} | ||||
| 		}, | ||||
| 	}, | ||||
| 	computed: { | ||||
| 		reactions(): any { | ||||
| 			return this.note.reactionCounts; | ||||
| 		}, | ||||
| 		isMe(): boolean { | ||||
| 			return this.$store.getters.isSignedIn && (this.$store.state.i.id === this.note.userId); | ||||
| 		} | ||||
| 			return this.$store.getters.isSignedIn && this.$store.state.i.id === this.note.userId; | ||||
| 		}, | ||||
| 	}, | ||||
| 	watch: { | ||||
| 		'reactions.like'() { | ||||
| 			this.anime('like'); | ||||
| 		}, | ||||
| 		'reactions.love'() { | ||||
| 			this.anime('love'); | ||||
| 		}, | ||||
| 		'reactions.laugh'() { | ||||
| 			this.anime('laugh'); | ||||
| 		}, | ||||
| 		'reactions.hmm'() { | ||||
| 			this.anime('hmm'); | ||||
| 		}, | ||||
| 		'reactions.surprise'() { | ||||
| 			this.anime('surprise'); | ||||
| 		}, | ||||
| 		'reactions.congrats'() { | ||||
| 			this.anime('congrats'); | ||||
| 		}, | ||||
| 		'reactions.angry'() { | ||||
| 			this.anime('angry'); | ||||
| 		}, | ||||
| 		'reactions.confused'() { | ||||
| 			this.anime('confused'); | ||||
| 		}, | ||||
| 		'reactions.rip'() { | ||||
| 			this.anime('rip'); | ||||
| 		}, | ||||
| 		'reactions.pudding'() { | ||||
| 			this.anime('pudding'); | ||||
| 		} | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		toggleReaction(reaction: string) { | ||||
| 			if (this.isMe) return; | ||||
|  | ||||
| 			const oldReaction = this.note.myReaction; | ||||
| 			if (oldReaction) { | ||||
| 				this.$root.api('notes/reactions/delete', { | ||||
| 					noteId: this.note.id | ||||
| 				}).then(() => { | ||||
| 					if (oldReaction !== reaction) { | ||||
| 						this.$root.api('notes/reactions/create', { | ||||
| 							noteId: this.note.id, | ||||
| 							reaction: reaction | ||||
| 						}); | ||||
| 					} | ||||
| 				}); | ||||
| 			} else { | ||||
| 				this.$root.api('notes/reactions/create', { | ||||
| 					noteId: this.note.id, | ||||
| 					reaction: reaction | ||||
| 				}); | ||||
| 			} | ||||
| 		}, | ||||
| 		anime(reaction: string) { | ||||
| 			if (this.$store.state.device.reduceMotion) return; | ||||
| 			if (document.hidden) return; | ||||
|  | ||||
| 			this.$nextTick(() => { | ||||
| 				const rect = this.$refs[reaction].$el.getBoundingClientRect(); | ||||
|  | ||||
| 				const x = rect.left; | ||||
| 				const y = rect.top; | ||||
|  | ||||
| 				const icon = new Icon({ | ||||
| 					parent: this, | ||||
| 					propsData: { | ||||
| 						reaction: reaction | ||||
| 					} | ||||
| 				}).$mount(); | ||||
|  | ||||
| 				icon.$el.style.position = 'absolute'; | ||||
| 				icon.$el.style.zIndex = 100; | ||||
| 				icon.$el.style.top = (y + window.scrollY) + 'px'; | ||||
| 				icon.$el.style.left = (x + window.scrollX) + 'px'; | ||||
| 				icon.$el.style.fontSize = window.getComputedStyle(this.$refs[reaction].$el).fontSize; | ||||
|  | ||||
| 				document.body.appendChild(icon.$el); | ||||
|  | ||||
| 				anime({ | ||||
| 					targets: icon.$el, | ||||
| 					opacity: [1, 0], | ||||
| 					translateY: [0, -64], | ||||
| 					duration: 1000, | ||||
| 					easing: 'linear', | ||||
| 					complete: () => { | ||||
| 						icon.destroyDom(); | ||||
| 					} | ||||
| 				}); | ||||
| 			}); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .mk-reactions-viewer | ||||
| 	margin 6px 0 | ||||
| 	margin: 4px -2px | ||||
|  | ||||
| 	&:empty | ||||
| 		display none | ||||
| @@ -144,38 +42,4 @@ export default Vue.extend({ | ||||
|  | ||||
| 			&:hover | ||||
| 				background var(--reactionViewerButtonBg) !important | ||||
|  | ||||
| 	> span | ||||
| 		display inline-block | ||||
| 		height 32px | ||||
| 		margin-right 6px | ||||
| 		padding 0 6px | ||||
| 		border-radius 4px | ||||
| 		cursor pointer | ||||
|  | ||||
| 		* | ||||
| 			user-select none | ||||
| 			pointer-events none | ||||
|  | ||||
| 		&.reacted | ||||
| 			background var(--primary) | ||||
|  | ||||
| 			> span | ||||
| 				color var(--primaryForeground) | ||||
|  | ||||
| 		&:not(.reacted) | ||||
| 			background var(--reactionViewerButtonBg) | ||||
|  | ||||
| 			&:hover | ||||
| 				background var(--reactionViewerButtonHoverBg) | ||||
|  | ||||
| 		> .mk-reaction-icon | ||||
| 			font-size 1.4em | ||||
|  | ||||
| 		> span | ||||
| 			font-size 1.1em | ||||
| 			line-height 32px | ||||
| 			vertical-align middle | ||||
| 			color var(--text) | ||||
|  | ||||
| </style> | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user