Compare commits
	
		
			1785 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 7576569dc9 | ||
|   | ea3bcbbc37 | ||
|   | d9f0e158a3 | ||
|   | 195f676500 | ||
|   | a9a2f4820b | ||
|   | 8414db57f0 | ||
|   | 609d68933e | ||
|   | a23b8cebbc | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 89f6b03cd6 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 7bc9de03a6 | ||
|   | 3c865d6054 | ||
|   | fd770b008e | ||
|   | b0d60ef2c2 | ||
|   | 7b9cea06ef | ||
|   | 30608d3e22 | ||
|   | 8bf4e55338 | ||
|   | 6ead1de383 | ||
|   | 3b628ec3c4 | ||
|   | 0ed704d173 | ||
|   | 87b6ef0ec5 | ||
|   | 5184a07cf2 | ||
|   | dba04cc59c | ||
|   | f4045fb5b3 | ||
|   | 16c36163b4 | ||
|   | 1ac033ff18 | ||
|   | ccfd48232a | ||
|   | 429bf179dc | ||
|   | 8ba3fb13eb | ||
|   | 11496d887e | ||
|   | bec48319ec | ||
|   | 71a93b2b43 | ||
|   | 6ed3f9e414 | ||
|   | dc8f592c1f | ||
|   | f66c31c771 | ||
|   | 55e2ae1408 | ||
|   | 19c72627fc | ||
|   | 2a4c53c3a4 | ||
|   | 1f2ebce8ed | ||
|   | fcea9dacb7 | ||
|   | 908872f374 | ||
|   | f688ceafb8 | ||
|   | b47b5d6d8b | ||
|   | 31ce3aa312 | ||
|   | 5b22d92e99 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | df148e25da | ||
|   | 4b26df5c3a | ||
|   | e765be4205 | ||
|   | f7d2457063 | ||
|   | 6032d803aa | ||
|   | 0de371db38 | ||
|   | ce3797c4af | ||
|   | 56dd8c298b | ||
|   | 3533257efe | ||
|   | dc2f08721d | ||
|   | 66608a4131 | ||
|   | 2fa90131eb | ||
|   | a51ed28db6 | ||
|   | 5ec290663b | ||
|   | 1374d6e34d | ||
|   | 45ade17c58 | ||
|   | c753e26187 | ||
|   | 577929eed1 | ||
|   | 1fde8a8fb0 | ||
|   | 77e53cbf9e | ||
|   | ab83e08bc7 | ||
|   | 2fad6e6d5f | ||
|   | a3604a6c95 | ||
|   | 44f6fe6f1f | ||
|   | 311b4e90ca | ||
|   | f5a937c523 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 0632a3ed3f | ||
|   | 71bada97df | ||
|   | 62509edcbe | ||
|   | f97cdfaa20 | ||
|   | 67ec10e86d | ||
|   | 481b3f2c58 | ||
|   | 7d599a68ea | ||
|   | 7ccff732b8 | ||
|   | 7587c896d5 | ||
|   | 91297f1ab3 | ||
|   | d872a16fe0 | ||
|   | 60aa35adf8 | ||
|   | 5035b66773 | ||
|   | fa9da8ecab | ||
|   | 1f9bca7188 | ||
|   | ffa5bdeb50 | ||
|   | e6bfb7398e | ||
|   | 6def0c776f | ||
|   | 24bae9eaed | ||
|   | fb5175a283 | ||
|   | 6e49437154 | ||
|   | 2511ed56ac | ||
|   | c4bfc99cf5 | ||
|   | 4efe38440d | ||
|   | 4a5f2c3c40 | ||
|   | 109738ccb9 | ||
|   | 433dbe179d | ||
|   | b21b33831a | ||
|   | 020cc471da | ||
|   | 43b47c4494 | ||
|   | 8751d91794 | ||
|   | 374b276f5c | ||
|   | 6138a74231 | ||
|   | 25438c4d64 | ||
|   | ae6ce19886 | ||
|   | e17a9bfd6f | ||
|   | dc2055f5bc | ||
|   | afeb8058b1 | ||
|   | 9299f99ac3 | ||
|   | 858fc7ebcc | ||
|   | 35089c65d3 | ||
|   | 643ca42829 | ||
|   | 935dc4fe33 | ||
|   | 3a9e74feb1 | ||
|   | 92e66fbf0c | ||
|   | a50515f569 | ||
|   | 2f8f47acea | ||
|   | dcb296db93 | ||
|   | 0bdae9ede7 | ||
|   | 11290c2a0f | ||
|   | 428b8f8669 | ||
|   | 7ced10f84e | ||
|   | 8ac54139c9 | ||
|   | 32afe77a26 | ||
|   | 6db8e33662 | ||
|   | 569561f247 | ||
|   | d132d82acf | ||
|   | 9ba0db9372 | ||
|   | 5d468b542d | ||
|   | 32273165c7 | ||
|   | 46fdb75bf4 | ||
|   | baf381814b | ||
|   | e90387c14e | ||
|   | 876790d499 | ||
|   | 8b56edda4b | ||
|   | 33352256d6 | ||
|   | e368ef11fa | ||
|   | 045f7c3185 | ||
|   | bf40e5a5c5 | ||
|   | cda3635d97 | ||
|   | 2eb561f132 | ||
|   | b5f6465d61 | ||
|   | 9725076c46 | ||
|   | f7228e79bb | ||
|   | d3e250288a | ||
|   | 38f8043cb2 | ||
|   | a61320ca8c | ||
|   | 4bc9bad34f | ||
|   | 4392e64672 | ||
|   | 74a0d60766 | ||
|   | 012a2b6b00 | ||
|   | 584bca7658 | ||
|   | 5dcd96d926 | ||
|   | bd2be2815c | ||
|   | 2a5635492a | ||
|   | eeea7527c1 | ||
|   | d943a9a2f4 | ||
|   | d4335f0e4d | ||
|   | 054f7cbdaa | ||
|   | 6ff95dab89 | ||
|   | 4461bde5da | ||
|   | 19152c28cb | ||
|   | dda2967e2d | ||
|   | a680bcda1f | ||
|   | 8d24fcba6a | ||
|   | 2a96429be8 | ||
|   | 5c6f376f4e | ||
|   | 1b24fad95f | ||
|   | 87743d9ef9 | ||
|   | 8ffd0abb1b | ||
|   | 2fed09ec18 | ||
|   | 6daabb35de | ||
|   | 59e98aa06c | ||
|   | 3601d95733 | ||
|   | 2c57dfd528 | ||
|   | 2348f2586c | ||
|   | ed11f954aa | ||
|   | 5765a8e38e | ||
|   | 4a925fade1 | ||
|   | fca86f43c4 | ||
|   | 12005de4c0 | ||
|   | 2e3d0d3435 | ||
|   | 7d76887517 | ||
|   | bf39ecd1e5 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 7ebee09f74 | ||
|   | 952a49f749 | ||
|   | 8f8c67ad6d | ||
|   | ce659f9926 | ||
|   | c23ec555ff | ||
|   | 25b0a93acd | ||
|   | 7b2b7d1456 | ||
|   | 37444939ab | ||
|   | 2fee2e5166 | ||
|   | 98bd6c3cb8 | ||
|   | fc31e44fd2 | ||
|   | 12f89f0e2e | ||
|   | cdf15fc43a | ||
|   | 2a12af28dd | ||
|   | f128fceaba | ||
|   | 26c5d66994 | ||
|   | bd390d424a | ||
|   | 6b85730361 | ||
|   | d6176d1901 | ||
|   | 43f336bea4 | ||
|   | d2ed9e965e | ||
|   | ea73e9d5de | ||
|   | 36ef862fc6 | ||
|   | 999275ca2c | ||
|   | 78c36ec260 | ||
|   | c985fed3e4 | ||
|   | f13fe431b8 | ||
|   | f1d7cc08bb | ||
|   | e662dfbcfb | ||
|   | 8aaf667f78 | ||
|   | fdfea73bdb | ||
|   | 50161bc84d | ||
|   | 8046a4488d | ||
|   | e818c37a0c | ||
|   | 16ffa0c3c7 | ||
|   | 6a9b839e62 | ||
|   | b5da01931c | ||
|   | 99b6896cf4 | ||
|   | 0ac05df628 | ||
|   | 83726ddcec | ||
|   | be627d488c | ||
|   | e615a3fdf3 | ||
|   | f670345d45 | ||
|   | 6032ec3823 | ||
|   | 01ed052ae6 | ||
|   | 88a9a7c48f | ||
|   | d74755f0a4 | ||
|   | e05871a7f8 | ||
|   | fed44e2f2b | ||
|   | 2189f450df | ||
|   | 288e8f0f75 | ||
|   | dfe7eaaa04 | ||
|   | 51b166b419 | ||
|   | 0ac9a85314 | ||
|   | d153297294 | ||
|   | ec71658087 | ||
|   | 3f359e67b3 | ||
|   | 3220d69a69 | ||
|   | 385116bf30 | ||
|   | f3b476a348 | ||
|   | d0dec99222 | ||
|   | b3fa50d4d1 | ||
|   | 1dbf245f76 | ||
|   | 7c092bc04c | ||
|   | b8f1a8a243 | ||
|   | c2b235b4a3 | ||
|   | 19a9d8d254 | ||
|   | c79d29bd6c | ||
|   | 14816a1c6d | ||
|   | 0c86f1c1aa | ||
|   | 8f440ae633 | ||
|   | 863a5ba872 | ||
|   | c87a43bdba | ||
|   | fa6a7186e0 | ||
|   | 34a5adf951 | ||
|   | 4b3ece439e | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 10dc97c43f | ||
|   | 2c59da36c2 | ||
|   | f457fb6067 | ||
|   | 6843019481 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 17cc5a9b95 | ||
|   | b51843ed50 | ||
|   | ecf44a4fc7 | ||
|   | 8be0188140 | ||
|   | 1008e38abc | ||
|   | b862e53a56 | ||
|   | 94042c2ea9 | ||
|   | 1d76bb42bb | ||
|   | d71a3b59b4 | ||
|   | 1e0c486f2a | ||
|   | 98ec9e2254 | ||
|   | f18c6c26a5 | ||
|   | b6f69b6477 | ||
|   | 901709057e | ||
|   | 30c4718b0d | ||
|   | 24fe68d75f | ||
|   | d0de0bc815 | ||
|   | 9643b1c44a | ||
|   | c1d02a4e1b | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | be842b5071 | ||
|   | c2eb80b44c | ||
|   | 9ed2a82d3b | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | b28eb54cac | ||
|   | 683d3a70b2 | ||
|   | 84fb010789 | ||
|   | 278c586414 | ||
|   | e9165bc6e0 | ||
|   | e3d190072f | ||
|   | e7004ef9f1 | ||
|   | 8336601ded | ||
|   | 1dfb82b85b | ||
|   | 0ffc30dcbf | ||
|   | 3aa74de53c | ||
|   | f78f5c7b02 | ||
|   | 0345fe6b30 | ||
|   | a51ba0d57c | ||
|   | 6a7719ccf3 | ||
|   | 4c18d9edc6 | ||
|   | c6d0fe3c6e | ||
|   | 03e1d3fbc4 | ||
|   | 700f8c9bb4 | ||
|   | 5a0fd674bb | ||
|   | 44099c551c | ||
|   | 111f44ce09 | ||
|   | c3c885de47 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 6d536c61e8 | ||
|   | 8a8c079b2f | ||
|   | b4a30e2a25 | ||
|   | f19f92c538 | ||
|   | e1a946ab45 | ||
|   | aa1817737e | ||
|   | 25ec5a24ab | ||
|   | 68784b3f8e | ||
|   | 2118fadc48 | ||
|   | f14cde4db9 | ||
|   | 75ce3f2eb8 | ||
|   | ca2230f690 | ||
|   | aa1dbe2710 | ||
|   | deddeb570e | ||
|   | 0ed197d4d9 | ||
|   | 046976dffc | ||
|   | bb8139196e | ||
|   | 1fea2cdcbe | ||
|   | fe3dd25bc3 | ||
|   | 5b09209ef9 | ||
|   | 62db650e3c | ||
|   | b847886254 | ||
|   | c6e69ffae4 | ||
|   | b24f368d3f | ||
|   | 4dc8351f56 | ||
|   | f3ab8199a5 | ||
|   | 28d953933a | ||
|   | 77d9ae92f6 | ||
|   | 7d00754587 | ||
|   | 982b5eb698 | ||
|   | 20a9c25d70 | ||
|   | eebed9944c | ||
|   | 507a192489 | ||
|   | 689dc3b9d5 | ||
|   | d765803b83 | ||
|   | 0fabb6a057 | ||
|   | 23efaae85e | ||
|   | 5b2f15726f | ||
|   | bc3a5f3512 | ||
|   | ba05f236bd | ||
|   | 6ac92ac4b8 | ||
|   | d9a1cd082c | ||
|   | a32071541a | ||
|   | eb4f625bbd | ||
|   | e36d45507a | ||
|   | e32884f07f | ||
|   | 1344ffa67d | ||
|   | e07210524f | ||
|   | 6f3996c061 | ||
|   | fd06fd4dc1 | ||
|   | d86d5feae3 | ||
|   | 0e20a8f07b | ||
|   | a40d784e3a | ||
|   | e145131b95 | ||
|   | 92873b8bb5 | ||
|   | d359b71c81 | ||
|   | f1a0bf4257 | ||
|   | ea4e2da58d | ||
|   | 1301b3b49e | ||
|   | 424625846e | ||
|   | 0790dd7a2c | ||
|   | b238d7b934 | ||
|   | 011e4fded2 | ||
|   | 2fe872a9c9 | ||
|   | 02c1515a0f | ||
|   | 408118a1e8 | ||
|   | 6a45bb21c3 | ||
|   | 5d4e9aa949 | ||
|   | c87b98c2af | ||
|   | 5a13c38a6d | ||
|   | 67f60ab307 | ||
|   | 08c278578d | ||
|   | 5e9d2d079d | ||
|   | 0e01fb5fc3 | ||
|   | d44dc7e00d | ||
|   | 82ee3a538b | ||
|   | fdc16253d1 | ||
|   | 7e83cd2d74 | ||
|   | 083eb75eff | ||
|   | f50afa768f | ||
|   | 1a80fe91ce | ||
|   | 4de1a5ef6c | ||
|   | d0d389299b | ||
|   | dc70804350 | ||
|   | 78d691571b | ||
|   | b7cbf4a42a | ||
|   | 87ca7c50b4 | ||
|   | 6c7550b3f3 | ||
|   | 4239ffa13f | ||
|   | c6cfb0df76 | ||
|   | 380cf0de69 | ||
|   | 11f25ea2e7 | ||
|   | ef62497777 | ||
|   | 2824d8a5b6 | ||
|   | 1c84c0828e | ||
|   | 39e4494836 | ||
|   | dc174ca759 | ||
|   | b61cfd0407 | ||
|   | 53405e54a8 | ||
|   | c7ef7531a9 | ||
|   | 626b4bf314 | ||
|   | 323d0e0154 | ||
|   | 6d1338317b | ||
|   | 1ce26d8aec | ||
|   | 7ba3d3ec98 | ||
|   | 24f58b3ecb | ||
|   | d1d8587096 | ||
|   | 96db630f5e | ||
|   | 91fae0ae8b | ||
|   | bfa1235b48 | ||
|   | 95d324a413 | ||
|   | ef3535319b | ||
|   | e9c04f4fa0 | ||
|   | e7180d529a | ||
|   | b8cd872738 | ||
|   | efaaa76185 | ||
|   | 19e1f996a6 | ||
|   | 40a69bf200 | ||
|   | 9e3abb9989 | ||
|   | 5ba48e06f7 | ||
|   | 8b3a0a524b | ||
|   | d9fe9cc5df | ||
|   | b202c7906a | ||
|   | b9c868cac6 | ||
|   | 33adf3c88d | ||
|   | 8b84f40975 | ||
|   | fa131d2023 | ||
|   | a83b38b50a | ||
|   | dcd7b286ef | ||
|   | b85bf769cd | ||
|   | 630a20d61e | ||
|   | 88c3794cf1 | ||
|   | 42eb457ad0 | ||
|   | d153a8de20 | ||
|   | 7f7551f44c | ||
|   | 23082b55a4 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | dac7387a7f | ||
|   | 8c6856d894 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 2c0e514fb2 | ||
|   | 1917b0339e | ||
|   | c05419f223 | ||
|   | e0deaec695 | ||
|   | d70e2a788e | ||
|   | 7343e6e2e8 | ||
|   | 106d4cc0d6 | ||
|   | c98879cb7a | ||
|   | 9ca755c313 | ||
|   | 25e0b98840 | ||
|   | 5599c43c71 | ||
|   | eb7597d7e4 | ||
|   | d5767e92c4 | ||
|   | ba3749d373 | ||
|   | d8088acdf2 | ||
|   | ad93e0aa3d | ||
|   | 691e58f03d | ||
|   | 95d5bccfca | ||
|   | 2aa8e0a4bf | ||
|   | 6e96d6677d | ||
|   | 8816c20f51 | ||
|   | e955fe1ffd | ||
|   | 5cbcac713a | ||
|   | 2b50364ab4 | ||
|   | fa04ac789e | ||
|   | 95ce8dce3d | ||
|   | 0b5eec4ca8 | ||
|   | 6d9716f90e | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | aa31061d90 | ||
|   | acc7797dff | ||
|   | 7959196dc7 | ||
|   | c6ff6939a5 | ||
|   | 769960f29e | ||
|   | d92e9759f3 | ||
|   | bf7e19b288 | ||
|   | 98954cd6d4 | ||
|   | 538bb978ed | ||
|   | 10232c5866 | ||
|   | 5cd6a0db16 | ||
|   | ff0a05a2d6 | ||
|   | e34b264af2 | ||
|   | 00d79487cd | ||
|   | 3cace734c7 | ||
|   | f428372869 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 5dd2feba9b | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | a1b026239e | ||
|   | 40735ce76b | ||
|   | 4a00c13b33 | ||
|   | 8e359d54bd | ||
|   | fb76dff836 | ||
|   | 2448bf4e4e | ||
|   | 91e0fc8c62 | ||
|   | b4f86feddb | ||
|   | 7167c8c593 | ||
|   | 51b79d4250 | ||
|   | 925fcc1c64 | ||
|   | fcdc14862c | ||
|   | dac2844cae | ||
|   | 706b0cea16 | ||
|   | 842e7844c7 | ||
|   | 1dceda50d8 | ||
|   | af8b9abba4 | ||
|   | 07b07685fa | ||
|   | cde43fe3c8 | ||
|   | 2fe84aa75b | ||
|   | 7d79a4840d | ||
|   | 3ee9479572 | ||
|   | ccf8e44acc | ||
|   | 451acb77df | ||
|   | e2c6227f47 | ||
|   | ebd1c877ad | ||
|   | 498094b3c7 | ||
|   | 1cc183ecdb | ||
|   | e8948452fd | ||
|   | ade7e62836 | ||
|   | 395cfa6108 | ||
|   | b5ff2abdb9 | ||
|   | 229e85b2c5 | ||
|   | 4257fed500 | ||
|   | 37058e3480 | ||
|   | a1b82e9723 | ||
|   | db943df0c8 | ||
|   | 299f83684b | ||
|   | ff8d300ea8 | ||
|   | 8b490b9b94 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | f83f8631ac | ||
|   | 16da91d8d1 | ||
|   | 8ffd62b462 | ||
|   | 935367e167 | ||
|   | 00618260f2 | ||
|   | 77d66fac7b | ||
|   | 17d7f59b06 | ||
|   | 2561547db1 | ||
|   | 7738438616 | ||
|   | 3d8fc4a794 | ||
|   | 87b4e7905e | ||
|   | 13c5d4985a | ||
|   | f0df4096fd | ||
|   | 5044424549 | ||
|   | 8ce67cdcd6 | ||
|   | 1915ccabdd | ||
|   | 6fea2f52f1 | ||
|   | f77eaaa08a | ||
|   | 7c5bc03492 | ||
|   | 72a1af6cd4 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 4bce6f14f3 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | a38ce86f87 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | f539491502 | ||
|   | ebeaef94e2 | ||
|   | 2399ba05cd | ||
|   | 8bcfa97349 | ||
|   | dd3e3ddcdd | ||
|   | 2555e23b10 | ||
|   | 1595683904 | ||
|   | d279f8e9ff | ||
|   | eaec936fa6 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | a0735b0e7a | ||
|   | 5b039a1bee | ||
|   | 921609cab1 | ||
|   | 199573ccee | ||
|   | 977200b7cd | ||
|   | 6abff253ea | ||
|   | ba64de334a | ||
|   | dc1d7fa9d7 | ||
|   | f42665d4bc | ||
|   | a5eb19c878 | ||
|   | 60fa8e13d6 | ||
|   | ecbaea463b | ||
|   | 814ddeb436 | ||
|   | d6466106e8 | ||
|   | 633f5384f9 | ||
|   | fa7989772c | ||
|   | 0e395612a6 | ||
|   | fb3f52f3ad | ||
|   | ba11c71d65 | ||
|   | bdc3081167 | ||
|   | 430efcf1b9 | ||
|   | 996450dd7c | ||
|   | fa779f0417 | ||
|   | 25cec6d28a | ||
|   | c5f8403cea | ||
|   | a9ae9a65c8 | ||
|   | 3698c679e2 | ||
|   | 881df20f1b | ||
|   | 7d269c0441 | ||
|   | ba38f64353 | ||
|   | db3ae303cb | ||
|   | 66f3a155e6 | ||
|   | 639b483e6c | ||
|   | 09843a409b | ||
|   | e894ed5a8b | ||
|   | d7808299fd | ||
|   | f92e0c16d2 | ||
|   | d94b3757be | ||
|   | 13e822cba6 | ||
|   | c57bf87f52 | ||
|   | 99fbd60265 | ||
|   | ea9b48db3c | ||
|   | c145c994a9 | ||
|   | d033998b56 | ||
|   | 3136c714bf | ||
|   | c0ee134f19 | ||
|   | d15ebe5732 | ||
|   | ef630195fa | ||
|   | e31921151e | ||
|   | f94992abbe | ||
|   | b00060c09c | ||
|   | f6217d96d2 | ||
|   | 3a6947c7ed | ||
|   | 0fb528ddf8 | ||
|   | 14c03f226d | ||
|   | 4f0d844b43 | ||
|   | b93395fc4c | ||
|   | 34eacb7e2d | ||
|   | 0177023ead | ||
|   | a4678e45de | ||
|   | f24869625e | ||
|   | 01beb705a2 | ||
|   | ce28c70c35 | ||
|   | 5e0f5c31e7 | ||
|   | b28dd4be52 | ||
|   | d8dcc4da27 | ||
|   | 291beb45fc | ||
|   | ffb345ccb5 | ||
|   | d2abe2cd81 | ||
|   | acffc3e522 | ||
|   | 0962e62b8c | ||
|   | 91ebd310b7 | ||
|   | 2974c74b4e | ||
|   | 3d24112d2d | ||
|   | 4a977cd523 | ||
|   | 4b1886990f | ||
|   | f3499b787c | ||
|   | 5209a584a2 | ||
|   | 57a63d38aa | ||
|   | 3efffbcf22 | ||
|   | 15eaebe522 | ||
|   | eee98358ac | ||
|   | 795fc5e7bc | ||
|   | 70ac668474 | ||
|   | 1004e0d6e8 | ||
|   | 52aa64fcb6 | ||
|   | 7860d97a10 | ||
|   | 409b37b271 | ||
|   | ad9b9964fa | ||
|   | d2b5276f43 | ||
|   | 7204e2a84c | ||
|   | 1377fa3332 | ||
|   | bf087bfccf | ||
|   | e846e3d571 | ||
|   | d646e62888 | ||
|   | c008154d18 | ||
|   | 29bd4de26a | ||
|   | 7559b8da6c | ||
|   | 35218e84fc | ||
|   | 2c135fa2f6 | ||
|   | 21da6bd047 | ||
|   | f1d65a66b4 | ||
|   | 63e2dbbb0d | ||
|   | a228c522f1 | ||
|   | a951c337b8 | ||
|   | db3efb3791 | ||
|   | 8ee771ca77 | ||
|   | 488bbc9651 | ||
|   | 29b2bdf613 | ||
|   | 7e35048829 | ||
|   | 4d6b9f62e5 | ||
|   | 5f9a9867eb | ||
|   | 059a8e07d2 | ||
|   | cf82f56e66 | ||
|   | 2778bd14d4 | ||
|   | 5b0446739c | ||
|   | 55f235d0ac | ||
|   | 4ec44c68e9 | ||
|   | e6952d499a | ||
|   | e0b82f827b | ||
|   | 0bccb17e82 | ||
|   | b251b8c6a9 | ||
|   | c2a62f632b | ||
|   | 359da9a5a1 | ||
|   | 2a235151ed | ||
|   | 9e318d5ebc | ||
|   | 6819eb3b4d | ||
|   | 4c6fb60dd2 | ||
|   | bffb9a5c45 | ||
|   | dca4053a67 | ||
|   | fd07f00d14 | ||
|   | bbeb6d534e | ||
|   | 37b5afa1a3 | ||
|   | 63b8af4531 | ||
|   | e89e76076a | ||
|   | 18b4f74cdb | ||
|   | b80d0a3b12 | ||
|   | e53dde385c | ||
|   | 6a7a4c20e6 | ||
|   | 6434dac04d | ||
|   | 5deb1bf40e | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 9cd334576c | ||
|   | ae36bf301a | ||
|   | 9f60688d37 | ||
|   | 6a5a9de795 | ||
|   | ca0ea9e57c | ||
|   | a77a7e8112 | ||
|   | b26ea2edc0 | ||
|   | 02b99dfd76 | ||
|   | af02b0f115 | ||
|   | 9b3c379678 | ||
|   | a423fd7695 | ||
|   | de6e1d8c9b | ||
|   | d9db3e8629 | ||
|   | ac1c81b7d6 | ||
|   | 49b2eec534 | ||
|   | f0abc46429 | ||
|   | 9fd4f5ee0a | ||
|   | 5e202c3def | ||
|   | 48223c1c76 | ||
|   | dddf7834cc | ||
|   | 66ef30b2cc | ||
|   | f802fe57b9 | ||
|   | ead884ce89 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 6a87e9f690 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 5b943722fb | ||
|   | 4d92b14308 | ||
|   | 167c96d14e | ||
|   | 8a42373753 | ||
|   | c1751a9b84 | ||
|   | 4e11da98d9 | ||
|   | 1b7d98c17e | ||
|   | 3038434712 | ||
|   | 117ab633a1 | ||
|   | e50fa4762d | ||
|   | aed1e839ba | ||
|   | 00f2974a2a | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 073c96af47 | ||
|   | 71da498364 | ||
|   | 8e9c11f160 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 98f6b23249 | ||
|   | 89288d8e0d | ||
|   | 724121eeaa | ||
|   | edee95a5ca | ||
|   | 0c2361bf72 | ||
|   | 92f8dc48e3 | ||
|   | 06a0fff4b0 | ||
|   | d55e4621ac | ||
|   | bc6bda3714 | ||
|   | d3aafd3f13 | ||
|   | 1a508de1c4 | ||
|   | 768cc0aff5 | ||
|   | 67f4c1f429 | ||
|   | 2d4ceec0a5 | ||
|   | 3e2a0cd89a | ||
|   | d1f4f2f663 | ||
|   | 6e3bf26cad | ||
|   | 672377f116 | ||
|   | 80ee5afba7 | ||
|   | f55fcd3305 | ||
|   | 64fc14ade5 | ||
|   | 807f245657 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 62f966dc27 | ||
|   | 09f97bf7a7 | ||
|   | 69460e494c | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 9bef723346 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | b99eabb2cf | ||
|   | 17be3f3d0f | ||
|   | 05fe2cb173 | ||
|   | 428be14c27 | ||
|   | a04fa8441e | ||
|   | 7bcfa84e1a | ||
|   | 1cc5986df3 | ||
|   | 7aa5d03875 | ||
|   | a59fbfac19 | ||
|   | 677f9ee8f6 | ||
|   | f4a16be2b4 | ||
|   | 46b967ee4a | ||
|   | 78568accd1 | ||
|   | e9f20a0fad | ||
|   | bbd9894e6b | ||
|   | f92745e381 | ||
|   | 2762b78bcc | ||
|   | 2d4ed2c8c2 | ||
|   | 2de8e8c358 | ||
|   | eb7b638db3 | ||
|   | 321e851b26 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | f8340be3bf | ||
|   | 02341ceb6e | ||
|   | 3dcdd7a5d7 | ||
|   | 85188b5de2 | ||
|   | b721d049c6 | ||
|   | e518fff944 | ||
|   | 048128c7e1 | ||
|   | d3717449c2 | ||
|   | 04de6218d3 | ||
|   | 0082473d78 | ||
|   | 77baca8e6e | ||
|   | 6a7169630c | ||
|   | 6b2089e043 | ||
|   | 14ad3af30d | ||
|   | e7e6d833b7 | ||
|   | d1a9561135 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | c7bda6f908 | ||
|   | ef43721e32 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | ba6cd874aa | ||
|   | f283d2423f | ||
|   | c07f668f14 | ||
|   | 596524a63c | ||
|   | 975e4dd285 | ||
|   | 09b05c8552 | ||
|   | 530ee6f80e | ||
|   | 6ad31dca76 | ||
|   | d423f8ae57 | ||
|   | 8e5ce7f8e3 | ||
|   | 33dfc21e4b | ||
|   | 3266f3948a | ||
|   | 7259887124 | ||
|   | 800de03187 | ||
|   | 78ba305e5c | ||
|   | bfed1475bb | ||
|   | 3281d263c4 | ||
|   | a9a1798e3a | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 6806eafaed | ||
|   | 3e20ea5b2e | ||
|   | 3f30a69b8b | ||
|   | 2d2e16d9f6 | ||
|   | 9c32118b77 | ||
|   | ecf2eb4738 | ||
|   | 3d754ea7eb | ||
|   | f755f24560 | ||
|   | 699879d95d | ||
|   | 6677508ba7 | ||
|   | 58da32358b | ||
|   | 491bc75095 | ||
|   | b9eafeee3f | ||
|   | c56ff5d88d | ||
|   | f5dd83a44a | ||
|   | 9a295a85b1 | ||
|   | 8e06d93c31 | ||
|   | 1a42200137 | ||
|   | bbf33d2475 | ||
|   | 93203ebfd1 | ||
|   | 67053eeaa0 | ||
|   | 43baf4ad6a | ||
|   | 5b2a36e47b | ||
|   | 2a0862a24e | ||
|   | ce31027b2e | ||
|   | 3f66c77821 | ||
|   | bc713656ec | ||
|   | 46d89faebc | ||
|   | 7135c0e308 | ||
|   | 1962bfb4a5 | ||
|   | a1fca2550e | ||
|   | c17f99b7a5 | ||
|   | 7cd76d60c2 | ||
|   | fa7c8cfe5b | ||
|   | 05fb8d35af | ||
|   | eaa827e2d9 | ||
|   | f365ea4585 | ||
|   | 5d2e43ffb9 | ||
|   | e9a97ed99a | ||
|   | fe98102600 | ||
|   | aae8845664 | ||
|   | 81a4388ecc | ||
|   | be3ab026fd | ||
|   | f92f9d8cb0 | ||
|   | 08a59591ae | ||
|   | a09a244242 | ||
|   | 483a61d90d | ||
|   | 385fb7586b | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | c624da70ef | ||
|   | 675668c395 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | bc9c7efe85 | ||
|   | 2488d40421 | ||
|   | bf7875bfaa | ||
|   | a84fa30774 | ||
|   | c19a763b3d | ||
|   | 0875460974 | ||
|   | f0b08d3936 | ||
|   | 16520c7b4c | ||
|   | 65549d06d9 | ||
|   | 52da66d550 | ||
|   | 251c3c3fe4 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | ce2d2a10c1 | ||
|   | 3b6d242ef6 | ||
|   | 0ebe801af4 | ||
|   | 05daa7ac7d | ||
|   | 990a583e5e | ||
|   | d9b02a18bf | ||
|   | 30aae79e5c | ||
|   | a149c121fb | ||
|   | 47f4b51207 | ||
|   | 79f4d886d0 | ||
|   | 2b556aba03 | ||
|   | 4f62043b0c | ||
|   | b1ae304c51 | ||
|   | 425bc032d0 | ||
|   | 0156b75bde | ||
|   | 8bc8fc58de | ||
|   | 9bf847b1fb | ||
|   | 0b078d203b | ||
|   | df59018b47 | ||
|   | b2681dcb5d | ||
|   | 46fa471636 | ||
|   | 5f2c441996 | ||
|   | a79cc42b26 | ||
|   | 739c993911 | ||
|   | cb180e00de | ||
|   | 4d46a61051 | ||
|   | 81969ea8b2 | ||
|   | ac474f3884 | ||
|   | a39aaf6eb1 | ||
|   | 68a7661f08 | ||
|   | ffcb2f755c | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 366e0d6bde | ||
|   | b3a3238e43 | ||
|   | 92828028db | ||
|   | bd97e315ff | ||
|   | 51083419f5 | ||
|   | b23bfd4d86 | ||
|   | 7de3e847bd | ||
|   | 0d1a541dba | ||
|   | 2717109fe2 | ||
|   | 60ca0626ce | ||
|   | 15dae0ae65 | ||
|   | 1c680118a0 | ||
|   | ad5efbba59 | ||
|   | 6dc7baa5e9 | ||
|   | c2b886e750 | ||
|   | edb61e52c5 | ||
|   | ded297b04c | ||
|   | 65e1d5978a | ||
|   | 86e76358b1 | ||
|   | 435e0257a4 | ||
|   | 1c45cc808b | ||
|   | ed27a2f963 | ||
|   | 1f53d1a149 | ||
|   | 8295f6d7a3 | ||
|   | b02f6341c9 | ||
|   | f6d577d411 | ||
|   | db3e73318e | ||
|   | 29c2071711 | ||
|   | 3acd524d09 | ||
|   | dae65cc123 | ||
|   | 695f154d87 | ||
|   | 59dca9a812 | ||
|   | b9f04f8f53 | ||
|   | 0985f14f18 | ||
|   | 56684dd7c3 | ||
|   | 47a5f3bc67 | ||
|   | 1c1e3009e9 | ||
|   | c7c3f6999b | ||
|   | fb4aa9bc1c | ||
|   | ef57f5907b | ||
|   | eff44f9cd1 | ||
|   | d7fa92d58f | ||
|   | 4e8033d5a4 | ||
|   | 8a207d8311 | ||
|   | 94ba9c8437 | ||
|   | 88c71c2998 | ||
|   | 7b6e55047f | ||
|   | 9d85d0bb08 | ||
|   | 27ac0bbc00 | ||
|   | affde9b4e2 | ||
|   | 88324b6dd9 | ||
|   | 9b95ffe6c6 | ||
|   | 6b137f8d69 | ||
|   | e78b2b0ab8 | ||
|   | 8b51428347 | ||
|   | b8d53a7b40 | ||
|   | b0d9e9caa2 | ||
|   | 1fc4ec8dc1 | ||
|   | a1e1e25800 | ||
|   | 3b020732ec | ||
|   | dcf92945fe | ||
|   | f9f33903d4 | ||
|   | d8bf06ab0f | ||
|   | 806dabe58b | ||
|   | a17b8c56d7 | ||
|   | 0eaaaba8f2 | ||
|   | f359d79d36 | ||
|   | 1d84000d94 | ||
|   | b70e22c150 | ||
|   | 0774ffe376 | ||
|   | 0096d7d8ac | ||
|   | 38db966b3d | ||
|   | cb7d313a66 | ||
|   | 91b7905f3f | ||
|   | 9a81fba992 | ||
|   | 43553d5c09 | ||
|   | e0ca8ce173 | ||
|   | 13624ea7c2 | ||
|   | 9502586c8b | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | d6753f2cf2 | ||
|   | 5ba36efcd2 | ||
|   | fd497ef105 | ||
|   | 9c4a7bf94c | ||
|   | 91f8adc138 | ||
|   | 69fa2373cb | ||
|   | 8b37fc4772 | ||
|   | 81e4ed9591 | ||
|   | 9cda89ec04 | ||
|   | fc180f030f | ||
|   | a827b6028d | ||
|   | 4517bf7342 | ||
|   | b21287262e | ||
|   | a60ae130c1 | ||
|   | dd88acd411 | ||
|   | b63fc1a9e5 | ||
|   | 17f143cfb2 | ||
|   | cf57d847d1 | ||
|   | 7c4c7bea14 | ||
|   | e5ec47fc75 | ||
|   | ad91dc2423 | ||
|   | 7acbe53948 | ||
|   | fe1b8ba0cb | ||
|   | b0a8a51b69 | ||
|   | c3ca21e610 | ||
|   | c1b47a2119 | ||
|   | caf625afee | ||
|   | 2bad3865a3 | ||
|   | 3f7d248684 | ||
|   | 4e7382b793 | ||
|   | 552ff4a044 | ||
|   | afb52a0cd5 | ||
|   | 1ac89b0f5b | ||
|   | 5039ca7ee1 | ||
|   | a48fd9ce18 | ||
|   | 58859c4811 | ||
|   | 5988fb3111 | ||
|   | 8dce821789 | ||
|   | 16fde0b507 | ||
|   | 9723662706 | ||
|   | df4415b4fe | ||
|   | 6e179e7cde | ||
|   | 87f248b8ec | ||
|   | 027140eccc | ||
|   | 92cf205c66 | ||
|   | fa3299840f | ||
|   | f54529d46f | ||
|   | b772add064 | ||
|   | 231f2e77a4 | ||
|   | a000a9e607 | ||
|   | e8da15ab1e | ||
|   | e070ccb313 | ||
|   | 2b06579228 | ||
|   | 853c847ba1 | ||
|   | e852680b0a | ||
|   | 0b0ee915b3 | ||
|   | 516d1d093f | ||
|   | aee9c79c0f | ||
|   | 2d4b183c14 | ||
|   | 03b20e11ca | ||
|   | e0e006e284 | ||
|   | a294a881ec | ||
|   | 53926082e7 | ||
|   | 2d185becc3 | ||
|   | 67fff324b0 | ||
|   | f64b7fcabc | ||
|   | 4cefa16db6 | ||
|   | 22722379df | ||
|   | b2b83dc45d | ||
|   | ebf6f8bbfd | ||
|   | 3e1631d180 | ||
|   | 97cb3c8613 | ||
|   | 6dda3a5d8a | ||
|   | e50b0540f5 | ||
|   | 63b4aee9bd | ||
|   | 5b5de6a89c | ||
|   | a11c991f83 | ||
|   | a0adcf0d1a | ||
|   | 93b2b82993 | ||
|   | 4dee7d91b1 | ||
|   | 839be6477d | ||
|   | 59e2ed8ab0 | ||
|   | 83790004dd | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | b70e9824ac | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 155d49e8ac | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 4ae10ab33d | ||
|   | 7124586eb1 | ||
|   | 74f6ed1851 | ||
|   | efae7a7bce | ||
|   | e59f13e8ff | ||
|   | 31ed8949b9 | ||
|   | f1174a15e0 | ||
|   | 912ffae600 | ||
|   | 71a5662195 | ||
|   | 774834a31f | ||
|   | 91f1c3a10a | ||
|   | 8fc1e07136 | ||
|   | a62e2b83ff | ||
|   | e31a2f7e55 | ||
|   | 1598e996b1 | ||
|   | 4fb7ee760a | ||
|   | 37865cb381 | ||
|   | ab8b882435 | ||
|   | 1b2996947e | ||
|   | 1d9c88e9a1 | ||
|   | ea56d368e3 | ||
|   | dbd3a750f5 | ||
|   | f41818141f | ||
|   | d2f576accd | ||
|   | 4e483856d4 | ||
|   | 2997f26e3c | ||
|   | cdab596240 | ||
|   | fca7a9da94 | ||
|   | 8ba178f795 | ||
|   | 8eb8243153 | ||
|   | b4967b862c | ||
|   | aee3517736 | ||
|   | 52ff8e84fa | ||
|   | 9bb6db649c | ||
|   | da99be9897 | ||
|   | 2d7ec8a471 | ||
|   | 4cbbfdad1a | ||
|   | 2924858311 | ||
|   | 85916bfea1 | ||
|   | 38ccd9e794 | ||
|   | c64b6be915 | ||
|   | d98c67e13c | ||
|   | d129151fdf | ||
|   | 1b9c69f793 | ||
|   | 42dd092334 | ||
|   | 8dc9ec06f8 | ||
|   | ae5da782e5 | ||
|   | 313b0cec65 | ||
|   | 12a51972ed | ||
|   | a2f3b2966f | ||
|   | 0c2627f08b | ||
|   | 9535df12dd | ||
|   | 2400471a0d | ||
|   | 784da8c37b | ||
|   | 3778f9c521 | ||
|   | e1cec85f1e | ||
|   | ca9c087060 | ||
|   | 5b2d91baad | ||
|   | 08e099b88d | ||
|   | 4153b0db38 | ||
|   | 88701a21bb | ||
|   | 3ddc73ca94 | ||
|   | 693d793265 | ||
|   | 5d685233dd | ||
|   | 16575751d9 | ||
|   | 1f6295f437 | ||
|   | 6737fe2ead | ||
|   | 4e77939fca | ||
|   | 21f528c07d | ||
|   | 23f835fac0 | ||
|   | f21343225c | ||
|   | f13a59f7db | ||
|   | 0315b9274c | ||
|   | da88043962 | ||
|   | 0352bf0cc2 | ||
|   | baa71070a8 | ||
|   | 2713064f27 | ||
|   | f6387ac115 | ||
|   | d704aca035 | ||
|   | 2b54b4ac06 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 7410f2f4c0 | ||
|   | 99c3c1258a | ||
|   | e51184931d | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 3bc9a40b48 | ||
|   | 9f49ca8fdb | ||
|   | 550d1547b4 | ||
|   | ca0b56ee57 | ||
|   | ef1d854f2c | ||
|   | a5023271ef | ||
|   | c3747db670 | ||
|   | fe1e60a28c | ||
|   | f91d2e8c8d | ||
|   | dccc2c60e3 | ||
|   | 933e25804c | ||
|   | 0b503661af | ||
|   | 58082431ff | ||
|   | 2536bfb5f5 | ||
|   | 6428066552 | ||
|   | 4bf3827b73 | ||
|   | 3cad494404 | ||
|   | ef0793311f | ||
|   | 6f3e341e89 | ||
|   | 2fea3be7c0 | ||
|   | 82059d4fd9 | ||
|   | 07ddeae2f1 | ||
|   | f2279758b2 | ||
|   | 1ed189a518 | ||
|   | 137741d307 | ||
|   | d702f6e090 | ||
|   | f33701233c | ||
|   | 70003269e5 | ||
|   | 61896d2386 | ||
|   | 52d640c5a7 | ||
|   | c65f5761e1 | ||
|   | 3016ac4805 | ||
|   | 28a47cd331 | ||
|   | 6ecb88b0d1 | ||
|   | 8df1278c8e | ||
|   | 52bec430d4 | ||
|   | da4cec8767 | ||
|   | ad0087d7dd | ||
|   | 9630860035 | ||
|   | 75e4c8d74d | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 1a5ee81e7e | ||
|   | 3476be16ab | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | c42f61a0f4 | ||
|   | b42a9e1c4e | ||
|   | 4495525705 | ||
|   | a603602f32 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 67b28f9b6e | ||
|   | fd947407af | ||
|   | 30444e5f1a | ||
|   | f0d818de24 | ||
|   | 3fb98e808f | ||
|   | 2c9bacfcea | ||
|   | ae0284b1b1 | ||
|   | 166c4ebda0 | ||
|   | 319eed029b | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | ec5aa10167 | ||
|   | a542765cf8 | ||
|   | fd3f8d43db | ||
|   | 4f4496078a | ||
|   | 8f4f5b4ce0 | ||
|   | bdc6718ae5 | ||
|   | 09d1f1c20d | ||
|   | 0efb7af17b | ||
|   | a45a78b94f | ||
|   | 6337c26cf0 | ||
|   | 208dec25d9 | ||
|   | 7d65a0c3d5 | ||
|   | bb925e5de3 | ||
|   | c9de5b65d4 | ||
|   | 9bc3fcf74f | ||
|   | 19d979c330 | ||
|   | bb7b335491 | ||
|   | be5a0b4794 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 48eea03386 | ||
|   | 566317dc83 | ||
|   | d4334645c2 | ||
|   | d60c3c4ee3 | ||
|   | 452514f7fe | ||
|   | 58abb0ce8f | ||
|   | 000d9cc1ce | ||
|   | 8cc017354a | ||
|   | 60269d15e8 | ||
|   | 7caa083612 | ||
|   | 68e1b00eb1 | ||
|   | 1d904c756a | ||
|   | 0a1db1f595 | ||
|   | e30e8267dd | ||
|   | 288a881817 | ||
|   | f593790872 | ||
|   | 1044ad8589 | ||
|   | 6e24015e68 | ||
|   | b9a2c449ff | ||
|   | 7c390cbf7b | ||
|   | a657d1c774 | ||
|   | f3936a79aa | ||
|   | 78b560d89a | ||
|   | 2fc6313380 | ||
|   | c2b882a5d7 | ||
|   | 667b18fe24 | ||
|   | 60c0dac5f2 | ||
|   | 79f3e60dac | ||
|   | c4e04d6bf2 | ||
|   | 49f8219e54 | ||
|   | abd873e0a8 | ||
|   | 0e45d0d47f | ||
|   | 043b66f5da | ||
|   | 5d6e1fc391 | ||
|   | fe292e77de | ||
|   | c996b5d0c8 | ||
|   | 7beb592f0c | ||
|   | b3b11acd96 | ||
|   | 3bcdfbbd00 | ||
|   | fdad5d149f | ||
|   | 2e712a9212 | ||
|   | 86c8e634bb | ||
|   | 197a9306c4 | ||
|   | 2e502a6b61 | ||
|   | aa8a40e950 | ||
|   | 2f45ac3712 | ||
|   | 8ecf3db608 | ||
|   | f59c68022f | ||
|   | 7aac2c4e29 | ||
|   | 0481de6629 | ||
|   | f59d0a75e4 | ||
|   | 22f4b3cc7b | ||
|   | a4283c415a | ||
|   | c0fbcee38a | ||
|   | 335200c31e | ||
|   | df71c90f9f | ||
|   | 4220bdc963 | ||
|   | 97f3b1e46f | ||
|   | 3a9dc358f8 | ||
|   | 2a3ab46a3d | ||
|   | 200a01f65f | ||
|   | e68936911d | ||
|   | 634ffeec54 | ||
|   | 8486cb785d | ||
|   | a9eda4e6e2 | ||
|   | f918f9b307 | ||
|   | d404d02d2d | ||
|   | 61f7a3974f | ||
|   | cad8e4dea2 | ||
|   | ef79903811 | ||
|   | c3cd0451ad | ||
|   | 773fe28fcb | ||
|   | 69e2576387 | ||
|   | 908a5a1bb4 | ||
|   | ffbd9ffc75 | ||
|   | 96223dd5e3 | ||
|   | 3231f12b93 | ||
|   | 1408f39d9a | ||
|   | 4ba06541aa | ||
|   | 5c78ed645a | ||
|   | 33e19447aa | ||
|   | b52d995719 | ||
|   | db5b90c093 | ||
|   | 39bc75a7f9 | ||
|   | 3492067ecf | ||
|   | e342a8da05 | ||
|   | 671d71dd47 | ||
|   | 2f18d2ed8f | ||
|   | f6e8165db0 | ||
|   | eab3b22772 | ||
|   | 7664aa5a8c | ||
|   | a366392cbe | ||
|   | c8c1bc09f9 | ||
|   | 11bb1608cf | ||
|   | b1d77775aa | ||
|   | bc3f5e0d78 | ||
|   | 53ea709697 | ||
|   | b7adbbb9bf | ||
|   | 31aaf559ac | ||
|   | 160185b108 | ||
|   | 848ff4440b | ||
|   | 74291b2cae | ||
|   | ae6c4e0c5f | ||
|   | ecb1840e27 | ||
|   | 42eb82a859 | ||
|   | 89a22908ce | ||
|   | bc3a94aa57 | ||
|   | 77fe579d9b | ||
|   | e8c7803a2f | ||
|   | 1abaef624c | ||
|   | 72cf2344a9 | ||
|   | 0462512e62 | ||
|   | 1d6b2bd969 | ||
|   | 5df90fdc4a | ||
|   | 607a5326d9 | ||
|   | 2cbd35acc4 | ||
|   | 9a0224ee21 | ||
|   | 2beedc5978 | ||
|   | 6d53e64798 | ||
|   | 3478cdea08 | ||
|   | b360f2ed45 | ||
|   | 7b0c4c29b4 | ||
|   | 03f5d7575c | ||
|   | e922d8904c | ||
|   | 45b55a8c98 | ||
|   | 8973b76bda | ||
|   | 41cf856e26 | ||
|   | b7aeb10304 | ||
|   | b8d9c1aa45 | ||
|   | d7dbe503b6 | ||
|   | c625dd074a | ||
|   | f8a977f1c0 | ||
|   | c35e760fd3 | ||
|   | bc34ac82cf | ||
|   | 98f25c9159 | ||
|   | ae9c13df66 | ||
|   | 9f8d21b2bc | ||
|   | e05e97561a | ||
|   | f9d21fd34a | ||
|   | 86aef5f3e0 | ||
|   | e6bc7922ac | ||
|   | b2f40b7d3e | ||
|   | 3878793405 | ||
|   | 33c7aef220 | ||
|   | e927f7a4ec | ||
|   | cd09fa5a28 | ||
|   | 9ca9757418 | ||
|   | 1fae2ffc37 | ||
|   | 71657ddb98 | ||
|   | 63845e0ba7 | ||
|   | 6781b68d33 | ||
|   | d058eff59a | ||
|   | f409faea2c | ||
|   | 77da98cd39 | ||
|   | 471afcbd57 | ||
|   | 72809f9d78 | ||
|   | 743fb45c3c | ||
|   | 93d6b71a31 | ||
|   | 9b10e93fba | ||
|   | 0740837b6a | ||
|   | ff49eacee4 | ||
|   | fbc6b267ff | ||
|   | 10cae8894e | ||
|   | 42addfed85 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 0dd6494ab9 | ||
|   | 9f4c6a3aef | ||
|   | 9438dc560d | ||
|   | 003ef65b59 | ||
|   | 978fb7e63a | ||
|   | 6203577696 | ||
|   | f2b61f6a7e | ||
|   | 6f4aa69723 | ||
|   | b308e1bb2b | ||
|   | ab3dad2d84 | ||
|   | 0af103f399 | ||
|   | 873608a7de | ||
|   | b04ad167da | ||
|   | ad0d06c0d8 | ||
|   | 151476ae8a | ||
|   | fbf43c1450 | ||
|   | 35a1fa5bf0 | ||
|   | 8d3f71d490 | ||
|   | 2239eddf88 | ||
|   | 94ea21d482 | ||
|   | 6a39f92431 | ||
|   | 7b2efa35c7 | ||
|   | c41ea84568 | ||
|   | 0e8262e623 | ||
|   | 4d97946943 | ||
|   | 96d48b5519 | ||
|   | 4cc54d081e | ||
|   | aab5a2ffbd | ||
|   | c8f165b4ad | ||
|   | 9776d8e06b | ||
|   | 10f845ae76 | ||
|   | 2c8f962889 | ||
|   | 1721a82352 | ||
|   | 59bec546e4 | ||
|   | 86503f2d69 | ||
|   | e4b8c688bb | ||
|   | 4535ab4c43 | ||
|   | dcdb57df9d | ||
|   | cfc2808c56 | ||
|   | 4a3d74c608 | ||
|   | e18655d18f | ||
|   | 12b4b78763 | ||
|   | 550a528fc1 | ||
|   | 4e3429a5c7 | ||
|   | ef98383075 | ||
|   | d66d1f142f | ||
|   | c896055cb1 | ||
|   | 2e8b2e0cf9 | ||
|   | 59012b5693 | ||
|   | dfb51e8d26 | ||
|   | 5107824352 | ||
|   | bf7ec18316 | ||
|   | 77d82d2d17 | ||
|   | 2777460150 | ||
|   | 9476a240d9 | ||
|   | bddb878931 | ||
|   | b0768d8a4a | ||
|   | 46bb7f9efb | ||
|   | a507b7c0b0 | ||
|   | 939c0dc5f9 | ||
|   | a89c206572 | ||
|   | 8b55263e72 | ||
|   | f2ad1e4639 | ||
|   | 0fbcec1c16 | ||
|   | ec2b73d076 | ||
|   | 6630bb0b39 | ||
|   | bef0d4c8bd | ||
|   | a57cb3bd31 | ||
|   | 1e4577a988 | ||
|   | fe792b5bbb | ||
|   | d4005133d0 | ||
|   | abe8e80268 | ||
|   | e38e4940b4 | ||
|   | 48dc1678c3 | ||
|   | 431383ab54 | ||
|   | 7a8d252f63 | ||
|   | 04525e2997 | ||
|   | a2f96f3f20 | ||
|   | a81ecb0b28 | ||
|   | 1122368ee0 | ||
|   | 6c54328391 | ||
|   | 1a26816f7a | ||
|   | 8538334d08 | ||
|   | 9387ebc569 | ||
|   | c99dce68ed | ||
|   | 6dea84c6d2 | ||
|   | 39060374c2 | ||
|   | d3ebb5d13f | ||
|   | 4e7c10d3d9 | ||
|   | e93ea66d2d | ||
|   | 152dd70ea5 | ||
|   | 7b94cf9f84 | ||
|   | d70e27a865 | ||
|   | b780ea336c | ||
|   | bd9f589d32 | ||
|   | d9d18bd8f9 | ||
|   | ffdaa6bc56 | ||
|   | c7f60e337e | ||
|   | 7f265dbd52 | ||
|   | 8929c5cabc | ||
|   | 4a610f3b0a | ||
|   | 55ec19edb5 | ||
|   | c319c61832 | ||
|   | 66db99b8cd | ||
|   | ff2162974d | ||
|   | 78e86af086 | ||
|   | 2dcf89eecf | ||
|   | fdf94be998 | ||
|   | 0e913a5727 | ||
|   | f3be077adc | ||
|   | a6e0471f8c | ||
|   | c5d734f9ad | ||
|   | ee12d887ae | ||
|   | b78d24be1e | ||
|   | d5379e2b36 | ||
|   | cf36557084 | ||
|   | fd1ee129dc | ||
|   | 1471b7a6b5 | ||
|   | 1d39d7efcb | ||
|   | 69ee97f6e2 | ||
|   | 12092e6083 | ||
|   | 6e29e40b8b | ||
|   | 842c9e735b | ||
|   | 2f63a25058 | ||
|   | d3b084003c | ||
|   | 0da9d3d8b0 | ||
|   | 58f3c6aab7 | ||
|   | 22e79675ad | ||
|   | e5c350d740 | ||
|   | 210124ac34 | ||
|   | 7f9a35d7ac | ||
|   | 71a30f9001 | ||
|   | 95a34d55fb | ||
|   | 34f052b672 | ||
|   | 0178c2e696 | ||
|   | 5cb0c07627 | ||
|   | d8fdbfe164 | ||
|   | 74e0b2734d | ||
|   | 3f5785bd03 | ||
|   | 15e5c69c15 | ||
|   | 57019c0b40 | ||
|   | 9d6641be3a | ||
|   | ac15c2e71f | ||
|   | 1fc9206c6d | ||
|   | a8fb0d477f | ||
|   | 0c372b68d4 | ||
|   | e7d9018944 | ||
|   | ce16884587 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 3345733d00 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | f91cccb6b1 | ||
|   | 6183262037 | ||
|   | 1c7a194950 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 286e15b967 | ||
|   | 744d366874 | ||
|   | afa62d3d44 | ||
|   | 270c7997c6 | ||
|   | fa95641f88 | ||
|   | aa9fe38c25 | ||
|   | 0d33cbbbbb | ||
|   | bf077da72f | ||
|   | d8f8e19d06 | ||
|   | 3c3d3e4c0c | ||
|   | 0efbeb36df | ||
|   | 73c396cb39 | ||
|   | 8e75f8a125 | ||
|   | e8a7e95c65 | ||
|   | 70a6889fe5 | ||
|   | 6aff7375f6 | ||
|   | d2ef95a8c3 | ||
|   | 1ae51df74a | ||
|   | 3098c6a915 | ||
|   | ab3f8fd10c | ||
|   | 4bdef3720c | ||
|   | c02cecc9e5 | ||
|   | 08b431723a | ||
|   | 83dcfec053 | ||
|   | 69ac7b739f | ||
|   | 9ccf9a2496 | ||
|   | 78563ef9a0 | ||
|   | 019d157b92 | ||
|   | 14de35e3f5 | ||
|   | a860479e88 | ||
|   | b351b3fae5 | ||
|   | 89918a9f79 | ||
|   | cadd020915 | ||
|   | e80933b8ae | ||
|   | 4c0832884f | ||
|   | e4ca940979 | ||
|   | 3fd9be3967 | ||
|   | 79ec7aba1d | ||
|   | 42b1f7eddd | ||
|   | 889a73caa4 | ||
|   | c34a89e962 | ||
|   | 2b4bf681e5 | ||
|   | d1d59e3557 | ||
|   | 668c21830c | ||
|   | 7c37ed07f8 | ||
|   | a135d8fd59 | ||
|   | 0db9aae162 | ||
|   | 1875c362af | ||
|   | 9b36dd9565 | ||
|   | 69452a27de | ||
|   | 6aa5c5895f | ||
|   | 12f20c67b1 | ||
|   | 66b8e5647d | ||
|   | 188a23fec7 | ||
|   | b408b45000 | ||
|   | c53cb94250 | ||
|   | ba2eeabe38 | ||
|   | 259fac224e | ||
|   | aad5440c9e | ||
|   | 5c40f0010f | ||
|   | fb1d181424 | ||
|   | 12cbd8ef5b | ||
|   | cfc4385d1f | ||
|   | 880ef024d0 | ||
|   | c6c6edbc0a | ||
|   | 83ba951bf9 | ||
|   | 9c22b1a68a | ||
|   | cd6a1d3446 | ||
|   | 4a9fc0c8ed | ||
|   | fada899b30 | ||
|   | 22b099fa8a | ||
|   | e0bc0d2830 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 90768d30aa | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 177c549493 | ||
|   | 5e1ee68189 | ||
|   | 175f6303bc | ||
|   | cf9f2a5562 | ||
|   | f04526baca | ||
|   | f085ecedb3 | ||
|   | 0986301788 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | fe418d8d9a | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 6009be34dc | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 01a0a54a2c | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | cfcaf77e21 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 3b37bdc0b9 | ||
|   | ec07112f94 | ||
|   | 464faf2673 | ||
|   | bde20a1a65 | ||
|   | 86c7276da9 | ||
|   | fec988bb79 | ||
|   | 0702d0974b | ||
|   | f443d36dbb | ||
|   | 5477f0a865 | ||
|   | dc02168f33 | ||
|   | cc5c32b4d2 | ||
|   | a35680a838 | ||
|   | 770cba73a6 | ||
|   | 401fc758fd | ||
|   | e8503e6351 | ||
|   | de23753409 | ||
|   | 4857d86cdd | ||
|   | dc4a072678 | ||
|   | c6ee5ccd88 | ||
|   | 68b630cb37 | ||
|   | 94c0238d3a | ||
|   | dbea387433 | ||
|   | d35f62d0e4 | ||
|   | 09b8e81a77 | ||
|   | 3b38979a34 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 0fd8c86c24 | ||
|   | 58d0ed1a2e | ||
|   | 8939452036 | ||
|   | a2931d6f7e | ||
|   | 38b75ad977 | ||
|   | dc4f585954 | ||
|   | 1fbe5365f7 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 04257db938 | ||
|   | ba08d1aa53 | ||
|   | c29cb5bfb9 | ||
|   | fb1e2efbdd | ||
|   | 131a454e7c | ||
|   | 92e5cff285 | ||
|   | b24e32e14e | ||
|   | 943805bdcd | ||
|   | ba9340a26b | ||
|   | 00119328f2 | ||
|   | a73c65da07 | ||
|   | 9021bb5694 | ||
|   | a3cf63823f | ||
|   | f15878cc6f | ||
|   | 33469ff87a | ||
|   | 23b0723168 | ||
|   | fda1ab3e05 | ||
|   | 490c05a869 | ||
|   | f0137daebe | ||
|   | b9fc0e6d71 | ||
|   | 979efee412 | ||
|   | f079041827 | ||
|   | 4edd9efc0b | ||
|   | 2913c7ccfb | ||
|   | e1f460f90f | ||
|   | 70f927ea43 | ||
|   | 80d343bb0b | ||
|   | 9e41fddea3 | ||
|   | 8384efc8c7 | ||
|   | 7797c86581 | ||
|   | 4da8cc478f | ||
|   | 285deeec52 | ||
|   | 2916e49422 | ||
|   | 41e5b9134b | ||
|   | d0d853dcb2 | ||
|   | be46c7e4c5 | ||
|   | 8e0f41d608 | ||
|   | a7b438072c | ||
|   | 99958e2fce | ||
|   | b82843d359 | ||
|   | 4dfc2dfa89 | ||
|   | 50c945607f | ||
|   | 01f28b21dd | ||
|   | 2cb39a8882 | ||
|   | 6ddb6bc160 | ||
|   | 92befbb4cc | ||
|   | ab701bb93e | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 7f9a88fd1c | ||
|   | c5073b33ef | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 765b922a8b | ||
|   | 9b7d6274fa | ||
|   | 26b384aef1 | ||
|   | 0b1e5e3e08 | ||
|   | 5b7506756e | ||
|   | 1f28a0dfeb | ||
|   | f56ec82f6b | ||
|   | 8ccbabf5ca | ||
|   | 7c763600b7 | ||
|   | 499491003b | ||
|   | 3a77d871d5 | ||
|   | 4ee6d0b549 | ||
|   | 64aa733b16 | ||
|   | 190a03103e | ||
|   | 0d75ae9d9a | ||
|   | 3129f8f073 | ||
|   | 7f751d3f20 | ||
|   | 0b5b834f8b | ||
|   | 0f649f7d37 | ||
|   | a1b100d412 | ||
|   | dd4ee1627e | ||
|   | 1da0fdcf78 | ||
|   | 800eec73b8 | ||
|   | 166cb5e179 | ||
|   | 19c872a1f3 | ||
|   | 9252c59d90 | ||
|   | 0b154ac7ba | ||
|   | d4eb0c8df9 | ||
|   | 5ba6f20701 | ||
|   | 695a082582 | ||
|   | 1b9f293959 | ||
|   | 7289d5b401 | ||
|   | 5bdbf98f8c | ||
|   | 4e915e96a5 | ||
|   | e148f6ce5e | ||
|   | 652d7d2c05 | ||
|   | 0b0111fe23 | ||
|   | 5d097fb29d | ||
|   | f29fe986af | ||
|   | 0c774979c0 | ||
|   | f0bc2ed1d7 | ||
|   | b174e5e57a | ||
|   | ae50b71c07 | ||
|   | b2eb50f260 | ||
|   | 790c7f2249 | ||
|   | 6a0f34c283 | ||
|   | d151445db7 | ||
|   | 18a3007273 | ||
|   | bea8c3c65c | ||
|   | 391ee01fe3 | ||
|   | be7cf9f731 | ||
|   | b92c2aa40e | ||
|   | 45ebcbf785 | ||
|   | 5f32484be0 | ||
|   | e245122f12 | ||
|   | 21570e2111 | ||
|   | 63e1165a01 | ||
|   | 89b5a69127 | ||
|   | 1152a9d03a | ||
|   | 10092d4570 | ||
|   | 429b4bec64 | ||
|   | 99f96583b6 | ||
|   | 5adb765f85 | ||
|   | 0eb787e0d0 | ||
|   | 4493c856a9 | ||
|   | 59d3d4a749 | 
							
								
								
									
										87
									
								
								.autogen/autogen.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										87
									
								
								.autogen/autogen.sh
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,87 @@ | ||||
| #!/usr/bin/env bash | ||||
| # __MISSKEY_BEARER_TOKEN= | ||||
| # __MISSKEY_CAMPAIGN_ID= | ||||
| # __MISSKEY_GITHUB_TOKEN= | ||||
| # __MISSKEY_HEAD=acid-chicken: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 '.[].head.label' | grep $__MISSKEY_HEAD)" && exit 1 | ||||
| cd "$(dirname $0)/.." && \ | ||||
| touch null.cache && \ | ||||
| rm *.cache && \ | ||||
| git checkout $__MISSKEY_BRANCH && \ | ||||
| git pull origin $__MISSKEY_BRANCH && \ | ||||
| git pull upstream $__MISSKEY_BRANCH && \ | ||||
| git stash && \ | ||||
| git rebase -f upstream/$__MISSKEY_BRANCH && \ | ||||
| git branch patch-autogen && \ | ||||
| git checkout patch-autogen && \ | ||||
| git reset --hard HEAD || \ | ||||
| exit 1 | ||||
| touch patreon.md.cache && \ | ||||
| rm patreon.md.cache && \ | ||||
| echo '<!-- PATREON_START -->' > patreon.md.cache && \ | ||||
| url="https://www.patreon.com/api/oauth2/v2/campaigns/$__MISSKEY_CAMPAIGN_ID/members?include=currently_entitled_tiers,user&fields%5Btier%5D=title&fields%5Buser%5D=full_name,thumb_url,url,hide_pledges" | ||||
| while : | ||||
|  do | ||||
|   touch patreon.raw.cache && \ | ||||
|   rm patreon.raw.cache && \ | ||||
|   curl -LSs -w '\n' -H "Authorization: Bearer $__MISSKEY_BEARER_TOKEN" -- $url > patreon.raw.cache && \ | ||||
|   touch patreon.cache && \ | ||||
|   rm patreon.cache && \ | ||||
|   cat patreon.raw.cache | \ | ||||
|   jq -r '(.data|map(select(.relationships.currently_entitled_tiers.data[]))|map(.relationships.user.data.id))as$data|.included|map(select(.attributes.hide_pledges==false))|map(select(.id as$id|$data|contains([$id])))|map(.attributes|[.full_name,.thumb_url,.url]|@tsv)|.[]|@text' >> patreon.cache && \ | ||||
|   echo '<table><tr>' >> patreon.md.cache && \ | ||||
|   cat patreon.cache | \ | ||||
|   awk -F'\t' '{print $2,$1}' | \ | ||||
|   sed -e 's/ /\\" alt=\\"/' | \ | ||||
|   xargs -I% echo '<td><img src="%"></td>' >> patreon.md.cache && \ | ||||
|   echo '</tr><tr>' >> patreon.md.cache && \ | ||||
|   cat patreon.cache | \ | ||||
|   awk -F'\t' '{print $3,$1}' | \ | ||||
|   sed -e 's/ /\\">/' | \ | ||||
|   xargs -I% echo '<td><a href="%</a></td>' >> patreon.md.cache && \ | ||||
|   echo '</tr></table>' >> patreon.md.cache || \ | ||||
|   exit 1 | ||||
|   new_url="$(cat patreon.raw.cache | jq -r '.links.next')" | ||||
|   test "$new_url" = 'null' && \ | ||||
|   break || \ | ||||
|   URL="$url" | ||||
| done | ||||
| ignore= && \ | ||||
| echo -e "\n**Last updated:** $(date -uR | sed 's/\+0000/UTC/')\n<!-- PATREON_END -->" >> patreon.md.cache && \ | ||||
| touch README.md && \ | ||||
| touch .autogen/README.md && \ | ||||
| rm .autogen/README.md && \ | ||||
| mv README.md .autogen/README.md && \ | ||||
| cat .autogen/README.md | while IFS= read line; | ||||
|  do | ||||
|   if [[ -z "$ignore" ]] | ||||
|    then | ||||
|     if [[ "$line" = '<!-- PATREON_START -->' ]] | ||||
|      then | ||||
|       ignore='PATREON_INSIDE' | ||||
|      else | ||||
|       echo "$line" >> README.md | ||||
|     fi | ||||
|    else | ||||
|     if [[ "$LINE" = '<!-- PATREON_END -->' ]] | ||||
|      then | ||||
|       ignore= | ||||
|       cat patreon.md.cache >> README.md | ||||
|     fi | ||||
|   fi | ||||
| done | ||||
| cat patreon.md.cache | ||||
| touch null.cache && \ | ||||
| rm *.cache && \ | ||||
| diff .autogen/README.md README.md > diff.cache | ||||
| cat diff.cache && \ | ||||
| test 4 -lt $(cat diff.cache | wc -l) && \ | ||||
| git add README.md && \ | ||||
| git commit -m 'Update README.md [AUTOGEN]' && \ | ||||
| git push -f origin patch-autogen && \ | ||||
| curl -LSs -w '\n' -X POST -d '{"title":"[AUTOMATED] Update README.md","body":"*This pull request was created by a tool.*","head":"'$__MISSKEY_HEAD'","base":"'$__MISSKEY_BRANCH'"}' -- "https://api.github.com/repos/$__MISSKEY_REPO/pulls?access_token=$__MISSKEY_GITHUB_TOKEN" | ||||
| git stash | ||||
| git checkout $__MISSKEY_BRANCH | ||||
| git branch -D patch-autogen | ||||
| @@ -50,8 +50,11 @@ remoteDriveCapacityMb: 8 | ||||
| # If enabled: | ||||
| #  Server will not cache remote files (Using direct link instead). | ||||
| #  You can save your storage. | ||||
| #  Users cannot see remote images when they turn off "Show media from a remote server" setting. | ||||
| preventCache: false | ||||
| # | ||||
| #  NOTE: | ||||
| #  * Users cannot see remote images when they turn off "Show media from a remote server" setting. | ||||
| #  * Since thumbnails are not provided, traffic increases. | ||||
| preventCacheRemoteFiles: false | ||||
|  | ||||
| drive: | ||||
|   storage: 'db' | ||||
| @@ -64,7 +67,7 @@ drive: | ||||
|   # config: | ||||
|   #   endPoint: | ||||
|   #   port: | ||||
|   #   secure: | ||||
|   #   useSSL: | ||||
|   #   accessKey: | ||||
|   #   secretKey: | ||||
|  | ||||
| @@ -75,7 +78,7 @@ drive: | ||||
|   # config: | ||||
|   #   endPoint: s3-us-west-2.amazonaws.com | ||||
|   #   region: us-west-2 | ||||
|   #   secure: true | ||||
|   #   useSSL: true | ||||
|   #   accessKey: XXX | ||||
|   #   secretKey: YYY | ||||
|  | ||||
| @@ -87,7 +90,7 @@ drive: | ||||
|   # config: | ||||
|   #   endPoint: s3-us-west-2.amazonaws.com | ||||
|   #   region: us-west-2 | ||||
|   #   secure: true | ||||
|   #   useSSL: true | ||||
|   #   accessKey: XXX | ||||
|   #   secretKey: YYY | ||||
|  | ||||
| @@ -123,6 +126,7 @@ drive: | ||||
| # google_maps_api_key: example-google-maps-api-key | ||||
|  | ||||
| # Twitter integration | ||||
| # You need to set the oauth callback url as : https://<your-misskey-instance>/api/tw/cb | ||||
| # twitter: | ||||
| #   consumer_key: example-twitter-consumer-key | ||||
| #   consumer_secret: example-twitter-consumer-secret-key | ||||
| @@ -134,3 +138,6 @@ drive: | ||||
|  | ||||
| # Clustering | ||||
| # clusterLimit: 1 | ||||
|  | ||||
| # Summaly proxy | ||||
| # summalyProxy: "http://example.com" | ||||
|   | ||||
| @@ -22,7 +22,6 @@ addons: | ||||
|       - ubuntu-toolchain-r-test | ||||
|     packages: | ||||
|       - g++-4.8 | ||||
|       - graphicsmagick | ||||
|  | ||||
| cache: | ||||
|   directories: | ||||
|   | ||||
							
								
								
									
										4
									
								
								.vsls.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								.vsls.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | ||||
| { | ||||
| 	"$schema": "http://json.schemastore.org/vsls", | ||||
| 	"gitignore": "exclude" | ||||
| } | ||||
							
								
								
									
										32
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										32
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -5,6 +5,34 @@ ChangeLog | ||||
|  | ||||
| This document describes breaking changes only. | ||||
|  | ||||
| 8.0.0 | ||||
| ----- | ||||
|  | ||||
| ### Migration | ||||
|  | ||||
| 起動する前に、`node cli/migration/8.0.0`してください。 | ||||
|  | ||||
| Please run `node cli/migration/8.0.0` before launch. | ||||
|  | ||||
|  | ||||
| 7.0.0 | ||||
| ----- | ||||
|  | ||||
| ### Migration | ||||
|  | ||||
| 起動する前に、`node cli/migration/7.0.0`してください。 | ||||
|  | ||||
| Please run `node cli/migration/7.0.0` before launch. | ||||
|  | ||||
| 6.0.0 | ||||
| ----- | ||||
|  | ||||
| ### Migration | ||||
|  | ||||
| オブジェクトストレージを使用している場合、設定ファイルの`drive.config.secure`を`drive.config.useSSL`にリネームしてください。 | ||||
|  | ||||
| If you use object storage, please rename `drive.config.secure` to `drive.config.useSSL` in config. | ||||
|  | ||||
| 5.0.0 | ||||
| ----- | ||||
|  | ||||
| @@ -19,13 +47,13 @@ Please run `node cli/migration/5.0.0` before launch. | ||||
|  | ||||
| オセロがリバーシに変更されました。 | ||||
|  | ||||
| Othello is now Reversi. | ||||
| Othello is rename to Reversi. | ||||
|  | ||||
| ### Migration | ||||
|  | ||||
| MongoDBの、`othelloGames`と`othelloMatchings`コレクションをそれぞれ`reversiGames`と`reversiMatchings`にリネームしてください。 | ||||
|  | ||||
| You need to rename `othelloGames` and `othelloMatchings` MongoDB collections to `reversiGames` and `reversiMatchings`. | ||||
| Please rename `othelloGames` and `othelloMatchings` MongoDB collections to `reversiGames` and `reversiMatchings` respectively. | ||||
|  | ||||
| 3.0.0 | ||||
| ----- | ||||
|   | ||||
| @@ -1,27 +1,27 @@ | ||||
| # Contribution guide | ||||
| :v: Misskeyへの貢献ありがとうございます。 :v: | ||||
| :v: Thanks for your contributions :v: | ||||
|  | ||||
| ## Issueの報告 | ||||
| 新機能の提案や不具合の報告は https://github.com/syuilo/misskey/issues で管理しています。 | ||||
| Issueを作成する前に、既に同じIssueが作成されていないかご確認ください。 | ||||
| もし既にIssueが作成されている場合は、既存のIssueにコメントをしたりリアクションをするようお願いします。 | ||||
| ## Issues | ||||
| Feature suggestions and bug reports are filed in https://github.com/syuilo/misskey/issues . | ||||
| Before creating a new issue, please search existing issues to avoid duplication. | ||||
| If you find the existing issue, please add your reaction or comment to the issue. | ||||
|  | ||||
| ## Issueの解決 | ||||
| [pr-welcomeのラベルがついているIssue](https://github.com/syuilo/misskey/labels/pr-welcome) | ||||
| の解決を目的としたPull Requestを作成してくださると非常にありがたいです。 | ||||
| ## Internationalization (i18n) | ||||
| Please see [Translation guide](./docs/translate.en.md). | ||||
|  | ||||
| ## 翻訳の改善 | ||||
| ソースコード中の `%i18n:id%` という形の文字列は、言語ファイルの対応するテキストに置換されます。 | ||||
| 言語ファイルは /locales ディレクトリに存在します。 | ||||
| ## Localization (l10n) | ||||
| Please use [Crowdin](https://crowdin.com/project/misskey) for localization. | ||||
|  | ||||
| ## ドキュメントの編集 | ||||
| 現在Misskeyはドキュメントが大きく不足しています。 | ||||
| ドキュメントは /docs ディレクトリに存在します。 | ||||
|  | ||||
|  | ||||
| ## テストの追加 | ||||
| 現在Misskeyはテストが大きく不足しています。 | ||||
| テストコードは /test ディレクトリに存在します。 | ||||
| ## Documentation | ||||
| * Documents for contributors are located in `/docs`. | ||||
| * Documents for instance admins are located in `/docs`. | ||||
| * Documents for end users are located in `src/docs`. | ||||
|  | ||||
| ## 自動テスト及び自動リリース | ||||
| Travis CIで行っています。 | ||||
| 設定ファイルは /.travis に存在します。 | ||||
| ## Test | ||||
| * Test codes are located in `/test`. | ||||
|  | ||||
| ## Continuous integration | ||||
| Misskey uses Travis for automated test. | ||||
| Configuration files are located in `/.travis`. | ||||
|   | ||||
							
								
								
									
										107
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										107
									
								
								README.md
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | ||||
| <img src="https://github.com/syuilo/misskey/blob/b3f42e62af698a67c2250533c437569559f1fdf9/src/himasaku/resources/himasaku.png?raw=true" align="right" width="320px"/> | ||||
| <img src="https://github.com/syuilo/misskey/blob/develop/assets/ai-orig.png?raw=true" align="right" height="320px"/> | ||||
|  | ||||
| [](https://misskey.xyz/) | ||||
| ================================================================ | ||||
| @@ -7,10 +7,12 @@ | ||||
| [![][dependencies-badge]][dependencies-link] | ||||
| [](http://makeapullrequest.com) [](https://greenkeeper.io/) | ||||
|  | ||||
| **Microblogging. Redefined.** | ||||
| **Sophisticated microblogging platform, evolving forever.** | ||||
|  | ||||
| **[Misskey](https://misskey.xyz)** is a completely open source, | ||||
| ultimately sophisticated professional microblogging software. | ||||
| [Misskey](https://misskey.xyz) 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? [Find instance!](https://joinmisskey.github.io/) | ||||
|  | ||||
| <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> | ||||
|  | ||||
| @@ -18,34 +20,91 @@ ultimately sophisticated professional microblogging software. | ||||
|  | ||||
| :sparkles: Features | ||||
| ---------------------------------------------------------------- | ||||
| * Rich text contents | ||||
| * Reactions | ||||
| * User lists | ||||
| * Customizable column view (called MisskeyDeck) | ||||
|   * and widgets! | ||||
| * Private messages | ||||
| * ActivityPub support | ||||
|  | ||||
| and more! You can see it with your own eyes at [misskey.xyz](https://misskey.xyz). | ||||
| <img src="/assets/about/post.png" align="left" height="200px"/> | ||||
|  | ||||
| :package: Create your instance | ||||
| <h3 align="left">Posting</h3> | ||||
| <p align="left"> | ||||
| 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! | ||||
| </p> | ||||
|  | ||||
| --- | ||||
|  | ||||
| <img src="/assets/about/reaction.png" align="right" height="200px"/> | ||||
|  | ||||
| <h3 align="right">Reactions</h3> | ||||
| <p align="right"> | ||||
| 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”. | ||||
| </p> | ||||
|  | ||||
| --- | ||||
|  | ||||
| <img src="/assets/about/ui.png" align="left" height="200px"/> | ||||
|  | ||||
| <h3 align="left">Interface</h3> | ||||
| <p align="left"> | ||||
| No UI fits for everyone. Therefore, Misskey has a highly customizable UI for your taste. You can edit layouts of your timeline, place selectable widgets you can easily move and create your unique home as this place will be your home. | ||||
| </p> | ||||
|  | ||||
| --- | ||||
|  | ||||
| <img src="/assets/about/drive.png" align="right" width="300px"/> | ||||
|  | ||||
| <h3 align="right">Misskey Drive</h3> | ||||
| <p align="right"> | ||||
| Wanna post a picture you have already uploaded? Wish to organize, name and create a folder for your uploaded files? Misskey Drive is the best solution for you. Very easy to share your files online. | ||||
| </p> | ||||
|  | ||||
| --- | ||||
|  | ||||
| and more! You can see it with your own eyes at [misskey.xyz](https://misskey.xyz) or [other instances](https://joinmisskey.github.io/). | ||||
|  | ||||
| :package: Create your own instance | ||||
| ---------------------------------------------------------------- | ||||
| If you want to run your own instance of Misskey, | ||||
| please see [Setup and installation guide](./docs/setup.en.md). | ||||
| Please see [Setup and installation guide](./docs/setup.en.md). | ||||
|  | ||||
| :wrench: Contribute | ||||
| :wrench: Contribution | ||||
| ---------------------------------------------------------------- | ||||
| **[PR](https://github.com/syuilo/misskey/pulls)s welcome!** | ||||
|  | ||||
| If you want to... | ||||
| * i18n ... please see [Translation guide](./docs/translate.en.md). | ||||
| * l10n ... please visit https://crowdin.com/project/misskey | ||||
| Please see [Contribution guide](./CONTRIBUTING.md). | ||||
|  | ||||
| :heart: Backers & Sponsors | ||||
| ---------------------------------------------------------------- | ||||
| | <img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/619786/32cf01444db24e578cd1982c197f6fc6/1?token-time=2145916800&token-hash=tB1e_r8RlZ5sFL0KV_e8dugapxatNBRK1Z3h67TO1g8%3D"> | <img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12378075/0156f769e20f412594fa6b87d85fe228/1?token-time=2145916800&token-hash=IsIJRUXszzoD6-7pDnRY8I05T9nSznc4GTaxj7C9SwU%3D"> | <img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/4503830/ccf2cc867ea64de0b524bb2e24b9a1cb/1?token-time=2145916800&token-hash=S1zP0QyLU52Dqq6dtc9qNYyWfW86XrYHiR4NMbeOrnA%3D"> | <img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12531784/93a45137841849329ba692da92ac7c60/1?token-time=2145916800&token-hash=tMosUojzUYJCH_3t--tvYA-SMCyrS__hzSndyaRSnbo%3D"> | | ||||
| |:-:|:-:|:-:|:-:| | ||||
| | [Gargron](https://www.patreon.com/mastodon) | [39ff](https://www.patreon.com/user/creators?u=12378075) | [dansup](https://www.patreon.com/dansup) | [Takashi Shibuya](https://www.patreon.com/user/creators?u=12531784) | | ||||
| <!-- PATREON_START --> | ||||
| <table><tr> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12731202/0995c46cdcb54153ab5f073f5869b70a/1?token-time=2145916800&token-hash=Yd60FK_SWfQO56SeiJpy1tDHOnCV4xdEywQe8gn5_Wo%3D" alt="negao"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/13099460/43cecdbaa63a40d79bf50a96b9910b9d/1?token-time=2145916800&token-hash=d6P5MWHHsCMxUuBAEPAoVc5wLUR19mIhqAq7Ma9h9rI%3D" alt="ne_moni"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12913507/f7181eacafe8469a93033d85f5969c29/1?token-time=2145916800&token-hash=f03BFb4S2FUx9YEt87TnEmifb4h33OywGBW2akQVtQY%3D" alt="Melilot"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12999811/5f349fafcce44dd1824a8b1ebbec4564/2?token-time=2145916800&token-hash=rwZ8qvbm_kpA4ib3kc07tVKupXeySpY5ATQFGxfL9v0%3D" alt="Axella"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/3384329/8b713330cb27404ea6e9fac50ff96efe/1?token-time=2145916800&token-hash=0eu4-m1gTWA9PhptVZt6rdKcusqcD7RB87rJT23VVFI%3D" alt="べすれい"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12021162/963128bb8d14476dbd8407943db8f31a/1?token-time=2145916800&token-hash=GgJ_NmUB6_nnRNLVGUWjV-WX91On7BOu59LKncYV9fE%3D" alt="gutfuckllc"></td> | ||||
| <td><img src="https://c8.patreon.com/2/100/12718187" alt="Peter G."></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/13039004/509d0c412eb14ae08d6a812a3054f7d6/1?token-time=2145916800&token-hash=zwSu01tOtn5xTUucDZHuPsCxF2HBEMVs9ROJKTlEV_o%3D" alt="nemu"></td> | ||||
| </tr><tr> | ||||
| <td><a href="https://www.patreon.com/user?u=12731202">negao</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=13099460">ne_moni</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=12913507">Melilot</a></td> | ||||
| <td><a href="https://www.patreon.com/AxellaMC">Axella</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> | ||||
| <td><a href="https://www.patreon.com/user?u=12718187">Peter G.</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=13039004">nemu</a></td> | ||||
| </tr></table> | ||||
| <table><tr> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/5881381/6235ca5d3fb04c8e95ef5b4ff2abcc18/2?token-time=2145916800&token-hash=zElv7ZcPL3viGsXbNG_KWiKrbV0vvw1gk0panx8DJoo%3D" alt="Naoki Kosaka"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12931605/ead494101f364dffa90efe49e36fb494/1?token-time=2145916800&token-hash=NzSFPjIlodXyv41rwK61aZWVZWfI4surJaNj8vWKvqM%3D" alt="Reiju"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/13034746/c711c7f58e204ecfbc2fd646bc8a4eee/1?token-time=2145916800&token-hash=UERBN4OyP7Nh5XwwdDg0N0IE5cD6_qUQMO81Z5Wizso%3D" alt="Hiratake"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/4503830/ccf2cc867ea64de0b524bb2e24b9a1cb/1?token-time=2145916800&token-hash=S1zP0QyLU52Dqq6dtc9qNYyWfW86XrYHiR4NMbeOrnA%3D" alt="dansup"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12531784/93a45137841849329ba692da92ac7c60/1?token-time=2145916800&token-hash=tMosUojzUYJCH_3t--tvYA-SMCyrS__hzSndyaRSnbo%3D" alt="Takashi Shibuya"></td> | ||||
| </tr><tr> | ||||
| <td><a href="https://www.patreon.com/user?u=5881381">Naoki Kosaka</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=12931605">Reiju</a></td> | ||||
| <td><a href="https://www.patreon.com/hiratake">Hiratake</a></td> | ||||
| <td><a href="https://www.patreon.com/dansup">dansup</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=12531784">Takashi Shibuya</a></td> | ||||
| </tr></table> | ||||
|  | ||||
| **Last updated:** Sun, 02 Sep 2018 05:30:06 UTC | ||||
| <!-- PATREON_END --> | ||||
|  | ||||
| :four_leaf_clover: Copyright | ||||
| ---------------------------------------------------------------- | ||||
|   | ||||
							
								
								
									
										
											BIN
										
									
								
								assets/about/drive.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								assets/about/drive.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 110 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/about/post.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								assets/about/post.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 344 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/about/reaction.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								assets/about/reaction.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 24 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/about/ui.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								assets/about/ui.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 125 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/ai-orig.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								assets/ai-orig.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 256 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/ai.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								assets/ai.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 243 KiB | 
| @@ -1,101 +0,0 @@ | ||||
| const chalk = require('chalk'); | ||||
| const log = require('single-line-log').stdout; | ||||
| const sequential = require('promise-sequential'); | ||||
| const { default: DriveFile, DriveFileChunk } = require('../built/models/drive-file'); | ||||
| const { default: DriveFileThumbnail, DriveFileThumbnailChunk } = require('../built/models/drive-file-thumbnail'); | ||||
| const { default: User } = require('../built/models/user'); | ||||
|  | ||||
| const q = { | ||||
| 	'metadata._user.host': { | ||||
| 		$ne: null | ||||
| 	}, | ||||
| 	'metadata.withoutChunks': false | ||||
| }; | ||||
|  | ||||
| async function main() { | ||||
| 	const promiseGens = []; | ||||
|  | ||||
| 	const count = await DriveFile.count(q); | ||||
|  | ||||
| 	let prev; | ||||
|  | ||||
| 	for (let i = 0; i < count; i++) { | ||||
| 		promiseGens.push(() => { | ||||
| 			const promise = new Promise(async (res, rej) => { | ||||
| 				const file = await DriveFile.findOne(prev ? Object.assign({ | ||||
| 					_id: { $lt: prev._id } | ||||
| 				}, q) : q, { | ||||
| 					sort: { | ||||
| 						_id: -1 | ||||
| 					} | ||||
| 				}); | ||||
|  | ||||
| 				prev = file; | ||||
|  | ||||
| 				function skip() { | ||||
| 					res([i, file, false]); | ||||
| 				} | ||||
|  | ||||
| 				if (file == null) return skip(); | ||||
|  | ||||
| 				log(chalk`{gray ${i}} scanning {bold ${file._id}} ${file.filename} ...`); | ||||
|  | ||||
| 				const attachingUsersCount = await User.count({ | ||||
| 					$or: [{ | ||||
| 						avatarId: file._id | ||||
| 					}, { | ||||
| 						bannerId: file._id | ||||
| 					}] | ||||
| 				}, { limit: 1 }); | ||||
| 				if (attachingUsersCount !== 0) return skip(); | ||||
|  | ||||
| 				Promise.all([ | ||||
| 					// チャンクをすべて削除 | ||||
| 					DriveFileChunk.remove({ | ||||
| 						files_id: file._id | ||||
| 					}), | ||||
|  | ||||
| 					DriveFile.update({ _id: file._id }, { | ||||
| 						$set: { | ||||
| 							'metadata.withoutChunks': true | ||||
| 						} | ||||
| 					}) | ||||
| 				]).then(async () => { | ||||
| 					res([i, file, true]); | ||||
|  | ||||
| 					//#region サムネイルもあれば削除 | ||||
| 					const thumbnail = await DriveFileThumbnail.findOne({ | ||||
| 						'metadata.originalId': file._id | ||||
| 					}); | ||||
|  | ||||
| 					if (thumbnail) { | ||||
| 						DriveFileThumbnailChunk.remove({ | ||||
| 							files_id: thumbnail._id | ||||
| 						}); | ||||
|  | ||||
| 						DriveFileThumbnail.remove({ _id: thumbnail._id }); | ||||
| 					} | ||||
| 					//#endregion | ||||
| 				}); | ||||
| 			}); | ||||
|  | ||||
| 			promise.then(([i, file, deleted]) => { | ||||
| 				if (deleted) { | ||||
| 					log(chalk`{gray ${i}} {red deleted: {bold ${file._id}} ${file.filename}}`); | ||||
| 				} else { | ||||
| 					log(chalk`{gray ${i}} {green skipped: {bold ${file._id}} ${file.filename}}`); | ||||
| 				} | ||||
| 				log.clear(); | ||||
| 				console.log(); | ||||
| 			}); | ||||
|  | ||||
| 			return promise; | ||||
| 		}); | ||||
| 	} | ||||
|  | ||||
| 	return await sequential(promiseGens); | ||||
| } | ||||
|  | ||||
| main().then(() => { | ||||
| 	console.log('ALL DONE'); | ||||
| }).catch(console.error); | ||||
| @@ -1,80 +0,0 @@ | ||||
| const chalk = require('chalk'); | ||||
| const log = require('single-line-log').stdout; | ||||
| const sequential = require('promise-sequential'); | ||||
| const { default: DriveFile, deleteDriveFile } = require('../built/models/drive-file'); | ||||
| const { default: Note } = require('../built/models/note'); | ||||
| const { default: MessagingMessage } = require('../built/models/messaging-message'); | ||||
| const { default: User } = require('../built/models/user'); | ||||
|  | ||||
| async function main() { | ||||
| 	const promiseGens = []; | ||||
|  | ||||
| 	const count = await DriveFile.count({}); | ||||
|  | ||||
| 	let prev; | ||||
|  | ||||
| 	for (let i = 0; i < count; i++) { | ||||
| 		promiseGens.push(() => { | ||||
| 			const promise = new Promise(async (res, rej) => { | ||||
| 				const file = await DriveFile.findOne(prev ? { | ||||
| 					_id: { $lt: prev._id } | ||||
| 				} : {}, { | ||||
| 					sort: { | ||||
| 						_id: -1 | ||||
| 					} | ||||
| 				}); | ||||
|  | ||||
| 				prev = file; | ||||
|  | ||||
| 				function skip() { | ||||
| 					res([i, file, false]); | ||||
| 				} | ||||
|  | ||||
| 				if (file == null) return skip(); | ||||
|  | ||||
| 				log(chalk`{gray ${i}} scanning {bold ${file._id}} ${file.filename} ...`); | ||||
|  | ||||
| 				const attachingUsersCount = await User.count({ | ||||
| 					$or: [{ | ||||
| 						avatarId: file._id | ||||
| 					}, { | ||||
| 						bannerId: file._id | ||||
| 					}] | ||||
| 				}, { limit: 1 }); | ||||
| 				if (attachingUsersCount !== 0) return skip(); | ||||
|  | ||||
| 				const attachingNotesCount = await Note.count({ | ||||
| 					mediaIds: file._id | ||||
| 				}, { limit: 1 }); | ||||
| 				if (attachingNotesCount !== 0) return skip(); | ||||
|  | ||||
| 				const attachingMessagesCount = await MessagingMessage.count({ | ||||
| 					fileId: file._id | ||||
| 				}, { limit: 1 }); | ||||
| 				if (attachingMessagesCount !== 0) return skip(); | ||||
|  | ||||
| 				deleteDriveFile(file).then(() => { | ||||
| 					res([i, file, true]); | ||||
| 				}).catch(rej); | ||||
| 			}); | ||||
|  | ||||
| 			promise.then(([i, file, deleted]) => { | ||||
| 				if (deleted) { | ||||
| 					log(chalk`{gray ${i}} {red deleted: {bold ${file._id}} ${file.filename}}`); | ||||
| 				} else { | ||||
| 					log(chalk`{gray ${i}} {green skipped: {bold ${file._id}} ${file.filename}}`); | ||||
| 				} | ||||
| 				log.clear(); | ||||
| 				console.log(); | ||||
| 			}); | ||||
|  | ||||
| 			return promise; | ||||
| 		}); | ||||
| 	} | ||||
|  | ||||
| 	return await sequential(promiseGens); | ||||
| } | ||||
|  | ||||
| main().then(() => { | ||||
| 	console.log('done'); | ||||
| }).catch(console.error); | ||||
| @@ -1,40 +0,0 @@ | ||||
| const { default: User, deleteUser } = require('../built/models/user'); | ||||
| const { default: zip } = require('@prezzemolo/zip') | ||||
|  | ||||
| const migrate = async (user) => { | ||||
| 	try { | ||||
| 		await deleteUser(user._id); | ||||
| 		return true; | ||||
| 	} catch (e) { | ||||
| 		return false; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| async function main() { | ||||
| 	const count = await User.count({ | ||||
| 		uri: /#/ | ||||
| 	}); | ||||
|  | ||||
| 	const dop = 1 | ||||
| 	const idop = ((count - (count % dop)) / dop) + 1 | ||||
|  | ||||
| 	return zip( | ||||
| 		1, | ||||
| 		async (time) => { | ||||
| 			console.log(`${time} / ${idop}`) | ||||
| 			const doc = await User.find({ | ||||
| 				uri: /#/ | ||||
| 			}, { | ||||
| 				limit: dop, skip: time * dop | ||||
| 			}) | ||||
| 			return Promise.all(doc.map(migrate)) | ||||
| 		}, | ||||
| 		idop | ||||
| 	).then(a => { | ||||
| 		const rv = [] | ||||
| 		a.forEach(e => rv.push(...e)) | ||||
| 		return rv | ||||
| 	}) | ||||
| } | ||||
|  | ||||
| main().then(console.dir).catch(console.error) | ||||
							
								
								
									
										134
									
								
								cli/migration/7.0.0.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										134
									
								
								cli/migration/7.0.0.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,134 @@ | ||||
| const { default: Stats } = require('../../built/models/stats'); | ||||
| const { default: User } = require('../../built/models/user'); | ||||
| const { default: Note } = require('../../built/models/note'); | ||||
| const { default: DriveFile } = require('../../built/models/drive-file'); | ||||
|  | ||||
| const now = new Date(); | ||||
| const y = now.getFullYear(); | ||||
| const m = now.getMonth(); | ||||
| const d = now.getDate(); | ||||
| const today = new Date(y, m, d); | ||||
|  | ||||
| async function main() { | ||||
| 	const localUsersCount = await User.count({ | ||||
| 		host: null | ||||
| 	}); | ||||
|  | ||||
| 	const remoteUsersCount = await User.count({ | ||||
| 		host: { $ne: null } | ||||
| 	}); | ||||
|  | ||||
| 	const localNotesCount = await Note.count({ | ||||
| 		'_user.host': null | ||||
| 	}); | ||||
|  | ||||
| 	const remoteNotesCount = await Note.count({ | ||||
| 		'_user.host': { $ne: null } | ||||
| 	}); | ||||
|  | ||||
| 	const localDriveFilesCount = await DriveFile.count({ | ||||
| 		'metadata._user.host': null | ||||
| 	}); | ||||
|  | ||||
| 	const remoteDriveFilesCount = await DriveFile.count({ | ||||
| 		'metadata._user.host': { $ne: null } | ||||
| 	}); | ||||
|  | ||||
| 	const localDriveFilesSize = await DriveFile | ||||
| 		.aggregate([{ | ||||
| 			$match: { | ||||
| 				'metadata._user.host': null, | ||||
| 				'metadata.deletedAt': { $exists: false } | ||||
| 			} | ||||
| 		}, { | ||||
| 			$project: { | ||||
| 				length: true | ||||
| 			} | ||||
| 		}, { | ||||
| 			$group: { | ||||
| 				_id: null, | ||||
| 				usage: { $sum: '$length' } | ||||
| 			} | ||||
| 		}]) | ||||
| 		.then(aggregates => { | ||||
| 			if (aggregates.length > 0) { | ||||
| 				return aggregates[0].usage; | ||||
| 			} | ||||
| 			return 0; | ||||
| 		}); | ||||
|  | ||||
| 	const remoteDriveFilesSize = await DriveFile | ||||
| 		.aggregate([{ | ||||
| 			$match: { | ||||
| 				'metadata._user.host': { $ne: null }, | ||||
| 				'metadata.deletedAt': { $exists: false } | ||||
| 			} | ||||
| 		}, { | ||||
| 			$project: { | ||||
| 				length: true | ||||
| 			} | ||||
| 		}, { | ||||
| 			$group: { | ||||
| 				_id: null, | ||||
| 				usage: { $sum: '$length' } | ||||
| 			} | ||||
| 		}]) | ||||
| 		.then(aggregates => { | ||||
| 			if (aggregates.length > 0) { | ||||
| 				return aggregates[0].usage; | ||||
| 			} | ||||
| 			return 0; | ||||
| 		}); | ||||
|  | ||||
| 	await Stats.insert({ | ||||
| 		date: today, | ||||
| 		users: { | ||||
| 			local: { | ||||
| 				total: localUsersCount, | ||||
| 				diff: 0 | ||||
| 			}, | ||||
| 			remote: { | ||||
| 				total: remoteUsersCount, | ||||
| 				diff: 0 | ||||
| 			} | ||||
| 		}, | ||||
| 		notes: { | ||||
| 			local: { | ||||
| 				total: localNotesCount, | ||||
| 				diff: 0, | ||||
| 				diffs: { | ||||
| 					normal: 0, | ||||
| 					reply: 0, | ||||
| 					renote: 0 | ||||
| 				} | ||||
| 			}, | ||||
| 			remote: { | ||||
| 				total: remoteNotesCount, | ||||
| 				diff: 0, | ||||
| 				diffs: { | ||||
| 					normal: 0, | ||||
| 					reply: 0, | ||||
| 					renote: 0 | ||||
| 				} | ||||
| 			} | ||||
| 		}, | ||||
| 		drive: { | ||||
| 			local: { | ||||
| 				totalCount: localDriveFilesCount, | ||||
| 				totalSize: localDriveFilesSize, | ||||
| 				diffCount: 0, | ||||
| 				diffSize: 0 | ||||
| 			}, | ||||
| 			remote: { | ||||
| 				totalCount: remoteDriveFilesCount, | ||||
| 				totalSize: remoteDriveFilesSize, | ||||
| 				diffCount: 0, | ||||
| 				diffSize: 0 | ||||
| 			} | ||||
| 		} | ||||
| 	}); | ||||
|  | ||||
| 	console.log('done'); | ||||
| } | ||||
|  | ||||
| main(); | ||||
							
								
								
									
										144
									
								
								cli/migration/8.0.0.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										144
									
								
								cli/migration/8.0.0.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,144 @@ | ||||
| const { default: Stats } = require('../../built/models/stats'); | ||||
| const { default: User } = require('../../built/models/user'); | ||||
| const { default: Note } = require('../../built/models/note'); | ||||
| const { default: DriveFile } = require('../../built/models/drive-file'); | ||||
|  | ||||
| const now = new Date(); | ||||
| const y = now.getFullYear(); | ||||
| const m = now.getMonth(); | ||||
| const d = now.getDate(); | ||||
| const h = now.getHours(); | ||||
| const date = new Date(y, m, d, h); | ||||
|  | ||||
| async function main() { | ||||
| 	await Stats.update({}, { | ||||
| 		$set: { | ||||
| 			span: 'day' | ||||
| 		} | ||||
| 	}, { | ||||
| 		multi: true | ||||
| 	}); | ||||
|  | ||||
| 	const localUsersCount = await User.count({ | ||||
| 		host: null | ||||
| 	}); | ||||
|  | ||||
| 	const remoteUsersCount = await User.count({ | ||||
| 		host: { $ne: null } | ||||
| 	}); | ||||
|  | ||||
| 	const localNotesCount = await Note.count({ | ||||
| 		'_user.host': null | ||||
| 	}); | ||||
|  | ||||
| 	const remoteNotesCount = await Note.count({ | ||||
| 		'_user.host': { $ne: null } | ||||
| 	}); | ||||
|  | ||||
| 	const localDriveFilesCount = await DriveFile.count({ | ||||
| 		'metadata._user.host': null | ||||
| 	}); | ||||
|  | ||||
| 	const remoteDriveFilesCount = await DriveFile.count({ | ||||
| 		'metadata._user.host': { $ne: null } | ||||
| 	}); | ||||
|  | ||||
| 	const localDriveFilesSize = await DriveFile | ||||
| 		.aggregate([{ | ||||
| 			$match: { | ||||
| 				'metadata._user.host': null, | ||||
| 				'metadata.deletedAt': { $exists: false } | ||||
| 			} | ||||
| 		}, { | ||||
| 			$project: { | ||||
| 				length: true | ||||
| 			} | ||||
| 		}, { | ||||
| 			$group: { | ||||
| 				_id: null, | ||||
| 				usage: { $sum: '$length' } | ||||
| 			} | ||||
| 		}]) | ||||
| 		.then(aggregates => { | ||||
| 			if (aggregates.length > 0) { | ||||
| 				return aggregates[0].usage; | ||||
| 			} | ||||
| 			return 0; | ||||
| 		}); | ||||
|  | ||||
| 	const remoteDriveFilesSize = await DriveFile | ||||
| 		.aggregate([{ | ||||
| 			$match: { | ||||
| 				'metadata._user.host': { $ne: null }, | ||||
| 				'metadata.deletedAt': { $exists: false } | ||||
| 			} | ||||
| 		}, { | ||||
| 			$project: { | ||||
| 				length: true | ||||
| 			} | ||||
| 		}, { | ||||
| 			$group: { | ||||
| 				_id: null, | ||||
| 				usage: { $sum: '$length' } | ||||
| 			} | ||||
| 		}]) | ||||
| 		.then(aggregates => { | ||||
| 			if (aggregates.length > 0) { | ||||
| 				return aggregates[0].usage; | ||||
| 			} | ||||
| 			return 0; | ||||
| 		}); | ||||
|  | ||||
| 	await Stats.insert({ | ||||
| 		date: date, | ||||
| 		span: 'hour', | ||||
| 		users: { | ||||
| 			local: { | ||||
| 				total: localUsersCount, | ||||
| 				diff: 0 | ||||
| 			}, | ||||
| 			remote: { | ||||
| 				total: remoteUsersCount, | ||||
| 				diff: 0 | ||||
| 			} | ||||
| 		}, | ||||
| 		notes: { | ||||
| 			local: { | ||||
| 				total: localNotesCount, | ||||
| 				diff: 0, | ||||
| 				diffs: { | ||||
| 					normal: 0, | ||||
| 					reply: 0, | ||||
| 					renote: 0 | ||||
| 				} | ||||
| 			}, | ||||
| 			remote: { | ||||
| 				total: remoteNotesCount, | ||||
| 				diff: 0, | ||||
| 				diffs: { | ||||
| 					normal: 0, | ||||
| 					reply: 0, | ||||
| 					renote: 0 | ||||
| 				} | ||||
| 			} | ||||
| 		}, | ||||
| 		drive: { | ||||
| 			local: { | ||||
| 				totalCount: localDriveFilesCount, | ||||
| 				totalSize: localDriveFilesSize, | ||||
| 				diffCount: 0, | ||||
| 				diffSize: 0 | ||||
| 			}, | ||||
| 			remote: { | ||||
| 				totalCount: remoteDriveFilesCount, | ||||
| 				totalSize: remoteDriveFilesSize, | ||||
| 				diffCount: 0, | ||||
| 				diffSize: 0 | ||||
| 			} | ||||
| 		} | ||||
| 	}); | ||||
|  | ||||
| 	console.log('done'); | ||||
| } | ||||
|  | ||||
| main(); | ||||
| @@ -1,3 +1,3 @@ | ||||
| files: | ||||
|   - source: /locales/ja.yml | ||||
|     translation: /locales/%two_letters_code%.yml | ||||
|   - source: /locales/ja-JP.yml | ||||
|     translation: /locales/%locale%.yml | ||||
|   | ||||
| @@ -1,26 +0,0 @@ | ||||
| FROM base/archlinux | ||||
|  | ||||
| MAINTAINER Aya Morisawa | ||||
|  | ||||
| RUN rm /etc/pacman.d/mirrorlist | ||||
| RUN echo 'Server = http://ftp.jaist.ac.jp/pub/Linux/ArchLinux/$repo/os/$arch'    >> /etc/pacman.d/mirrorlist | ||||
| RUN echo 'Server = http://ftp.tsukuba.wide.ad.jp/Linux/archlinux/$repo/os/$arch' >> /etc/pacman.d/mirrorlist | ||||
|  | ||||
| RUN rm /etc/localtime | ||||
| RUN ln -s /usr/share/zoneinfo/Asia/Tokyo /etc/localtime | ||||
|  | ||||
| RUN pacman -Sy --noconfirm | ||||
| RUN pacman -S --noconfirm pacman | ||||
| RUN pacman-db-upgrade | ||||
| RUN pacman -S --noconfirm archlinux-keyring | ||||
| RUN pacman -Syyu --noconfirm | ||||
| RUN pacman -S --noconfirm git nodejs npm mongodb redis | ||||
|  | ||||
| COPY misskey.sh /root/misskey.sh | ||||
| RUN chmod u+x /root/misskey.sh | ||||
|  | ||||
| EXPOSE 80 | ||||
| EXPOSE 443 | ||||
| EXPOSE 27017 | ||||
|  | ||||
| CMD ["/root/misskey.sh"] | ||||
| @@ -1,6 +0,0 @@ | ||||
| #!/bin/sh | ||||
| redis-server --daemonize yes | ||||
| mongod > /dev/null & | ||||
| cd /root/misskey | ||||
| npm start | ||||
| tail -f /dev/null | ||||
| @@ -1,29 +0,0 @@ | ||||
| Setup with Docker :whale: | ||||
| ================================================================ | ||||
|  | ||||
| Ensure that the working directory is the repository root directory. | ||||
|  | ||||
| To create misskey image: | ||||
| ``` console | ||||
| $ sudo docker build -t misskey ./docker | ||||
| ``` | ||||
|  | ||||
| To run misskey: | ||||
| ``` console | ||||
| $ sudo docker run --rm -i -t -p $PORT:80 -v $(pwd):/root/misskey -v $DBPATH:/data/db misskey | ||||
| ``` | ||||
|  | ||||
| where `$PORT` is the port used to access Misskey Web from host browser | ||||
| and `$DBPATH` is the path of MongoDB database on the host for data persistence. | ||||
|  | ||||
| ex: | ||||
| ``` console | ||||
| $ sudo docker run --rm -i -t -p 80:80 -v $(pwd):/root/misskey -v /data/db:/data/db misskey | ||||
| ``` | ||||
|  | ||||
| If you want to run misskey in production mode, add `--env NODE_ENV=production` like this: | ||||
| ``` console | ||||
| $ sudo docker run --rm -i -t -p 80:80 -v $(pwd):/root/misskey -v /data/db:/data/db --env NODE_ENV=production misskey | ||||
| ``` | ||||
|  | ||||
| Note that `$(pwd)` is the working directory. | ||||
| @@ -33,14 +33,3 @@ node cli/suspend @syuilo@misskey.xyz | ||||
| ``` shell | ||||
| node cli/reset-password (User-ID or Username) | ||||
| ``` | ||||
|  | ||||
| ## Clean up cached remote files | ||||
| ``` shell | ||||
| node cli/clean-cached-remote-files | ||||
| ``` | ||||
|  | ||||
| ## Clean up unused drive files | ||||
| ``` shell | ||||
| node cli/clean-unused-drive-files | ||||
| ``` | ||||
| > We recommend that you announce a user that unused drive files will be deleted before performing this operation, as it may delete the user's important files. | ||||
|   | ||||
| @@ -33,14 +33,3 @@ node cli/suspend @syuilo@misskey.xyz | ||||
| ``` shell | ||||
| node cli/reset-password (ユーザーID または ユーザー名) | ||||
| ``` | ||||
|  | ||||
| ## キャッシュされたリモートファイルをクリーンアップする | ||||
| ``` shell | ||||
| node cli/clean-cached-remote-files | ||||
| ``` | ||||
|  | ||||
| ## 使われていないドライブのファイルをクリーンアップする | ||||
| ``` shell | ||||
| node cli/clean-unused-drive-files | ||||
| ``` | ||||
| > ユーザーの大事なファイルを削除する可能性があるので、この操作を実行する前にユーザーに告知することをお勧めします。 | ||||
|   | ||||
| @@ -54,7 +54,7 @@ Please visit https://www.google.com/recaptcha/intro/ and generate keys. | ||||
|  | ||||
| *(optional)* Generating VAPID keys | ||||
| ---------------------------------------------------------------- | ||||
| If you want to enable ServiceWroker, you need to generate VAPID keys: | ||||
| If you want to enable ServiceWorker, you need to generate VAPID keys: | ||||
| Unless you have set your global node_modules location elsewhere, you need to run this in root. | ||||
|  | ||||
| ``` shell | ||||
| @@ -62,6 +62,13 @@ npm install web-push -g | ||||
| web-push generate-vapid-keys | ||||
| ``` | ||||
|  | ||||
| *(optional)* Create a twitter application | ||||
| ---------------------------------------------------------------- | ||||
| If you want to enable the twitter integration, you need to create a twitter app at [https://developer.twitter.com/en/apply/user](https://developer.twitter.com/en/apply/user). | ||||
|  | ||||
| In the app you need to set the oauth callback url as : https://misskey-instance/api/tw/cb | ||||
|  | ||||
|  | ||||
| *5.* Make configuration file | ||||
| ---------------------------------------------------------------- | ||||
| 1. `cp .config/example.yml .config/default.yml` Copy the `.config/example.yml` and rename it to `default.yml`. | ||||
| @@ -124,6 +131,7 @@ You can check if the service is running with `systemctl status misskey`. | ||||
| 2. `git checkout $(git tag -l | grep -v 'rc[0-9]*$' | sort -V | tail -n 1)` | ||||
| 3. `npm install` | ||||
| 4. `npm run build` | ||||
| 5. Check [ChangeLog](../CHANGELOG.md) for migration information | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
|   | ||||
| @@ -10,7 +10,7 @@ Misskeyサーバーの構築にご関心をお寄せいただきありがとう | ||||
|  | ||||
| *1.* Misskeyユーザーの作成 | ||||
| ---------------------------------------------------------------- | ||||
| Misskeyのrootで実行しない方がよいため、代わりにユーザーを作成します。 | ||||
| Misskeyはrootユーザーで実行しない方がよいため、代わりにユーザーを作成します。 | ||||
| Debianの例: | ||||
|  | ||||
| ``` | ||||
| @@ -109,6 +109,7 @@ Restart=always | ||||
| [Install] | ||||
| WantedBy=multi-user.target | ||||
| ``` | ||||
| CentOSで1024以下のポートを使用してMisskeyを使用する場合は`ExecStart=/usr/bin/sudo /usr/bin/npm start`に変更する必要があります。 | ||||
|  | ||||
| 3. `systemctl daemon-reload ; systemctl enable misskey` systemdを再読み込みしmisskeyサービスを有効化 | ||||
| 4. `systemctl start misskey` misskeyサービスの起動 | ||||
| @@ -120,6 +121,7 @@ WantedBy=multi-user.target | ||||
| 2. `git checkout $(git tag -l | grep -v 'rc[0-9]*$' | sort -V | tail -n 1)` | ||||
| 3. `npm install` | ||||
| 4. `npm run build` | ||||
| 5. [ChangeLog](../CHANGELOG.md)でマイグレーション情報を確認する | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
|   | ||||
| @@ -11,12 +11,12 @@ If you find an untranslated part on Misskey: | ||||
| 	- In fact, `foo` should be a word that is appropriate for the situation and is easy to understand in English. | ||||
| 	- For example, if the untranslated portion is the following "タイムライン" you must write: `%i18n:@timeline%`. | ||||
|  | ||||
| 3. Open the `locales/ja.yml`, check whether the <strong>file name (path)</strong> found in step 1 exists, if not, create it. | ||||
| 3. Open the `locales/ja-JP.yml`, check whether the <strong>file name (path)</strong> found in step 1 exists, if not, create it. | ||||
| 	- Do not put the beginning of the path `src/client/app/` in the locale file. | ||||
| 	- For example, in this case we want to modify untranslated parts of `src/client/app/mobile/views/pages/home.vue`, so the key is `mobile/views/pages/home.vue`. | ||||
|  | ||||
| 4. Add the text property using the `foo` keyword below the path that you found or created in step 2. Make sure to type your text in quotation marks. Text should always be inside of quotes. | ||||
| 	-   For example, in this case we add timeline: `timeline: "タイムライン"` to `locales/ja.yml`. | ||||
| 	-   For example, in this case we add timeline: `timeline: "タイムライン"` to `locales/ja-JP.yml`. | ||||
|  | ||||
| 5. And done! | ||||
|  | ||||
|   | ||||
| @@ -16,7 +16,7 @@ Si vous trouvez un segment non-traduit sur Misskey : | ||||
| 	- Par exemple, dans ce cas de figure, nous voulons modifier le segment non-traduit de : `src/client/app/mobile/views/pages/home.vue`donc il faut juste écrire : `mobile/views/pages/home.vue` dans les fichiers linguistiques. | ||||
|  | ||||
| 4. Ajoutez la propriété du texte traduit grâce à la clef `foo`, en-dessous du chemin correspondant à votre modification que vous avez trouvé ou créé dans l'étape 2. À côté, veuillez indiquer entre "guillemets" la valeur de votre traduction. | ||||
| 	- Par exemple, dans ce cas de figure, nous ajoutons la propriété et la traduction `timeline: "Timeline"` à `locales/fr.yml`, mais aussi la propriété et la version originale `timeline: "タイムライン"` à `locales/ja.yml`. | ||||
| 	- Par exemple, dans ce cas de figure, nous ajoutons la propriété et la traduction `timeline: "Timeline"` à `locales/fr.yml`, mais aussi la propriété et la version originale `timeline: "タイムライン"` à `locales/ja-JP.yml`. | ||||
|  | ||||
| 5. Vous avez réussi à traduire une portion de misskey ! | ||||
|  | ||||
|   | ||||
| @@ -11,12 +11,12 @@ Misskey内の未翻訳箇所を見つけたら | ||||
| 	- `foo`は実際にはその場に適したわかりやすい(英語の)名前にしてください。 | ||||
| 	- 例えば未翻訳箇所が「タイムライン」というテキストだった場合、`%i18n:@timeline%`のようにします。 | ||||
|  | ||||
| 3. `locales/ja.yml`を開き、1.で見つけた<strong>ファイル名(パス)</strong>のキーが存在するか確認し、無ければ作成してください。 | ||||
| 3. `locales/ja-JP.yml`を開き、1.で見つけた<strong>ファイル名(パス)</strong>のキーが存在するか確認し、無ければ作成してください。 | ||||
| 	- パスの`src/client/app/`は省略してください。 | ||||
| 	- 例えば、今回の例では`src/client/app/mobile/views/pages/home.vue`の未翻訳箇所を修正したいので、キーは`mobile/views/pages/home.vue`になります。 | ||||
|  | ||||
| 4. そのキーの直下に2.で置換した`foo`の部分をキーとし、テキストを値とするプロパティを追加します。 | ||||
| 	- 例えば、今回の例で言うと`locales/ja.yml`に`timeline: "タイムライン"`を追加します。 | ||||
| 	- 例えば、今回の例で言うと`locales/ja-JP.yml`に`timeline: "タイムライン"`を追加します。 | ||||
|  | ||||
| 5. 完了です! | ||||
|  | ||||
|   | ||||
							
								
								
									
										15
									
								
								gulpfile.ts
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								gulpfile.ts
									
									
									
									
									
								
							| @@ -23,7 +23,6 @@ const uglifyes = require('uglify-es'); | ||||
|  | ||||
| const locales = require('./locales'); | ||||
| import { fa } from './src/misc/fa'; | ||||
| import config from './src/config'; | ||||
|  | ||||
| const uglify = uglifyComposer(uglifyes, console); | ||||
|  | ||||
| @@ -60,7 +59,16 @@ 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:lang', () => | ||||
| 	gulp.src(['./built/client/assets/*.*-*.js']) | ||||
| 		.pipe(rename(path => { | ||||
| 			path.basename = path.basename.replace(/\-(.*)$/, ''); | ||||
| 		})) | ||||
| 		.pipe(gulp.dest('./built/client/assets/')) | ||||
| ); | ||||
|  | ||||
| gulp.task('build:copy', ['build:copy:views', 'build:copy:lang'], () => | ||||
| 	gulp.src([ | ||||
| 		'./build/Release/crypto_key.node', | ||||
| 		'./src/const.json', | ||||
| @@ -70,7 +78,7 @@ gulp.task('build:copy', ['build:copy:views'], () => | ||||
| 	]).pipe(gulp.dest('./built/')) | ||||
| ); | ||||
|  | ||||
| gulp.task('test', ['lint', 'mocha']); | ||||
| gulp.task('test', ['mocha']); | ||||
|  | ||||
| gulp.task('lint', () => | ||||
| 	gulp.src('./src/**/*.ts') | ||||
| @@ -118,7 +126,6 @@ gulp.task('build:client:script', () => { | ||||
| 	const client = require('./built/client/meta.json'); | ||||
| 	return gulp.src(['./src/client/app/boot.js', './src/client/app/safe.js']) | ||||
| 		.pipe(replace('VERSION', JSON.stringify(client.version))) | ||||
| 		.pipe(replace('API', JSON.stringify(config.api_url))) | ||||
| 		.pipe(replace('ENV', JSON.stringify(env))) | ||||
| 		.pipe(replace('LANGS', JSON.stringify(Object.keys(locales)))) | ||||
| 		.pipe(isProduction ? uglify({ | ||||
|   | ||||
							
								
								
									
										3
									
								
								locales/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								locales/README.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | ||||
| # **DO NOT edit locale files** except `ja-JP.yml`. | ||||
|  | ||||
| Please see [Contribution guide](../CONTRIBUTING.md) for more information. | ||||
| @@ -6,6 +6,19 @@ common: | ||||
|   misskey: "A ⭐ of fediverse" | ||||
|   about-title: "A ⭐ of fediverse." | ||||
|   about: "Misskeyを見つけていただき、ありがとうございます。Misskeyは、地球で生まれた<b>分散マイクロブログSNS</b>です。Fediverse(様々なSNSで構成される宇宙)の中に存在するため、他のSNSと相互に繋がっています。暫し都会の喧騒から離れて、新しいインターネットにダイブしてみませんか。" | ||||
|   intro: | ||||
|     title: "Misskeyって?" | ||||
|     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" | ||||
|     features: "特徴" | ||||
|     rich-contents: "投稿" | ||||
|     rich-contents-desc: "自分の考え、話題の出来事、皆と共有したいことについて発信してください。必要であれば、様々な構文を使って投稿を装飾したり、好きな画像、動画などのファイルやアンケートを添付することもできます。" | ||||
|     reaction: "リアクション" | ||||
|     reaction-desc: "あなたの気持ちを伝える最も簡単な方法です。Misskeyは、他のユーザーの投稿に様々なリアクションを付けることができます。いちどMisskeyのリアクション機能を体験してしまうと、もう「いいね」の概念しか存在しないSNSには戻れなくなるかもしれません。" | ||||
|     ui: "インターフェース" | ||||
|     ui-desc: "どのようなUIが使いやすいかは人それぞれです。だから、Misskeyは自由度の高いUIを持っています。レイアウトやデザインを調整したり、カスタマイズ可能な様々なウィジェットを配置したりして、自分だけのホームを作ってください。" | ||||
|     drive: "ドライブ" | ||||
|     drive-desc: "以前投稿したことのある画像をまた投稿したくなったことはありませんか?もしくは、アップロードしたファイルをフォルダ分けして整理したくなったことはありませんか?Misskeyの根幹に組み込まれたドライブ機能によってそれらが解決します。ファイルの共有も簡単です。" | ||||
|     outro: "他にもMisskeyにしかない機能はまだまだあるので、ぜひあなた自身の目で確かめてください。Misskeyは分散型SNSなので、このインスタンスが気に入らなければ他のインスタンスを試すこともできます。それでは、GLHF!" | ||||
|   adblock: | ||||
|     detected: "広告ブロッカーを無効にしてください" | ||||
|     warning: "<strong>Misskeyは広告を掲載していません</strong>が、広告をブロックする機能が有効だと一部の機能が利用できなかったり、不具合が発生する場合があります。" | ||||
| @@ -68,6 +81,15 @@ common: | ||||
|     confused: "こまこまのこまり" | ||||
|     rip: "RIP" | ||||
|     pudding: "Pudding" | ||||
|   note-visibility: | ||||
|     public: "公開" | ||||
|     home: "ホーム" | ||||
|     home-desc: "ホームタイムラインにのみ公開" | ||||
|     followers: "フォロワー" | ||||
|     followers-desc: "自分のフォロワーにのみ公開" | ||||
|     specified: "ダイレクト" | ||||
|     specified-desc: "指定したユーザーにのみ公開" | ||||
|     private: "非公開" | ||||
|   note-placeholders: | ||||
|     a: "今どうしてる?" | ||||
|     b: "何かありましたか?" | ||||
| @@ -84,8 +106,15 @@ common: | ||||
|   my-token-regenerated: "あなたのトークンが更新されたのでサインアウトします。" | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   verified-user: "認証済みのユーザー" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   verified-user: "公式アカウント" | ||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   show-full-acct: "ユーザー名のホストを省略しない" | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
| @@ -126,7 +155,10 @@ common: | ||||
|     home: "ホーム" | ||||
|     local: "ローカル" | ||||
|     hybrid: "ソーシャル" | ||||
|     hashtag: "ハッシュタグ" | ||||
|     global: "グローバル" | ||||
|     mentions: "あなた宛て" | ||||
|     direct: "ダイレクト投稿" | ||||
|     notifications: "通知" | ||||
|     list: "リスト" | ||||
|     swap-left: "左に移動" | ||||
| @@ -169,6 +201,9 @@ common/views/components/games/reversi/reversi.vue: | ||||
| common/views/components/games/reversi/reversi.game.vue: | ||||
|   surrender: "投了" | ||||
|   surrendered: "投了により" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
| common/views/components/games/reversi/reversi.index.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "他のMisskeyユーザーとリバーシで対戦しよう" | ||||
| @@ -226,6 +261,12 @@ common/views/components/connect-failed.troubleshooter.vue: | ||||
|   success-desc: "正常に接続できるようです。ページを再度読み込みしてください。" | ||||
|   flush: "キャッシュの削除" | ||||
|   set-version: "バージョン指定" | ||||
| common/views/components/media-banner.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "隠す" | ||||
|   show: "もっと見る" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "ユーザーを探す" | ||||
|   you: "あなた" | ||||
| @@ -256,6 +297,8 @@ common/views/components/nav.vue: | ||||
|   develop: "開発者" | ||||
|   feedback: "フィードバック" | ||||
| common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   pin: "ピン留め" | ||||
|   delete: "削除" | ||||
| @@ -284,7 +327,10 @@ common/views/components/signin.vue: | ||||
|   signin: "サインイン" | ||||
|   or: "または" | ||||
|   signin-with-twitter: "Twitterでログイン" | ||||
|   login-failed: "ログインできませんでした。ユーザー名とパスワードを確認してください。" | ||||
| common/views/components/signup.vue: | ||||
|   invitation-code: "招待コード" | ||||
|   invitation-info: "招待コードをお持ちでない方は、<a href=\"{}\">管理者</a>までご連絡ください。" | ||||
|   username: "ユーザー名" | ||||
|   checking: "確認しています..." | ||||
|   available: "利用できます" | ||||
| @@ -330,6 +376,9 @@ common/views/components/visibility-chooser.vue: | ||||
|   specified: "ダイレクト" | ||||
|   specified-desc: "指定したユーザーにのみ公開" | ||||
|   private: "非公開" | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "確認中" | ||||
|   no-broadcasts: "お知らせはありません" | ||||
| @@ -353,8 +402,6 @@ common/views/widgets/posts-monitor.vue: | ||||
|   toggle: "表示を切り替え" | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "ハッシュタグ" | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "サーバー情報" | ||||
|   toggle: "表示を切り替え" | ||||
| @@ -404,6 +451,7 @@ desktop: | ||||
|   uploading-avatar: "新しいアバターをアップロードしています" | ||||
|   avatar-updated: "アバターを更新しました" | ||||
|   choose-avatar: "アバターにする画像を選択" | ||||
|   invalid-filetype: "この形式のファイルはサポートされていません" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Black ... Total" | ||||
|   notes: "Blue ... Notes" | ||||
| @@ -417,6 +465,28 @@ desktop/views/components/calendar.vue: | ||||
|   prev: "前の月" | ||||
|   next: "次の月" | ||||
|   go: "クリックして時間遡行" | ||||
| desktop/views/components/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の累計" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの累計" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の累計" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の累計" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| desktop/views/components/choose-file-from-drive-window.vue: | ||||
|   choose-file: "ファイル選択中" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| @@ -437,6 +507,7 @@ desktop/views/components/drive-window.vue: | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   nsfw: "閲覧注意" | ||||
|   contextmenu: | ||||
|     rename: "名前を変更" | ||||
|     mark-as-sensitive: "閲覧注意に設定" | ||||
| @@ -538,8 +609,6 @@ desktop/views/components/notes.note.vue: | ||||
|   detail: "詳細" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   hide: "隠す" | ||||
|   see-more: "もっと見る" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "読み込みに失敗しました。" | ||||
|   retry: "リトライ" | ||||
| @@ -609,6 +678,9 @@ desktop/views/components/settings.vue: | ||||
|   behaviour: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込みます。" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   auto-popout: "ウィンドウの自動ポップアウト" | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   advanced: "詳細設定" | ||||
| @@ -620,11 +692,15 @@ desktop/views/components/settings.vue: | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||
|   show-renoted-my-notes: "Renoteされた自分の投稿をタイムラインに表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   show-maps-desc: "位置情報が添付された投稿のマップを自動的に展開します。" | ||||
|   sound: "サウンド" | ||||
| @@ -717,7 +793,7 @@ desktop/views/components/settings.profile.vue: | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
| @@ -734,7 +810,13 @@ desktop/views/components/timeline.vue: | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
|   list: "リスト" | ||||
|   hashtag: "ハッシュタグ" | ||||
|   add-tag-timeline: "ハッシュタグを追加" | ||||
|   add-list: "リストを追加" | ||||
|   list-name: "リスト名" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
|   adjective: "さん" | ||||
| @@ -745,6 +827,7 @@ desktop/views/components/ui.header.account.vue: | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
|   customize: "ホームのカスタマイズ" | ||||
|   admin: "管理" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   dark: "闇に飲まれる" | ||||
| @@ -781,6 +864,34 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "ドライブ" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   invite: "招待" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "メディア投稿のみ" | ||||
|   is-media-view: "メディアビュー" | ||||
| @@ -789,6 +900,11 @@ desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "詳しく..." | ||||
|   gotit: "わかった" | ||||
| @@ -797,7 +913,10 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "やってる" | ||||
|   signup-button: "やる" | ||||
|   timeline: "タイムライン" | ||||
|   announcements: "お知らせ" | ||||
|   photos: "最近の画像" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
|   info: "情報" | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Misskey Drive" | ||||
| desktop/views/pages/favorites.vue: | ||||
| @@ -813,7 +932,7 @@ desktop/views/pages/selectdrive.vue: | ||||
|   cancel: "キャンセル" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "検索機能を利用することができません。" | ||||
|   not-available: "検索機能はインスタンスの設定で無効になっています。" | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "{}で共有" | ||||
| @@ -906,12 +1025,15 @@ mobile/views/components/drive-file-chooser.vue: | ||||
|   select-file: "ファイルを選択" | ||||
| mobile/views/components/drive-folder-chooser.vue: | ||||
|   select-folder: "フォルダーを選択" | ||||
| mobile/views/components/drive.file.vue: | ||||
|   nsfw: "閲覧注意" | ||||
| mobile/views/components/drive.file-detail.vue: | ||||
|   download: "ダウンロード" | ||||
|   rename: "名前を変更" | ||||
|   move: "移動" | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -931,8 +1053,6 @@ mobile/views/components/friends-maker.vue: | ||||
|   close: "閉じる" | ||||
| mobile/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   more: "もっと見る" | ||||
|   less: "隠す" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   location: "位置情報" | ||||
| @@ -992,6 +1112,7 @@ mobile/views/components/ui.nav.vue: | ||||
|   game: "ゲーム" | ||||
|   darkmode: "ダークモード" | ||||
|   settings: "設定" | ||||
|   admin: "管理" | ||||
|   about: "Misskeyについて" | ||||
| mobile/views/components/user-timeline.vue: | ||||
|   no-notes: "このユーザーは投稿していないようです。" | ||||
| @@ -1020,6 +1141,8 @@ mobile/views/pages/home.vue: | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| mobile/views/pages/welcome.vue: | ||||
| @@ -1060,6 +1183,9 @@ mobile/views/pages/settings/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
| @@ -1081,15 +1207,23 @@ mobile/views/pages/settings.vue: | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   timeline: "タイムライン" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteを表示する" | ||||
|   show-renoted-my-notes: "Renoteされた自分の投稿を表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteを表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteを表示する" | ||||
|   post-style: "投稿の表示スタイル" | ||||
|   post-style-standard: "標準" | ||||
|   post-style-smart: "スマート" | ||||
|   notification-position: "通知の表示" | ||||
|   notification-position-bottom: "下" | ||||
|   notification-position-top: "上" | ||||
|   behavior: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   load-raw-images: "添付された画像を高画質で表示する" | ||||
|   load-remote-media: "リモートサーバーのメディアを表示する" | ||||
| @@ -1108,6 +1242,8 @@ mobile/views/pages/settings.vue: | ||||
|   update-available-desc: "ページを再度読み込みすると更新が適用されます。" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   following: "フォロー" | ||||
| @@ -6,6 +6,19 @@ common: | ||||
|   misskey: "A ⭐ of fediverse" | ||||
|   about-title: "A ⭐ of fediverse." | ||||
|   about: "Misskeyを見つけていただき、ありがとうございます。Misskeyは、地球で生まれた<b>分散マイクロブログSNS</b>です。Fediverse(様々なSNSで構成される宇宙)の中に存在するため、他のSNSと相互に繋がっています。暫し都会の喧騒から離れて、新しいインターネットにダイブしてみませんか。" | ||||
|   intro: | ||||
|     title: "Misskeyって?" | ||||
|     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" | ||||
|     features: "特徴" | ||||
|     rich-contents: "投稿" | ||||
|     rich-contents-desc: "自分の考え、話題の出来事、皆と共有したいことについて発信してください。必要であれば、様々な構文を使って投稿を装飾したり、好きな画像、動画などのファイルやアンケートを添付することもできます。" | ||||
|     reaction: "リアクション" | ||||
|     reaction-desc: "あなたの気持ちを伝える最も簡単な方法です。Misskeyは、他のユーザーの投稿に様々なリアクションを付けることができます。いちどMisskeyのリアクション機能を体験してしまうと、もう「いいね」の概念しか存在しないSNSには戻れなくなるかもしれません。" | ||||
|     ui: "インターフェース" | ||||
|     ui-desc: "どのようなUIが使いやすいかは人それぞれです。だから、Misskeyは自由度の高いUIを持っています。レイアウトやデザインを調整したり、カスタマイズ可能な様々なウィジェットを配置したりして、自分だけのホームを作ってください。" | ||||
|     drive: "ドライブ" | ||||
|     drive-desc: "以前投稿したことのある画像をまた投稿したくなったことはありませんか?もしくは、アップロードしたファイルをフォルダ分けして整理したくなったことはありませんか?Misskeyの根幹に組み込まれたドライブ機能によってそれらが解決します。ファイルの共有も簡単です。" | ||||
|     outro: "他にもMisskeyにしかない機能はまだまだあるので、ぜひあなた自身の目で確かめてください。Misskeyは分散型SNSなので、このインスタンスが気に入らなければ他のインスタンスを試すこともできます。それでは、GLHF!" | ||||
|   adblock: | ||||
|     detected: "広告ブロッカーを無効にしてください" | ||||
|     warning: "<strong>Misskeyは広告を掲載していません</strong>が、広告をブロックする機能が有効だと一部の機能が利用できなかったり、不具合が発生する場合があります。" | ||||
| @@ -58,7 +71,7 @@ common: | ||||
|     friday: "金曜日" | ||||
|     saturday: "土曜日" | ||||
|   reactions: | ||||
|     like: "Gefällt mir" | ||||
|     like: "いいね" | ||||
|     love: "Lieben" | ||||
|     laugh: "Lachen" | ||||
|     hmm: "Hmm...?" | ||||
| @@ -68,6 +81,15 @@ common: | ||||
|     confused: "Verwirrt" | ||||
|     rip: "RIP" | ||||
|     pudding: "Pudding" | ||||
|   note-visibility: | ||||
|     public: "公開" | ||||
|     home: "ホーム" | ||||
|     home-desc: "ホームタイムラインにのみ公開" | ||||
|     followers: "フォロワー" | ||||
|     followers-desc: "自分のフォロワーにのみ公開" | ||||
|     specified: "ダイレクト" | ||||
|     specified-desc: "指定したユーザーにのみ公開" | ||||
|     private: "非公開" | ||||
|   note-placeholders: | ||||
|     a: "Was machst du gerade?" | ||||
|     b: "Was ist so passiert?" | ||||
| @@ -84,8 +106,15 @@ common: | ||||
|   my-token-regenerated: "Dein Token wurde generiert. Du wirst jetzt abgemeldet." | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   verified-user: "認証済みのユーザー" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   verified-user: "公式アカウント" | ||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   show-full-acct: "ユーザー名のホストを省略しない" | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
| @@ -126,7 +155,10 @@ common: | ||||
|     home: "Startseite" | ||||
|     local: "Lokal" | ||||
|     hybrid: "ソーシャル" | ||||
|     hashtag: "ハッシュタグ" | ||||
|     global: "Global" | ||||
|     mentions: "あなた宛て" | ||||
|     direct: "ダイレクト投稿" | ||||
|     notifications: "Mitteilungen" | ||||
|     list: "Listen" | ||||
|     swap-left: "Nach links" | ||||
| @@ -169,6 +201,9 @@ common/views/components/games/reversi/reversi.vue: | ||||
| common/views/components/games/reversi/reversi.game.vue: | ||||
|   surrender: "投了" | ||||
|   surrendered: "投了により" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
| common/views/components/games/reversi/reversi.index.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "他のMisskeyユーザーとリバーシで対戦しよう" | ||||
| @@ -226,6 +261,12 @@ common/views/components/connect-failed.troubleshooter.vue: | ||||
|   success-desc: "Die Verbindung scheint zu funktionieren. Bitte lade die Seite neu." | ||||
|   flush: "Cache leeren" | ||||
|   set-version: "Version angeben" | ||||
| common/views/components/media-banner.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "隠す" | ||||
|   show: "もっと見る" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "Einen Nutzer suchen" | ||||
|   you: "Du" | ||||
| @@ -256,6 +297,8 @@ common/views/components/nav.vue: | ||||
|   develop: "Entwickler" | ||||
|   feedback: "Feedback" | ||||
| common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "Diese Anmerkung favorisieren" | ||||
|   pin: "An die Profilseite pinnen" | ||||
|   delete: "Löschen" | ||||
| @@ -284,7 +327,10 @@ common/views/components/signin.vue: | ||||
|   signin: "Anmelden" | ||||
|   or: "または" | ||||
|   signin-with-twitter: "Twitterでログイン" | ||||
|   login-failed: "ログインできませんでした。ユーザー名とパスワードを確認してください。" | ||||
| common/views/components/signup.vue: | ||||
|   invitation-code: "招待コード" | ||||
|   invitation-info: "招待コードをお持ちでない方は、<a href=\"{}\">管理者</a>までご連絡ください。" | ||||
|   username: "Benutzername" | ||||
|   checking: "Überprüfung..." | ||||
|   available: "Verfügbar" | ||||
| @@ -330,6 +376,9 @@ common/views/components/visibility-chooser.vue: | ||||
|   specified: "Direkt" | ||||
|   specified-desc: "Poste nur für bestimmte Benutzer" | ||||
|   private: "Privat" | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "Laden" | ||||
|   no-broadcasts: "Keine Broadcasts" | ||||
| @@ -353,8 +402,6 @@ common/views/widgets/posts-monitor.vue: | ||||
|   toggle: "表示を切り替え" | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "ハッシュタグ" | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "Serverinformationen" | ||||
|   toggle: "Sicht umschalten" | ||||
| @@ -404,6 +451,7 @@ desktop: | ||||
|   uploading-avatar: "新しいアバターをアップロードしています" | ||||
|   avatar-updated: "アバターを更新しました" | ||||
|   choose-avatar: "アバターにする画像を選択" | ||||
|   invalid-filetype: "この形式のファイルはサポートされていません" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Schwarz ... komplett" | ||||
|   notes: "Blau ... Hinweise" | ||||
| @@ -417,6 +465,28 @@ desktop/views/components/calendar.vue: | ||||
|   prev: "Vorheriger Monat" | ||||
|   next: "Nächster Monat" | ||||
|   go: "Klicke zur Navigation" | ||||
| desktop/views/components/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の累計" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの累計" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の累計" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の累計" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| desktop/views/components/choose-file-from-drive-window.vue: | ||||
|   choose-file: "Datei auswählen" | ||||
|   upload: "Dateien von deinem PC hochladen" | ||||
| @@ -437,6 +507,7 @@ desktop/views/components/drive-window.vue: | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "Avatar" | ||||
|   banner: "Banner" | ||||
|   nsfw: "閲覧注意" | ||||
|   contextmenu: | ||||
|     rename: "Umbenennen" | ||||
|     mark-as-sensitive: "閲覧注意に設定" | ||||
| @@ -538,8 +609,6 @@ desktop/views/components/notes.note.vue: | ||||
|   detail: "Zeige Details" | ||||
|   private: "Dieser Beitrag ist eine privat" | ||||
|   deleted: "Dieser Beitrag wurde entfernt" | ||||
|   hide: "隠す" | ||||
|   see-more: "もっと見る" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "Laden fehlgeschlagen." | ||||
|   retry: "Erneut versuchen" | ||||
| @@ -609,6 +678,9 @@ desktop/views/components/settings.vue: | ||||
|   behaviour: "Verhalten" | ||||
|   fetch-on-scroll: "Aktualisieren beim scrollen" | ||||
|   fetch-on-scroll-desc: "Wenn du runterscrollst empfängt die Seite automatisch zusätzliche Inhalte." | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   auto-popout: "Automatische Pop-out Fenster" | ||||
|   auto-popout-desc: "Pop-out ein offenes Fenster wenn möglich. Diese Einstellung wird im Browser gespeichert." | ||||
|   advanced: "Erweiterte Einstellungen" | ||||
| @@ -620,11 +692,15 @@ desktop/views/components/settings.vue: | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "Nacht Modus" | ||||
|   circle-icons: "Kreisförmige Icons" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   gradient-window-header: "Übergang in Fensterköpfen" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "Zeige Antworten" | ||||
|   show-my-renotes: "Zeige meine Reposts auf der Zeitleiste" | ||||
|   show-renoted-my-notes: "Zeige meine Reposts, die geteilt wurden, auf der Zeitleiste" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "Karte anzeigen" | ||||
|   show-maps-desc: "Zeige den Standort zu diesem Beitrag automatisch an." | ||||
|   sound: "Ton" | ||||
| @@ -717,7 +793,7 @@ desktop/views/components/settings.profile.vue: | ||||
|   birthday: "誕生日" | ||||
|   save: "Profil aktualisieren" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
| @@ -734,7 +810,13 @@ desktop/views/components/timeline.vue: | ||||
|   local: "Lokal" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "Global" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
|   list: "Listen" | ||||
|   hashtag: "ハッシュタグ" | ||||
|   add-tag-timeline: "ハッシュタグを追加" | ||||
|   add-list: "リストを追加" | ||||
|   list-name: "リスト名" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
|   adjective: "さん" | ||||
| @@ -745,6 +827,7 @@ desktop/views/components/ui.header.account.vue: | ||||
|   lists: "Listen" | ||||
|   follow-requests: "フォロー申請" | ||||
|   customize: "ホームのカスタマイズ" | ||||
|   admin: "管理" | ||||
|   settings: "Einstellungen" | ||||
|   signout: "Ausloggen" | ||||
|   dark: "Verdunkeln" | ||||
| @@ -781,6 +864,34 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "ドライブ" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   invite: "招待" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "メディア投稿のみ" | ||||
|   is-media-view: "メディアビュー" | ||||
| @@ -789,6 +900,11 @@ desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "詳しく..." | ||||
|   gotit: "わかった" | ||||
| @@ -797,7 +913,10 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "やってる" | ||||
|   signup-button: "やる" | ||||
|   timeline: "タイムライン" | ||||
|   announcements: "お知らせ" | ||||
|   photos: "最近の画像" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
|   info: "情報" | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Misskey Drive" | ||||
| desktop/views/pages/favorites.vue: | ||||
| @@ -813,7 +932,7 @@ desktop/views/pages/selectdrive.vue: | ||||
|   cancel: "Abbrechen" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "検索機能を利用することができません。" | ||||
|   not-available: "検索機能はインスタンスの設定で無効になっています。" | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "{}で共有" | ||||
| @@ -906,12 +1025,15 @@ mobile/views/components/drive-file-chooser.vue: | ||||
|   select-file: "ファイルを選択" | ||||
| mobile/views/components/drive-folder-chooser.vue: | ||||
|   select-folder: "フォルダーを選択" | ||||
| mobile/views/components/drive.file.vue: | ||||
|   nsfw: "閲覧注意" | ||||
| mobile/views/components/drive.file-detail.vue: | ||||
|   download: "ダウンロード" | ||||
|   rename: "名前を変更" | ||||
|   move: "移動" | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -931,8 +1053,6 @@ mobile/views/components/friends-maker.vue: | ||||
|   close: "閉じる" | ||||
| mobile/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   more: "もっと見る" | ||||
|   less: "隠す" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   location: "位置情報" | ||||
| @@ -992,6 +1112,7 @@ mobile/views/components/ui.nav.vue: | ||||
|   game: "ゲーム" | ||||
|   darkmode: "ダークモード" | ||||
|   settings: "設定" | ||||
|   admin: "管理" | ||||
|   about: "Misskeyについて" | ||||
| mobile/views/components/user-timeline.vue: | ||||
|   no-notes: "このユーザーは投稿していないようです。" | ||||
| @@ -1020,6 +1141,8 @@ mobile/views/pages/home.vue: | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| mobile/views/pages/welcome.vue: | ||||
| @@ -1060,6 +1183,9 @@ mobile/views/pages/settings/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "Profil wurde aktualisiert" | ||||
|   uploading: "アップロード中" | ||||
| @@ -1081,15 +1207,23 @@ mobile/views/pages/settings.vue: | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   timeline: "タイムライン" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteを表示する" | ||||
|   show-renoted-my-notes: "Renoteされた自分の投稿を表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteを表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteを表示する" | ||||
|   post-style: "投稿の表示スタイル" | ||||
|   post-style-standard: "標準" | ||||
|   post-style-smart: "スマート" | ||||
|   notification-position: "通知の表示" | ||||
|   notification-position-bottom: "下" | ||||
|   notification-position-top: "上" | ||||
|   behavior: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   load-raw-images: "添付された画像を高画質で表示する" | ||||
|   load-remote-media: "リモートサーバーのメディアを表示する" | ||||
| @@ -1108,6 +1242,8 @@ mobile/views/pages/settings.vue: | ||||
|   update-available-desc: "ページを再度読み込みすると更新が適用されます。" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   following: "フォロー" | ||||
| @@ -6,19 +6,32 @@ common: | ||||
|   misskey: "A ⭐ of the fediverse" | ||||
|   about-title: "A ⭐ of the fediverse." | ||||
|   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 a open-source <b>decentralized microblogging service</b>. Sophisticated fully customizable Ui, varieties of reaction for posts, free file storage providing integrated management system and other advancing functions are available. Also, network system called “Fediverse” enables us to communicate with users on other SNSs. Like, if you post something, then your posts will sent not only to Misskey but also mastodon. Just imagine that the planet is sending a microwave to other planet to communication." | ||||
|     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!" | ||||
|     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" | ||||
|     ui-desc: "No UI fits for everyone. Therefore, Misskey has a highly customizable UI for your taste. Make your original home by editing, adjusting layouts of timeline and placing selectable widgets you can easily customize." | ||||
|     drive: "Misskey Drive" | ||||
|     drive-desc: "Wanna post a picture you have already uploaded? Wish to organize, name and create a folder for your uploaded files? Misskey Drive is the best solution for you. Very easy to share your files online." | ||||
|     outro: "Check further Misskey-unique features on your eyes! Feeling like this is not for you, try other instances as Misskey is a decentralized SNS so that you can easily find your mates. Then, GLHF!" | ||||
|   adblock: | ||||
|     detected: "Please disable ad blocker." | ||||
|     warning: "<strong>Misskey is not running ads</strong>, but some features may be unavailable or malfunctioning if ad blocking features are enabled." | ||||
|   application-authorization: "Application authorizations." | ||||
|     warning: "Some features may be unavailable or cause malfunctions if ad blocking features are enabled. <strong>Misskey is not running ads</strong>." | ||||
|   application-authorization: "Application authorizations" | ||||
|   close: "Close" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   do-not-copy-paste: "Please do not enter or paste the code here. Account may be compromised." | ||||
|   got-it: "Got it!" | ||||
|   customization-tips: | ||||
|     title: "Customization tips" | ||||
|     paragraph1: "Home customization allows you to add/delete, drag and drop and rearrange widgets." | ||||
|     paragraph2: "You can change the display by <strong>right clicking</strong> on some widgets." | ||||
|     paragraph3: "To delete a widget, <strong>drag and drop the widget onto the area labeled \"Trash\"</strong> in the header." | ||||
|     paragraph4: "To finish the customization, click \"Finish\" in the upper right." | ||||
|     paragraph2: "You can change the display by <strong><strong>right</strong> clicking</strong> on some widgets." | ||||
|     paragraph3: "To delete a widget, drag and drop the widget onto <strong>the area labeled \"Trash\"</strong> in the header." | ||||
|     paragraph4: "To finish the customization, click \"Finish\" on the upper right." | ||||
|     gotit: "Got it!" | ||||
|   notification: | ||||
|     file-uploaded: "File uploaded!" | ||||
| @@ -68,13 +81,22 @@ common: | ||||
|     confused: "Confused" | ||||
|     rip: "RIP" | ||||
|     pudding: "Pudding" | ||||
|   note-visibility: | ||||
|     public: "Public" | ||||
|     home: "Home" | ||||
|     home-desc: "Post to the home timeline only" | ||||
|     followers: "Followers" | ||||
|     followers-desc: "Post to followers only" | ||||
|     specified: "Direct" | ||||
|     specified-desc: "Post to specified users only" | ||||
|     private: "Private" | ||||
|   note-placeholders: | ||||
|     a: "What are you doing?" | ||||
|     b: "What's happening?" | ||||
|     c: "What’s on your mind?" | ||||
|     d: "What do you wish to say?" | ||||
|     d: "Would you post any words?" | ||||
|     e: "Write here" | ||||
|     f: "Waiting for your writing..." | ||||
|     f: "Waiting for your writing." | ||||
|   search: "Search" | ||||
|   delete: "Delete" | ||||
|   loading: "Loading" | ||||
| @@ -84,8 +106,15 @@ common: | ||||
|   my-token-regenerated: "Your token has been regenerated, so you will be signed out." | ||||
|   i-like-sushi: "I prefer sushi rather than pudding" | ||||
|   show-reversi-board-labels: "Show row and column labels in Reversi" | ||||
|   verified-user: "Verified user" | ||||
|   use-contrast-reversi-stones: "Make the stone color clear in reversi" | ||||
|   verified-user: "Verified account" | ||||
|   disable-animated-mfm: "Disable animated texts in a post" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "Always post with a warning about media attachment" | ||||
|   show-full-acct: "Do not omit the hostname from the username" | ||||
|   reduce-motion: "Reduce motion in UI" | ||||
|   this-setting-is-this-device-only: "Only for this device" | ||||
|   do-not-use-in-production: 'As this is for development, do not use this in production.' | ||||
|   reversi: | ||||
|     drawn: "Draw" | ||||
|     my-turn: "Your turn" | ||||
| @@ -126,7 +155,10 @@ common: | ||||
|     home: "Home" | ||||
|     local: "Local" | ||||
|     hybrid: "Social" | ||||
|     hashtag: "Hashtag" | ||||
|     global: "Global" | ||||
|     mentions: "Mentions" | ||||
|     direct: "ダイレクト投稿" | ||||
|     notifications: "Notifications" | ||||
|     list: "Lists" | ||||
|     swap-left: "Move to the left" | ||||
| @@ -141,23 +173,23 @@ common: | ||||
| auth/views/form.vue: | ||||
|   share-access: "Would you <b>allow</b> <i>{{ app.name }}</i> to access your account?" | ||||
|   permission-ask: "This application requires the following permissions:" | ||||
|   account-read: "Viewing account information:" | ||||
|   account-write: "Modify account informations:" | ||||
|   account-read: "View account information." | ||||
|   account-write: "Modify account information." | ||||
|   note-write: "Post." | ||||
|   like-write: "To react to posts." | ||||
|   following-write: "Follow or unfollow." | ||||
|   like-write: "React to posts." | ||||
|   following-write: "Follow and unfollow." | ||||
|   drive-read: "Read your drive." | ||||
|   drive-write: "Upload/delete files in your drive." | ||||
|   notification-read: "Read your notifications." | ||||
|   notification-write: "Manage your notifications." | ||||
|   cancel: "Cancel" | ||||
|   accept: "Grant access." | ||||
|   accept: "Allow access." | ||||
| auth/views/index.vue: | ||||
|   loading: "Loading" | ||||
|   denied: "Application authorization denied." | ||||
|   denied: "Application authorization has been denied." | ||||
|   denied-paragraph: "This application will not access your account." | ||||
|   already-authorized: "This application has already been authorized." | ||||
|   allowed: "Application authorizations allowed.+" | ||||
|   allowed: "Application authorizations allowed." | ||||
|   callback-url: "Going back to the application." | ||||
|   please-go-back: "Please go back to the application." | ||||
|   error: "Session does not exist." | ||||
| @@ -169,6 +201,9 @@ common/views/components/games/reversi/reversi.vue: | ||||
| common/views/components/games/reversi/reversi.game.vue: | ||||
|   surrender: "Surrender" | ||||
|   surrendered: "By surrender" | ||||
|   is-llotheo: "The lesser one wins(Llotheo)" | ||||
|   looped-map: "Looped map" | ||||
|   can-put-everywhere: "Can put everywhere" | ||||
| common/views/components/games/reversi/reversi.index.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "Play reversi with your friends!" | ||||
| @@ -176,13 +211,13 @@ common/views/components/games/reversi/reversi.index.vue: | ||||
|   rule: "How to play" | ||||
|   rule-desc: "Reversi is a strategy board game for two players, played on an 8×8 uncheckered board. There are sixty-four identical game pieces called disks (often spelled \"discs\"), which are light on one side and dark on the other. Players take turns placing disks on the board with their assigned color facing up. During a play, any disks of the opponent's color that are in a straight line and bounded by the disk just placed and another disk of the current player's color are turned over to the current player's color. The object of the game is to have the majority of disks turned to display your color when the last playable empty square is filled." | ||||
|   mode-invite: "Invite" | ||||
|   mode-invite-desc: "Invite to the game a user." | ||||
|   invitations: "You received invitation!" | ||||
|   my-games: "My games" | ||||
|   mode-invite-desc: "Game with a specified user." | ||||
|   invitations: "You’ve got an invitation!" | ||||
|   my-games: "My game" | ||||
|   all-games: "All games" | ||||
|   enter-username: "Enter username" | ||||
|   enter-username: "Enter a username" | ||||
|   game-state: | ||||
|     ended: "Ended" | ||||
|     ended: "Finished" | ||||
|     playing: "In Progress" | ||||
| common/views/components/games/reversi/reversi.room.vue: | ||||
|   settings-of-the-game: "Game settings" | ||||
| @@ -191,14 +226,14 @@ common/views/components/games/reversi/reversi.room.vue: | ||||
|   black-or-white: "Black/White" | ||||
|   black-is: "Black is {}" | ||||
|   rules: "Rules" | ||||
|   is-llotheo: "The lesser one wins" | ||||
|   is-llotheo: "The lesser side wins" | ||||
|   looped-map: "Looped map" | ||||
|   can-put-everywhere: "Can put everywhere" | ||||
|   settings-of-the-bot: "Bot settings" | ||||
|   this-game-is-started-soon: "The game will begin soon" | ||||
|   waiting-for-other: "Waiting for the other party's preparation" | ||||
|   this-game-is-started-soon: "The game will begin in seconds" | ||||
|   waiting-for-other: "Waiting for the opponent" | ||||
|   waiting-for-me: "Waiting for the your preparation" | ||||
|   waiting-for-both: "Waiting for yours" | ||||
|   waiting-for-both: "Prepareing" | ||||
|   cancel: "Cancel" | ||||
|   ready: "Ready" | ||||
|   cancel-ready: "Cancel \"Ready\"" | ||||
| @@ -223,9 +258,15 @@ common/views/components/connect-failed.troubleshooter.vue: | ||||
|   no-server: "Unable to connect to the Misskey server" | ||||
|   no-server-desc: "The network connection of your device is normal, but you could not connect to the Misskey server. There is a possibility that the server is either down, or under maintenance, please try again later." | ||||
|   success: "Successfully connected to the Misskey server" | ||||
|   success-desc: "It seems to be able to connect. Please reload the page." | ||||
|   success-desc: "Looks like we have a connection. Please reload the page." | ||||
|   flush: "Clean cache" | ||||
|   set-version: "Specify version" | ||||
| common/views/components/media-banner.vue: | ||||
|   sensitive: "NSFW" | ||||
|   click-to-show: "Click to show" | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "Hide" | ||||
|   show: "See more" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "Find a user" | ||||
|   you: "You" | ||||
| @@ -236,13 +277,13 @@ common/views/components/messaging-room.vue: | ||||
|   no-history: "There is no further history" | ||||
|   resize-form: "Drag to resize" | ||||
|   new-message: "New message" | ||||
|   only-one-file-attached: "メッセージに添付できるのはひとつのファイルのみです" | ||||
|   only-one-file-attached: "Only ONE file can be attached to a message." | ||||
| common/views/components/messaging-room.form.vue: | ||||
|   input-message-here: "Enter message here" | ||||
|   send: "Send" | ||||
|   attach-from-local: "Attach files from your device" | ||||
|   attach-from-drive: "Attach files from your Drive" | ||||
|   only-one-file-attached: "メッセージに添付できるのはひとつのファイルのみです" | ||||
|   only-one-file-attached: "Only one file can be attached to the message." | ||||
| common/views/components/messaging-room.message.vue: | ||||
|   is-read: "Read" | ||||
|   deleted: "This message has been deleted" | ||||
| @@ -256,10 +297,12 @@ common/views/components/nav.vue: | ||||
|   develop: "Developers" | ||||
|   feedback: "Feedback" | ||||
| common/views/components/note-menu.vue: | ||||
|   detail: "Details" | ||||
|   copy-link: "Copy link" | ||||
|   favorite: "Favorite this note" | ||||
|   pin: "Pin to your profile page" | ||||
|   pin: "Pin to your profile" | ||||
|   delete: "Delete" | ||||
|   delete-confirm: "Are you sure you want to delete this post?" | ||||
|   delete-confirm: "Delete this post?" | ||||
|   remote: "Show original note" | ||||
| common/views/components/poll.vue: | ||||
|   vote-to: "Vote for '{}'" | ||||
| @@ -269,13 +312,13 @@ common/views/components/poll.vue: | ||||
|   show-result: "Show results" | ||||
|   voted: "Voted" | ||||
| common/views/components/poll-editor.vue: | ||||
|   no-only-one-choice: "At least two choices are required for this survey." | ||||
|   no-only-one-choice: "At least two choices are required" | ||||
|   choice-n: "Choice {}" | ||||
|   remove: "Delete this choice" | ||||
|   remove: "Delete the choice" | ||||
|   add: "+ Add a choice" | ||||
|   destroy: "Discard the poll" | ||||
| common/views/components/reaction-picker.vue: | ||||
|   choose-reaction: "Express a reaction" | ||||
|   choose-reaction: "Send a reaction" | ||||
| common/views/components/signin.vue: | ||||
|   username: "Username" | ||||
|   password: "Password" | ||||
| @@ -284,17 +327,20 @@ common/views/components/signin.vue: | ||||
|   signin: "Sign in" | ||||
|   or: "Or" | ||||
|   signin-with-twitter: "Log in with Twitter" | ||||
|   login-failed: "Log in failed. Make sure you have entered your correct username and password." | ||||
| common/views/components/signup.vue: | ||||
|   invitation-code: "Invitation code" | ||||
|   invitation-info: "If you do not have an invitation code, please contact an <a href=\"{}\">administrator</a>." | ||||
|   username: "Username" | ||||
|   checking: "Checking..." | ||||
|   checking: "Confirming..." | ||||
|   available: "Available" | ||||
|   unavailable: "Unavailable" | ||||
|   error: "Network error" | ||||
|   invalid-format: "Only use letters, numbers and -." | ||||
|   too-short: "Please enter at least 1 character!" | ||||
|   too-long: "Please enter up to 20 characters." | ||||
|   invalid-format: "letters, numbers and _ are acceptable." | ||||
|   too-short: "Should not be blank!" | ||||
|   too-long: "Enter within 20 characters." | ||||
|   password: "Password" | ||||
|   password-placeholder: "We recommend more than 8 characters." | ||||
|   password-placeholder: "More than 8 characters are recommended." | ||||
|   weak-password: "Weak password" | ||||
|   normal-password: "Fair password" | ||||
|   strong-password: "Strong password" | ||||
| @@ -324,12 +370,15 @@ common/views/components/uploader.vue: | ||||
| common/views/components/visibility-chooser.vue: | ||||
|   public: "Public" | ||||
|   home: "Home" | ||||
|   home-desc: "Post to the home timeline only" | ||||
|   home-desc: "Post to Home only" | ||||
|   followers: "Followers" | ||||
|   followers-desc: "Post to followers only" | ||||
|   followers-desc: "Post to Followers only" | ||||
|   specified: "Direct" | ||||
|   specified-desc: "Post to specified users only" | ||||
|   private: "Private" | ||||
| common/views/components/trends.vue: | ||||
|   count: "{} users mentioned" | ||||
|   empty: "No popular hashtag trends" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "Fetching" | ||||
|   no-broadcasts: "No announcements" | ||||
| @@ -337,14 +386,14 @@ common/views/widgets/broadcast.vue: | ||||
|   next: "Next" | ||||
| common/views/widgets/calendar.vue: | ||||
|   year: "Year {}" | ||||
|   month: "Month {}" | ||||
|   day: "Day {}" | ||||
|   month: "{}," | ||||
|   day: "{}" | ||||
|   today: "Today: " | ||||
|   this-month: "This month: " | ||||
|   this-year: "This year: " | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "Request for donations" | ||||
|   text: "To keep Misskey up and running, we have to spend money on our domain name, the server costs and so on. Since we don't receive money from advertisements, we count on donations from all of you. If you're interested in helping, contact {}. Thank you for your contribution!" | ||||
|   text: "To keep Misskey up and running, there have to happen some expense for the domain name, the server and so on. Since our policy is not to display any advertisements, we count on your donations. If you're interested in helping, contact {}. Thank you for your contribution!" | ||||
| common/views/widgets/photo-stream.vue: | ||||
|   title: "Photo stream" | ||||
|   no-photos: "No photos" | ||||
| @@ -353,8 +402,6 @@ common/views/widgets/posts-monitor.vue: | ||||
|   toggle: "Toggle views" | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "Hashtags" | ||||
|   count: "{} users mentioned" | ||||
|   empty: "No popular hashtag trends" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "Server info" | ||||
|   toggle: "Toggle views" | ||||
| @@ -385,8 +432,8 @@ common/views/widgets/tips.vue: | ||||
|   tips-line20: "The percentage of the calendar widget shows the percentage of time elapsed." | ||||
|   tips-line21: "You can also use the API to develop bots." | ||||
|   tips-line23: "Mayu is so cute with its eyebrows." | ||||
|   tips-line24: "Misskey started in 2014." | ||||
|   tips-line25: "You can receive notification even if Misskey is not open in a compatible browser." | ||||
|   tips-line24: "Misskey has been running since 2014." | ||||
|   tips-line25: "In a browser compatible with notification features, you can receive notifications in case Misskey is not open" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "Signed in as {}" | ||||
|   following: "Following" | ||||
| @@ -397,13 +444,14 @@ desktop: | ||||
|   banner-crop-title: "Crop the part that appears as a banner" | ||||
|   banner: "Banner" | ||||
|   uploading-banner: "Uploading a new banner" | ||||
|   banner-updated: "Updated the banner" | ||||
|   banner-updated: "Successfully updated the banner" | ||||
|   choose-banner: "Choose the banner" | ||||
|   avatar-crop-title: "Crop the part that appears as an avatar" | ||||
|   avatar: "Avatar" | ||||
|   uploading-avatar: "Uploading a new avatar" | ||||
|   avatar-updated: "Updated the avatar" | ||||
|   choose-avatar: "Choose an avatar image" | ||||
|   avatar-updated: "Successfully updated the avatar" | ||||
|   choose-avatar: "Select an image for the avatar" | ||||
|   invalid-filetype: "This filetype is not acceptable here" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Black ... Total" | ||||
|   notes: "Blue ... Notes" | ||||
| @@ -417,6 +465,28 @@ desktop/views/components/calendar.vue: | ||||
|   prev: "Previous month" | ||||
|   next: "Next month" | ||||
|   go: "Click to navigate" | ||||
| desktop/views/components/charts.vue: | ||||
|   title: "Charts" | ||||
|   per-day: "per Day" | ||||
|   per-hour: "per Hour" | ||||
|   notes: "Posts" | ||||
|   users: "Users" | ||||
|   drive: "Drive" | ||||
|   network: "Network" | ||||
|   charts: | ||||
|     notes: "The number of posts: increase/decrease (Combined)" | ||||
|     local-notes: "The number of posts: increase/decrease (Local)" | ||||
|     remote-notes: "The number of posts: increase/decrease (Remote)" | ||||
|     notes-total: "The number of posts: cumulative total" | ||||
|     users: "The number of users: increase/decrease" | ||||
|     users-total: "The number of users: cumulative total" | ||||
|     drive: "Capacity used as the storage: increase/decrease" | ||||
|     drive-total: "Capacity used as the storage: cumulative total" | ||||
|     drive-files: "The number of files on the storage: increase/decrease" | ||||
|     drive-files-total: "The number of files on the storage: cumulative total" | ||||
|     network-requests: "Requests" | ||||
|     network-time: "Response time" | ||||
|     network-usage: "Traffic" | ||||
| desktop/views/components/choose-file-from-drive-window.vue: | ||||
|   choose-file: "Choose files" | ||||
|   upload: "Upload files from your device" | ||||
| @@ -437,6 +507,7 @@ desktop/views/components/drive-window.vue: | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "Avatar" | ||||
|   banner: "Banner" | ||||
|   nsfw: "NSFW" | ||||
|   contextmenu: | ||||
|     rename: "Rename" | ||||
|     mark-as-sensitive: "Mark as 'sensitive'" | ||||
| @@ -451,7 +522,7 @@ desktop/views/components/drive.file.vue: | ||||
|     rename-file: "Rename file" | ||||
|     input-new-file-name: "Enter new name" | ||||
|     copied: "Copied" | ||||
|     copied-url-to-clipboard: "Copied URL to clipboard" | ||||
|     copied-url-to-clipboard: "URL has been copied to clipboard" | ||||
| desktop/views/components/drive.folder.vue: | ||||
|   unable-to-process: "The operation could not be completed." | ||||
|   circular-reference-detected: "The destination folder is a subfolder of the folder you wish to move." | ||||
| @@ -467,7 +538,7 @@ desktop/views/components/drive.nav-folder.vue: | ||||
| desktop/views/components/drive.vue: | ||||
|   search: "Search" | ||||
|   load-more: "Load more" | ||||
|   empty-draghover: "Drop it here, don't I look cute?" | ||||
|   empty-draghover: "Drop it here! Yep, cuz you know I'm cute, right?" | ||||
|   empty-drive: "Your media storage is empty" | ||||
|   empty-drive-description: "Right-click to open the menu, or drag and drop a file onto here for uploading." | ||||
|   empty-folder: "This folder is empty" | ||||
| @@ -477,7 +548,7 @@ desktop/views/components/drive.vue: | ||||
|   url-upload: "Upload from a URL" | ||||
|   url-of-file: "URL of file you want to upload" | ||||
|   url-upload-requested: "Upload requested" | ||||
|   may-take-time: "It may take some time for the upload to complete." | ||||
|   may-take-time: "It may take some time until the upload is complete." | ||||
|   create-folder: "Create a folder" | ||||
|   folder-name: "Folder name" | ||||
|   contextmenu: | ||||
| @@ -485,7 +556,7 @@ desktop/views/components/drive.vue: | ||||
|     upload: "Upload a file" | ||||
|     url-upload: "Upload from a URL" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "The content is NSFW" | ||||
|   sensitive: "NSFW" | ||||
|   click-to-show: "Click to show" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "The content is NSFW" | ||||
| @@ -502,7 +573,7 @@ desktop/views/components/followers.vue: | ||||
| desktop/views/components/following-window.vue: | ||||
|   following: "Following {}" | ||||
| desktop/views/components/following.vue: | ||||
|   empty: "You don’t follow anyone." | ||||
|   empty: "It seems you don't have any following users…" | ||||
| desktop/views/components/friends-maker.vue: | ||||
|   title: "Recommended users:" | ||||
|   empty: "Couldn't find any recommended users." | ||||
| @@ -524,8 +595,8 @@ desktop/views/components/messaging-window.vue: | ||||
|   title: "Messaging" | ||||
| desktop/views/components/note-detail.vue: | ||||
|   more: "Load more conversations" | ||||
|   private: "This post is private" | ||||
|   deleted: "This post has been removed" | ||||
|   private: "Post is private" | ||||
|   deleted: "Post has been removed" | ||||
|   reposted-by: "Reposted by {}" | ||||
|   location: "Location" | ||||
|   renote: "Repost" | ||||
| @@ -536,10 +607,8 @@ desktop/views/components/notes.note.vue: | ||||
|   renote: "Repost" | ||||
|   add-reaction: "Add a reaction" | ||||
|   detail: "Show details" | ||||
|   private: "This post is private" | ||||
|   deleted: "The post has been deleted" | ||||
|   hide: "Hide" | ||||
|   see-more: "See more" | ||||
|   private: "Post is private" | ||||
|   deleted: "Post has been deleted" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "Loading failed." | ||||
|   retry: "Retry" | ||||
| @@ -551,15 +620,15 @@ desktop/views/components/post-form.vue: | ||||
|   add-visible-user: "+Add a user" | ||||
|   attach-location-information: "Attach location information" | ||||
|   hide-contents: "Hide contents" | ||||
|   reply-placeholder: "Reply to this note..." | ||||
|   quote-placeholder: "Quote this note..." | ||||
|   reply-placeholder: "Reply to this post..." | ||||
|   quote-placeholder: "Quote this Post..." | ||||
|   submit: "Post" | ||||
|   reply: "Reply" | ||||
|   renote: "Repost" | ||||
|   posted: "Posted!" | ||||
|   replied: "Replied!" | ||||
|   reposted: "Reposted!" | ||||
|   note-failed: "Failed to post the note" | ||||
|   note-failed: "Failed to post" | ||||
|   reply-failed: "Failed to reply" | ||||
|   renote-failed: "Failed to repost" | ||||
|   posting: "Posting" | ||||
| @@ -572,12 +641,12 @@ desktop/views/components/post-form.vue: | ||||
|   recent-tags: "Recent" | ||||
|   click-to-tagging: "Click to tagging" | ||||
|   visibility: "Visibility" | ||||
|   geolocation-alert: "Your device does not support geolocalization." | ||||
|   geolocation-alert: "Your device does not provide location services." | ||||
|   error: "Error" | ||||
|   enter-username: "Please enter a username..." | ||||
|   annotations: "内容への注釈 (オプション)" | ||||
|   annotations: "Annotations for the post (optional)" | ||||
| desktop/views/components/post-form-window.vue: | ||||
|   note: "New note" | ||||
|   note: "New Post" | ||||
|   reply: "Reply" | ||||
|   attaches: "{} media attached" | ||||
|   uploading-media: "Uploading {} media" | ||||
| @@ -589,9 +658,9 @@ desktop/views/components/renote-form.vue: | ||||
|   renote: "Repost" | ||||
|   reposting: "Reposting..." | ||||
|   success: "Reposted!" | ||||
|   failure: "Repost failed" | ||||
|   failure: "Failed to Repost" | ||||
| desktop/views/components/renote-form-window.vue: | ||||
|   title: "Are you sure you want to repost this?" | ||||
|   title: "Do you want to Repost it?" | ||||
| desktop/views/components/settings-window.vue: | ||||
|   settings: "Settings" | ||||
| desktop/views/components/settings.vue: | ||||
| @@ -609,8 +678,11 @@ desktop/views/components/settings.vue: | ||||
|   behaviour: "Behavior" | ||||
|   fetch-on-scroll: "Endless loading on scroll" | ||||
|   fetch-on-scroll-desc: "When you scroll down the page, it automatically fetches additional content." | ||||
|   note-visibility: "Post visibility" | ||||
|   default-note-visibility: "Default visibility" | ||||
|   remember-note-visibility: "Remember post visibility" | ||||
|   auto-popout: "Auto pop-out window" | ||||
|   auto-popout-desc: "Pops-out a newly opened window (onto a new tab), if possible. This setting is stored in the browser." | ||||
|   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." | ||||
|   advanced: "Advanced settings" | ||||
|   api-via-stream: "API request via stream" | ||||
|   api-via-stream-desc: "API request is performed via the WebSocket connection instead of native fetch API (for better performance). This setting is stored in the browser." | ||||
| @@ -620,13 +692,17 @@ desktop/views/components/settings.vue: | ||||
|   delete-wallpaper: "Remove background" | ||||
|   dark-mode: "Dark Mode" | ||||
|   circle-icons: "Use circle icons" | ||||
|   contrasted-acct: "Add contrast to username" | ||||
|   gradient-window-header: "Use gradients on window headers" | ||||
|   post-form-on-timeline: "Display post form at the top of the timeline" | ||||
|   suggest-recent-hashtags: "Show recent popular hashtags on the post form" | ||||
|   show-clock-on-header: "Show clock on upper-right" | ||||
|   show-reply-target: "Display reply target" | ||||
|   show-my-renotes: "Show my reposts in the timeline" | ||||
|   show-renoted-my-notes: "Show my posts that have been shared in the timeline" | ||||
|   show-maps: "Show the map" | ||||
|   show-maps-desc: "Automatically show the location on the map attached to this post." | ||||
|   show-my-renotes: "Show my renotes in the timeline" | ||||
|   show-renoted-my-notes: "Show renoted my posts in timelines" | ||||
|   show-local-renotes: "Show renoted local posts in timelines" | ||||
|   show-maps: "Display a map to show the location" | ||||
|   show-maps-desc: "If there comes a post contains location information, show a map to display the location." | ||||
|   sound: "Sound" | ||||
|   enable-sounds: "Enable sound" | ||||
|   enable-sounds-desc: "Play a sound when you receive a post/message. This setting is stored in the browser." | ||||
| @@ -671,26 +747,26 @@ desktop/views/components/settings.vue: | ||||
|   third-parties: "Third-parties" | ||||
| desktop/views/components/settings.2fa.vue: | ||||
|   intro: "If you set up 2-step verification, you will not only need a password at sign-in, but also a pre-registered physical device (such as your smartphone), which will improve security." | ||||
|   detail: "See details..." | ||||
|   detail: "Details…" | ||||
|   url: "https://www.google.com/landing/2step/" | ||||
|   caution: "If you lose access to your device, you won't be able to connect to Misskey anymore!" | ||||
|   caution: "If you lose access to your registered device, you won't be able to connect to Misskey anymore!" | ||||
|   register: "Register a device" | ||||
|   already-registered: "A device is already registered" | ||||
|   unregister: "Disable" | ||||
|   already-registered: "This device is already registered" | ||||
|   unregister: "Unregister" | ||||
|   unregistered: "Two-factor authentication has been disabled." | ||||
|   enter-password: "Enter the password" | ||||
|   authenticator: "First, you need to install Google Authenticator on your device:" | ||||
|   howtoinstall: "How to install" | ||||
|   scan: "And then, scan the QR code:" | ||||
|   done: "Please enter the token displaying on your device:" | ||||
|   done: "Please enter the token displayed on your device:" | ||||
|   submit: "Submit" | ||||
|   success: "Settings saved!" | ||||
|   failed: "Failed to setup. Please ensure that the token is correct." | ||||
|   info: "From now on, enter the token that is displayed on your device in addition to your password when signing-in to Misskey." | ||||
|   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." | ||||
| desktop/views/components/settings.api.vue: | ||||
|   intro: "To access the API, set this token as the key 'i' of request parameters." | ||||
|   caution: "Please do not show this token to third parties (do not enter it somewhere else other than here) otherwise your account could get compromised." | ||||
|   regeneration-of-token: "In the unlikely event that this token leaks out, you can regenerate it." | ||||
|   caution: "Do not enter this token to any apps nor tell this token to others otherwise your account may get compromised." | ||||
|   regeneration-of-token: "If your token gets leaked, you can regenerate it." | ||||
|   regenerate-token: "Regenerate the token" | ||||
|   token: "Token:" | ||||
|   enter-password: "Please enter the password" | ||||
| @@ -698,7 +774,7 @@ desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "No linked applications" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "Max" | ||||
|   in-use: " in use." | ||||
|   in-use: "In use" | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "No muted users" | ||||
| desktop/views/components/settings.password.vue: | ||||
| @@ -710,18 +786,18 @@ desktop/views/components/settings.password.vue: | ||||
|   changed: "Password updated" | ||||
| desktop/views/components/settings.profile.vue: | ||||
|   avatar: "Avatar" | ||||
|   choice-avatar: "Choose an image" | ||||
|   choice-avatar: "Select an image" | ||||
|   name: "Name" | ||||
|   location: "Location" | ||||
|   description: "Description" | ||||
|   birthday: "Birthday" | ||||
|   save: "Update profile" | ||||
|   locked-account: "Protect your account" | ||||
|   is-locked: "Make a note private" | ||||
|   is-locked: "Follow request needs approval" | ||||
|   other: "Other" | ||||
|   is-bot: "This account is a Bot" | ||||
|   is-cat: "This account is a Cat" | ||||
|   profile-updated: "Profile updated" | ||||
|   profile-updated: "Your profile has been updated" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "This post is private" | ||||
|   deleted: "This post has been deleted" | ||||
| @@ -734,10 +810,16 @@ desktop/views/components/timeline.vue: | ||||
|   local: "Local" | ||||
|   hybrid: "Social" | ||||
|   global: "Global" | ||||
|   mentions: "Mentions" | ||||
|   messages: "Messages" | ||||
|   list: "Lists" | ||||
|   hashtag: "Hashtag" | ||||
|   add-tag-timeline: "Add hashtag tl" | ||||
|   add-list: "Add list" | ||||
|   list-name: "List name" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "Welcome back," | ||||
|   adjective: "さん" | ||||
|   adjective: "-san" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "Your profile" | ||||
|   drive: "Media storage" | ||||
| @@ -745,6 +827,7 @@ desktop/views/components/ui.header.account.vue: | ||||
|   lists: "Lists" | ||||
|   follow-requests: "Follow requests" | ||||
|   customize: "Customize home layout" | ||||
|   admin: "Admin" | ||||
|   settings: "Settings" | ||||
|   signout: "Sign out" | ||||
|   dark: "Submerge in dark" | ||||
| @@ -765,7 +848,7 @@ desktop/views/components/received-follow-requests-window.vue: | ||||
|   reject: "Reject" | ||||
| desktop/views/components/user-lists-window.vue: | ||||
|   title: "User lists" | ||||
|   create-list: "Create new list" | ||||
|   create-list: "Create list" | ||||
|   list-name: "List name" | ||||
| desktop/views/components/user-preview.vue: | ||||
|   notes: "Posts" | ||||
| @@ -781,6 +864,34 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "Pop-out" | ||||
|   close: "Close" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
|   dashboard: "Dashboard" | ||||
|   drive: "Drive" | ||||
|   users: "Users" | ||||
|   update: "Updates" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   dashboard: "Dashboard" | ||||
|   all-users: "All Users" | ||||
|   original-users: "Users on this instance" | ||||
|   all-notes: "All the posts" | ||||
|   original-notes: "Posts on this instance" | ||||
|   invite: "Invite" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   suspend-user: "Suspend a user" | ||||
|   suspend: "Suspend" | ||||
|   suspended: "Successfully suspended." | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "Unsuspend users" | ||||
|   unsuspend: "Unsuspend" | ||||
|   unsuspended: "The user has successfully unsuspended." | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "User account verification settings" | ||||
|   verify: "Verify account" | ||||
|   verified: "The account is now being verified" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "User account unverification settings" | ||||
|   unverify: "Unverify account" | ||||
|   unverified: "The account is now being unverified" | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "Only media posts" | ||||
|   is-media-view: "Media view" | ||||
| @@ -789,15 +900,23 @@ desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "Reposted by {}" | ||||
|   private: "This post is private" | ||||
|   deleted: "This post has been deleted" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "All Users" | ||||
|   original-users: "Users on this instance" | ||||
|   all-notes: "All the posts" | ||||
|   original-notes: "Posts on this instance" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "More details..." | ||||
|   gotit: "Got it!" | ||||
|   signin: "Log In" | ||||
|   signup: "Sign up" | ||||
|   signin-button: "Log in" | ||||
|   signin-button: "Logging in..." | ||||
|   signup-button: "Sign up" | ||||
|   timeline: "Timeline" | ||||
|   announcements: "Announcements" | ||||
|   photos: "Recent uploaded" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
|   info: "Information" | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Misskey storage" | ||||
| desktop/views/pages/favorites.vue: | ||||
| @@ -805,35 +924,35 @@ desktop/views/pages/favorites.vue: | ||||
| desktop/views/pages/home-customize.vue: | ||||
|   title: "Customize home layout" | ||||
| desktop/views/pages/note.vue: | ||||
|   prev: "Previous note" | ||||
|   next: "Next note" | ||||
|   prev: "Previous post" | ||||
|   next: "Next post" | ||||
| desktop/views/pages/selectdrive.vue: | ||||
|   title: "Choose file(s)" | ||||
|   ok: "OK" | ||||
|   cancel: "Cancel" | ||||
|   upload: "Upload files from your device" | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "The search feature is not available." | ||||
|   not-available: "Search feature is turned off in the settings for this instance." | ||||
|   not-found: "No posts were found for '{}'" | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "Share with {}." | ||||
| desktop/views/pages/tag.vue: | ||||
|   no-posts-found: "No posts \"{}\" found." | ||||
|   no-posts-found: "No posts contains \"{}\" found." | ||||
| desktop/views/pages/user-list.users.vue: | ||||
|   users: "User" | ||||
|   add-user: "Add a user" | ||||
|   username: "Username" | ||||
| desktop/views/pages/user/user.followers-you-know.vue: | ||||
|   title: "Followers you know" | ||||
|   title: "Followers you may know" | ||||
|   loading: "Loading" | ||||
|   no-users: "No followers you know" | ||||
| desktop/views/pages/user/user.friends.vue: | ||||
|   title: "Frequent mentions" | ||||
|   loading: "Loading" | ||||
|   no-users: "No users" | ||||
|   no-users: "No frequent mentions" | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "This account has been suspended." | ||||
|   is-remote: "This user is a remote user, so the information about them that you see here is not complete. " | ||||
|   is-remote: "This profile belongs to a remote user. The profile that you see here may not be complete. " | ||||
|   view-remote: "See their complete profile" | ||||
| desktop/views/pages/user/user.home.vue: | ||||
|   last-used-at: "Last active:" | ||||
| @@ -850,7 +969,7 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   muted: "Muting" | ||||
|   unmute: "Unmute" | ||||
|   push-to-a-list: "Add to list" | ||||
|   list-pushed: "You added {user} to {list}." | ||||
|   list-pushed: "Successfully added {user} to {list}." | ||||
| desktop/views/pages/user/user.header.vue: | ||||
|   posts: "Notes" | ||||
|   following: "Following" | ||||
| @@ -858,18 +977,18 @@ desktop/views/pages/user/user.header.vue: | ||||
|   is-bot: "This account is a Bot" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "Posts" | ||||
|   with-replies: "Notes and replies" | ||||
|   with-replies: "Posts and replies" | ||||
|   with-media: "Media" | ||||
|   empty: "This user doesn't seem to have posted anything yet." | ||||
| desktop/views/widgets/messaging.vue: | ||||
|   title: "Messaging" | ||||
|   title: "Message" | ||||
| desktop/views/widgets/notifications.vue: | ||||
|   title: "Notifications" | ||||
|   settings: "Settings" | ||||
| desktop/views/widgets/polls.vue: | ||||
|   title: "Polls" | ||||
|   refresh: "refresh" | ||||
|   nothing: "Nothing" | ||||
|   nothing: "No polls found!" | ||||
| desktop/views/widgets/post-form.vue: | ||||
|   title: "Post" | ||||
|   note: "Post" | ||||
| @@ -879,11 +998,11 @@ desktop/views/widgets/profile.vue: | ||||
| desktop/views/widgets/trends.vue: | ||||
|   title: "Trend" | ||||
|   refresh: "refresh" | ||||
|   nothing: "Nothing" | ||||
|   nothing: "No trends found!" | ||||
| desktop/views/widgets/users.vue: | ||||
|   title: "Recommended users" | ||||
|   refresh: "refresh" | ||||
|   no-one: "No one" | ||||
|   no-one: "Anyone!" | ||||
| mobile/views/components/drive.vue: | ||||
|   drive: "Media storage" | ||||
|   used: "used" | ||||
| @@ -906,14 +1025,17 @@ mobile/views/components/drive-file-chooser.vue: | ||||
|   select-file: "Choose files" | ||||
| mobile/views/components/drive-folder-chooser.vue: | ||||
|   select-folder: "Choose a folder" | ||||
| mobile/views/components/drive.file.vue: | ||||
|   nsfw: "NSFW" | ||||
| mobile/views/components/drive.file-detail.vue: | ||||
|   download: "Download" | ||||
|   rename: "Rename" | ||||
|   move: "Move" | ||||
|   hash: "Hash (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "NSFW" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "The content is NSFW" | ||||
|   sensitive: "NSFW" | ||||
|   click-to-show: "Click to show" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "The content is NSFW" | ||||
| @@ -924,15 +1046,13 @@ mobile/views/components/follow-button.vue: | ||||
|   request-pending: "Pending follow request" | ||||
|   follow-request: "Follow request" | ||||
| mobile/views/components/friends-maker.vue: | ||||
|   title: "Let's follow users" | ||||
|   title: "Let's follow them" | ||||
|   empty: "Featured user was not found." | ||||
|   fetching: "Loading" | ||||
|   refresh: "See more" | ||||
|   close: "Close" | ||||
| mobile/views/components/note.vue: | ||||
|   reposted-by: "Reposted by {}" | ||||
|   more: "See more" | ||||
|   less: "Hide" | ||||
|   private: "This post is private" | ||||
|   deleted: "This post has been deleted" | ||||
|   location: "Location" | ||||
| @@ -955,7 +1075,7 @@ mobile/views/components/notes.vue: | ||||
|   failed: "Failed to load" | ||||
|   retry: "Retry" | ||||
| mobile/views/components/notifications.vue: | ||||
|   more: "More" | ||||
|   more: "See more" | ||||
|   empty: "No notifications" | ||||
| mobile/views/components/post-form.vue: | ||||
|   add-visible-user: "Add a user" | ||||
| @@ -964,7 +1084,7 @@ mobile/views/components/post-form.vue: | ||||
|   renote: "Renote" | ||||
|   quote-placeholder: "Quote this post... (optional)" | ||||
|   reply-placeholder: "Reply to this note..." | ||||
|   cw-placeholder: "Comments about content (optional)" | ||||
|   cw-placeholder: "Comments for the post (optional)" | ||||
|   location-alert: "Your device does not provide location services" | ||||
|   error: "Error" | ||||
|   username-prompt: "Enter user name" | ||||
| @@ -978,7 +1098,7 @@ mobile/views/components/timeline.vue: | ||||
|   load-more: "More" | ||||
| mobile/views/components/ui.header.vue: | ||||
|   welcome-back: "Welcome back, " | ||||
|   adjective: "さん" | ||||
|   adjective: "Sir" | ||||
| mobile/views/components/ui.nav.vue: | ||||
|   timeline: "Timeline" | ||||
|   notifications: "Notifications" | ||||
| @@ -990,12 +1110,13 @@ mobile/views/components/ui.nav.vue: | ||||
|   user-lists: "Lists" | ||||
|   widgets: "Widgets" | ||||
|   game: "Games" | ||||
|   darkmode: "Dark mode" | ||||
|   darkmode: "Dark theme" | ||||
|   settings: "Settings" | ||||
|   admin: "Admin" | ||||
|   about: "About Misskey" | ||||
| mobile/views/components/user-timeline.vue: | ||||
|   no-notes: "It seems this user hasn't posted anything yet." | ||||
|   no-notes-with-media: "There are no notes with media attachments" | ||||
|   no-notes-with-media: "There are no posts attaching media" | ||||
|   load-more: "More" | ||||
| mobile/views/components/users-list.vue: | ||||
|   all: "All" | ||||
| @@ -1005,12 +1126,12 @@ mobile/views/pages/favorites.vue: | ||||
|   title: "Favorites" | ||||
| mobile/views/pages/user-lists.vue: | ||||
|   title: "Lists" | ||||
|   enter-list-name: "Enter list name" | ||||
|   enter-list-name: "Enter a name of the list to make" | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "Drive" | ||||
|   more: "Load more" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "Let's start! 📦" | ||||
|   lets-start: "Your account is now ready! 📦" | ||||
| mobile/views/pages/followers.vue: | ||||
|   followers-of: "Followers of {}" | ||||
| mobile/views/pages/following.vue: | ||||
| @@ -1020,6 +1141,8 @@ mobile/views/pages/home.vue: | ||||
|   local: "Local" | ||||
|   hybrid: "Social" | ||||
|   global: "Global" | ||||
|   mentions: "Mentions" | ||||
|   messages: "Messages" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "No posts \"{}\" found." | ||||
| mobile/views/pages/welcome.vue: | ||||
| @@ -1060,6 +1183,9 @@ mobile/views/pages/settings/settings.profile.vue: | ||||
|   avatar: "Avatar" | ||||
|   banner: "Banner" | ||||
|   is-cat: "This account is a Cat" | ||||
|   is-locked: "Follow request needs approval" | ||||
|   advanced: "Advanced" | ||||
|   privacy: "Privacy" | ||||
|   save: "Update profile" | ||||
|   saved: "Profile updated" | ||||
|   uploading: "Uploading" | ||||
| @@ -1067,7 +1193,7 @@ mobile/views/pages/settings/settings.profile.vue: | ||||
| mobile/views/pages/search.vue: | ||||
|   search: "Search" | ||||
|   empty: "No posts were found for '{}'" | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
|   not-found: "No posts were found for \"{}\"." | ||||
| mobile/views/pages/selectdrive.vue: | ||||
|   select-file: "Choose files" | ||||
| mobile/views/pages/settings.vue: | ||||
| @@ -1079,19 +1205,27 @@ mobile/views/pages/settings.vue: | ||||
|   specify-language: "Select your language" | ||||
|   design: "Design and display" | ||||
|   dark-mode: "Dark Mode" | ||||
|   i-am-under-limited-internet: "I'm under limited internet" | ||||
|   i-am-under-limited-internet: "I'm in limited bandwidth" | ||||
|   circle-icons: "Use circle icons" | ||||
|   contrasted-acct: "Add contrast to username" | ||||
|   timeline: "Timeline" | ||||
|   show-reply-target: "Show reply target" | ||||
|   show-my-renotes: "Show my reposts" | ||||
|   show-renoted-my-notes: "Show my reposted posts" | ||||
|   show-renoted-my-notes: "Show renoted my posts" | ||||
|   show-local-renotes: "Show renoted local posts" | ||||
|   post-style: "Post design" | ||||
|   post-style-standard: "Standard" | ||||
|   post-style-smart: "Smart" | ||||
|   notification-position: "Notification style" | ||||
|   notification-position-bottom: "Bottom" | ||||
|   notification-position-top: "Top" | ||||
|   behavior: "Behavior" | ||||
|   fetch-on-scroll: "Endless loading on scroll" | ||||
|   note-visibility: "Post visibility" | ||||
|   default-note-visibility: "Default visibility" | ||||
|   remember-note-visibility: "Remember post visibility" | ||||
|   disable-via-mobile: "Don't mark the post as 'from mobile'" | ||||
|   load-raw-images: "Show attached images in high-quality" | ||||
|   load-raw-images: "Show attached images in original quality" | ||||
|   load-remote-media: "Show media from a remote server" | ||||
|   twitter: "Twitter integration" | ||||
|   twitter-connect: "Connect to your Twitter account" | ||||
| @@ -1108,17 +1242,19 @@ mobile/views/pages/settings.vue: | ||||
|   update-available-desc: "Updates will be applied after reloading the page" | ||||
|   settings: "Settings" | ||||
|   signout: "Sign out" | ||||
|   sound: "Sounds" | ||||
|   enable-sounds: "Enable sounds" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "Follows you" | ||||
|   following: "Following" | ||||
|   followers: "Followers" | ||||
|   notes: "Notes" | ||||
|   notes: "Posts" | ||||
|   overview: "Overview" | ||||
|   timeline: "Timeline" | ||||
|   media: "Media" | ||||
|   is-suspended: "This account has been suspended." | ||||
|   is-remote: "This user is a remote user, so the information you see here is not complete." | ||||
|   view-remote: "See their complete profile" | ||||
|   is-remote: "The user is a remote user. The profile that you see here may not complete." | ||||
|   view-remote: "See his/her complete profile" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "Recent notes" | ||||
|   images: "Images" | ||||
| @@ -1141,8 +1277,8 @@ mobile/views/pages/user/home.photos.vue: | ||||
|   loading: "Loading" | ||||
|   no-photos: "No photos" | ||||
| docs: | ||||
|   edit-this-page-on-github: "Did you find an error or do you want to contribute to the documentation? " | ||||
|   edit-this-page-on-github-link: "Edit this page on Github!" | ||||
|   edit-this-page-on-github: "Found a mistake or want to contribute for the documentation?" | ||||
|   edit-this-page-on-github-link: "Edit this page at GitHub!" | ||||
|   api: | ||||
|     entities: | ||||
|       properties: "Properties" | ||||
| @@ -1153,11 +1289,11 @@ docs: | ||||
|       require-credential: "This endpoint requires the authentication information." | ||||
|       require-permission: "This endpoint requires {permission} permission." | ||||
|       has-limit: "There is a rate limit." | ||||
|       duration-limit: "You can't request when a frequency of a request in during {duration} milliseconds exceeds {max} times." | ||||
|       min-interval-limit: "You can't request before {interval} milliseconds have passed since the previous request." | ||||
|       duration-limit: "If you have sent your requests more than {max} times in {duration} milliseconds, you will be unable to send more requests." | ||||
|       min-interval-limit: "If {interval} milliseconds haven't passed since the last request, you can't send a request." | ||||
|       show-src: "You can view the source code for this endpoint." | ||||
|       show-src-link: "See the code on GitHub" | ||||
|       generated: "This doc is generated by an API definition." | ||||
|       generated: "This document is generated by the API definition." | ||||
|     props: | ||||
|       name: "Name" | ||||
|       type: "Type" | ||||
| @@ -6,12 +6,25 @@ 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?" | ||||
|   intro: | ||||
|     title: "Misskeyって?" | ||||
|     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" | ||||
|     features: "特徴" | ||||
|     rich-contents: "投稿" | ||||
|     rich-contents-desc: "自分の考え、話題の出来事、皆と共有したいことについて発信してください。必要であれば、様々な構文を使って投稿を装飾したり、好きな画像、動画などのファイルやアンケートを添付することもできます。" | ||||
|     reaction: "リアクション" | ||||
|     reaction-desc: "あなたの気持ちを伝える最も簡単な方法です。Misskeyは、他のユーザーの投稿に様々なリアクションを付けることができます。いちどMisskeyのリアクション機能を体験してしまうと、もう「いいね」の概念しか存在しないSNSには戻れなくなるかもしれません。" | ||||
|     ui: "インターフェース" | ||||
|     ui-desc: "どのようなUIが使いやすいかは人それぞれです。だから、Misskeyは自由度の高いUIを持っています。レイアウトやデザインを調整したり、カスタマイズ可能な様々なウィジェットを配置したりして、自分だけのホームを作ってください。" | ||||
|     drive: "ドライブ" | ||||
|     drive-desc: "以前投稿したことのある画像をまた投稿したくなったことはありませんか?もしくは、アップロードしたファイルをフォルダ分けして整理したくなったことはありませんか?Misskeyの根幹に組み込まれたドライブ機能によってそれらが解決します。ファイルの共有も簡単です。" | ||||
|     outro: "他にもMisskeyにしかない機能はまだまだあるので、ぜひあなた自身の目で確かめてください。Misskeyは分散型SNSなので、このインスタンスが気に入らなければ他のインスタンスを試すこともできます。それでは、GLHF!" | ||||
|   adblock: | ||||
|     detected: "Por favor, desactive el bloqueador de publicidad." | ||||
|     warning: "<strong>Misskey no tiene anuncios publicitarios.</strong> Sin embargo, algunas características podrían no estar disponibles si el bloqueador de publicidad está habilitado." | ||||
|   application-authorization: "Autorizaciones de la aplicación." | ||||
|   close: "Cerrar" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   do-not-copy-paste: "Por favor no copies código aquí. Tu cuenta puede resultar comprometida." | ||||
|   got-it: "¡Listo!" | ||||
|   customization-tips: | ||||
|     title: "Consejos de personalización" | ||||
| @@ -58,7 +71,7 @@ common: | ||||
|     friday: "Viernes" | ||||
|     saturday: "Sábado" | ||||
|   reactions: | ||||
|     like: "me gusta" | ||||
|     like: "Me gusta" | ||||
|     love: "amor" | ||||
|     laugh: "risa" | ||||
|     hmm: "hmm" | ||||
| @@ -68,6 +81,15 @@ common: | ||||
|     confused: "confundido" | ||||
|     rip: "RIP" | ||||
|     pudding: "Chafado" | ||||
|   note-visibility: | ||||
|     public: "公開" | ||||
|     home: "ホーム" | ||||
|     home-desc: "ホームタイムラインにのみ公開" | ||||
|     followers: "フォロワー" | ||||
|     followers-desc: "自分のフォロワーにのみ公開" | ||||
|     specified: "ダイレクト" | ||||
|     specified-desc: "指定したユーザーにのみ公開" | ||||
|     private: "非公開" | ||||
|   note-placeholders: | ||||
|     a: "¿Qué haces?" | ||||
|     b: "¿Qué está pasando?" | ||||
| @@ -84,8 +106,15 @@ common: | ||||
|   my-token-regenerated: "Tu token se ha regenerado vas a ser desconectado." | ||||
|   i-like-sushi: "Prefiero sushi a pudín" | ||||
|   show-reversi-board-labels: "Mostrar etiquetas de filas y columnas en Reversi" | ||||
|   verified-user: "Usuario verificado" | ||||
|   use-contrast-reversi-stones: "Hacer el color de la piedra claro en Reversi" | ||||
|   verified-user: "Cuenta verificada" | ||||
|   disable-animated-mfm: "Desactivar texto animado en una publicación" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   show-full-acct: "ユーザー名のホストを省略しない" | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   do-not-use-in-production: 'Esto está en desarrollo, no usarlo para producción.' | ||||
|   reversi: | ||||
|     drawn: "Empatado" | ||||
|     my-turn: "Mi turno" | ||||
| @@ -126,7 +155,10 @@ common: | ||||
|     home: "Inicio" | ||||
|     local: "Local" | ||||
|     hybrid: "Social" | ||||
|     hashtag: "ハッシュタグ" | ||||
|     global: "Global" | ||||
|     mentions: "あなた宛て" | ||||
|     direct: "ダイレクト投稿" | ||||
|     notifications: "Notificaciones" | ||||
|     list: "Listado" | ||||
|     swap-left: "Desplazar a la izq." | ||||
| @@ -169,6 +201,9 @@ common/views/components/games/reversi/reversi.vue: | ||||
| common/views/components/games/reversi/reversi.game.vue: | ||||
|   surrender: "Rendirse" | ||||
|   surrendered: "Por rendirse" | ||||
|   is-llotheo: "El último gana (Llotheo)" | ||||
|   looped-map: "Mapa en bucle" | ||||
|   can-put-everywhere: "Puedes colocar donde quieras" | ||||
| common/views/components/games/reversi/reversi.index.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "¡Juega Reversi con tus amigos!" | ||||
| @@ -226,6 +261,12 @@ common/views/components/connect-failed.troubleshooter.vue: | ||||
|   success-desc: "Parece que la conexión ha sido posible. Por favor refresca la página." | ||||
|   flush: "Limpiar la memoria caché" | ||||
|   set-version: "Escoge la versión" | ||||
| common/views/components/media-banner.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "隠す" | ||||
|   show: "もっと見る" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "Encuentra un usuario" | ||||
|   you: "Tu" | ||||
| @@ -256,6 +297,8 @@ common/views/components/nav.vue: | ||||
|   develop: "Desarrolladores" | ||||
|   feedback: "Opiniones" | ||||
| common/views/components/note-menu.vue: | ||||
|   detail: "Detalles" | ||||
|   copy-link: "Copiar enlace" | ||||
|   favorite: "Me gusta esta nota" | ||||
|   pin: "Fijar en el perfil" | ||||
|   delete: "Borrar" | ||||
| @@ -284,7 +327,10 @@ common/views/components/signin.vue: | ||||
|   signin: "Entra" | ||||
|   or: "O" | ||||
|   signin-with-twitter: "Ingresar con Twitter" | ||||
|   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" | ||||
|   invitation-info: "Si no tienes un código de invitación, por favor contacta un <a href=\"{}\">administrador</a>." | ||||
|   username: "Usuario" | ||||
|   checking: "Comprobando..." | ||||
|   available: "Disponible" | ||||
| @@ -330,6 +376,9 @@ common/views/components/visibility-chooser.vue: | ||||
|   specified: "Directo" | ||||
|   specified-desc: "Publica solo para los seguidores que quieras" | ||||
|   private: "Privada" | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "Recuperando" | ||||
|   no-broadcasts: "Sin emisión" | ||||
| @@ -353,8 +402,6 @@ common/views/widgets/posts-monitor.vue: | ||||
|   toggle: "Alternar vistas" | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "Etiquetas" | ||||
|   count: "{} usuarios mencionados" | ||||
|   empty: "Ninguna tendencia popular ahora" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "Información del servidor" | ||||
|   toggle: "Alternar vistas" | ||||
| @@ -404,6 +451,7 @@ desktop: | ||||
|   uploading-avatar: "Cargando un nuevo avatar" | ||||
|   avatar-updated: "Avatar actualizado" | ||||
|   choose-avatar: "Escoge una imagen de avatar" | ||||
|   invalid-filetype: "Este tipo de archivo no es compatible aquí" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Negro ... Total" | ||||
|   notes: "Azul ... Notas" | ||||
| @@ -417,6 +465,28 @@ desktop/views/components/calendar.vue: | ||||
|   prev: "Mes anterior" | ||||
|   next: "Próximo mes" | ||||
|   go: "Click para navegar" | ||||
| desktop/views/components/charts.vue: | ||||
|   title: "Gráficos" | ||||
|   per-day: "por día" | ||||
|   per-hour: "por hora" | ||||
|   notes: "Publicaciones" | ||||
|   users: "Usuarios" | ||||
|   drive: "Unidad" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     notes: "Número de publicaciones: aumentar/disminuir (Combinado)" | ||||
|     local-notes: "Número de publicaciones: aumentar/disminuir (Local)" | ||||
|     remote-notes: "Número de publicaciones: aumentar/disminuir (Remoto)" | ||||
|     notes-total: "Número de publicaciones: Acumulativo total" | ||||
|     users: "Número de usuarios: aumentar/disminuir" | ||||
|     users-total: "Número de usuarios: Acumulativo total" | ||||
|     drive: "Capacidad de almacenamiento usada: aumentar/disminuir" | ||||
|     drive-total: "Capacidad de almacenamiento usada: Acumulativa total" | ||||
|     drive-files: "Número de archivos almacenados: aumentar/disminuir" | ||||
|     drive-files-total: "Número de archivos almacenados: Acumulativo total" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| desktop/views/components/choose-file-from-drive-window.vue: | ||||
|   choose-file: "Escoger archivos" | ||||
|   upload: "Cargar archivos de tu dispositivo" | ||||
| @@ -437,6 +507,7 @@ desktop/views/components/drive-window.vue: | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "Avatar" | ||||
|   banner: "Banner" | ||||
|   nsfw: "Ver más" | ||||
|   contextmenu: | ||||
|     rename: "Renombrar" | ||||
|     mark-as-sensitive: "Marcar como 'sensible'" | ||||
| @@ -488,31 +559,31 @@ 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: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
|   sensitive: "Este contenido no es apropiado para ver en el trabajo" | ||||
|   click-to-show: "Click para mostrar" | ||||
| desktop/views/components/follow-button.vue: | ||||
|   following: "Siguiendo" | ||||
|   follow: "Sigue" | ||||
|   request-pending: "Pendiente de aprobación" | ||||
|   follow-request: "フォロー申請" | ||||
|   follow-request: "Solicitud de seguir" | ||||
| desktop/views/components/followers-window.vue: | ||||
|   followers: "{} のフォロワー" | ||||
|   followers: "{} seguidores" | ||||
| desktop/views/components/followers.vue: | ||||
|   empty: "フォロワーはいないようです。" | ||||
|   empty: "Parece que no tienes seguidores aún." | ||||
| desktop/views/components/following-window.vue: | ||||
|   following: "{} のフォロー" | ||||
|   following: "Siguiendo {}" | ||||
| desktop/views/components/following.vue: | ||||
|   empty: "フォロー中のユーザーはいないようです。" | ||||
|   empty: "Parece que aún no sigues a nadie." | ||||
| desktop/views/components/friends-maker.vue: | ||||
|   title: "気になるユーザーをフォロー:" | ||||
|   empty: "おすすめのユーザーは見つかりませんでした。" | ||||
|   fetching: "読み込んでいます" | ||||
|   refresh: "もっと見る" | ||||
|   close: "閉じる" | ||||
|   title: "Usuarios recomendados:" | ||||
|   empty: "No se pudieron encontrar usuarios para recomendar" | ||||
|   fetching: "Cargando" | ||||
|   refresh: "Más" | ||||
|   close: "Cerrar" | ||||
| desktop/views/components/game-window.vue: | ||||
|   game: "リバーシ" | ||||
|   game: "Reversi" | ||||
| desktop/views/components/home.vue: | ||||
|   done: "完了" | ||||
|   done: "Listo" | ||||
|   add-widget: "Agregar accesorio:" | ||||
|   add: "Agregar" | ||||
| desktop/views/input-dialog.vue: | ||||
| @@ -538,8 +609,6 @@ desktop/views/components/notes.note.vue: | ||||
|   detail: "Mostrar detalles" | ||||
|   private: "Esta publicación es privada" | ||||
|   deleted: "Esta publicación ha sido borrada" | ||||
|   hide: "隠す" | ||||
|   see-more: "もっと見る" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "Error al cargar." | ||||
|   retry: "Reintentar" | ||||
| @@ -575,7 +644,7 @@ desktop/views/components/post-form.vue: | ||||
|   geolocation-alert: "Tu dispositivo no tiene soporte de geolocalización." | ||||
|   error: "Error" | ||||
|   enter-username: "Por favor escribe un nombre de usuario..." | ||||
|   annotations: "内容への注釈 (オプション)" | ||||
|   annotations: "Anotaciones a la publicación (opcional)" | ||||
| desktop/views/components/post-form-window.vue: | ||||
|   note: "Nota nueva" | ||||
|   reply: "Responder" | ||||
| @@ -609,6 +678,9 @@ desktop/views/components/settings.vue: | ||||
|   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." | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   auto-popout: "Ventana emergente automática" | ||||
|   auto-popout-desc: "Muestra una ventana emergente si es posible. Esta configuración depende del navegador." | ||||
|   advanced: "Configuración avanzada" | ||||
| @@ -620,11 +692,15 @@ desktop/views/components/settings.vue: | ||||
|   delete-wallpaper: "Suprimir fondo" | ||||
|   dark-mode: "Modo Nocturno" | ||||
|   circle-icons: "Usar iconos circulares" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   gradient-window-header: "Usar degradados en las cabeceras de las páginas" | ||||
|   post-form-on-timeline: "Mostrar el formulario de las entradas encima de la línea de tiempo" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||
|   show-renoted-my-notes: "Renoteされた自分の投稿をタイムラインに表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   show-maps-desc: "位置情報が添付された投稿のマップを自動的に展開します。" | ||||
|   sound: "サウンド" | ||||
| @@ -717,7 +793,7 @@ desktop/views/components/settings.profile.vue: | ||||
|   birthday: "Fecha de nacimiento" | ||||
|   save: "Perfil actualizado" | ||||
|   locked-account: "Protege tu cuenta" | ||||
|   is-locked: "Crear una nota privada" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
| @@ -734,41 +810,48 @@ desktop/views/components/timeline.vue: | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
|   list: "リスト" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
|   adjective: "さん" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "プロフィール" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
|   customize: "ホームのカスタマイズ" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   dark: "闇に飲まれる" | ||||
| desktop/views/components/ui.header.nav.vue: | ||||
|   home: "ホーム" | ||||
|   deck: "デッキ" | ||||
|   messaging: "メッセージ" | ||||
|   game: "ゲーム" | ||||
| desktop/views/components/ui.header.notifications.vue: | ||||
|   title: "通知" | ||||
| desktop/views/components/ui.header.post.vue: | ||||
|   post: "新規投稿" | ||||
| desktop/views/components/ui.header.search.vue: | ||||
|   placeholder: "検索" | ||||
| desktop/views/components/received-follow-requests-window.vue: | ||||
|   title: "フォロー申請" | ||||
|   accept: "承認" | ||||
|   reject: "拒否" | ||||
| desktop/views/components/user-lists-window.vue: | ||||
|   title: "リスト" | ||||
|   create-list: "リストを作成" | ||||
|   hashtag: "ハッシュタグ" | ||||
|   add-tag-timeline: "ハッシュタグを追加" | ||||
|   add-list: "リストを追加" | ||||
|   list-name: "リスト名" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "Bienvenido/a de vuelta," | ||||
|   adjective: "-san" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "Tu perfil" | ||||
|   drive: "Unidad" | ||||
|   favorites: "Favoritos" | ||||
|   lists: "Listas" | ||||
|   follow-requests: "Solicitudes de seguimiento" | ||||
|   customize: "Personalizar la página de inicio" | ||||
|   admin: "Admin" | ||||
|   settings: "Configuraciones" | ||||
|   signout: "Desconectarse" | ||||
|   dark: "Sumergirse en la oscuridad" | ||||
| desktop/views/components/ui.header.nav.vue: | ||||
|   home: "Inicio" | ||||
|   deck: "Cubierta" | ||||
|   messaging: "Mensajes" | ||||
|   game: "Juegos" | ||||
| desktop/views/components/ui.header.notifications.vue: | ||||
|   title: "Notificaciones" | ||||
| desktop/views/components/ui.header.post.vue: | ||||
|   post: "Crear una publicación" | ||||
| desktop/views/components/ui.header.search.vue: | ||||
|   placeholder: "Buscar" | ||||
| desktop/views/components/received-follow-requests-window.vue: | ||||
|   title: "Solicitudes de seguidores" | ||||
|   accept: "Aceptar" | ||||
|   reject: "Rechazar" | ||||
| desktop/views/components/user-lists-window.vue: | ||||
|   title: "Listas de usuario" | ||||
|   create-list: "Crear lista" | ||||
|   list-name: "Nombre de lista" | ||||
| desktop/views/components/user-preview.vue: | ||||
|   notes: "投稿" | ||||
|   notes: "Publicaciones" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
| desktop/views/components/users-list.vue: | ||||
| @@ -781,6 +864,34 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "ドライブ" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   invite: "招待" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "メディア投稿のみ" | ||||
|   is-media-view: "メディアビュー" | ||||
| @@ -789,6 +900,11 @@ desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "詳しく..." | ||||
|   gotit: "わかった" | ||||
| @@ -797,7 +913,10 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "やってる" | ||||
|   signup-button: "やる" | ||||
|   timeline: "タイムライン" | ||||
|   announcements: "お知らせ" | ||||
|   photos: "最近の画像" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
|   info: "情報" | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Misskey Drive" | ||||
| desktop/views/pages/favorites.vue: | ||||
| @@ -813,7 +932,7 @@ desktop/views/pages/selectdrive.vue: | ||||
|   cancel: "キャンセル" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "検索機能を利用することができません。" | ||||
|   not-available: "検索機能はインスタンスの設定で無効になっています。" | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "{}で共有" | ||||
| @@ -906,12 +1025,15 @@ mobile/views/components/drive-file-chooser.vue: | ||||
|   select-file: "ファイルを選択" | ||||
| mobile/views/components/drive-folder-chooser.vue: | ||||
|   select-folder: "フォルダーを選択" | ||||
| mobile/views/components/drive.file.vue: | ||||
|   nsfw: "閲覧注意" | ||||
| mobile/views/components/drive.file-detail.vue: | ||||
|   download: "ダウンロード" | ||||
|   rename: "名前を変更" | ||||
|   move: "移動" | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -931,8 +1053,6 @@ mobile/views/components/friends-maker.vue: | ||||
|   close: "閉じる" | ||||
| mobile/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   more: "もっと見る" | ||||
|   less: "隠す" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   location: "位置情報" | ||||
| @@ -992,6 +1112,7 @@ mobile/views/components/ui.nav.vue: | ||||
|   game: "ゲーム" | ||||
|   darkmode: "ダークモード" | ||||
|   settings: "設定" | ||||
|   admin: "管理" | ||||
|   about: "Misskeyについて" | ||||
| mobile/views/components/user-timeline.vue: | ||||
|   no-notes: "このユーザーは投稿していないようです。" | ||||
| @@ -1020,6 +1141,8 @@ mobile/views/pages/home.vue: | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| mobile/views/pages/welcome.vue: | ||||
| @@ -1060,6 +1183,9 @@ mobile/views/pages/settings/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
| @@ -1081,15 +1207,23 @@ mobile/views/pages/settings.vue: | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   timeline: "タイムライン" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteを表示する" | ||||
|   show-renoted-my-notes: "Renoteされた自分の投稿を表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteを表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteを表示する" | ||||
|   post-style: "投稿の表示スタイル" | ||||
|   post-style-standard: "標準" | ||||
|   post-style-smart: "スマート" | ||||
|   notification-position: "通知の表示" | ||||
|   notification-position-bottom: "下" | ||||
|   notification-position-top: "上" | ||||
|   behavior: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   load-raw-images: "添付された画像を高画質で表示する" | ||||
|   load-remote-media: "リモートサーバーのメディアを表示する" | ||||
| @@ -1108,6 +1242,8 @@ mobile/views/pages/settings.vue: | ||||
|   update-available-desc: "ページを再度読み込みすると更新が適用されます。" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   following: "フォロー" | ||||
| @@ -4,20 +4,33 @@ meta: | ||||
|   divider: "" | ||||
| common: | ||||
|   misskey: "Une ⭐ du fédiverse" | ||||
|   about-title: "Une ⭐ du fédiverse." | ||||
|   about: "Merci d'avoir découvert Misskey. Misskey est une <b>plateforme de micro-blogging distribuée</b> née sur Terre. Parce qu'il fait partie du Fédiverse (un univers composé de diverses plateformes de réseaux sociaux organisées), il est mutuellement connecté avec d'autres plateformes de réseaux sociaux. Désirez-vous prendre une pause, pendant un instant, loin de l'agitation de la ville et plonger dans un nouvel Internet ?" | ||||
|   about-title: "Une ⭐ du fédivers." | ||||
|   about: "Merci d'avoir découvert Misskey. Misskey est une <b>plateforme de microblogage distribuée</b> née sur Terre. Parce qu'il fait partie du Fédivers (un univers composé de diverses plateformes de réseaux sociaux organisées), il est mutuellement connecté avec d'autres plateformes de réseaux sociaux. Désirez-vous prendre une pause, pendant un instant, loin de l'agitation de la ville et plonger dans un nouvel Internet ?" | ||||
|   intro: | ||||
|     title: "C’est quoi Misskey ?" | ||||
|     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" | ||||
|     features: "Fonctionnalités" | ||||
|     rich-contents: "Notes" | ||||
|     rich-contents-desc: "自分の考え、話題の出来事、皆と共有したいことについて発信してください。必要であれば、様々な構文を使って投稿を装飾したり、好きな画像、動画などのファイルやアンケートを添付することもできます。" | ||||
|     reaction: "Réactions" | ||||
|     reaction-desc: "あなたの気持ちを伝える最も簡単な方法です。Misskeyは、他のユーザーの投稿に様々なリアクションを付けることができます。いちどMisskeyのリアクション機能を体験してしまうと、もう「いいね」の概念しか存在しないSNSには戻れなくなるかもしれません。" | ||||
|     ui: "Interface utilisateur" | ||||
|     ui-desc: "どのようなUIが使いやすいかは人それぞれです。だから、Misskeyは自由度の高いUIを持っています。レイアウトやデザインを調整したり、カスタマイズ可能な様々なウィジェットを配置したりして、自分だけのホームを作ってください。" | ||||
|     drive: "Drive" | ||||
|     drive-desc: "以前投稿したことのある画像をまた投稿したくなったことはありませんか?もしくは、アップロードしたファイルをフォルダ分けして整理したくなったことはありませんか?Misskeyの根幹に組み込まれたドライブ機能によってそれらが解決します。ファイルの共有も簡単です。" | ||||
|     outro: "他にもMisskeyにしかない機能はまだまだあるので、ぜひあなた自身の目で確かめてください。Misskeyは分散型SNSなので、このインスタンスが気に入らなければ他のインスタンスを試すこともできます。それでは、GLHF!" | ||||
|   adblock: | ||||
|     detected: "Veuillez désactiver le bloqueur de publicités" | ||||
|     detected: "Veuillez désactiver votre bloqueur de publicités" | ||||
|     warning: "<strong>Misskey n'utilise pas de publicités</strong>, mais quelques options peuvent être non disponibles ou fonctionneraient mal si un bloqueur de publicités est activé." | ||||
|   application-authorization: "Permissions de l'application" | ||||
|   close: "Fermer" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   do-not-copy-paste: "Veuillez ne pas entrer ou coller le code ici. Le compte peut être compromis." | ||||
|   got-it: "J'ai compris !" | ||||
|   customization-tips: | ||||
|     title: "Conseils de personnalisation" | ||||
|     paragraph1: "La personnalisation à la maison vous permet d'ajouter / supprimer, glisser et déposer et réorganiser les widgets." | ||||
|     paragraph2: "Vous pouvez changer l'affichage en <strong>cliquant droit</strong> sur certains widgets." | ||||
|     paragraph3: "Pour supprimer un widget, <strong>glissez et déposez le widget sur la zone étiquetée \"Corbeille\"</strong> dans l'en-tête." | ||||
|     paragraph3: "Pour supprimer un widget, <strong>glissez et déposez le widget sur la zone étiquetée « Corbeille »</strong> dans l'en-tête." | ||||
|     paragraph4: "Pour terminer la personnalisation, cliquez sur \"Terminer\" dans le coin supérieur droit." | ||||
|     gotit: "Compris!" | ||||
|   notification: | ||||
| @@ -30,7 +43,7 @@ common: | ||||
|     quoted-by: "Cité·e par {} :" | ||||
|   time: | ||||
|     unknown: "inconnu" | ||||
|     future: "future" | ||||
|     future: "à l'instant" | ||||
|     just_now: "à l'instant" | ||||
|     seconds_ago: "Il y a {} seconde·s" | ||||
|     minutes_ago: "Il y a {} minute·s" | ||||
| @@ -58,21 +71,30 @@ common: | ||||
|     friday: "Vendredi" | ||||
|     saturday: "Samedi" | ||||
|   reactions: | ||||
|     like: "Aime" | ||||
|     like: "J'aime" | ||||
|     love: "Adore" | ||||
|     laugh: "Rire" | ||||
|     hmm: "Hmm ... ?" | ||||
|     hmm: "Hmm … ?" | ||||
|     surprise: "Wow" | ||||
|     congrats: "Félicitations !" | ||||
|     angry: "En colère" | ||||
|     confused: "Confus" | ||||
|     rip: "RIP" | ||||
|     pudding: "Pudding" | ||||
|   note-visibility: | ||||
|     public: "Public" | ||||
|     home: "Accueil" | ||||
|     home-desc: "Publier sur le fil local uniquement" | ||||
|     followers: "Abonnés·es" | ||||
|     followers-desc: "Publier à vos abonnés·es uniquement" | ||||
|     specified: "Direct" | ||||
|     specified-desc: "Publier aux utilisateurs·trices mentionnés·es" | ||||
|     private: "Privé" | ||||
|   note-placeholders: | ||||
|     a: "Que faîtes vous maintenant ?" | ||||
|     a: "Que faites-vous maintenant ?" | ||||
|     b: "Quoi de neuf ?" | ||||
|     c: "Qu'avez-vous en tête ?" | ||||
|     d: "Voulez-vous exprimer quelque chose ?" | ||||
|     d: "Désirez-vous publier quelques mots ?" | ||||
|     e: "Écrivez ici" | ||||
|     f: "En attente de vos écrits" | ||||
|   search: "Recherche" | ||||
| @@ -82,10 +104,17 @@ common: | ||||
|   update-available-title: "Mise à jour disponible" | ||||
|   update-available: "Une nouvelle version de Misskey est disponible ({newer}, version actuelle: {current}). Veuillez recharger la page pour appliquer la mise à jour." | ||||
|   my-token-regenerated: "Votre token vient d'être généré, vous allez maintenant être déconnecté." | ||||
|   i-like-sushi: "Je préfère les sushis (au pudding)" | ||||
|   i-like-sushi: "Je préfère les sushis plutôt que le pudding" | ||||
|   show-reversi-board-labels: "Afficher les étiquettes des lignes et colonnes dans Reversi" | ||||
|   verified-user: "Utilisateur·trice vérifié·e" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   verified-user: "Compte vérifié" | ||||
|   disable-animated-mfm: "Désactiver les textes animés dans les publications" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   show-full-acct: "ユーザー名のホストを省略しない" | ||||
|   reduce-motion: "Réduire les animations dans l’interface utilisateur" | ||||
|   this-setting-is-this-device-only: "Uniquement sur cet appareil" | ||||
|   do-not-use-in-production: 'Il s’agit d’une version de développement. Ne pas utiliser dans un environnement de production.' | ||||
|   reversi: | ||||
|     drawn: "Partie nulle" | ||||
|     my-turn: "C’est votre tour" | ||||
| @@ -101,18 +130,18 @@ common: | ||||
|     analog-clock: "Horloge analogique" | ||||
|     profile: "Profil" | ||||
|     calendar: "Calendrier" | ||||
|     timemachine: "Calendrier (Machine de temps)" | ||||
|     timemachine: "Calendrier (Machine temporelle)" | ||||
|     activity: "Activité" | ||||
|     rss: "Lecteur de flux RSS" | ||||
|     memo: "Pense-bête" | ||||
|     trends: "Tendances" | ||||
|     photo-stream: "Flux de photos" | ||||
|     posts-monitor: "Graph des publications" | ||||
|     posts-monitor: "Graphe des publications" | ||||
|     slideshow: "Diaporama" | ||||
|     version: "Version" | ||||
|     broadcast: "Diffusion" | ||||
|     notifications: "Notifications" | ||||
|     users: "Utilisateurs" | ||||
|     users: "Utilisateur·rice·s" | ||||
|     polls: "Sondages" | ||||
|     post-form: "Formulaire de publication" | ||||
|     messaging: "Messagerie" | ||||
| @@ -126,7 +155,10 @@ common: | ||||
|     home: "Accueil" | ||||
|     local: "Local" | ||||
|     hybrid: "Social" | ||||
|     hashtag: "ハッシュタグ" | ||||
|     global: "Global" | ||||
|     mentions: "Mentions" | ||||
|     direct: "ダイレクト投稿" | ||||
|     notifications: "Notifications" | ||||
|     list: "Liste" | ||||
|     swap-left: "Déplacer à gauche" | ||||
| @@ -169,18 +201,21 @@ common/views/components/games/reversi/reversi.vue: | ||||
| common/views/components/games/reversi/reversi.game.vue: | ||||
|   surrender: "Se rendre" | ||||
|   surrendered: "Par abandon" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "Carte en boucle" | ||||
|   can-put-everywhere: "Peut poser partout" | ||||
| common/views/components/games/reversi/reversi.index.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "Jouer à Reversi avec vos amis·es !" | ||||
|   sub-title: "Jouer à Reversi avec vos ami·e·s !" | ||||
|   invite: "Inviter" | ||||
|   rule: "Comment Jouer ?" | ||||
|   rule: "Comment jouer ?" | ||||
|   rule-desc: "リバーシは、相手と交互に石をボードに置いて、相手の石を挟んで自分の色に変えてゆき、最終的に残った石が多い方が勝ちというボードゲームです。" | ||||
|   mode-invite: "Inviter" | ||||
|   mode-invite-desc: "Inviter un joueur." | ||||
|   mode-invite-desc: "Inviter un·e joueur·se." | ||||
|   invitations: "Vous avez reçu une invitation !" | ||||
|   my-games: "Mes jeux" | ||||
|   all-games: "Tous les jeux" | ||||
|   enter-username: "Saisir un nom d'utilisateur" | ||||
|   enter-username: "Saisir un nom d'utilisateur·rice" | ||||
|   game-state: | ||||
|     ended: "Terminée" | ||||
|     playing: "En cours" | ||||
| @@ -201,7 +236,7 @@ common/views/components/games/reversi/reversi.room.vue: | ||||
|   waiting-for-both: "En attente que vous soyez prêt" | ||||
|   cancel: "Annuler" | ||||
|   ready: "Prêt" | ||||
|   cancel-ready: "Annuler \"Je suis prêt\"" | ||||
|   cancel-ready: "Annuler « Prêt »" | ||||
| common/views/components/connect-failed.vue: | ||||
|   title: "Échec de connexion au serveur" | ||||
|   description: "Il y a soit un problème avec votre connexion internet, soit le serveur est hors-ligne ou en maintenance. Veuillez {ressayer} plus tard." | ||||
| @@ -226,21 +261,27 @@ common/views/components/connect-failed.troubleshooter.vue: | ||||
|   success-desc: "Succès de la connexion au serveur de Misskey. Veuillez recharger la page." | ||||
|   flush: "Vider le cache" | ||||
|   set-version: "Choisissez une version" | ||||
| common/views/components/media-banner.vue: | ||||
|   sensitive: "Contenu sensible" | ||||
|   click-to-show: "Cliquer pour afficher" | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "Masquer" | ||||
|   show: "Voir plus" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "Trouver un utilisateur" | ||||
|   search-user: "Trouver un·e utilisateur·trice" | ||||
|   you: "Vous" | ||||
|   no-history: "Pas d'historique" | ||||
| common/views/components/messaging-room.vue: | ||||
|   empty: "Pas de conversations" | ||||
|   more: "Voir Plus" | ||||
|   more: "Voir plus" | ||||
|   no-history: "Il n'y a pas plus d'historique" | ||||
|   resize-form: "Faites glisser pour redimensionner" | ||||
|   new-message: "Nouveau message" | ||||
|   only-one-file-attached: "Un seul fichier uniquement peut être joint au message" | ||||
|   only-one-file-attached: "Un seul fichier peut être joint au message" | ||||
| common/views/components/messaging-room.form.vue: | ||||
|   input-message-here: "Tapez ici votre message" | ||||
|   send: "Envoyer" | ||||
|   attach-from-local: "Joindre un fichier depuis votre PC" | ||||
|   attach-from-local: "Joindre un fichier depuis votre ordinateur" | ||||
|   attach-from-drive: "Joindre un fichier depuis votre Drive" | ||||
|   only-one-file-attached: "Un seul fichier uniquement peut être joint au message" | ||||
| common/views/components/messaging-room.message.vue: | ||||
| @@ -248,23 +289,25 @@ common/views/components/messaging-room.message.vue: | ||||
|   deleted: "Ce message a été supprimé" | ||||
| common/views/components/nav.vue: | ||||
|   about: "À propos" | ||||
|   stats: "Stats" | ||||
|   status: "Status" | ||||
|   stats: "Statistiques" | ||||
|   status: "Statut" | ||||
|   wiki: "Wiki" | ||||
|   donors: "Donateurs" | ||||
|   repository: "Repo" | ||||
|   develop: "Développeurs" | ||||
|   donors: "Donateur·rice·s" | ||||
|   repository: "Dépôt" | ||||
|   develop: "Développeur·se·s" | ||||
|   feedback: "Remarques" | ||||
| common/views/components/note-menu.vue: | ||||
|   favorite: "Favorite this note" | ||||
|   pin: "Épingler sur votre profile" | ||||
|   detail: "Détails" | ||||
|   copy-link: "Copier le lien" | ||||
|   favorite: "Mettre cette note en favoris" | ||||
|   pin: "Épingler sur votre profil" | ||||
|   delete: "Supprimer" | ||||
|   delete-confirm: "Supprimer cette publication ?" | ||||
|   remote: "Afficher les note originale" | ||||
|   remote: "Afficher la note originale" | ||||
| common/views/components/poll.vue: | ||||
|   vote-to: "Voter pour '{}'" | ||||
|   vote-count: "{} votes" | ||||
|   total-users: "{} utilisateurs ont voté" | ||||
|   total-users: "{} utilisateur·rice·s ont voté·e·s" | ||||
|   vote: "Vote" | ||||
|   show-result: "Montrer les résultats" | ||||
|   voted: "Voté" | ||||
| @@ -277,31 +320,34 @@ common/views/components/poll-editor.vue: | ||||
| common/views/components/reaction-picker.vue: | ||||
|   choose-reaction: "Choisissez votre réaction" | ||||
| common/views/components/signin.vue: | ||||
|   username: "Nom d'utilisateur" | ||||
|   username: "Nom d'utilisateur·rice" | ||||
|   password: "Mot de passe" | ||||
|   token: "Token" | ||||
|   signing-in: "Connexion...." | ||||
|   signing-in: "Connexion…" | ||||
|   signin: "Se connecter" | ||||
|   or: "Ou" | ||||
|   signin-with-twitter: "Se connecter via Twitter" | ||||
|   login-failed: "Échec d'authentification. Veuillez vérifier que votre nom d'utilisateur et mot de passe sont corrects." | ||||
| common/views/components/signup.vue: | ||||
|   username: "Nom d'utilisateur" | ||||
|   checking: "Vérification" | ||||
|   invitation-code: "Code d’invitation" | ||||
|   invitation-info: "Si vous n’avez pas de code d’invitation, contactez un·e <a href=\"{}\">administrateur·rice</a>." | ||||
|   username: "Nom d'utilisateur·rice" | ||||
|   checking: "Vérification…" | ||||
|   available: "Disponible" | ||||
|   unavailable: "Non disponible" | ||||
|   error: "Erreur de réseau" | ||||
|   invalid-format: "Utilisez seulement des lettres, nombres et/ou -." | ||||
|   error: "Erreur du réseau" | ||||
|   invalid-format: "Vous pouvez utiliser des lettres, des nombres et _." | ||||
|   too-short: "Veuillez saisir au moins un caractère !" | ||||
|   too-long: "Veuillez entrer au maximum 20 caractères." | ||||
|   password: "Mot de Passe" | ||||
|   password-placeholder: "Nous recommendons au moins 8 caractères." | ||||
|   password: "Mot de passe" | ||||
|   password-placeholder: "Nous recommandons au moins 8 caractères." | ||||
|   weak-password: "Faible" | ||||
|   normal-password: "Moyen" | ||||
|   strong-password: "Fort" | ||||
|   retype: "Retapez" | ||||
|   retype-placeholder: "Confirmez votre mot de passe" | ||||
|   password-matched: "OK" | ||||
|   password-not-matched: "Les mots de passes ne correspondent pas." | ||||
|   password-not-matched: "Les mots de passe ne correspondent pas." | ||||
|   recaptcha: "Vérifier" | ||||
|   create: "Créer un compte" | ||||
|   some-error: "La création du compte a échoué. Veuillez réessayer." | ||||
| @@ -313,14 +359,14 @@ common/views/components/stream-indicator.vue: | ||||
|   reconnecting: "Reconnexion en cours" | ||||
|   connected: "Connecté" | ||||
| common/views/components/twitter-setting.vue: | ||||
|   description: "Si vous liez votre compte Twitter à votre compte Misskey, vous verrez ensuite votre compte Twitter s'afficher sur votre profile, vous aurez aussi la possibilité de vous connecter à Misskey en utilisant votre compte Twitter." | ||||
|   description: "Si vous liez votre compte Twitter à votre compte Misskey, vous verrez ensuite votre compte Twitter s'afficher sur votre profil, vous aurez aussi la possibilité de vous connecter à Misskey en utilisant votre compte Twitter." | ||||
|   connected-to: "Vous êtes connecté à ce compte Twitter" | ||||
|   detail: "Détails…" | ||||
|   reconnect: "Reconnecter" | ||||
|   reconnect: "Reconnexion" | ||||
|   connect: "Lier votre compte Twitter" | ||||
|   disconnect: "Déconnecter" | ||||
|   disconnect: "Déconnexion" | ||||
| common/views/components/uploader.vue: | ||||
|   waiting: "En attente" | ||||
|   waiting: "Veuillez patienter" | ||||
| common/views/components/visibility-chooser.vue: | ||||
|   public: "Public" | ||||
|   home: "Accueil" | ||||
| @@ -328,42 +374,43 @@ common/views/components/visibility-chooser.vue: | ||||
|   followers: "Abonné·e·s" | ||||
|   followers-desc: "Publier à vos abonné·e·s uniquement" | ||||
|   specified: "Direct" | ||||
|   specified-desc: "Publier aux utilisateurs·trices mentionné·es" | ||||
|   specified-desc: "Publier aux utilisateur·rice·s mentionné·e·s" | ||||
|   private: "Privé" | ||||
| common/views/components/trends.vue: | ||||
|   count: "{} utilisateurs·trices mentionnés·es" | ||||
|   empty: "Aucune tendance" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "Récuperation" | ||||
|   fetching: "Récupération" | ||||
|   no-broadcasts: "Aucune annonce" | ||||
|   have-a-nice-day: "Passez une bonne journée !" | ||||
|   next: "Suivant" | ||||
| common/views/widgets/calendar.vue: | ||||
|   year: "{} année" | ||||
|   month: "{} mois" | ||||
|   day: "{} jour" | ||||
|   year: "Année {}" | ||||
|   month: "Mois {}" | ||||
|   day: "Jour {}" | ||||
|   today: "Aujourd'hui :" | ||||
|   this-month: "Ce mois-ci :" | ||||
|   this-year: "Cette année :" | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "Dons" | ||||
|   title: "Faire un don" | ||||
|   text: "Les frais pour faire fonctionner Misskey sortent directement de notre poche. Nous ne recevons pas d'argent issu de la publicité, si vous pouvez nous faire des dons, on vous serait éternellement reconnaissants. Si vous êtes intéressé·es veuillez contacter {}. Merci pour votre contribution !" | ||||
| common/views/widgets/photo-stream.vue: | ||||
|   title: "Flux de photo" | ||||
|   no-photos: "Pas de photos" | ||||
|   title: "Flux de photos" | ||||
|   no-photos: "Pas de photo" | ||||
| common/views/widgets/posts-monitor.vue: | ||||
|   title: "Graph des publications" | ||||
|   title: "Graphe des publications" | ||||
|   toggle: "Basculer entre les vues" | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "Étiquettes" | ||||
|   count: "{} utilisateurs mentionnés" | ||||
|   empty: "Aucune tendance" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "Info sur le serveur" | ||||
|   title: "Informations sur le serveur" | ||||
|   toggle: "Afficher les vues" | ||||
| common/views/widgets/memo.vue: | ||||
|   title: "Pense-bête" | ||||
|   memo: "Écrivez ici !" | ||||
|   save: "Enregistrer" | ||||
| common/views/widgets/slideshow.vue: | ||||
|   folder-customize-mode: "Veuillez quitter le mode personnalisé pour pouvour spécifier un dossier" | ||||
|   folder-customize-mode: "Pour pouvoir spécifier un dossier, veuillez quitter le mode de personnalisation" | ||||
|   folder: "Veuillez cliquer pour spécifier le dossier" | ||||
|   no-image: "Il n'y a aucune image dans ce dossier" | ||||
| common/views/widgets/tips.vue: | ||||
| @@ -371,55 +418,78 @@ common/views/widgets/tips.vue: | ||||
|   tips-line2: "<kbd>p</kbd>または<kbd>n</kbd>で投稿フォームを開きます" | ||||
|   tips-line3: "Vous pouvez glisser et déposer des fichiers sur la fenêtre de la note" | ||||
|   tips-line4: "Vous pouvez coller des images à partir du presse-papier sur la fenêtre de la note" | ||||
|   tips-line5: "Vous pouvez téléverser des fichiers sur le Drive en faisant un glisser/déplacer" | ||||
|   tips-line6: "ドライブでファイルをドラッグしてフォルダ移動できます" | ||||
|   tips-line5: "Vous pouvez téléverser des fichiers sur le Drive en faisant un glisser-déposer" | ||||
|   tips-line6: "Vous pouvez déplacer un dossier en le glissant dans le Drive" | ||||
|   tips-line7: "ドライブでフォルダをドラッグしてフォルダ移動できます" | ||||
|   tips-line8: "Vous pouvez personnaliser l'Accueil via les paramètres" | ||||
|   tips-line9: "Misskey est sous licence AGPLv3" | ||||
|   tips-line10: "タイムマシンウィジェットを利用すると、簡単に過去のタイムラインに遡れます" | ||||
|   tips-line11: "Vous pouvez épingler des notes sur votre page en appuyant sur \"…\"" | ||||
|   tips-line11: "Vous pouvez épingler des notes sur votre page en cliquant sur « … »" | ||||
|   tips-line13: "Tous les fichiers attachés à cette publication sont sauvegardés dans le Drive" | ||||
|   tips-line14: "ホームのカスタマイズ中、ウィジェットを右クリックしてデザインを変更できます" | ||||
|   tips-line17: "Vous pouvez mettre un texte en surbrillance en le mettant entre ** **" | ||||
|   tips-line19: "いくつかのウィンドウはブラウザの外に切り離すことができます" | ||||
|   tips-line20: "カレンダーウィジェットのパーセンテージは、経過の割合を示しています" | ||||
|   tips-line21: "Vous pouvez aussi utiliser l'API pour développer des Bots." | ||||
|   tips-line23: "まゆかわいいよまゆ" | ||||
|   tips-line23: "Mayu est mignone avec ses sourcils." | ||||
|   tips-line24: "Misskey a vu le jour en 2014" | ||||
|   tips-line25: "対応ブラウザではMisskeyを開いていなくても通知を受け取れます" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "Connecté·é en tant que {}" | ||||
|   signed-in-as: "Connecté·e en tant que {}" | ||||
|   following: "Suit" | ||||
|   follow: "Suivre" | ||||
|   request-pending: "Demande d'abonnement en attente" | ||||
|   follow-request: "Demande d'abonnement" | ||||
| desktop: | ||||
|   banner-crop-title: "Découpez la partie qui apparaîtra comme une bannière" | ||||
|   banner-crop-title: "Découpez la partie qui apparaitra comme bannière" | ||||
|   banner: "Bannière" | ||||
|   uploading-banner: "Téléversement d'une nouvelle bannière" | ||||
|   banner-updated: "La bannière est mise à jour" | ||||
|   choose-banner: "Choisir une bannière" | ||||
|   avatar-crop-title: "Découpez la partie qui apparaîtra dans l'avatar" | ||||
|   avatar-crop-title: "Découpez la partie qui apparaitra comme avatar" | ||||
|   avatar: "Avatar" | ||||
|   uploading-avatar: "Téléversement du nouvel avatar" | ||||
|   avatar-updated: "L'avatar est mis à jour" | ||||
|   choose-avatar: "Choisir un avatar" | ||||
|   invalid-filetype: "この形式のファイルはサポートされていません" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Noirs ... Total" | ||||
|   notes: "Bleu ... Notes" | ||||
|   replies: "Rouge ... Réponses" | ||||
|   renotes: "Vert ... Partages" | ||||
| desktop/views/components/activity.vue: | ||||
|   title: "Activitié" | ||||
|   title: "Activité" | ||||
|   toggle: "Afficher les vues" | ||||
| desktop/views/components/calendar.vue: | ||||
|   title: "{1} / {2}" | ||||
|   prev: "Mois dernier" | ||||
|   next: "Mois prochain" | ||||
|   go: "Cliquer pour naviguer" | ||||
|   go: "Cliquez pour naviguer" | ||||
| desktop/views/components/charts.vue: | ||||
|   title: "Graphiques" | ||||
|   per-day: "par jour" | ||||
|   per-hour: "par heure" | ||||
|   notes: "Publications" | ||||
|   users: "Utilisateurs" | ||||
|   drive: "Drive" | ||||
|   network: "Réseau" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の累計" | ||||
|     users: "Nombre d’utilisateurs·trices : augmentation/diminution" | ||||
|     users-total: "Nombre total d’utilisateurs·trices : total cumulé" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の累計" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の累計" | ||||
|     network-requests: "Requêtes" | ||||
|     network-time: "Temps de réponse" | ||||
|     network-usage: "Traffic" | ||||
| desktop/views/components/choose-file-from-drive-window.vue: | ||||
|   choose-file: "Sélection de fichiers" | ||||
|   upload: "Téléverser des fichiers à partir de votre PC" | ||||
|   upload: "Téléverser des fichiers à partir de votre ordinateur" | ||||
|   cancel: "Annuler" | ||||
|   ok: "OK" | ||||
|   choose-prompt: "Choisir un fichier" | ||||
| @@ -437,6 +507,7 @@ desktop/views/components/drive-window.vue: | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "Avatar" | ||||
|   banner: "Bannière" | ||||
|   nsfw: "CW" | ||||
|   contextmenu: | ||||
|     rename: "Renommer" | ||||
|     mark-as-sensitive: "Marquer comme sensible" | ||||
| @@ -450,14 +521,14 @@ desktop/views/components/drive.file.vue: | ||||
|     add-app: "Ajouter une application" | ||||
|     rename-file: "Renommer le ficher" | ||||
|     input-new-file-name: "Entrer un nouveau nom" | ||||
|     copied: "Copied" | ||||
|     copied-url-to-clipboard: "L'URL a été copié dans le presse-papier" | ||||
|     copied: "Copié" | ||||
|     copied-url-to-clipboard: "L'URL a été copiée dans le presse-papier" | ||||
| desktop/views/components/drive.folder.vue: | ||||
|   unable-to-process: "L'opération n'a pas pu être complétée" | ||||
|   circular-reference-detected: "Le dossier de destination est un sous-dossier du dossier que vous souhaitez déplacer." | ||||
|   unhandled-error: "Erreur inconnue" | ||||
|   contextmenu: | ||||
|     move-to-this-folder: "Bouger dans ce dossier" | ||||
|     move-to-this-folder: "Déplacer dans ce dossier" | ||||
|     show-in-new-window: "Ouvrir dans une nouvelle fenêtre" | ||||
|     rename: "Renommer" | ||||
|     rename-folder: "Renommer le dossier" | ||||
| @@ -505,7 +576,7 @@ 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." | ||||
|   empty: "Impossible de trouver des utilisateurs·trices à recommander." | ||||
|   fetching: "Chargement" | ||||
|   refresh: "Plus" | ||||
|   close: "Fermer" | ||||
| @@ -538,8 +609,6 @@ desktop/views/components/notes.note.vue: | ||||
|   detail: "Afficher les détails" | ||||
|   private: "cette publication est privée" | ||||
|   deleted: "cette publication a été supprimée" | ||||
|   hide: "Masquer" | ||||
|   see-more: "Voir plus" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "Échec du chargement." | ||||
|   retry: "Réessayer" | ||||
| @@ -609,6 +678,9 @@ desktop/views/components/settings.vue: | ||||
|   behaviour: "Comportement" | ||||
|   fetch-on-scroll: "Chargement lors du défilement" | ||||
|   fetch-on-scroll-desc: "Chargement automatique du contenu lors du défilement de la page." | ||||
|   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" | ||||
|   auto-popout: "Fenêtre contextuelle automatique" | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   advanced: "Paramètres avancés" | ||||
| @@ -620,16 +692,20 @@ desktop/views/components/settings.vue: | ||||
|   delete-wallpaper: "Supprimer le fond d'écran" | ||||
|   dark-mode: "Mode nuit" | ||||
|   circle-icons: "Utiliser des icônes circulaires" | ||||
|   contrasted-acct: "Nom d’utilisateur contrasté" | ||||
|   gradient-window-header: "Utiliser les dégradés sur la barre de titre de la fenêtre" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   post-form-on-timeline: "Afficher le formulaire en haut du fil" | ||||
|   suggest-recent-hashtags: "Afficher les hashtags populaires dans le champs de saisie" | ||||
|   show-clock-on-header: "Afficher l'horloge à droite sur le coté supérieur" | ||||
|   show-reply-target: "Afficher les réponses" | ||||
|   show-my-renotes: "Afficher mes republications dans le fil" | ||||
|   show-renoted-my-notes: "Renoteされた自分の投稿をタイムラインに表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "Afficher la carte" | ||||
|   show-maps-desc: "位置情報が添付された投稿のマップを自動的に展開します。" | ||||
|   sound: "Son" | ||||
|   enable-sounds: "Activer le son" | ||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||
|   enable-sounds-desc: "Jouer un son lorsque vous recevez un message. Ce paramètre est sauvegardé dans le navigateur." | ||||
|   volume: "Volume" | ||||
|   test: "Test" | ||||
|   mobile: "Mobile" | ||||
| @@ -690,7 +766,7 @@ desktop/views/components/settings.2fa.vue: | ||||
| desktop/views/components/settings.api.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
|   regeneration-of-token: "万が一このトークンが漏れたりその可能性がある場合はトークンを再生成できます。" | ||||
|   regeneration-of-token: "Si votre jeton est compromis, vous pouvez le régénérer." | ||||
|   regenerate-token: "Regenerer le token" | ||||
|   token: "Jeton :" | ||||
|   enter-password: "Veuillez entrer le mot de passe" | ||||
| @@ -717,7 +793,7 @@ desktop/views/components/settings.profile.vue: | ||||
|   birthday: "Date de naissance" | ||||
|   save: "Mettre à jour le profil" | ||||
|   locked-account: "Protéger votre compte" | ||||
|   is-locked: "Rendre la note privée" | ||||
|   is-locked: "Demande d’abonnement en attente d’approbation" | ||||
|   other: "Autre" | ||||
|   is-bot: "Ce compte est un Bot" | ||||
|   is-cat: "Ce compte est un Chat" | ||||
| @@ -734,7 +810,13 @@ desktop/views/components/timeline.vue: | ||||
|   local: "Local" | ||||
|   hybrid: "Social" | ||||
|   global: "Global" | ||||
|   mentions: "Mentions" | ||||
|   messages: "メッセージ" | ||||
|   list: "Listes" | ||||
|   hashtag: "ハッシュタグ" | ||||
|   add-tag-timeline: "ハッシュタグを追加" | ||||
|   add-list: "リストを追加" | ||||
|   list-name: "リスト名" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "Content de vous revoir !" | ||||
|   adjective: "さん" | ||||
| @@ -745,6 +827,7 @@ desktop/views/components/ui.header.account.vue: | ||||
|   lists: "Listes" | ||||
|   follow-requests: "Demandes de suivi" | ||||
|   customize: "Personnaliser l'Accueil" | ||||
|   admin: "Admin" | ||||
|   settings: "Réglages" | ||||
|   signout: "Déconnexion" | ||||
|   dark: "Fall in dark" | ||||
| @@ -781,6 +864,34 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "Fermer" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
|   dashboard: "Tableau de bord" | ||||
|   drive: "Drive" | ||||
|   users: "Utilisateur·rice·s" | ||||
|   update: "Mises à jour" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   dashboard: "Tableau de bord" | ||||
|   all-users: "Toutes les utilisateurrices" | ||||
|   original-users: "Utilisateurrices sur cette instance" | ||||
|   all-notes: "Toutes les publications" | ||||
|   original-notes: "Publication sur cette instance" | ||||
|   invite: "Invitation" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   suspend-user: "Suspendre un·e utilisateur·rice" | ||||
|   suspend: "Suspendre" | ||||
|   suspended: "Suspendu avec succès" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "Lever la suspension d’utilisateur·rice·s" | ||||
|   unsuspend: "Suspension levée" | ||||
|   unsuspended: "La suspension de l’utilisateur·rice a été levée avec succès" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "Paramètres de vérification du compte utilisateur" | ||||
|   verify: "Vérification du compte" | ||||
|   verified: "Le compte a été vérifié" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "Ôter la vérification du compte" | ||||
|   unverified: "Ce compte n'est pas vérifié" | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "Les publications médias uniquement" | ||||
|   is-media-view: "Vue média" | ||||
| @@ -789,6 +900,11 @@ desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "Reposté par {}" | ||||
|   private: "cette publication est privée" | ||||
|   deleted: "cette publication a été supprimée" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "Toutes les utilisateurrices" | ||||
|   original-users: "Utilisateurrices sur cette instance" | ||||
|   all-notes: "Toutes les publications" | ||||
|   original-notes: "Publication sur cette instance" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "à propos" | ||||
|   gotit: "J'ai compris !" | ||||
| @@ -797,7 +913,10 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "Se connecter" | ||||
|   signup-button: "S'inscrire" | ||||
|   timeline: "Fil d'actualité" | ||||
|   announcements: "Notices" | ||||
|   photos: "Images récentes" | ||||
|   powered-by-misskey: "Propulsé par <b>Misskey</b>." | ||||
|   info: "Informations" | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Lecteur de Misskey" | ||||
| desktop/views/pages/favorites.vue: | ||||
| @@ -813,12 +932,12 @@ desktop/views/pages/selectdrive.vue: | ||||
|   cancel: "Annuler" | ||||
|   upload: "Uploader un ou plusieurs fichier(s) depuis votre PC" | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "Vous ne pouvez pas utiliser la fonctionnalité de recherche." | ||||
|   not-available: "検索機能はインスタンスの設定で無効になっています。" | ||||
|   not-found: "Aucun message trouvé pour '{}'" | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "Partager avec {}" | ||||
| desktop/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
|   no-posts-found: "Pas de message avec un hashtag {} trouvé." | ||||
| desktop/views/pages/user-list.users.vue: | ||||
|   users: "Utilisateurs" | ||||
|   add-user: "Ajouter un utilisateur" | ||||
| @@ -843,7 +962,7 @@ desktop/views/pages/user/user.photos.vue: | ||||
|   no-photos: "Pas de photos" | ||||
| desktop/views/pages/user/user.profile.vue: | ||||
|   follows-you: "Vous suis" | ||||
|   stalk: "ストークする" | ||||
|   stalk: "Traquer" | ||||
|   stalking: "ストーキングしています" | ||||
|   unstalk: "ストーク解除" | ||||
|   mute: "Mettre en sourdine" | ||||
| @@ -893,11 +1012,11 @@ mobile/views/components/drive.vue: | ||||
|   load-more: "Charger plus" | ||||
|   nothing-in-drive: "Rien" | ||||
|   folder-is-empty: "Ce dossier est vide" | ||||
|   prompt: "何をしますか?(数字を入力してください): <1 → ファイルをアップロード | 2 → ファイルをURLでアップロード | 3 → フォルダ作成 | 4 → このフォルダ名を変更 | 5 → このフォルダを移動 | 6 → このフォルダを削除>" | ||||
|   prompt: "Que veux-tu faire ? (Entrez un nombre): <1 → Télécharger le fichier | 2 → Télécharger le fichier avec l'URL | 3 → Créer le dossier | 4 → Modifier le nom du dossier | 5 → Déplacer ce dossier | 6 → Supprimer ce dossier >" | ||||
|   deletion-alert: "Désolé ! La suppression d’un dossier n’est pas encore implémentée." | ||||
|   folder-name: "Nom du dossier" | ||||
|   root-rename-alert: "現在いる場所はルートで、フォルダではないため名前の変更はできません。名前を変更したいフォルダに移動してからやってください。" | ||||
|   root-move-alert: "現在いる場所はルートで、フォルダではないため移動はできません。移動したいフォルダに移動してからやってください。" | ||||
|   root-rename-alert: "L'emplacement actuel est la racine, pas le dossier, vous ne pouvez donc pas le renommer. Veuillez vous déplacer dans le dossier dont vous souhaitez modifier le nom." | ||||
|   root-move-alert: "L'emplacement actuel est la racine, ce n'est pas un dossier et il ne peut pas être déplacé. Veuillez vous déplacer dans le dossier que vous souhaitez déplacer." | ||||
|   url-prompt: "URL du fichier que vous souhaitez téléverser" | ||||
|   uploading: "アップロードをリクエストしました。アップロードが完了するまで時間がかかる場合があります。" | ||||
| mobile/views/components/drive-file-detail.vue: | ||||
| @@ -906,12 +1025,15 @@ mobile/views/components/drive-file-chooser.vue: | ||||
|   select-file: "Choisissez un fichier" | ||||
| mobile/views/components/drive-folder-chooser.vue: | ||||
|   select-folder: "Choisissez un dossier" | ||||
| mobile/views/components/drive.file.vue: | ||||
|   nsfw: "CW" | ||||
| mobile/views/components/drive.file-detail.vue: | ||||
|   download: "Télécharger" | ||||
|   rename: "Renommer" | ||||
|   move: "Déplacer" | ||||
|   hash: "Hash (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "CW" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "Le contenu est NSFW" | ||||
|   click-to-show: "Cliquer pour afficher" | ||||
| @@ -925,14 +1047,12 @@ mobile/views/components/follow-button.vue: | ||||
|   follow-request: "Demande d'abonnement" | ||||
| mobile/views/components/friends-maker.vue: | ||||
|   title: "Abonnez-vous aux utilisateurs" | ||||
|   empty: "Impossible de trouver des utilisateurs à recommander." | ||||
|   empty: "Impossible de trouver des utilisateurs·trices à recommander." | ||||
|   fetching: "Chargement" | ||||
|   refresh: "Voir plus" | ||||
|   close: "Fermer" | ||||
| mobile/views/components/note.vue: | ||||
|   reposted-by: "Renoté par {}" | ||||
|   more: "Voir plus" | ||||
|   less: "Masquer" | ||||
|   private: "cette publication est privée" | ||||
|   deleted: "cette publication a été supprimée" | ||||
|   location: "Géolocalisation" | ||||
| @@ -977,8 +1097,8 @@ mobile/views/components/timeline.vue: | ||||
|   empty: "Pas de notes" | ||||
|   load-more: "Afficher plus" | ||||
| mobile/views/components/ui.header.vue: | ||||
|   welcome-back: "Bon retour parmi nous !" | ||||
|   adjective: "さん" | ||||
|   welcome-back: "Content de vous revoir ! " | ||||
|   adjective: "M." | ||||
| mobile/views/components/ui.nav.vue: | ||||
|   timeline: "Fil d'actualité" | ||||
|   notifications: "Notifications" | ||||
| @@ -992,6 +1112,7 @@ mobile/views/components/ui.nav.vue: | ||||
|   game: "Jeux" | ||||
|   darkmode: "Mode nuit" | ||||
|   settings: "Réglages" | ||||
|   admin: "Admin" | ||||
|   about: "À propose de Misskey" | ||||
| mobile/views/components/user-timeline.vue: | ||||
|   no-notes: "Cette utilisateur semble n'avoir rien poster pour le moment" | ||||
| @@ -1020,8 +1141,10 @@ mobile/views/pages/home.vue: | ||||
|   local: "Local" | ||||
|   hybrid: "Social" | ||||
|   global: "Global" | ||||
|   mentions: "Mentions" | ||||
|   messages: "メッセージ" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
|   no-posts-found: "Pas de message avec un hashtag {} trouvé." | ||||
| mobile/views/pages/welcome.vue: | ||||
|   signup: "S'enregistrer" | ||||
| mobile/views/pages/widgets.vue: | ||||
| @@ -1060,6 +1183,9 @@ mobile/views/pages/settings/settings.profile.vue: | ||||
|   avatar: "Avatar" | ||||
|   banner: "Bannière" | ||||
|   is-cat: "Ce compte est un Bot" | ||||
|   is-locked: "Demande d’abonnement en attente d’approbation" | ||||
|   advanced: "Avancé" | ||||
|   privacy: "Vie privée" | ||||
|   save: "Mettre à jour le profil" | ||||
|   saved: "Profil mis à jour avec succès" | ||||
|   uploading: "En cours d'envoi" | ||||
| @@ -1067,7 +1193,7 @@ mobile/views/pages/settings/settings.profile.vue: | ||||
| mobile/views/pages/search.vue: | ||||
|   search: "Chercher" | ||||
|   empty: "Aucun message trouvé pour '{}' " | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
|   not-found: "Aucun post pour {} n'a été trouvé." | ||||
| mobile/views/pages/selectdrive.vue: | ||||
|   select-file: "Choisissez un fichier" | ||||
| mobile/views/pages/settings.vue: | ||||
| @@ -1081,15 +1207,23 @@ mobile/views/pages/settings.vue: | ||||
|   dark-mode: "Mode nuit" | ||||
|   i-am-under-limited-internet: "J'ai un accès Internet limité" | ||||
|   circle-icons: "Utiliser des icônes circulaires" | ||||
|   contrasted-acct: "Nom d’utilisateur contrasté" | ||||
|   timeline: "Fil d'actualité" | ||||
|   show-reply-target: "Afficher les réponses" | ||||
|   show-my-renotes: "Afficher mes republications" | ||||
|   show-renoted-my-notes: "Afficher les notes que j'ai repartagé" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteを表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteを表示する" | ||||
|   post-style: "Style de la publication" | ||||
|   post-style-standard: "Standard" | ||||
|   post-style-smart: "Intelligent" | ||||
|   notification-position: "Style de notification" | ||||
|   notification-position-bottom: "en bas" | ||||
|   notification-position-top: "en haut" | ||||
|   behavior: "Comportement" | ||||
|   fetch-on-scroll: "Chargement lors du défilement" | ||||
|   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" | ||||
|   disable-via-mobile: "Ne pas mentionner que ma publication provient d'un 'périphérique mobile'" | ||||
|   load-raw-images: "Afficher les photos jointes en haute qualité" | ||||
|   load-remote-media: "Afficher les médias sur le serveur distant" | ||||
| @@ -1108,6 +1242,8 @@ mobile/views/pages/settings.vue: | ||||
|   update-available-desc: "Les mises à jour seront appliquées une fois la page est rechargée." | ||||
|   settings: "Réglages" | ||||
|   signout: "Déconnexion" | ||||
|   sound: "Sons" | ||||
|   enable-sounds: "Activer les sons" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "vous suit" | ||||
|   following: "Abonnements" | ||||
| @@ -1150,14 +1286,14 @@ docs: | ||||
|       params: "Paramètres" | ||||
|       no-params: "Aucun paramètre" | ||||
|       res: "Réponse" | ||||
|       require-credential: "このエンドポイントは認証情報が必須です。" | ||||
|       require-permission: "このエンドポイントは{permission}の権限を必要とします。" | ||||
|       has-limit: "レートリミットがあります。" | ||||
|       require-credential: "Ce point de communication nécessite une authentification." | ||||
|       require-permission: "Ce point de communication nécessite la permission {permission}." | ||||
|       has-limit: "Il y’a un taux limite." | ||||
|       duration-limit: "直近{duration}ミリ秒の間のこのエンドポイントへのリクエスト数の合計が{max}を超える場合はリクエストできません。" | ||||
|       min-interval-limit: "前回のリクエストから{interval}ミリ秒経っていない場合はリクエストできません。" | ||||
|       show-src: "このエンドポイントのソースコードも閲覧できます。" | ||||
|       show-src: "Vous pouvez voir le code source ce point de communication." | ||||
|       show-src-link: "Consulter le code sur GitHub" | ||||
|       generated: "このドキュメントはAPI定義に基づき自動生成されています。" | ||||
|       generated: "Ce document est généré à partir de la définition de l’API." | ||||
|     props: | ||||
|       name: "Nom" | ||||
|       type: "Type" | ||||
| @@ -5,23 +5,9 @@ | ||||
| const fs = require('fs'); | ||||
| const yaml = require('js-yaml'); | ||||
|  | ||||
| const loadLang = lang => yaml.safeLoad( | ||||
| 	fs.readFileSync(`${__dirname}/${lang}.yml`, 'utf-8')); | ||||
| const langs = ['de-DE', 'en-US', 'fr-FR', 'ja-JP', 'ja-KS', 'pl-PL', 'es-ES', 'nl-NL']; | ||||
|  | ||||
| const native = loadLang('ja'); | ||||
| const loadLocale = lang => yaml.safeLoad(fs.readFileSync(`${__dirname}/${lang}.yml`, 'utf-8')); | ||||
| const locales = langs.map(lang => ({ [lang]: loadLocale(lang) })); | ||||
|  | ||||
| const langs = { | ||||
| 	'de': loadLang('de'), | ||||
| 	'en': loadLang('en'), | ||||
| 	'fr': loadLang('fr'), | ||||
| 	'ja': native, | ||||
| 	'pl': loadLang('pl'), | ||||
| 	'es': loadLang('es') | ||||
| }; | ||||
|  | ||||
| Object.values(langs).forEach(locale => { | ||||
| 	// Extend native language (Japanese) | ||||
| 	locale = Object.assign({}, native, locale); | ||||
| }); | ||||
|  | ||||
| module.exports = langs; | ||||
| module.exports = locales.reduce((a, b) => ({ ...a, ...b })); | ||||
|   | ||||
| @@ -6,6 +6,19 @@ common: | ||||
|   misskey: "A ⭐ of fediverse" | ||||
|   about-title: "A ⭐ of fediverse." | ||||
|   about: "Misskeyを見つけていただき、ありがとうございます。Misskeyは、地球で生まれた<b>分散マイクロブログSNS</b>です。Fediverse(様々なSNSで構成される宇宙)の中に存在するため、他のSNSと相互に繋がっています。暫し都会の喧騒から離れて、新しいインターネットにダイブしてみませんか。" | ||||
|   intro: | ||||
|     title: "Misskeyって?" | ||||
|     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" | ||||
|     features: "特徴" | ||||
|     rich-contents: "投稿" | ||||
|     rich-contents-desc: "自分の考え、話題の出来事、皆と共有したいことについて発信してください。必要であれば、様々な構文を使って投稿を装飾したり、好きな画像、動画などのファイルやアンケートを添付することもできます。" | ||||
|     reaction: "リアクション" | ||||
|     reaction-desc: "あなたの気持ちを伝える最も簡単な方法です。Misskeyは、他のユーザーの投稿に様々なリアクションを付けることができます。いちどMisskeyのリアクション機能を体験してしまうと、もう「いいね」の概念しか存在しないSNSには戻れなくなるかもしれません。" | ||||
|     ui: "インターフェース" | ||||
|     ui-desc: "どのようなUIが使いやすいかは人それぞれです。だから、Misskeyは自由度の高いUIを持っています。レイアウトやデザインを調整したり、カスタマイズ可能な様々なウィジェットを配置したりして、自分だけのホームを作ってください。" | ||||
|     drive: "ドライブ" | ||||
|     drive-desc: "以前投稿したことのある画像をまた投稿したくなったことはありませんか?もしくは、アップロードしたファイルをフォルダ分けして整理したくなったことはありませんか?Misskeyの根幹に組み込まれたドライブ機能によってそれらが解決します。ファイルの共有も簡単です。" | ||||
|     outro: "他にもMisskeyにしかない機能はまだまだあるので、ぜひあなた自身の目で確かめてください。Misskeyは分散型SNSなので、このインスタンスが気に入らなければ他のインスタンスを試すこともできます。それでは、GLHF!" | ||||
|   adblock: | ||||
|     detected: "広告ブロッカーを無効にしてください" | ||||
|     warning: "<strong>Misskeyは広告を掲載していません</strong>が、広告をブロックする機能が有効だと一部の機能が利用できなかったり、不具合が発生する場合があります。" | ||||
| @@ -68,6 +81,15 @@ common: | ||||
|     confused: "こまこまのこまり" | ||||
|     rip: "RIP" | ||||
|     pudding: "Pudding" | ||||
|   note-visibility: | ||||
|     public: "公開" | ||||
|     home: "ホーム" | ||||
|     home-desc: "ホームタイムラインにのみ公開" | ||||
|     followers: "フォロワー" | ||||
|     followers-desc: "自分のフォロワーにのみ公開" | ||||
|     specified: "ダイレクト" | ||||
|     specified-desc: "指定したユーザーにのみ公開" | ||||
|     private: "非公開" | ||||
|   note-placeholders: | ||||
|     a: "今どうしてる?" | ||||
|     b: "何かありましたか?" | ||||
| @@ -84,8 +106,15 @@ common: | ||||
|   my-token-regenerated: "あなたのトークンが更新されたのでサインアウトします。" | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   verified-user: "認証済みのユーザー" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   verified-user: "公式アカウント" | ||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   show-full-acct: "ユーザー名のホストを省略しない" | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
| @@ -126,7 +155,10 @@ common: | ||||
|     home: "ホーム" | ||||
|     local: "ローカル" | ||||
|     hybrid: "ソーシャル" | ||||
|     hashtag: "ハッシュタグ" | ||||
|     global: "グローバル" | ||||
|     mentions: "あなた宛て" | ||||
|     direct: "ダイレクト投稿" | ||||
|     notifications: "通知" | ||||
|     list: "リスト" | ||||
|     swap-left: "左に移動" | ||||
| @@ -169,6 +201,9 @@ common/views/components/games/reversi/reversi.vue: | ||||
| common/views/components/games/reversi/reversi.game.vue: | ||||
|   surrender: "投了" | ||||
|   surrendered: "投了により" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
| common/views/components/games/reversi/reversi.index.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "他のMisskeyユーザーとリバーシで対戦しよう" | ||||
| @@ -226,6 +261,12 @@ common/views/components/connect-failed.troubleshooter.vue: | ||||
|   success-desc: "正常に接続できるようです。ページを再度読み込みしてください。" | ||||
|   flush: "キャッシュの削除" | ||||
|   set-version: "バージョン指定" | ||||
| common/views/components/media-banner.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "隠す" | ||||
|   show: "もっと見る" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "ユーザーを探す" | ||||
|   you: "あなた" | ||||
| @@ -256,6 +297,8 @@ common/views/components/nav.vue: | ||||
|   develop: "開発者" | ||||
|   feedback: "フィードバック" | ||||
| common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   pin: "ピン留め" | ||||
|   delete: "削除" | ||||
| @@ -284,7 +327,10 @@ common/views/components/signin.vue: | ||||
|   signin: "サインイン" | ||||
|   or: "または" | ||||
|   signin-with-twitter: "Twitterでログイン" | ||||
|   login-failed: "ログインできませんでした。ユーザー名とパスワードを確認してください。" | ||||
| common/views/components/signup.vue: | ||||
|   invitation-code: "招待コード" | ||||
|   invitation-info: "招待コードをお持ちでない方は、<a href=\"{}\">管理者</a>までご連絡ください。" | ||||
|   username: "ユーザー名" | ||||
|   checking: "確認しています..." | ||||
|   available: "利用できます" | ||||
| @@ -330,6 +376,9 @@ common/views/components/visibility-chooser.vue: | ||||
|   specified: "ダイレクト" | ||||
|   specified-desc: "指定したユーザーにのみ公開" | ||||
|   private: "非公開" | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "確認中" | ||||
|   no-broadcasts: "お知らせはありません" | ||||
| @@ -353,8 +402,6 @@ common/views/widgets/posts-monitor.vue: | ||||
|   toggle: "表示を切り替え" | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "ハッシュタグ" | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "サーバー情報" | ||||
|   toggle: "表示を切り替え" | ||||
| @@ -404,6 +451,7 @@ desktop: | ||||
|   uploading-avatar: "新しいアバターをアップロードしています" | ||||
|   avatar-updated: "アバターを更新しました" | ||||
|   choose-avatar: "アバターにする画像を選択" | ||||
|   invalid-filetype: "この形式のファイルはサポートされていません" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Black ... Total" | ||||
|   notes: "Blue ... Notes" | ||||
| @@ -417,6 +465,28 @@ desktop/views/components/calendar.vue: | ||||
|   prev: "前の月" | ||||
|   next: "次の月" | ||||
|   go: "クリックして時間遡行" | ||||
| desktop/views/components/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の累計" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの累計" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の累計" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の累計" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| desktop/views/components/choose-file-from-drive-window.vue: | ||||
|   choose-file: "ファイル選択中" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| @@ -437,6 +507,7 @@ desktop/views/components/drive-window.vue: | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   nsfw: "閲覧注意" | ||||
|   contextmenu: | ||||
|     rename: "名前を変更" | ||||
|     mark-as-sensitive: "閲覧注意に設定" | ||||
| @@ -538,8 +609,6 @@ desktop/views/components/notes.note.vue: | ||||
|   detail: "詳細" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   hide: "隠す" | ||||
|   see-more: "もっと見る" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "読み込みに失敗しました。" | ||||
|   retry: "リトライ" | ||||
| @@ -609,6 +678,9 @@ desktop/views/components/settings.vue: | ||||
|   behaviour: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込みます。" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   auto-popout: "ウィンドウの自動ポップアウト" | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   advanced: "詳細設定" | ||||
| @@ -620,11 +692,15 @@ desktop/views/components/settings.vue: | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||
|   show-renoted-my-notes: "Renoteされた自分の投稿をタイムラインに表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   show-maps-desc: "位置情報が添付された投稿のマップを自動的に展開します。" | ||||
|   sound: "サウンド" | ||||
| @@ -717,7 +793,7 @@ desktop/views/components/settings.profile.vue: | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
| @@ -734,7 +810,13 @@ desktop/views/components/timeline.vue: | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
|   list: "リスト" | ||||
|   hashtag: "ハッシュタグ" | ||||
|   add-tag-timeline: "ハッシュタグを追加" | ||||
|   add-list: "リストを追加" | ||||
|   list-name: "リスト名" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
|   adjective: "さん" | ||||
| @@ -745,6 +827,7 @@ desktop/views/components/ui.header.account.vue: | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
|   customize: "ホームのカスタマイズ" | ||||
|   admin: "管理" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   dark: "闇に飲まれる" | ||||
| @@ -781,6 +864,34 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "ドライブ" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   invite: "招待" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "メディア投稿のみ" | ||||
|   is-media-view: "メディアビュー" | ||||
| @@ -789,6 +900,11 @@ desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "詳しく..." | ||||
|   gotit: "わかった" | ||||
| @@ -797,7 +913,10 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "やってる" | ||||
|   signup-button: "やる" | ||||
|   timeline: "タイムライン" | ||||
|   announcements: "お知らせ" | ||||
|   photos: "最近の画像" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
|   info: "情報" | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Misskey Drive" | ||||
| desktop/views/pages/favorites.vue: | ||||
| @@ -813,7 +932,7 @@ desktop/views/pages/selectdrive.vue: | ||||
|   cancel: "キャンセル" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "検索機能を利用することができません。" | ||||
|   not-available: "検索機能はインスタンスの設定で無効になっています。" | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "{}で共有" | ||||
| @@ -906,12 +1025,15 @@ mobile/views/components/drive-file-chooser.vue: | ||||
|   select-file: "ファイルを選択" | ||||
| mobile/views/components/drive-folder-chooser.vue: | ||||
|   select-folder: "フォルダーを選択" | ||||
| mobile/views/components/drive.file.vue: | ||||
|   nsfw: "閲覧注意" | ||||
| mobile/views/components/drive.file-detail.vue: | ||||
|   download: "ダウンロード" | ||||
|   rename: "名前を変更" | ||||
|   move: "移動" | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -931,8 +1053,6 @@ mobile/views/components/friends-maker.vue: | ||||
|   close: "閉じる" | ||||
| mobile/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   more: "もっと見る" | ||||
|   less: "隠す" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   location: "位置情報" | ||||
| @@ -992,6 +1112,7 @@ mobile/views/components/ui.nav.vue: | ||||
|   game: "ゲーム" | ||||
|   darkmode: "ダークモード" | ||||
|   settings: "設定" | ||||
|   admin: "管理" | ||||
|   about: "Misskeyについて" | ||||
| mobile/views/components/user-timeline.vue: | ||||
|   no-notes: "このユーザーは投稿していないようです。" | ||||
| @@ -1020,6 +1141,8 @@ mobile/views/pages/home.vue: | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| mobile/views/pages/welcome.vue: | ||||
| @@ -1060,6 +1183,9 @@ mobile/views/pages/settings/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
| @@ -1081,15 +1207,23 @@ mobile/views/pages/settings.vue: | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   timeline: "タイムライン" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteを表示する" | ||||
|   show-renoted-my-notes: "Renoteされた自分の投稿を表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteを表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteを表示する" | ||||
|   post-style: "投稿の表示スタイル" | ||||
|   post-style-standard: "標準" | ||||
|   post-style-smart: "スマート" | ||||
|   notification-position: "通知の表示" | ||||
|   notification-position-bottom: "下" | ||||
|   notification-position-top: "上" | ||||
|   behavior: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   load-raw-images: "添付された画像を高画質で表示する" | ||||
|   load-remote-media: "リモートサーバーのメディアを表示する" | ||||
| @@ -1108,6 +1242,8 @@ mobile/views/pages/settings.vue: | ||||
|   update-available-desc: "ページを再度読み込みすると更新が適用されます。" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   following: "フォロー" | ||||
| @@ -6,6 +6,19 @@ common: | ||||
|   misskey: "A ⭐ of fediverse" | ||||
|   about-title: "A ⭐ of fediverse." | ||||
|   about: "Misskeyを見つけていただき、ありがとうございます。Misskeyは、地球で生まれた<b>分散マイクロブログSNS</b>です。Fediverse(様々なSNSで構成される宇宙)の中に存在するため、他のSNSと相互に繋がっています。暫し都会の喧騒から離れて、新しいインターネットにダイブしてみませんか。" | ||||
|   intro: | ||||
|     title: "Misskeyって?" | ||||
|     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" | ||||
|     features: "特徴" | ||||
|     rich-contents: "投稿" | ||||
|     rich-contents-desc: "自分の考え、話題の出来事、皆と共有したいことについて発信してください。必要であれば、様々な構文を使って投稿を装飾したり、好きな画像、動画などのファイルやアンケートを添付することもできます。" | ||||
|     reaction: "リアクション" | ||||
|     reaction-desc: "あなたの気持ちを伝える最も簡単な方法です。Misskeyは、他のユーザーの投稿に様々なリアクションを付けることができます。いちどMisskeyのリアクション機能を体験してしまうと、もう「いいね」の概念しか存在しないSNSには戻れなくなるかもしれません。" | ||||
|     ui: "インターフェース" | ||||
|     ui-desc: "どのようなUIが使いやすいかは人それぞれです。だから、Misskeyは自由度の高いUIを持っています。レイアウトやデザインを調整したり、カスタマイズ可能な様々なウィジェットを配置したりして、自分だけのホームを作ってください。" | ||||
|     drive: "ドライブ" | ||||
|     drive-desc: "以前投稿したことのある画像をまた投稿したくなったことはありませんか?もしくは、アップロードしたファイルをフォルダ分けして整理したくなったことはありませんか?Misskeyの根幹に組み込まれたドライブ機能によってそれらが解決します。ファイルの共有も簡単です。" | ||||
|     outro: "他にもMisskeyにしかない機能はまだまだあるので、ぜひあなた自身の目で確かめてください。Misskeyは分散型SNSなので、このインスタンスが気に入らなければ他のインスタンスを試すこともできます。それでは、GLHF!" | ||||
|   adblock: | ||||
|     detected: "広告ブロッカーを無効にしてください" | ||||
|     warning: "<strong>Misskeyは広告を掲載していません</strong>が、広告をブロックする機能が有効だと一部の機能が利用できなかったり、不具合が発生する場合があります。" | ||||
| @@ -73,6 +86,16 @@ common: | ||||
|     rip: "RIP" | ||||
|     pudding: "Pudding" | ||||
| 
 | ||||
|   note-visibility: | ||||
|     public: "公開" | ||||
|     home: "ホーム" | ||||
|     home-desc: "ホームタイムラインにのみ公開" | ||||
|     followers: "フォロワー" | ||||
|     followers-desc: "自分のフォロワーにのみ公開" | ||||
|     specified: "ダイレクト" | ||||
|     specified-desc: "指定したユーザーにのみ公開" | ||||
|     private: "非公開" | ||||
| 
 | ||||
|   note-placeholders: | ||||
|     a: "今どうしてる?" | ||||
|     b: "何かありましたか?" | ||||
| @@ -90,8 +113,16 @@ common: | ||||
|   my-token-regenerated: "あなたのトークンが更新されたのでサインアウトします。" | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   verified-user: "認証済みのユーザー" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   verified-user: "公式アカウント" | ||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   show-full-acct: "ユーザー名のホストを省略しない" | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
| 
 | ||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||
| 
 | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
| @@ -135,7 +166,10 @@ common: | ||||
|     home: "ホーム" | ||||
|     local: "ローカル" | ||||
|     hybrid: "ソーシャル" | ||||
|     hashtag: "ハッシュタグ" | ||||
|     global: "グローバル" | ||||
|     mentions: "あなた宛て" | ||||
|     direct: "ダイレクト投稿" | ||||
|     notifications: "通知" | ||||
|     list: "リスト" | ||||
|     swap-left: "左に移動" | ||||
| @@ -182,6 +216,9 @@ common/views/components/games/reversi/reversi.vue: | ||||
| common/views/components/games/reversi/reversi.game.vue: | ||||
|   surrender: "投了" | ||||
|   surrendered: "投了により" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
| 
 | ||||
| common/views/components/games/reversi/reversi.index.vue: | ||||
|   title: "Misskey Reversi" | ||||
| @@ -244,6 +281,14 @@ common/views/components/connect-failed.troubleshooter.vue: | ||||
|   flush: "キャッシュの削除" | ||||
|   set-version: "バージョン指定" | ||||
| 
 | ||||
| common/views/components/media-banner.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| 
 | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "隠す" | ||||
|   show: "もっと見る" | ||||
| 
 | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "ユーザーを探す" | ||||
|   you: "あなた" | ||||
| @@ -279,6 +324,8 @@ common/views/components/nav.vue: | ||||
|   feedback: "フィードバック" | ||||
| 
 | ||||
| common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   pin: "ピン留め" | ||||
|   delete: "削除" | ||||
| @@ -311,8 +358,11 @@ common/views/components/signin.vue: | ||||
|   signin: "サインイン" | ||||
|   or: "または" | ||||
|   signin-with-twitter: "Twitterでログイン" | ||||
|   login-failed: "ログインできませんでした。ユーザー名とパスワードを確認してください。" | ||||
| 
 | ||||
| common/views/components/signup.vue: | ||||
|   invitation-code: "招待コード" | ||||
|   invitation-info: "招待コードをお持ちでない方は、<a href=\"{}\">管理者</a>までご連絡ください。" | ||||
|   username: "ユーザー名" | ||||
|   checking: "確認しています..." | ||||
|   available: "利用できます" | ||||
| @@ -364,6 +414,10 @@ common/views/components/visibility-chooser.vue: | ||||
|   specified-desc: "指定したユーザーにのみ公開" | ||||
|   private: "非公開" | ||||
| 
 | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| 
 | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "確認中" | ||||
|   no-broadcasts: "お知らせはありません" | ||||
| @@ -392,8 +446,6 @@ common/views/widgets/posts-monitor.vue: | ||||
| 
 | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "ハッシュタグ" | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| 
 | ||||
| common/views/widgets/server.vue: | ||||
|   title: "サーバー情報" | ||||
| @@ -449,6 +501,7 @@ desktop: | ||||
|   uploading-avatar: "新しいアバターをアップロードしています" | ||||
|   avatar-updated: "アバターを更新しました" | ||||
|   choose-avatar: "アバターにする画像を選択" | ||||
|   invalid-filetype: "この形式のファイルはサポートされていません" | ||||
| 
 | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Black ... Total" | ||||
| @@ -466,6 +519,29 @@ desktop/views/components/calendar.vue: | ||||
|   next: "次の月" | ||||
|   go: "クリックして時間遡行" | ||||
| 
 | ||||
| desktop/views/components/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の累計" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの累計" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の累計" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の累計" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| 
 | ||||
| desktop/views/components/choose-file-from-drive-window.vue: | ||||
|   choose-file: "ファイル選択中" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| @@ -490,6 +566,7 @@ desktop/views/components/drive-window.vue: | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   nsfw: "閲覧注意" | ||||
|   contextmenu: | ||||
|     rename: "名前を変更" | ||||
|     mark-as-sensitive: "閲覧注意に設定" | ||||
| @@ -609,8 +686,6 @@ desktop/views/components/notes.note.vue: | ||||
|   detail: "詳細" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   hide: "隠す" | ||||
|   see-more: "もっと見る" | ||||
| 
 | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "読み込みに失敗しました。" | ||||
| @@ -690,6 +765,9 @@ desktop/views/components/settings.vue: | ||||
|   behaviour: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込みます。" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   auto-popout: "ウィンドウの自動ポップアウト" | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   advanced: "詳細設定" | ||||
| @@ -702,11 +780,15 @@ desktop/views/components/settings.vue: | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||
|   show-renoted-my-notes: "Renoteされた自分の投稿をタイムラインに表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   show-maps-desc: "位置情報が添付された投稿のマップを自動的に展開します。" | ||||
| 
 | ||||
| @@ -814,7 +896,7 @@ desktop/views/components/settings.profile.vue: | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
| @@ -834,7 +916,13 @@ desktop/views/components/timeline.vue: | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
|   list: "リスト" | ||||
|   hashtag: "ハッシュタグ" | ||||
|   add-tag-timeline: "ハッシュタグを追加" | ||||
|   add-list: "リストを追加" | ||||
|   list-name: "リスト名" | ||||
| 
 | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
| @@ -847,6 +935,7 @@ desktop/views/components/ui.header.account.vue: | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
|   customize: "ホームのカスタマイズ" | ||||
|   admin: "管理" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   dark: "闇に飲まれる" | ||||
| @@ -894,6 +983,40 @@ desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "閉じる" | ||||
| 
 | ||||
| desktop/views/pages/admin/admin.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "ドライブ" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
| 
 | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   invite: "招待" | ||||
| 
 | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
| 
 | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
| 
 | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
| 
 | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| 
 | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "メディア投稿のみ" | ||||
|   is-media-view: "メディアビュー" | ||||
| @@ -904,6 +1027,12 @@ desktop/views/pages/deck/deck.note.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| 
 | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
| 
 | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "詳しく..." | ||||
|   gotit: "わかった" | ||||
| @@ -912,7 +1041,10 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "やってる" | ||||
|   signup-button: "やる" | ||||
|   timeline: "タイムライン" | ||||
|   announcements: "お知らせ" | ||||
|   photos: "最近の画像" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
|   info: "情報" | ||||
| 
 | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Misskey Drive" | ||||
| @@ -934,7 +1066,7 @@ desktop/views/pages/selectdrive.vue: | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| 
 | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "検索機能を利用することができません。" | ||||
|   not-available: "検索機能はインスタンスの設定で無効になっています。" | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
| 
 | ||||
| desktop/views/pages/share.vue: | ||||
| @@ -1050,12 +1182,16 @@ mobile/views/components/drive-file-chooser.vue: | ||||
| mobile/views/components/drive-folder-chooser.vue: | ||||
|   select-folder: "フォルダーを選択" | ||||
| 
 | ||||
| mobile/views/components/drive.file.vue: | ||||
|   nsfw: "閲覧注意" | ||||
| 
 | ||||
| mobile/views/components/drive.file-detail.vue: | ||||
|   download: "ダウンロード" | ||||
|   rename: "名前を変更" | ||||
|   move: "移動" | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
| 
 | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
| @@ -1080,8 +1216,6 @@ mobile/views/components/friends-maker.vue: | ||||
| 
 | ||||
| mobile/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   more: "もっと見る" | ||||
|   less: "隠す" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   location: "位置情報" | ||||
| @@ -1151,6 +1285,7 @@ mobile/views/components/ui.nav.vue: | ||||
|   game: "ゲーム" | ||||
|   darkmode: "ダークモード" | ||||
|   settings: "設定" | ||||
|   admin: "管理" | ||||
|   about: "Misskeyについて" | ||||
| 
 | ||||
| mobile/views/components/user-timeline.vue: | ||||
| @@ -1188,6 +1323,8 @@ mobile/views/pages/home.vue: | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
| 
 | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| @@ -1240,6 +1377,9 @@ mobile/views/pages/settings/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
| @@ -1264,15 +1404,23 @@ mobile/views/pages/settings.vue: | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   timeline: "タイムライン" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteを表示する" | ||||
|   show-renoted-my-notes: "Renoteされた自分の投稿を表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteを表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteを表示する" | ||||
|   post-style: "投稿の表示スタイル" | ||||
|   post-style-standard: "標準" | ||||
|   post-style-smart: "スマート" | ||||
|   notification-position: "通知の表示" | ||||
|   notification-position-bottom: "下" | ||||
|   notification-position-top: "上" | ||||
|   behavior: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   load-raw-images: "添付された画像を高画質で表示する" | ||||
|   load-remote-media: "リモートサーバーのメディアを表示する" | ||||
| @@ -1291,6 +1439,8 @@ mobile/views/pages/settings.vue: | ||||
|   update-available-desc: "ページを再度読み込みすると更新が適用されます。" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
| 
 | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
| @@ -1354,6 +1504,5 @@ docs: | ||||
|       type: "型" | ||||
|       description: "説明" | ||||
| 
 | ||||
| 
 | ||||
| dev/views/index.vue: | ||||
|   manage-apps: "アプリの管理" | ||||
							
								
								
									
										1302
									
								
								locales/ja-KS.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1302
									
								
								locales/ja-KS.yml
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -6,13 +6,26 @@ common: | ||||
|   misskey: "A ⭐ of fediverse" | ||||
|   about-title: "A ⭐ of fediverse." | ||||
|   about: "Misskey를 찾아 주셔서 감사합니다. Misskey은 지구에서 태어난 <b>분산 마이크로 블로그 SNS </b> 입니다. Fediverse (다양한 SNS로 구성되는 우주)에 존재하는 다른 SNS와 상호 연결되어 있습니다. 잠시 도시의 번잡함에서 벗어나 새로운 인터넷에 다이브 해 보지 않겠습니까." | ||||
|   intro: | ||||
|     title: "Misskeyって?" | ||||
|     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" | ||||
|     features: "特徴" | ||||
|     rich-contents: "投稿" | ||||
|     rich-contents-desc: "自分の考え、話題の出来事、皆と共有したいことについて発信してください。必要であれば、様々な構文を使って投稿を装飾したり、好きな画像、動画などのファイルやアンケートを添付することもできます。" | ||||
|     reaction: "リアクション" | ||||
|     reaction-desc: "あなたの気持ちを伝える最も簡単な方法です。Misskeyは、他のユーザーの投稿に様々なリアクションを付けることができます。いちどMisskeyのリアクション機能を体験してしまうと、もう「いいね」の概念しか存在しないSNSには戻れなくなるかもしれません。" | ||||
|     ui: "インターフェース" | ||||
|     ui-desc: "どのようなUIが使いやすいかは人それぞれです。だから、Misskeyは自由度の高いUIを持っています。レイアウトやデザインを調整したり、カスタマイズ可能な様々なウィジェットを配置したりして、自分だけのホームを作ってください。" | ||||
|     drive: "ドライブ" | ||||
|     drive-desc: "以前投稿したことのある画像をまた投稿したくなったことはありませんか?もしくは、アップロードしたファイルをフォルダ分けして整理したくなったことはありませんか?Misskeyの根幹に組み込まれたドライブ機能によってそれらが解決します。ファイルの共有も簡単です。" | ||||
|     outro: "他にもMisskeyにしかない機能はまだまだあるので、ぜひあなた自身の目で確かめてください。Misskeyは分散型SNSなので、このインスタンスが気に入らなければ他のインスタンスを試すこともできます。それでは、GLHF!" | ||||
|   adblock: | ||||
|     detected: "광고 차단기를 해제하십시오" | ||||
|     warning: "<strong>Misskey는 광고를 게재하지 않습니다</strong> 그러나 광고를 차단하는 기능 기능을 사용할 경우 일부 기능을 사용할 수 없게 될 가능성이나 결함이 발생하는 경우가 있습니다." | ||||
|   application-authorization: "앱의 연계" | ||||
|   close: "닫기" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   got-it: "わかった" | ||||
|   got-it: "알았습니다" | ||||
|   customization-tips: | ||||
|     title: "사용자 정의 팁" | ||||
|     paragraph1: "홈 정의는 위젯을 추가 / 삭제하거나 드래그 앤 드롭하여 정렬 할 수 있습니다." | ||||
| @@ -39,7 +52,7 @@ common: | ||||
|     weeks_ago: "{}주전" | ||||
|     months_ago: "{}개월전" | ||||
|     years_ago: "{}년전" | ||||
|   month-and-day: "{month}月 {day}日" | ||||
|   month-and-day: "{month}월 {day}일" | ||||
|   trash: "휴지통" | ||||
|   weekday-short: | ||||
|     sunday: "일" | ||||
| @@ -58,7 +71,7 @@ common: | ||||
|     friday: "금요일" | ||||
|     saturday: "토요일" | ||||
|   reactions: | ||||
|     like: "좋네" | ||||
|     like: "いいね" | ||||
|     love: "좋아" | ||||
|     laugh: "크크" | ||||
|     hmm: "음..." | ||||
| @@ -68,6 +81,15 @@ common: | ||||
|     confused: "곤란하고 있어" | ||||
|     rip: "RIP" | ||||
|     pudding: "Pudding" | ||||
|   note-visibility: | ||||
|     public: "公開" | ||||
|     home: "ホーム" | ||||
|     home-desc: "ホームタイムラインにのみ公開" | ||||
|     followers: "フォロワー" | ||||
|     followers-desc: "自分のフォロワーにのみ公開" | ||||
|     specified: "ダイレクト" | ||||
|     specified-desc: "指定したユーザーにのみ公開" | ||||
|     private: "非公開" | ||||
|   note-placeholders: | ||||
|     a: "지금 어떻게하고있어?" | ||||
|     b: "뭔가 있었습니까?" | ||||
| @@ -84,8 +106,15 @@ common: | ||||
|   my-token-regenerated: "당신의 토큰이 업데이트되어 있기 때문에 로그 아웃합니다." | ||||
|   i-like-sushi: "나는(푸딩보다 오히려)스시가 좋아" | ||||
|   show-reversi-board-labels: "리버시 보드의 행과 열 레이블을 표시" | ||||
|   verified-user: "인증 된 사용자" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   verified-user: "公式アカウント" | ||||
|   disable-animated-mfm: "게시물의 문자 애니메이션을 비활성화 할" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   show-full-acct: "ユーザー名のホストを省略しない" | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||
|   reversi: | ||||
|     drawn: "무승부" | ||||
|     my-turn: "당신의 차례입니다" | ||||
| @@ -122,13 +151,16 @@ common: | ||||
|     tips: "팁" | ||||
|     hashtags: "해시 태그" | ||||
|   deck: | ||||
|     widgets: "ウィジェット" | ||||
|     home: "ホーム" | ||||
|     local: "ローカル" | ||||
|     hybrid: "ソーシャル" | ||||
|     global: "グローバル" | ||||
|     notifications: "通知" | ||||
|     list: "リスト" | ||||
|     widgets: "위젯" | ||||
|     home: "홈" | ||||
|     local: "로컬" | ||||
|     hybrid: "소셜" | ||||
|     hashtag: "ハッシュタグ" | ||||
|     global: "글로벌" | ||||
|     mentions: "あなた宛て" | ||||
|     direct: "ダイレクト投稿" | ||||
|     notifications: "통지" | ||||
|     list: "목록" | ||||
|     swap-left: "左に移動" | ||||
|     swap-right: "右に移動" | ||||
|     swap-up: "上に移動" | ||||
| @@ -150,10 +182,10 @@ auth/views/form.vue: | ||||
|   drive-write: "ドライブを操作する。" | ||||
|   notification-read: "通知を見る。" | ||||
|   notification-write: "通知を操作する。" | ||||
|   cancel: "キャンセル" | ||||
|   cancel: "취소" | ||||
|   accept: "アクセスを許可" | ||||
| auth/views/index.vue: | ||||
|   loading: "読み込み中" | ||||
|   loading: "로드 중" | ||||
|   denied: "アプリケーションの連携をキャンセルしました。" | ||||
|   denied-paragraph: "このアプリがあなたのアカウントにアクセスすることはありません。" | ||||
|   already-authorized: "このアプリは既に連携済みです" | ||||
| @@ -165,15 +197,18 @@ auth/views/index.vue: | ||||
| common/views/components/games/reversi/reversi.vue: | ||||
|   matching: | ||||
|     waiting-for: "{}を待っています" | ||||
|     cancel: "キャンセル" | ||||
|     cancel: "취소" | ||||
| common/views/components/games/reversi/reversi.game.vue: | ||||
|   surrender: "投了" | ||||
|   surrender: "기권" | ||||
|   surrendered: "投了により" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "루프 지도" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
| common/views/components/games/reversi/reversi.index.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "他のMisskeyユーザーとリバーシで対戦しよう" | ||||
|   invite: "招待" | ||||
|   rule: "遊び方" | ||||
|   invite: "초대" | ||||
|   rule: "게임 방법" | ||||
|   rule-desc: "リバーシは、相手と交互に石をボードに置いて、相手の石を挟んで自分の色に変えてゆき、最終的に残った石が多い方が勝ちというボードゲームです。" | ||||
|   mode-invite: "招待" | ||||
|   mode-invite-desc: "指定したユーザーと対戦するモードです。" | ||||
| @@ -182,26 +217,26 @@ common/views/components/games/reversi/reversi.index.vue: | ||||
|   all-games: "みんなの対局" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
|   game-state: | ||||
|     ended: "終了" | ||||
|     playing: "進行中" | ||||
|     ended: "종료" | ||||
|     playing: "진행중" | ||||
| common/views/components/games/reversi/reversi.room.vue: | ||||
|   settings-of-the-game: "ゲームの設定" | ||||
|   choose-map: "マップを選択" | ||||
|   random: "ランダム" | ||||
|   black-or-white: "先手/後手" | ||||
|   black-is: "{}が黒" | ||||
|   rules: "ルール" | ||||
|   rules: "규칙" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   looped-map: "루프 지도" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
|   settings-of-the-bot: "Botの設定" | ||||
|   this-game-is-started-soon: "ゲームは数秒後に開始されます" | ||||
|   waiting-for-other: "相手の準備が完了するのを待っています" | ||||
|   waiting-for-me: "あなたの準備が完了するのを待っています" | ||||
|   waiting-for-both: "準備中" | ||||
|   cancel: "キャンセル" | ||||
|   ready: "準備完了" | ||||
|   cancel-ready: "準備続行" | ||||
|   waiting-for-both: "준비중" | ||||
|   cancel: "취소" | ||||
|   ready: "준비 완료" | ||||
|   cancel-ready: "준비 계속" | ||||
| common/views/components/connect-failed.vue: | ||||
|   title: "サーバーに接続できません" | ||||
|   description: "インターネット回線に問題があるか、サーバーがダウンまたはメンテナンスしている可能性があります。しばらくしてから{再度お試し}ください。" | ||||
| @@ -226,9 +261,15 @@ common/views/components/connect-failed.troubleshooter.vue: | ||||
|   success-desc: "正常に接続できるようです。ページを再度読み込みしてください。" | ||||
|   flush: "キャッシュの削除" | ||||
|   set-version: "バージョン指定" | ||||
| common/views/components/media-banner.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "隠す" | ||||
|   show: "もっと見る" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "ユーザーを探す" | ||||
|   you: "あなた" | ||||
|   you: "당신" | ||||
|   no-history: "履歴はありません" | ||||
| common/views/components/messaging-room.vue: | ||||
|   empty: "このユーザーと話したことはありません" | ||||
| @@ -239,12 +280,12 @@ common/views/components/messaging-room.vue: | ||||
|   only-one-file-attached: "メッセージに添付できるのはひとつのファイルのみです" | ||||
| common/views/components/messaging-room.form.vue: | ||||
|   input-message-here: "ここにメッセージを入力" | ||||
|   send: "送信" | ||||
|   send: "전송" | ||||
|   attach-from-local: "PCからファイルを添付する" | ||||
|   attach-from-drive: "ドライブからファイルを添付する" | ||||
|   only-one-file-attached: "メッセージに添付できるのはひとつのファイルのみです" | ||||
| common/views/components/messaging-room.message.vue: | ||||
|   is-read: "既読" | ||||
|   is-read: "읽음" | ||||
|   deleted: "このメッセージは削除されました" | ||||
| common/views/components/nav.vue: | ||||
|   about: "Misskeyについて" | ||||
| @@ -256,6 +297,8 @@ common/views/components/nav.vue: | ||||
|   develop: "開発者" | ||||
|   feedback: "フィードバック" | ||||
| common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   pin: "ピン留め" | ||||
|   delete: "削除" | ||||
| @@ -284,7 +327,10 @@ common/views/components/signin.vue: | ||||
|   signin: "サインイン" | ||||
|   or: "または" | ||||
|   signin-with-twitter: "Twitterでログイン" | ||||
|   login-failed: "ログインできませんでした。ユーザー名とパスワードを確認してください。" | ||||
| common/views/components/signup.vue: | ||||
|   invitation-code: "招待コード" | ||||
|   invitation-info: "招待コードをお持ちでない方は、<a href=\"{}\">管理者</a>までご連絡ください。" | ||||
|   username: "ユーザー名" | ||||
|   checking: "確認しています..." | ||||
|   available: "利用できます" | ||||
| @@ -330,6 +376,9 @@ common/views/components/visibility-chooser.vue: | ||||
|   specified: "ダイレクト" | ||||
|   specified-desc: "指定したユーザーにのみ公開" | ||||
|   private: "非公開" | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "確認中" | ||||
|   no-broadcasts: "お知らせはありません" | ||||
| @@ -353,8 +402,6 @@ common/views/widgets/posts-monitor.vue: | ||||
|   toggle: "表示を切り替え" | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "ハッシュタグ" | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "サーバー情報" | ||||
|   toggle: "表示を切り替え" | ||||
| @@ -404,6 +451,7 @@ desktop: | ||||
|   uploading-avatar: "新しいアバターをアップロードしています" | ||||
|   avatar-updated: "アバターを更新しました" | ||||
|   choose-avatar: "アバターにする画像を選択" | ||||
|   invalid-filetype: "この形式のファイルはサポートされていません" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Black ... Total" | ||||
|   notes: "Blue ... Notes" | ||||
| @@ -417,6 +465,28 @@ desktop/views/components/calendar.vue: | ||||
|   prev: "前の月" | ||||
|   next: "次の月" | ||||
|   go: "クリックして時間遡行" | ||||
| desktop/views/components/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の累計" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの累計" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の累計" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の累計" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| desktop/views/components/choose-file-from-drive-window.vue: | ||||
|   choose-file: "ファイル選択中" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| @@ -437,6 +507,7 @@ desktop/views/components/drive-window.vue: | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   nsfw: "閲覧注意" | ||||
|   contextmenu: | ||||
|     rename: "名前を変更" | ||||
|     mark-as-sensitive: "閲覧注意に設定" | ||||
| @@ -538,8 +609,6 @@ desktop/views/components/notes.note.vue: | ||||
|   detail: "詳細" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   hide: "隠す" | ||||
|   see-more: "もっと見る" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "読み込みに失敗しました。" | ||||
|   retry: "リトライ" | ||||
| @@ -609,6 +678,9 @@ desktop/views/components/settings.vue: | ||||
|   behaviour: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込みます。" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   auto-popout: "ウィンドウの自動ポップアウト" | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   advanced: "詳細設定" | ||||
| @@ -620,11 +692,15 @@ desktop/views/components/settings.vue: | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||
|   show-renoted-my-notes: "Renoteされた自分の投稿をタイムラインに表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   show-maps-desc: "位置情報が添付された投稿のマップを自動的に展開します。" | ||||
|   sound: "サウンド" | ||||
| @@ -717,7 +793,7 @@ desktop/views/components/settings.profile.vue: | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
| @@ -734,7 +810,13 @@ desktop/views/components/timeline.vue: | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
|   list: "リスト" | ||||
|   hashtag: "ハッシュタグ" | ||||
|   add-tag-timeline: "ハッシュタグを追加" | ||||
|   add-list: "リストを追加" | ||||
|   list-name: "リスト名" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
|   adjective: "さん" | ||||
| @@ -745,6 +827,7 @@ desktop/views/components/ui.header.account.vue: | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
|   customize: "ホームのカスタマイズ" | ||||
|   admin: "管理" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   dark: "闇に飲まれる" | ||||
| @@ -781,6 +864,34 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "ドライブ" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   invite: "招待" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "メディア投稿のみ" | ||||
|   is-media-view: "メディアビュー" | ||||
| @@ -789,6 +900,11 @@ desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "詳しく..." | ||||
|   gotit: "わかった" | ||||
| @@ -797,7 +913,10 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "やってる" | ||||
|   signup-button: "やる" | ||||
|   timeline: "タイムライン" | ||||
|   announcements: "お知らせ" | ||||
|   photos: "最近の画像" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
|   info: "情報" | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Misskey Drive" | ||||
| desktop/views/pages/favorites.vue: | ||||
| @@ -813,7 +932,7 @@ desktop/views/pages/selectdrive.vue: | ||||
|   cancel: "キャンセル" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "検索機能を利用することができません。" | ||||
|   not-available: "検索機能はインスタンスの設定で無効になっています。" | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "{}で共有" | ||||
| @@ -906,12 +1025,15 @@ mobile/views/components/drive-file-chooser.vue: | ||||
|   select-file: "ファイルを選択" | ||||
| mobile/views/components/drive-folder-chooser.vue: | ||||
|   select-folder: "フォルダーを選択" | ||||
| mobile/views/components/drive.file.vue: | ||||
|   nsfw: "閲覧注意" | ||||
| mobile/views/components/drive.file-detail.vue: | ||||
|   download: "ダウンロード" | ||||
|   rename: "名前を変更" | ||||
|   move: "移動" | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -931,8 +1053,6 @@ mobile/views/components/friends-maker.vue: | ||||
|   close: "閉じる" | ||||
| mobile/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   more: "もっと見る" | ||||
|   less: "隠す" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   location: "位置情報" | ||||
| @@ -992,6 +1112,7 @@ mobile/views/components/ui.nav.vue: | ||||
|   game: "ゲーム" | ||||
|   darkmode: "ダークモード" | ||||
|   settings: "設定" | ||||
|   admin: "管理" | ||||
|   about: "Misskeyについて" | ||||
| mobile/views/components/user-timeline.vue: | ||||
|   no-notes: "このユーザーは投稿していないようです。" | ||||
| @@ -1020,6 +1141,8 @@ mobile/views/pages/home.vue: | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| mobile/views/pages/welcome.vue: | ||||
| @@ -1060,6 +1183,9 @@ mobile/views/pages/settings/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
| @@ -1081,15 +1207,23 @@ mobile/views/pages/settings.vue: | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   timeline: "タイムライン" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteを表示する" | ||||
|   show-renoted-my-notes: "Renoteされた自分の投稿を表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteを表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteを表示する" | ||||
|   post-style: "投稿の表示スタイル" | ||||
|   post-style-standard: "標準" | ||||
|   post-style-smart: "スマート" | ||||
|   notification-position: "通知の表示" | ||||
|   notification-position-bottom: "下" | ||||
|   notification-position-top: "上" | ||||
|   behavior: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   load-raw-images: "添付された画像を高画質で表示する" | ||||
|   load-remote-media: "リモートサーバーのメディアを表示する" | ||||
| @@ -1108,6 +1242,8 @@ mobile/views/pages/settings.vue: | ||||
|   update-available-desc: "ページを再度読み込みすると更新が適用されます。" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   following: "フォロー" | ||||
							
								
								
									
										1302
									
								
								locales/nl-NL.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1302
									
								
								locales/nl-NL.yml
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,11 +1,24 @@ | ||||
| --- | ||||
| meta: | ||||
|   lang: "Português" | ||||
|   lang: "norsk" | ||||
|   divider: "" | ||||
| common: | ||||
|   misskey: "A ⭐ of fediverse" | ||||
|   about-title: "A ⭐ of fediverse." | ||||
|   about: "Misskeyを見つけていただき、ありがとうございます。Misskeyは、地球で生まれた<b>分散マイクロブログSNS</b>です。Fediverse(様々なSNSで構成される宇宙)の中に存在するため、他のSNSと相互に繋がっています。暫し都会の喧騒から離れて、新しいインターネットにダイブしてみませんか。" | ||||
|   intro: | ||||
|     title: "Misskeyって?" | ||||
|     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" | ||||
|     features: "特徴" | ||||
|     rich-contents: "投稿" | ||||
|     rich-contents-desc: "自分の考え、話題の出来事、皆と共有したいことについて発信してください。必要であれば、様々な構文を使って投稿を装飾したり、好きな画像、動画などのファイルやアンケートを添付することもできます。" | ||||
|     reaction: "リアクション" | ||||
|     reaction-desc: "あなたの気持ちを伝える最も簡単な方法です。Misskeyは、他のユーザーの投稿に様々なリアクションを付けることができます。いちどMisskeyのリアクション機能を体験してしまうと、もう「いいね」の概念しか存在しないSNSには戻れなくなるかもしれません。" | ||||
|     ui: "インターフェース" | ||||
|     ui-desc: "どのようなUIが使いやすいかは人それぞれです。だから、Misskeyは自由度の高いUIを持っています。レイアウトやデザインを調整したり、カスタマイズ可能な様々なウィジェットを配置したりして、自分だけのホームを作ってください。" | ||||
|     drive: "ドライブ" | ||||
|     drive-desc: "以前投稿したことのある画像をまた投稿したくなったことはありませんか?もしくは、アップロードしたファイルをフォルダ分けして整理したくなったことはありませんか?Misskeyの根幹に組み込まれたドライブ機能によってそれらが解決します。ファイルの共有も簡単です。" | ||||
|     outro: "他にもMisskeyにしかない機能はまだまだあるので、ぜひあなた自身の目で確かめてください。Misskeyは分散型SNSなので、このインスタンスが気に入らなければ他のインスタンスを試すこともできます。それでは、GLHF!" | ||||
|   adblock: | ||||
|     detected: "広告ブロッカーを無効にしてください" | ||||
|     warning: "<strong>Misskeyは広告を掲載していません</strong>が、広告をブロックする機能が有効だと一部の機能が利用できなかったり、不具合が発生する場合があります。" | ||||
| @@ -29,26 +42,26 @@ common: | ||||
|     reply-from: "{}さんから返信:" | ||||
|     quoted-by: "{}さんが引用:" | ||||
|   time: | ||||
|     unknown: "なぞのじかん" | ||||
|     future: "未来" | ||||
|     just_now: "たった今" | ||||
|     seconds_ago: "{}秒前" | ||||
|     minutes_ago: "{}分前" | ||||
|     hours_ago: "{}時間前" | ||||
|     days_ago: "{}日前" | ||||
|     weeks_ago: "{}週間前" | ||||
|     months_ago: "{}ヶ月前" | ||||
|     years_ago: "{}年前" | ||||
|     unknown: "ukjent" | ||||
|     future: "fremtidig" | ||||
|     just_now: "akkurat nå" | ||||
|     seconds_ago: "{} sekunder siden" | ||||
|     minutes_ago: "{} minutter siden" | ||||
|     hours_ago: "{} time siden" | ||||
|     days_ago: "{} dag siden" | ||||
|     weeks_ago: "{} uke(r) siden" | ||||
|     months_ago: "{} måned(er) siden" | ||||
|     years_ago: "{} år siden" | ||||
|   month-and-day: "{month}月 {day}日" | ||||
|   trash: "ゴミ箱" | ||||
|   weekday-short: | ||||
|     sunday: "日" | ||||
|     monday: "月" | ||||
|     tuesday: "火" | ||||
|     wednesday: "水" | ||||
|     thursday: "木" | ||||
|     friday: "金" | ||||
|     saturday: "土" | ||||
|     sunday: "S" | ||||
|     monday: "M" | ||||
|     tuesday: "T" | ||||
|     wednesday: "O" | ||||
|     thursday: "T" | ||||
|     friday: "F" | ||||
|     saturday: "L" | ||||
|   weekday: | ||||
|     sunday: "日曜日" | ||||
|     monday: "月曜日" | ||||
| @@ -58,16 +71,25 @@ common: | ||||
|     friday: "金曜日" | ||||
|     saturday: "土曜日" | ||||
|   reactions: | ||||
|     like: "いいね" | ||||
|     love: "しゅき" | ||||
|     laugh: "笑" | ||||
|     hmm: "ふぅ~む" | ||||
|     surprise: "わお" | ||||
|     congrats: "おめでとう" | ||||
|     angry: "おこ" | ||||
|     confused: "こまこまのこまり" | ||||
|     like: "Lik" | ||||
|     love: "Elsk" | ||||
|     laugh: "Le" | ||||
|     hmm: "Hmm…?" | ||||
|     surprise: "Wow" | ||||
|     congrats: "Gratulerer!" | ||||
|     angry: "Sint" | ||||
|     confused: "Forvirret" | ||||
|     rip: "RIP" | ||||
|     pudding: "Pudding" | ||||
|   note-visibility: | ||||
|     public: "公開" | ||||
|     home: "ホーム" | ||||
|     home-desc: "ホームタイムラインにのみ公開" | ||||
|     followers: "フォロワー" | ||||
|     followers-desc: "自分のフォロワーにのみ公開" | ||||
|     specified: "ダイレクト" | ||||
|     specified-desc: "指定したユーザーにのみ公開" | ||||
|     private: "非公開" | ||||
|   note-placeholders: | ||||
|     a: "今どうしてる?" | ||||
|     b: "何かありましたか?" | ||||
| @@ -80,12 +102,19 @@ common: | ||||
|   loading: "読み込み中" | ||||
|   ok: "わかった" | ||||
|   update-available-title: "更新があります" | ||||
|   update-available: "Misskeyの新しいバージョンがあります({newer}。現在{current}を利用中)。ページを再度読み込みすると更新が適用されます。" | ||||
|   my-token-regenerated: "あなたのトークンが更新されたのでサインアウトします。" | ||||
|   update-available: "En ny versjon av Misskey er nå tilgjengelig ({newer}, nåværende versjon er {current}). Last inn siden igjen for at oppdateringen skal tre i kraft." | ||||
|   my-token-regenerated: "Ditt synbol har blitt generert. Du vil nå bli utlogget." | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   verified-user: "認証済みのユーザー" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   verified-user: "公式アカウント" | ||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   show-full-acct: "ユーザー名のホストを省略しない" | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
| @@ -126,7 +155,10 @@ common: | ||||
|     home: "ホーム" | ||||
|     local: "ローカル" | ||||
|     hybrid: "ソーシャル" | ||||
|     hashtag: "ハッシュタグ" | ||||
|     global: "グローバル" | ||||
|     mentions: "あなた宛て" | ||||
|     direct: "ダイレクト投稿" | ||||
|     notifications: "通知" | ||||
|     list: "リスト" | ||||
|     swap-left: "左に移動" | ||||
| @@ -169,6 +201,9 @@ common/views/components/games/reversi/reversi.vue: | ||||
| common/views/components/games/reversi/reversi.game.vue: | ||||
|   surrender: "投了" | ||||
|   surrendered: "投了により" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
| common/views/components/games/reversi/reversi.index.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "他のMisskeyユーザーとリバーシで対戦しよう" | ||||
| @@ -203,8 +238,8 @@ common/views/components/games/reversi/reversi.room.vue: | ||||
|   ready: "準備完了" | ||||
|   cancel-ready: "準備続行" | ||||
| common/views/components/connect-failed.vue: | ||||
|   title: "サーバーに接続できません" | ||||
|   description: "インターネット回線に問題があるか、サーバーがダウンまたはメンテナンスしている可能性があります。しばらくしてから{再度お試し}ください。" | ||||
|   title: "Kunne ikke koble til tjeneren." | ||||
|   description: "Det er enten et problem med internettilknytningen din, eller så har tjeneren blitt tatt ned for vedlikehold. {Prøv igjen} senere." | ||||
|   thanks: "いつもMisskeyをご利用いただきありがとうございます。" | ||||
|   troubleshoot: "トラブルシュート" | ||||
| common/views/components/connect-failed.troubleshooter.vue: | ||||
| @@ -226,6 +261,12 @@ common/views/components/connect-failed.troubleshooter.vue: | ||||
|   success-desc: "正常に接続できるようです。ページを再度読み込みしてください。" | ||||
|   flush: "キャッシュの削除" | ||||
|   set-version: "バージョン指定" | ||||
| common/views/components/media-banner.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "隠す" | ||||
|   show: "もっと見る" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "ユーザーを探す" | ||||
|   you: "あなた" | ||||
| @@ -256,6 +297,8 @@ common/views/components/nav.vue: | ||||
|   develop: "開発者" | ||||
|   feedback: "フィードバック" | ||||
| common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   pin: "ピン留め" | ||||
|   delete: "削除" | ||||
| @@ -284,7 +327,10 @@ common/views/components/signin.vue: | ||||
|   signin: "サインイン" | ||||
|   or: "または" | ||||
|   signin-with-twitter: "Twitterでログイン" | ||||
|   login-failed: "ログインできませんでした。ユーザー名とパスワードを確認してください。" | ||||
| common/views/components/signup.vue: | ||||
|   invitation-code: "招待コード" | ||||
|   invitation-info: "招待コードをお持ちでない方は、<a href=\"{}\">管理者</a>までご連絡ください。" | ||||
|   username: "ユーザー名" | ||||
|   checking: "確認しています..." | ||||
|   available: "利用できます" | ||||
| @@ -330,6 +376,9 @@ common/views/components/visibility-chooser.vue: | ||||
|   specified: "ダイレクト" | ||||
|   specified-desc: "指定したユーザーにのみ公開" | ||||
|   private: "非公開" | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "確認中" | ||||
|   no-broadcasts: "お知らせはありません" | ||||
| @@ -353,8 +402,6 @@ common/views/widgets/posts-monitor.vue: | ||||
|   toggle: "表示を切り替え" | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "ハッシュタグ" | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "サーバー情報" | ||||
|   toggle: "表示を切り替え" | ||||
| @@ -404,6 +451,7 @@ desktop: | ||||
|   uploading-avatar: "新しいアバターをアップロードしています" | ||||
|   avatar-updated: "アバターを更新しました" | ||||
|   choose-avatar: "アバターにする画像を選択" | ||||
|   invalid-filetype: "この形式のファイルはサポートされていません" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Black ... Total" | ||||
|   notes: "Blue ... Notes" | ||||
| @@ -417,6 +465,28 @@ desktop/views/components/calendar.vue: | ||||
|   prev: "前の月" | ||||
|   next: "次の月" | ||||
|   go: "クリックして時間遡行" | ||||
| desktop/views/components/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の累計" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの累計" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の累計" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の累計" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| desktop/views/components/choose-file-from-drive-window.vue: | ||||
|   choose-file: "ファイル選択中" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| @@ -437,6 +507,7 @@ desktop/views/components/drive-window.vue: | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   nsfw: "閲覧注意" | ||||
|   contextmenu: | ||||
|     rename: "名前を変更" | ||||
|     mark-as-sensitive: "閲覧注意に設定" | ||||
| @@ -538,8 +609,6 @@ desktop/views/components/notes.note.vue: | ||||
|   detail: "詳細" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   hide: "隠す" | ||||
|   see-more: "もっと見る" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "読み込みに失敗しました。" | ||||
|   retry: "リトライ" | ||||
| @@ -609,6 +678,9 @@ desktop/views/components/settings.vue: | ||||
|   behaviour: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込みます。" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   auto-popout: "ウィンドウの自動ポップアウト" | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   advanced: "詳細設定" | ||||
| @@ -620,11 +692,15 @@ desktop/views/components/settings.vue: | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||
|   show-renoted-my-notes: "Renoteされた自分の投稿をタイムラインに表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   show-maps-desc: "位置情報が添付された投稿のマップを自動的に展開します。" | ||||
|   sound: "サウンド" | ||||
| @@ -717,7 +793,7 @@ desktop/views/components/settings.profile.vue: | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
| @@ -734,7 +810,13 @@ desktop/views/components/timeline.vue: | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
|   list: "リスト" | ||||
|   hashtag: "ハッシュタグ" | ||||
|   add-tag-timeline: "ハッシュタグを追加" | ||||
|   add-list: "リストを追加" | ||||
|   list-name: "リスト名" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
|   adjective: "さん" | ||||
| @@ -745,6 +827,7 @@ desktop/views/components/ui.header.account.vue: | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
|   customize: "ホームのカスタマイズ" | ||||
|   admin: "管理" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   dark: "闇に飲まれる" | ||||
| @@ -781,6 +864,34 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "ドライブ" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   invite: "招待" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "メディア投稿のみ" | ||||
|   is-media-view: "メディアビュー" | ||||
| @@ -789,6 +900,11 @@ desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "詳しく..." | ||||
|   gotit: "わかった" | ||||
| @@ -797,7 +913,10 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "やってる" | ||||
|   signup-button: "やる" | ||||
|   timeline: "タイムライン" | ||||
|   announcements: "お知らせ" | ||||
|   photos: "最近の画像" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
|   info: "情報" | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Misskey Drive" | ||||
| desktop/views/pages/favorites.vue: | ||||
| @@ -813,7 +932,7 @@ desktop/views/pages/selectdrive.vue: | ||||
|   cancel: "キャンセル" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "検索機能を利用することができません。" | ||||
|   not-available: "検索機能はインスタンスの設定で無効になっています。" | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "{}で共有" | ||||
| @@ -906,12 +1025,15 @@ mobile/views/components/drive-file-chooser.vue: | ||||
|   select-file: "ファイルを選択" | ||||
| mobile/views/components/drive-folder-chooser.vue: | ||||
|   select-folder: "フォルダーを選択" | ||||
| mobile/views/components/drive.file.vue: | ||||
|   nsfw: "閲覧注意" | ||||
| mobile/views/components/drive.file-detail.vue: | ||||
|   download: "ダウンロード" | ||||
|   rename: "名前を変更" | ||||
|   move: "移動" | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -931,8 +1053,6 @@ mobile/views/components/friends-maker.vue: | ||||
|   close: "閉じる" | ||||
| mobile/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   more: "もっと見る" | ||||
|   less: "隠す" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   location: "位置情報" | ||||
| @@ -992,6 +1112,7 @@ mobile/views/components/ui.nav.vue: | ||||
|   game: "ゲーム" | ||||
|   darkmode: "ダークモード" | ||||
|   settings: "設定" | ||||
|   admin: "管理" | ||||
|   about: "Misskeyについて" | ||||
| mobile/views/components/user-timeline.vue: | ||||
|   no-notes: "このユーザーは投稿していないようです。" | ||||
| @@ -1020,6 +1141,8 @@ mobile/views/pages/home.vue: | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| mobile/views/pages/welcome.vue: | ||||
| @@ -1060,6 +1183,9 @@ mobile/views/pages/settings/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
| @@ -1081,15 +1207,23 @@ mobile/views/pages/settings.vue: | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   timeline: "タイムライン" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteを表示する" | ||||
|   show-renoted-my-notes: "Renoteされた自分の投稿を表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteを表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteを表示する" | ||||
|   post-style: "投稿の表示スタイル" | ||||
|   post-style-standard: "標準" | ||||
|   post-style-smart: "スマート" | ||||
|   notification-position: "通知の表示" | ||||
|   notification-position-bottom: "下" | ||||
|   notification-position-top: "上" | ||||
|   behavior: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   load-raw-images: "添付された画像を高画質で表示する" | ||||
|   load-remote-media: "リモートサーバーのメディアを表示する" | ||||
| @@ -1108,6 +1242,8 @@ mobile/views/pages/settings.vue: | ||||
|   update-available-desc: "ページを再度読み込みすると更新が適用されます。" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   following: "フォロー" | ||||
| @@ -6,6 +6,19 @@ common: | ||||
|   misskey: "⭐ Fediwersum" | ||||
|   about-title: "⭐ Fediwersum" | ||||
|   about: "Dziękujemy za znalezienie Misskey. Misskey jest <b>zdecentralizowaną platformą mikroblogową</b> powstałą na Ziemi. Ponieważ działa ona w Fediwersum (uniwersum, w którego skład wchodzi wiele sieci społecznościowych), jest ona połączona z innymi platformami społecznościowymi. Spróbujesz odpocząć od zatłoczoneo miasta i zanurzyć się w nowym Internecie?" | ||||
|   intro: | ||||
|     title: "Misskeyって?" | ||||
|     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" | ||||
|     features: "特徴" | ||||
|     rich-contents: "投稿" | ||||
|     rich-contents-desc: "自分の考え、話題の出来事、皆と共有したいことについて発信してください。必要であれば、様々な構文を使って投稿を装飾したり、好きな画像、動画などのファイルやアンケートを添付することもできます。" | ||||
|     reaction: "リアクション" | ||||
|     reaction-desc: "あなたの気持ちを伝える最も簡単な方法です。Misskeyは、他のユーザーの投稿に様々なリアクションを付けることができます。いちどMisskeyのリアクション機能を体験してしまうと、もう「いいね」の概念しか存在しないSNSには戻れなくなるかもしれません。" | ||||
|     ui: "インターフェース" | ||||
|     ui-desc: "どのようなUIが使いやすいかは人それぞれです。だから、Misskeyは自由度の高いUIを持っています。レイアウトやデザインを調整したり、カスタマイズ可能な様々なウィジェットを配置したりして、自分だけのホームを作ってください。" | ||||
|     drive: "ドライブ" | ||||
|     drive-desc: "以前投稿したことのある画像をまた投稿したくなったことはありませんか?もしくは、アップロードしたファイルをフォルダ分けして整理したくなったことはありませんか?Misskeyの根幹に組み込まれたドライブ機能によってそれらが解決します。ファイルの共有も簡単です。" | ||||
|     outro: "他にもMisskeyにしかない機能はまだまだあるので、ぜひあなた自身の目で確かめてください。Misskeyは分散型SNSなので、このインスタンスが気に入らなければ他のインスタンスを試すこともできます。それでは、GLHF!" | ||||
|   adblock: | ||||
|     detected: "Spróbuj wyłączyć blokadę reklam." | ||||
|     warning: "<strong>Misskey nie zawiera reklam</strong>, ale część funkcji może nie działać prawidłowo z włączonym blokowaniem reklam." | ||||
| @@ -39,7 +52,7 @@ common: | ||||
|     weeks_ago: "{} tyg. temu" | ||||
|     months_ago: "{} mies. temu" | ||||
|     years_ago: "{} lat temu" | ||||
|   month-and-day: "{month}月 {day}日" | ||||
|   month-and-day: "{month}-{day}" | ||||
|   trash: "Kosz" | ||||
|   weekday-short: | ||||
|     sunday: "N" | ||||
| @@ -58,7 +71,7 @@ common: | ||||
|     friday: "Piątek" | ||||
|     saturday: "Sobota" | ||||
|   reactions: | ||||
|     like: "Lubię" | ||||
|     like: "いいね" | ||||
|     love: "Kocham" | ||||
|     laugh: "Śmieszne" | ||||
|     hmm: "Hmm…?" | ||||
| @@ -68,6 +81,15 @@ common: | ||||
|     confused: "Zmieszany" | ||||
|     rip: "RIP" | ||||
|     pudding: "Pudding" | ||||
|   note-visibility: | ||||
|     public: "公開" | ||||
|     home: "ホーム" | ||||
|     home-desc: "ホームタイムラインにのみ公開" | ||||
|     followers: "フォロワー" | ||||
|     followers-desc: "自分のフォロワーにのみ公開" | ||||
|     specified: "ダイレクト" | ||||
|     specified-desc: "指定したユーザーにのみ公開" | ||||
|     private: "非公開" | ||||
|   note-placeholders: | ||||
|     a: "Co robisz?" | ||||
|     b: "Co się wydarzyło?" | ||||
| @@ -84,8 +106,15 @@ common: | ||||
|   my-token-regenerated: "Twój token został wygenerowany. Zostaniesz wylogowany." | ||||
|   i-like-sushi: "Wolę sushi od puddingu" | ||||
|   show-reversi-board-labels: "Pokazuj podpisy wierszy i kolumn w Reversi" | ||||
|   verified-user: "Zweryfikowany użytkownik" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   verified-user: "公式アカウント" | ||||
|   disable-animated-mfm: "Wyłącz animowany tekst we wpisach" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   show-full-acct: "ユーザー名のホストを省略しない" | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||
|   reversi: | ||||
|     drawn: "Remis" | ||||
|     my-turn: "Twoja kolej" | ||||
| @@ -126,7 +155,10 @@ common: | ||||
|     home: "Strona główna" | ||||
|     local: "Lokalne" | ||||
|     hybrid: "Społeczność" | ||||
|     hashtag: "ハッシュタグ" | ||||
|     global: "Globalne" | ||||
|     mentions: "あなた宛て" | ||||
|     direct: "ダイレクト投稿" | ||||
|     notifications: "Powiadomienia" | ||||
|     list: "Listy" | ||||
|     swap-left: "Przesuń w lewo" | ||||
| @@ -169,6 +201,9 @@ common/views/components/games/reversi/reversi.vue: | ||||
| common/views/components/games/reversi/reversi.game.vue: | ||||
|   surrender: "投了" | ||||
|   surrendered: "投了により" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
| common/views/components/games/reversi/reversi.index.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "Zagraj w Reversi ze znajomymi!" | ||||
| @@ -226,6 +261,12 @@ common/views/components/connect-failed.troubleshooter.vue: | ||||
|   success-desc: "Wygląda na to, że udało się połączyć. Odśwież stronę." | ||||
|   flush: "Wyczyść pamięć podręczną" | ||||
|   set-version: "Określ wersję" | ||||
| common/views/components/media-banner.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "隠す" | ||||
|   show: "もっと見る" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "Znajdź użytkownika" | ||||
|   you: "Ty" | ||||
| @@ -256,6 +297,8 @@ common/views/components/nav.vue: | ||||
|   develop: "Autorzy" | ||||
|   feedback: "Podziel się opinią" | ||||
| common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "Dodaj do ulubionych" | ||||
|   pin: "Przypnij do profilu" | ||||
|   delete: "Usuń" | ||||
| @@ -284,7 +327,10 @@ common/views/components/signin.vue: | ||||
|   signin: "Zaloguj" | ||||
|   or: "または" | ||||
|   signin-with-twitter: "Zaloguj się za pomocą Twittera" | ||||
|   login-failed: "ログインできませんでした。ユーザー名とパスワードを確認してください。" | ||||
| common/views/components/signup.vue: | ||||
|   invitation-code: "招待コード" | ||||
|   invitation-info: "招待コードをお持ちでない方は、<a href=\"{}\">管理者</a>までご連絡ください。" | ||||
|   username: "Nazwa użytkownika" | ||||
|   checking: "Sprawdzanie…" | ||||
|   available: "Dostępna" | ||||
| @@ -330,6 +376,9 @@ common/views/components/visibility-chooser.vue: | ||||
|   specified: "Bezpośredni" | ||||
|   specified-desc: "Tylko dla określonych użytkowników" | ||||
|   private: "Prywatny" | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "Sprawdzanie" | ||||
|   no-broadcasts: "Brak transmisji" | ||||
| @@ -353,8 +402,6 @@ common/views/widgets/posts-monitor.vue: | ||||
|   toggle: "Przełącz widok" | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "Hashtagi" | ||||
|   count: "Wspomniany przez {} użytkowników" | ||||
|   empty: "Brak popularnych hashtagów" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "Informacje o serwerze" | ||||
|   toggle: "Przełącz widok" | ||||
| @@ -395,15 +442,16 @@ common/views/pages/follow.vue: | ||||
|   follow-request: "Poproś o śledzenie" | ||||
| desktop: | ||||
|   banner-crop-title: "バナーとして表示する部分を選択" | ||||
|   banner: "バナー" | ||||
|   uploading-banner: "新しいバナーをアップロードしています" | ||||
|   banner-updated: "バナーを更新しました" | ||||
|   choose-banner: "バナーにする画像を選択" | ||||
|   avatar-crop-title: "アバターとして表示する部分を選択" | ||||
|   avatar: "アバター" | ||||
|   uploading-avatar: "新しいアバターをアップロードしています" | ||||
|   avatar-updated: "アバターを更新しました" | ||||
|   choose-avatar: "アバターにする画像を選択" | ||||
|   banner: "Baner" | ||||
|   uploading-banner: "Wysyłanie baneru" | ||||
|   banner-updated: "Zmieniono baner" | ||||
|   choose-banner: "Wybierz baner" | ||||
|   avatar-crop-title: "Wybierz część obrazu, która zostanie użyta jako awatar" | ||||
|   avatar: "Awatar" | ||||
|   uploading-avatar: "Wysyłanie awatara" | ||||
|   avatar-updated: "Wysłano awatar" | ||||
|   choose-avatar: "Wybierz awatar" | ||||
|   invalid-filetype: "この形式のファイルはサポートされていません" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Czarny … Łącznie" | ||||
|   notes: "Niebieski … Wpisy" | ||||
| @@ -417,6 +465,28 @@ desktop/views/components/calendar.vue: | ||||
|   prev: "Poprzedni miesiąc" | ||||
|   next: "Następny miesiąc" | ||||
|   go: "Naciśnij, aby przejść" | ||||
| desktop/views/components/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の累計" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの累計" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の累計" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の累計" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| desktop/views/components/choose-file-from-drive-window.vue: | ||||
|   choose-file: "Wybierz plik" | ||||
|   upload: "Wyślij pliki z Twojego komputera" | ||||
| @@ -437,6 +507,7 @@ desktop/views/components/drive-window.vue: | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "Awatar" | ||||
|   banner: "Baner" | ||||
|   nsfw: "閲覧注意" | ||||
|   contextmenu: | ||||
|     rename: "Zmień nazwę" | ||||
|     mark-as-sensitive: "Oznacz jako zawartość wrażliwą" | ||||
| @@ -538,8 +609,6 @@ desktop/views/components/notes.note.vue: | ||||
|   detail: "Pokaż szczegóły" | ||||
|   private: "ten wpis jest prywatny" | ||||
|   deleted: "ten wpis został usunięty" | ||||
|   hide: "Zwiń" | ||||
|   see-more: "Więcej" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "Ładowanie nie powiodło się." | ||||
|   retry: "Spróbuj ponownie" | ||||
| @@ -609,6 +678,9 @@ desktop/views/components/settings.vue: | ||||
|   behaviour: "Zachowanie" | ||||
|   fetch-on-scroll: "Automatycznie ładuj po przeciągnięciu w dół" | ||||
|   fetch-on-scroll-desc: "Po przewinięciu na dół strony automatycznie zostaną załadowane nowe treści." | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   auto-popout: "Automatycznie pojawiające się okna" | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   advanced: "Ustawienia zaawansowane" | ||||
| @@ -620,11 +692,15 @@ desktop/views/components/settings.vue: | ||||
|   delete-wallpaper: "Usuń tło" | ||||
|   dark-mode: "Tryb ciemny" | ||||
|   circle-icons: "Używaj okrągłych ikon" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   gradient-window-header: "Używaj gradientów na pasku tytułu okna" | ||||
|   post-form-on-timeline: "Wyświetlaj formularz tworzenia wpisu w górnej części osi czasu" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "Pokazuj cel odpowiedzi" | ||||
|   show-my-renotes: "Pokazuj moje udostępnienia na osi czasu" | ||||
|   show-renoted-my-notes: "Pokazuj udostępnienia moich wpisów na osi czasu" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "Automatycznie pokazuj mapę" | ||||
|   show-maps-desc: "Mapa będzie automatycznie rozwijana dla wpisów zawierających informacje o lokalizacji." | ||||
|   sound: "Dźwięk" | ||||
| @@ -717,7 +793,7 @@ desktop/views/components/settings.profile.vue: | ||||
|   birthday: "Data urodzenia" | ||||
|   save: "Aktualizuj profil" | ||||
|   locked-account: "Zabezpiecz swoje konto" | ||||
|   is-locked: "Uczyń wpis prywatnym" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "Inne" | ||||
|   is-bot: "To konto jest prowadzone przez bota" | ||||
|   is-cat: "To konto jest prowadzone przez kota" | ||||
| @@ -734,7 +810,13 @@ desktop/views/components/timeline.vue: | ||||
|   local: "Lokalne" | ||||
|   hybrid: "Społeczność" | ||||
|   global: "Globalne" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
|   list: "Listy" | ||||
|   hashtag: "ハッシュタグ" | ||||
|   add-tag-timeline: "ハッシュタグを追加" | ||||
|   add-list: "リストを追加" | ||||
|   list-name: "リスト名" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "Witaj ponownie," | ||||
|   adjective: "さん" | ||||
| @@ -745,6 +827,7 @@ desktop/views/components/ui.header.account.vue: | ||||
|   lists: "Listy" | ||||
|   follow-requests: "Prośby o śledzenie" | ||||
|   customize: "Dostosuj stronę główną" | ||||
|   admin: "管理" | ||||
|   settings: "Ustawienia" | ||||
|   signout: "Wyloguj się" | ||||
|   dark: "Sprowadź ciemność" | ||||
| @@ -781,6 +864,34 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "Pop-out" | ||||
|   close: "Zamknij" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "ドライブ" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   invite: "招待" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "Tylko wpisy z zawartością multimedialną" | ||||
|   is-media-view: "Widok multimediów" | ||||
| @@ -789,6 +900,11 @@ desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "Udostępniono przez {}" | ||||
|   private: "ten wpis jest prywatny" | ||||
|   deleted: "ten wpis został usunięty" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "O Misskey" | ||||
|   gotit: "Rozumiem!" | ||||
| @@ -797,7 +913,10 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "Zaloguj się" | ||||
|   signup-button: "Zarejestruj się" | ||||
|   timeline: "Oś czasu" | ||||
|   announcements: "お知らせ" | ||||
|   photos: "最近の画像" | ||||
|   powered-by-misskey: "Oparto o <b>Misskey</b>." | ||||
|   info: "情報" | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Dysk Misskey" | ||||
| desktop/views/pages/favorites.vue: | ||||
| @@ -813,7 +932,7 @@ desktop/views/pages/selectdrive.vue: | ||||
|   cancel: "Anuluj" | ||||
|   upload: "Wyślij pliki z Twojego komputera" | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "Funkcja wyszukiwania nie może zostać wykorzystywana." | ||||
|   not-available: "検索機能はインスタンスの設定で無効になっています。" | ||||
|   not-found: "Nie znaleziono wpisów zawierających „{}”" | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "Udostępnij z {}." | ||||
| @@ -906,12 +1025,15 @@ mobile/views/components/drive-file-chooser.vue: | ||||
|   select-file: "Wybierz plik" | ||||
| mobile/views/components/drive-folder-chooser.vue: | ||||
|   select-folder: "Wybierz katalog" | ||||
| mobile/views/components/drive.file.vue: | ||||
|   nsfw: "閲覧注意" | ||||
| mobile/views/components/drive.file-detail.vue: | ||||
|   download: "Pobierz" | ||||
|   rename: "Zmień nazwę" | ||||
|   move: "Przenieś" | ||||
|   hash: "Hash (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "To jest zawartość NSFW" | ||||
|   click-to-show: "Naciśnij aby wyświetlić" | ||||
| @@ -931,8 +1053,6 @@ mobile/views/components/friends-maker.vue: | ||||
|   close: "Zamknij" | ||||
| mobile/views/components/note.vue: | ||||
|   reposted-by: "Udostępniono przez {}" | ||||
|   more: "Rozwiń" | ||||
|   less: "Zwiń" | ||||
|   private: "ten wpis jest prywatny" | ||||
|   deleted: "ten wpis został usunięty" | ||||
|   location: "Informacje o lokalizacji" | ||||
| @@ -992,6 +1112,7 @@ mobile/views/components/ui.nav.vue: | ||||
|   game: "Gry" | ||||
|   darkmode: "Tryb ciemny" | ||||
|   settings: "Ustawienia" | ||||
|   admin: "管理" | ||||
|   about: "O Misskey" | ||||
| mobile/views/components/user-timeline.vue: | ||||
|   no-notes: "Wygląda na to, że ten użytkownik nie opublikował jeszcze niczego" | ||||
| @@ -1020,6 +1141,8 @@ mobile/views/pages/home.vue: | ||||
|   local: "Lokalne" | ||||
|   hybrid: "Społeczność" | ||||
|   global: "Globalne" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "Nie znaleziono wpisów zawierających „{}”." | ||||
| mobile/views/pages/welcome.vue: | ||||
| @@ -1060,6 +1183,9 @@ mobile/views/pages/settings/settings.profile.vue: | ||||
|   avatar: "Awatar" | ||||
|   banner: "Baner" | ||||
|   is-cat: "To konto jest prowadzone przez kota" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "Aktualizuj profil" | ||||
|   saved: "Pomyślnie zaktualizowano profil" | ||||
|   uploading: "Wysyłanie" | ||||
| @@ -1081,15 +1207,23 @@ mobile/views/pages/settings.vue: | ||||
|   dark-mode: "Tryb ciemny" | ||||
|   i-am-under-limited-internet: "Ograniczaj zużycie transferu" | ||||
|   circle-icons: "Używaj okrągłych ikon" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   timeline: "Oś czasu" | ||||
|   show-reply-target: "Pokazuj cel odpowiedzi" | ||||
|   show-my-renotes: "Pokazuj moje udostępnienia" | ||||
|   show-renoted-my-notes: "Pokazuj udostępnienia moich wpisów" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteを表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteを表示する" | ||||
|   post-style: "Styl wpisów" | ||||
|   post-style-standard: "Standardowy" | ||||
|   post-style-smart: "Inteligentny" | ||||
|   notification-position: "通知の表示" | ||||
|   notification-position-bottom: "下" | ||||
|   notification-position-top: "上" | ||||
|   behavior: "Zachowanie" | ||||
|   fetch-on-scroll: "Automatycznie ładuj po przeciągnięciu w dół" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   disable-via-mobile: "Nie oznaczaj wpisów jako „wysłane z telefonu”" | ||||
|   load-raw-images: "Wyświetlaj załączone zdjęcia w wysokiej jakości" | ||||
|   load-remote-media: "Wyświetlaj zawartość multimedialną ze zdalnych serwerów" | ||||
| @@ -1108,6 +1242,8 @@ mobile/views/pages/settings.vue: | ||||
|   update-available-desc: "Odśwież stronę, aby zastosować aktualizację." | ||||
|   settings: "Ustawienia" | ||||
|   signout: "Wyloguj" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "Śledzi Cię" | ||||
|   following: "Śledzeni" | ||||
| @@ -1163,4 +1299,4 @@ docs: | ||||
|       type: "Rodzaj" | ||||
|       description: "Opis" | ||||
| dev/views/index.vue: | ||||
|   manage-apps: "アプリの管理" | ||||
|   manage-apps: "Zarządzaj aplikacjami" | ||||
							
								
								
									
										1302
									
								
								locales/pt-PT.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1302
									
								
								locales/pt-PT.yml
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -6,6 +6,19 @@ common: | ||||
|   misskey: "A ⭐ of fediverse" | ||||
|   about-title: "A ⭐ of fediverse." | ||||
|   about: "Misskeyを見つけていただき、ありがとうございます。Misskeyは、地球で生まれた<b>分散マイクロブログSNS</b>です。Fediverse(様々なSNSで構成される宇宙)の中に存在するため、他のSNSと相互に繋がっています。暫し都会の喧騒から離れて、新しいインターネットにダイブしてみませんか。" | ||||
|   intro: | ||||
|     title: "Misskeyって?" | ||||
|     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" | ||||
|     features: "特徴" | ||||
|     rich-contents: "投稿" | ||||
|     rich-contents-desc: "自分の考え、話題の出来事、皆と共有したいことについて発信してください。必要であれば、様々な構文を使って投稿を装飾したり、好きな画像、動画などのファイルやアンケートを添付することもできます。" | ||||
|     reaction: "リアクション" | ||||
|     reaction-desc: "あなたの気持ちを伝える最も簡単な方法です。Misskeyは、他のユーザーの投稿に様々なリアクションを付けることができます。いちどMisskeyのリアクション機能を体験してしまうと、もう「いいね」の概念しか存在しないSNSには戻れなくなるかもしれません。" | ||||
|     ui: "インターフェース" | ||||
|     ui-desc: "どのようなUIが使いやすいかは人それぞれです。だから、Misskeyは自由度の高いUIを持っています。レイアウトやデザインを調整したり、カスタマイズ可能な様々なウィジェットを配置したりして、自分だけのホームを作ってください。" | ||||
|     drive: "ドライブ" | ||||
|     drive-desc: "以前投稿したことのある画像をまた投稿したくなったことはありませんか?もしくは、アップロードしたファイルをフォルダ分けして整理したくなったことはありませんか?Misskeyの根幹に組み込まれたドライブ機能によってそれらが解決します。ファイルの共有も簡単です。" | ||||
|     outro: "他にもMisskeyにしかない機能はまだまだあるので、ぜひあなた自身の目で確かめてください。Misskeyは分散型SNSなので、このインスタンスが気に入らなければ他のインスタンスを試すこともできます。それでは、GLHF!" | ||||
|   adblock: | ||||
|     detected: "広告ブロッカーを無効にしてください" | ||||
|     warning: "<strong>Misskeyは広告を掲載していません</strong>が、広告をブロックする機能が有効だと一部の機能が利用できなかったり、不具合が発生する場合があります。" | ||||
| @@ -68,6 +81,15 @@ common: | ||||
|     confused: "こまこまのこまり" | ||||
|     rip: "RIP" | ||||
|     pudding: "Pudding" | ||||
|   note-visibility: | ||||
|     public: "公開" | ||||
|     home: "ホーム" | ||||
|     home-desc: "ホームタイムラインにのみ公開" | ||||
|     followers: "フォロワー" | ||||
|     followers-desc: "自分のフォロワーにのみ公開" | ||||
|     specified: "ダイレクト" | ||||
|     specified-desc: "指定したユーザーにのみ公開" | ||||
|     private: "非公開" | ||||
|   note-placeholders: | ||||
|     a: "今どうしてる?" | ||||
|     b: "何かありましたか?" | ||||
| @@ -84,8 +106,15 @@ common: | ||||
|   my-token-regenerated: "あなたのトークンが更新されたのでサインアウトします。" | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   verified-user: "認証済みのユーザー" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   verified-user: "公式アカウント" | ||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   show-full-acct: "ユーザー名のホストを省略しない" | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
| @@ -126,7 +155,10 @@ common: | ||||
|     home: "ホーム" | ||||
|     local: "ローカル" | ||||
|     hybrid: "ソーシャル" | ||||
|     hashtag: "ハッシュタグ" | ||||
|     global: "グローバル" | ||||
|     mentions: "あなた宛て" | ||||
|     direct: "ダイレクト投稿" | ||||
|     notifications: "通知" | ||||
|     list: "リスト" | ||||
|     swap-left: "左に移動" | ||||
| @@ -169,6 +201,9 @@ common/views/components/games/reversi/reversi.vue: | ||||
| common/views/components/games/reversi/reversi.game.vue: | ||||
|   surrender: "投了" | ||||
|   surrendered: "投了により" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
| common/views/components/games/reversi/reversi.index.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "他のMisskeyユーザーとリバーシで対戦しよう" | ||||
| @@ -226,6 +261,12 @@ common/views/components/connect-failed.troubleshooter.vue: | ||||
|   success-desc: "正常に接続できるようです。ページを再度読み込みしてください。" | ||||
|   flush: "キャッシュの削除" | ||||
|   set-version: "バージョン指定" | ||||
| common/views/components/media-banner.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "隠す" | ||||
|   show: "もっと見る" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "ユーザーを探す" | ||||
|   you: "あなた" | ||||
| @@ -256,6 +297,8 @@ common/views/components/nav.vue: | ||||
|   develop: "開発者" | ||||
|   feedback: "フィードバック" | ||||
| common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   pin: "ピン留め" | ||||
|   delete: "削除" | ||||
| @@ -284,7 +327,10 @@ common/views/components/signin.vue: | ||||
|   signin: "サインイン" | ||||
|   or: "または" | ||||
|   signin-with-twitter: "Twitterでログイン" | ||||
|   login-failed: "ログインできませんでした。ユーザー名とパスワードを確認してください。" | ||||
| common/views/components/signup.vue: | ||||
|   invitation-code: "招待コード" | ||||
|   invitation-info: "招待コードをお持ちでない方は、<a href=\"{}\">管理者</a>までご連絡ください。" | ||||
|   username: "ユーザー名" | ||||
|   checking: "確認しています..." | ||||
|   available: "利用できます" | ||||
| @@ -330,6 +376,9 @@ common/views/components/visibility-chooser.vue: | ||||
|   specified: "ダイレクト" | ||||
|   specified-desc: "指定したユーザーにのみ公開" | ||||
|   private: "非公開" | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "確認中" | ||||
|   no-broadcasts: "お知らせはありません" | ||||
| @@ -353,8 +402,6 @@ common/views/widgets/posts-monitor.vue: | ||||
|   toggle: "表示を切り替え" | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "ハッシュタグ" | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "サーバー情報" | ||||
|   toggle: "表示を切り替え" | ||||
| @@ -404,6 +451,7 @@ desktop: | ||||
|   uploading-avatar: "新しいアバターをアップロードしています" | ||||
|   avatar-updated: "アバターを更新しました" | ||||
|   choose-avatar: "アバターにする画像を選択" | ||||
|   invalid-filetype: "この形式のファイルはサポートされていません" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Black ... Total" | ||||
|   notes: "Blue ... Notes" | ||||
| @@ -417,6 +465,28 @@ desktop/views/components/calendar.vue: | ||||
|   prev: "前の月" | ||||
|   next: "次の月" | ||||
|   go: "クリックして時間遡行" | ||||
| desktop/views/components/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の累計" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの累計" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の累計" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の累計" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| desktop/views/components/choose-file-from-drive-window.vue: | ||||
|   choose-file: "ファイル選択中" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| @@ -437,6 +507,7 @@ desktop/views/components/drive-window.vue: | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   nsfw: "閲覧注意" | ||||
|   contextmenu: | ||||
|     rename: "名前を変更" | ||||
|     mark-as-sensitive: "閲覧注意に設定" | ||||
| @@ -538,8 +609,6 @@ desktop/views/components/notes.note.vue: | ||||
|   detail: "詳細" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   hide: "隠す" | ||||
|   see-more: "もっと見る" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "読み込みに失敗しました。" | ||||
|   retry: "リトライ" | ||||
| @@ -609,6 +678,9 @@ desktop/views/components/settings.vue: | ||||
|   behaviour: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込みます。" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   auto-popout: "ウィンドウの自動ポップアウト" | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   advanced: "詳細設定" | ||||
| @@ -620,11 +692,15 @@ desktop/views/components/settings.vue: | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||
|   show-renoted-my-notes: "Renoteされた自分の投稿をタイムラインに表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   show-maps-desc: "位置情報が添付された投稿のマップを自動的に展開します。" | ||||
|   sound: "サウンド" | ||||
| @@ -717,7 +793,7 @@ desktop/views/components/settings.profile.vue: | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
| @@ -734,7 +810,13 @@ desktop/views/components/timeline.vue: | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
|   list: "リスト" | ||||
|   hashtag: "ハッシュタグ" | ||||
|   add-tag-timeline: "ハッシュタグを追加" | ||||
|   add-list: "リストを追加" | ||||
|   list-name: "リスト名" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
|   adjective: "さん" | ||||
| @@ -745,6 +827,7 @@ desktop/views/components/ui.header.account.vue: | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
|   customize: "ホームのカスタマイズ" | ||||
|   admin: "管理" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   dark: "闇に飲まれる" | ||||
| @@ -781,6 +864,34 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "ドライブ" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   invite: "招待" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "メディア投稿のみ" | ||||
|   is-media-view: "メディアビュー" | ||||
| @@ -789,6 +900,11 @@ desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "詳しく..." | ||||
|   gotit: "わかった" | ||||
| @@ -797,7 +913,10 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "やってる" | ||||
|   signup-button: "やる" | ||||
|   timeline: "タイムライン" | ||||
|   announcements: "お知らせ" | ||||
|   photos: "最近の画像" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
|   info: "情報" | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Misskey Drive" | ||||
| desktop/views/pages/favorites.vue: | ||||
| @@ -813,7 +932,7 @@ desktop/views/pages/selectdrive.vue: | ||||
|   cancel: "キャンセル" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "検索機能を利用することができません。" | ||||
|   not-available: "検索機能はインスタンスの設定で無効になっています。" | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "{}で共有" | ||||
| @@ -906,12 +1025,15 @@ mobile/views/components/drive-file-chooser.vue: | ||||
|   select-file: "ファイルを選択" | ||||
| mobile/views/components/drive-folder-chooser.vue: | ||||
|   select-folder: "フォルダーを選択" | ||||
| mobile/views/components/drive.file.vue: | ||||
|   nsfw: "閲覧注意" | ||||
| mobile/views/components/drive.file-detail.vue: | ||||
|   download: "ダウンロード" | ||||
|   rename: "名前を変更" | ||||
|   move: "移動" | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -931,8 +1053,6 @@ mobile/views/components/friends-maker.vue: | ||||
|   close: "閉じる" | ||||
| mobile/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   more: "もっと見る" | ||||
|   less: "隠す" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   location: "位置情報" | ||||
| @@ -992,6 +1112,7 @@ mobile/views/components/ui.nav.vue: | ||||
|   game: "ゲーム" | ||||
|   darkmode: "ダークモード" | ||||
|   settings: "設定" | ||||
|   admin: "管理" | ||||
|   about: "Misskeyについて" | ||||
| mobile/views/components/user-timeline.vue: | ||||
|   no-notes: "このユーザーは投稿していないようです。" | ||||
| @@ -1020,6 +1141,8 @@ mobile/views/pages/home.vue: | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| mobile/views/pages/welcome.vue: | ||||
| @@ -1060,6 +1183,9 @@ mobile/views/pages/settings/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
| @@ -1081,15 +1207,23 @@ mobile/views/pages/settings.vue: | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   timeline: "タイムライン" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteを表示する" | ||||
|   show-renoted-my-notes: "Renoteされた自分の投稿を表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteを表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteを表示する" | ||||
|   post-style: "投稿の表示スタイル" | ||||
|   post-style-standard: "標準" | ||||
|   post-style-smart: "スマート" | ||||
|   notification-position: "通知の表示" | ||||
|   notification-position-bottom: "下" | ||||
|   notification-position-top: "上" | ||||
|   behavior: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   load-raw-images: "添付された画像を高画質で表示する" | ||||
|   load-remote-media: "リモートサーバーのメディアを表示する" | ||||
| @@ -1108,6 +1242,8 @@ mobile/views/pages/settings.vue: | ||||
|   update-available-desc: "ページを再度読み込みすると更新が適用されます。" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   following: "フォロー" | ||||
| @@ -6,6 +6,19 @@ common: | ||||
|   misskey: "A ⭐ of fediverse" | ||||
|   about-title: "A ⭐ of fediverse." | ||||
|   about: "Misskeyを見つけていただき、ありがとうございます。Misskeyは、地球で生まれた<b>分散マイクロブログSNS</b>です。Fediverse(様々なSNSで構成される宇宙)の中に存在するため、他のSNSと相互に繋がっています。暫し都会の喧騒から離れて、新しいインターネットにダイブしてみませんか。" | ||||
|   intro: | ||||
|     title: "Misskeyって?" | ||||
|     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" | ||||
|     features: "特徴" | ||||
|     rich-contents: "投稿" | ||||
|     rich-contents-desc: "自分の考え、話題の出来事、皆と共有したいことについて発信してください。必要であれば、様々な構文を使って投稿を装飾したり、好きな画像、動画などのファイルやアンケートを添付することもできます。" | ||||
|     reaction: "リアクション" | ||||
|     reaction-desc: "あなたの気持ちを伝える最も簡単な方法です。Misskeyは、他のユーザーの投稿に様々なリアクションを付けることができます。いちどMisskeyのリアクション機能を体験してしまうと、もう「いいね」の概念しか存在しないSNSには戻れなくなるかもしれません。" | ||||
|     ui: "インターフェース" | ||||
|     ui-desc: "どのようなUIが使いやすいかは人それぞれです。だから、Misskeyは自由度の高いUIを持っています。レイアウトやデザインを調整したり、カスタマイズ可能な様々なウィジェットを配置したりして、自分だけのホームを作ってください。" | ||||
|     drive: "ドライブ" | ||||
|     drive-desc: "以前投稿したことのある画像をまた投稿したくなったことはありませんか?もしくは、アップロードしたファイルをフォルダ分けして整理したくなったことはありませんか?Misskeyの根幹に組み込まれたドライブ機能によってそれらが解決します。ファイルの共有も簡単です。" | ||||
|     outro: "他にもMisskeyにしかない機能はまだまだあるので、ぜひあなた自身の目で確かめてください。Misskeyは分散型SNSなので、このインスタンスが気に入らなければ他のインスタンスを試すこともできます。それでは、GLHF!" | ||||
|   adblock: | ||||
|     detected: "広告ブロッカーを無効にしてください" | ||||
|     warning: "<strong>Misskeyは広告を掲載していません</strong>が、広告をブロックする機能が有効だと一部の機能が利用できなかったり、不具合が発生する場合があります。" | ||||
| @@ -68,6 +81,15 @@ common: | ||||
|     confused: "こまこまのこまり" | ||||
|     rip: "RIP" | ||||
|     pudding: "Pudding" | ||||
|   note-visibility: | ||||
|     public: "公開" | ||||
|     home: "ホーム" | ||||
|     home-desc: "ホームタイムラインにのみ公開" | ||||
|     followers: "フォロワー" | ||||
|     followers-desc: "自分のフォロワーにのみ公開" | ||||
|     specified: "ダイレクト" | ||||
|     specified-desc: "指定したユーザーにのみ公開" | ||||
|     private: "非公開" | ||||
|   note-placeholders: | ||||
|     a: "今どうしてる?" | ||||
|     b: "何かありましたか?" | ||||
| @@ -84,8 +106,15 @@ common: | ||||
|   my-token-regenerated: "あなたのトークンが更新されたのでサインアウトします。" | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   verified-user: "認証済みのユーザー" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   verified-user: "公式アカウント" | ||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   show-full-acct: "ユーザー名のホストを省略しない" | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
| @@ -126,7 +155,10 @@ common: | ||||
|     home: "ホーム" | ||||
|     local: "ローカル" | ||||
|     hybrid: "ソーシャル" | ||||
|     hashtag: "ハッシュタグ" | ||||
|     global: "グローバル" | ||||
|     mentions: "あなた宛て" | ||||
|     direct: "ダイレクト投稿" | ||||
|     notifications: "通知" | ||||
|     list: "リスト" | ||||
|     swap-left: "左に移動" | ||||
| @@ -169,6 +201,9 @@ common/views/components/games/reversi/reversi.vue: | ||||
| common/views/components/games/reversi/reversi.game.vue: | ||||
|   surrender: "投了" | ||||
|   surrendered: "投了により" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
| common/views/components/games/reversi/reversi.index.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "他のMisskeyユーザーとリバーシで対戦しよう" | ||||
| @@ -226,6 +261,12 @@ common/views/components/connect-failed.troubleshooter.vue: | ||||
|   success-desc: "正常に接続できるようです。ページを再度読み込みしてください。" | ||||
|   flush: "キャッシュの削除" | ||||
|   set-version: "バージョン指定" | ||||
| common/views/components/media-banner.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "隠す" | ||||
|   show: "もっと見る" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "ユーザーを探す" | ||||
|   you: "あなた" | ||||
| @@ -256,6 +297,8 @@ common/views/components/nav.vue: | ||||
|   develop: "開発者" | ||||
|   feedback: "フィードバック" | ||||
| common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   pin: "ピン留め" | ||||
|   delete: "削除" | ||||
| @@ -284,7 +327,10 @@ common/views/components/signin.vue: | ||||
|   signin: "サインイン" | ||||
|   or: "または" | ||||
|   signin-with-twitter: "Twitterでログイン" | ||||
|   login-failed: "ログインできませんでした。ユーザー名とパスワードを確認してください。" | ||||
| common/views/components/signup.vue: | ||||
|   invitation-code: "招待コード" | ||||
|   invitation-info: "招待コードをお持ちでない方は、<a href=\"{}\">管理者</a>までご連絡ください。" | ||||
|   username: "ユーザー名" | ||||
|   checking: "確認しています..." | ||||
|   available: "利用できます" | ||||
| @@ -330,6 +376,9 @@ common/views/components/visibility-chooser.vue: | ||||
|   specified: "ダイレクト" | ||||
|   specified-desc: "指定したユーザーにのみ公開" | ||||
|   private: "非公開" | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "確認中" | ||||
|   no-broadcasts: "お知らせはありません" | ||||
| @@ -353,8 +402,6 @@ common/views/widgets/posts-monitor.vue: | ||||
|   toggle: "表示を切り替え" | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "ハッシュタグ" | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "サーバー情報" | ||||
|   toggle: "表示を切り替え" | ||||
| @@ -404,6 +451,7 @@ desktop: | ||||
|   uploading-avatar: "新しいアバターをアップロードしています" | ||||
|   avatar-updated: "アバターを更新しました" | ||||
|   choose-avatar: "アバターにする画像を選択" | ||||
|   invalid-filetype: "この形式のファイルはサポートされていません" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Black ... Total" | ||||
|   notes: "Blue ... Notes" | ||||
| @@ -417,6 +465,28 @@ desktop/views/components/calendar.vue: | ||||
|   prev: "前の月" | ||||
|   next: "次の月" | ||||
|   go: "クリックして時間遡行" | ||||
| desktop/views/components/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の累計" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの累計" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の累計" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の累計" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| desktop/views/components/choose-file-from-drive-window.vue: | ||||
|   choose-file: "ファイル選択中" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| @@ -437,6 +507,7 @@ desktop/views/components/drive-window.vue: | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   nsfw: "閲覧注意" | ||||
|   contextmenu: | ||||
|     rename: "名前を変更" | ||||
|     mark-as-sensitive: "閲覧注意に設定" | ||||
| @@ -538,8 +609,6 @@ desktop/views/components/notes.note.vue: | ||||
|   detail: "詳細" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   hide: "隠す" | ||||
|   see-more: "もっと見る" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "読み込みに失敗しました。" | ||||
|   retry: "リトライ" | ||||
| @@ -609,6 +678,9 @@ desktop/views/components/settings.vue: | ||||
|   behaviour: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込みます。" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   auto-popout: "ウィンドウの自動ポップアウト" | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   advanced: "詳細設定" | ||||
| @@ -620,11 +692,15 @@ desktop/views/components/settings.vue: | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||
|   show-renoted-my-notes: "Renoteされた自分の投稿をタイムラインに表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   show-maps-desc: "位置情報が添付された投稿のマップを自動的に展開します。" | ||||
|   sound: "サウンド" | ||||
| @@ -717,7 +793,7 @@ desktop/views/components/settings.profile.vue: | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
| @@ -734,7 +810,13 @@ desktop/views/components/timeline.vue: | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
|   list: "リスト" | ||||
|   hashtag: "ハッシュタグ" | ||||
|   add-tag-timeline: "ハッシュタグを追加" | ||||
|   add-list: "リストを追加" | ||||
|   list-name: "リスト名" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
|   adjective: "さん" | ||||
| @@ -745,6 +827,7 @@ desktop/views/components/ui.header.account.vue: | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
|   customize: "ホームのカスタマイズ" | ||||
|   admin: "管理" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   dark: "闇に飲まれる" | ||||
| @@ -781,6 +864,34 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "ドライブ" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   invite: "招待" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "メディア投稿のみ" | ||||
|   is-media-view: "メディアビュー" | ||||
| @@ -789,6 +900,11 @@ desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "詳しく..." | ||||
|   gotit: "わかった" | ||||
| @@ -797,7 +913,10 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "やってる" | ||||
|   signup-button: "やる" | ||||
|   timeline: "タイムライン" | ||||
|   announcements: "お知らせ" | ||||
|   photos: "最近の画像" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
|   info: "情報" | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Misskey Drive" | ||||
| desktop/views/pages/favorites.vue: | ||||
| @@ -813,7 +932,7 @@ desktop/views/pages/selectdrive.vue: | ||||
|   cancel: "キャンセル" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "検索機能を利用することができません。" | ||||
|   not-available: "検索機能はインスタンスの設定で無効になっています。" | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "{}で共有" | ||||
| @@ -906,12 +1025,15 @@ mobile/views/components/drive-file-chooser.vue: | ||||
|   select-file: "ファイルを選択" | ||||
| mobile/views/components/drive-folder-chooser.vue: | ||||
|   select-folder: "フォルダーを選択" | ||||
| mobile/views/components/drive.file.vue: | ||||
|   nsfw: "閲覧注意" | ||||
| mobile/views/components/drive.file-detail.vue: | ||||
|   download: "ダウンロード" | ||||
|   rename: "名前を変更" | ||||
|   move: "移動" | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -931,8 +1053,6 @@ mobile/views/components/friends-maker.vue: | ||||
|   close: "閉じる" | ||||
| mobile/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   more: "もっと見る" | ||||
|   less: "隠す" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   location: "位置情報" | ||||
| @@ -992,6 +1112,7 @@ mobile/views/components/ui.nav.vue: | ||||
|   game: "ゲーム" | ||||
|   darkmode: "ダークモード" | ||||
|   settings: "設定" | ||||
|   admin: "管理" | ||||
|   about: "Misskeyについて" | ||||
| mobile/views/components/user-timeline.vue: | ||||
|   no-notes: "このユーザーは投稿していないようです。" | ||||
| @@ -1020,6 +1141,8 @@ mobile/views/pages/home.vue: | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| mobile/views/pages/welcome.vue: | ||||
| @@ -1060,6 +1183,9 @@ mobile/views/pages/settings/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
| @@ -1081,15 +1207,23 @@ mobile/views/pages/settings.vue: | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   timeline: "タイムライン" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteを表示する" | ||||
|   show-renoted-my-notes: "Renoteされた自分の投稿を表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteを表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteを表示する" | ||||
|   post-style: "投稿の表示スタイル" | ||||
|   post-style-standard: "標準" | ||||
|   post-style-smart: "スマート" | ||||
|   notification-position: "通知の表示" | ||||
|   notification-position-bottom: "下" | ||||
|   notification-position-top: "上" | ||||
|   behavior: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   load-raw-images: "添付された画像を高画質で表示する" | ||||
|   load-remote-media: "リモートサーバーのメディアを表示する" | ||||
| @@ -1108,6 +1242,8 @@ mobile/views/pages/settings.vue: | ||||
|   update-available-desc: "ページを再度読み込みすると更新が適用されます。" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   following: "フォロー" | ||||
							
								
								
									
										79
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										79
									
								
								package.json
									
									
									
									
									
								
							| @@ -1,8 +1,8 @@ | ||||
| { | ||||
| 	"name": "misskey", | ||||
| 	"author": "syuilo <i@syuilo.com>", | ||||
| 	"version": "5.22.0", | ||||
| 	"clientVersion": "1.0.8127", | ||||
| 	"version": "8.56.0", | ||||
| 	"clientVersion": "1.0.9912", | ||||
| 	"codename": "nighthike", | ||||
| 	"main": "./built/index.js", | ||||
| 	"private": true, | ||||
| @@ -20,10 +20,10 @@ | ||||
| 		"format": "gulp format" | ||||
| 	}, | ||||
| 	"dependencies": { | ||||
| 		"@fortawesome/fontawesome": "1.1.8", | ||||
| 		"@fortawesome/fontawesome-free-brands": "5.0.13", | ||||
| 		"@fortawesome/fontawesome-free-regular": "5.0.13", | ||||
| 		"@fortawesome/fontawesome-free-solid": "5.0.13", | ||||
| 		"@fortawesome/fontawesome-svg-core": "1.2.4", | ||||
| 		"@fortawesome/free-brands-svg-icons": "5.3.1", | ||||
| 		"@fortawesome/free-regular-svg-icons": "5.3.1", | ||||
| 		"@fortawesome/free-solid-svg-icons": "5.3.1", | ||||
| 		"@koa/cors": "2.2.2", | ||||
| 		"@prezzemolo/rap": "0.1.2", | ||||
| 		"@prezzemolo/zip": "0.0.3", | ||||
| @@ -31,7 +31,8 @@ | ||||
| 		"@types/dateformat": "1.0.1", | ||||
| 		"@types/debug": "0.0.30", | ||||
| 		"@types/deep-equal": "1.0.1", | ||||
| 		"@types/elasticsearch": "5.0.25", | ||||
| 		"@types/double-ended-queue": "2.1.0", | ||||
| 		"@types/elasticsearch": "5.0.26", | ||||
| 		"@types/file-type": "5.2.1", | ||||
| 		"@types/gulp": "3.8.36", | ||||
| 		"@types/gulp-htmlmin": "1.3.32", | ||||
| @@ -54,12 +55,12 @@ | ||||
| 		"@types/koa-send": "4.1.1", | ||||
| 		"@types/koa-views": "2.0.3", | ||||
| 		"@types/koa__cors": "2.2.3", | ||||
| 		"@types/minio": "6.0.2", | ||||
| 		"@types/minio": "7.0.0", | ||||
| 		"@types/mkdirp": "0.5.2", | ||||
| 		"@types/mocha": "5.2.3", | ||||
| 		"@types/mongodb": "3.1.3", | ||||
| 		"@types/mongodb": "3.1.7", | ||||
| 		"@types/ms": "0.7.30", | ||||
| 		"@types/node": "10.5.8", | ||||
| 		"@types/node": "10.10.1", | ||||
| 		"@types/portscanner": "2.1.0", | ||||
| 		"@types/pug": "2.0.4", | ||||
| 		"@types/qrcode": "1.2.0", | ||||
| @@ -69,17 +70,17 @@ | ||||
| 		"@types/request-promise-native": "1.0.15", | ||||
| 		"@types/rimraf": "2.0.2", | ||||
| 		"@types/seedrandom": "2.4.27", | ||||
| 		"@types/sharp": "0.17.9", | ||||
| 		"@types/sharp": "0.17.10", | ||||
| 		"@types/showdown": "1.7.5", | ||||
| 		"@types/single-line-log": "1.1.0", | ||||
| 		"@types/speakeasy": "2.0.2", | ||||
| 		"@types/systeminformation": "3.23.0", | ||||
| 		"@types/tmp": "0.0.33", | ||||
| 		"@types/uuid": "3.4.3", | ||||
| 		"@types/webpack": "4.4.9", | ||||
| 		"@types/uuid": "3.4.4", | ||||
| 		"@types/webpack": "4.4.11", | ||||
| 		"@types/webpack-stream": "3.2.10", | ||||
| 		"@types/websocket": "0.0.39", | ||||
| 		"@types/ws": "5.1.2", | ||||
| 		"@types/websocket": "0.0.40", | ||||
| 		"@types/ws": "6.0.1", | ||||
| 		"animejs": "2.2.0", | ||||
| 		"autosize": "4.0.2", | ||||
| 		"autwh": "0.1.0", | ||||
| @@ -88,17 +89,18 @@ | ||||
| 		"bootstrap-vue": "2.0.0-rc.11", | ||||
| 		"cafy": "11.3.0", | ||||
| 		"chalk": "2.4.1", | ||||
| 		"chart.js": "2.7.2", | ||||
| 		"commander": "2.17.1", | ||||
| 		"crc-32": "1.2.0", | ||||
| 		"css-loader": "1.0.0", | ||||
| 		"dateformat": "3.0.3", | ||||
| 		"debug": "3.1.0", | ||||
| 		"debug": "4.0.1", | ||||
| 		"deep-equal": "1.0.1", | ||||
| 		"deepcopy": "0.6.3", | ||||
| 		"diskusage": "0.2.4", | ||||
| 		"dompurify": "1.0.5", | ||||
| 		"double-ended-queue": "2.1.0-0", | ||||
| 		"elasticsearch": "15.1.1", | ||||
| 		"element-ui": "2.4.6", | ||||
| 		"emojilib": "2.3.0", | ||||
| 		"escape-regexp": "0.0.1", | ||||
| 		"eslint": "5.0.1", | ||||
| @@ -124,12 +126,11 @@ | ||||
| 		"gulp-util": "3.0.8", | ||||
| 		"hard-source-webpack-plugin": "0.12.0", | ||||
| 		"highlight.js": "9.12.0", | ||||
| 		"html-minifier": "3.5.19", | ||||
| 		"html-minifier": "3.5.20", | ||||
| 		"http-signature": "1.2.0", | ||||
| 		"insert-text-at-cursor": "0.1.1", | ||||
| 		"is-root": "2.0.0", | ||||
| 		"is-url": "1.2.4", | ||||
| 		"jquery": "3.3.1", | ||||
| 		"js-yaml": "3.12.0", | ||||
| 		"jsdom": "11.12.0", | ||||
| 		"koa": "2.5.1", | ||||
| @@ -145,22 +146,23 @@ | ||||
| 		"koa-slow": "2.1.0", | ||||
| 		"koa-views": "6.1.4", | ||||
| 		"loader-utils": "1.1.0", | ||||
| 		"lodash.assign": "4.2.0", | ||||
| 		"mecab-async": "0.1.2", | ||||
| 		"minio": "6.0.0", | ||||
| 		"merge-options": "1.0.1", | ||||
| 		"minio": "7.0.1", | ||||
| 		"mkdirp": "0.5.1", | ||||
| 		"mocha": "5.2.0", | ||||
| 		"moji": "0.5.1", | ||||
| 		"mongodb": "3.1.1", | ||||
| 		"monk": "6.0.6", | ||||
| 		"ms": "2.1.1", | ||||
| 		"nan": "2.10.0", | ||||
| 		"node-sass": "4.9.3", | ||||
| 		"node-sass-json-importer": "3.3.1", | ||||
| 		"nan": "2.11.0", | ||||
| 		"nested-property": "0.0.7", | ||||
| 		"nprogress": "0.2.0", | ||||
| 		"object-assign-deep": "0.4.0", | ||||
| 		"on-build-webpack": "0.1.0", | ||||
| 		"os-utils": "0.0.14", | ||||
| 		"parse5": "5.0.0", | ||||
| 		"parse5": "5.1.0", | ||||
| 		"portscanner": "2.2.0", | ||||
| 		"progress-bar-webpack-plugin": "1.11.0", | ||||
| 		"promise-sequential": "1.1.1", | ||||
| @@ -173,48 +175,51 @@ | ||||
| 		"redis": "2.8.0", | ||||
| 		"request": "2.88.0", | ||||
| 		"request-promise-native": "1.0.5", | ||||
| 		"request-stats": "3.0.0", | ||||
| 		"rimraf": "2.6.2", | ||||
| 		"rndstr": "1.0.0", | ||||
| 		"s-age": "1.1.2", | ||||
| 		"sass-loader": "7.1.0", | ||||
| 		"seedrandom": "2.4.3", | ||||
| 		"sharp": "0.20.5", | ||||
| 		"seedrandom": "2.4.4", | ||||
| 		"sharp": "0.20.7", | ||||
| 		"showdown": "1.8.6", | ||||
| 		"showdown-highlightjs-extension": "0.1.2", | ||||
| 		"single-line-log": "1.1.2", | ||||
| 		"speakeasy": "2.0.0", | ||||
| 		"stringz": "1.0.0", | ||||
| 		"style-loader": "0.22.1", | ||||
| 		"style-loader": "0.23.0", | ||||
| 		"stylus": "0.54.5", | ||||
| 		"stylus-loader": "3.0.2", | ||||
| 		"summaly": "2.1.2", | ||||
| 		"systeminformation": "3.42.9", | ||||
| 		"summaly": "2.2.0", | ||||
| 		"systeminformation": "3.45.6", | ||||
| 		"syuilo-password-strength": "0.0.1", | ||||
| 		"textarea-caret": "3.1.0", | ||||
| 		"tmp": "0.0.33", | ||||
| 		"ts-loader": "4.4.1", | ||||
| 		"ts-node": "7.0.0", | ||||
| 		"ts-node": "7.0.1", | ||||
| 		"tslint": "5.10.0", | ||||
| 		"typescript": "2.9.2", | ||||
| 		"typescript-eslint-parser": "18.0.0", | ||||
| 		"uglify-es": "3.3.9", | ||||
| 		"url-loader": "1.0.1", | ||||
| 		"url-loader": "1.1.1", | ||||
| 		"uuid": "3.3.2", | ||||
| 		"v-animate-css": "0.0.2", | ||||
| 		"vue": "2.5.17", | ||||
| 		"vue-cropperjs": "2.2.1", | ||||
| 		"vue-js-modal": "1.3.16", | ||||
| 		"vue-chartjs": "3.4.0", | ||||
| 		"vue-cropperjs": "2.2.2", | ||||
| 		"vue-js-modal": "1.3.26", | ||||
| 		"vue-json-tree-view": "2.1.4", | ||||
| 		"vue-loader": "15.3.0", | ||||
| 		"vue-loader": "15.4.2", | ||||
| 		"vue-router": "3.0.1", | ||||
| 		"vue-style-loader": "4.1.1", | ||||
| 		"vue-style-loader": "4.1.2", | ||||
| 		"vue-template-compiler": "2.5.17", | ||||
| 		"vuedraggable": "2.16.0", | ||||
| 		"vuewordcloud": "18.7.11", | ||||
| 		"vuex": "3.0.1", | ||||
| 		"vuex-persistedstate": "2.5.4", | ||||
| 		"web-push": "3.3.2", | ||||
| 		"web-push": "3.3.3", | ||||
| 		"webfinger.js": "2.6.6", | ||||
| 		"webpack": "4.16.5", | ||||
| 		"webpack": "4.19.1", | ||||
| 		"webpack-cli": "3.1.0", | ||||
| 		"websocket": "1.0.26", | ||||
| 		"ws": "6.0.0", | ||||
|   | ||||
| @@ -6,6 +6,10 @@ html | ||||
| 		&, * | ||||
| 			cursor progress !important | ||||
|  | ||||
| html | ||||
| 	// iOSのため | ||||
| 	overflow auto | ||||
|  | ||||
| body | ||||
| 	overflow-wrap break-word | ||||
|  | ||||
|   | ||||
| @@ -1,3 +1,24 @@ | ||||
| <template> | ||||
| <router-view id="app"></router-view> | ||||
| <router-view id="app" v-hotkey.global="keymap"></router-view> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { url, lang } from './config'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	computed: { | ||||
| 		keymap(): any { | ||||
| 			return { | ||||
| 				'h|slash': this.help | ||||
| 			}; | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		help() { | ||||
| 			window.open(`${url}/docs/${lang}/keyboard-shortcut`, '_blank'); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
| 	<div class="app"> | ||||
| 		<section> | ||||
| 			<h2>{{ app.name }}</h2> | ||||
| 			<p class="nid">{{ app.nameId }}</p> | ||||
| 			<p class="id">{{ app.id }}</p> | ||||
| 			<p class="description">{{ app.description }}</p> | ||||
| 		</section> | ||||
| 		<section> | ||||
|   | ||||
| @@ -80,7 +80,7 @@ export default Vue.extend({ | ||||
| 		accepted() { | ||||
| 			this.state = 'accepted'; | ||||
| 			if (this.session.app.callbackUrl) { | ||||
| 				location.href = this.session.app.callbackUrl + '?token=' + this.session.token; | ||||
| 				location.href = `${this.session.app.callbackUrl}?token=${this.session.token}`; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
|   | ||||
| @@ -18,6 +18,8 @@ | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	const langs = LANGS; | ||||
|  | ||||
| 	//#region Load settings | ||||
| 	let settings = null; | ||||
| 	const vuex = localStorage.getItem('vuex'); | ||||
| @@ -32,19 +34,28 @@ | ||||
| 	//#region Detect app name | ||||
| 	let app = null; | ||||
|  | ||||
| 	if (url.pathname == '/docs' || url.pathname.startsWith('/docs/')) app = 'docs'; | ||||
| 	if (url.pathname == '/dev' || url.pathname.startsWith('/dev/')) app = 'dev'; | ||||
| 	if (url.pathname == '/auth' || url.pathname.startsWith('/auth/')) app = 'auth'; | ||||
| 	if (`${url.pathname}/`.startsWith('/docs/')) app = 'docs'; | ||||
| 	if (`${url.pathname}/`.startsWith('/dev/')) app = 'dev'; | ||||
| 	if (`${url.pathname}/`.startsWith('/auth/')) app = 'auth'; | ||||
| 	//#endregion | ||||
|  | ||||
| 	//#region Detect the user language | ||||
| 	let lang = navigator.language.split('-')[0]; | ||||
| 	let lang = null; | ||||
|  | ||||
| 	// The default language is English | ||||
| 	if (!LANGS.includes(lang)) lang = 'en'; | ||||
| 	if (langs.includes(navigator.language)) { | ||||
| 		lang = navigator.language; | ||||
| 	} else { | ||||
| 		lang = langs.find(x => x.split('-')[0] == navigator.language); | ||||
|  | ||||
| 	if (settings) { | ||||
| 		if (settings.device.lang) lang = settings.device.lang; | ||||
| 		if (lang == null) { | ||||
| 			// Fallback | ||||
| 			lang = 'en-US'; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if (settings && settings.device.lang && | ||||
| 		langs.includes(settings.device.lang)) { | ||||
| 		lang = settings.device.lang; | ||||
| 	} | ||||
| 	//#endregion | ||||
|  | ||||
| @@ -85,7 +96,7 @@ | ||||
|  | ||||
| 	// Get salt query | ||||
| 	const salt = localStorage.getItem('salt') | ||||
| 		? '?salt=' + localStorage.getItem('salt') | ||||
| 		? `?salt=${localStorage.getItem('salt')}` | ||||
| 		: ''; | ||||
|  | ||||
| 	// Load an app script | ||||
| @@ -104,7 +115,7 @@ | ||||
| 	// グローバルにタイマーIDを代入しておく | ||||
| 	window.mkBootTimer = window.setTimeout(async () => { | ||||
| 		// Fetch meta | ||||
| 		const res = await fetch(API + '/meta', { | ||||
| 		const res = await fetch('/api/meta', { | ||||
| 			method: 'POST', | ||||
| 			cache: 'no-cache' | ||||
| 		}); | ||||
| @@ -131,7 +142,7 @@ | ||||
| 		// Random | ||||
| 		localStorage.setItem('salt', Math.random().toString()); | ||||
|  | ||||
| 		// Clear cache (serive worker) | ||||
| 		// Clear cache (service worker) | ||||
| 		try { | ||||
| 			navigator.serviceWorker.controller.postMessage('clear'); | ||||
|  | ||||
|   | ||||
							
								
								
									
										109
									
								
								src/client/app/common/hotkey.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										109
									
								
								src/client/app/common/hotkey.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,109 @@ | ||||
| import keyCode from './keycode'; | ||||
| import { concat } from '../../../prelude/array'; | ||||
|  | ||||
| type pattern = { | ||||
| 	which: string[]; | ||||
| 	ctrl?: boolean; | ||||
| 	shift?: boolean; | ||||
| 	alt?: boolean; | ||||
| }; | ||||
|  | ||||
| type action = { | ||||
| 	patterns: pattern[]; | ||||
|  | ||||
| 	callback: Function; | ||||
| }; | ||||
|  | ||||
| const getKeyMap = keymap => Object.entries(keymap).map(([patterns, callback]): action => { | ||||
| 	const result = { | ||||
| 		patterns: [], | ||||
| 		callback: callback | ||||
| 	} as action; | ||||
|  | ||||
| 	result.patterns = patterns.split('|').map(part => { | ||||
| 		const pattern = { | ||||
| 			which: [], | ||||
| 			ctrl: false, | ||||
| 			alt: false, | ||||
| 			shift: false | ||||
| 		} as pattern; | ||||
|  | ||||
| 		part.trim().split('+').forEach(key => { | ||||
| 			key = key.trim().toLowerCase(); | ||||
| 			switch (key) { | ||||
| 				case 'ctrl': pattern.ctrl = true; break; | ||||
| 				case 'alt': pattern.alt = true; break; | ||||
| 				case 'shift': pattern.shift = true; break; | ||||
| 				default: pattern.which = keyCode(key).map(k => k.toLowerCase()); | ||||
| 			} | ||||
| 		}); | ||||
|  | ||||
| 		return pattern; | ||||
| 	}); | ||||
|  | ||||
| 	return result; | ||||
| }); | ||||
|  | ||||
| const ignoreElemens = ['input', 'textarea']; | ||||
|  | ||||
| export default { | ||||
| 	install(Vue) { | ||||
| 		Vue.directive('hotkey', { | ||||
| 			bind(el, binding) { | ||||
| 				el._hotkey_global = binding.modifiers.global === true; | ||||
|  | ||||
| 				const actions = getKeyMap(binding.value); | ||||
|  | ||||
| 				// flatten | ||||
| 				const reservedKeys = concat(concat(actions.map(a => a.patterns.map(p => p.which)))); | ||||
|  | ||||
| 				el.dataset.reservedKeys = reservedKeys.map(key => `'${key}'`).join(' '); | ||||
|  | ||||
| 				el._keyHandler = e => { | ||||
| 					const key = e.code.toLowerCase(); | ||||
|  | ||||
| 					const targetReservedKeys = document.activeElement ? ((document.activeElement as any).dataset || {}).reservedKeys || '' : ''; | ||||
| 					if (document.activeElement && ignoreElemens.some(el => document.activeElement.matches(el))) return; | ||||
|  | ||||
| 					for (const action of actions) { | ||||
| 						if (el._hotkey_global && targetReservedKeys.includes(`'${key}'`)) break; | ||||
|  | ||||
| 						const matched = action.patterns.some(pattern => { | ||||
| 							const matched = pattern.which.includes(key) && | ||||
| 								pattern.ctrl == e.ctrlKey && | ||||
| 								pattern.shift == e.shiftKey && | ||||
| 								pattern.alt == e.altKey; | ||||
|  | ||||
| 							if (matched) { | ||||
| 								e.preventDefault(); | ||||
| 								e.stopPropagation(); | ||||
| 								action.callback(e); | ||||
| 								return true; | ||||
| 							} else { | ||||
| 								return false; | ||||
| 							} | ||||
| 						}); | ||||
|  | ||||
| 						if (matched) { | ||||
| 							break; | ||||
| 						} | ||||
| 					} | ||||
| 				}; | ||||
|  | ||||
| 				if (el._hotkey_global) { | ||||
| 					document.addEventListener('keydown', el._keyHandler); | ||||
| 				} else { | ||||
| 					el.addEventListener('keydown', el._keyHandler); | ||||
| 				} | ||||
| 			}, | ||||
|  | ||||
| 			unbind(el) { | ||||
| 				if (el._hotkey_global) { | ||||
| 					document.removeEventListener('keydown', el._keyHandler); | ||||
| 				} else { | ||||
| 					el.removeEventListener('keydown', el._keyHandler); | ||||
| 				} | ||||
| 			} | ||||
| 		}); | ||||
| 	} | ||||
| }; | ||||
							
								
								
									
										33
									
								
								src/client/app/common/keycode.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								src/client/app/common/keycode.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | ||||
| export default (input: string): string[] => { | ||||
| 	if (Object.keys(aliases).some(a => a.toLowerCase() == input.toLowerCase())) { | ||||
| 		const codes = aliases[input]; | ||||
| 		return Array.isArray(codes) ? codes : [codes]; | ||||
| 	} else { | ||||
| 		return [input]; | ||||
| 	} | ||||
| }; | ||||
|  | ||||
| export const aliases = { | ||||
| 	'esc': 'Escape', | ||||
| 	'enter': ['Enter', 'NumpadEnter'], | ||||
| 	'up': 'ArrowUp', | ||||
| 	'down': 'ArrowDown', | ||||
| 	'left': 'ArrowLeft', | ||||
| 	'right': 'ArrowRight', | ||||
| 	'plus': ['NumpadAdd', 'Semicolon'], | ||||
| }; | ||||
|  | ||||
| /*! | ||||
| * Programatically add the following | ||||
| */ | ||||
|  | ||||
| // lower case chars | ||||
| for (let i = 97; i < 123; i++) { | ||||
| 	const char = String.fromCharCode(i); | ||||
| 	aliases[char] = `Key${char.toUpperCase()}`; | ||||
| } | ||||
|  | ||||
| // numbers | ||||
| for (let i = 0; i < 10; i++) { | ||||
| 	aliases[i] = [`Numpad${i}`, `Digit${i}`]; | ||||
| } | ||||
| @@ -9,7 +9,7 @@ export default async function(mios: MiOS, force = false, silent = false) { | ||||
| 		localStorage.setItem('should-refresh', 'true'); | ||||
| 		localStorage.setItem('v', newer); | ||||
|  | ||||
| 		// Clear cache (serive worker) | ||||
| 		// Clear cache (service worker) | ||||
| 		try { | ||||
| 			if (navigator.serviceWorker.controller) { | ||||
| 				navigator.serviceWorker.controller.postMessage('clear'); | ||||
|   | ||||
| @@ -1,2 +0,0 @@ | ||||
| const gcd = (a, b) => !b ? a : gcd(b, a % b); | ||||
| export default gcd; | ||||
							
								
								
									
										10
									
								
								src/client/app/common/scripts/get-face.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								src/client/app/common/scripts/get-face.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | ||||
| const faces = [ | ||||
| 	'(=^・・^=)', | ||||
| 	'v(\'ω\')v', | ||||
| 	'🐡( \'-\' 🐡 )フグパンチ!!!!', | ||||
| 	'🖕(´・_・`)🖕', | ||||
| 	'(。>﹏<。)', | ||||
| 	'(Δ・x・Δ)' | ||||
| ]; | ||||
|  | ||||
| export default () => faces[Math.floor(Math.random() * faces.length)]; | ||||
| @@ -1,5 +0,0 @@ | ||||
| export default () => [ | ||||
| 	'(=^・・^=)', | ||||
| 	'v(\'ω\')v', | ||||
| 	'🐡( \'-\' 🐡 )フグパンチ!!!!' | ||||
| ][Math.floor(Math.random() * 3)]; | ||||
| @@ -1,53 +0,0 @@ | ||||
| export default function(qs: string) { | ||||
| 	const q = { | ||||
| 		text: '' | ||||
| 	}; | ||||
|  | ||||
| 	qs.split(' ').forEach(x => { | ||||
| 		if (/^([a-z_]+?):(.+?)$/.test(x)) { | ||||
| 			const [key, value] = x.split(':'); | ||||
| 			switch (key) { | ||||
| 				case 'user': | ||||
| 					q['includeUserUsernames'] = value.split(','); | ||||
| 					break; | ||||
| 				case 'exclude_user': | ||||
| 					q['excludeUserUsernames'] = value.split(','); | ||||
| 					break; | ||||
| 				case 'follow': | ||||
| 					q['following'] = value == 'null' ? null : value == 'true'; | ||||
| 					break; | ||||
| 				case 'reply': | ||||
| 					q['reply'] = value == 'null' ? null : value == 'true'; | ||||
| 					break; | ||||
| 				case 'renote': | ||||
| 					q['renote'] = value == 'null' ? null : value == 'true'; | ||||
| 					break; | ||||
| 				case 'media': | ||||
| 					q['media'] = value == 'null' ? null : value == 'true'; | ||||
| 					break; | ||||
| 				case 'poll': | ||||
| 					q['poll'] = value == 'null' ? null : value == 'true'; | ||||
| 					break; | ||||
| 				case 'until': | ||||
| 				case 'since': | ||||
| 					// YYYY-MM-DD | ||||
| 					if (/^[0-9]+\-[0-9]+\-[0-9]+$/) { | ||||
| 						const [yyyy, mm, dd] = value.split('-'); | ||||
| 						q[`${key}_date`] = (new Date(parseInt(yyyy, 10), parseInt(mm, 10) - 1, parseInt(dd, 10))).getTime(); | ||||
| 					} | ||||
| 					break; | ||||
| 				default: | ||||
| 					q[key] = value; | ||||
| 					break; | ||||
| 			} | ||||
| 		} else { | ||||
| 			q.text += x + ' '; | ||||
| 		} | ||||
| 	}); | ||||
|  | ||||
| 	if (q.text) { | ||||
| 		q.text = q.text.trim(); | ||||
| 	} | ||||
|  | ||||
| 	return q; | ||||
| } | ||||
| @@ -3,8 +3,10 @@ import MiOS from '../../../../../mios'; | ||||
|  | ||||
| export class ReversiGameStream extends Stream { | ||||
| 	constructor(os: MiOS, me, game) { | ||||
| 		super(os, 'games/reversi-game', { | ||||
| 			i: me ? me.token : null, | ||||
| 		super(os, 'games/reversi-game', me ? { | ||||
| 			i: me.token, | ||||
| 			game: game.id | ||||
| 		} : { | ||||
| 			game: game.id | ||||
| 		}); | ||||
| 	} | ||||
|   | ||||
							
								
								
									
										13
									
								
								src/client/app/common/scripts/streaming/hashtag.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								src/client/app/common/scripts/streaming/hashtag.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | ||||
| import Stream from './stream'; | ||||
| import MiOS from '../../../mios'; | ||||
|  | ||||
| export class HashtagStream extends Stream { | ||||
| 	constructor(os: MiOS, me, q) { | ||||
| 		super(os, 'hashtag', me ? { | ||||
| 			i: me.token, | ||||
| 			q: JSON.stringify(q) | ||||
| 		} : { | ||||
| 			q: JSON.stringify(q) | ||||
| 		}); | ||||
| 	} | ||||
| } | ||||
| @@ -50,6 +50,30 @@ export class HomeStream extends Stream { | ||||
| 			}); | ||||
| 		}); | ||||
|  | ||||
| 		this.on('unreadMention', () => { | ||||
| 			os.store.dispatch('mergeMe', { | ||||
| 				hasUnreadMentions: true | ||||
| 			}); | ||||
| 		}); | ||||
|  | ||||
| 		this.on('readAllUnreadMentions', () => { | ||||
| 			os.store.dispatch('mergeMe', { | ||||
| 				hasUnreadMentions: false | ||||
| 			}); | ||||
| 		}); | ||||
|  | ||||
| 		this.on('unreadSpecifiedNote', () => { | ||||
| 			os.store.dispatch('mergeMe', { | ||||
| 				hasUnreadSpecifiedNotes: true | ||||
| 			}); | ||||
| 		}); | ||||
|  | ||||
| 		this.on('readAllUnreadSpecifiedNotes', () => { | ||||
| 			os.store.dispatch('mergeMe', { | ||||
| 				hasUnreadSpecifiedNotes: false | ||||
| 			}); | ||||
| 		}); | ||||
|  | ||||
| 		this.on('clientSettingUpdated', x => { | ||||
| 			os.store.commit('settings/set', { | ||||
| 				key: x.key, | ||||
|   | ||||
| @@ -7,9 +7,9 @@ import MiOS from '../../../mios'; | ||||
|  */ | ||||
| export class LocalTimelineStream extends Stream { | ||||
| 	constructor(os: MiOS, me) { | ||||
| 		super(os, 'local-timeline', { | ||||
| 		super(os, 'local-timeline', me ? { | ||||
| 			i: me.token | ||||
| 		}); | ||||
| 		} : {}); | ||||
| 	} | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,7 @@ | ||||
| import { EventEmitter } from 'eventemitter3'; | ||||
| import * as uuid from 'uuid'; | ||||
| import Connection from './stream'; | ||||
| import { erase } from '../../../../../prelude/array'; | ||||
|  | ||||
| /** | ||||
|  * ストリーム接続を管理するクラス | ||||
| @@ -89,7 +90,7 @@ export default abstract class StreamManager<T extends Connection> extends EventE | ||||
| 	 * @param userId use で発行したユーザーID | ||||
| 	 */ | ||||
| 	public dispose(userId) { | ||||
| 		this.users = this.users.filter(id => id != userId); | ||||
| 		this.users = erase(userId, this.users); | ||||
|  | ||||
| 		this._connection.user = `Managed (${ this.users.length })`; | ||||
|  | ||||
|   | ||||
| @@ -44,11 +44,11 @@ export default class Connection extends EventEmitter { | ||||
|  | ||||
| 		const query = params | ||||
| 			? Object.keys(params) | ||||
| 				.map(k => encodeURIComponent(k) + '=' + encodeURIComponent(params[k])) | ||||
| 				.map(k => `${encodeURIComponent(k)}=${encodeURIComponent(params[k])}`) | ||||
| 				.join('&') | ||||
| 			: null; | ||||
|  | ||||
| 		this.socket = new ReconnectingWebsocket(`${wsUrl}/${endpoint}${query ? '?' + query : ''}`); | ||||
| 		this.socket = new ReconnectingWebsocket(`${wsUrl}/${endpoint}${query ? `?${query}` : ''}`); | ||||
| 		this.socket.addEventListener('open', this.onOpen); | ||||
| 		this.socket.addEventListener('close', this.onClose); | ||||
| 		this.socket.addEventListener('message', this.onMessage); | ||||
|   | ||||
| @@ -1,19 +1,25 @@ | ||||
| <template> | ||||
| <span class="mk-acct"> | ||||
| 	<span class="name">@{{ user.username }}</span> | ||||
| 	<span class="host" v-if="user.host">@{{ user.host }}</span> | ||||
| 	<span class="host" :class="{ fade: $store.state.settings.contrastedAcct }" v-if="user.host || detail || $store.state.settings.showFullAcct">@{{ user.host || host }}</span> | ||||
| </span> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { host } from '../../../config'; | ||||
| export default Vue.extend({ | ||||
| 	props: ['user'] | ||||
| 	props: ['user', 'detail'], | ||||
| 	data() { | ||||
| 		return { | ||||
| 			host | ||||
| 		}; | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .mk-acct | ||||
| 	> .host | ||||
| 	> .host.fade | ||||
| 		opacity 0.5 | ||||
| </style> | ||||
|   | ||||
| @@ -125,7 +125,7 @@ export default Vue.extend({ | ||||
| 			} | ||||
|  | ||||
| 			if (this.type == 'user') { | ||||
| 				const cacheKey = 'autocomplete:user:' + this.q; | ||||
| 				const cacheKey = `autocomplete:user:${this.q}`; | ||||
| 				const cache = sessionStorage.getItem(cacheKey); | ||||
| 				if (cache) { | ||||
| 					const users = JSON.parse(cache); | ||||
| @@ -148,7 +148,7 @@ export default Vue.extend({ | ||||
| 					this.hashtags = JSON.parse(localStorage.getItem('hashtags') || '[]'); | ||||
| 					this.fetching = false; | ||||
| 				} else { | ||||
| 					const cacheKey = 'autocomplete:hashtag:' + this.q; | ||||
| 					const cacheKey = `autocomplete:hashtag:${this.q}`; | ||||
| 					const cache = sessionStorage.getItem(cacheKey); | ||||
| 					if (cache) { | ||||
| 						const hashtags = JSON.parse(cache); | ||||
|   | ||||
| @@ -1,8 +1,16 @@ | ||||
| <template> | ||||
| 	<span class="mk-avatar" :title="user | acct" :style="style" v-if="disableLink && !disablePreview" v-user-preview="user.id" @click="onClick"></span> | ||||
| 	<span class="mk-avatar" :title="user | acct" :style="style" v-else-if="disableLink && disablePreview" @click="onClick"></span> | ||||
| 	<router-link class="mk-avatar" :to="user | userPage" :title="user | acct" :target="target" :style="style" v-else-if="!disableLink && !disablePreview" v-user-preview="user.id"></router-link> | ||||
| 	<router-link class="mk-avatar" :to="user | userPage" :title="user | acct" :target="target" :style="style" v-else-if="!disableLink && disablePreview"></router-link> | ||||
| 	<span class="mk-avatar" :style="style" :class="{ cat }" :title="user | acct" v-if="disableLink && !disablePreview" v-user-preview="user.id" @click="onClick"> | ||||
| 		<span class="inner" :style="icon"></span> | ||||
| 	</span> | ||||
| 	<span class="mk-avatar" :style="style" :class="{ cat }" :title="user | acct" v-else-if="disableLink && disablePreview" @click="onClick"> | ||||
| 		<span class="inner" :style="icon"></span> | ||||
| 	</span> | ||||
| 	<router-link class="mk-avatar" :style="style" :class="{ cat }" :to="user | userPage" :title="user | acct" :target="target" v-else-if="!disableLink && !disablePreview" v-user-preview="user.id"> | ||||
| 		<span class="inner" :style="icon"></span> | ||||
| 	</router-link> | ||||
| 	<router-link class="mk-avatar" :style="style" :class="{ cat }" :to="user | userPage" :title="user | acct" :target="target" v-else-if="!disableLink && disablePreview"> | ||||
| 		<span class="inner" :style="icon"></span> | ||||
| 	</router-link> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| @@ -30,7 +38,15 @@ export default Vue.extend({ | ||||
| 		lightmode(): boolean { | ||||
| 			return this.$store.state.device.lightmode; | ||||
| 		}, | ||||
| 		cat(): boolean { | ||||
| 			return this.user.isCat && this.$store.state.settings.circleIcons; | ||||
| 		}, | ||||
| 		style(): any { | ||||
| 			return { | ||||
| 				borderRadius: this.$store.state.settings.circleIcons ? '100%' : null | ||||
| 			}; | ||||
| 		}, | ||||
| 		icon(): any { | ||||
| 			return { | ||||
| 				backgroundColor: this.lightmode | ||||
| 					? `rgb(${this.user.avatarColor.slice(0, 3).join(',')})` | ||||
| @@ -51,10 +67,47 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .mk-avatar | ||||
|  | ||||
| root(isDark) | ||||
| 	display inline-block | ||||
| 	vertical-align bottom | ||||
| 	background-size cover | ||||
|  | ||||
| 	&:not(.cat) | ||||
| 		overflow hidden | ||||
| 		border-radius 8px | ||||
|  | ||||
| 	&.cat::before, | ||||
| 	&.cat::after | ||||
| 		background #df548f | ||||
| 		border solid 4px isDark ? #e0eefd : #202224 | ||||
| 		box-sizing border-box | ||||
| 		content '' | ||||
| 		display inline-block | ||||
| 		height 50% | ||||
| 		width 50% | ||||
|  | ||||
| 	&.cat::before | ||||
| 		border-radius 0 75% 75% | ||||
| 		transform rotate(37.5deg) skew(30deg) | ||||
|  | ||||
| 	&.cat::after | ||||
| 		border-radius 75% 0 75% 75% | ||||
| 		transform rotate(-37.5deg) skew(-30deg) | ||||
|  | ||||
| 	.inner | ||||
| 		background-position center center | ||||
| 		background-size cover | ||||
| 		bottom 0 | ||||
| 		left 0 | ||||
| 		position absolute | ||||
| 		right 0 | ||||
| 		top 0 | ||||
| 		transition border-radius 1s ease | ||||
| 		z-index 1 | ||||
|  | ||||
| .mk-avatar[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .mk-avatar:not([data-darkmode]) | ||||
| 	root(false) | ||||
| </style> | ||||
|   | ||||
| @@ -57,7 +57,7 @@ export default Vue.extend({ | ||||
| 		} | ||||
|  | ||||
| 		// Check internet connection | ||||
| 		fetch('https://google.com?rand=' + Math.random(), { | ||||
| 		fetch(`https://google.com?rand=${Math.random()}`, { | ||||
| 			mode: 'no-cors' | ||||
| 		}).then(() => { | ||||
| 			this.internet = true; | ||||
|   | ||||
							
								
								
									
										44
									
								
								src/client/app/common/views/components/cw-button.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								src/client/app/common/views/components/cw-button.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,44 @@ | ||||
| <template> | ||||
| <button class="nrvgflfuaxwgkxoynpnumyookecqrrvh" @click="toggle">{{ value ? '%i18n:@hide%' : '%i18n:@show%' }}</button> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: { | ||||
| 		value: { | ||||
| 			type: Boolean, | ||||
| 			required: true | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		toggle() { | ||||
| 			this.$emit('input', !this.value); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| root(isDark) | ||||
| 	display inline-block | ||||
| 	padding 4px 8px | ||||
| 	font-size 0.7em | ||||
| 	color isDark ? #393f4f : #fff | ||||
| 	background isDark ? #687390 : #b1b9c1 | ||||
| 	border-radius 2px | ||||
| 	cursor pointer | ||||
| 	user-select none | ||||
|  | ||||
| 	&:hover | ||||
| 		background isDark ? #707b97 : #bbc4ce | ||||
|  | ||||
| .nrvgflfuaxwgkxoynpnumyookecqrrvh[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .nrvgflfuaxwgkxoynpnumyookecqrrvh:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
| @@ -18,11 +18,11 @@ | ||||
| 	</div> | ||||
|  | ||||
| 	<div class="board"> | ||||
| 		<div class="labels-x" v-if="this.$store.state.settings.reversiBoardLabels"> | ||||
| 		<div class="labels-x" v-if="this.$store.state.settings.games.reversi.showBoardLabels"> | ||||
| 			<span v-for="i in game.settings.map[0].length">{{ String.fromCharCode(64 + i) }}</span> | ||||
| 		</div> | ||||
| 		<div class="flex"> | ||||
| 			<div class="labels-y" v-if="this.$store.state.settings.reversiBoardLabels"> | ||||
| 			<div class="labels-y" v-if="this.$store.state.settings.games.reversi.showBoardLabels"> | ||||
| 				<div v-for="i in game.settings.map.length">{{ i }}</div> | ||||
| 			</div> | ||||
| 			<div class="cells" :style="cellsStyle"> | ||||
| @@ -30,15 +30,15 @@ | ||||
| 						:class="{ empty: stone == null, none: o.map[i] == 'null', isEnded: game.isEnded, myTurn: !game.isEnded && isMyTurn, can: turnUser ? o.canPut(turnUser.id == blackUser.id, i) : null, prev: o.prevPos == i }" | ||||
| 						@click="set(i)" | ||||
| 						:title="`${String.fromCharCode(65 + o.transformPosToXy(i)[0])}${o.transformPosToXy(i)[1] + 1}`"> | ||||
| 					<img v-if="stone === true" :src="blackUser.avatarUrl" alt=""> | ||||
| 					<img v-if="stone === false" :src="whiteUser.avatarUrl" alt=""> | ||||
| 					<img v-if="stone === true" :src="blackUser.avatarUrl" alt="black" :class="{ contrast: $store.state.settings.games.reversi.useContrastStones }"> | ||||
| 					<img v-if="stone === false" :src="whiteUser.avatarUrl" alt="white" :class="{ contrast: $store.state.settings.games.reversi.useContrastStones }"> | ||||
| 				</div> | ||||
| 			</div> | ||||
| 			<div class="labels-y" v-if="this.$store.state.settings.reversiBoardLabels"> | ||||
| 			<div class="labels-y" v-if="this.$store.state.settings.games.reversi.showBoardLabels"> | ||||
| 				<div v-for="i in game.settings.map.length">{{ i }}</div> | ||||
| 			</div> | ||||
| 		</div> | ||||
| 		<div class="labels-x" v-if="this.$store.state.settings.reversiBoardLabels"> | ||||
| 		<div class="labels-x" v-if="this.$store.state.settings.games.reversi.showBoardLabels"> | ||||
| 			<span v-for="i in game.settings.map[0].length">{{ String.fromCharCode(64 + i) }}</span> | ||||
| 		</div> | ||||
| 	</div> | ||||
| @@ -50,15 +50,21 @@ | ||||
| 	</div> | ||||
|  | ||||
| 	<div class="player" v-if="game.isEnded"> | ||||
| 		<el-button-group> | ||||
| 			<el-button type="primary" @click="logPos = 0" :disabled="logPos == 0">%fa:angle-double-left%</el-button> | ||||
| 			<el-button type="primary" @click="logPos--" :disabled="logPos == 0">%fa:angle-left%</el-button> | ||||
| 		</el-button-group> | ||||
| 		<div> | ||||
| 			<button @click="logPos = 0" :disabled="logPos == 0">%fa:angle-double-left%</button> | ||||
| 			<button @click="logPos--" :disabled="logPos == 0">%fa:angle-left%</button> | ||||
| 		</div> | ||||
| 		<span>{{ logPos }} / {{ logs.length }}</span> | ||||
| 		<el-button-group> | ||||
| 			<el-button type="primary" @click="logPos++" :disabled="logPos == logs.length">%fa:angle-right%</el-button> | ||||
| 			<el-button type="primary" @click="logPos = logs.length" :disabled="logPos == logs.length">%fa:angle-double-right%</el-button> | ||||
| 		</el-button-group> | ||||
| 		<div> | ||||
| 			<button @click="logPos++" :disabled="logPos == logs.length">%fa:angle-right%</button> | ||||
| 			<button @click="logPos = logs.length" :disabled="logPos == logs.length">%fa:angle-double-right%</button> | ||||
| 		</div> | ||||
| 	</div> | ||||
|  | ||||
| 	<div class="info"> | ||||
| 		<p v-if="game.settings.isLlotheo">%i18n:@is-llotheo%</p> | ||||
| 		<p v-if="game.settings.loopedBoard">%i18n:@looped-map%</p> | ||||
| 		<p v-if="game.settings.canPutEverywhere">%i18n:@can-put-everywhere%</p> | ||||
| 	</div> | ||||
| </div> | ||||
| </template> | ||||
| @@ -153,11 +159,9 @@ export default Vue.extend({ | ||||
| 				canPutEverywhere: this.game.settings.canPutEverywhere, | ||||
| 				loopedBoard: this.game.settings.loopedBoard | ||||
| 			}); | ||||
| 			this.logs.forEach((log, i) => { | ||||
| 				if (i < v) { | ||||
| 			for (const log of this.logs.slice(0, v)) { | ||||
| 				this.o.put(log.color, log.pos); | ||||
| 			} | ||||
| 			}); | ||||
| 			this.$forceUpdate(); | ||||
| 		} | ||||
| 	}, | ||||
| @@ -415,6 +419,13 @@ root(isDark) | ||||
| 						width 100% | ||||
| 						height 100% | ||||
|  | ||||
| 						&.contrast | ||||
| 							&[alt="black"] | ||||
| 								filter brightness(.5) | ||||
|  | ||||
| 							&[alt="white"] | ||||
| 								filter brightness(2) | ||||
|  | ||||
| 	> .graph | ||||
| 		display grid | ||||
| 		grid-template-columns repeat(61, 1fr) | ||||
|   | ||||
| @@ -3,7 +3,6 @@ | ||||
| 	<h1>%i18n:@title%</h1> | ||||
| 	<p>%i18n:@sub-title%</p> | ||||
| 	<div class="play"> | ||||
| 		<!--<el-button round>フリーマッチ(準備中)</el-button>--> | ||||
| 		<form-button primary round @click="match">%i18n:@invite%</form-button> | ||||
| 		<details> | ||||
| 			<summary>%i18n:@rule%</summary> | ||||
| @@ -32,6 +31,7 @@ | ||||
| 			<mk-avatar class="avatar" :user="g.user2"/> | ||||
| 			<span><b>{{ g.user1 | userName }}</b> vs <b>{{ g.user2 | userName }}</b></span> | ||||
| 			<span class="state">{{ g.isEnded ? '%i18n:@game-state.ended%' : '%i18n:@game-state.playing%' }}</span> | ||||
| 			<mk-time :time="g.createdAt" /> | ||||
| 		</a> | ||||
| 	</section> | ||||
| 	<section v-if="games.length > 0"> | ||||
| @@ -41,6 +41,7 @@ | ||||
| 			<mk-avatar class="avatar" :user="g.user2"/> | ||||
| 			<span><b>{{ g.user1 | userName }}</b> vs <b>{{ g.user2 | userName }}</b></span> | ||||
| 			<span class="state">{{ g.isEnded ? '%i18n:@game-state.ended%' : '%i18n:@game-state.playing%' }}</span> | ||||
| 			<mk-time :time="g.createdAt" /> | ||||
| 		</a> | ||||
| 	</section> | ||||
| </div> | ||||
|   | ||||
| @@ -59,11 +59,6 @@ | ||||
| 			</header> | ||||
|  | ||||
| 			<div> | ||||
| 				<el-alert v-for="message in messages" | ||||
| 						:title="message.text" | ||||
| 						:type="message.type" | ||||
| 						:key="message.id"/> | ||||
|  | ||||
| 				<template v-for="item in form"> | ||||
| 					<mk-switch v-if="item.type == 'switch'" v-model="item.value" :key="item.id" :text="item.label" @change="onChangeForm(item)">{{ item.desc || '' }}</mk-switch> | ||||
|  | ||||
| @@ -93,7 +88,7 @@ | ||||
| 						</header> | ||||
|  | ||||
| 						<div> | ||||
| 							<el-input v-model="item.value" @change="onChangeForm(item)"/> | ||||
| 							<input v-model="item.value" @change="onChangeForm(item)"/> | ||||
| 						</div> | ||||
| 					</div> | ||||
| 				</template> | ||||
|   | ||||
| @@ -1,5 +1,8 @@ | ||||
| import Vue from 'vue'; | ||||
|  | ||||
| import cwButton from './cw-button.vue'; | ||||
| import tagCloud from './tag-cloud.vue'; | ||||
| import trends from './trends.vue'; | ||||
| import analogClock from './analog-clock.vue'; | ||||
| import menu from './menu.vue'; | ||||
| import noteHeader from './note-header.vue'; | ||||
| @@ -40,6 +43,9 @@ import uiSelect from './ui/select.vue'; | ||||
| import formButton from './ui/form/button.vue'; | ||||
| import formRadio from './ui/form/radio.vue'; | ||||
|  | ||||
| Vue.component('mk-cw-button', cwButton); | ||||
| Vue.component('mk-tag-cloud', tagCloud); | ||||
| Vue.component('mk-trends', trends); | ||||
| Vue.component('mk-analog-clock', analogClock); | ||||
| Vue.component('mk-menu', menu); | ||||
| Vue.component('mk-note-header', noteHeader); | ||||
|   | ||||
							
								
								
									
										90
									
								
								src/client/app/common/views/components/media-banner.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										90
									
								
								src/client/app/common/views/components/media-banner.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,90 @@ | ||||
| <template> | ||||
| <div class="mk-media-banner"> | ||||
| 	<div class="sensitive" v-if="media.isSensitive && hide" @click="hide = false"> | ||||
| 		<span class="icon">%fa:exclamation-triangle%</span> | ||||
| 		<b>%i18n:@sensitive%</b> | ||||
| 		<span>%i18n:@click-to-show%</span> | ||||
| 	</div> | ||||
| 	<div class="audio" v-else-if="media.type.startsWith('audio')"> | ||||
| 		<audio class="audio" | ||||
| 			:src="media.url" | ||||
| 			:title="media.name" | ||||
| 			controls | ||||
| 			ref="audio" | ||||
| 			preload="metadata" /> | ||||
| 	</div> | ||||
| 	<a class="download" v-else | ||||
| 		:href="media.url" | ||||
| 		:title="media.name" | ||||
| 		:download="media.name" | ||||
| 	> | ||||
| 		<span class="icon">%fa:download%</span> | ||||
| 		<b>{{ media.name }}</b> | ||||
| 	</a> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: { | ||||
| 		media: { | ||||
| 			type: Object, | ||||
| 			required: true | ||||
| 		} | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| 			hide: true | ||||
| 		}; | ||||
| 	} | ||||
| }) | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| root(isDark) | ||||
| 	width 100% | ||||
| 	border-radius 4px | ||||
| 	margin-top 4px | ||||
| 	overflow hidden | ||||
|  | ||||
| 	> .download, | ||||
| 	> .sensitive | ||||
| 		display flex | ||||
| 		align-items center | ||||
| 		font-size 12px | ||||
| 		padding 8px 12px | ||||
| 		white-space nowrap | ||||
|  | ||||
| 		> * | ||||
| 			display block | ||||
|  | ||||
| 		> b | ||||
| 			overflow hidden | ||||
| 			text-overflow ellipsis | ||||
|  | ||||
| 		> *:not(:last-child) | ||||
| 			margin-right .2em | ||||
|  | ||||
| 		> .icon | ||||
| 			font-size 1.6em | ||||
|  | ||||
| 	> .download | ||||
| 		background isDark ? #21242d : #f7f7f7 | ||||
|  | ||||
| 	> .sensitive | ||||
| 		background #111 | ||||
| 		color #fff | ||||
|  | ||||
| 	> .audio | ||||
| 		.audio | ||||
| 			display block | ||||
| 			width 100% | ||||
|  | ||||
| .mk-media-banner[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .mk-media-banner:not([data-darkmode]) | ||||
| 	root(false) | ||||
| </style> | ||||
| @@ -1,18 +1,27 @@ | ||||
| <template> | ||||
| <div class="mk-media-list"> | ||||
| 	<div :data-count="mediaList.length" ref="grid"> | ||||
| 		<template v-for="media in mediaList"> | ||||
| 			<mk-media-video :video="media" :key="media.id" v-if="media.type.startsWith('video')" :inline-playable="mediaList.length === 1"/> | ||||
| 			<mk-media-image :image="media" :key="media.id" v-else :raw="raw"/> | ||||
| 	<template v-for="media in mediaList.filter(media => !previewable(media))"> | ||||
| 		<x-banner :media="media" :key="media.id"/> | ||||
| 	</template> | ||||
| 	<div v-if="mediaList.filter(media => previewable(media)).length > 0" class="gird-container"> | ||||
| 		<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"/> | ||||
| 			</template> | ||||
| 		</div> | ||||
| 	</div> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import XBanner from './media-banner.vue'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	components: { | ||||
| 		XBanner | ||||
| 	}, | ||||
| 	props: { | ||||
| 		mediaList: { | ||||
| 			required: true | ||||
| @@ -22,15 +31,25 @@ export default Vue.extend({ | ||||
| 		} | ||||
| 	}, | ||||
| 	mounted() { | ||||
| 		// for Safari bug | ||||
| 		//#region for Safari bug | ||||
| 		if (this.$refs.grid) { | ||||
| 			this.$refs.grid.style.height = this.$refs.grid.clientHeight ? `${this.$refs.grid.clientHeight}px` : '128px'; | ||||
| 		} | ||||
| 		//#endregion | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		previewable(file) { | ||||
| 			return file.type.startsWith('video') || file.type.startsWith('image'); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .mk-media-list | ||||
| 	> .gird-container | ||||
| 		width 100% | ||||
| 		margin-top 4px | ||||
|  | ||||
| 		&:before | ||||
| 			content '' | ||||
|   | ||||
| @@ -1,10 +1,10 @@ | ||||
| <template> | ||||
| <div class="mk-menu"> | ||||
| <div class="onchrpzrvnoruiaenfcqvccjfuupzzwv"> | ||||
| 	<div class="backdrop" ref="backdrop" @click="close"></div> | ||||
| 	<div class="popover" :class="{ hukidasi }" ref="popover"> | ||||
| 		<template v-for="item in items"> | ||||
| 		<template v-for="item, i in items"> | ||||
| 			<div v-if="item === null"></div> | ||||
| 			<button v-if="item" @click="clicked(item.action)" v-html="item.icon ? item.icon + ' ' + item.text : item.text"></button> | ||||
| 			<button v-if="item" @click="clicked(item.action)" v-html="item.icon ? item.icon + ' ' + item.text : item.text" :tabindex="i"></button> | ||||
| 		</template> | ||||
| 	</div> | ||||
| </div> | ||||
| @@ -108,7 +108,7 @@ export default Vue.extend({ | ||||
| 				easing: 'easeInBack', | ||||
| 				complete: () => { | ||||
| 					this.$emit('closed'); | ||||
| 					this.$destroy(); | ||||
| 					this.destroyDom(); | ||||
| 				} | ||||
| 			}); | ||||
| 		} | ||||
| @@ -119,9 +119,10 @@ export default Vue.extend({ | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
| 	$bg-color = isDark ? #2c303c : #fff | ||||
| 	$border-color = rgba(27, 31, 35, 0.15) | ||||
|  | ||||
| .mk-menu | ||||
| 	position initial | ||||
|  | ||||
| 	> .backdrop | ||||
| @@ -131,14 +132,14 @@ $border-color = rgba(27, 31, 35, 0.15) | ||||
| 		z-index 10000 | ||||
| 		width 100% | ||||
| 		height 100% | ||||
| 		background rgba(#000, 0.1) | ||||
| 		background rgba(#000, isDark ? 0.5 : 0.1) | ||||
| 		opacity 0 | ||||
|  | ||||
| 	> .popover | ||||
| 		position absolute | ||||
| 		z-index 10001 | ||||
| 		padding 8px 0 | ||||
| 		background #fff | ||||
| 		background $bg-color | ||||
| 		border 1px solid $border-color | ||||
| 		border-radius 4px | ||||
| 		box-shadow 0 3px 12px rgba(27, 31, 35, 0.15) | ||||
| @@ -172,12 +173,13 @@ $border-color = rgba(27, 31, 35, 0.15) | ||||
| 				border-top solid $balloon-size transparent | ||||
| 				border-left solid $balloon-size transparent | ||||
| 				border-right solid $balloon-size transparent | ||||
| 				border-bottom solid $balloon-size #fff | ||||
| 				border-bottom solid $balloon-size $bg-color | ||||
|  | ||||
| 		> button | ||||
| 			display block | ||||
| 			padding 8px 16px | ||||
| 			width 100% | ||||
| 			color isDark ? #d6dce2 : #111 | ||||
|  | ||||
| 			&:hover | ||||
| 				color $theme-color-foreground | ||||
| @@ -191,6 +193,12 @@ $border-color = rgba(27, 31, 35, 0.15) | ||||
| 		> div | ||||
| 			margin 8px 0 | ||||
| 			height 1px | ||||
| 			background #eee | ||||
| 			background isDark ? #1c2023 : #eee | ||||
|  | ||||
| .onchrpzrvnoruiaenfcqvccjfuupzzwv[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .onchrpzrvnoruiaenfcqvccjfuupzzwv:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -3,7 +3,7 @@ | ||||
| 	@dragover.prevent.stop="onDragover" | ||||
| 	@drop.prevent.stop="onDrop" | ||||
| > | ||||
| 	<div class="stream"> | ||||
| 	<div class="body"> | ||||
| 		<p class="init" v-if="init">%fa:spinner .spin%%i18n:common.loading%</p> | ||||
| 		<p class="empty" v-if="!init && messages.length == 0">%fa:info-circle%%i18n:@empty%</p> | ||||
| 		<p class="no-history" v-if="!init && messages.length > 0 && !existMoreMessages">%fa:flag%%i18n:@no-history%</p> | ||||
| @@ -77,6 +77,12 @@ export default Vue.extend({ | ||||
| 		this.connection.on('message', this.onMessage); | ||||
| 		this.connection.on('read', this.onRead); | ||||
|  | ||||
| 		if (this.isNaked) { | ||||
| 			window.addEventListener('scroll', this.onScroll, { passive: true }); | ||||
| 		} else { | ||||
| 			this.$el.addEventListener('scroll', this.onScroll, { passive: true }); | ||||
| 		} | ||||
|  | ||||
| 		document.addEventListener('visibilitychange', this.onVisibilitychange); | ||||
|  | ||||
| 		this.fetchMessages().then(() => { | ||||
| @@ -90,6 +96,12 @@ export default Vue.extend({ | ||||
| 		this.connection.off('read', this.onRead); | ||||
| 		this.connection.close(); | ||||
|  | ||||
| 		if (this.isNaked) { | ||||
| 			window.removeEventListener('scroll', this.onScroll); | ||||
| 		} else { | ||||
| 			this.$el.removeEventListener('scroll', this.onScroll); | ||||
| 		} | ||||
|  | ||||
| 		document.removeEventListener('visibilitychange', this.onVisibilitychange); | ||||
| 	}, | ||||
|  | ||||
| @@ -226,6 +238,14 @@ export default Vue.extend({ | ||||
| 			}, 4000); | ||||
| 		}, | ||||
|  | ||||
| 		onScroll() { | ||||
| 			const el = this.isNaked ? window.document.documentElement : this.$el; | ||||
| 			const current = el.scrollTop + el.clientHeight; | ||||
| 			if (current > el.scrollHeight - 1) { | ||||
| 				this.showIndicator = false; | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
| 		onVisibilitychange() { | ||||
| 			if (document.hidden) return; | ||||
| 			this.messages.forEach(message => { | ||||
| @@ -251,7 +271,7 @@ root(isDark) | ||||
| 	height 100% | ||||
| 	background isDark ? #191b22 : #fff | ||||
|  | ||||
| 	> .stream | ||||
| 	> .body | ||||
| 		width 100% | ||||
| 		max-width 600px | ||||
| 		margin 0 auto | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| import Vue from 'vue'; | ||||
| import Vue, { VNode } from 'vue'; | ||||
| import * as emojilib from 'emojilib'; | ||||
| import { length } from 'stringz'; | ||||
| import parse from '../../../../../mfm/parse'; | ||||
| @@ -6,10 +6,7 @@ import getAcct from '../../../../../misc/acct/render'; | ||||
| import { url } from '../../../config'; | ||||
| import MkUrl from './url.vue'; | ||||
| import MkGoogle from './google.vue'; | ||||
|  | ||||
| const flatten = list => list.reduce( | ||||
| 	(a, b) => a.concat(Array.isArray(b) ? flatten(b) : b), [] | ||||
| ); | ||||
| import { concat } from '../../../../../prelude/array'; | ||||
|  | ||||
| export default Vue.component('misskey-flavored-markdown', { | ||||
| 	props: { | ||||
| @@ -32,20 +29,20 @@ export default Vue.component('misskey-flavored-markdown', { | ||||
| 	}, | ||||
|  | ||||
| 	render(createElement) { | ||||
| 		let ast; | ||||
| 		let ast: any[]; | ||||
|  | ||||
| 		if (this.ast == null) { | ||||
| 			// Parse text to ast | ||||
| 			ast = parse(this.text); | ||||
| 		} else { | ||||
| 			ast = this.ast; | ||||
| 			ast = this.ast as any[]; | ||||
| 		} | ||||
|  | ||||
| 		let bigCount = 0; | ||||
| 		let motionCount = 0; | ||||
|  | ||||
| 		// Parse ast to DOM | ||||
| 		const els = flatten(ast.map(token => { | ||||
| 		const els = concat(ast.map((token): VNode[] => { | ||||
| 			switch (token.type) { | ||||
| 				case 'text': { | ||||
| 					const text = token.content.replace(/(\r\n|\n|\r)/g, '\n'); | ||||
| @@ -56,12 +53,12 @@ export default Vue.component('misskey-flavored-markdown', { | ||||
| 						x[x.length - 1].pop(); | ||||
| 						return x; | ||||
| 					} else { | ||||
| 						return createElement('span', text.replace(/\n/g, ' ')); | ||||
| 						return [createElement('span', text.replace(/\n/g, ' '))]; | ||||
| 					} | ||||
| 				} | ||||
|  | ||||
| 				case 'bold': { | ||||
| 					return createElement('b', token.bold); | ||||
| 					return [createElement('b', token.bold)]; | ||||
| 				} | ||||
|  | ||||
| 				case 'big': { | ||||
| @@ -95,23 +92,23 @@ export default Vue.component('misskey-flavored-markdown', { | ||||
| 				} | ||||
|  | ||||
| 				case 'url': { | ||||
| 					return createElement(MkUrl, { | ||||
| 					return [createElement(MkUrl, { | ||||
| 						props: { | ||||
| 							url: token.content, | ||||
| 							target: '_blank' | ||||
| 						} | ||||
| 					}); | ||||
| 					})]; | ||||
| 				} | ||||
|  | ||||
| 				case 'link': { | ||||
| 					return createElement('a', { | ||||
| 					return [createElement('a', { | ||||
| 						attrs: { | ||||
| 							class: 'link', | ||||
| 							href: token.url, | ||||
| 							target: '_blank', | ||||
| 							title: token.url | ||||
| 						} | ||||
| 					}, token.title); | ||||
| 					}, token.title)]; | ||||
| 				} | ||||
|  | ||||
| 				case 'mention': { | ||||
| @@ -129,16 +126,16 @@ export default Vue.component('misskey-flavored-markdown', { | ||||
| 				} | ||||
|  | ||||
| 				case 'hashtag': { | ||||
| 					return createElement('a', { | ||||
| 					return [createElement('a', { | ||||
| 						attrs: { | ||||
| 							href: `${url}/tags/${encodeURIComponent(token.hashtag)}`, | ||||
| 							target: '_blank' | ||||
| 						} | ||||
| 					}, token.content); | ||||
| 					}, token.content)]; | ||||
| 				} | ||||
|  | ||||
| 				case 'code': { | ||||
| 					return createElement('pre', { | ||||
| 					return [createElement('pre', { | ||||
| 						class: 'code' | ||||
| 					}, [ | ||||
| 						createElement('code', { | ||||
| @@ -146,15 +143,15 @@ export default Vue.component('misskey-flavored-markdown', { | ||||
| 								innerHTML: token.html | ||||
| 							} | ||||
| 						}) | ||||
| 					]); | ||||
| 					])]; | ||||
| 				} | ||||
|  | ||||
| 				case 'inline-code': { | ||||
| 					return createElement('code', { | ||||
| 					return [createElement('code', { | ||||
| 						domProps: { | ||||
| 							innerHTML: token.html | ||||
| 						} | ||||
| 					}); | ||||
| 					})]; | ||||
| 				} | ||||
|  | ||||
| 				case 'quote': { | ||||
| @@ -164,58 +161,51 @@ export default Vue.component('misskey-flavored-markdown', { | ||||
| 						const x = text2.split('\n') | ||||
| 							.map(t => [createElement('span', t), createElement('br')]); | ||||
| 						x[x.length - 1].pop(); | ||||
| 						return createElement('div', { | ||||
| 						return [createElement('div', { | ||||
| 							attrs: { | ||||
| 								class: 'quote' | ||||
| 							} | ||||
| 						}, x); | ||||
| 						}, x)]; | ||||
| 					} else { | ||||
| 						return createElement('span', { | ||||
| 						return [createElement('span', { | ||||
| 							attrs: { | ||||
| 								class: 'quote' | ||||
| 							} | ||||
| 						}, text2.replace(/\n/g, ' ')); | ||||
| 						}, text2.replace(/\n/g, ' '))]; | ||||
| 					} | ||||
| 				} | ||||
|  | ||||
| 				case 'title': { | ||||
| 					return createElement('div', { | ||||
| 					return [createElement('div', { | ||||
| 						attrs: { | ||||
| 							class: 'title' | ||||
| 						} | ||||
| 					}, token.title); | ||||
| 					}, token.title)]; | ||||
| 				} | ||||
|  | ||||
| 				case 'emoji': { | ||||
| 					const emoji = emojilib.lib[token.emoji]; | ||||
| 					return createElement('span', emoji ? emoji.char : token.content); | ||||
| 					return [createElement('span', emoji ? emoji.char : token.content)]; | ||||
| 				} | ||||
|  | ||||
| 				case 'search': { | ||||
| 					return createElement(MkGoogle, { | ||||
| 					return [createElement(MkGoogle, { | ||||
| 						props: { | ||||
| 							q: token.query | ||||
| 						} | ||||
| 					}); | ||||
| 					})]; | ||||
| 				} | ||||
|  | ||||
| 				default: { | ||||
| 					console.log('unknown ast type:', token.type); | ||||
|  | ||||
| 					return []; | ||||
| 				} | ||||
| 			} | ||||
| 		})); | ||||
|  | ||||
| 		const _els = []; | ||||
| 		els.forEach((el, i) => { | ||||
| 			if (el.tag == 'br') { | ||||
| 				if (!['div', 'pre'].includes(els[i - 1].tag)) { | ||||
| 					_els.push(el); | ||||
| 				} | ||||
| 			} else { | ||||
| 				_els.push(el); | ||||
| 			} | ||||
| 		}); | ||||
|  | ||||
| 		// el.tag === 'br' のとき i !== 0 が保証されるため、短絡評価により els[i - 1] は配列外参照しない | ||||
| 		const _els = els.filter((el, i) => !(el.tag === 'br' && ['div', 'pre'].includes(els[i - 1].tag))); | ||||
| 		return createElement('span', _els); | ||||
| 	} | ||||
| }); | ||||
|   | ||||
| @@ -6,7 +6,7 @@ | ||||
| 	<i>・</i> | ||||
| 	<a :href="feedbackUrl" target="_blank">%i18n:@feedback%</a> | ||||
| 	<i>・</i> | ||||
| 	<a :href="devUrl">%i18n:@develop%</a> | ||||
| 	<a href="/dev">%i18n:@develop%</a> | ||||
| 	<i>・</i> | ||||
| 	<a href="https://twitter.com/misskey_xyz" target="_blank">Follow us on %fa:B twitter%</a> | ||||
| </span> | ||||
| @@ -14,18 +14,21 @@ | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { docsUrl, statsUrl, statusUrl, devUrl, repositoryUrl, feedbackUrl, lang } from '../../../config'; | ||||
| import { lang } from '../../../config'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	data() { | ||||
| 		return { | ||||
| 			aboutUrl: `${docsUrl}/${lang}/about`, | ||||
| 			statsUrl, | ||||
| 			statusUrl, | ||||
| 			devUrl, | ||||
| 			repositoryUrl: repositoryUrl || `https://github.com/syuilo/misskey`, | ||||
| 			feedbackUrl: feedbackUrl || `https://github.com/syuilo/misskey/issues/new` | ||||
| 			aboutUrl: `/docs/${lang}/about`, | ||||
| 			repositoryUrl: 'https://github.com/syuilo/misskey', | ||||
| 			feedbackUrl: 'https://github.com/syuilo/misskey/issues/new' | ||||
| 		} | ||||
| 	}, | ||||
| 	created() { | ||||
| 		(this as any).os.getMeta().then(meta => { | ||||
| 			if (meta.maintainer.repository_url) this.repositoryUrl = meta.maintainer.repository_url; | ||||
| 			if (meta.maintainer.feedback_url) this.feedbackUrl = meta.maintainer.feedback_url; | ||||
| 		}); | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
| <header class="bvonvjxbwzaiskogyhbwgyxvcgserpmu"> | ||||
| 	<mk-avatar class="avatar" :user="note.user" v-if="$store.state.device.postStyle == 'smart'"/> | ||||
| 	<router-link class="name" :to="note.user | userPage" v-user-preview="note.user.id">{{ note.user | userName }}</router-link> | ||||
| 	<span class="is-verified" v-if="note.user.isVerified" title="%i18n:common.verified-user%">%fa:bookmark%</span> | ||||
| 	<span class="is-verified" v-if="note.user.isVerified" title="%i18n:common.verified-user%">%fa:star%</span> | ||||
| 	<span class="is-admin" v-if="note.user.isAdmin">admin</span> | ||||
| 	<span class="is-bot" v-if="note.user.isBot">bot</span> | ||||
| 	<span class="is-cat" v-if="note.user.isCat">cat</span> | ||||
|   | ||||
| @@ -6,17 +6,27 @@ | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { url } from '../../../config'; | ||||
| import copyToClipboard from '../../../common/scripts/copy-to-clipboard'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: ['note', 'source', 'compact'], | ||||
| 	computed: { | ||||
| 		items() { | ||||
| 			const items = []; | ||||
| 			items.push({ | ||||
| 			const items = [{ | ||||
| 				icon: '%fa:info-circle%', | ||||
| 				text: '%i18n:@detail%', | ||||
| 				action: this.detail | ||||
| 			}, { | ||||
| 				icon: '%fa:link%', | ||||
| 				text: '%i18n:@copy-link%', | ||||
| 				action: this.copyLink | ||||
| 			}, null, { | ||||
| 				icon: '%fa:star%', | ||||
| 				text: '%i18n:@favorite%', | ||||
| 				action: this.favorite | ||||
| 			}); | ||||
| 			}]; | ||||
|  | ||||
| 			if (this.note.userId == this.$store.state.i.id) { | ||||
| 				items.push({ | ||||
| 					icon: '%fa:thumbtack%', | ||||
| @@ -42,11 +52,19 @@ export default Vue.extend({ | ||||
| 		} | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		detail() { | ||||
| 			this.$router.push(`/notes/${ this.note.id }`); | ||||
| 		}, | ||||
|  | ||||
| 		copyLink() { | ||||
| 			copyToClipboard(`${url}/notes/${ this.note.id }`); | ||||
| 		}, | ||||
|  | ||||
| 		pin() { | ||||
| 			(this as any).api('i/pin', { | ||||
| 				noteId: this.note.id | ||||
| 			}).then(() => { | ||||
| 				this.$destroy(); | ||||
| 				this.destroyDom(); | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| @@ -55,7 +73,7 @@ export default Vue.extend({ | ||||
| 			(this as any).api('notes/delete', { | ||||
| 				noteId: this.note.id | ||||
| 			}).then(() => { | ||||
| 				this.$destroy(); | ||||
| 				this.destroyDom(); | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| @@ -63,13 +81,13 @@ export default Vue.extend({ | ||||
| 			(this as any).api('notes/favorites/create', { | ||||
| 				noteId: this.note.id | ||||
| 			}).then(() => { | ||||
| 				this.$destroy(); | ||||
| 				this.destroyDom(); | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		closed() { | ||||
| 			this.$nextTick(() => { | ||||
| 				this.$destroy(); | ||||
| 				this.destroyDom(); | ||||
| 			}); | ||||
| 		} | ||||
| 	} | ||||
|   | ||||
| @@ -20,6 +20,7 @@ | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { erase } from '../../../../../prelude/array'; | ||||
| export default Vue.extend({ | ||||
| 	data() { | ||||
| 		return { | ||||
| @@ -53,7 +54,7 @@ export default Vue.extend({ | ||||
|  | ||||
| 		get() { | ||||
| 			return { | ||||
| 				choices: this.choices.filter(choice => choice != '') | ||||
| 				choices: erase('', this.choices) | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
|   | ||||
| @@ -21,6 +21,7 @@ | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { sum } from '../../../../../prelude/array'; | ||||
| export default Vue.extend({ | ||||
| 	props: ['note'], | ||||
| 	data() { | ||||
| @@ -33,7 +34,7 @@ export default Vue.extend({ | ||||
| 			return this.note.poll; | ||||
| 		}, | ||||
| 		total(): number { | ||||
| 			return this.poll.choices.reduce((a, b) => a + b.votes, 0); | ||||
| 			return sum(this.poll.choices.map(x => x.votes)); | ||||
| 		}, | ||||
| 		isVoted(): boolean { | ||||
| 			return this.poll.choices.some(c => c.isVoted); | ||||
|   | ||||
| @@ -1,17 +1,17 @@ | ||||
| <template> | ||||
| <span class="mk-reaction-icon"> | ||||
| 	<img v-if="reaction == 'like'" src="/assets/reactions/like.png" alt="%i18n:common.reactions.like%"> | ||||
| 	<img v-if="reaction == 'love'" src="/assets/reactions/love.png" alt="%i18n:common.reactions.love%"> | ||||
| 	<img v-if="reaction == 'laugh'" src="/assets/reactions/laugh.png" alt="%i18n:common.reactions.laugh%"> | ||||
| 	<img v-if="reaction == 'hmm'" src="/assets/reactions/hmm.png" alt="%i18n:common.reactions.hmm%"> | ||||
| 	<img v-if="reaction == 'surprise'" src="/assets/reactions/surprise.png" alt="%i18n:common.reactions.surprise%"> | ||||
| 	<img v-if="reaction == 'congrats'" src="/assets/reactions/congrats.png" alt="%i18n:common.reactions.congrats%"> | ||||
| 	<img v-if="reaction == 'angry'" src="/assets/reactions/angry.png" alt="%i18n:common.reactions.angry%"> | ||||
| 	<img v-if="reaction == 'confused'" src="/assets/reactions/confused.png" alt="%i18n:common.reactions.confused%"> | ||||
| 	<img v-if="reaction == 'rip'" src="/assets/reactions/rip.png" alt="%i18n:common.reactions.rip%"> | ||||
| 	<img v-if="reaction == 'like'" src="https://twemoji.maxcdn.com/2/svg/1f44d.svg" alt="%i18n:common.reactions.like%"> | ||||
| 	<img v-if="reaction == 'love'" src="https://twemoji.maxcdn.com/2/svg/2764.svg" alt="%i18n:common.reactions.love%"> | ||||
| 	<img v-if="reaction == 'laugh'" src="https://twemoji.maxcdn.com/2/svg/1f606.svg" alt="%i18n:common.reactions.laugh%"> | ||||
| 	<img v-if="reaction == 'hmm'" src="https://twemoji.maxcdn.com/2/svg/1f914.svg" alt="%i18n:common.reactions.hmm%"> | ||||
| 	<img v-if="reaction == 'surprise'" src="https://twemoji.maxcdn.com/2/svg/1f62e.svg" alt="%i18n:common.reactions.surprise%"> | ||||
| 	<img v-if="reaction == 'congrats'" src="https://twemoji.maxcdn.com/2/svg/1f389.svg" alt="%i18n:common.reactions.congrats%"> | ||||
| 	<img v-if="reaction == 'angry'" src="https://twemoji.maxcdn.com/2/svg/1f4a2.svg" alt="%i18n:common.reactions.angry%"> | ||||
| 	<img v-if="reaction == 'confused'" src="https://twemoji.maxcdn.com/2/svg/1f625.svg" alt="%i18n:common.reactions.confused%"> | ||||
| 	<img v-if="reaction == 'rip'" src="https://twemoji.maxcdn.com/2/svg/1f607.svg" alt="%i18n:common.reactions.rip%"> | ||||
| 	<template v-if="reaction == 'pudding'"> | ||||
| 		<img v-if="$store.getters.isSignedIn && $store.state.settings.iLikeSushi" src="/assets/reactions/sushi.png" alt="%i18n:common.reactions.pudding%"> | ||||
| 		<img v-else src="/assets/reactions/pudding.png" alt="%i18n:common.reactions.pudding%"> | ||||
| 		<img v-if="$store.getters.isSignedIn && $store.state.settings.iLikeSushi" src="https://twemoji.maxcdn.com/2/svg/1f363.svg" alt="%i18n:common.reactions.pudding%"> | ||||
| 		<img v-else src="https://twemoji.maxcdn.com/2/svg/1f36e.svg" alt="%i18n:common.reactions.pudding%"> | ||||
| 	</template> | ||||
| </span> | ||||
| </template> | ||||
|   | ||||
| @@ -1,9 +1,9 @@ | ||||
| <template> | ||||
| <div class="mk-reaction-picker"> | ||||
| <div class="mk-reaction-picker" v-hotkey.global="keymap"> | ||||
| 	<div class="backdrop" ref="backdrop" @click="close"></div> | ||||
| 	<div class="popover" :class="{ compact, big }" ref="popover"> | ||||
| 		<p v-if="!compact">{{ title }}</p> | ||||
| 		<div> | ||||
| 		<div ref="buttons" :class="{ showFocus }"> | ||||
| 			<button @click="react('like')" @mouseover="onMouseover" @mouseout="onMouseout" tabindex="1" title="%i18n:common.reactions.like%"><mk-reaction-icon reaction='like'/></button> | ||||
| 			<button @click="react('love')" @mouseover="onMouseover" @mouseout="onMouseout" tabindex="2" title="%i18n:common.reactions.love%"><mk-reaction-icon reaction='love'/></button> | ||||
| 			<button @click="react('laugh')" @mouseover="onMouseover" @mouseout="onMouseout" tabindex="3" title="%i18n:common.reactions.laugh%"><mk-reaction-icon reaction='laugh'/></button> | ||||
| @@ -31,30 +31,84 @@ export default Vue.extend({ | ||||
| 			type: Object, | ||||
| 			required: true | ||||
| 		}, | ||||
|  | ||||
| 		source: { | ||||
| 			required: true | ||||
| 		}, | ||||
|  | ||||
| 		compact: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		}, | ||||
|  | ||||
| 		cb: { | ||||
| 			required: false | ||||
| 		}, | ||||
|  | ||||
| 		big: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		}, | ||||
|  | ||||
| 		showFocus: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		}, | ||||
|  | ||||
| 		animation: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: true | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			title: placeholder | ||||
| 			title: placeholder, | ||||
| 			focus: null | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	computed: { | ||||
| 		keymap(): any { | ||||
| 			return { | ||||
| 				'esc': this.close, | ||||
| 				'enter|space|plus': this.choose, | ||||
| 				'up|k': this.focusUp, | ||||
| 				'left|h|shift+tab': this.focusLeft, | ||||
| 				'right|l|tab': this.focusRight, | ||||
| 				'down|j': this.focusDown, | ||||
| 				'1': () => this.react('like'), | ||||
| 				'2': () => this.react('love'), | ||||
| 				'3': () => this.react('laugh'), | ||||
| 				'4': () => this.react('hmm'), | ||||
| 				'5': () => this.react('surprise'), | ||||
| 				'6': () => this.react('congrats'), | ||||
| 				'7': () => this.react('angry'), | ||||
| 				'8': () => this.react('confused'), | ||||
| 				'9': () => this.react('rip'), | ||||
| 				'0': () => this.react('pudding'), | ||||
| 			}; | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	watch: { | ||||
| 		focus(i) { | ||||
| 			this.$refs.buttons.children[i].focus(); | ||||
|  | ||||
| 			if (this.showFocus) { | ||||
| 				this.title = this.$refs.buttons.children[i].title; | ||||
| 			} | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	mounted() { | ||||
| 		this.$nextTick(() => { | ||||
| 			this.focus = 0; | ||||
|  | ||||
| 			const popover = this.$refs.popover as any; | ||||
|  | ||||
| 			const rect = this.source.getBoundingClientRect(); | ||||
| @@ -76,7 +130,7 @@ export default Vue.extend({ | ||||
| 			anime({ | ||||
| 				targets: this.$refs.backdrop, | ||||
| 				opacity: 1, | ||||
| 				duration: 100, | ||||
| 				duration: this.animation ? 100 : 0, | ||||
| 				easing: 'linear' | ||||
| 			}); | ||||
|  | ||||
| @@ -84,10 +138,11 @@ export default Vue.extend({ | ||||
| 				targets: this.$refs.popover, | ||||
| 				opacity: 1, | ||||
| 				scale: [0.5, 1], | ||||
| 				duration: 500 | ||||
| 				duration: this.animation ? 500 : 0 | ||||
| 			}); | ||||
| 		}); | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		react(reaction) { | ||||
| 			(this as any).api('notes/reactions/create', { | ||||
| @@ -95,21 +150,25 @@ export default Vue.extend({ | ||||
| 				reaction: reaction | ||||
| 			}).then(() => { | ||||
| 				if (this.cb) this.cb(); | ||||
| 				this.$destroy(); | ||||
| 				this.$emit('closed'); | ||||
| 				this.destroyDom(); | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		onMouseover(e) { | ||||
| 			this.title = e.target.title; | ||||
| 		}, | ||||
|  | ||||
| 		onMouseout(e) { | ||||
| 			this.title = placeholder; | ||||
| 		}, | ||||
|  | ||||
| 		close() { | ||||
| 			(this.$refs.backdrop as any).style.pointerEvents = 'none'; | ||||
| 			anime({ | ||||
| 				targets: this.$refs.backdrop, | ||||
| 				opacity: 0, | ||||
| 				duration: 200, | ||||
| 				duration: this.animation ? 200 : 0, | ||||
| 				easing: 'linear' | ||||
| 			}); | ||||
|  | ||||
| @@ -118,10 +177,33 @@ export default Vue.extend({ | ||||
| 				targets: this.$refs.popover, | ||||
| 				opacity: 0, | ||||
| 				scale: 0.5, | ||||
| 				duration: 200, | ||||
| 				duration: this.animation ? 200 : 0, | ||||
| 				easing: 'easeInBack', | ||||
| 				complete: () => this.$destroy() | ||||
| 				complete: () => { | ||||
| 					this.$emit('closed'); | ||||
| 					this.destroyDom(); | ||||
| 				} | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		focusUp() { | ||||
| 			this.focus = this.focus == 0 ? 9 : this.focus < 5 ? (this.focus + 4) : (this.focus - 5); | ||||
| 		}, | ||||
|  | ||||
| 		focusDown() { | ||||
| 			this.focus = this.focus == 9 ? 0 : this.focus >= 5 ? (this.focus - 4) : (this.focus + 5); | ||||
| 		}, | ||||
|  | ||||
| 		focusRight() { | ||||
| 			this.focus = this.focus == 9 ? 0 : (this.focus + 1); | ||||
| 		}, | ||||
|  | ||||
| 		focusLeft() { | ||||
| 			this.focus = this.focus == 0 ? 9 : (this.focus - 1); | ||||
| 		}, | ||||
|  | ||||
| 		choose() { | ||||
| 			this.$refs.buttons.childNodes[this.focus].click(); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| @@ -207,6 +289,21 @@ root(isDark) | ||||
| 			width 240px | ||||
| 			text-align center | ||||
|  | ||||
| 			&.showFocus | ||||
| 				> button:focus | ||||
| 					z-index 1 | ||||
|  | ||||
| 					&:after | ||||
| 						content "" | ||||
| 						pointer-events none | ||||
| 						position absolute | ||||
| 						top 0 | ||||
| 						right 0 | ||||
| 						bottom 0 | ||||
| 						left 0 | ||||
| 						border 2px solid rgba($theme-color, 0.3) | ||||
| 						border-radius 4px | ||||
|  | ||||
| 			> button | ||||
| 				padding 0 | ||||
| 				width 40px | ||||
|   | ||||
| @@ -1,16 +1,16 @@ | ||||
| <template> | ||||
| <div class="mk-reactions-viewer"> | ||||
| 	<template v-if="reactions"> | ||||
| 		<span v-if="reactions.like"><mk-reaction-icon reaction="like"/><span>{{ reactions.like }}</span></span> | ||||
| 		<span v-if="reactions.love"><mk-reaction-icon reaction="love"/><span>{{ reactions.love }}</span></span> | ||||
| 		<span v-if="reactions.laugh"><mk-reaction-icon reaction="laugh"/><span>{{ reactions.laugh }}</span></span> | ||||
| 		<span v-if="reactions.hmm"><mk-reaction-icon reaction="hmm"/><span>{{ reactions.hmm }}</span></span> | ||||
| 		<span v-if="reactions.surprise"><mk-reaction-icon reaction="surprise"/><span>{{ reactions.surprise }}</span></span> | ||||
| 		<span v-if="reactions.congrats"><mk-reaction-icon reaction="congrats"/><span>{{ reactions.congrats }}</span></span> | ||||
| 		<span v-if="reactions.angry"><mk-reaction-icon reaction="angry"/><span>{{ reactions.angry }}</span></span> | ||||
| 		<span v-if="reactions.confused"><mk-reaction-icon reaction="confused"/><span>{{ reactions.confused }}</span></span> | ||||
| 		<span v-if="reactions.rip"><mk-reaction-icon reaction="rip"/><span>{{ reactions.rip }}</span></span> | ||||
| 		<span v-if="reactions.pudding"><mk-reaction-icon reaction="pudding"/><span>{{ reactions.pudding }}</span></span> | ||||
| 		<span :class="{notReacted}" @click="react('like')" v-if="reactions.like"><mk-reaction-icon reaction="like"/><span>{{ reactions.like }}</span></span> | ||||
| 		<span :class="{notReacted}" @click="react('love')" v-if="reactions.love"><mk-reaction-icon reaction="love"/><span>{{ reactions.love }}</span></span> | ||||
| 		<span :class="{notReacted}" @click="react('laugh')" v-if="reactions.laugh"><mk-reaction-icon reaction="laugh"/><span>{{ reactions.laugh }}</span></span> | ||||
| 		<span :class="{notReacted}" @click="react('hmm')" v-if="reactions.hmm"><mk-reaction-icon reaction="hmm"/><span>{{ reactions.hmm }}</span></span> | ||||
| 		<span :class="{notReacted}" @click="react('surprise')" v-if="reactions.surprise"><mk-reaction-icon reaction="surprise"/><span>{{ reactions.surprise }}</span></span> | ||||
| 		<span :class="{notReacted}" @click="react('congrats')" v-if="reactions.congrats"><mk-reaction-icon reaction="congrats"/><span>{{ reactions.congrats }}</span></span> | ||||
| 		<span :class="{notReacted}" @click="react('angry')" v-if="reactions.angry"><mk-reaction-icon reaction="angry"/><span>{{ reactions.angry }}</span></span> | ||||
| 		<span :class="{notReacted}" @click="react('confused')" v-if="reactions.confused"><mk-reaction-icon reaction="confused"/><span>{{ reactions.confused }}</span></span> | ||||
| 		<span :class="{notReacted}" @click="react('rip')" v-if="reactions.rip"><mk-reaction-icon reaction="rip"/><span>{{ reactions.rip }}</span></span> | ||||
| 		<span :class="{notReacted}" @click="react('pudding')" v-if="reactions.pudding"><mk-reaction-icon reaction="pudding"/><span>{{ reactions.pudding }}</span></span> | ||||
| 	</template> | ||||
| </div> | ||||
| </template> | ||||
| @@ -22,6 +22,17 @@ export default Vue.extend({ | ||||
| 	computed: { | ||||
| 		reactions(): number { | ||||
| 			return this.note.reactionCounts; | ||||
| 		}, | ||||
| 		notReacted(): boolean { | ||||
| 			return this.note.myReaction == null; | ||||
| 		} | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		react(reaction: string) { | ||||
| 			(this as any).api('notes/reactions/create', { | ||||
| 				noteId: this.note.id, | ||||
| 				reaction: reaction | ||||
| 			}); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| @@ -40,6 +51,9 @@ root(isDark) | ||||
| 	> span | ||||
| 		margin-right 8px | ||||
|  | ||||
| 		&.notReacted | ||||
| 			cursor pointer | ||||
|  | ||||
| 		> .mk-reaction-icon | ||||
| 			font-size 1.4em | ||||
|  | ||||
|   | ||||
| @@ -12,13 +12,13 @@ | ||||
| 	</ui-input> | ||||
| 	<ui-input v-if="user && user.twoFactorEnabled" v-model="token" type="number" required/> | ||||
| 	<ui-button type="submit" :disabled="signing">{{ signing ? '%i18n:@signing-in%' : '%i18n:@signin%' }}</ui-button> | ||||
| 	<p style="margin: 8px 0;" v-if="twitterIntegration">%i18n:@or%<a :href="`${apiUrl}/signin/twitter`">%i18n:@signin-with-twitter%</a></p> | ||||
| 	<p style="margin: 8px 0;">%i18n:@or% <a :href="`${apiUrl}/signin/twitter`">%i18n:@signin-with-twitter%</a></p> | ||||
| </form> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { apiUrl, host, twitterIntegration } from '../../../config'; | ||||
| import { apiUrl, host } from '../../../config'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: { | ||||
| @@ -36,8 +36,7 @@ export default Vue.extend({ | ||||
| 			password: '', | ||||
| 			token: '', | ||||
| 			apiUrl, | ||||
| 			host, | ||||
| 			twitterIntegration | ||||
| 			host | ||||
| 		}; | ||||
| 	}, | ||||
| 	methods: { | ||||
| @@ -60,7 +59,7 @@ export default Vue.extend({ | ||||
| 			}).then(() => { | ||||
| 				location.reload(); | ||||
| 			}).catch(() => { | ||||
| 				alert('something happened'); | ||||
| 				alert('%i18n:@login-failed%'); | ||||
| 				this.signing = false; | ||||
| 			}); | ||||
| 		} | ||||
| @@ -79,7 +78,7 @@ export default Vue.extend({ | ||||
| 			cursor wait !important | ||||
|  | ||||
| 	> .avatar | ||||
| 		margin 16px auto 0 auto | ||||
| 		margin 0 auto 0 auto | ||||
| 		width 64px | ||||
| 		height 64px | ||||
| 		background #ddd | ||||
|   | ||||
| @@ -1,5 +1,11 @@ | ||||
| <template> | ||||
| <form class="mk-signup" @submit.prevent="onSubmit" :autocomplete="Math.random()"> | ||||
| 	<template v-if="meta"> | ||||
| 		<ui-input v-if="meta.disableRegistration" v-model="invitationCode" type="text" :autocomplete="Math.random()" spellcheck="false" required> | ||||
| 			<span>%i18n:@invitation-code%</span> | ||||
| 			<span slot="prefix">%fa:id-card-alt%</span> | ||||
| 			<p slot="text" v-html="'%i18n:@invitation-info%'.replace('{}', meta.maintainer.url)"></p> | ||||
| 		</ui-input> | ||||
| 		<ui-input v-model="username" type="text" pattern="^[a-zA-Z0-9_]{1,20}$" :autocomplete="Math.random()" spellcheck="false" required @input="onChangeUsername"> | ||||
| 			<span>%i18n:@username%</span> | ||||
| 			<span slot="prefix">@</span> | ||||
| @@ -29,15 +35,16 @@ | ||||
| 				<p slot="text" v-if="passwordRetypeState == 'not-match'" style="color:#FF1161">%fa:exclamation-triangle .fw% %i18n:@password-not-matched%</p> | ||||
| 			</div> | ||||
| 		</ui-input> | ||||
| 	<div v-if="recaptchaSitekey != null" class="g-recaptcha" :data-sitekey="recaptchaSitekey" style="margin: 16px 0;"></div> | ||||
| 		<div v-if="meta.recaptchaSitekey != null" class="g-recaptcha" :data-sitekey="meta.recaptchaSitekey" style="margin: 16px 0;"></div> | ||||
| 		<ui-button type="submit">%i18n:@create%</ui-button> | ||||
| 	</template> | ||||
| </form> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| const getPasswordStrength = require('syuilo-password-strength'); | ||||
| import { host, url, recaptchaSitekey } from '../../../config'; | ||||
| import { host, url } from '../../../config'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	data() { | ||||
| @@ -46,11 +53,12 @@ export default Vue.extend({ | ||||
| 			username: '', | ||||
| 			password: '', | ||||
| 			retypedPassword: '', | ||||
| 			invitationCode: '', | ||||
| 			url, | ||||
| 			recaptchaSitekey, | ||||
| 			usernameState: null, | ||||
| 			passwordStrength: '', | ||||
| 			passwordRetypeState: null | ||||
| 			passwordRetypeState: null, | ||||
| 			meta: null | ||||
| 		} | ||||
| 	}, | ||||
| 	computed: { | ||||
| @@ -61,6 +69,17 @@ export default Vue.extend({ | ||||
| 				this.usernameState != 'max-range'); | ||||
| 		} | ||||
| 	}, | ||||
| 	created() { | ||||
| 		(this as any).os.getMeta().then(meta => { | ||||
| 			this.meta = meta; | ||||
| 		}); | ||||
| 	}, | ||||
| 	mounted() { | ||||
| 		const head = document.getElementsByTagName('head')[0]; | ||||
| 		const script = document.createElement('script'); | ||||
| 		script.setAttribute('src', 'https://www.google.com/recaptcha/api.js'); | ||||
| 		head.appendChild(script); | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		onChangeUsername() { | ||||
| 			if (this.username == '') { | ||||
| @@ -110,7 +129,8 @@ export default Vue.extend({ | ||||
| 			(this as any).api('signup', { | ||||
| 				username: this.username, | ||||
| 				password: this.password, | ||||
| 				'g-recaptcha-response': recaptchaSitekey != null ? (window as any).grecaptcha.getResponse() : null | ||||
| 				invitationCode: this.invitationCode, | ||||
| 				'g-recaptcha-response': this.meta.recaptchaSitekey != null ? (window as any).grecaptcha.getResponse() : null | ||||
| 			}).then(() => { | ||||
| 				(this as any).api('signin', { | ||||
| 					username: this.username, | ||||
| @@ -121,19 +141,11 @@ export default Vue.extend({ | ||||
| 			}).catch(() => { | ||||
| 				alert('%i18n:@some-error%'); | ||||
|  | ||||
| 				if (recaptchaSitekey != null) { | ||||
| 				if (this.meta.recaptchaSitekey != null) { | ||||
| 					(window as any).grecaptcha.reset(); | ||||
| 				} | ||||
| 			}); | ||||
| 		} | ||||
| 	}, | ||||
| 	mounted() { | ||||
| 		if (recaptchaSitekey != null) { | ||||
| 			const head = document.getElementsByTagName('head')[0]; | ||||
| 			const script = document.createElement('script'); | ||||
| 			script.setAttribute('src', 'https://www.google.com/recaptcha/api.js'); | ||||
| 			head.appendChild(script); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|   | ||||
							
								
								
									
										90
									
								
								src/client/app/common/views/components/tag-cloud.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										90
									
								
								src/client/app/common/views/components/tag-cloud.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,90 @@ | ||||
| <template> | ||||
| <div class="jtivnzhfwquxpsfidertopbmwmchmnmo"> | ||||
| 	<p class="fetching" v-if="fetching">%fa:spinner .pulse .fw%%i18n:common.loading%<mk-ellipsis/></p> | ||||
| 	<p class="empty" v-else-if="tags.length == 0">%fa:exclamation-circle%%i18n:@empty%</p> | ||||
| 	<div v-else> | ||||
| 		<vue-word-cloud | ||||
| 				:words="tags.slice(0, 20).map(x => [x.name, x.count])" | ||||
| 				:color="color" | ||||
| 				:spacing="1"> | ||||
| 			<template slot-scope="{word, text, weight}"> | ||||
| 				<div style="cursor: pointer;" :title="weight"> | ||||
| 					{{ text }} | ||||
| 				</div> | ||||
| 			</template> | ||||
| 		</vue-word-cloud> | ||||
| 	</div> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import * as VueWordCloud from 'vuewordcloud'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	components: { | ||||
| 		[VueWordCloud.name]: VueWordCloud | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| 			tags: [], | ||||
| 			fetching: true, | ||||
| 			clock: null | ||||
| 		}; | ||||
| 	}, | ||||
| 	mounted() { | ||||
| 		this.fetch(); | ||||
| 		this.clock = setInterval(this.fetch, 1000 * 60); | ||||
| 	}, | ||||
| 	beforeDestroy() { | ||||
| 		clearInterval(this.clock); | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		fetch() { | ||||
| 			(this as any).api('aggregation/hashtags').then(tags => { | ||||
| 				this.tags = tags; | ||||
| 				this.fetching = false; | ||||
| 			}); | ||||
| 		}, | ||||
| 		color([, weight]) { | ||||
| 			const peak = Math.max.apply(null, this.tags.map(x => x.count)); | ||||
| 			const w = weight / peak; | ||||
|  | ||||
| 			if (w > 0.9) { | ||||
| 				return this.$store.state.device.darkmode ? '#ff4e69' : '#ff4e69'; | ||||
| 			} else if (w > 0.5) { | ||||
| 				return this.$store.state.device.darkmode ? '#3bc4c7' : '#3bc4c7'; | ||||
| 			} else { | ||||
| 				return this.$store.state.device.darkmode ? '#fff' : '#555'; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| root(isDark) | ||||
| 	height 100% | ||||
| 	width 100% | ||||
|  | ||||
| 	> .fetching | ||||
| 	> .empty | ||||
| 		margin 0 | ||||
| 		padding 16px | ||||
| 		text-align center | ||||
| 		color #aaa | ||||
|  | ||||
| 		> [data-fa] | ||||
| 			margin-right 4px | ||||
|  | ||||
| 	> div | ||||
| 		height 100% | ||||
| 		width 100% | ||||
|  | ||||
| .jtivnzhfwquxpsfidertopbmwmchmnmo[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .jtivnzhfwquxpsfidertopbmwmchmnmo:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										103
									
								
								src/client/app/common/views/components/trends.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										103
									
								
								src/client/app/common/views/components/trends.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,103 @@ | ||||
| <template> | ||||
| <div class="csqvmxybqbycalfhkxvyfrgbrdalkaoc"> | ||||
| 	<p class="fetching" v-if="fetching">%fa:spinner .pulse .fw%%i18n:common.loading%<mk-ellipsis/></p> | ||||
| 	<p class="empty" v-else-if="stats.length == 0">%fa:exclamation-circle%%i18n:@empty%</p> | ||||
| 	<!-- トランジションを有効にするとなぜかメモリリークする --> | ||||
| 	<transition-group v-else tag="div" name="chart"> | ||||
| 		<div v-for="stat in stats" :key="stat.tag"> | ||||
| 			<div class="tag"> | ||||
| 				<router-link :to="`/tags/${ encodeURIComponent(stat.tag) }`" :title="stat.tag">#{{ stat.tag }}</router-link> | ||||
| 				<p>{{ '%i18n:@count%'.replace('{}', stat.usersCount) }}</p> | ||||
| 			</div> | ||||
| 			<x-chart class="chart" :src="stat.chart"/> | ||||
| 		</div> | ||||
| 	</transition-group> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import XChart from './trends.chart.vue'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	components: { | ||||
| 		XChart | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| 			stats: [], | ||||
| 			fetching: true, | ||||
| 			clock: null | ||||
| 		}; | ||||
| 	}, | ||||
| 	mounted() { | ||||
| 		this.fetch(); | ||||
| 		this.clock = setInterval(this.fetch, 1000 * 60); | ||||
| 	}, | ||||
| 	beforeDestroy() { | ||||
| 		clearInterval(this.clock); | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		fetch() { | ||||
| 			(this as any).api('hashtags/trend').then(stats => { | ||||
| 				this.stats = stats; | ||||
| 				this.fetching = false; | ||||
| 			}); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| root(isDark) | ||||
| 	> .fetching | ||||
| 	> .empty | ||||
| 		margin 0 | ||||
| 		padding 16px | ||||
| 		text-align center | ||||
| 		color #aaa | ||||
|  | ||||
| 		> [data-fa] | ||||
| 			margin-right 4px | ||||
|  | ||||
| 	> div | ||||
| 		.chart-move | ||||
| 			transition transform 1s ease | ||||
|  | ||||
| 		> div | ||||
| 			display flex | ||||
| 			align-items center | ||||
| 			padding 14px 16px | ||||
|  | ||||
| 			&:not(:last-child) | ||||
| 				border-bottom solid 1px isDark ? #393f4f : #eee | ||||
|  | ||||
| 			> .tag | ||||
| 				flex 1 | ||||
| 				overflow hidden | ||||
| 				font-size 14px | ||||
| 				color isDark ? #9baec8 : #65727b | ||||
|  | ||||
| 				> a | ||||
| 					display block | ||||
| 					width 100% | ||||
| 					white-space nowrap | ||||
| 					overflow hidden | ||||
| 					text-overflow ellipsis | ||||
| 					color inherit | ||||
|  | ||||
| 				> p | ||||
| 					margin 0 | ||||
| 					font-size 75% | ||||
| 					opacity 0.7 | ||||
|  | ||||
| 			> .chart | ||||
| 				height 30px | ||||
|  | ||||
| .csqvmxybqbycalfhkxvyfrgbrdalkaoc[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .csqvmxybqbycalfhkxvyfrgbrdalkaoc:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
| @@ -24,17 +24,32 @@ export default Vue.extend({ | ||||
|  | ||||
| root(isDark) | ||||
| 	margin 16px | ||||
| 	padding 16px | ||||
| 	color isDark ? #fff : #000 | ||||
| 	background isDark ? #282C37 : #fff | ||||
| 	box-shadow 0 3px 1px -2px rgba(#000, 0.2), 0 2px 2px 0 rgba(#000, 0.14), 0 1px 5px 0 rgba(#000, 0.12) | ||||
|  | ||||
| 	> header | ||||
| 		padding 16px | ||||
| 		font-weight bold | ||||
| 		font-size 20px | ||||
| 		color isDark ? #fff : #444 | ||||
|  | ||||
| 		@media (min-width 500px) | ||||
| 			padding 24px 32px | ||||
|  | ||||
| 	> section | ||||
| 		padding 20px 16px | ||||
| 		border-top solid 1px isDark ? rgba(#000, 0.3) : rgba(#000, 0.1) | ||||
|  | ||||
| 		@media (min-width 500px) | ||||
| 			padding 32px | ||||
|  | ||||
| 		&.fit-top | ||||
| 			padding-top 0 | ||||
|  | ||||
| 		> header | ||||
| 		font-weight normal | ||||
| 		font-size 24px | ||||
| 			margin-bottom 16px | ||||
| 			font-weight bold | ||||
| 			color isDark ? #fff : #444 | ||||
|  | ||||
| .ui-card[data-darkmode] | ||||
|   | ||||
| @@ -55,7 +55,7 @@ export default Vue.extend({ | ||||
|  | ||||
| root(isDark) | ||||
| 	display inline-block | ||||
| 	margin 32px 32px 32px 0 | ||||
| 	margin 0 32px 0 0 | ||||
| 	cursor pointer | ||||
| 	transition all 0.3s | ||||
|  | ||||
|   | ||||
| @@ -64,6 +64,12 @@ root(isDark) | ||||
| 	cursor pointer | ||||
| 	transition all 0.3s | ||||
|  | ||||
| 	&:first-child | ||||
| 		margin-top 0 | ||||
|  | ||||
| 	&:last-child | ||||
| 		margin-bottom 0 | ||||
|  | ||||
| 	> * | ||||
| 		user-select none | ||||
|  | ||||
| @@ -89,6 +95,7 @@ root(isDark) | ||||
|  | ||||
| 	> .button | ||||
| 		display inline-block | ||||
| 		flex-shrink 0 | ||||
| 		margin 3px 0 0 0 | ||||
| 		width 34px | ||||
| 		height 14px | ||||
|   | ||||
| @@ -1,26 +1,20 @@ | ||||
| <template> | ||||
| <iframe v-if="youtubeId" type="text/html" height="250" | ||||
| 	:src="`https://www.youtube.com/embed/${youtubeId}?origin=${misskeyUrl}`" | ||||
| 	frameborder="0"/> | ||||
| <iframe v-else-if="spotifyId" | ||||
| 	:src="`https://open.spotify.com/embed/track/${spotifyId}`" | ||||
| 	frameborder="0" allowtransparency="true" allow="encrypted-media" /> | ||||
| <iframe v-else-if="nicovideoId" | ||||
| 	:src="`https://embed.nicovideo.jp/watch/${nicovideoId}?oldScript=1&referer=${misskeyUrl}&from=${position || '0'}&allowProgrammaticFullScreen=1`" | ||||
| 	frameborder="0" allow="autoplay; encrypted-media" allowfullscreen /> | ||||
| <div v-if="player.url" class="player" :style="`padding: ${(player.height || 0) / (player.width || 1) * 100}% 0 0`"> | ||||
| 	<iframe :src="player.url" :width="player.width || '100%'" :heigth="player.height || 250" frameborder="0" allow="autoplay; encrypted-media" allowfullscreen /> | ||||
| </div> | ||||
| <div v-else-if="tweetUrl && detail" class="twitter"> | ||||
| 	<blockquote ref="tweet" class="twitter-tweet" :data-theme="$store.state.device.darkmode ? 'dark' : null"> | ||||
| 		<a :href="url"></a> | ||||
| 	</blockquote> | ||||
| </div> | ||||
| <div v-else class="mk-url-preview"> | ||||
| 	<a :href="url" target="_blank" :title="url" v-if="!fetching"> | ||||
| 	<a :class="{ mini }" :href="url" target="_blank" :title="url" v-if="!fetching"> | ||||
| 		<div class="thumbnail" v-if="thumbnail" :style="`background-image: url(${thumbnail})`"></div> | ||||
| 		<article> | ||||
| 			<header> | ||||
| 				<h1>{{ title }}</h1> | ||||
| 			</header> | ||||
| 			<p>{{ description }}</p> | ||||
| 			<p>{{ description.length > 85 ? description.slice(0, 85) + '…' : description }}</p> | ||||
| 			<footer> | ||||
| 				<img class="icon" v-if="icon" :src="icon"/> | ||||
| 				<p>{{ sitename }}</p> | ||||
| @@ -34,18 +28,105 @@ | ||||
| import Vue from 'vue'; | ||||
| import { url as misskeyUrl } from '../../../config'; | ||||
|  | ||||
| // THIS IS THE WHITELIST FOR THE EMBED PLAYER | ||||
| const whiteList = [ | ||||
| 	'afreecatv.com', | ||||
| 	'aparat.com', | ||||
| 	'applemusic.com', | ||||
| 	'amazon.com', | ||||
| 	'awa.fm', | ||||
| 	'bandcamp.com', | ||||
| 	'bbc.co.uk', | ||||
| 	'beatport.com', | ||||
| 	'bilibili.com', | ||||
| 	'boomstream.com', | ||||
| 	'breakers.tv', | ||||
| 	'cam4.com', | ||||
| 	'cavelis.net', | ||||
| 	'chaturbate.com', | ||||
| 	'cnn.com', | ||||
| 	'cybergame.tv', | ||||
| 	'dailymotion.com', | ||||
| 	'deezer.com', | ||||
| 	'djlive.pl', | ||||
| 	'e-onkyo.com', | ||||
| 	'eventials.com', | ||||
| 	'facebook.com', | ||||
| 	'fc2.com', | ||||
| 	'gameplank.tv', | ||||
| 	'goodgame.ru', | ||||
| 	'google.com', | ||||
| 	'hardtunes.com', | ||||
| 	'instagram.com', | ||||
| 	'johnnylooch.com', | ||||
| 	'kexp.org', | ||||
| 	'lahzenegar.com', | ||||
| 	'liveedu.tv', | ||||
| 	'livetube.cc', | ||||
| 	'livestream.com', | ||||
| 	'meridix.com', | ||||
| 	'mixcloud.com', | ||||
| 	'mixer.com', | ||||
| 	'mobcrush.com', | ||||
| 	'mylive.in.th', | ||||
| 	'myspace.com', | ||||
| 	'netflix.com', | ||||
| 	'newretrowave.com', | ||||
| 	'nhk.or.jp', | ||||
| 	'nicovideo.jp', | ||||
| 	'nico.ms', | ||||
| 	'noisetrade.com', | ||||
| 	'nood.tv', | ||||
| 	'npr.org', | ||||
| 	'openrec.tv', | ||||
| 	'pandora.com', | ||||
| 	'pandora.tv', | ||||
| 	'picarto.tv', | ||||
| 	'pscp.tv', | ||||
| 	'restream.io', | ||||
| 	'reverbnation.com', | ||||
| 	'sermonaudio.com', | ||||
| 	'smashcast.tv', | ||||
| 	'songkick.com', | ||||
| 	'soundcloud.com', | ||||
| 	'spinninrecords.com', | ||||
| 	'spotify.com', | ||||
| 	'stitcher.com', | ||||
| 	'stream.me', | ||||
| 	'switchboard.live', | ||||
| 	'tunein.com', | ||||
| 	'twitcasting.tv', | ||||
| 	'twitch.tv', | ||||
| 	'twitter.com', | ||||
| 	'vaughnlive.tv', | ||||
| 	'veoh.com', | ||||
| 	'vimeo.com', | ||||
| 	'watchpeoplecode.com', | ||||
| 	'web.tv', | ||||
| 	'youtube.com', | ||||
| 	'youtu.be' | ||||
| ]; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: { | ||||
| 		url: { | ||||
| 			type: String, | ||||
| 			require: true | ||||
| 		}, | ||||
|  | ||||
| 		detail: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		}, | ||||
|  | ||||
| 		mini: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			fetching: true, | ||||
| @@ -54,34 +135,20 @@ export default Vue.extend({ | ||||
| 			thumbnail: null, | ||||
| 			icon: null, | ||||
| 			sitename: null, | ||||
| 			youtubeId: null, | ||||
| 			spotifyId: null, | ||||
| 			nicovideoId: null, | ||||
| 			position: null, | ||||
| 			player: { | ||||
| 				url: null, | ||||
| 				width: null, | ||||
| 				height: null | ||||
| 			}, | ||||
| 			tweetUrl: null, | ||||
| 			misskeyUrl | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	created() { | ||||
| 		const url = new URL(this.url); | ||||
|  | ||||
| 		if (url.hostname == 'www.youtube.com') { | ||||
| 			this.youtubeId = url.searchParams.get('v'); | ||||
| 			return; | ||||
| 		} else if (url.hostname == 'youtu.be') { | ||||
| 			this.youtubeId = url.pathname; | ||||
| 			return; | ||||
| 		} else if (url.hostname == 'open.spotify.com') { | ||||
| 			this.spotifyId = url.pathname.split('/').reverse().filter(x => x !== '')[0]; | ||||
| 			return; | ||||
| 		} else if (['nicovideo.jp', 'www.nicovideo.jp', 'nico.ms'].includes(url.hostname)) { | ||||
| 			const id = url.pathname.split('/').reverse().filter(x => x !== '')[0]; | ||||
| 			if (['sm', 'nm', 'ax', 'ca', 'cd', 'cw', 'fx', 'ig', 'na', 'om', 'sd', 'sk', 'yk', 'yo', 'za', 'zb', 'zc', 'zd', 'ze', 'nl', 'so', ...Array(10).keys()].some(x => id.startsWith(x)) { | ||||
| 				this.nicovideoId = id; | ||||
| 				this.position = url.searchParams.get('from'); | ||||
| 				return; | ||||
| 			} | ||||
| 		} else if (this.detail && url.hostname == 'twitter.com' && /^\/.+\/status(es)?\/\d+/.test(url.pathname)) { | ||||
| 		if (this.detail && url.hostname == 'twitter.com' && /^\/.+\/status(es)?\/\d+/.test(url.pathname)) { | ||||
| 			this.tweetUrl = url; | ||||
| 			const twttr = (window as any).twttr || {}; | ||||
| 			const loadTweet = () => twttr.widgets.load(this.$refs.tweet); | ||||
| @@ -102,25 +169,35 @@ export default Vue.extend({ | ||||
| 			} | ||||
| 			return; | ||||
| 		} | ||||
| 		fetch('/url?url=' + encodeURIComponent(this.url)).then(res => { | ||||
|  | ||||
| 		fetch(`/url?url=${encodeURIComponent(this.url)}`).then(res => { | ||||
| 			res.json().then(info => { | ||||
| 				if (info.url != null) { | ||||
| 				if (info.url == null) return; | ||||
| 				this.title = info.title; | ||||
| 				this.description = info.description; | ||||
| 				this.thumbnail = info.thumbnail; | ||||
| 				this.icon = info.icon; | ||||
| 				this.sitename = info.sitename; | ||||
|  | ||||
| 				this.fetching = false; | ||||
| 				if (whiteList.some(x => x == url.hostname || url.hostname.endsWith(`.${x}`))) { | ||||
| 					this.player = info.player; | ||||
| 				} | ||||
| 			}); | ||||
| 			}) | ||||
| 		}); | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| iframe | ||||
| .player | ||||
| 	position relative | ||||
| 	width 100% | ||||
|  | ||||
| 	> iframe | ||||
| 		height 100% | ||||
| 		left 0 | ||||
| 		position absolute | ||||
| 		top 0 | ||||
| 		width 100% | ||||
|  | ||||
| root(isDark) | ||||
| @@ -222,6 +299,29 @@ root(isDark) | ||||
| 						width 12px | ||||
| 						height 12px | ||||
|  | ||||
| 		&.mini | ||||
| 			font-size 10px | ||||
|  | ||||
| 			> .thumbnail | ||||
| 				position relative | ||||
| 				width 100% | ||||
| 				height 60px | ||||
|  | ||||
| 			> article | ||||
| 				left 0 | ||||
| 				width 100% | ||||
| 				padding 8px | ||||
|  | ||||
| 				> header | ||||
| 					margin-bottom 4px | ||||
|  | ||||
| 				> footer | ||||
| 					margin-top 4px | ||||
|  | ||||
| 					> img | ||||
| 						width 12px | ||||
| 						height 12px | ||||
|  | ||||
| .mk-url-preview[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
|   | ||||
| @@ -12,6 +12,7 @@ | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { toUnicode as decodePunycode } from 'punycode'; | ||||
| export default Vue.extend({ | ||||
| 	props: ['url', 'target'], | ||||
| 	data() { | ||||
| @@ -27,11 +28,11 @@ export default Vue.extend({ | ||||
| 	created() { | ||||
| 		const url = new URL(this.url); | ||||
| 		this.schema = url.protocol; | ||||
| 		this.hostname = url.hostname; | ||||
| 		this.hostname = decodePunycode(url.hostname); | ||||
| 		this.port = url.port; | ||||
| 		this.pathname = url.pathname; | ||||
| 		this.query = url.search; | ||||
| 		this.hash = url.hash; | ||||
| 		this.pathname = decodeURIComponent(url.pathname); | ||||
| 		this.query = decodeURIComponent(url.search); | ||||
| 		this.hash = decodeURIComponent(url.hash); | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|   | ||||
| @@ -44,7 +44,12 @@ import Vue from 'vue'; | ||||
| import * as anime from 'animejs'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: ['source', 'compact', 'v'], | ||||
| 	props: ['source', 'compact'], | ||||
| 	data() { | ||||
| 		return { | ||||
| 			v: this.$store.state.settings.rememberNoteVisibility ? (this.$store.state.device.visibility || this.$store.state.settings.defaultNoteVisibility) : this.$store.state.settings.defaultNoteVisibility | ||||
| 		} | ||||
| 	}, | ||||
| 	mounted() { | ||||
| 		this.$nextTick(() => { | ||||
| 			const popover = this.$refs.popover as any; | ||||
| @@ -92,8 +97,11 @@ export default Vue.extend({ | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		choose(visibility) { | ||||
| 			if (this.$store.state.settings.rememberNoteVisibility) { | ||||
| 				this.$store.commit('device/setVisibility', visibility); | ||||
| 			} | ||||
| 			this.$emit('chosen', visibility); | ||||
| 			this.$destroy(); | ||||
| 			this.destroyDom(); | ||||
| 		}, | ||||
| 		close() { | ||||
| 			(this.$refs.backdrop as any).style.pointerEvents = 'none'; | ||||
| @@ -111,7 +119,7 @@ export default Vue.extend({ | ||||
| 				scale: 0.5, | ||||
| 				duration: 200, | ||||
| 				easing: 'easeInBack', | ||||
| 				complete: () => this.$destroy() | ||||
| 				complete: () => this.destroyDom() | ||||
| 			}); | ||||
| 		} | ||||
| 	} | ||||
|   | ||||
| @@ -1,6 +1,7 @@ | ||||
| <template> | ||||
| <div class="mk-welcome-timeline"> | ||||
| 	<div v-for="note in notes"> | ||||
| 	<transition-group name="ldzpakcixzickvggyixyrhqwjaefknon" tag="div"> | ||||
| 		<div v-for="note in notes" :key="note.id"> | ||||
| 			<mk-avatar class="avatar" :user="note.user" target="_blank"/> | ||||
| 			<div class="body"> | ||||
| 				<header> | ||||
| @@ -17,6 +18,7 @@ | ||||
| 				</div> | ||||
| 			</div> | ||||
| 		</div> | ||||
| 	</transition-group> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| @@ -31,15 +33,30 @@ export default Vue.extend({ | ||||
| 			default: undefined | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			fetching: true, | ||||
| 			notes: [] | ||||
| 			notes: [], | ||||
| 			connection: null, | ||||
| 			connectionId: null | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	mounted() { | ||||
| 		this.fetch(); | ||||
|  | ||||
| 		this.connection = (this as any).os.streams.localTimelineStream.getConnection(); | ||||
| 		this.connectionId = (this as any).os.streams.localTimelineStream.use(); | ||||
|  | ||||
| 		this.connection.on('note', this.onNote); | ||||
| 	}, | ||||
|  | ||||
| 	beforeDestroy() { | ||||
| 		this.connection.off('note', this.onNote); | ||||
| 		(this as any).os.streams.localTimelineStream.dispose(this.connectionId); | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		fetch(cb?) { | ||||
| 			this.fetching = true; | ||||
| @@ -48,22 +65,38 @@ export default Vue.extend({ | ||||
| 				local: true, | ||||
| 				reply: false, | ||||
| 				renote: false, | ||||
| 				media: false, | ||||
| 				poll: false, | ||||
| 				bot: false | ||||
| 				file: false, | ||||
| 				poll: false | ||||
| 			}).then(notes => { | ||||
| 				this.notes = notes; | ||||
| 				this.fetching = false; | ||||
| 			}); | ||||
| 		} | ||||
| 		}, | ||||
|  | ||||
| 		onNote(note) { | ||||
| 			if (note.replyId != null) return; | ||||
| 			if (note.renoteId != null) return; | ||||
| 			if (note.poll != null) return; | ||||
|  | ||||
| 			this.notes.unshift(note); | ||||
| 		}, | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .ldzpakcixzickvggyixyrhqwjaefknon-enter | ||||
| .ldzpakcixzickvggyixyrhqwjaefknon-leave-to | ||||
| 	opacity 0 | ||||
| 	transform translateY(-30px) | ||||
|  | ||||
| root(isDark) | ||||
| 	background isDark ? #282C37 : #fff | ||||
|  | ||||
| 	> div | ||||
| 		> * | ||||
| 			transition transform .3s ease, opacity .3s ease | ||||
|  | ||||
| 		> div | ||||
| 			padding 16px | ||||
| 			overflow-wrap break-word | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user