Compare commits
	
		
			857 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 0eefd2922c | ||
|   | 30c0f98691 | ||
|   | 06a7c2e138 | ||
|   | 3537b3de8e | ||
|   | ed6450244d | ||
|   | e813880392 | ||
|   | 9a57efa6d9 | ||
|   | 31de530497 | ||
|   | 16b6b1f2b3 | ||
|   | a2a25eb5f8 | ||
|   | 274cf1af1c | ||
|   | 7d11c8b767 | ||
|   | 7e50e03cfb | ||
|   | 89d5df20a5 | ||
|   | c09a2a37fe | ||
|   | b5745877ca | ||
|   | 6e04549a9b | ||
|   | 38139ee6c9 | ||
|   | 6b96bd0185 | ||
|   | f2b9863eea | ||
|   | f56adce51f | ||
|   | 35362ed3c7 | ||
|   | cd0b9a8e3f | ||
|   | 110aadd65c | ||
|   | ff76c815b1 | ||
|   | 1b9b8912ae | ||
|   | 579b61a806 | ||
|   | 1e2b484929 | ||
|   | 25dd19dd8c | ||
|   | b8b4991a46 | ||
|   | 8b68c5da37 | ||
|   | f26e641905 | ||
|   | 57669c9c03 | ||
|   | 094d873f2e | ||
|   | 7b42653271 | ||
|   | 6a82e94c54 | ||
|   | 1fa4d0d3f8 | ||
|   | d5818214f3 | ||
|   | 0c63ec8157 | ||
|   | 8317a219a5 | ||
|   | ec652dd0ac | ||
|   | 8e3dd75c85 | ||
|   | 3f4de3b1cc | ||
|   | e0d3fd17ce | ||
|   | 671c7cf06b | ||
|   | 99a2c5b3fa | ||
|   | 0343de95b8 | ||
|   | 13f258308e | ||
|   | c627288bde | ||
|   | 1eef90f6cb | ||
|   | 29476ea3da | ||
|   | 7609741680 | ||
|   | 5df85b5feb | ||
|   | b4a4d784c3 | ||
|   | d715af0620 | ||
|   | fe8c384618 | ||
|   | 47d4de75da | ||
|   | 016c7fd2c4 | ||
|   | 7ca5e33a3a | ||
|   | 436773837b | ||
|   | fccfe19e13 | ||
|   | 18be0d36f3 | ||
|   | 9ea7de3564 | ||
|   | d1dce76e28 | ||
|   | f4bf824e79 | ||
|   | cbf5d4b71d | ||
|   | 61e5cb2041 | ||
|   | 38a6aa26bc | ||
|   | 32942709bf | ||
|   | a0305c4c04 | ||
|   | 74be1c81b1 | ||
|   | e82a44c03d | ||
|   | 1e9eeeb980 | ||
|   | 0c7111b438 | ||
|   | ef74653a4b | ||
|   | b032f78769 | ||
|   | 7a0a8b5d2b | ||
|   | 459b374d61 | ||
|   | cc6af402be | ||
|   | f3eeadcd8f | ||
|   | 5b0b83faa7 | ||
|   | 5f289e4767 | ||
|   | a36d73cb52 | ||
|   | 9e319006f3 | ||
|   | 7b8a2aef0f | ||
|   | 4fe2f29478 | ||
|   | 76a25917c0 | ||
|   | df6c9b1a1c | ||
|   | 0ef64a6d0b | ||
|   | 1eb6ad58d5 | ||
|   | 49f8cfb0db | ||
|   | 15a8b4c6e5 | ||
|   | 97d68d7b31 | ||
|   | 4dde54e344 | ||
|   | 3304cc106e | ||
|   | dabda21eb7 | ||
|   | 0a64f638c6 | ||
|   | 3cbdfcb43d | ||
|   | b6e33e93de | ||
|   | 77b441f14c | ||
|   | 297019c22c | ||
|   | f5f2215b47 | ||
|   | 904114740b | ||
|   | d2d3f7810e | ||
|   | 2b07b3a873 | ||
|   | f6e4a1770e | ||
|   | 31006507c0 | ||
|   | 9ca6a6bf06 | ||
|   | afdacf14b7 | ||
|   | 5da18ba535 | ||
|   | e6cc937ac2 | ||
|   | 87091a2e03 | ||
|   | 59d67d3140 | ||
|   | 7b4c307c46 | ||
|   | 92484be87f | ||
|   | 56b8f8b07d | ||
|   | 722de35037 | ||
|   | d93f76c1af | ||
|   | cba0dd5e17 | ||
|   | a2e2d5ba77 | ||
|   | 61e05cb50e | ||
|   | 49e82adc6c | ||
|   | e4e668b327 | ||
|   | 8028c85c67 | ||
|   | 28cb9cae51 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 7f2eb64131 | ||
|   | 3e5330a92b | ||
|   | 93e5e4afc0 | ||
|   | aa5528d11e | ||
|   | 251629ab61 | ||
|   | 82d94b5963 | ||
|   | 8240901332 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 0a870b8e7e | ||
|   | 88dd653fa5 | ||
|   | b712b70330 | ||
|   | a018c2f09f | ||
|   | 04c16e53a5 | ||
|   | 5e89e73f76 | ||
|   | 2c9432d7a9 | ||
|   | 19d1775b36 | ||
|   | ecc235c545 | ||
|   | 382b1d2250 | ||
|   | 629693355a | ||
|   | 00a3f8d392 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 80b6e8090e | ||
|   | a5f817d896 | ||
|   | 51b0244cf2 | ||
|   | 01131e2606 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 6283b7668e | ||
|   | d058ecc4ea | ||
|   | 77a0450b5d | ||
|   | 1dd1b9084f | ||
|   | 6341807d02 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 51a1f30225 | ||
|   | 5422482696 | ||
|   | cd7f8b080e | ||
|   | faf29b768f | ||
|   | 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 | ||
|   | 37b5afa1a3 | ||
|   | b80d0a3b12 | ||
|   | 9f60688d37 | ||
|   | ca0ea9e57c | ||
|   | a77a7e8112 | ||
|   | b26ea2edc0 | ||
|   | 02b99dfd76 | ||
|   | af02b0f115 | ||
|   | 9b3c379678 | ||
|   | a423fd7695 | ||
|   | de6e1d8c9b | ||
|   | d9db3e8629 | ||
|   | ac1c81b7d6 | ||
|   | 49b2eec534 | 
| @@ -1,18 +1,19 @@ | ||||
| #!/usr/bin/env bash | ||||
| # BEARER_TOKEN= | ||||
| # CAMPAIGN_ID= | ||||
| # GITHUB_TOKEN= | ||||
| # HEAD='acid-chicken:patch-autogen' | ||||
| # REPO='syuilo/misskey' | ||||
| test "$(curl -LSs -w '\n' -- "https://api.github.com/repos/$REPO/pulls?access_token=$GITHUB_TOKEN" | jq -r '.[].head.label' | grep $HEAD)" && exit 1 | ||||
| # __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 master && \ | ||||
| git pull origin master && \ | ||||
| git pull upstream master && \ | ||||
| git checkout $__MISSKEY_BRANCH && \ | ||||
| git pull origin $__MISSKEY_BRANCH && \ | ||||
| git pull upstream $__MISSKEY_BRANCH && \ | ||||
| git stash && \ | ||||
| git rebase -f upstream/master && \ | ||||
| git rebase -f upstream/$__MISSKEY_BRANCH && \ | ||||
| git branch patch-autogen && \ | ||||
| git checkout patch-autogen && \ | ||||
| git reset --hard HEAD || \ | ||||
| @@ -20,12 +21,12 @@ 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/$CAMPAIGN_ID/members?include=currently_entitled_tiers,user&fields%5Btier%5D=title&fields%5Buser%5D=full_name,thumb_url,url,hide_pledges" | ||||
| 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 $BEARER_TOKEN" -- $URL > 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 | \ | ||||
| @@ -42,31 +43,31 @@ while : | ||||
|   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' && \ | ||||
|   new_url="$(cat patreon.raw.cache | jq -r '.links.next')" | ||||
|   test "$new_url" = 'null' && \ | ||||
|   break || \ | ||||
|   URL="$NEW_URL" | ||||
|   URL="$url" | ||||
| done | ||||
| IGNORE= && \ | ||||
| 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; | ||||
| cat .autogen/README.md | while IFS= read line; | ||||
|  do | ||||
|   if [[ -z "$IGNORE" ]] | ||||
|   if [[ -z "$ignore" ]] | ||||
|    then | ||||
|     if [[ "$LINE" = '<!-- PATREON_START -->' ]] | ||||
|     if [[ "$line" = '<!-- PATREON_START -->' ]] | ||||
|      then | ||||
|       IGNORE='PATREON_INSIDE' | ||||
|       ignore='PATREON_INSIDE' | ||||
|      else | ||||
|       echo "$LINE" >> README.md | ||||
|       echo "$line" >> README.md | ||||
|     fi | ||||
|    else | ||||
|     if [[ "$LINE" = '<!-- PATREON_END -->' ]] | ||||
|      then | ||||
|       IGNORE= | ||||
|       ignore= | ||||
|       cat patreon.md.cache >> README.md | ||||
|     fi | ||||
|   fi | ||||
| @@ -80,7 +81,7 @@ 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":"'$HEAD'","base":"master"}' -- "https://api.github.com/repos/$REPO/pulls?access_token=$GITHUB_TOKEN" | ||||
| 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 master | ||||
| git checkout $__MISSKEY_BRANCH | ||||
| git branch -D patch-autogen | ||||
|   | ||||
| @@ -7,27 +7,51 @@ maintainer: | ||||
|   repository_url: https://github.com/syuilo/misskey # Repository URL | ||||
|   feedback_url: https://github.com/syuilo/misskey/issues # Feedback URL (e.g. github issue) | ||||
|  | ||||
| # URL and Port settings overview | ||||
| # e.g., If you want to realize following structure: | ||||
| # | ||||
| #               +--- https://example.com:123 ----------+ | ||||
| # +------+      |+-------------+      +---------------+| | ||||
| # | User | ---> || Proxy (123) | ---> | Misskey (456) || | ||||
| # +------+      |+-------------+      +---------------+| | ||||
| #               +--------------------------------------+ | ||||
| # | ||||
| # You need to set 'https://example.com:123' to 'url' prop and | ||||
| # You need to set 456 to 'port' prop. | ||||
| # | ||||
| # In other words, the 'url' prop should be the final accessible URL seen by a user. | ||||
| # 'port' prop is a port that the Misskey server should actually listen | ||||
| # on and it is not necessarily the port that a user accesses. | ||||
|  | ||||
| url: http://localhost/ | ||||
| # Final accessible URL seen by a user. | ||||
| url: https://example.tld/ | ||||
|  | ||||
|  | ||||
| ### Port and TLS settings ###################################### | ||||
| # | ||||
| # Misskey supports two deployment options for public. | ||||
| # | ||||
|  | ||||
| # Option 1: With Reverse Proxy | ||||
| # | ||||
| #                 +----- https://example.tld/ ------------+ | ||||
| #   +------+      |+-------------+      +----------------+| | ||||
| #   | User | ---> || Proxy (443) | ---> | Misskey (3000) || | ||||
| #   +------+      |+-------------+      +----------------+| | ||||
| #                 +---------------------------------------+ | ||||
| # | ||||
| #   You need to setup reverse proxy. (eg. Nginx) | ||||
| #   You do not define 'https' section. | ||||
|  | ||||
| # Option 2: Standalone | ||||
| # | ||||
| #                 +- https://example.tld/ -+ | ||||
| #   +------+      |   +---------------+    | | ||||
| #   | User | ---> |   | Misskey (443) |    | | ||||
| #   +------+      |   +---------------+    | | ||||
| #                 +------------------------+ | ||||
| # | ||||
| #   You need to run Misskey as root. | ||||
| #   You need to set Certificate in 'https' section. | ||||
|  | ||||
| # To use option 1, uncomment below line. | ||||
| # port: 3000    # A port that your Misskey server should listen. | ||||
|  | ||||
| # To use option 2, uncomment below lines. | ||||
| # port: 443 | ||||
| # | ||||
| # https: | ||||
| #   # path for certification | ||||
| #   key: /etc/letsencrypt/live/example.tld/privkey.pem | ||||
| #   cert: /etc/letsencrypt/live/example.tld/fullchain.pem | ||||
|  | ||||
| ################################################################ | ||||
|  | ||||
| # A port that your Misskey server should listen. | ||||
| # This value is not a port to use when accessing with a browser. | ||||
| port: 80 | ||||
|  | ||||
| mongodb: | ||||
|   host: localhost | ||||
| @@ -98,12 +122,6 @@ drive: | ||||
| # Below settings are optional | ||||
| # | ||||
|  | ||||
| # TLS | ||||
| # https: | ||||
| #   # path for certification | ||||
| #   key: example-tls-key | ||||
| #   cert: example-tls-cert | ||||
|  | ||||
| # Elasticsearch | ||||
| # elasticsearch: | ||||
| #   host: localhost | ||||
|   | ||||
							
								
								
									
										10
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -5,6 +5,12 @@ ChangeLog | ||||
|  | ||||
| This document describes breaking changes only. | ||||
|  | ||||
| 9.0.0 | ||||
| ----- | ||||
|  | ||||
| Misskey v8.64.0 を使っている方は、9.0.0に際しては特にすべきことはありません。 | ||||
| Misskey v8.64.0 に満たないバージョンをお使いの方は、一旦8.64.0にアップデートして(そして起動して)から9.0.0に再度アップデートしてください。 | ||||
|  | ||||
| 8.0.0 | ||||
| ----- | ||||
|  | ||||
| @@ -47,13 +53,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`. | ||||
|   | ||||
							
								
								
									
										86
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										86
									
								
								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,12 +7,12 @@ | ||||
| [![][dependencies-badge]][dependencies-link] | ||||
| [](http://makeapullrequest.com) [](https://greenkeeper.io/) | ||||
|  | ||||
| Sophisticated microblogging platform, evolving forever. | ||||
| **Sophisticated microblogging platform, evolving forever.** | ||||
|  | ||||
| [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? | ||||
| 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> | ||||
|  | ||||
| @@ -20,54 +20,70 @@ Why don't you take a short break from the hustle and bustle of the city, and div | ||||
|  | ||||
| :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"/> | ||||
|  | ||||
| <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!** | ||||
|  | ||||
| ### i18n | ||||
|  | ||||
| Please see [Translation guide](./docs/translate.en.md). | ||||
|  | ||||
| ### l10n | ||||
|  | ||||
| Misskey is using Crowdin for l10n. | ||||
|  | ||||
| [](https://crowdin.com/project/misskey) | ||||
| Please see [Contribution guide](./CONTRIBUTING.md). | ||||
|  | ||||
| :heart: Backers & Sponsors | ||||
| ---------------------------------------------------------------- | ||||
| <!-- PATREON_START --> | ||||
| <table><tr> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12378075/0156f769e20f412594fa6b87d85fe228/1?token-time=2145916800&token-hash=IsIJRUXszzoD6-7pDnRY8I05T9nSznc4GTaxj7C9SwU%3D" alt="39ff"></td> | ||||
| <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/1?token-time=2145916800&token-hash=DVrSdOqQq2dufgNgWZ3XMnEtl_ZAktr8Lhf2tbHKtoA%3D" alt="Axella"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12913507/f7181eacafe8469a93033d85f5969c29/2?token-time=2145916800&token-hash=mgPdX9TqZxEg4TTPuc477dxhIgYk9246qafjWZEqZ7g%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="Xeltica"></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=12378075">39ff</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=12731202">negao</a></td> | ||||
| <td><a href="https://www.patreon.com/negao">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/AxellaMC">Xeltica</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=3384329">べすれい</a></td> | ||||
| <td><a href="https://www.patreon.com/gutfuckllc">gutfuckllc</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=12718187">Peter G.</a></td> | ||||
| @@ -75,23 +91,17 @@ Misskey is using Crowdin for l10n. | ||||
| </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/4950409/28e7d016209243759d9316be2e21381d/2?token-time=2145916800&token-hash=LuEaDkchH3GQWUcTOhBQ8xfKQYF0s5FjlZRd7Yduia8%3D" alt="mikan54951"></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> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12959468/c249e15aebec4424b5c0f427173671b6/1?token-time=2145916800&token-hash=lubpCEdxAkxPlpR2O6bvZ7BIh8Q4nGf-U_mE1qpjVAQ%3D" alt="fujishan"></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=4950409">mikan54951</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=12531784">Takashi Shibuya</a></td> | ||||
| <td><a href="https://www.patreon.com/fujishan">fujishan</a></td> | ||||
| </tr></table> | ||||
|  | ||||
| **Last updated:** Sun, 26 Aug 2018 08:55:06 UTC | ||||
| **Last updated:** Tue, 02 Oct 2018 09:25:07 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 | 
| @@ -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 | ||||
| @@ -131,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)でマイグレーション情報を確認する | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
|   | ||||
| @@ -78,7 +78,7 @@ gulp.task('build:copy', ['build:copy:views', 'build:copy:lang'], () => | ||||
| 	]).pipe(gulp.dest('./built/')) | ||||
| ); | ||||
|  | ||||
| gulp.task('test', ['lint', 'mocha']); | ||||
| gulp.task('test', ['mocha']); | ||||
|  | ||||
| gulp.task('lint', () => | ||||
| 	gulp.src('./src/**/*.ts') | ||||
| @@ -166,9 +166,7 @@ gulp.task('build:client:pug', [ | ||||
| 			.pipe(pug({ | ||||
| 				locals: { | ||||
| 					themeColor: constants.themeColor, | ||||
| 					facss: fa.dom.css(), | ||||
| 					//hljscss: fs.readFileSync('./node_modules/highlight.js/styles/default.css', 'utf8') | ||||
| 					hljscss: fs.readFileSync('./src/client/assets/code-highlight.css', 'utf8') | ||||
| 					facss: fa.dom.css() | ||||
| 				} | ||||
| 			})) | ||||
| 			.pipe(htmlmin({ | ||||
|   | ||||
| @@ -1,5 +1,3 @@ | ||||
| # **Please DO NOT edit these files** except `ja-JP.yml`. | ||||
| # **DO NOT edit locale files** except `ja-JP.yml`. | ||||
|  | ||||
| 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) 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: "何かありましたか?" | ||||
| @@ -87,6 +109,12 @@ common: | ||||
|   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: "あなたのターンです" | ||||
| @@ -127,7 +155,10 @@ common: | ||||
|     home: "ホーム" | ||||
|     local: "ローカル" | ||||
|     hybrid: "ソーシャル" | ||||
|     hashtag: "ハッシュタグ" | ||||
|     global: "グローバル" | ||||
|     mentions: "あなた宛て" | ||||
|     direct: "ダイレクト投稿" | ||||
|     notifications: "通知" | ||||
|     list: "リスト" | ||||
|     swap-left: "左に移動" | ||||
| @@ -230,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: "あなた" | ||||
| @@ -260,6 +297,8 @@ common/views/components/nav.vue: | ||||
|   develop: "開発者" | ||||
|   feedback: "フィードバック" | ||||
| common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   pin: "ピン留め" | ||||
|   delete: "削除" | ||||
| @@ -337,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: "お知らせはありません" | ||||
| @@ -360,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: "表示を切り替え" | ||||
| @@ -432,6 +472,7 @@ desktop/views/components/charts.vue: | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
| @@ -443,6 +484,9 @@ desktop/views/components/charts.vue: | ||||
|     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からドライブにファイルをアップロード" | ||||
| @@ -565,8 +609,6 @@ desktop/views/components/notes.note.vue: | ||||
|   detail: "詳細" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   hide: "隠す" | ||||
|   see-more: "もっと見る" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "読み込みに失敗しました。" | ||||
|   retry: "リトライ" | ||||
| @@ -636,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: "詳細設定" | ||||
| @@ -647,6 +692,7 @@ desktop/views/components/settings.vue: | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
| @@ -747,7 +793,7 @@ desktop/views/components/settings.profile.vue: | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
| @@ -764,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: "さん" | ||||
| @@ -861,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: | ||||
| @@ -998,8 +1053,6 @@ mobile/views/components/friends-maker.vue: | ||||
|   close: "閉じる" | ||||
| mobile/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   more: "もっと見る" | ||||
|   less: "隠す" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   location: "位置情報" | ||||
| @@ -1088,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: | ||||
| @@ -1128,6 +1183,9 @@ mobile/views/pages/settings/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
| @@ -1149,6 +1207,7 @@ mobile/views/pages/settings.vue: | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   timeline: "タイムライン" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteを表示する" | ||||
| @@ -1157,8 +1216,14 @@ mobile/views/pages/settings.vue: | ||||
|   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: "リモートサーバーのメディアを表示する" | ||||
| @@ -1178,7 +1243,7 @@ mobile/views/pages/settings.vue: | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enableSounds: "サウンドを有効にする" | ||||
|   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: "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?" | ||||
| @@ -87,6 +109,12 @@ common: | ||||
|   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: "あなたのターンです" | ||||
| @@ -127,7 +155,10 @@ common: | ||||
|     home: "Startseite" | ||||
|     local: "Lokal" | ||||
|     hybrid: "ソーシャル" | ||||
|     hashtag: "ハッシュタグ" | ||||
|     global: "Global" | ||||
|     mentions: "あなた宛て" | ||||
|     direct: "ダイレクト投稿" | ||||
|     notifications: "Mitteilungen" | ||||
|     list: "Listen" | ||||
|     swap-left: "Nach links" | ||||
| @@ -230,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" | ||||
| @@ -260,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" | ||||
| @@ -337,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" | ||||
| @@ -360,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" | ||||
| @@ -432,6 +472,7 @@ desktop/views/components/charts.vue: | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
| @@ -443,6 +484,9 @@ desktop/views/components/charts.vue: | ||||
|     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" | ||||
| @@ -565,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" | ||||
| @@ -636,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" | ||||
| @@ -647,6 +692,7 @@ 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: "最近のハッシュタグを投稿フォームに表示する" | ||||
| @@ -747,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です" | ||||
| @@ -764,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: "さん" | ||||
| @@ -861,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: | ||||
| @@ -998,8 +1053,6 @@ mobile/views/components/friends-maker.vue: | ||||
|   close: "閉じる" | ||||
| mobile/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   more: "もっと見る" | ||||
|   less: "隠す" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   location: "位置情報" | ||||
| @@ -1088,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: | ||||
| @@ -1128,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: "アップロード中" | ||||
| @@ -1149,6 +1207,7 @@ mobile/views/pages/settings.vue: | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   timeline: "タイムライン" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteを表示する" | ||||
| @@ -1157,8 +1216,14 @@ mobile/views/pages/settings.vue: | ||||
|   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: "リモートサーバーのメディアを表示する" | ||||
| @@ -1178,7 +1243,7 @@ mobile/views/pages/settings.vue: | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enableSounds: "サウンドを有効にする" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   following: "フォロー" | ||||
|   | ||||
| @@ -6,6 +6,19 @@ 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: "Some features may be unavailable or cause malfunctions if ad blocking features are enabled. <strong>Misskey is not running ads</strong>." | ||||
| @@ -68,6 +81,15 @@ 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?" | ||||
| @@ -84,9 +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" | ||||
|   use-contrast-reversi-stones: "Make the stone color clear" | ||||
|   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" | ||||
| @@ -127,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" | ||||
| @@ -230,6 +261,12 @@ common/views/components/connect-failed.troubleshooter.vue: | ||||
|   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" | ||||
| @@ -260,6 +297,8 @@ 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" | ||||
|   delete: "Delete" | ||||
| @@ -337,6 +376,9 @@ common/views/components/visibility-chooser.vue: | ||||
|   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" | ||||
| @@ -360,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" | ||||
| @@ -399,6 +439,7 @@ common/views/pages/follow.vue: | ||||
|   following: "Following" | ||||
|   follow: "Follow" | ||||
|   request-pending: "Pending follow request" | ||||
|   follow-processing: "Processing follow" | ||||
|   follow-request: "Follow request" | ||||
| desktop: | ||||
|   banner-crop-title: "Crop the part that appears as a banner" | ||||
| @@ -432,6 +473,7 @@ desktop/views/components/charts.vue: | ||||
|   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)" | ||||
| @@ -443,6 +485,9 @@ desktop/views/components/charts.vue: | ||||
|     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" | ||||
| @@ -521,6 +566,7 @@ desktop/views/components/follow-button.vue: | ||||
|   following: "Following" | ||||
|   follow: "Follow" | ||||
|   request-pending: "Pending follow request" | ||||
|   follow-processing: "Processing follow" | ||||
|   follow-request: "Follow request" | ||||
| desktop/views/components/followers-window.vue: | ||||
|   followers: "{}'s followers" | ||||
| @@ -565,8 +611,6 @@ desktop/views/components/notes.note.vue: | ||||
|   detail: "Show details" | ||||
|   private: "Post is private" | ||||
|   deleted: "Post has been deleted" | ||||
|   hide: "Hide" | ||||
|   see-more: "See more" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "Loading failed." | ||||
|   retry: "Retry" | ||||
| @@ -636,6 +680,9 @@ 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: "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" | ||||
| @@ -647,6 +694,7 @@ 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" | ||||
| @@ -747,7 +795,7 @@ desktop/views/components/settings.profile.vue: | ||||
|   birthday: "Birthday" | ||||
|   save: "Update profile" | ||||
|   locked-account: "Protect your account" | ||||
|   is-locked: "Make your posts private" | ||||
|   is-locked: "Follow request needs approval" | ||||
|   other: "Other" | ||||
|   is-bot: "This account is a Bot" | ||||
|   is-cat: "This account is a Cat" | ||||
| @@ -764,7 +812,13 @@ 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: "-san" | ||||
| @@ -861,7 +915,10 @@ desktop/views/pages/welcome.vue: | ||||
|   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: | ||||
| @@ -897,7 +954,7 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   no-users: "No frequent mentions" | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "This account has been suspended." | ||||
|   is-remote: "The user is a remote user. The profile that you see here may 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:" | ||||
| @@ -989,6 +1046,7 @@ mobile/views/components/follow-button.vue: | ||||
|   following: "Following" | ||||
|   follow: "Follow" | ||||
|   request-pending: "Pending follow request" | ||||
|   follow-processing: "Processing follow" | ||||
|   follow-request: "Follow request" | ||||
| mobile/views/components/friends-maker.vue: | ||||
|   title: "Let's follow them" | ||||
| @@ -998,8 +1056,6 @@ mobile/views/components/friends-maker.vue: | ||||
|   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" | ||||
| @@ -1088,6 +1144,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: | ||||
| @@ -1128,6 +1186,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" | ||||
| @@ -1149,6 +1210,7 @@ mobile/views/pages/settings.vue: | ||||
|   dark-mode: "Dark Mode" | ||||
|   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" | ||||
| @@ -1157,8 +1219,14 @@ mobile/views/pages/settings.vue: | ||||
|   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 original quality" | ||||
|   load-remote-media: "Show media from a remote server" | ||||
| @@ -1178,7 +1246,7 @@ mobile/views/pages/settings.vue: | ||||
|   settings: "Settings" | ||||
|   signout: "Sign out" | ||||
|   sound: "Sounds" | ||||
|   enableSounds: "Enable sounds" | ||||
|   enable-sounds: "Enable sounds" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "Follows you" | ||||
|   following: "Following" | ||||
|   | ||||
| @@ -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: "いいね" | ||||
|     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,9 +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" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   verified-user: "公式アカウント" | ||||
|   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" | ||||
| @@ -127,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." | ||||
| @@ -170,9 +201,9 @@ common/views/components/games/reversi/reversi.vue: | ||||
| common/views/components/games/reversi/reversi.game.vue: | ||||
|   surrender: "Rendirse" | ||||
|   surrendered: "Por rendirse" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
|   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!" | ||||
| @@ -230,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" | ||||
| @@ -260,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" | ||||
| @@ -288,10 +327,10 @@ common/views/components/signin.vue: | ||||
|   signin: "Entra" | ||||
|   or: "O" | ||||
|   signin-with-twitter: "Ingresar con Twitter" | ||||
|   login-failed: "ログインできませんでした。ユーザー名とパスワードを確認してください。" | ||||
|   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: "招待コード" | ||||
|   invitation-info: "招待コードをお持ちでない方は、<a href=\"{}\">管理者</a>までご連絡ください。" | ||||
|   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" | ||||
| @@ -337,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" | ||||
| @@ -360,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" | ||||
| @@ -411,7 +451,7 @@ desktop: | ||||
|   uploading-avatar: "Cargando un nuevo avatar" | ||||
|   avatar-updated: "Avatar actualizado" | ||||
|   choose-avatar: "Escoge una imagen de avatar" | ||||
|   invalid-filetype: "この形式のファイルはサポートされていません" | ||||
|   invalid-filetype: "Este tipo de archivo no es compatible aquí" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Negro ... Total" | ||||
|   notes: "Azul ... Notas" | ||||
| @@ -426,23 +466,27 @@ desktop/views/components/calendar.vue: | ||||
|   next: "Próximo mes" | ||||
|   go: "Click para navegar" | ||||
| desktop/views/components/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   title: "Gráficos" | ||||
|   per-day: "por día" | ||||
|   per-hour: "por hora" | ||||
|   notes: "Publicaciones" | ||||
|   users: "Usuarios" | ||||
|   drive: "Unidad" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の累計" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの累計" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の累計" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の累計" | ||||
|     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" | ||||
| @@ -463,7 +507,7 @@ desktop/views/components/drive-window.vue: | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "Avatar" | ||||
|   banner: "Banner" | ||||
|   nsfw: "閲覧注意" | ||||
|   nsfw: "Ver más" | ||||
|   contextmenu: | ||||
|     rename: "Renombrar" | ||||
|     mark-as-sensitive: "Marcar como 'sensible'" | ||||
| @@ -515,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: | ||||
| @@ -565,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" | ||||
| @@ -602,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" | ||||
| @@ -636,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" | ||||
| @@ -647,6 +692,7 @@ 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: "最近のハッシュタグを投稿フォームに表示する" | ||||
| @@ -747,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です" | ||||
| @@ -764,42 +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: "ホームのカスタマイズ" | ||||
|   admin: "管理" | ||||
|   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: | ||||
| @@ -861,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: | ||||
| @@ -998,8 +1053,6 @@ mobile/views/components/friends-maker.vue: | ||||
|   close: "閉じる" | ||||
| mobile/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   more: "もっと見る" | ||||
|   less: "隠す" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   location: "位置情報" | ||||
| @@ -1088,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: | ||||
| @@ -1128,6 +1183,9 @@ mobile/views/pages/settings/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
| @@ -1149,6 +1207,7 @@ mobile/views/pages/settings.vue: | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   timeline: "タイムライン" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteを表示する" | ||||
| @@ -1157,8 +1216,14 @@ mobile/views/pages/settings.vue: | ||||
|   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: "リモートサーバーのメディアを表示する" | ||||
| @@ -1178,7 +1243,7 @@ mobile/views/pages/settings.vue: | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enableSounds: "サウンドを有効にする" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   following: "フォロー" | ||||
|   | ||||
| @@ -6,6 +6,19 @@ common: | ||||
|   misskey: "Une ⭐ du fédiverse" | ||||
|   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 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é." | ||||
| @@ -68,6 +81,15 @@ common: | ||||
|     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 faites-vous maintenant ?" | ||||
|     b: "Quoi de neuf ?" | ||||
| @@ -87,6 +109,12 @@ common: | ||||
|   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" | ||||
| @@ -127,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" | ||||
| @@ -172,7 +203,7 @@ common/views/components/games/reversi/reversi.game.vue: | ||||
|   surrendered: "Par abandon" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "Carte en boucle" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
|   can-put-everywhere: "Peut poser partout" | ||||
| common/views/components/games/reversi/reversi.index.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "Jouer à Reversi avec vos ami·e·s !" | ||||
| @@ -230,6 +261,12 @@ 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·e utilisateur·trice" | ||||
|   you: "Vous" | ||||
| @@ -260,6 +297,8 @@ common/views/components/nav.vue: | ||||
|   develop: "Développeur·se·s" | ||||
|   feedback: "Remarques" | ||||
| common/views/components/note-menu.vue: | ||||
|   detail: "Détails" | ||||
|   copy-link: "Copier le lien" | ||||
|   favorite: "Mettre cette note en favoris" | ||||
|   pin: "Épingler sur votre profil" | ||||
|   delete: "Supprimer" | ||||
| @@ -337,6 +376,9 @@ common/views/components/visibility-chooser.vue: | ||||
|   specified: "Direct" | ||||
|   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écupération" | ||||
|   no-broadcasts: "Aucune annonce" | ||||
| @@ -360,8 +402,6 @@ common/views/widgets/posts-monitor.vue: | ||||
|   toggle: "Basculer entre les vues" | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "Étiquettes" | ||||
|   count: "{} utilisateur·rice·s mentionné·e·s" | ||||
|   empty: "Aucune tendance" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "Informations sur le serveur" | ||||
|   toggle: "Afficher les vues" | ||||
| @@ -391,7 +431,7 @@ common/views/widgets/tips.vue: | ||||
|   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: | ||||
| @@ -432,17 +472,21 @@ desktop/views/components/charts.vue: | ||||
|   notes: "Publications" | ||||
|   users: "Utilisateurs" | ||||
|   drive: "Drive" | ||||
|   network: "Réseau" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の累計" | ||||
|     users: "ユーザーの増減" | ||||
|     users-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 ordinateur" | ||||
| @@ -565,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" | ||||
| @@ -636,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" | ||||
| @@ -647,8 +692,9 @@ 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" | ||||
| @@ -747,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" | ||||
| @@ -764,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: "さん" | ||||
| @@ -861,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: | ||||
| @@ -971,14 +1026,14 @@ mobile/views/components/drive-file-chooser.vue: | ||||
| mobile/views/components/drive-folder-chooser.vue: | ||||
|   select-folder: "Choisissez un dossier" | ||||
| mobile/views/components/drive.file.vue: | ||||
|   nsfw: "閲覧注意" | ||||
|   nsfw: "CW" | ||||
| mobile/views/components/drive.file-detail.vue: | ||||
|   download: "Télécharger" | ||||
|   rename: "Renommer" | ||||
|   move: "Déplacer" | ||||
|   hash: "Hash (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
|   nsfw: "CW" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "Le contenu est NSFW" | ||||
|   click-to-show: "Cliquer pour afficher" | ||||
| @@ -998,8 +1053,6 @@ mobile/views/components/friends-maker.vue: | ||||
|   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" | ||||
| @@ -1045,7 +1098,7 @@ mobile/views/components/timeline.vue: | ||||
|   load-more: "Afficher plus" | ||||
| mobile/views/components/ui.header.vue: | ||||
|   welcome-back: "Content de vous revoir ! " | ||||
|   adjective: "さん" | ||||
|   adjective: "M." | ||||
| mobile/views/components/ui.nav.vue: | ||||
|   timeline: "Fil d'actualité" | ||||
|   notifications: "Notifications" | ||||
| @@ -1088,6 +1141,8 @@ mobile/views/pages/home.vue: | ||||
|   local: "Local" | ||||
|   hybrid: "Social" | ||||
|   global: "Global" | ||||
|   mentions: "Mentions" | ||||
|   messages: "メッセージ" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "Pas de message avec un hashtag {} trouvé." | ||||
| mobile/views/pages/welcome.vue: | ||||
| @@ -1128,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" | ||||
| @@ -1149,6 +1207,7 @@ 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" | ||||
| @@ -1157,8 +1216,14 @@ mobile/views/pages/settings.vue: | ||||
|   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" | ||||
| @@ -1178,7 +1243,7 @@ mobile/views/pages/settings.vue: | ||||
|   settings: "Réglages" | ||||
|   signout: "Déconnexion" | ||||
|   sound: "Sons" | ||||
|   enableSounds: "Activer le son" | ||||
|   enable-sounds: "Activer les sons" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "vous suit" | ||||
|   following: "Abonnements" | ||||
| @@ -1223,7 +1288,7 @@ docs: | ||||
|       res: "Réponse" | ||||
|       require-credential: "Ce point de communication nécessite une authentification." | ||||
|       require-permission: "Ce point de communication nécessite la permission {permission}." | ||||
|       has-limit: "レートリミットがあります。" | ||||
|       has-limit: "Il y’a un taux limite." | ||||
|       duration-limit: "直近{duration}ミリ秒の間のこのエンドポイントへのリクエスト数の合計が{max}を超える場合はリクエストできません。" | ||||
|       min-interval-limit: "前回のリクエストから{interval}ミリ秒経っていない場合はリクエストできません。" | ||||
|       show-src: "Vous pouvez voir le code source ce point de communication." | ||||
|   | ||||
| @@ -5,24 +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-JP'); | ||||
| const loadLocale = lang => yaml.safeLoad(fs.readFileSync(`${__dirname}/${lang}.yml`, 'utf-8')); | ||||
| const locales = langs.map(lang => ({ [lang]: loadLocale(lang) })); | ||||
|  | ||||
| const langs = { | ||||
| 	'de-DE': loadLang('de-DE'), | ||||
| 	'en-US': loadLang('en-US'), | ||||
| 	'fr-FR': loadLang('fr-FR'), | ||||
| 	'ja-JP': native, | ||||
| 	'ja-KS': loadLang('ja-KS'), | ||||
| 	'pl-PL': loadLang('pl-PL'), | ||||
| 	'es-ES': loadLang('es-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: "何かありましたか?" | ||||
| @@ -87,6 +109,12 @@ common: | ||||
|   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: "あなたのターンです" | ||||
| @@ -127,7 +155,10 @@ common: | ||||
|     home: "ホーム" | ||||
|     local: "ローカル" | ||||
|     hybrid: "ソーシャル" | ||||
|     hashtag: "ハッシュタグ" | ||||
|     global: "グローバル" | ||||
|     mentions: "あなた宛て" | ||||
|     direct: "ダイレクト投稿" | ||||
|     notifications: "通知" | ||||
|     list: "リスト" | ||||
|     swap-left: "左に移動" | ||||
| @@ -230,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: "あなた" | ||||
| @@ -260,6 +297,8 @@ common/views/components/nav.vue: | ||||
|   develop: "開発者" | ||||
|   feedback: "フィードバック" | ||||
| common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   pin: "ピン留め" | ||||
|   delete: "削除" | ||||
| @@ -337,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: "お知らせはありません" | ||||
| @@ -360,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: "表示を切り替え" | ||||
| @@ -432,6 +472,7 @@ desktop/views/components/charts.vue: | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
| @@ -443,6 +484,9 @@ desktop/views/components/charts.vue: | ||||
|     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からドライブにファイルをアップロード" | ||||
| @@ -565,8 +609,6 @@ desktop/views/components/notes.note.vue: | ||||
|   detail: "詳細" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   hide: "隠す" | ||||
|   see-more: "もっと見る" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "読み込みに失敗しました。" | ||||
|   retry: "リトライ" | ||||
| @@ -636,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: "詳細設定" | ||||
| @@ -647,6 +692,7 @@ desktop/views/components/settings.vue: | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
| @@ -747,7 +793,7 @@ desktop/views/components/settings.profile.vue: | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
| @@ -764,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: "さん" | ||||
| @@ -861,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: | ||||
| @@ -998,8 +1053,6 @@ mobile/views/components/friends-maker.vue: | ||||
|   close: "閉じる" | ||||
| mobile/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   more: "もっと見る" | ||||
|   less: "隠す" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   location: "位置情報" | ||||
| @@ -1088,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: | ||||
| @@ -1128,6 +1183,9 @@ mobile/views/pages/settings/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
| @@ -1149,6 +1207,7 @@ mobile/views/pages/settings.vue: | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   timeline: "タイムライン" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteを表示する" | ||||
| @@ -1157,8 +1216,14 @@ mobile/views/pages/settings.vue: | ||||
|   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: "リモートサーバーのメディアを表示する" | ||||
| @@ -1178,7 +1243,7 @@ mobile/views/pages/settings.vue: | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enableSounds: "サウンドを有効にする" | ||||
|   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: "何かありましたか?" | ||||
| @@ -93,6 +116,11 @@ common: | ||||
|   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: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||
|  | ||||
| @@ -138,7 +166,10 @@ common: | ||||
|     home: "ホーム" | ||||
|     local: "ローカル" | ||||
|     hybrid: "ソーシャル" | ||||
|     hashtag: "ハッシュタグ" | ||||
|     global: "グローバル" | ||||
|     mentions: "あなた宛て" | ||||
|     direct: "ダイレクト投稿" | ||||
|     notifications: "通知" | ||||
|     list: "リスト" | ||||
|     swap-left: "左に移動" | ||||
| @@ -250,6 +281,45 @@ common/views/components/connect-failed.troubleshooter.vue: | ||||
|   flush: "キャッシュの削除" | ||||
|   set-version: "バージョン指定" | ||||
|  | ||||
| common/views/components/media-banner.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
|  | ||||
| common/views/components/theme.vue: | ||||
|   light-theme: "非ダークモード時に使用するテーマ" | ||||
|   dark-theme: "ダークモード時に使用するテーマ" | ||||
|   install-a-theme: "テーマのインストール" | ||||
|   theme-code: "テーマコード" | ||||
|   install: "インストール" | ||||
|   installed: "「{}」をインストールしました" | ||||
|   create-a-theme: "テーマの作成" | ||||
|   save-created-theme: "テーマを保存" | ||||
|   primary-color: "プライマリ カラー" | ||||
|   secondary-color: "セカンダリ カラー" | ||||
|   text-color: "文字色" | ||||
|   base-theme: "ベーステーマ" | ||||
|   base-theme-light: "Light" | ||||
|   base-theme-dark: "Dark" | ||||
|   theme-name: "テーマ名" | ||||
|   preview-created-theme: "プレビュー" | ||||
|   invalid-theme: "テーマが正しくありません。" | ||||
|   already-installed: "既にそのテーマはインストールされています。" | ||||
|   saved: "保存しました" | ||||
|   installed-themes: "インストールされたテーマ" | ||||
|   select-theme: "テーマを選択してください" | ||||
|   uninstall: "アンインストール" | ||||
|   uninstalled: "「{}」をアンインストールしました" | ||||
|   author: "作者" | ||||
|   desc: "説明" | ||||
|   export: "エクスポート" | ||||
|   import: "インポート" | ||||
|   import-by-code: "またはコードをペースト" | ||||
|   theme-name-required: "テーマ名は必須です。" | ||||
|  | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "隠す" | ||||
|   show: "もっと見る" | ||||
|  | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "ユーザーを探す" | ||||
|   you: "あなた" | ||||
| @@ -289,6 +359,7 @@ common/views/components/note-menu.vue: | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   pin: "ピン留め" | ||||
|   unpin: "ピン留め解除" | ||||
|   delete: "削除" | ||||
|   delete-confirm: "この投稿を削除しますか?" | ||||
|   remote: "投稿元で見る" | ||||
| @@ -375,6 +446,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: "お知らせはありません" | ||||
| @@ -403,8 +478,6 @@ common/views/widgets/posts-monitor.vue: | ||||
|  | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "ハッシュタグ" | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
|  | ||||
| common/views/widgets/server.vue: | ||||
|   title: "サーバー情報" | ||||
| @@ -447,6 +520,7 @@ common/views/pages/follow.vue: | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
|   request-pending: "フォロー許可待ち" | ||||
|   follow-processing: "フォロー処理中" | ||||
|   follow-request: "フォロー申請" | ||||
|  | ||||
| desktop: | ||||
| @@ -485,6 +559,7 @@ desktop/views/components/charts.vue: | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
| @@ -496,6 +571,9 @@ desktop/views/components/charts.vue: | ||||
|     drive-total: "ドライブ使用量の累計" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の累計" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
|  | ||||
| desktop/views/components/choose-file-from-drive-window.vue: | ||||
|   choose-file: "ファイル選択中" | ||||
| @@ -585,6 +663,7 @@ desktop/views/components/follow-button.vue: | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
|   request-pending: "フォロー許可待ち" | ||||
|   follow-processing: "フォロー処理中" | ||||
|   follow-request: "フォロー申請" | ||||
|  | ||||
| desktop/views/components/followers-window.vue: | ||||
| @@ -641,8 +720,6 @@ desktop/views/components/notes.note.vue: | ||||
|   detail: "詳細" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   hide: "隠す" | ||||
|   see-more: "もっと見る" | ||||
|  | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "読み込みに失敗しました。" | ||||
| @@ -718,10 +795,14 @@ desktop/views/components/settings.vue: | ||||
|   2fa: "二段階認証" | ||||
|   other: "その他" | ||||
|   license: "ライセンス" | ||||
|   theme: "テーマ" | ||||
|  | ||||
|   behaviour: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込みます。" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   auto-popout: "ウィンドウの自動ポップアウト" | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   advanced: "詳細設定" | ||||
| @@ -733,8 +814,10 @@ desktop/views/components/settings.vue: | ||||
|   choose-wallpaper: "壁紙を選択" | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
|   use-shadow: "UIに影を使用" | ||||
|   rounded-corners: "UIの角を丸める" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
| @@ -743,7 +826,6 @@ desktop/views/components/settings.vue: | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   show-maps-desc: "位置情報が添付された投稿のマップを自動的に展開します。" | ||||
|  | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
| @@ -849,7 +931,7 @@ desktop/views/components/settings.profile.vue: | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
| @@ -869,7 +951,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: "おかえりなさい、" | ||||
| @@ -988,7 +1076,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" | ||||
| @@ -1149,6 +1240,7 @@ mobile/views/components/follow-button.vue: | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
|   request-pending: "フォロー許可待ち" | ||||
|   follow-processing: "フォロー処理中" | ||||
|   follow-request: "フォロー申請" | ||||
|  | ||||
| mobile/views/components/friends-maker.vue: | ||||
| @@ -1160,8 +1252,6 @@ mobile/views/components/friends-maker.vue: | ||||
|  | ||||
| mobile/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   more: "もっと見る" | ||||
|   less: "隠す" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   location: "位置情報" | ||||
| @@ -1269,6 +1359,8 @@ mobile/views/pages/home.vue: | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   mentions: "あなた宛て" | ||||
|   messages: "メッセージ" | ||||
|  | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| @@ -1321,6 +1413,9 @@ mobile/views/pages/settings/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
| @@ -1345,6 +1440,7 @@ mobile/views/pages/settings.vue: | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   timeline: "タイムライン" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteを表示する" | ||||
| @@ -1353,8 +1449,15 @@ mobile/views/pages/settings.vue: | ||||
|   post-style: "投稿の表示スタイル" | ||||
|   post-style-standard: "標準" | ||||
|   post-style-smart: "スマート" | ||||
|   notification-position: "通知の表示" | ||||
|   notification-position-bottom: "下" | ||||
|   notification-position-top: "上" | ||||
|   theme: "テーマ" | ||||
|   behavior: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   load-raw-images: "添付された画像を高画質で表示する" | ||||
|   load-remote-media: "リモートサーバーのメディアを表示する" | ||||
| @@ -1374,7 +1477,7 @@ mobile/views/pages/settings.vue: | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enableSounds: "サウンドを有効にする" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|  | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   | ||||
										
											
												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: "뭔가 있었습니까?" | ||||
| @@ -87,6 +109,12 @@ common: | ||||
|   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: "당신의 차례입니다" | ||||
| @@ -127,7 +155,10 @@ common: | ||||
|     home: "홈" | ||||
|     local: "로컬" | ||||
|     hybrid: "소셜" | ||||
|     hashtag: "ハッシュタグ" | ||||
|     global: "글로벌" | ||||
|     mentions: "あなた宛て" | ||||
|     direct: "ダイレクト投稿" | ||||
|     notifications: "통지" | ||||
|     list: "목록" | ||||
|     swap-left: "左に移動" | ||||
| @@ -230,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: "당신" | ||||
| @@ -260,6 +297,8 @@ common/views/components/nav.vue: | ||||
|   develop: "開発者" | ||||
|   feedback: "フィードバック" | ||||
| common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   pin: "ピン留め" | ||||
|   delete: "削除" | ||||
| @@ -337,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: "お知らせはありません" | ||||
| @@ -360,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: "表示を切り替え" | ||||
| @@ -432,6 +472,7 @@ desktop/views/components/charts.vue: | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
| @@ -443,6 +484,9 @@ desktop/views/components/charts.vue: | ||||
|     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からドライブにファイルをアップロード" | ||||
| @@ -565,8 +609,6 @@ desktop/views/components/notes.note.vue: | ||||
|   detail: "詳細" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   hide: "隠す" | ||||
|   see-more: "もっと見る" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "読み込みに失敗しました。" | ||||
|   retry: "リトライ" | ||||
| @@ -636,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: "詳細設定" | ||||
| @@ -647,6 +692,7 @@ desktop/views/components/settings.vue: | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
| @@ -747,7 +793,7 @@ desktop/views/components/settings.profile.vue: | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
| @@ -764,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: "さん" | ||||
| @@ -861,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: | ||||
| @@ -998,8 +1053,6 @@ mobile/views/components/friends-maker.vue: | ||||
|   close: "閉じる" | ||||
| mobile/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   more: "もっと見る" | ||||
|   less: "隠す" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   location: "位置情報" | ||||
| @@ -1088,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: | ||||
| @@ -1128,6 +1183,9 @@ mobile/views/pages/settings/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
| @@ -1149,6 +1207,7 @@ mobile/views/pages/settings.vue: | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   timeline: "タイムライン" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteを表示する" | ||||
| @@ -1157,8 +1216,14 @@ mobile/views/pages/settings.vue: | ||||
|   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: "リモートサーバーのメディアを表示する" | ||||
| @@ -1178,7 +1243,7 @@ mobile/views/pages/settings.vue: | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enableSounds: "サウンドを有効にする" | ||||
|   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
											
										
									
								
							
							
								
								
									
										1302
									
								
								locales/no-NO.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1302
									
								
								locales/no-NO.yml
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -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." | ||||
| @@ -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?" | ||||
| @@ -87,6 +109,12 @@ common: | ||||
|   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" | ||||
| @@ -127,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" | ||||
| @@ -230,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" | ||||
| @@ -260,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ń" | ||||
| @@ -337,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" | ||||
| @@ -360,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" | ||||
| @@ -432,6 +472,7 @@ desktop/views/components/charts.vue: | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
| @@ -443,6 +484,9 @@ desktop/views/components/charts.vue: | ||||
|     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" | ||||
| @@ -565,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" | ||||
| @@ -636,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" | ||||
| @@ -647,6 +692,7 @@ 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: "最近のハッシュタグを投稿フォームに表示する" | ||||
| @@ -747,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" | ||||
| @@ -764,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: "さん" | ||||
| @@ -861,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: | ||||
| @@ -998,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" | ||||
| @@ -1088,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: | ||||
| @@ -1128,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" | ||||
| @@ -1149,6 +1207,7 @@ 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" | ||||
| @@ -1157,8 +1216,14 @@ mobile/views/pages/settings.vue: | ||||
|   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" | ||||
| @@ -1178,7 +1243,7 @@ mobile/views/pages/settings.vue: | ||||
|   settings: "Ustawienia" | ||||
|   signout: "Wyloguj" | ||||
|   sound: "サウンド" | ||||
|   enableSounds: "サウンドを有効にする" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "Śledzi Cię" | ||||
|   following: "Śledzeni" | ||||
|   | ||||
| @@ -6,6 +6,19 @@ common: | ||||
|   misskey: "Uma ⭐ do fediverso" | ||||
|   about-title: "Uma ⭐ do fediverso." | ||||
|   about: "Obrigado por encontrar Misskey. Uma <b>plataforma descentralizada de microblog</b> nascida na Terra. Já que ela existe no Fediverso (um universo onde várias plataformas de mídia social são organizadas), ela é ligada com outras plataformas.Por que você não tira uma folga do agito e confusão da cidade, e mergulha em uma nova internet?" | ||||
|   intro: | ||||
|     title: "O que é Misskey?" | ||||
|     about: "Misskey é um <b>serviço de microblog descentralizado</b>. Personalização sofisticada da interface, variedade de reações a posts, armazenamento de arquivos grátis com gerenciamento integrado e outras funções avançadas estão disponíveis. Um sistema em rede chamado \"Fediverso\" permite que nos comuniquemos com usuários em outras redes sociais. Se você postar algo, por exemplo, seu post não será mandado apenas para o Misskey, mas também para o Mastodon. Apenas imagine que o planeta está enviando ondas de rádio para outros planetas para se comunicar." | ||||
|     features: "Recursos" | ||||
|     rich-contents: "Post" | ||||
|     rich-contents-desc: "Apenas poste suas ideias, temas do momento e qualquer coisa que você queira compartilhar. Você pode querer decorar suas palavras, anexar suas imagens favoritas, enviar arquivos, inclusive vídeos ou criar uma enquete. Essas são as coisas que você pode fazer em Misskey." | ||||
|     reaction: "Reações" | ||||
|     reaction-desc: "あなたの気持ちを伝える最も簡単な方法です。Misskeyは、他のユーザーの投稿に様々なリアクションを付けることができます。いちどMisskeyのリアクション機能を体験してしまうと、もう「いいね」の概念しか存在しないSNSには戻れなくなるかもしれません。" | ||||
|     ui: "インターフェース" | ||||
|     ui-desc: "どのようなUIが使いやすいかは人それぞれです。だから、Misskeyは自由度の高いUIを持っています。レイアウトやデザインを調整したり、カスタマイズ可能な様々なウィジェットを配置したりして、自分だけのホームを作ってください。" | ||||
|     drive: "ドライブ" | ||||
|     drive-desc: "以前投稿したことのある画像をまた投稿したくなったことはありませんか?もしくは、アップロードしたファイルをフォルダ分けして整理したくなったことはありませんか?Misskeyの根幹に組み込まれたドライブ機能によってそれらが解決します。ファイルの共有も簡単です。" | ||||
|     outro: "他にもMisskeyにしかない機能はまだまだあるので、ぜひあなた自身の目で確かめてください。Misskeyは分散型SNSなので、このインスタンスが気に入らなければ他のインスタンスを試すこともできます。それでは、GLHF!" | ||||
|   adblock: | ||||
|     detected: "Por favor, desative o bloqueador de anúncios." | ||||
|     warning: "Alguns recursos podem não estar disponíveis ou apresentar mal funcionamento se o bloqueio de anúncios estiver ativado. <strong>Misskey não está usando anúncios</strong>" | ||||
| @@ -68,6 +81,15 @@ common: | ||||
|     confused: "Confuso" | ||||
|     rip: "RIP" | ||||
|     pudding: "Pudim" | ||||
|   note-visibility: | ||||
|     public: "公開" | ||||
|     home: "ホーム" | ||||
|     home-desc: "ホームタイムラインにのみ公開" | ||||
|     followers: "フォロワー" | ||||
|     followers-desc: "自分のフォロワーにのみ公開" | ||||
|     specified: "ダイレクト" | ||||
|     specified-desc: "指定したユーザーにのみ公開" | ||||
|     private: "非公開" | ||||
|   note-placeholders: | ||||
|     a: "O que está fazendo?" | ||||
|     b: "O que está acontecendo?" | ||||
| @@ -87,6 +109,12 @@ common: | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   verified-user: "Conta verificada" | ||||
|   disable-animated-mfm: "Desativar texto animado nas publicações" | ||||
|   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: "Empatado" | ||||
|     my-turn: "Seu turno" | ||||
| @@ -127,7 +155,10 @@ common: | ||||
|     home: "Início" | ||||
|     local: "Local" | ||||
|     hybrid: "Social" | ||||
|     hashtag: "ハッシュタグ" | ||||
|     global: "Global" | ||||
|     mentions: "あなた宛て" | ||||
|     direct: "ダイレクト投稿" | ||||
|     notifications: "Notificações" | ||||
|     list: "Listas" | ||||
|     swap-left: "Mover para a esquerda" | ||||
| @@ -230,6 +261,12 @@ common/views/components/connect-failed.troubleshooter.vue: | ||||
|   success-desc: "正常に接続できるようです。ページを再度読み込みしてください。" | ||||
|   flush: "Limpar o cache" | ||||
|   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: "Você" | ||||
| @@ -260,6 +297,8 @@ common/views/components/nav.vue: | ||||
|   develop: "開発者" | ||||
|   feedback: "フィードバック" | ||||
| common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   pin: "ピン留め" | ||||
|   delete: "削除" | ||||
| @@ -337,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: "お知らせはありません" | ||||
| @@ -360,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: "表示を切り替え" | ||||
| @@ -432,6 +472,7 @@ desktop/views/components/charts.vue: | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
| @@ -443,6 +484,9 @@ desktop/views/components/charts.vue: | ||||
|     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からドライブにファイルをアップロード" | ||||
| @@ -565,8 +609,6 @@ desktop/views/components/notes.note.vue: | ||||
|   detail: "詳細" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   hide: "隠す" | ||||
|   see-more: "もっと見る" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "読み込みに失敗しました。" | ||||
|   retry: "リトライ" | ||||
| @@ -636,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: "詳細設定" | ||||
| @@ -647,6 +692,7 @@ desktop/views/components/settings.vue: | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
| @@ -747,7 +793,7 @@ desktop/views/components/settings.profile.vue: | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
| @@ -764,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: "さん" | ||||
| @@ -861,7 +913,10 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "やってる" | ||||
|   signup-button: "やる" | ||||
|   timeline: "Timeline" | ||||
|   announcements: "お知らせ" | ||||
|   photos: "最近の画像" | ||||
|   powered-by-misskey: "Desenvolvido por <b>Misskey</b>." | ||||
|   info: "情報" | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Drive Misskey" | ||||
| desktop/views/pages/favorites.vue: | ||||
| @@ -998,8 +1053,6 @@ mobile/views/components/friends-maker.vue: | ||||
|   close: "閉じる" | ||||
| mobile/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   more: "もっと見る" | ||||
|   less: "隠す" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   location: "位置情報" | ||||
| @@ -1088,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: | ||||
| @@ -1120,20 +1175,23 @@ mobile/views/pages/games/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
|   name: "Nome" | ||||
|   account: "Conta" | ||||
|   location: "Lugar" | ||||
|   description: "Biografia" | ||||
|   birthday: "Data de nascimento" | ||||
|   avatar: "Avatar" | ||||
|   banner: "Capa" | ||||
|   is-cat: "Esta conta é gato" | ||||
|   is-locked: "Pedido para seguir precisa ser aprovado" | ||||
|   advanced: "Avançado" | ||||
|   privacy: "Provacidade" | ||||
|   save: "Atualizar perfil" | ||||
|   saved: "Perfil atualizado" | ||||
|   uploading: "Enviando" | ||||
|   upload-failed: "Falha ao enviar" | ||||
| mobile/views/pages/search.vue: | ||||
|   search: "検索" | ||||
|   search: "Pesquisar" | ||||
|   empty: "「{}」に関する投稿は見つかりませんでした。" | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
| mobile/views/pages/selectdrive.vue: | ||||
| @@ -1149,6 +1207,7 @@ mobile/views/pages/settings.vue: | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   timeline: "タイムライン" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteを表示する" | ||||
| @@ -1157,53 +1216,59 @@ mobile/views/pages/settings.vue: | ||||
|   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: "リモートサーバーのメディアを表示する" | ||||
|   twitter: "Twitter連携" | ||||
|   twitter-connect: "Twitterアカウントに接続する" | ||||
|   twitter-reconnect: "再接続する" | ||||
|   twitter-disconnect: "切断する" | ||||
|   update: "Misskey Update" | ||||
|   version: "バージョン:" | ||||
|   latest-version: "最新のバージョン:" | ||||
|   update-checking: "アップデートを確認中" | ||||
|   check-for-updates: "アップデートを確認" | ||||
|   no-updates: "利用可能な更新はありません" | ||||
|   no-updates-desc: "お使いのMisskeyは最新です。" | ||||
|   update-available: "新しいバージョンが利用可能です" | ||||
|   update-available-desc: "ページを再度読み込みすると更新が適用されます。" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enableSounds: "サウンドを有効にする" | ||||
|   twitter-connect: "Conectar à sua conta no Twitter" | ||||
|   twitter-reconnect: "Reconectar" | ||||
|   twitter-disconnect: "Desconectar" | ||||
|   update: "Atualizar Misskey" | ||||
|   version: "Versão atual;" | ||||
|   latest-version: "Última versão:" | ||||
|   update-checking: "Verificando atualizações" | ||||
|   check-for-updates: "Verificar atualizações" | ||||
|   no-updates: "Sem atualizações" | ||||
|   no-updates-desc: "Seu Misskey está atualizado" | ||||
|   update-available: "Uma nova versão está disponível" | ||||
|   update-available-desc: "Atualizações vão ser aplicadas depois de recarregar a página" | ||||
|   settings: "Configurações" | ||||
|   signout: "Sair" | ||||
|   sound: "Sons" | ||||
|   enable-sounds: "Ativar sons" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   notes: "投稿" | ||||
|   follows-you: "Te segue" | ||||
|   following: "Seguindo" | ||||
|   followers: "Seguidores" | ||||
|   notes: "Posts" | ||||
|   overview: "概要" | ||||
|   timeline: "タイムライン" | ||||
|   media: "メディア" | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   timeline: "Linha do tempo" | ||||
|   media: "Mídia" | ||||
|   is-suspended: "Esta conta foi suspensa" | ||||
|   is-remote: "Este é uma usuário remoto. O perfil que vê aqui pode não estar completo." | ||||
|   view-remote: "Ver o perfil completo." | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "Notas recentes" | ||||
|   images: "Imagens" | ||||
|   activity: "Atividade" | ||||
|   keywords: "キーワード" | ||||
|   domains: "頻出ドメイン" | ||||
|   frequently-replied-users: "よく会話するユーザー" | ||||
|   keywords: "Palavras chave" | ||||
|   domains: "Domínios" | ||||
|   frequently-replied-users: "Perguntas frequentes" | ||||
|   followers-you-know: "Seguidores que você conhece" | ||||
|   last-used-at: "Ativo pela última vez:" | ||||
| mobile/views/pages/user/home.followers-you-know.vue: | ||||
|   loading: "Carregando" | ||||
|   no-users: "知り合いのユーザーはいません" | ||||
| mobile/views/pages/user/home.friends.vue: | ||||
|   loading: "読み込み中" | ||||
|   loading: "Carregando" | ||||
|   no-users: "よく会話するユーザーはいません" | ||||
| mobile/views/pages/user/home.notes.vue: | ||||
|   loading: "Carregando" | ||||
| @@ -1213,14 +1278,14 @@ mobile/views/pages/user/home.photos.vue: | ||||
|   no-photos: "Sem fotos" | ||||
| docs: | ||||
|   edit-this-page-on-github: "間違いや改善点を見つけましたか?" | ||||
|   edit-this-page-on-github-link: "このページをGitHubで編集" | ||||
|   edit-this-page-on-github-link: "Edite esta página no GitHub!" | ||||
|   api: | ||||
|     entities: | ||||
|       properties: "プロパティ" | ||||
|       properties: "Propriedades" | ||||
|     endpoints: | ||||
|       params: "パラメータ" | ||||
|       no-params: "パラメータはありません" | ||||
|       res: "レスポンス" | ||||
|       params: "Parâmetros" | ||||
|       no-params: "Sem parâmetros" | ||||
|       res: "Resposta" | ||||
|       require-credential: "このエンドポイントは認証情報が必須です。" | ||||
|       require-permission: "このエンドポイントは{permission}の権限を必要とします。" | ||||
|       has-limit: "レートリミットがあります。" | ||||
|   | ||||
| @@ -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: "何かありましたか?" | ||||
| @@ -87,6 +109,12 @@ common: | ||||
|   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: "あなたのターンです" | ||||
| @@ -127,7 +155,10 @@ common: | ||||
|     home: "ホーム" | ||||
|     local: "ローカル" | ||||
|     hybrid: "ソーシャル" | ||||
|     hashtag: "ハッシュタグ" | ||||
|     global: "グローバル" | ||||
|     mentions: "あなた宛て" | ||||
|     direct: "ダイレクト投稿" | ||||
|     notifications: "通知" | ||||
|     list: "リスト" | ||||
|     swap-left: "左に移動" | ||||
| @@ -230,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: "あなた" | ||||
| @@ -260,6 +297,8 @@ common/views/components/nav.vue: | ||||
|   develop: "開発者" | ||||
|   feedback: "フィードバック" | ||||
| common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   pin: "ピン留め" | ||||
|   delete: "削除" | ||||
| @@ -337,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: "お知らせはありません" | ||||
| @@ -360,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: "表示を切り替え" | ||||
| @@ -432,6 +472,7 @@ desktop/views/components/charts.vue: | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
| @@ -443,6 +484,9 @@ desktop/views/components/charts.vue: | ||||
|     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からドライブにファイルをアップロード" | ||||
| @@ -565,8 +609,6 @@ desktop/views/components/notes.note.vue: | ||||
|   detail: "詳細" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   hide: "隠す" | ||||
|   see-more: "もっと見る" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "読み込みに失敗しました。" | ||||
|   retry: "リトライ" | ||||
| @@ -636,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: "詳細設定" | ||||
| @@ -647,6 +692,7 @@ desktop/views/components/settings.vue: | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
| @@ -747,7 +793,7 @@ desktop/views/components/settings.profile.vue: | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
| @@ -764,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: "さん" | ||||
| @@ -861,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: | ||||
| @@ -998,8 +1053,6 @@ mobile/views/components/friends-maker.vue: | ||||
|   close: "閉じる" | ||||
| mobile/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   more: "もっと見る" | ||||
|   less: "隠す" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   location: "位置情報" | ||||
| @@ -1088,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: | ||||
| @@ -1128,6 +1183,9 @@ mobile/views/pages/settings/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
| @@ -1149,6 +1207,7 @@ mobile/views/pages/settings.vue: | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   timeline: "タイムライン" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteを表示する" | ||||
| @@ -1157,8 +1216,14 @@ mobile/views/pages/settings.vue: | ||||
|   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: "リモートサーバーのメディアを表示する" | ||||
| @@ -1178,7 +1243,7 @@ mobile/views/pages/settings.vue: | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enableSounds: "サウンドを有効にする" | ||||
|   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: "何かありましたか?" | ||||
| @@ -87,6 +109,12 @@ common: | ||||
|   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: "あなたのターンです" | ||||
| @@ -127,7 +155,10 @@ common: | ||||
|     home: "ホーム" | ||||
|     local: "ローカル" | ||||
|     hybrid: "ソーシャル" | ||||
|     hashtag: "ハッシュタグ" | ||||
|     global: "グローバル" | ||||
|     mentions: "あなた宛て" | ||||
|     direct: "ダイレクト投稿" | ||||
|     notifications: "通知" | ||||
|     list: "リスト" | ||||
|     swap-left: "左に移動" | ||||
| @@ -230,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: "あなた" | ||||
| @@ -260,6 +297,8 @@ common/views/components/nav.vue: | ||||
|   develop: "開発者" | ||||
|   feedback: "フィードバック" | ||||
| common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   pin: "ピン留め" | ||||
|   delete: "削除" | ||||
| @@ -337,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: "お知らせはありません" | ||||
| @@ -360,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: "表示を切り替え" | ||||
| @@ -432,6 +472,7 @@ desktop/views/components/charts.vue: | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
| @@ -443,6 +484,9 @@ desktop/views/components/charts.vue: | ||||
|     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からドライブにファイルをアップロード" | ||||
| @@ -565,8 +609,6 @@ desktop/views/components/notes.note.vue: | ||||
|   detail: "詳細" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   hide: "隠す" | ||||
|   see-more: "もっと見る" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "読み込みに失敗しました。" | ||||
|   retry: "リトライ" | ||||
| @@ -636,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: "詳細設定" | ||||
| @@ -647,6 +692,7 @@ desktop/views/components/settings.vue: | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
| @@ -747,7 +793,7 @@ desktop/views/components/settings.profile.vue: | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
| @@ -764,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: "さん" | ||||
| @@ -861,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: | ||||
| @@ -998,8 +1053,6 @@ mobile/views/components/friends-maker.vue: | ||||
|   close: "閉じる" | ||||
| mobile/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   more: "もっと見る" | ||||
|   less: "隠す" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   location: "位置情報" | ||||
| @@ -1088,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: | ||||
| @@ -1128,6 +1183,9 @@ mobile/views/pages/settings/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
| @@ -1149,6 +1207,7 @@ mobile/views/pages/settings.vue: | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   timeline: "タイムライン" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteを表示する" | ||||
| @@ -1157,8 +1216,14 @@ mobile/views/pages/settings.vue: | ||||
|   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: "リモートサーバーのメディアを表示する" | ||||
| @@ -1178,7 +1243,7 @@ mobile/views/pages/settings.vue: | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enableSounds: "サウンドを有効にする" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   following: "フォロー" | ||||
|   | ||||
							
								
								
									
										57
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										57
									
								
								package.json
									
									
									
									
									
								
							| @@ -1,8 +1,8 @@ | ||||
| { | ||||
| 	"name": "misskey", | ||||
| 	"author": "syuilo <i@syuilo.com>", | ||||
| 	"version": "8.17.0", | ||||
| 	"clientVersion": "1.0.9212", | ||||
| 	"version": "9.3.0", | ||||
| 	"clientVersion": "1.0.10062", | ||||
| 	"codename": "nighthike", | ||||
| 	"main": "./built/index.js", | ||||
| 	"private": true, | ||||
| @@ -20,14 +20,14 @@ | ||||
| 		"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", | ||||
| 		"@types/bcryptjs": "2.4.1", | ||||
| 		"@types/bcryptjs": "2.4.2", | ||||
| 		"@types/dateformat": "1.0.1", | ||||
| 		"@types/debug": "0.0.30", | ||||
| 		"@types/deep-equal": "1.0.1", | ||||
| @@ -51,16 +51,16 @@ | ||||
| 		"@types/koa-logger": "3.1.0", | ||||
| 		"@types/koa-mount": "3.0.1", | ||||
| 		"@types/koa-multer": "1.0.0", | ||||
| 		"@types/koa-router": "7.0.31", | ||||
| 		"@types/koa-router": "7.0.32", | ||||
| 		"@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.4", | ||||
| 		"@types/mongodb": "3.1.7", | ||||
| 		"@types/ms": "0.7.30", | ||||
| 		"@types/node": "10.9.4", | ||||
| 		"@types/node": "10.10.3", | ||||
| 		"@types/portscanner": "2.1.0", | ||||
| 		"@types/pug": "2.0.4", | ||||
| 		"@types/qrcode": "1.2.0", | ||||
| @@ -75,12 +75,13 @@ | ||||
| 		"@types/single-line-log": "1.1.0", | ||||
| 		"@types/speakeasy": "2.0.2", | ||||
| 		"@types/systeminformation": "3.23.0", | ||||
| 		"@types/tinycolor2": "1.4.1", | ||||
| 		"@types/tmp": "0.0.33", | ||||
| 		"@types/uuid": "3.4.4", | ||||
| 		"@types/webpack": "4.4.11", | ||||
| 		"@types/webpack": "4.4.12", | ||||
| 		"@types/webpack-stream": "3.2.10", | ||||
| 		"@types/websocket": "0.0.40", | ||||
| 		"@types/ws": "6.0.0", | ||||
| 		"@types/ws": "6.0.1", | ||||
| 		"animejs": "2.2.0", | ||||
| 		"autosize": "4.0.2", | ||||
| 		"autwh": "0.1.0", | ||||
| @@ -94,14 +95,13 @@ | ||||
| 		"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", | ||||
| @@ -132,9 +132,10 @@ | ||||
| 		"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", | ||||
| 		"json5": "2.1.0", | ||||
| 		"json5-loader": "1.0.1", | ||||
| 		"koa": "2.5.1", | ||||
| 		"koa-bodyparser": "4.2.1", | ||||
| 		"koa-compress": "3.0.0", | ||||
| @@ -151,7 +152,7 @@ | ||||
| 		"lodash.assign": "4.2.0", | ||||
| 		"mecab-async": "0.1.2", | ||||
| 		"merge-options": "1.0.1", | ||||
| 		"minio": "7.0.0", | ||||
| 		"minio": "7.0.1", | ||||
| 		"mkdirp": "0.5.1", | ||||
| 		"mocha": "5.2.0", | ||||
| 		"moji": "0.5.1", | ||||
| @@ -160,8 +161,6 @@ | ||||
| 		"ms": "2.1.1", | ||||
| 		"nan": "2.11.0", | ||||
| 		"nested-property": "0.0.7", | ||||
| 		"node-sass": "4.9.3", | ||||
| 		"node-sass-json-importer": "3.3.1", | ||||
| 		"nprogress": "0.2.0", | ||||
| 		"object-assign-deep": "0.4.0", | ||||
| 		"on-build-webpack": "0.1.0", | ||||
| @@ -179,6 +178,7 @@ | ||||
| 		"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", | ||||
| @@ -194,9 +194,10 @@ | ||||
| 		"stylus": "0.54.5", | ||||
| 		"stylus-loader": "3.0.2", | ||||
| 		"summaly": "2.2.0", | ||||
| 		"systeminformation": "3.44.2", | ||||
| 		"systeminformation": "3.45.6", | ||||
| 		"syuilo-password-strength": "0.0.1", | ||||
| 		"textarea-caret": "3.1.0", | ||||
| 		"tinycolor2": "1.4.1", | ||||
| 		"tmp": "0.0.33", | ||||
| 		"ts-loader": "4.4.1", | ||||
| 		"ts-node": "7.0.1", | ||||
| @@ -209,22 +210,24 @@ | ||||
| 		"v-animate-css": "0.0.2", | ||||
| 		"vue": "2.5.17", | ||||
| 		"vue-chartjs": "3.4.0", | ||||
| 		"vue-cropperjs": "2.2.1", | ||||
| 		"vue-js-modal": "1.3.24", | ||||
| 		"vue-color": "2.6.0", | ||||
| 		"vue-cropperjs": "2.2.2", | ||||
| 		"vue-js-modal": "1.3.26", | ||||
| 		"vue-json-tree-view": "2.1.4", | ||||
| 		"vue-loader": "15.4.1", | ||||
| 		"vue-loader": "15.4.2", | ||||
| 		"vue-router": "3.0.1", | ||||
| 		"vue-style-loader": "4.1.2", | ||||
| 		"vue-svg-inline-loader": "1.1.3", | ||||
| 		"vue-template-compiler": "2.5.17", | ||||
| 		"vue-thin-modal": "1.1.1", | ||||
| 		"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.17.1", | ||||
| 		"webpack": "4.19.1", | ||||
| 		"webpack-cli": "3.1.0", | ||||
| 		"websocket": "1.0.26", | ||||
| 		"websocket": "1.0.28", | ||||
| 		"ws": "6.0.0", | ||||
| 		"xev": "2.0.1" | ||||
| 	}, | ||||
|   | ||||
| @@ -6,6 +6,10 @@ html | ||||
| 		&, * | ||||
| 			cursor progress !important | ||||
|  | ||||
| html | ||||
| 	// iOSのため | ||||
| 	overflow auto | ||||
|  | ||||
| body | ||||
| 	overflow-wrap break-word | ||||
|  | ||||
| @@ -23,7 +27,7 @@ body | ||||
| 	z-index 65536 | ||||
|  | ||||
| 	.bar | ||||
| 		background $theme-color | ||||
| 		background var(--primary) | ||||
|  | ||||
| 		position fixed | ||||
| 		z-index 65537 | ||||
| @@ -40,7 +44,7 @@ body | ||||
| 		right 0px | ||||
| 		width 100px | ||||
| 		height 100% | ||||
| 		box-shadow 0 0 10px $theme-color, 0 0 5px $theme-color | ||||
| 		box-shadow 0 0 10px var(--primary), 0 0 5px var(--primary) | ||||
| 		opacity 1 | ||||
|  | ||||
| 		transform rotate(3deg) translate(0px, -4px) | ||||
| @@ -60,8 +64,8 @@ body | ||||
| 		box-sizing border-box | ||||
|  | ||||
| 		border solid 2px transparent | ||||
| 		border-top-color $theme-color | ||||
| 		border-left-color $theme-color | ||||
| 		border-top-color var(--primary) | ||||
| 		border-left-color var(--primary) | ||||
| 		border-radius 50% | ||||
|  | ||||
| 		animation progress-spinner 400ms linear infinite | ||||
|   | ||||
| @@ -1,6 +1,32 @@ | ||||
| <template> | ||||
| <div> | ||||
| 	<router-view id="app"></router-view> | ||||
| 	<modal-portal/> | ||||
| </div> | ||||
| <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, | ||||
| 				'd': this.dark | ||||
| 			}; | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		help() { | ||||
| 			window.open(`${url}/docs/${lang}/keyboard-shortcut`, '_blank'); | ||||
| 		}, | ||||
|  | ||||
| 		dark() { | ||||
| 			this.$store.commit('device/set', { | ||||
| 				key: 'darkmode', | ||||
| 				value: !this.$store.state.device.darkmode | ||||
| 			}); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|   | ||||
| @@ -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}`; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
|   | ||||
| @@ -34,9 +34,6 @@ html | ||||
| 		//- FontAwesome style | ||||
| 		style #{facss} | ||||
|  | ||||
| 		//- highlight.js style | ||||
| 		style #{hljscss} | ||||
|  | ||||
| 	body | ||||
| 		noscript: p | ||||
| 			| JavaScriptを有効にしてください | ||||
|   | ||||
| @@ -18,6 +18,17 @@ | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	const langs = LANGS; | ||||
|  | ||||
| 	//#region Apply theme | ||||
| 	const theme = localStorage.getItem('theme'); | ||||
| 	if (theme) { | ||||
| 		Object.entries(JSON.parse(theme)).forEach(([k, v]) => { | ||||
| 			document.documentElement.style.setProperty(`--${k}`, v.toString()); | ||||
| 		}); | ||||
| 	} | ||||
| 	//#endregion | ||||
|  | ||||
| 	//#region Load settings | ||||
| 	let settings = null; | ||||
| 	const vuex = localStorage.getItem('vuex'); | ||||
| @@ -40,10 +51,10 @@ | ||||
| 	//#region Detect the user language | ||||
| 	let lang = null; | ||||
|  | ||||
| 	if (LANGS.includes(navigator.language)) { | ||||
| 	if (langs.includes(navigator.language)) { | ||||
| 		lang = navigator.language; | ||||
| 	} else { | ||||
| 		lang = LANGS.find(x => x.split('-')[0] == navigator.language); | ||||
| 		lang = langs.find(x => x.split('-')[0] == navigator.language); | ||||
|  | ||||
| 		if (lang == null) { | ||||
| 			// Fallback | ||||
| @@ -52,7 +63,7 @@ | ||||
| 	} | ||||
|  | ||||
| 	if (settings && settings.device.lang && | ||||
| 		LANGS.includes(settings.device.lang)) { | ||||
| 		langs.includes(settings.device.lang)) { | ||||
| 		lang = settings.device.lang; | ||||
| 	} | ||||
| 	//#endregion | ||||
| @@ -82,19 +93,12 @@ | ||||
| 		app = isMobile ? 'mobile' : 'desktop'; | ||||
| 	} | ||||
|  | ||||
| 	// Dark/Light | ||||
| 	if (settings) { | ||||
| 		if (settings.device.darkmode) { | ||||
| 			document.documentElement.setAttribute('data-darkmode', 'true'); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// Script version | ||||
| 	const ver = localStorage.getItem('v') || VERSION; | ||||
|  | ||||
| 	// Get salt query | ||||
| 	const salt = localStorage.getItem('salt') | ||||
| 		? '?salt=' + localStorage.getItem('salt') | ||||
| 		? `?salt=${localStorage.getItem('salt')}` | ||||
| 		: ''; | ||||
|  | ||||
| 	// Load an app script | ||||
| @@ -140,7 +144,7 @@ | ||||
| 		// Random | ||||
| 		localStorage.setItem('salt', Math.random().toString()); | ||||
|  | ||||
| 		// Clear cache (serive worker) | ||||
| 		// Clear cache (service worker) | ||||
| 		try { | ||||
| 			navigator.serviceWorker.controller.postMessage('clear'); | ||||
|  | ||||
|   | ||||
							
								
								
									
										110
									
								
								src/client/app/common/hotkey.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										110
									
								
								src/client/app/common/hotkey.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,110 @@ | ||||
| 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: KeyboardEvent) => { | ||||
| 					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 && | ||||
| 								e.metaKey == false; | ||||
|  | ||||
| 							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,8 +1,8 @@ | ||||
| require('fuckadblock'); | ||||
|  | ||||
| declare const fuckAdBlock: any; | ||||
|  | ||||
| export default (os) => { | ||||
| 	require('fuckadblock'); | ||||
|  | ||||
| 	function adBlockDetected() { | ||||
| 		os.apis.dialog({ | ||||
| 			title: '%fa:exclamation-triangle%%i18n:common.adblock.detected%', | ||||
|   | ||||
| @@ -1,2 +0,0 @@ | ||||
| const gcd = (a, b) => !b ? a : gcd(b, a % b); | ||||
| export default gcd; | ||||
| @@ -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); | ||||
| @@ -259,15 +259,13 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
| .mk-autocomplete | ||||
| 	position fixed | ||||
| 	z-index 65535 | ||||
| 	max-width 100% | ||||
| 	margin-top calc(1em + 8px) | ||||
| 	overflow hidden | ||||
| 	background isDark ? #313543 : #fff | ||||
| 	background var(--faceHeader) | ||||
| 	border solid 1px rgba(#000, 0.1) | ||||
| 	border-radius 4px | ||||
| 	transition top 0.1s ease, left 0.1s ease | ||||
| @@ -299,16 +297,16 @@ root(isDark) | ||||
| 				text-overflow ellipsis | ||||
|  | ||||
| 			&:hover | ||||
| 				background isDark ? rgba(#fff, 0.1) : rgba(#000, 0.1) | ||||
| 				background var(--autocompleteItemHoverBg) | ||||
|  | ||||
| 			&[data-selected='true'] | ||||
| 				background $theme-color | ||||
| 				background var(--primary) | ||||
|  | ||||
| 				&, * | ||||
| 					color #fff !important | ||||
|  | ||||
| 			&:active | ||||
| 				background darken($theme-color, 10%) | ||||
| 				background var(--primaryDarken10) | ||||
|  | ||||
| 				&, * | ||||
| 					color #fff !important | ||||
| @@ -325,15 +323,15 @@ root(isDark) | ||||
|  | ||||
| 		.name | ||||
| 			margin 0 8px 0 0 | ||||
| 			color isDark ? rgba(#fff, 0.8) : rgba(#000, 0.8) | ||||
| 			color var(--autocompleteItemText) | ||||
|  | ||||
| 		.username | ||||
| 			color isDark ? rgba(#fff, 0.3) : rgba(#000, 0.3) | ||||
| 			color var(--autocompleteItemTextSub) | ||||
|  | ||||
| 	> .hashtags > li | ||||
|  | ||||
| 		.name | ||||
| 			color isDark ? rgba(#fff, 0.8) : rgba(#000, 0.8) | ||||
| 			color var(--autocompleteItemText) | ||||
|  | ||||
| 	> .emojis > li | ||||
|  | ||||
| @@ -343,15 +341,9 @@ root(isDark) | ||||
| 			width 24px | ||||
|  | ||||
| 		.name | ||||
| 			color isDark ? rgba(#fff, 0.8) : rgba(#000, 0.8) | ||||
| 			color var(--autocompleteItemText) | ||||
|  | ||||
| 		.alias | ||||
| 			margin 0 0 0 8px | ||||
| 			color isDark ? rgba(#fff, 0.3) : rgba(#000, 0.3) | ||||
|  | ||||
| .mk-autocomplete[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .mk-autocomplete:not([data-darkmode]) | ||||
| 	root(false) | ||||
| 			color var(--autocompleteItemTextSub) | ||||
| </style> | ||||
|   | ||||
| @@ -1,15 +1,15 @@ | ||||
| <template> | ||||
| 	<span class="mk-avatar" :class="{ cat }" :title="user | acct" v-if="disableLink && !disablePreview" v-user-preview="user.id" @click="onClick"> | ||||
| 		<span class="inner" :style="style"></span> | ||||
| 	<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" :class="{ cat }" :title="user | acct" v-else-if="disableLink && disablePreview" @click="onClick"> | ||||
| 		<span class="inner" :style="style"></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" :class="{ cat }" :to="user | userPage" :title="user | acct" :target="target" v-else-if="!disableLink && !disablePreview" v-user-preview="user.id"> | ||||
| 		<span class="inner" :style="style"></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" :class="{ cat }" :to="user | userPage" :title="user | acct" :target="target" v-else-if="!disableLink && disablePreview"> | ||||
| 		<span class="inner" :style="style"></span> | ||||
| 	<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> | ||||
|  | ||||
| @@ -42,6 +42,11 @@ export default Vue.extend({ | ||||
| 			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(',')})` | ||||
| @@ -53,6 +58,11 @@ export default Vue.extend({ | ||||
| 			}; | ||||
| 		} | ||||
| 	}, | ||||
| 	mounted() { | ||||
| 		if (this.user.avatarColor) { | ||||
| 			this.$el.style.color = `rgb(${this.user.avatarColor.slice(0, 3).join(',')})`; | ||||
| 		} | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		onClick(e) { | ||||
| 			this.$emit('click', e); | ||||
| @@ -62,8 +72,7 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
|  | ||||
| root(isDark) | ||||
| .mk-avatar | ||||
| 	display inline-block | ||||
| 	vertical-align bottom | ||||
|  | ||||
| @@ -74,7 +83,7 @@ root(isDark) | ||||
| 	&.cat::before, | ||||
| 	&.cat::after | ||||
| 		background #df548f | ||||
| 		border solid 4px isDark ? #e0eefd : #202224 | ||||
| 		border solid 4px currentColor | ||||
| 		box-sizing border-box | ||||
| 		content '' | ||||
| 		display inline-block | ||||
| @@ -100,9 +109,4 @@ root(isDark) | ||||
| 		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; | ||||
|   | ||||
| @@ -39,7 +39,7 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
|  | ||||
| .mk-connect-failed | ||||
| 	width 100% | ||||
| @@ -70,17 +70,17 @@ export default Vue.extend({ | ||||
| 		display block | ||||
| 		margin 1em auto 0 auto | ||||
| 		padding 8px 10px | ||||
| 		color $theme-color-foreground | ||||
| 		background $theme-color | ||||
| 		color var(--primaryForeground) | ||||
| 		background var(--primary) | ||||
|  | ||||
| 		&:focus | ||||
| 			outline solid 3px rgba($theme-color, 0.3) | ||||
| 			outline solid 3px var(--primaryAlpha03) | ||||
|  | ||||
| 		&:hover | ||||
| 			background lighten($theme-color, 10%) | ||||
| 			background var(--primaryLighten10) | ||||
|  | ||||
| 		&:active | ||||
| 			background darken($theme-color, 10%) | ||||
| 			background var(--primaryDarken10) | ||||
|  | ||||
| 	> .thanks | ||||
| 		display block | ||||
|   | ||||
							
								
								
									
										38
									
								
								src/client/app/common/views/components/cw-button.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								src/client/app/common/views/components/cw-button.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,38 @@ | ||||
| <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> | ||||
| .nrvgflfuaxwgkxoynpnumyookecqrrvh | ||||
| 	display inline-block | ||||
| 	padding 4px 8px | ||||
| 	font-size 0.7em | ||||
| 	color var(--cwButtonFg) | ||||
| 	background var(--cwButtonBg) | ||||
| 	border-radius 2px | ||||
| 	cursor pointer | ||||
| 	user-select none | ||||
|  | ||||
| 	&:hover | ||||
| 		background var(--cwButtonHoverBg) | ||||
|  | ||||
| </style> | ||||
| @@ -9,7 +9,7 @@ | ||||
| </template> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
|  | ||||
| .a | ||||
| 	display block | ||||
| @@ -18,8 +18,8 @@ | ||||
| 		display block | ||||
| 		//fill #151513 | ||||
| 		//color #fff | ||||
| 		fill $theme-color | ||||
| 		color $theme-color-foreground | ||||
| 		fill var(--primary) | ||||
| 		color var(--primaryForeground) | ||||
|  | ||||
| 		.octo-arm | ||||
| 			transform-origin 130px 106px | ||||
|   | ||||
| @@ -50,15 +50,15 @@ | ||||
| 	</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"> | ||||
| @@ -159,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(); | ||||
| 		} | ||||
| 	}, | ||||
| @@ -306,9 +304,7 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
| .xqnhankfuuilcwvhgsopeqncafzsquya | ||||
| 	text-align center | ||||
|  | ||||
| 	> .go-index | ||||
| @@ -321,7 +317,7 @@ root(isDark) | ||||
|  | ||||
| 	> header | ||||
| 		padding 8px | ||||
| 		border-bottom dashed 1px isDark ? #4c5761 : #c4cdd4 | ||||
| 		border-bottom dashed 1px var(--reversiGameHeaderLine) | ||||
|  | ||||
| 		a | ||||
| 			color inherit | ||||
| @@ -388,30 +384,30 @@ root(isDark) | ||||
| 						user-select none | ||||
|  | ||||
| 					&.empty | ||||
| 						border solid 2px isDark ? #51595f : #eee | ||||
| 						border solid 2px var(--reversiGameEmptyCell) | ||||
|  | ||||
| 					&.empty.can | ||||
| 						background isDark ? #51595f : #eee | ||||
| 						background var(--reversiGameEmptyCell) | ||||
|  | ||||
| 					&.empty.myTurn | ||||
| 						border-color isDark ? #6a767f : #ddd | ||||
| 						border-color var(--reversiGameEmptyCellMyTurn) | ||||
|  | ||||
| 						&.can | ||||
| 							background isDark ? #51595f : #eee | ||||
| 							background var(--reversiGameEmptyCellCanPut) | ||||
| 							cursor pointer | ||||
|  | ||||
| 							&:hover | ||||
| 								border-color darken($theme-color, 10%) | ||||
| 								background $theme-color | ||||
| 								border-color var(--primaryDarken10) | ||||
| 								background var(--primary) | ||||
|  | ||||
| 							&:active | ||||
| 								background darken($theme-color, 10%) | ||||
| 								background var(--primaryDarken10) | ||||
|  | ||||
| 					&.prev | ||||
| 						box-shadow 0 0 0 4px rgba($theme-color, 0.7) | ||||
| 						box-shadow 0 0 0 4px var(--primaryAlpha07) | ||||
|  | ||||
| 					&.isEnded | ||||
| 						border-color isDark ? #6a767f : #ddd | ||||
| 						border-color var(--reversiGameEmptyCellMyTurn) | ||||
|  | ||||
| 					&.none | ||||
| 						border-color transparent !important | ||||
| @@ -460,10 +456,4 @@ root(isDark) | ||||
| 			margin 0 8px | ||||
| 			min-width 70px | ||||
|  | ||||
| .xqnhankfuuilcwvhgsopeqncafzsquya[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .xqnhankfuuilcwvhgsopeqncafzsquya:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -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> | ||||
| @@ -139,9 +138,7 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
| .phgnkghfpyvkrvwiajkiuoxyrdaqpzcx | ||||
| 	> h1 | ||||
| 		margin 0 | ||||
| 		padding 24px | ||||
| @@ -149,7 +146,7 @@ root(isDark) | ||||
| 		text-align center | ||||
| 		font-weight normal | ||||
| 		color #fff | ||||
| 		background linear-gradient(to bottom, isDark ? #45730e : #8bca3e, isDark ? #464300 : #d6cf31) | ||||
| 		background linear-gradient(to bottom, var(--reversiBannerGradientStart), var(--reversiBannerGradientEnd)) | ||||
|  | ||||
| 		& + p | ||||
| 			margin 0 | ||||
| @@ -157,7 +154,7 @@ root(isDark) | ||||
| 			margin-bottom 12px | ||||
| 			text-align center | ||||
| 			font-size 14px | ||||
| 			border-bottom solid 1px isDark ? #535f65 : #d3d9dc | ||||
| 			border-bottom solid 1px var(--faceDivider) | ||||
|  | ||||
| 	> .play | ||||
| 		margin 0 auto | ||||
| @@ -172,14 +169,14 @@ root(isDark) | ||||
| 				padding 16px | ||||
| 				font-size 14px | ||||
| 				text-align left | ||||
| 				background isDark ? #282c37 : #f5f5f5 | ||||
| 				background var(--reversiDescBg) | ||||
| 				border-radius 8px | ||||
|  | ||||
| 	> section | ||||
| 		margin 0 auto | ||||
| 		padding 0 16px 16px 16px | ||||
| 		max-width 500px | ||||
| 		border-top solid 1px isDark ? #535f65 : #d3d9dc | ||||
| 		border-top solid 1px var(--faceDivider) | ||||
|  | ||||
| 		> h2 | ||||
| 			margin 0 | ||||
| @@ -190,9 +187,9 @@ root(isDark) | ||||
| 	.invitation | ||||
| 		margin 8px 0 | ||||
| 		padding 8px | ||||
| 		color isDark ? #fff : #677f84 | ||||
| 		background isDark ? #282c37 : #fff | ||||
| 		box-shadow 0 2px 16px rgba(#000, isDark ? 0.7 : 0.15) | ||||
| 		color var(--text) | ||||
| 		background var(--face) | ||||
| 		box-shadow 0 2px 16px var(--reversiListItemShadow) | ||||
| 		border-radius 6px | ||||
| 		cursor pointer | ||||
|  | ||||
| @@ -201,13 +198,13 @@ root(isDark) | ||||
| 			user-select none | ||||
|  | ||||
| 		&:focus | ||||
| 			border-color $theme-color | ||||
| 			border-color var(--primary) | ||||
|  | ||||
| 		&:hover | ||||
| 			background isDark ? #313543 : #f5f5f5 | ||||
| 			box-shadow 0 0 0 100px inset rgba(0, 0, 0, 0.05) | ||||
|  | ||||
| 		&:active | ||||
| 			background isDark ? #1e222b : #eee | ||||
| 			box-shadow 0 0 0 100px inset rgba(0, 0, 0, 0.1) | ||||
|  | ||||
| 		> .avatar | ||||
| 			width 32px | ||||
| @@ -222,9 +219,9 @@ root(isDark) | ||||
| 		display block | ||||
| 		margin 8px 0 | ||||
| 		padding 8px | ||||
| 		color isDark ? #fff : #677f84 | ||||
| 		background isDark ? #282c37 : #fff | ||||
| 		box-shadow 0 2px 16px rgba(#000, isDark ? 0.7 : 0.15) | ||||
| 		color var(--text) | ||||
| 		background var(--face) | ||||
| 		box-shadow 0 2px 16px var(--reversiListItemShadow) | ||||
| 		border-radius 6px | ||||
| 		cursor pointer | ||||
|  | ||||
| @@ -233,10 +230,10 @@ root(isDark) | ||||
| 			user-select none | ||||
|  | ||||
| 		&:hover | ||||
| 			background isDark ? #313543 : #f5f5f5 | ||||
| 			box-shadow 0 0 0 100px inset rgba(0, 0, 0, 0.05) | ||||
|  | ||||
| 		&:active | ||||
| 			background isDark ? #1e222b : #eee | ||||
| 			box-shadow 0 0 0 100px inset rgba(0, 0, 0, 0.1) | ||||
|  | ||||
| 		> .avatar | ||||
| 			width 32px | ||||
| @@ -247,10 +244,4 @@ root(isDark) | ||||
| 			margin 0 8px | ||||
| 			line-height 32px | ||||
|  | ||||
| .phgnkghfpyvkrvwiajkiuoxyrdaqpzcx[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .phgnkghfpyvkrvwiajkiuoxyrdaqpzcx:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -47,9 +47,9 @@ | ||||
| 			</header> | ||||
|  | ||||
| 			<div> | ||||
| 				<mk-switch v-model="game.settings.isLlotheo" @change="updateSettings" text="%i18n:@is-llotheo%"/> | ||||
| 				<mk-switch v-model="game.settings.loopedBoard" @change="updateSettings" text="%i18n:@looped-map%"/> | ||||
| 				<mk-switch v-model="game.settings.canPutEverywhere" @change="updateSettings" text="%i18n:@can-put-everywhere%"/> | ||||
| 				<ui-switch v-model="game.settings.isLlotheo" @change="updateSettings">%i18n:@is-llotheo%</ui-switch> | ||||
| 				<ui-switch v-model="game.settings.loopedBoard" @change="updateSettings">%i18n:@looped-map%</ui-switch> | ||||
| 				<ui-switch v-model="game.settings.canPutEverywhere" @change="updateSettings">%i18n:@can-put-everywhere%</ui-switch> | ||||
| 			</div> | ||||
| 		</div> | ||||
|  | ||||
| @@ -59,13 +59,8 @@ | ||||
| 			</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> | ||||
| 					<ui-switch v-if="item.type == 'switch'" v-model="item.value" :key="item.id" :text="item.label" @change="onChangeForm(item)">{{ item.desc || '' }}</ui-switch> | ||||
|  | ||||
| 					<div class="card" v-if="item.type == 'radio'" :key="item.id"> | ||||
| 						<header> | ||||
| @@ -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> | ||||
| @@ -257,11 +252,9 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
| .urbixznjwwuukfsckrwzwsqzsxornqij | ||||
| 	text-align center | ||||
| 	background isDark ? #191b22 : #f9f9f9 | ||||
| 	background var(--bg) | ||||
|  | ||||
| 	> header | ||||
| 		padding 8px | ||||
| @@ -278,10 +271,10 @@ root(isDark) | ||||
| 					> select | ||||
| 						width 100% | ||||
| 						padding 12px 14px | ||||
| 						background isDark ? #282C37 : #fff | ||||
| 						border 1px solid isDark ? #6a707d : #dcdfe6 | ||||
| 						background var(--face) | ||||
| 						border 1px solid var(--reversiMapSelectBorder) | ||||
| 						border-radius 4px | ||||
| 						color isDark ? #fff : #606266 | ||||
| 						color var(--text) | ||||
| 						cursor pointer | ||||
| 						transition border-color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1) | ||||
| 						-webkit-appearance none | ||||
| @@ -289,17 +282,18 @@ root(isDark) | ||||
| 						appearance none | ||||
|  | ||||
| 						&:hover | ||||
| 							border-color isDark ? #a7aebd : #c0c4cc | ||||
| 							border-color var(--reversiMapSelectHoverBorder) | ||||
|  | ||||
| 						&:focus | ||||
| 						&:active | ||||
| 							border-color $theme-color | ||||
| 							border-color var(--primary) | ||||
|  | ||||
| 				> div | ||||
| 					> .random | ||||
| 						padding 32px 0 | ||||
| 						font-size 64px | ||||
| 						color isDark ? #4e5961 : #d8d8d8 | ||||
| 						color var(--text) | ||||
| 						opacity 0.7 | ||||
|  | ||||
| 					> .board | ||||
| 						display grid | ||||
| @@ -307,11 +301,11 @@ root(isDark) | ||||
| 						width 300px | ||||
| 						height 300px | ||||
| 						margin 0 auto | ||||
| 						color isDark ? #fff : #444 | ||||
| 						color var(--text) | ||||
|  | ||||
| 						> div | ||||
| 							background transparent | ||||
| 							border solid 2px isDark ? #6a767f : #ddd | ||||
| 							border solid 2px var(--faceDivider) | ||||
| 							border-radius 6px | ||||
| 							overflow hidden | ||||
| 							cursor pointer | ||||
| @@ -336,32 +330,26 @@ root(isDark) | ||||
| 		.card | ||||
| 			max-width 400px | ||||
| 			border-radius 4px | ||||
| 			background isDark ? #282C37 : #fff | ||||
| 			color isDark ? #fff : #303133 | ||||
| 			box-shadow 0 2px 12px 0 rgba(#000, isDark ? 0.7 : 0.1) | ||||
| 			background var(--face) | ||||
| 			color var(--text) | ||||
| 			box-shadow 0 2px 12px 0 var(--reversiRoomFormShadow) | ||||
|  | ||||
| 			> header | ||||
| 				padding 18px 20px | ||||
| 				border-bottom 1px solid isDark ? #1c2023 : #ebeef5 | ||||
| 				border-bottom 1px solid var(--faceDivider) | ||||
|  | ||||
| 			> div | ||||
| 				padding 20px | ||||
| 				color isDark ? #fff : #606266 | ||||
| 				color var(--text) | ||||
|  | ||||
| 	> footer | ||||
| 		position sticky | ||||
| 		bottom 0 | ||||
| 		padding 16px | ||||
| 		background rgba(isDark ? #191b22 : #fff, 0.9) | ||||
| 		border-top solid 1px isDark ? #606266 : #c4cdd4 | ||||
| 		background var(--reversiRoomFooterBg) | ||||
| 		border-top solid 1px var(--faceDivider) | ||||
|  | ||||
| 		> .status | ||||
| 			margin 0 0 16px 0 | ||||
|  | ||||
| .urbixznjwwuukfsckrwzwsqzsxornqij[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .urbixznjwwuukfsckrwzwsqzsxornqij:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -156,11 +156,9 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
| 	color isDark ? #fff : #677f84 | ||||
| 	background isDark ? #191b22 : #fff | ||||
| .vchtoekanapleubgzioubdtmlkribzfd | ||||
| 	color var(--text) | ||||
| 	background var(--bg) | ||||
|  | ||||
| 	> .matching | ||||
| 		> h1 | ||||
| @@ -177,10 +175,4 @@ root(isDark) | ||||
| 			text-align center | ||||
| 			border-top dashed 1px #c4cdd4 | ||||
|  | ||||
| .vchtoekanapleubgzioubdtmlkribzfd[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .vchtoekanapleubgzioubdtmlkribzfd:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -26,7 +26,7 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| root(isDark) | ||||
| .mk-google | ||||
| 	display flex | ||||
| 	margin 8px 0 | ||||
|  | ||||
| @@ -37,31 +37,25 @@ root(isDark) | ||||
| 		height 40px | ||||
| 		font-family sans-serif | ||||
| 		font-size 16px | ||||
| 		color isDark ? #dee4e8 : #55595c | ||||
| 		background isDark ? #191b22 : #fff | ||||
| 		border solid 1px isDark ? #495156 : #dadada | ||||
| 		color var(--googleSearchFg) | ||||
| 		background var(--googleSearchBg) | ||||
| 		border solid 1px var(--googleSearchBorder) | ||||
| 		border-radius 4px 0 0 4px | ||||
|  | ||||
| 		&:hover | ||||
| 			border-color isDark ? #777c86 : #b0b0b0 | ||||
| 			border-color var(--googleSearchHoverBorder) | ||||
|  | ||||
| 	> button | ||||
| 		flex-shrink 0 | ||||
| 		padding 0 16px | ||||
| 		border solid 1px isDark ? #495156 : #dadada | ||||
| 		border solid 1px var(--googleSearchBorder) | ||||
| 		border-left none | ||||
| 		border-radius 0 4px 4px 0 | ||||
|  | ||||
| 		&:hover | ||||
| 			background-color isDark ? #2e3440 : #eee | ||||
| 			background-color var(--googleSearchHoverButton) | ||||
|  | ||||
| 		&:active | ||||
| 			box-shadow 0 2px 4px rgba(#000, 0.15) inset | ||||
|  | ||||
| .mk-google[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .mk-google:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -1,5 +1,10 @@ | ||||
| import Vue from 'vue'; | ||||
|  | ||||
| import theme from './theme.vue'; | ||||
| import instance from './instance.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'; | ||||
| @@ -26,7 +31,6 @@ import messagingRoom from './messaging-room.vue'; | ||||
| import urlPreview from './url-preview.vue'; | ||||
| import twitterSetting from './twitter-setting.vue'; | ||||
| import fileTypeIcon from './file-type-icon.vue'; | ||||
| import Switch from './switch.vue'; | ||||
| import Reversi from './games/reversi/reversi.vue'; | ||||
| import welcomeTimeline from './welcome-timeline.vue'; | ||||
| import uiInput from './ui/input.vue'; | ||||
| @@ -40,6 +44,11 @@ import uiSelect from './ui/select.vue'; | ||||
| import formButton from './ui/form/button.vue'; | ||||
| import formRadio from './ui/form/radio.vue'; | ||||
|  | ||||
| Vue.component('mk-theme', theme); | ||||
| Vue.component('mk-instance', instance); | ||||
| 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); | ||||
| @@ -66,7 +75,6 @@ Vue.component('mk-messaging-room', messagingRoom); | ||||
| Vue.component('mk-url-preview', urlPreview); | ||||
| Vue.component('mk-twitter-setting', twitterSetting); | ||||
| Vue.component('mk-file-type-icon', fileTypeIcon); | ||||
| Vue.component('mk-switch', Switch); | ||||
| Vue.component('mk-reversi', Reversi); | ||||
| Vue.component('mk-welcome-timeline', welcomeTimeline); | ||||
| Vue.component('ui-input', uiInput); | ||||
|   | ||||
							
								
								
									
										51
									
								
								src/client/app/common/views/components/instance.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								src/client/app/common/views/components/instance.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | ||||
| <template> | ||||
| <div class="nhasjydimbopojusarffqjyktglcuxjy" v-if="meta"> | ||||
| 	<div class="banner" :style="{ backgroundImage: meta.bannerUrl ? `url(${meta.bannerUrl})` : null }"></div> | ||||
|  | ||||
| 	<h1>{{ meta.name }}</h1> | ||||
| 	<p v-html="meta.description || '%i18n:common.about%'"></p> | ||||
| 	<router-link to="/">%i18n:@start%</router-link> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	data() { | ||||
| 		return { | ||||
| 			meta: null | ||||
| 		} | ||||
| 	}, | ||||
| 	created() { | ||||
| 		(this as any).os.getMeta().then(meta => { | ||||
| 			this.meta = meta; | ||||
| 		}); | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .nhasjydimbopojusarffqjyktglcuxjy | ||||
| 	color var(--text) | ||||
| 	background var(--face) | ||||
| 	text-align center | ||||
|  | ||||
| 	> .banner | ||||
| 		height 100px | ||||
| 		background-position center | ||||
| 		background-size cover | ||||
|  | ||||
| 	> h1 | ||||
| 		margin 16px | ||||
| 		font-size 16px | ||||
|  | ||||
| 	> p | ||||
| 		margin 16px | ||||
| 		font-size 14px | ||||
|  | ||||
| 	> a | ||||
| 		display block | ||||
| 		padding-bottom 16px | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										85
									
								
								src/client/app/common/views/components/media-banner.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										85
									
								
								src/client/app/common/views/components/media-banner.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,85 @@ | ||||
| <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> | ||||
| .mk-media-banner | ||||
| 	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 var(--noteAttachedFile) | ||||
|  | ||||
| 	> .sensitive | ||||
| 		background #111 | ||||
| 		color #fff | ||||
|  | ||||
| 	> .audio | ||||
| 		.audio | ||||
| 			display block | ||||
| 			width 100% | ||||
|  | ||||
| </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(); | ||||
| 				} | ||||
| 			}); | ||||
| 		} | ||||
| @@ -117,11 +117,10 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| .onchrpzrvnoruiaenfcqvccjfuupzzwv | ||||
| 	$bg-color = var(--popupBg) | ||||
| 	$border-color = rgba(27, 31, 35, 0.15) | ||||
|  | ||||
| .mk-menu | ||||
| 	position initial | ||||
|  | ||||
| 	> .backdrop | ||||
| @@ -131,14 +130,14 @@ $border-color = rgba(27, 31, 35, 0.15) | ||||
| 		z-index 10000 | ||||
| 		width 100% | ||||
| 		height 100% | ||||
| 		background rgba(#000, 0.1) | ||||
| 		background var(--modalBackdrop) | ||||
| 		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,25 +171,26 @@ $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 var(--popupFg) | ||||
|  | ||||
| 			&:hover | ||||
| 				color $theme-color-foreground | ||||
| 				background $theme-color | ||||
| 				color var(--primaryForeground) | ||||
| 				background var(--primary) | ||||
| 				text-decoration none | ||||
|  | ||||
| 			&:active | ||||
| 				color $theme-color-foreground | ||||
| 				background darken($theme-color, 10%) | ||||
| 				color var(--primaryForeground) | ||||
| 				background var(--primaryDarken10) | ||||
|  | ||||
| 		> div | ||||
| 			margin 8px 0 | ||||
| 			height 1px | ||||
| 			background #eee | ||||
| 			background var(--faceDivider) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -195,9 +195,7 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
| .mk-messaging-form | ||||
| 	> textarea | ||||
| 		cursor auto | ||||
| 		display block | ||||
| @@ -209,10 +207,10 @@ root(isDark) | ||||
| 		padding 8px | ||||
| 		resize none | ||||
| 		font-size 1em | ||||
| 		color isDark ? #fff : #000 | ||||
| 		color var(--inputText) | ||||
| 		outline none | ||||
| 		border none | ||||
| 		border-top solid 1px isDark ? #4b5056 : #eee | ||||
| 		border-top solid 1px var(--faceDivider) | ||||
| 		border-radius 0 | ||||
| 		box-shadow none | ||||
| 		background transparent | ||||
| @@ -234,10 +232,10 @@ root(isDark) | ||||
| 		transition color 0.1s ease | ||||
|  | ||||
| 		&:hover | ||||
| 			color $theme-color | ||||
| 			color var(--primary) | ||||
|  | ||||
| 		&:active | ||||
| 			color darken($theme-color, 10%) | ||||
| 			color var(--primaryDarken10) | ||||
| 			transition color 0s ease | ||||
|  | ||||
| 	.files | ||||
| @@ -293,19 +291,13 @@ root(isDark) | ||||
| 		transition color 0.1s ease | ||||
|  | ||||
| 		&:hover | ||||
| 			color $theme-color | ||||
| 			color var(--primary) | ||||
|  | ||||
| 		&:active | ||||
| 			color darken($theme-color, 10%) | ||||
| 			color var(--primaryDarken10) | ||||
| 			transition color 0s ease | ||||
|  | ||||
| 	input[type=file] | ||||
| 		display none | ||||
|  | ||||
| .mk-messaging-form[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .mk-messaging-form:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -59,10 +59,8 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
| 	$me-balloon-color = $theme-color | ||||
| .message | ||||
| 	$me-balloon-color = var(--primary) | ||||
|  | ||||
| 	padding 10px 12px 10px 12px | ||||
| 	background-color transparent | ||||
| @@ -179,7 +177,7 @@ root(isDark) | ||||
| 			display block | ||||
| 			margin 2px 0 0 0 | ||||
| 			font-size 10px | ||||
| 			color isDark ? rgba(#fff, 0.4) : rgba(#000, 0.4) | ||||
| 			color var(--messagingRoomMessageInfo) | ||||
|  | ||||
| 			> [data-fa] | ||||
| 				margin-left 4px | ||||
| @@ -192,7 +190,7 @@ root(isDark) | ||||
| 			padding-left 66px | ||||
|  | ||||
| 			> .balloon | ||||
| 				$color = isDark ? #2d3338 : #eee | ||||
| 				$color = var(--messagingRoomMessageBg) | ||||
| 				float left | ||||
| 				background $color | ||||
|  | ||||
| @@ -208,8 +206,7 @@ root(isDark) | ||||
|  | ||||
| 				> .content | ||||
| 					> .text | ||||
| 						if isDark | ||||
| 							color #fff | ||||
| 							color var(--messagingRoomMessageFg) | ||||
|  | ||||
| 			> footer | ||||
| 				text-align left | ||||
| @@ -250,18 +247,9 @@ root(isDark) | ||||
|  | ||||
| 				> .read | ||||
| 					user-select none | ||||
| 					margin 0 4px 0 0 | ||||
| 					color isDark ? rgba(#fff, 0.5) : rgba(#000, 0.5) | ||||
| 					font-size 11px | ||||
|  | ||||
| 	&[data-is-deleted] | ||||
| 		> .balloon | ||||
| 			opacity 0.5 | ||||
|  | ||||
| .message[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .message:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -262,14 +262,12 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
| .mk-messaging-room | ||||
| 	display flex | ||||
| 	flex 1 | ||||
| 	flex-direction column | ||||
| 	height 100% | ||||
| 	background isDark ? #191b22 : #fff | ||||
| 	background var(--messagingRoomBg) | ||||
|  | ||||
| 	> .body | ||||
| 		width 100% | ||||
| @@ -277,24 +275,15 @@ root(isDark) | ||||
| 		margin 0 auto | ||||
| 		flex 1 | ||||
|  | ||||
| 		> .init | ||||
| 			width 100% | ||||
| 			margin 0 | ||||
| 			padding 16px 8px 8px 8px | ||||
| 			text-align center | ||||
| 			font-size 0.8em | ||||
| 			color rgba(isDark ? #fff : #000, 0.4) | ||||
|  | ||||
| 			[data-fa] | ||||
| 				margin-right 4px | ||||
|  | ||||
| 		> .init, | ||||
| 		> .empty | ||||
| 			width 100% | ||||
| 			margin 0 | ||||
| 			padding 16px 8px 8px 8px | ||||
| 			text-align center | ||||
| 			font-size 0.8em | ||||
| 			color rgba(isDark ? #fff : #000, 0.4) | ||||
| 			color var(--messagingRoomInfo) | ||||
| 			opacity 0.5 | ||||
|  | ||||
| 			[data-fa] | ||||
| 				margin-right 4px | ||||
| @@ -305,7 +294,8 @@ root(isDark) | ||||
| 			padding 16px | ||||
| 			text-align center | ||||
| 			font-size 0.8em | ||||
| 			color rgba(isDark ? #fff : #000, 0.4) | ||||
| 			color var(--messagingRoomInfo) | ||||
| 			opacity 0.5 | ||||
|  | ||||
| 			[data-fa] | ||||
| 				margin-right 4px | ||||
| @@ -349,7 +339,7 @@ root(isDark) | ||||
| 				left 0 | ||||
| 				right 0 | ||||
| 				margin 0 auto | ||||
| 				background rgba(isDark ? #fff : #000, 0.1) | ||||
| 				background var(--messagingRoomDateDividerLine) | ||||
|  | ||||
| 			> span | ||||
| 				display inline-block | ||||
| @@ -357,8 +347,8 @@ root(isDark) | ||||
| 				padding 0 16px | ||||
| 				//font-weight bold | ||||
| 				line-height 32px | ||||
| 				color rgba(isDark ? #fff : #000, 0.3) | ||||
| 				background isDark ? #191b22 : #fff | ||||
| 				color var(--messagingRoomDateDividerText) | ||||
| 				background var(--messagingRoomBg) | ||||
|  | ||||
| 	> footer | ||||
| 		position -webkit-sticky | ||||
| @@ -369,7 +359,7 @@ root(isDark) | ||||
| 		max-width 600px | ||||
| 		margin 0 auto | ||||
| 		padding 0 | ||||
| 		background rgba(isDark ? #282c37 : #fff, 0.95) | ||||
| 		//background rgba(var(--face), 0.95) | ||||
| 		background-clip content-box | ||||
|  | ||||
| 		> .new-message | ||||
| @@ -386,15 +376,15 @@ root(isDark) | ||||
| 				cursor pointer | ||||
| 				line-height 32px | ||||
| 				font-size 12px | ||||
| 				color $theme-color-foreground | ||||
| 				background $theme-color | ||||
| 				color var(--primaryForeground) | ||||
| 				background var(--primary) | ||||
| 				border-radius 16px | ||||
|  | ||||
| 				&:hover | ||||
| 					background lighten($theme-color, 10%) | ||||
| 					background var(--primaryLighten10) | ||||
|  | ||||
| 				&:active | ||||
| 					background darken($theme-color, 10%) | ||||
| 					background var(--primaryDarken10) | ||||
|  | ||||
| 				> [data-fa] | ||||
| 					position absolute | ||||
| @@ -410,10 +400,4 @@ root(isDark) | ||||
| 	transition opacity 0.5s | ||||
| 	opacity 0 | ||||
|  | ||||
| .mk-messaging-room[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .mk-messaging-room:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -167,9 +167,7 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
| .mk-messaging | ||||
|  | ||||
| 	&[data-compact] | ||||
| 		font-size 0.8em | ||||
| @@ -204,12 +202,10 @@ root(isDark) | ||||
| 		left 0 | ||||
| 		z-index 1 | ||||
| 		width 100% | ||||
| 		background #fff | ||||
| 		box-shadow 0 0px 2px rgba(#000, 0.2) | ||||
|  | ||||
| 		> .form | ||||
| 			padding 8px | ||||
| 			background isDark ? #282c37 : #f7f7f7 | ||||
| 			background rgba(0, 0, 0, 0.02) | ||||
|  | ||||
| 			> label | ||||
| 				display block | ||||
| @@ -229,32 +225,22 @@ root(isDark) | ||||
| 					bottom 0 | ||||
| 					left 0 | ||||
| 					width 1em | ||||
| 					line-height 56px | ||||
| 					line-height 48px | ||||
| 					margin auto | ||||
| 					color #555 | ||||
|  | ||||
| 			> input | ||||
| 				margin 0 | ||||
| 				padding 0 0 0 32px | ||||
| 				padding 0 0 0 42px | ||||
| 				width 100% | ||||
| 				font-size 1em | ||||
| 				line-height 38px | ||||
| 				color #000 | ||||
| 				line-height 48px | ||||
| 				color var(--faceText) | ||||
| 				outline none | ||||
| 				background isDark ? #191b22 : #fff | ||||
| 				border solid 1px isDark ? #495156 : #eee | ||||
| 				background transparent | ||||
| 				border none | ||||
| 				border-radius 5px | ||||
| 				box-shadow none | ||||
| 				transition color 0.5s ease, border 0.5s ease | ||||
|  | ||||
| 				&:hover | ||||
| 					border solid 1px isDark ? #b0b0b0 : #ddd | ||||
| 					transition border 0.2s ease | ||||
|  | ||||
| 				&:focus | ||||
| 					color darken($theme-color, 20%) | ||||
| 					border solid 1px $theme-color | ||||
| 					transition color 0, border 0 | ||||
|  | ||||
| 		> .result | ||||
| 			display block | ||||
| @@ -287,7 +273,7 @@ root(isDark) | ||||
| 					&:hover | ||||
| 					&:focus | ||||
| 						color #fff | ||||
| 						background $theme-color | ||||
| 						background var(--primary) | ||||
|  | ||||
| 						.name | ||||
| 							color #fff | ||||
| @@ -297,7 +283,7 @@ root(isDark) | ||||
|  | ||||
| 					&:active | ||||
| 						color #fff | ||||
| 						background darken($theme-color, 10%) | ||||
| 						background var(--primaryDarken10) | ||||
|  | ||||
| 						.name | ||||
| 							color #fff | ||||
| @@ -329,21 +315,21 @@ root(isDark) | ||||
| 		> a | ||||
| 			display block | ||||
| 			text-decoration none | ||||
| 			background isDark ? #282c37 : #fff | ||||
| 			border-bottom solid 1px isDark ? #1c2023 : #eee | ||||
| 			background var(--face) | ||||
| 			border-bottom solid 1px var(--faceDivider) | ||||
|  | ||||
| 			* | ||||
| 				pointer-events none | ||||
| 				user-select none | ||||
|  | ||||
| 			&:hover | ||||
| 				background isDark ? #1e2129 : #fafafa | ||||
| 				box-shadow 0 0 0 100px inset rgba(0, 0, 0, 0.05) | ||||
|  | ||||
| 				> .avatar | ||||
| 				.avatar | ||||
| 					filter saturate(200%) | ||||
|  | ||||
| 			&:active | ||||
| 				background isDark ? #14161b : #eee | ||||
| 				box-shadow 0 0 0 100px inset rgba(0, 0, 0, 0.1) | ||||
|  | ||||
| 			&[data-is-read] | ||||
| 			&[data-is-me] | ||||
| @@ -383,17 +369,17 @@ root(isDark) | ||||
| 						overflow hidden | ||||
| 						text-overflow ellipsis | ||||
| 						font-size 1em | ||||
| 						color isDark ? #fff : rgba(#000, 0.9) | ||||
| 						color var(--noteHeaderName) | ||||
| 						font-weight bold | ||||
| 						transition all 0.1s ease | ||||
|  | ||||
| 					> .username | ||||
| 						margin 0 8px | ||||
| 						color isDark ? #606984 : rgba(#000, 0.5) | ||||
| 						color var(--noteHeaderAcct) | ||||
|  | ||||
| 					> .mk-time | ||||
| 						margin 0 0 0 auto | ||||
| 						color isDark ? #606984 : rgba(#000, 0.5) | ||||
| 						color var(--noteHeaderInfo) | ||||
| 						font-size 80% | ||||
|  | ||||
| 				> .avatar | ||||
| @@ -413,10 +399,10 @@ root(isDark) | ||||
| 						overflow hidden | ||||
| 						overflow-wrap break-word | ||||
| 						font-size 1.1em | ||||
| 						color isDark ? #fff : rgba(#000, 0.8) | ||||
| 						color var(--faceText) | ||||
|  | ||||
| 						.me | ||||
| 							color isDark ? rgba(#fff, 0.7) : rgba(#000, 0.4) | ||||
| 							opacity 0.7 | ||||
|  | ||||
| 					> .image | ||||
| 						display block | ||||
| @@ -461,10 +447,4 @@ root(isDark) | ||||
| 					> .avatar | ||||
| 						margin 0 12px 0 0 | ||||
|  | ||||
| .mk-messaging[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .mk-messaging:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -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); | ||||
| 	} | ||||
| }); | ||||
|   | ||||
| @@ -2,6 +2,8 @@ | ||||
| <span class="mk-nav"> | ||||
| 	<a :href="aboutUrl">%i18n:@about%</a> | ||||
| 	<i>・</i> | ||||
| 	<a href="/stats">%i18n:@stats%</a> | ||||
| 	<i>・</i> | ||||
| 	<a :href="repositoryUrl">%i18n:@repository%</a> | ||||
| 	<i>・</i> | ||||
| 	<a :href="feedbackUrl" target="_blank">%i18n:@feedback%</a> | ||||
|   | ||||
| @@ -42,9 +42,7 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
| .bvonvjxbwzaiskogyhbwgyxvcgserpmu | ||||
| 	display flex | ||||
| 	align-items baseline | ||||
| 	white-space nowrap | ||||
| @@ -61,7 +59,7 @@ root(isDark) | ||||
| 		margin 0 .5em 0 0 | ||||
| 		padding 0 | ||||
| 		overflow hidden | ||||
| 		color isDark ? #fff : #627079 | ||||
| 		color var(--noteHeaderName) | ||||
| 		font-size 1em | ||||
| 		font-weight bold | ||||
| 		text-decoration none | ||||
| @@ -82,19 +80,19 @@ root(isDark) | ||||
| 		margin 0 .5em 0 0 | ||||
| 		padding 1px 6px | ||||
| 		font-size 80% | ||||
| 		color isDark ? #758188 : #aaa | ||||
| 		border solid 1px isDark ? #57616f : #ddd | ||||
| 		color var(--noteHeaderBadgeFg) | ||||
| 		background var(--noteHeaderBadgeBg) | ||||
| 		border-radius 3px | ||||
|  | ||||
| 		&.is-admin | ||||
| 			border-color isDark ? #d42c41 : #f56a7b | ||||
| 			color isDark ? #d42c41 : #f56a7b | ||||
| 			background var(--noteHeaderAdminBg) | ||||
| 			color var(--noteHeaderAdminFg) | ||||
|  | ||||
| 	> .username | ||||
| 		margin 0 .5em 0 0 | ||||
| 		overflow hidden | ||||
| 		text-overflow ellipsis | ||||
| 		color isDark ? #606984 : #ccc | ||||
| 		color var(--noteHeaderAcct) | ||||
| 		flex-shrink 2147483647 | ||||
|  | ||||
| 	> .info | ||||
| @@ -102,7 +100,7 @@ root(isDark) | ||||
| 		font-size 0.9em | ||||
|  | ||||
| 		> * | ||||
| 			color isDark ? #606984 : #c0c0c0 | ||||
| 			color var(--noteHeaderInfo) | ||||
|  | ||||
| 		> .mobile | ||||
| 			margin-right 8px | ||||
| @@ -110,15 +108,9 @@ root(isDark) | ||||
| 		> .app | ||||
| 			margin-right 8px | ||||
| 			padding-right 8px | ||||
| 			border-right solid 1px isDark ? #1c2023 : #eaeaea | ||||
| 			border-right solid 1px var(--faceDivider) | ||||
|  | ||||
| 		> .visibility | ||||
| 			margin-left 8px | ||||
|  | ||||
| .bvonvjxbwzaiskogyhbwgyxvcgserpmu[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .bvonvjxbwzaiskogyhbwgyxvcgserpmu:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -28,17 +28,29 @@ export default Vue.extend({ | ||||
| 			}]; | ||||
|  | ||||
| 			if (this.note.userId == this.$store.state.i.id) { | ||||
| 				if ((this.$store.state.i.pinnedNoteIds || []).includes(this.note.id)) { | ||||
| 					items.push({ | ||||
| 						icon: '%fa:thumbtack%', | ||||
| 						text: '%i18n:@unpin%', | ||||
| 						action: this.unpin | ||||
| 					}); | ||||
| 				} else { | ||||
| 					items.push({ | ||||
| 						icon: '%fa:thumbtack%', | ||||
| 						text: '%i18n:@pin%', | ||||
| 						action: this.pin | ||||
| 					}); | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			if (this.note.userId == this.$store.state.i.id || this.$store.state.i.isAdmin) { | ||||
| 				items.push({ | ||||
| 					icon: '%fa:trash-alt R%', | ||||
| 					text: '%i18n:@delete%', | ||||
| 					action: this.del | ||||
| 				}); | ||||
| 			} | ||||
|  | ||||
| 			if (this.note.uri) { | ||||
| 				items.push({ | ||||
| 					icon: '%fa:external-link-square-alt%', | ||||
| @@ -48,9 +60,11 @@ export default Vue.extend({ | ||||
| 					} | ||||
| 				}); | ||||
| 			} | ||||
|  | ||||
| 			return items; | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		detail() { | ||||
| 			this.$router.push(`/notes/${ this.note.id }`); | ||||
| @@ -64,7 +78,15 @@ export default Vue.extend({ | ||||
| 			(this as any).api('i/pin', { | ||||
| 				noteId: this.note.id | ||||
| 			}).then(() => { | ||||
| 				this.$destroy(); | ||||
| 				this.destroyDom(); | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		unpin() { | ||||
| 			(this as any).api('i/unpin', { | ||||
| 				noteId: this.note.id | ||||
| 			}).then(() => { | ||||
| 				this.destroyDom(); | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| @@ -73,7 +95,7 @@ export default Vue.extend({ | ||||
| 			(this as any).api('notes/delete', { | ||||
| 				noteId: this.note.id | ||||
| 			}).then(() => { | ||||
| 				this.$destroy(); | ||||
| 				this.destroyDom(); | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| @@ -81,13 +103,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) | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
| @@ -67,9 +68,7 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
| .mk-poll-editor | ||||
| 	padding 8px | ||||
|  | ||||
| 	> .caution | ||||
| @@ -102,49 +101,43 @@ root(isDark) | ||||
| 				padding 6px 8px | ||||
| 				width 300px | ||||
| 				font-size 14px | ||||
| 				color isDark ? #fff : #000 | ||||
| 				background isDark ? #191b22 : #fff | ||||
| 				border solid 1px rgba($theme-color, 0.1) | ||||
| 				color var(--inputText) | ||||
| 				background var(--pollEditorInputBg) | ||||
| 				border solid 1px var(--primaryAlpha01) | ||||
| 				border-radius 4px | ||||
|  | ||||
| 				&:hover | ||||
| 					border-color rgba($theme-color, 0.2) | ||||
| 					border-color var(--primaryAlpha02) | ||||
|  | ||||
| 				&:focus | ||||
| 					border-color rgba($theme-color, 0.5) | ||||
| 					border-color var(--primaryAlpha05) | ||||
|  | ||||
| 			> button | ||||
| 				padding 4px 8px | ||||
| 				color rgba($theme-color, 0.4) | ||||
| 				color var(--primaryAlpha04) | ||||
|  | ||||
| 				&:hover | ||||
| 					color rgba($theme-color, 0.6) | ||||
| 					color var(--primaryAlpha06) | ||||
|  | ||||
| 				&:active | ||||
| 					color darken($theme-color, 30%) | ||||
| 					color var(--primaryDarken30) | ||||
|  | ||||
| 	> .add | ||||
| 		margin 8px 0 0 0 | ||||
| 		vertical-align top | ||||
| 		color $theme-color | ||||
| 		color var(--primary) | ||||
|  | ||||
| 	> .destroy | ||||
| 		position absolute | ||||
| 		top 0 | ||||
| 		right 0 | ||||
| 		padding 4px 8px | ||||
| 		color rgba($theme-color, 0.4) | ||||
| 		color var(--primaryAlpha04) | ||||
|  | ||||
| 		&:hover | ||||
| 			color rgba($theme-color, 0.6) | ||||
| 			color var(--primaryAlpha06) | ||||
|  | ||||
| 		&:active | ||||
| 			color darken($theme-color, 30%) | ||||
|  | ||||
| .mk-poll-editor[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .mk-poll-editor:not([data-darkmode]) | ||||
| 	root(false) | ||||
| 			color var(--primaryDarken30) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -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); | ||||
| @@ -66,10 +67,7 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
|  | ||||
| .mk-poll | ||||
| 	> ul | ||||
| 		display block | ||||
| 		margin 0 | ||||
| @@ -81,8 +79,8 @@ root(isDark) | ||||
| 			margin 4px 0 | ||||
| 			padding 4px 8px | ||||
| 			width 100% | ||||
| 			color isDark ? #fff : #000 | ||||
| 			border solid 1px isDark ? #5e636f : #eee | ||||
| 			color var(--pollChoiceText) | ||||
| 			border solid 1px var(--pollChoiceBorder) | ||||
| 			border-radius 4px | ||||
| 			overflow hidden | ||||
| 			cursor pointer | ||||
| @@ -98,7 +96,7 @@ root(isDark) | ||||
| 				top 0 | ||||
| 				left 0 | ||||
| 				height 100% | ||||
| 				background $theme-color | ||||
| 				background var(--primary) | ||||
| 				transition width 1s ease | ||||
|  | ||||
| 			> span | ||||
| @@ -109,7 +107,7 @@ root(isDark) | ||||
| 					margin-left 4px | ||||
|  | ||||
| 	> p | ||||
| 		color isDark ? #a3aebf : #000 | ||||
| 		color var(--text) | ||||
|  | ||||
| 		a | ||||
| 			color inherit | ||||
| @@ -124,10 +122,4 @@ root(isDark) | ||||
| 			&:active | ||||
| 				background transparent | ||||
|  | ||||
| .mk-poll[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .mk-poll:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -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,21 +177,42 @@ 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(); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| $border-color = rgba(27, 31, 35, 0.15) | ||||
|  | ||||
| root(isDark) | ||||
| .mk-reaction-picker | ||||
| 	position initial | ||||
|  | ||||
| 	> .backdrop | ||||
| @@ -142,11 +222,11 @@ root(isDark) | ||||
| 		z-index 10000 | ||||
| 		width 100% | ||||
| 		height 100% | ||||
| 		background isDark ? rgba(#000, 0.4) : rgba(#000, 0.1) | ||||
| 		background var(--modalBackdrop) | ||||
| 		opacity 0 | ||||
|  | ||||
| 	> .popover | ||||
| 		$bgcolor = isDark ? #2c303c : #fff | ||||
| 		$bgcolor = var(--popupBg) | ||||
| 		position absolute | ||||
| 		z-index 10001 | ||||
| 		background $bgcolor | ||||
| @@ -199,14 +279,29 @@ root(isDark) | ||||
| 			margin 0 | ||||
| 			padding 8px 10px | ||||
| 			font-size 14px | ||||
| 			color isDark ? #d6dce2 : #586069 | ||||
| 			border-bottom solid 1px isDark ? #1c2023 : #e1e4e8 | ||||
| 			color var(--popupFg) | ||||
| 			border-bottom solid 1px var(--faceDivider) | ||||
|  | ||||
| 		> div | ||||
| 			padding 4px | ||||
| 			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 var(--primaryAlpha03) | ||||
| 						border-radius 4px | ||||
|  | ||||
| 			> button | ||||
| 				padding 0 | ||||
| 				width 40px | ||||
| @@ -215,16 +310,10 @@ root(isDark) | ||||
| 				border-radius 2px | ||||
|  | ||||
| 				&:hover | ||||
| 					background isDark ? #252731 : #eee | ||||
| 					background var(--reactionPickerButtonHoverBg) | ||||
|  | ||||
| 				&:active | ||||
| 					background $theme-color | ||||
| 					background var(--primary) | ||||
| 					box-shadow inset 0 0.15em 0.3em rgba(27, 31, 35, 0.15) | ||||
|  | ||||
| .mk-reaction-picker[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .mk-reaction-picker:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -39,10 +39,9 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| root(isDark) | ||||
| 	$borderColor = isDark ? #5e6673 : #eee | ||||
| 	border-top dashed 1px $borderColor | ||||
| 	border-bottom dashed 1px $borderColor | ||||
| .mk-reactions-viewer | ||||
| 	border-top dashed 1px var(--reactionViewerBorder) | ||||
| 	border-bottom dashed 1px var(--reactionViewerBorder) | ||||
| 	margin 4px 0 | ||||
|  | ||||
| 	&:empty | ||||
| @@ -60,12 +59,6 @@ root(isDark) | ||||
| 		> span | ||||
| 			margin-left 4px | ||||
| 			font-size 1.2em | ||||
| 			color isDark ? #d1d5dc : #444 | ||||
|  | ||||
| .mk-reactions-viewer[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .mk-reactions-viewer:not([data-darkmode]) | ||||
| 	root(false) | ||||
| 			color var(--text) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -1,16 +1,16 @@ | ||||
| <template> | ||||
| <form class="mk-signin" :class="{ signing }" @submit.prevent="onSubmit"> | ||||
| 	<div class="avatar" :style="{ backgroundImage: user ? `url('${ user.avatarUrl }')` : null }" v-show="withAvatar"></div> | ||||
| 	<ui-input v-model="username" type="text" pattern="^[a-zA-Z0-9_]+$" spellcheck="false" autofocus required @input="onUsernameChange"> | ||||
| 	<ui-input v-model="username" type="text" pattern="^[a-zA-Z0-9_]+$" spellcheck="false" autofocus required @input="onUsernameChange" styl="fill"> | ||||
| 		<span>%i18n:@username%</span> | ||||
| 		<span slot="prefix">@</span> | ||||
| 		<span slot="suffix">@{{ host }}</span> | ||||
| 	</ui-input> | ||||
| 	<ui-input v-model="password" type="password" required> | ||||
| 	<ui-input v-model="password" type="password" required styl="fill"> | ||||
| 		<span>%i18n:@password%</span> | ||||
| 		<span slot="prefix">%fa:lock%</span> | ||||
| 	</ui-input> | ||||
| 	<ui-input v-if="user && user.twoFactorEnabled" v-model="token" type="number" required/> | ||||
| 	<ui-input v-if="user && user.twoFactorEnabled" v-model="token" type="number" required styl="fill"/> | ||||
| 	<ui-button type="submit" :disabled="signing">{{ signing ? '%i18n:@signing-in%' : '%i18n:@signin%' }}</ui-button> | ||||
| 	<p style="margin: 8px 0;">%i18n:@or% <a :href="`${apiUrl}/signin/twitter`">%i18n:@signin-with-twitter%</a></p> | ||||
| </form> | ||||
| @@ -68,7 +68,7 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
|  | ||||
| .mk-signin | ||||
| 	color #555 | ||||
| @@ -78,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,12 +1,12 @@ | ||||
| <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> | ||||
| 		<ui-input v-if="meta.disableRegistration" v-model="invitationCode" type="text" :autocomplete="Math.random()" spellcheck="false" required styl="fill"> | ||||
| 			<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"> | ||||
| 		<ui-input v-model="username" type="text" pattern="^[a-zA-Z0-9_]{1,20}$" :autocomplete="Math.random()" spellcheck="false" required @input="onChangeUsername" styl="fill"> | ||||
| 			<span>%i18n:@username%</span> | ||||
| 			<span slot="prefix">@</span> | ||||
| 			<span slot="suffix">@{{ host }}</span> | ||||
| @@ -18,7 +18,7 @@ | ||||
| 			<p slot="text" v-if="usernameState == 'min-range'" style="color:#FF1161">%fa:exclamation-triangle .fw% %i18n:@too-short%</p> | ||||
| 			<p slot="text" v-if="usernameState == 'max-range'" style="color:#FF1161">%fa:exclamation-triangle .fw% %i18n:@too-long%</p> | ||||
| 		</ui-input> | ||||
| 		<ui-input v-model="password" type="password" :autocomplete="Math.random()" required @input="onChangePassword" :with-password-meter="true"> | ||||
| 		<ui-input v-model="password" type="password" :autocomplete="Math.random()" required @input="onChangePassword" :with-password-meter="true" styl="fill"> | ||||
| 			<span>%i18n:@password%</span> | ||||
| 			<span slot="prefix">%fa:lock%</span> | ||||
| 			<div slot="text"> | ||||
| @@ -27,7 +27,7 @@ | ||||
| 				<p slot="text" v-if="passwordStrength == 'high'" style="color:#3CB7B5">%fa:check .fw% %i18n:@strong-password%</p> | ||||
| 			</div> | ||||
| 		</ui-input> | ||||
| 		<ui-input v-model="retypedPassword" type="password" :autocomplete="Math.random()" required @input="onChangePasswordRetype"> | ||||
| 		<ui-input v-model="retypedPassword" type="password" :autocomplete="Math.random()" required @input="onChangePasswordRetype" styl="fill"> | ||||
| 			<span>%i18n:@password% (%i18n:@retype%)</span> | ||||
| 			<span slot="prefix">%fa:lock%</span> | ||||
| 			<div slot="text"> | ||||
| @@ -151,7 +151,7 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
|  | ||||
| .mk-signup | ||||
| 	min-width 302px | ||||
|   | ||||
| @@ -1,199 +0,0 @@ | ||||
| <template> | ||||
| <div | ||||
| 	class="mk-switch" | ||||
| 	:class="{ disabled, checked }" | ||||
| 	role="switch" | ||||
| 	:aria-checked="checked" | ||||
| 	:aria-disabled="disabled" | ||||
| 	@click="switchValue" | ||||
| 	@mouseover="mouseenter" | ||||
| > | ||||
| 	<input | ||||
| 		type="checkbox" | ||||
| 		@change="handleChange" | ||||
| 		ref="input" | ||||
| 		:disabled="disabled" | ||||
| 		@keydown.enter="switchValue" | ||||
| 	> | ||||
| 	<span class="button"> | ||||
| 		<span :style="{ transform }"></span> | ||||
| 	</span> | ||||
| 	<span class="label"> | ||||
| 		<span :aria-hidden="!checked">{{ text }}</span> | ||||
| 		<p :aria-hidden="!checked"> | ||||
| 			<slot></slot> | ||||
| 		</p> | ||||
| 	</span> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| export default Vue.extend({ | ||||
| 	props: { | ||||
| 		value: { | ||||
| 			type: Boolean, | ||||
| 			default: false | ||||
| 		}, | ||||
| 		disabled: { | ||||
| 			type: Boolean, | ||||
| 			default: false | ||||
| 		}, | ||||
| 		text: String | ||||
| 	},/* | ||||
| 	created() { | ||||
| 		if (!~[true, false].indexOf(this.value)) { | ||||
| 			this.$emit('input', false); | ||||
| 		} | ||||
| 	},*/ | ||||
| 	computed: { | ||||
| 		checked(): boolean { | ||||
| 			return this.value; | ||||
| 		}, | ||||
| 		transform(): string { | ||||
| 			return this.checked ? 'translate3d(20px, 0, 0)' : ''; | ||||
| 		} | ||||
| 	}, | ||||
| 	watch: { | ||||
| 		value() { | ||||
| 			(this.$el).style.transition = 'all 0.3s'; | ||||
| 			(this.$refs.input as any).checked = this.checked; | ||||
| 		} | ||||
| 	}, | ||||
| 	mounted() { | ||||
| 		(this.$refs.input as any).checked = this.checked; | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		mouseenter() { | ||||
| 			(this.$el).style.transition = 'all 0s'; | ||||
| 		}, | ||||
| 		handleChange() { | ||||
| 			(this.$el).style.transition = 'all 0.3s'; | ||||
| 			this.$emit('input', !this.checked); | ||||
| 			this.$emit('change', !this.checked); | ||||
| 			this.$nextTick(() => { | ||||
| 				// set input's checked property | ||||
| 				// in case parent refuses to change component's value | ||||
| 				(this.$refs.input as any).checked = this.checked; | ||||
| 			}); | ||||
| 		}, | ||||
| 		switchValue() { | ||||
| 			!this.disabled && this.handleChange(); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
| 	display flex | ||||
| 	margin 12px 0 | ||||
| 	cursor pointer | ||||
| 	transition all 0.3s | ||||
|  | ||||
| 	> * | ||||
| 		user-select none | ||||
|  | ||||
| 	&.disabled | ||||
| 		opacity 0.6 | ||||
| 		cursor not-allowed | ||||
|  | ||||
| 	&.checked | ||||
| 		> .button | ||||
| 			background-color $theme-color | ||||
| 			border-color $theme-color | ||||
|  | ||||
| 		> .label | ||||
| 			> span | ||||
| 				color $theme-color | ||||
|  | ||||
| 		&:hover | ||||
| 			> .label | ||||
| 				> span | ||||
| 					color darken($theme-color, 10%) | ||||
|  | ||||
| 			> .button | ||||
| 				background darken($theme-color, 10%) | ||||
| 				border-color darken($theme-color, 10%) | ||||
|  | ||||
| 	&:hover | ||||
| 		> .label | ||||
| 			> span | ||||
| 				color isDark ? #fff : #2e3338 | ||||
|  | ||||
| 		> .button | ||||
| 			$color = isDark ? #15181d : #ced2da | ||||
| 			background $color | ||||
| 			border-color $color | ||||
|  | ||||
| 	> input | ||||
| 		position absolute | ||||
| 		width 0 | ||||
| 		height 0 | ||||
| 		opacity 0 | ||||
| 		margin 0 | ||||
|  | ||||
| 		&:focus + .button | ||||
| 			&:after | ||||
| 				content "" | ||||
| 				pointer-events none | ||||
| 				position absolute | ||||
| 				top -5px | ||||
| 				right -5px | ||||
| 				bottom -5px | ||||
| 				left -5px | ||||
| 				border 2px solid rgba($theme-color, 0.3) | ||||
| 				border-radius 14px | ||||
|  | ||||
| 	> .button | ||||
| 		$color = isDark ? #1c1f25 : #dcdfe6 | ||||
|  | ||||
| 		display inline-block | ||||
| 		margin 0 | ||||
| 		width 40px | ||||
| 		min-width 40px | ||||
| 		height 20px | ||||
| 		min-height 20px | ||||
| 		background $color | ||||
| 		border 1px solid $color | ||||
| 		outline none | ||||
| 		border-radius 10px | ||||
| 		transition inherit | ||||
|  | ||||
| 		> * | ||||
| 			position absolute | ||||
| 			top 1px | ||||
| 			left 1px | ||||
| 			border-radius 100% | ||||
| 			transition transform 0.3s | ||||
| 			width 16px | ||||
| 			height 16px | ||||
| 			background-color #fff | ||||
|  | ||||
| 	> .label | ||||
| 		margin-left 8px | ||||
| 		display block | ||||
| 		font-size 15px | ||||
| 		cursor pointer | ||||
| 		transition inherit | ||||
|  | ||||
| 		> span | ||||
| 			display block | ||||
| 			line-height 20px | ||||
| 			color isDark ? #c4ccd2 : #4a535a | ||||
| 			transition inherit | ||||
|  | ||||
| 		> p | ||||
| 			margin 0 | ||||
| 			//font-size 90% | ||||
| 			color isDark ? #78858e : #9daab3 | ||||
|  | ||||
| .mk-switch[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .mk-switch:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										84
									
								
								src/client/app/common/views/components/tag-cloud.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										84
									
								
								src/client/app/common/views/components/tag-cloud.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,84 @@ | ||||
| <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> | ||||
| .jtivnzhfwquxpsfidertopbmwmchmnmo | ||||
| 	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% | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										290
									
								
								src/client/app/common/views/components/theme.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										290
									
								
								src/client/app/common/views/components/theme.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,290 @@ | ||||
| <template> | ||||
| <div class="nicnklzforebnpfgasiypmpdaaglujqm"> | ||||
| 	<label> | ||||
| 		<span>%i18n:@light-theme%</span> | ||||
| 		<ui-select v-model="light" placeholder="%i18n:@light-theme%"> | ||||
| 			<option v-for="x in themes" :value="x.id" :key="x.id">{{ x.name }}</option> | ||||
| 		</ui-select> | ||||
| 	</label> | ||||
|  | ||||
| 	<label> | ||||
| 		<span>%i18n:@dark-theme%</span> | ||||
| 		<ui-select v-model="dark" placeholder="%i18n:@dark-theme%"> | ||||
| 			<option v-for="x in themes" :value="x.id" :key="x.id">{{ x.name }}</option> | ||||
| 		</ui-select> | ||||
| 	</label> | ||||
|  | ||||
| 	<details class="creator"> | ||||
| 		<summary>%fa:palette% %i18n:@create-a-theme%</summary> | ||||
| 		<div> | ||||
| 			<span>%i18n:@base-theme%:</span> | ||||
| 			<ui-radio v-model="myThemeBase" value="light">%i18n:@base-theme-light%</ui-radio> | ||||
| 			<ui-radio v-model="myThemeBase" value="dark">%i18n:@base-theme-dark%</ui-radio> | ||||
| 		</div> | ||||
| 		<div> | ||||
| 			<ui-input v-model="myThemeName"> | ||||
| 				<span>%i18n:@theme-name%</span> | ||||
| 			</ui-input> | ||||
| 			<ui-textarea v-model="myThemeDesc"> | ||||
| 				<span>%i18n:@desc%</span> | ||||
| 			</ui-textarea> | ||||
| 		</div> | ||||
| 		<div> | ||||
| 			<div style="padding-bottom:8px;">%i18n:@primary-color%:</div> | ||||
| 			<color-picker v-model="myThemePrimary"/> | ||||
| 		</div> | ||||
| 		<div> | ||||
| 			<div style="padding-bottom:8px;">%i18n:@secondary-color%:</div> | ||||
| 			<color-picker v-model="myThemeSecondary"/> | ||||
| 		</div> | ||||
| 		<div> | ||||
| 			<div style="padding-bottom:8px;">%i18n:@text-color%:</div> | ||||
| 			<color-picker v-model="myThemeText"/> | ||||
| 		</div> | ||||
| 		<ui-button @click="preview()">%fa:eye% %i18n:@preview-created-theme%</ui-button> | ||||
| 		<ui-button primary @click="gen()">%fa:save R% %i18n:@save-created-theme%</ui-button> | ||||
| 	</details> | ||||
|  | ||||
| 	<details> | ||||
| 		<summary>%fa:download% %i18n:@install-a-theme%</summary> | ||||
| 		<ui-button @click="import_()">%fa:file-import% %i18n:@import%</ui-button> | ||||
| 		<input ref="file" type="file" accept=".misskeytheme" style="display:none;" @change="onUpdateImportFile"/> | ||||
| 		<p>%i18n:@import-by-code%:</p> | ||||
| 		<ui-textarea v-model="installThemeCode"> | ||||
| 			<span>%i18n:@theme-code%</span> | ||||
| 		</ui-textarea> | ||||
| 		<ui-button @click="() => install(this.installThemeCode)">%fa:check% %i18n:@install%</ui-button> | ||||
| 	</details> | ||||
|  | ||||
| 	<details> | ||||
| 		<summary>%fa:folder-open% %i18n:@installed-themes%</summary> | ||||
| 		<ui-select v-model="selectedInstalledThemeId" placeholder="%i18n:@select-theme%"> | ||||
| 			<option v-for="x in installedThemes" :value="x.id" :key="x.id">{{ x.name }}</option> | ||||
| 		</ui-select> | ||||
| 		<template v-if="selectedInstalledTheme"> | ||||
| 			<ui-input readonly :value="selectedInstalledTheme.author"> | ||||
| 				<span>%i18n:@author%</span> | ||||
| 			</ui-input> | ||||
| 			<ui-textarea v-if="selectedInstalledTheme.desc" readonly :value="selectedInstalledTheme.desc"> | ||||
| 				<span>%i18n:@desc%</span> | ||||
| 			</ui-textarea> | ||||
| 			<ui-textarea readonly :value="selectedInstalledThemeCode"> | ||||
| 				<span>%i18n:@theme-code%</span> | ||||
| 			</ui-textarea> | ||||
| 			<ui-button @click="export_()" link :download="`${selectedInstalledTheme.name}.misskeytheme`" ref="export">%fa:box% %i18n:@export%</ui-button> | ||||
| 			<ui-button @click="uninstall()">%fa:trash-alt R% %i18n:@uninstall%</ui-button> | ||||
| 		</template> | ||||
| 	</details> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { lightTheme, darkTheme, builtinThemes, applyTheme, Theme } from '../../../theme'; | ||||
| import { Chrome } from 'vue-color'; | ||||
| import * as uuid from 'uuid'; | ||||
| import * as tinycolor from 'tinycolor2'; | ||||
| import * as JSON5 from 'json5'; | ||||
|  | ||||
| // 後方互換性のため | ||||
| function convertOldThemedefinition(t) { | ||||
| 	const t2 = { | ||||
| 		id: t.meta.id, | ||||
| 		name: t.meta.name, | ||||
| 		author: t.meta.author, | ||||
| 		base: t.meta.base, | ||||
| 		vars: t.meta.vars, | ||||
| 		props: t | ||||
| 	}; | ||||
| 	delete t2.props.meta; | ||||
| 	return t2; | ||||
| } | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	components: { | ||||
| 		ColorPicker: Chrome | ||||
| 	}, | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			installThemeCode: null, | ||||
| 			selectedInstalledThemeId: null, | ||||
| 			myThemeBase: 'light', | ||||
| 			myThemeName: '', | ||||
| 			myThemeDesc: '', | ||||
| 			myThemePrimary: lightTheme.vars.primary, | ||||
| 			myThemeSecondary: lightTheme.vars.secondary, | ||||
| 			myThemeText: lightTheme.vars.text | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	computed: { | ||||
| 		themes(): Theme[] { | ||||
| 			return this.$store.state.device.themes.concat(builtinThemes); | ||||
| 		}, | ||||
|  | ||||
| 		installedThemes(): Theme[] { | ||||
| 			return this.$store.state.device.themes; | ||||
| 		}, | ||||
|  | ||||
| 		light: { | ||||
| 			get() { return this.$store.state.device.lightTheme; }, | ||||
| 			set(value) { this.$store.commit('device/set', { key: 'lightTheme', value }); } | ||||
| 		}, | ||||
|  | ||||
| 		dark: { | ||||
| 			get() { return this.$store.state.device.darkTheme; }, | ||||
| 			set(value) { this.$store.commit('device/set', { key: 'darkTheme', value }); } | ||||
| 		}, | ||||
|  | ||||
| 		selectedInstalledTheme() { | ||||
| 			if (this.selectedInstalledThemeId == null) return null; | ||||
| 			return this.installedThemes.find(x => x.id == this.selectedInstalledThemeId); | ||||
| 		}, | ||||
|  | ||||
| 		selectedInstalledThemeCode() { | ||||
| 			if (this.selectedInstalledTheme == null) return null; | ||||
| 			return JSON5.stringify(this.selectedInstalledTheme, null, '\t'); | ||||
| 		}, | ||||
|  | ||||
| 		myTheme(): any { | ||||
| 			return { | ||||
| 				name: this.myThemeName, | ||||
| 				author: this.$store.state.i.username, | ||||
| 				desc: this.myThemeDesc, | ||||
| 				base: this.myThemeBase, | ||||
| 				vars: { | ||||
| 					primary: tinycolor(typeof this.myThemePrimary == 'string' ? this.myThemePrimary : this.myThemePrimary.rgba).toRgbString(), | ||||
| 					secondary: tinycolor(typeof this.myThemeSecondary == 'string' ? this.myThemeSecondary : this.myThemeSecondary.rgba).toRgbString(), | ||||
| 					text: tinycolor(typeof this.myThemeText == 'string' ? this.myThemeText : this.myThemeText.rgba).toRgbString() | ||||
| 				} | ||||
| 			}; | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	watch: { | ||||
| 		myThemeBase(v) { | ||||
| 			const theme = v == 'light' ? lightTheme : darkTheme; | ||||
| 			this.myThemePrimary = theme.vars.primary; | ||||
| 			this.myThemeSecondary = theme.vars.secondary; | ||||
| 			this.myThemeText = theme.vars.text; | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	beforeCreate() { | ||||
| 		// migrate old theme definitions | ||||
| 		// 後方互換性のため | ||||
| 		this.$store.commit('device/set', { | ||||
| 			key: 'themes', value: this.$store.state.device.themes.map(t => { | ||||
| 				if (t.id == null) { | ||||
| 					return convertOldThemedefinition(t); | ||||
| 				} else { | ||||
| 					return t; | ||||
| 				} | ||||
| 			}) | ||||
| 		}); | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		install(code) { | ||||
| 			let theme; | ||||
|  | ||||
| 			try { | ||||
| 				theme = JSON5.parse(code); | ||||
| 			} catch (e) { | ||||
| 				alert('%i18n:@invalid-theme%'); | ||||
| 				return; | ||||
| 			} | ||||
|  | ||||
| 			// 後方互換性のため | ||||
| 			if (theme.id == null && theme.meta != null) { | ||||
| 				theme = convertOldThemedefinition(theme); | ||||
| 			} | ||||
|  | ||||
| 			if (theme.id == null) { | ||||
| 				alert('%i18n:@invalid-theme%'); | ||||
| 				return; | ||||
| 			} | ||||
|  | ||||
| 			if (this.$store.state.device.themes.some(t => t.id == theme.id)) { | ||||
| 				alert('%i18n:@already-installed%'); | ||||
| 				return; | ||||
| 			} | ||||
|  | ||||
| 			const themes = this.$store.state.device.themes.concat(theme); | ||||
| 			this.$store.commit('device/set', { | ||||
| 				key: 'themes', value: themes | ||||
| 			}); | ||||
|  | ||||
| 			alert('%i18n:@installed%'.replace('{}', theme.name)); | ||||
| 		}, | ||||
|  | ||||
| 		uninstall() { | ||||
| 			const theme = this.selectedInstalledTheme; | ||||
| 			const themes = this.$store.state.device.themes.filter(t => t.id != theme.id); | ||||
| 			this.$store.commit('device/set', { | ||||
| 				key: 'themes', value: themes | ||||
| 			}); | ||||
| 			alert('%i18n:@uninstalled%'.replace('{}', theme.name)); | ||||
| 		}, | ||||
|  | ||||
| 		import_() { | ||||
| 			(this.$refs.file as any).click(); | ||||
| 		} | ||||
|  | ||||
| 		export_() { | ||||
| 			const blob = new Blob([this.selectedInstalledThemeCode], { | ||||
| 				type: 'application/json5' | ||||
| 			}); | ||||
| 			this.$refs.export.$el.href = window.URL.createObjectURL(blob); | ||||
| 		}, | ||||
|  | ||||
| 		onUpdateImportFile() { | ||||
| 			const f = (this.$refs.file as any).files[0]; | ||||
|  | ||||
| 			const reader = new FileReader(); | ||||
|  | ||||
| 			reader.onload = e => { | ||||
| 				this.install(e.target.result); | ||||
| 			}; | ||||
|  | ||||
| 			reader.readAsText(f); | ||||
| 		}, | ||||
|  | ||||
| 		preview() { | ||||
| 			applyTheme(this.myTheme, false); | ||||
| 		}, | ||||
|  | ||||
| 		gen() { | ||||
| 			const theme = this.myTheme; | ||||
| 			if (theme.name == null || theme.name.trim() == '') { | ||||
| 				alert('%i18n:@theme-name-required%'); | ||||
| 				return; | ||||
| 			} | ||||
| 			theme.id = uuid(); | ||||
| 			const themes = this.$store.state.device.themes.concat(theme); | ||||
| 			this.$store.commit('device/set', { | ||||
| 				key: 'themes', value: themes | ||||
| 			}); | ||||
| 			alert('%i18n:@saved%'); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .nicnklzforebnpfgasiypmpdaaglujqm | ||||
| 	> details | ||||
| 		border-top solid 1px var(--faceDivider) | ||||
|  | ||||
| 		> summary | ||||
| 			padding 16px 0 | ||||
|  | ||||
| 		> *:last-child | ||||
| 			margin-bottom 16px | ||||
|  | ||||
| 	> .creator | ||||
| 		> div | ||||
| 			padding 16px 0 | ||||
| 			border-bottom solid 1px var(--faceDivider) | ||||
| </style> | ||||
							
								
								
									
										98
									
								
								src/client/app/common/views/components/trends.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										98
									
								
								src/client/app/common/views/components/trends.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,98 @@ | ||||
| <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> | ||||
| .csqvmxybqbycalfhkxvyfrgbrdalkaoc | ||||
| 	> .fetching | ||||
| 	> .empty | ||||
| 		margin 0 | ||||
| 		padding 16px | ||||
| 		text-align center | ||||
| 		color var(--text) | ||||
| 		opacity 0.7 | ||||
|  | ||||
| 		> [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 var(--faceDivider) | ||||
|  | ||||
| 			> .tag | ||||
| 				flex 1 | ||||
| 				overflow hidden | ||||
| 				font-size 14px | ||||
| 				color var(--text) | ||||
|  | ||||
| 				> 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 | ||||
|  | ||||
| </style> | ||||
| @@ -1,9 +1,7 @@ | ||||
| <template> | ||||
| <div class="ui-button" :class="[styl]"> | ||||
| 	<button :type="type" @click="$emit('click')"> | ||||
| <component class="dmtdnykelhudezerjlfpbhgovrgnqqgr" :is="link ? 'a' : 'button'" :class="[styl, { inline, primary }]" :type="type" @click="$emit('click')"> | ||||
| 	<slot></slot> | ||||
| 	</button> | ||||
| </div> | ||||
| </component> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| @@ -13,70 +11,100 @@ export default Vue.extend({ | ||||
| 		type: { | ||||
| 			type: String, | ||||
| 			required: false | ||||
| 		}, | ||||
| 		primary: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		}, | ||||
| 		inline: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		}, | ||||
| 		link: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		} | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| 			styl: 'fill' | ||||
| 		}; | ||||
| 	}, | ||||
| 	inject: { | ||||
| 		isCardChild: { default: false } | ||||
| 	}, | ||||
| 	created() { | ||||
| 		if (this.isCardChild) { | ||||
| 			this.styl = 'line'; | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark, fill) | ||||
| 	> button | ||||
| .dmtdnykelhudezerjlfpbhgovrgnqqgr | ||||
| 	display block | ||||
| 	width 100% | ||||
| 	margin 0 | ||||
| 		padding 0 | ||||
| 		font-weight bold | ||||
| 	padding 8px | ||||
| 	text-align center | ||||
| 	font-weight normal | ||||
| 	font-size 16px | ||||
| 		line-height 44px | ||||
| 	border none | ||||
| 	border-radius 6px | ||||
| 	outline none | ||||
| 	box-shadow none | ||||
| 	text-decoration none | ||||
| 	user-select none | ||||
|  | ||||
| 		if fill | ||||
| 			color $theme-color-foreground | ||||
| 			background $theme-color | ||||
| 	* | ||||
| 		pointer-events none | ||||
|  | ||||
| 	&:focus | ||||
| 		&:after | ||||
| 			content "" | ||||
| 			pointer-events none | ||||
| 			position absolute | ||||
| 			top -5px | ||||
| 			right -5px | ||||
| 			bottom -5px | ||||
| 			left -5px | ||||
| 			border 2px solid var(--primaryAlpha03) | ||||
| 			border-radius 10px | ||||
|  | ||||
| 	&:not(.inline) + .dmtdnykelhudezerjlfpbhgovrgnqqgr | ||||
| 		margin-top 16px | ||||
|  | ||||
| 	&.inline | ||||
| 		display inline-block | ||||
| 		width auto | ||||
|  | ||||
| 	&.primary | ||||
| 		font-weight bold | ||||
|  | ||||
| 	&.fill | ||||
| 		color var(--text) | ||||
| 		background var(--buttonBg) | ||||
|  | ||||
| 		&:hover | ||||
| 				background lighten($theme-color, 5%) | ||||
| 			background var(--buttonHoverBg) | ||||
|  | ||||
| 		&:active | ||||
| 				background darken($theme-color, 5%) | ||||
| 		else | ||||
| 			color $theme-color | ||||
| 			background var(--buttonActiveBg) | ||||
|  | ||||
| 		&.primary | ||||
| 			color var(--primaryForeground) | ||||
| 			background var(--primary) | ||||
|  | ||||
| 			&:hover | ||||
| 				background var(--primaryLighten5) | ||||
|  | ||||
| 			&:active | ||||
| 				background var(--primaryDarken5) | ||||
|  | ||||
| 	&:not(.fill) | ||||
| 		color var(--primary) | ||||
| 		background none | ||||
|  | ||||
| 		&:hover | ||||
| 				color darken($theme-color, 5%) | ||||
| 			color var(--primaryDarken5) | ||||
|  | ||||
| 		&:active | ||||
| 				background rgba($theme-color, 0.3) | ||||
|  | ||||
| .ui-button[data-darkmode] | ||||
| 	&.fill | ||||
| 		root(true, true) | ||||
| 	&:not(.fill) | ||||
| 		root(true, false) | ||||
|  | ||||
| .ui-button:not([data-darkmode]) | ||||
| 	&.fill | ||||
| 		root(false, true) | ||||
| 	&:not(.fill) | ||||
| 		root(false, false) | ||||
| 			background var(--primaryAlpha03) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -20,27 +20,33 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
| .ui-card | ||||
| 	margin 16px | ||||
| 	padding 16px | ||||
| 	color isDark ? #fff : #000 | ||||
| 	background isDark ? #282C37 : #fff | ||||
| 	color var(--faceText) | ||||
| 	background var(--face) | ||||
| 	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 var(--faceText) | ||||
|  | ||||
| 		@media (min-width 500px) | ||||
| 			padding 24px 32px | ||||
|  | ||||
| 	> section | ||||
| 		padding 20px 16px | ||||
| 		border-top solid 1px var(--faceDivider) | ||||
|  | ||||
| 		@media (min-width 500px) | ||||
| 			padding 32px | ||||
|  | ||||
| 		&.fit-top | ||||
| 			padding-top 0 | ||||
|  | ||||
| 		> header | ||||
| 		font-weight normal | ||||
| 		font-size 24px | ||||
| 		color isDark ? #fff : #444 | ||||
|  | ||||
| .ui-card[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .ui-card:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| 			margin-bottom 16px | ||||
| 			font-weight bold | ||||
| 			color var(--faceText) | ||||
| </style> | ||||
|   | ||||
| @@ -19,7 +19,7 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
|  | ||||
| .ui-form | ||||
| 	> fieldset | ||||
|   | ||||
| @@ -25,9 +25,7 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
| .nvemkhtwcnnpkdrwfcbzuwhfulejhmzg | ||||
| 	display inline-block | ||||
|  | ||||
| 	& + .nvemkhtwcnnpkdrwfcbzuwhfulejhmzg | ||||
| @@ -38,11 +36,11 @@ root(isDark) | ||||
| 		margin 0 | ||||
| 		padding 12px 20px | ||||
| 		font-size 14px | ||||
| 		border 1px solid isDark ? #6d727d : #dcdfe6 | ||||
| 		border 1px solid var(--formButtonBorder) | ||||
| 		border-radius 4px | ||||
| 		outline none | ||||
| 		box-shadow none | ||||
| 		color isDark ? #fff : #606266 | ||||
| 		color var(--text) | ||||
| 		transition 0.1s | ||||
|  | ||||
| 		* | ||||
| @@ -50,40 +48,34 @@ root(isDark) | ||||
|  | ||||
| 		&:hover | ||||
| 		&:focus | ||||
| 			color $theme-color | ||||
| 			background rgba($theme-color, isDark ? 0.2 : 0.12) | ||||
| 			border-color rgba($theme-color, isDark ? 0.5 : 0.3) | ||||
| 			color var(--primary) | ||||
| 			background var(--formButtonHoverBg) | ||||
| 			border-color var(--formButtonHoverBorder) | ||||
|  | ||||
| 		&:active | ||||
| 			color darken($theme-color, 20%) | ||||
| 			background rgba($theme-color, 0.12) | ||||
| 			border-color $theme-color | ||||
| 			color var(--primaryDarken20) | ||||
| 			background var(--formButtonActiveBg) | ||||
| 			border-color var(--primary) | ||||
| 			transition all 0s | ||||
|  | ||||
| 	&.primary | ||||
| 		> button | ||||
| 			border 1px solid $theme-color | ||||
| 			background $theme-color | ||||
| 			color $theme-color-foreground | ||||
| 			border 1px solid var(--primary) | ||||
| 			background var(--primary) | ||||
| 			color var(--primaryForeground) | ||||
|  | ||||
| 			&:hover | ||||
| 			&:focus | ||||
| 				background lighten($theme-color, 20%) | ||||
| 				border-color lighten($theme-color, 20%) | ||||
| 				background var(--primaryLighten20) | ||||
| 				border-color var(--primaryLighten20) | ||||
|  | ||||
| 			&:active | ||||
| 				background darken($theme-color, 20%) | ||||
| 				border-color darken($theme-color, 20%) | ||||
| 				background var(--primaryDarken20) | ||||
| 				border-color var(--primaryDarken20) | ||||
| 				transition all 0s | ||||
|  | ||||
| 	&.round | ||||
| 		> button | ||||
| 			border-radius 64px | ||||
|  | ||||
| .nvemkhtwcnnpkdrwfcbzuwhfulejhmzg[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .nvemkhtwcnnpkdrwfcbzuwhfulejhmzg:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -49,9 +49,7 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
| .uywduthvrdnlpsvsjkqigicixgyfctto | ||||
| 	display inline-flex | ||||
| 	margin 0 16px 0 0 | ||||
| 	cursor pointer | ||||
| @@ -62,7 +60,7 @@ root(isDark) | ||||
|  | ||||
| 	&:hover | ||||
| 		> .button | ||||
| 			border solid 2px isDark ? rgba(#fff, 0.7) : rgba(#000, 0.54) | ||||
| 			border solid 2px var(--inputLabel) | ||||
|  | ||||
| 	&.disabled | ||||
| 		opacity 0.6 | ||||
| @@ -70,15 +68,15 @@ root(isDark) | ||||
|  | ||||
| 	&.checked | ||||
| 		> .button | ||||
| 			border-color $theme-color | ||||
| 			border-color var(--primary) | ||||
|  | ||||
| 			&:after | ||||
| 				background-color $theme-color | ||||
| 				background-color var(--primary) | ||||
| 				transform scale(1) | ||||
| 				opacity 1 | ||||
|  | ||||
| 		> .label | ||||
| 			color $theme-color | ||||
| 			color var(--primary) | ||||
|  | ||||
| 	> input | ||||
| 		position absolute | ||||
| @@ -93,7 +91,7 @@ root(isDark) | ||||
| 		width 20px | ||||
| 		height 20px | ||||
| 		background none | ||||
| 		border solid 2px isDark ? rgba(#fff, 0.6) : rgba(#000, 0.4) | ||||
| 		border solid 2px var(--radioBorder) | ||||
| 		border-radius 100% | ||||
| 		transition inherit | ||||
|  | ||||
| @@ -117,10 +115,4 @@ root(isDark) | ||||
| 		line-height 20px | ||||
| 		cursor pointer | ||||
|  | ||||
| .uywduthvrdnlpsvsjkqigicixgyfctto[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .uywduthvrdnlpsvsjkqigicixgyfctto:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -71,14 +71,18 @@ export default Vue.extend({ | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		}, | ||||
| 		styl: { | ||||
| 			type: String, | ||||
| 			required: false, | ||||
| 			default: 'line' | ||||
| 		} | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| 			v: this.value, | ||||
| 			focused: false, | ||||
| 			passwordStrength: '', | ||||
| 			styl: 'fill' | ||||
| 			passwordStrength: '' | ||||
| 		}; | ||||
| 	}, | ||||
| 	computed: { | ||||
| @@ -117,14 +121,6 @@ export default Vue.extend({ | ||||
| 			} | ||||
| 		} | ||||
| 	}, | ||||
| 	inject: { | ||||
| 		isCardChild: { default: false } | ||||
| 	}, | ||||
| 	created() { | ||||
| 		if (this.isCardChild) { | ||||
| 			this.styl = 'line'; | ||||
| 		} | ||||
| 	}, | ||||
| 	mounted() { | ||||
| 		if (this.$refs.prefix) { | ||||
| 			this.$refs.label.style.left = (this.$refs.prefix.offsetLeft + this.$refs.prefix.offsetWidth) + 'px'; | ||||
| @@ -155,9 +151,7 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark, fill) | ||||
| root(fill) | ||||
| 	margin 32px 0 | ||||
|  | ||||
| 	> .icon | ||||
| @@ -167,7 +161,7 @@ root(isDark, fill) | ||||
| 		width 24px | ||||
| 		text-align center | ||||
| 		line-height 32px | ||||
| 		color isDark ? rgba(#fff, 0.7) : rgba(#000, 0.54) | ||||
| 		color var(--inputLabel) | ||||
|  | ||||
| 		&:not(:empty) + .input | ||||
| 			margin-left 28px | ||||
| @@ -183,7 +177,7 @@ root(isDark, fill) | ||||
| 				left 0 | ||||
| 				right 0 | ||||
| 				height 1px | ||||
| 				background isDark ? rgba(#fff, 0.7) : rgba(#000, 0.42) | ||||
| 				background var(--inputBorder) | ||||
|  | ||||
| 			&:after | ||||
| 				content '' | ||||
| @@ -193,7 +187,7 @@ root(isDark, fill) | ||||
| 				left 0 | ||||
| 				right 0 | ||||
| 				height 2px | ||||
| 				background $theme-color | ||||
| 				background var(--primary) | ||||
| 				opacity 0 | ||||
| 				transform scaleX(0.12) | ||||
| 				transition border 0.3s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1), transform 0.3s cubic-bezier(0.4, 0, 0.2, 1) | ||||
| @@ -242,7 +236,7 @@ root(isDark, fill) | ||||
| 			transition-duration 0.3s | ||||
| 			font-size 16px | ||||
| 			line-height 32px | ||||
| 			color isDark ? rgba(#fff, 0.7) : rgba(#000, 0.54) | ||||
| 			color var(--inputLabel) | ||||
| 			pointer-events none | ||||
| 			//will-change transform | ||||
| 			transform-origin top left | ||||
| @@ -257,7 +251,7 @@ root(isDark, fill) | ||||
| 			font-weight fill ? bold : normal | ||||
| 			font-size 16px | ||||
| 			line-height 32px | ||||
| 			color isDark ? #fff : #000 | ||||
| 			color var(--inputText) | ||||
| 			background transparent | ||||
| 			border none | ||||
| 			border-radius 0 | ||||
| @@ -280,7 +274,7 @@ root(isDark, fill) | ||||
| 			top 0 | ||||
| 			font-size 16px | ||||
| 			line-height fill ? 44px : 32px | ||||
| 			color isDark ? rgba(#fff, 0.7) : rgba(#000, 0.54) | ||||
| 			color var(--inputLabel) | ||||
| 			pointer-events none | ||||
|  | ||||
| 			&:empty | ||||
| @@ -325,7 +319,7 @@ root(isDark, fill) | ||||
| 					transform scaleX(1) | ||||
|  | ||||
| 			> .label | ||||
| 				color $theme-color | ||||
| 				color var(--primary) | ||||
|  | ||||
| 	&.focused | ||||
| 	&.filled | ||||
| @@ -335,16 +329,10 @@ root(isDark, fill) | ||||
| 				left 0 !important | ||||
| 				transform scale(0.75) | ||||
|  | ||||
| .ui-input[data-darkmode] | ||||
| .ui-input | ||||
| 	&.fill | ||||
| 		root(true, true) | ||||
| 		root(true) | ||||
| 	&:not(.fill) | ||||
| 		root(true, false) | ||||
|  | ||||
| .ui-input:not([data-darkmode]) | ||||
| 	&.fill | ||||
| 		root(false, true) | ||||
| 	&:not(.fill) | ||||
| 		root(false, false) | ||||
| 		root(false) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -51,11 +51,9 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
| .ui-radio | ||||
| 	display inline-block | ||||
| 	margin 32px 32px 32px 0 | ||||
| 	margin 0 32px 0 0 | ||||
| 	cursor pointer | ||||
| 	transition all 0.3s | ||||
|  | ||||
| @@ -68,10 +66,10 @@ root(isDark) | ||||
|  | ||||
| 	&.checked | ||||
| 		> .button | ||||
| 			border-color $theme-color | ||||
| 			border-color var(--primary) | ||||
|  | ||||
| 			&:after | ||||
| 				background-color $theme-color | ||||
| 				background-color var(--primary) | ||||
| 				transform scale(1) | ||||
| 				opacity 1 | ||||
|  | ||||
| @@ -87,7 +85,7 @@ root(isDark) | ||||
| 		width 20px | ||||
| 		height 20px | ||||
| 		background none | ||||
| 		border solid 2px isDark ? rgba(#fff, 0.7) : rgba(#000, 0.54) | ||||
| 		border solid 2px var(--inputLabel) | ||||
| 		border-radius 100% | ||||
| 		transition inherit | ||||
|  | ||||
| @@ -111,10 +109,4 @@ root(isDark) | ||||
| 		line-height 20px | ||||
| 		cursor pointer | ||||
|  | ||||
| .ui-radio[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .ui-radio:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -29,13 +29,17 @@ export default Vue.extend({ | ||||
| 		required: { | ||||
| 			type: Boolean, | ||||
| 			required: false | ||||
| 		}, | ||||
| 		styl: { | ||||
| 			type: String, | ||||
| 			required: false, | ||||
| 			default: 'line' | ||||
| 		} | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| 			v: this.value, | ||||
| 			focused: false, | ||||
| 			styl: 'fill' | ||||
| 			focused: false | ||||
| 		}; | ||||
| 	}, | ||||
| 	computed: { | ||||
| @@ -48,14 +52,6 @@ export default Vue.extend({ | ||||
| 			this.v = v; | ||||
| 		} | ||||
| 	}, | ||||
| 	inject: { | ||||
| 		isCardChild: { default: false } | ||||
| 	}, | ||||
| 	created() { | ||||
| 		if (this.isCardChild) { | ||||
| 			this.styl = 'line'; | ||||
| 		} | ||||
| 	}, | ||||
| 	mounted() { | ||||
| 		if (this.$refs.prefix) { | ||||
| 			this.$refs.label.style.left = (this.$refs.prefix.offsetLeft + this.$refs.prefix.offsetWidth) + 'px'; | ||||
| @@ -70,9 +66,7 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark, fill) | ||||
| root(fill) | ||||
| 	margin 32px 0 | ||||
|  | ||||
| 	> .icon | ||||
| @@ -103,7 +97,7 @@ root(isDark, fill) | ||||
| 				left 0 | ||||
| 				right 0 | ||||
| 				height 1px | ||||
| 				background isDark ? rgba(#fff, 0.7) : rgba(#000, 0.42) | ||||
| 				background var(--inputBorder) | ||||
|  | ||||
| 			&:after | ||||
| 				content '' | ||||
| @@ -113,7 +107,7 @@ root(isDark, fill) | ||||
| 				left 0 | ||||
| 				right 0 | ||||
| 				height 2px | ||||
| 				background $theme-color | ||||
| 				background var(--primary) | ||||
| 				opacity 0 | ||||
| 				transform scaleX(0.12) | ||||
| 				transition border 0.3s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1), transform 0.3s cubic-bezier(0.4, 0, 0.2, 1) | ||||
| @@ -143,7 +137,7 @@ root(isDark, fill) | ||||
| 			font-weight fill ? bold : normal | ||||
| 			font-size 16px | ||||
| 			height 32px | ||||
| 			color isDark ? #fff : #000 | ||||
| 			color var(--inputText) | ||||
| 			background transparent | ||||
| 			border none | ||||
| 			border-radius 0 | ||||
| @@ -190,7 +184,7 @@ root(isDark, fill) | ||||
| 					transform scaleX(1) | ||||
|  | ||||
| 			> .label | ||||
| 				color $theme-color | ||||
| 				color var(--primary) | ||||
|  | ||||
| 	&.focused | ||||
| 	&.filled | ||||
| @@ -200,16 +194,10 @@ root(isDark, fill) | ||||
| 				left 0 !important | ||||
| 				transform scale(0.75) | ||||
|  | ||||
| .ui-select[data-darkmode] | ||||
| .ui-select | ||||
| 	&.fill | ||||
| 		root(true, true) | ||||
| 		root(true) | ||||
| 	&:not(.fill) | ||||
| 		root(true, false) | ||||
|  | ||||
| .ui-select:not([data-darkmode]) | ||||
| 	&.fill | ||||
| 		root(false, true) | ||||
| 	&:not(.fill) | ||||
| 		root(false, false) | ||||
| 		root(false) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -19,7 +19,7 @@ | ||||
| 	<span class="label"> | ||||
| 		<span :aria-hidden="!checked"><slot></slot></span> | ||||
| 		<p :aria-hidden="!checked"> | ||||
| 			<slot name="text"></slot> | ||||
| 			<slot name="desc"></slot> | ||||
| 		</p> | ||||
| 	</span> | ||||
| </div> | ||||
| @@ -56,14 +56,18 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
| .ui-switch | ||||
| 	display flex | ||||
| 	margin 32px 0 | ||||
| 	cursor pointer | ||||
| 	transition all 0.3s | ||||
|  | ||||
| 	&:first-child | ||||
| 		margin-top 0 | ||||
|  | ||||
| 	&:last-child | ||||
| 		margin-bottom 0 | ||||
|  | ||||
| 	> * | ||||
| 		user-select none | ||||
|  | ||||
| @@ -73,11 +77,11 @@ root(isDark) | ||||
|  | ||||
| 	&.checked | ||||
| 		> .button | ||||
| 			background-color rgba($theme-color, 0.4) | ||||
| 			border-color rgba($theme-color, 0.4) | ||||
| 			background-color var(--primaryAlpha04) | ||||
| 			border-color var(--primaryAlpha04) | ||||
|  | ||||
| 			> * | ||||
| 				background-color $theme-color | ||||
| 				background-color var(--primary) | ||||
| 				transform translateX(14px) | ||||
|  | ||||
| 	> input | ||||
| @@ -89,10 +93,11 @@ root(isDark) | ||||
|  | ||||
| 	> .button | ||||
| 		display inline-block | ||||
| 		flex-shrink 0 | ||||
| 		margin 3px 0 0 0 | ||||
| 		width 34px | ||||
| 		height 14px | ||||
| 		background isDark ? rgba(#fff, 0.15) : rgba(#000, 0.25) | ||||
| 		background var(--switchTrack) | ||||
| 		outline none | ||||
| 		border-radius 14px | ||||
| 		transition inherit | ||||
| @@ -118,18 +123,11 @@ root(isDark) | ||||
| 		> span | ||||
| 			display block | ||||
| 			line-height 20px | ||||
| 			color isDark ? #c4ccd2 : rgba(#000, 0.75) | ||||
| 			color currentColor | ||||
| 			transition inherit | ||||
|  | ||||
| 		> p | ||||
| 			margin 0 | ||||
| 			//font-size 90% | ||||
| 			color isDark ? #78858e : #9daab3 | ||||
|  | ||||
| .ui-switch[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .ui-switch:not([data-darkmode]) | ||||
| 	root(false) | ||||
| 			opacity 0.7 | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -63,9 +63,7 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark, fill) | ||||
| root(fill) | ||||
| 	margin 42px 0 32px 0 | ||||
|  | ||||
| 	> .input | ||||
| @@ -84,7 +82,7 @@ root(isDark, fill) | ||||
| 				left 0 | ||||
| 				right 0 | ||||
| 				background none | ||||
| 				border solid 1px isDark ? rgba(#fff, 0.7) : rgba(#000, 0.42) | ||||
| 				border solid 1px var(--inputBorder) | ||||
| 				border-radius 3px | ||||
| 				pointer-events none | ||||
|  | ||||
| @@ -97,7 +95,7 @@ root(isDark, fill) | ||||
| 				left 0 | ||||
| 				right 0 | ||||
| 				background none | ||||
| 				border solid 2px $theme-color | ||||
| 				border solid 2px var(--primary) | ||||
| 				border-radius 3px | ||||
| 				opacity 0 | ||||
| 				transition opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1) | ||||
| @@ -112,7 +110,7 @@ root(isDark, fill) | ||||
| 			transition-duration 0.3s | ||||
| 			font-size 16px | ||||
| 			line-height 32px | ||||
| 			color isDark ? rgba(#fff, 0.7) : rgba(#000, 0.54) | ||||
| 			color var(--inputLabel) | ||||
| 			pointer-events none | ||||
| 			//will-change transform | ||||
| 			transform-origin top left | ||||
| @@ -126,7 +124,7 @@ root(isDark, fill) | ||||
| 			font inherit | ||||
| 			font-weight fill ? bold : normal | ||||
| 			font-size 16px | ||||
| 			color isDark ? #fff : #000 | ||||
| 			color var(--inputText) | ||||
| 			background transparent | ||||
| 			border none | ||||
| 			border-radius 0 | ||||
| @@ -149,7 +147,7 @@ root(isDark, fill) | ||||
| 					opacity 1 | ||||
|  | ||||
| 			> .label | ||||
| 				color $theme-color | ||||
| 				color var(--primary) | ||||
|  | ||||
| 	&.focused | ||||
| 	&.filled | ||||
| @@ -159,16 +157,10 @@ root(isDark, fill) | ||||
| 				left 0 !important | ||||
| 				transform scale(0.75) | ||||
|  | ||||
| .ui-textarea[data-darkmode] | ||||
| 	&.fill | ||||
| 		root(true, true) | ||||
| 	&:not(.fill) | ||||
| 		root(true, false) | ||||
| .ui-textarea.fill | ||||
| 	root(true) | ||||
|  | ||||
| .ui-textarea:not([data-darkmode]) | ||||
| 	&.fill | ||||
| 		root(false, true) | ||||
| 	&:not(.fill) | ||||
| 		root(false, false) | ||||
| .ui-textarea:not(.fill) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -81,7 +81,7 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
|  | ||||
| .mk-uploader | ||||
| 	overflow auto | ||||
| @@ -100,7 +100,7 @@ export default Vue.extend({ | ||||
| 			margin 8px 0 0 0 | ||||
| 			padding 0 | ||||
| 			height 36px | ||||
| 			box-shadow 0 -1px 0 rgba($theme-color, 0.1) | ||||
| 			box-shadow 0 -1px 0 var(--primaryAlpha01) | ||||
| 			border-top solid 8px transparent | ||||
|  | ||||
| 			&:first-child | ||||
| @@ -127,7 +127,7 @@ export default Vue.extend({ | ||||
| 				padding 0 | ||||
| 				max-width 256px | ||||
| 				font-size 0.8em | ||||
| 				color rgba($theme-color, 0.7) | ||||
| 				color var(--primaryAlpha07) | ||||
| 				white-space nowrap | ||||
| 				text-overflow ellipsis | ||||
| 				overflow hidden | ||||
| @@ -145,17 +145,17 @@ export default Vue.extend({ | ||||
| 				font-size 0.8em | ||||
|  | ||||
| 				> .initing | ||||
| 					color rgba($theme-color, 0.5) | ||||
| 					color var(--primaryAlpha05) | ||||
|  | ||||
| 				> .kb | ||||
| 					color rgba($theme-color, 0.5) | ||||
| 					color var(--primaryAlpha05) | ||||
|  | ||||
| 				> .percentage | ||||
| 					display inline-block | ||||
| 					width 48px | ||||
| 					text-align right | ||||
|  | ||||
| 					color rgba($theme-color, 0.7) | ||||
| 					color var(--primaryAlpha07) | ||||
|  | ||||
| 					&:after | ||||
| 						content '%' | ||||
| @@ -174,10 +174,10 @@ export default Vue.extend({ | ||||
| 				overflow hidden | ||||
|  | ||||
| 				&::-webkit-progress-value | ||||
| 					background $theme-color | ||||
| 					background var(--primary) | ||||
|  | ||||
| 				&::-webkit-progress-bar | ||||
| 					background rgba($theme-color, 0.1) | ||||
| 					background var(--primaryAlpha01) | ||||
|  | ||||
| 			> .progress | ||||
| 				display block | ||||
| @@ -191,13 +191,13 @@ export default Vue.extend({ | ||||
| 				border-radius 4px | ||||
| 				background linear-gradient( | ||||
| 					45deg, | ||||
| 					lighten($theme-color, 30%) 25%, | ||||
| 					$theme-color               25%, | ||||
| 					$theme-color               50%, | ||||
| 					lighten($theme-color, 30%) 50%, | ||||
| 					lighten($theme-color, 30%) 75%, | ||||
| 					$theme-color               75%, | ||||
| 					$theme-color | ||||
| 					var(--primaryLighten30) 25%, | ||||
| 					var(--primary)               25%, | ||||
| 					var(--primary)               50%, | ||||
| 					var(--primaryLighten30) 50%, | ||||
| 					var(--primaryLighten30) 75%, | ||||
| 					var(--primary)               75%, | ||||
| 					var(--primary) | ||||
| 				) | ||||
| 				background-size 32px 32px | ||||
| 				animation bg 1.5s linear infinite | ||||
|   | ||||
| @@ -8,13 +8,13 @@ | ||||
| 	</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> | ||||
| @@ -118,6 +118,12 @@ export default Vue.extend({ | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		}, | ||||
|  | ||||
| 		mini: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| @@ -164,7 +170,7 @@ 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) return; | ||||
| 				this.title = info.title; | ||||
| @@ -194,17 +200,17 @@ export default Vue.extend({ | ||||
| 		top 0 | ||||
| 		width 100% | ||||
|  | ||||
| root(isDark) | ||||
| .mk-url-preview | ||||
| 	> a | ||||
| 		display block | ||||
| 		font-size 14px | ||||
| 		border solid 1px isDark ? #191b1f : #eee | ||||
| 		border solid 1px var(--urlPreviewBorder) | ||||
| 		border-radius 4px | ||||
| 		overflow hidden | ||||
|  | ||||
| 		&:hover | ||||
| 			text-decoration none | ||||
| 			border-color isDark ? #4f5561 : #ddd | ||||
| 			border-color var(--urlPreviewBorderHover) | ||||
|  | ||||
| 			> article > header > h1 | ||||
| 				text-decoration underline | ||||
| @@ -229,11 +235,11 @@ root(isDark) | ||||
| 				> h1 | ||||
| 					margin 0 | ||||
| 					font-size 1em | ||||
| 					color isDark ? #d6dae0 : #555 | ||||
| 					color var(--urlPreviewTitle) | ||||
|  | ||||
| 			> p | ||||
| 				margin 0 | ||||
| 				color isDark ? #a4aab3 : #777 | ||||
| 				color var(--urlPreviewText) | ||||
| 				font-size 0.8em | ||||
|  | ||||
| 			> footer | ||||
| @@ -250,7 +256,7 @@ root(isDark) | ||||
| 				> p | ||||
| 					display inline-block | ||||
| 					margin 0 | ||||
| 					color isDark ? #b0b4bf : #666 | ||||
| 					color var(--urlPreviewInfo) | ||||
| 					font-size 0.8em | ||||
| 					line-height 16px | ||||
| 					vertical-align top | ||||
| @@ -293,10 +299,27 @@ root(isDark) | ||||
| 						width 12px | ||||
| 						height 12px | ||||
|  | ||||
| .mk-url-preview[data-darkmode] | ||||
| 	root(true) | ||||
| 		&.mini | ||||
| 			font-size 10px | ||||
|  | ||||
| .mk-url-preview:not([data-darkmode]) | ||||
| 	root(false) | ||||
| 			> .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 | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -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> | ||||
|   | ||||
| @@ -47,7 +47,7 @@ export default Vue.extend({ | ||||
| 	props: ['source', 'compact'], | ||||
| 	data() { | ||||
| 		return { | ||||
| 			v: this.$store.state.device.visibility || 'public' | ||||
| 			v: this.$store.state.settings.rememberNoteVisibility ? (this.$store.state.device.visibility || this.$store.state.settings.defaultNoteVisibility) : this.$store.state.settings.defaultNoteVisibility | ||||
| 		} | ||||
| 	}, | ||||
| 	mounted() { | ||||
| @@ -97,9 +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'; | ||||
| @@ -117,7 +119,7 @@ export default Vue.extend({ | ||||
| 				scale: 0.5, | ||||
| 				duration: 200, | ||||
| 				easing: 'easeInBack', | ||||
| 				complete: () => this.$destroy() | ||||
| 				complete: () => this.destroyDom() | ||||
| 			}); | ||||
| 		} | ||||
| 	} | ||||
| @@ -125,11 +127,9 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| $border-color = rgba(27, 31, 35, 0.15) | ||||
|  | ||||
| root(isDark) | ||||
| .mk-visibility-chooser | ||||
| 	position initial | ||||
|  | ||||
| 	> .backdrop | ||||
| @@ -139,11 +139,11 @@ root(isDark) | ||||
| 		z-index 10000 | ||||
| 		width 100% | ||||
| 		height 100% | ||||
| 		background isDark ? rgba(#000, 0.4) : rgba(#000, 0.1) | ||||
| 		background var(--modalBackdrop) | ||||
| 		opacity 0 | ||||
|  | ||||
| 	> .popover | ||||
| 		$bgcolor = isDark ? #2c303c : #fff | ||||
| 		$bgcolor = var(--popupBg) | ||||
| 		position absolute | ||||
| 		z-index 10001 | ||||
| 		width 240px | ||||
| @@ -187,18 +187,18 @@ root(isDark) | ||||
| 			display flex | ||||
| 			padding 8px 14px | ||||
| 			font-size 12px | ||||
| 			color isDark ? #fff : #666 | ||||
| 			color var(--popupFg) | ||||
| 			cursor pointer | ||||
|  | ||||
| 			&:hover | ||||
| 				background isDark ? #252731 : #eee | ||||
| 				background var(--faceClearButtonHover) | ||||
|  | ||||
| 			&:active | ||||
| 				background isDark ? #21242b : #ddd | ||||
| 				background var(--faceClearButtonActive) | ||||
|  | ||||
| 			&.active | ||||
| 				color $theme-color-foreground | ||||
| 				background $theme-color | ||||
| 				color var(--primaryForeground) | ||||
| 				background var(--primary) | ||||
|  | ||||
| 			> * | ||||
| 				user-select none | ||||
| @@ -220,11 +220,4 @@ root(isDark) | ||||
|  | ||||
| 				> span:last-child:not(:first-child) | ||||
| 					opacity 0.6 | ||||
|  | ||||
| .mk-visibility-chooser[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .mk-visibility-chooser:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user