Compare commits
	
		
			864 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 845be966a0 | ||
|   | 80818d79eb | ||
|   | cb9b3c00dd | ||
|   | dbb7c756cd | ||
|   | 13f381710c | ||
|   | 70897c0e9a | ||
|   | f51d1c5264 | ||
|   | 70d0937aab | ||
|   | 7d1ab6102f | ||
|   | 77ddd778be | ||
|   | 890ecb693f | ||
|   | 209fe7dcaf | ||
|   | e0d6f7c7c4 | ||
|   | 5d3fe9599b | ||
|   | 0fe0b6d254 | ||
|   | b794216eaf | ||
|   | 1fccde38f6 | ||
|   | 41bd436d3e | ||
|   | c66155ed48 | ||
|   | 627bd410fa | ||
|   | 41a3932c6b | ||
|   | 785b8d7846 | ||
|   | 622c8f9598 | ||
|   | ef978a6364 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | d95fbe1c6b | ||
|   | d4ffddc2ab | ||
|   | 3d497cedfc | ||
|   | e8de29ae79 | ||
|   | b622946844 | ||
|   | d013f78cc7 | ||
|   | 2afbafdb3b | ||
|   | 67148114a8 | ||
|   | 7903140ec2 | ||
|   | cefd296200 | ||
|   | 99d1c15851 | ||
|   | a3107ab26f | ||
|   | 854cfae75b | ||
|   | 36ab82957d | ||
|   | de9f54386c | ||
|   | 7f43820765 | ||
|   | 955e907e7f | ||
|   | 4c18022e7d | ||
|   | 509f59e46d | ||
|   | f14c372f5e | ||
|   | f028800a96 | ||
|   | 8a1ce7a4f3 | ||
|   | ea7a139ae0 | ||
|   | 63959eb3da | ||
|   | a6adbc4e56 | ||
|   | b418cb67ba | ||
|   | 0ccc360c0a | ||
|   | 1e0dda3c40 | ||
|   | 9197793bc8 | ||
|   | 29f62241bc | ||
|   | 8de1e91dec | ||
|   | de822a22d4 | ||
|   | f2cef456bd | ||
|   | 5d681d0fd6 | ||
|   | 2ed24ebd75 | ||
|   | 6e6824ecb0 | ||
|   | 0504a4f659 | ||
|   | 9a261755d2 | ||
|   | 8533663b26 | ||
|   | 0a4015b8a2 | ||
|   | dcfe56322e | ||
|   | d00a693026 | ||
|   | fb36ecad70 | ||
|   | 26c39768ca | ||
|   | df8abcfce8 | ||
|   | e3aab0e9e3 | ||
|   | e3dfc49ed0 | ||
|   | 8485284f63 | ||
|   | e549e19c03 | ||
|   | 2ace47cbb9 | ||
|   | dc184e7bc9 | ||
|   | aef1bd094b | ||
|   | 4f8b22f53b | ||
|   | 0f3cbafe91 | ||
|   | 16ad232c40 | ||
|   | 4d235a2be5 | ||
|   | aadf6fa9b1 | ||
|   | a72e9bc8b2 | ||
|   | f11ef93a81 | ||
|   | 9136556218 | ||
|   | 3ead008295 | ||
|   | 9ff5693442 | ||
|   | ac84b42394 | ||
|   | a79361c71f | ||
|   | 85e17d5dc7 | ||
|   | 45493fd093 | ||
|   | 6f987a2391 | ||
|   | ddf785a393 | ||
|   | b8e20fe717 | ||
|   | 82555bf9b6 | ||
|   | ffe6f6c168 | ||
|   | 6b11f5bb7d | ||
|   | 1a65d14864 | ||
|   | 6c1f1ffdb1 | ||
|   | 61cdbd5dd2 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | e7e321e2b3 | ||
|   | fb5f6fdc10 | ||
|   | 00290fbf75 | ||
|   | ff02dc723b | ||
|   | 67521c0d2a | ||
|   | da8765150b | ||
|   | ea7f51bc12 | ||
|   | 1b34b3b7e2 | ||
|   | bca4ceb7ae | ||
|   | 5648cd53d0 | ||
|   | 8dab37539f | ||
|   | 2dd42c0061 | ||
|   | dfafed504a | ||
|   | 9fcd2bcb0a | ||
|   | 4c701b91a6 | ||
|   | 84f7aa6d09 | ||
|   | 82f0c64dee | ||
|   | 4b7c6b124b | ||
|   | e043b678d4 | ||
|   | fef4f7fce8 | ||
|   | 9732b3521a | ||
|   | a59fcc4aec | ||
|   | 979e1e78fb | ||
|   | c1a929022f | ||
|   | 611bb81032 | ||
|   | 5047020e6d | ||
|   | fb74a6a689 | ||
|   | a14a216c8d | ||
|   | 549e212a59 | ||
|   | 1bdc91ad47 | ||
|   | 67f288479c | ||
|   | 496e45c2bb | ||
|   | e458bd3cc7 | ||
|   | 031911c463 | ||
|   | 4aa7f638f9 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | f6f4ea69ae | ||
|   | ef945597f2 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 3ab4e1d368 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | c6216f5b5f | ||
|   | 4f24d58a79 | ||
|   | 73d6e7ba66 | ||
|   | 949707e18e | ||
|   | f51b299c17 | ||
|   | d2e0faa533 | ||
|   | 22015044a5 | ||
|   | 61f86dcb2b | ||
|   | 8f3bce6b11 | ||
|   | ee736e73a9 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 99f867897e | ||
|   | c66c5b6e75 | ||
|   | f25ecc19b9 | ||
|   | 48e09970f3 | ||
|   | f05cb79604 | ||
|   | 46d3293edd | ||
|   | 9703d613cf | ||
|   | 704e217dbb | ||
|   | a103032d94 | ||
|   | c7207a4bd7 | ||
|   | 35c65fe589 | ||
|   | 6d5bd0c484 | ||
|   | cfbb6e8092 | ||
|   | feef4a933e | ||
|   | 468bc67569 | ||
|   | 0d517fa52f | ||
|   | d9054367c1 | ||
|   | 1213373027 | ||
|   | 100a525507 | ||
|   | 1bec4e2d12 | ||
|   | 03cd1d27bf | ||
|   | 9427a756c9 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | d32b2a8ce5 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 15473b4368 | ||
|   | 54de0dc4a7 | ||
|   | 0162eaf826 | ||
|   | 572cfafbe1 | ||
|   | 4d6335ce9a | ||
|   | 1c9c4af9f1 | ||
|   | a6844ebc9d | ||
|   | 072492c29b | ||
|   | 99da4f9839 | ||
|   | 88664486af | ||
|   | 80daf7c749 | ||
|   | 92ba64c35c | ||
|   | a8ee51ffd6 | ||
|   | 5538afc61d | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | beb2f7e558 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 6243184c95 | ||
|   | 1b3baef966 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 98f38ee29b | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 09b82bfea4 | ||
|   | 937f686264 | ||
|   | 9bc9cbac21 | ||
|   | 6024550158 | ||
|   | 4ae5f82171 | ||
|   | 6d2c9dcee9 | ||
|   | 0f1b0e1870 | ||
|   | 81c682cdc8 | ||
|   | ab9fa67d9f | ||
|   | 9537fce335 | ||
|   | 9d97e7e348 | ||
|   | ebe7939412 | ||
|   | 807e3e8ca7 | ||
|   | a59faf9117 | ||
|   | d786036155 | ||
|   | 61d6ed5489 | ||
|   | b38200d48a | ||
|   | a0c396a842 | ||
|   | 88fbc53e37 | ||
|   | a2206b2d52 | ||
|   | a95ff447d7 | ||
|   | 49dbd7f9d2 | ||
|   | 2ad2779096 | ||
|   | 23045369aa | ||
|   | 116faf26e6 | ||
|   | 2582b8d132 | ||
|   | 63f7941073 | ||
|   | 676f026085 | ||
|   | a13319fd86 | ||
|   | be8765278c | ||
|   | c8bb3dc209 | ||
|   | ea16befb73 | ||
|   | 20b1bb7681 | ||
|   | bd10eb50eb | ||
|   | d47c0eb31a | ||
|   | 177e8bb19f | ||
|   | d156111637 | ||
|   | 8c13d3e50b | ||
|   | 6ff01016f0 | ||
|   | 5d659da012 | ||
|   | 28e7552a1a | ||
|   | 53d264814b | ||
|   | 2d6b20d34b | ||
|   | 99073b56df | ||
|   | 5dce81c0db | ||
|   | be82d845a4 | ||
|   | f49ccd0cd3 | ||
|   | 69d83f535d | ||
|   | c7988fb6f5 | ||
|   | 3961fd08c9 | ||
|   | e3faf64061 | ||
|   | ed83993e15 | ||
|   | 0f8847bb74 | ||
|   | a72cfa7535 | ||
|   | 514b74a19d | ||
|   | a2c124306f | ||
|   | 273f67e268 | ||
|   | 2870a7e463 | ||
|   | 935b074a7a | ||
|   | 9d9c609bfb | ||
|   | f6a664f181 | ||
|   | fce68d1f75 | ||
|   | 88739c2444 | ||
|   | 7e2f10fce3 | ||
|   | a494c3a5cc | ||
|   | d6bb702883 | ||
|   | d15a972c68 | ||
|   | 2ae7d31725 | ||
|   | 2e329b1888 | ||
|   | 522d40328b | ||
|   | 2ecbff45bf | ||
|   | b6f7282c13 | ||
|   | 65e5cfa68e | ||
|   | 10e59957d1 | ||
|   | 4f74373df3 | ||
|   | 2d414bbf86 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | a199969b81 | ||
|   | 3aef5e6748 | ||
|   | 2b536a7443 | ||
|   | 20fe68de05 | ||
|   | c7684b59de | ||
|   | a7237d157a | ||
|   | 35f91fa280 | ||
|   | 299ac32225 | ||
|   | a038738d72 | ||
|   | 2b0a919fb5 | ||
|   | 946c706913 | ||
|   | 89b5d976ee | ||
|   | 6f679bb6b4 | ||
|   | db4e7b0e16 | ||
|   | 9ca942490d | ||
|   | ebcf249c8b | ||
|   | 939c487503 | ||
|   | 981a8b267e | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 9531da80a0 | ||
|   | e1109b168c | ||
|   | b7c70039aa | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 17b6f6cf2a | ||
|   | dd88483ba4 | ||
|   | 0ff27f65b3 | ||
|   | b1655740df | ||
|   | 6d562aece1 | ||
|   | 2182c3372b | ||
|   | d3331bfe82 | ||
|   | cfc4a2e8b4 | ||
|   | 36c41c8eb3 | ||
|   | d255157e6e | ||
|   | c12e07277d | ||
|   | 06b4fb5095 | ||
|   | 8fafdcb428 | ||
|   | 537a606bb6 | ||
|   | 3dc7a4463c | ||
|   | fd6ff05b60 | ||
|   | 1a159e41b8 | ||
|   | 23533cdd16 | ||
|   | 2f598b8fa1 | ||
|   | bca349fec1 | ||
|   | 719fac6480 | ||
|   | 1012b2b2c7 | ||
|   | 5149be4b1b | ||
|   | d12deeb0d8 | ||
|   | 9df81d1939 | ||
|   | 3be0079868 | ||
|   | 9b253ccb3a | ||
|   | dded76099c | ||
|   | 41a7ec7d3d | ||
|   | 168c773ba0 | ||
|   | 9abed92196 | ||
|   | 4a75e3602a | ||
|   | 1a689f6641 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 08d7ae11d6 | ||
|   | 9535759787 | ||
|   | f8fc31f14a | ||
|   | b74bf97761 | ||
|   | a090b908bd | ||
|   | 3046821026 | ||
|   | e94c73efe2 | ||
|   | e85f9f4aa5 | ||
|   | ad67886f96 | ||
|   | 5df0e102fd | ||
|   | a04f0e3545 | ||
|   | dff9c7ac48 | ||
|   | 3a80b59986 | ||
|   | 07560a4fdd | ||
|   | 7edca21c05 | ||
|   | 34105abd9d | ||
|   | 1bbca48a0b | ||
|   | 21f6a86772 | ||
|   | 6559197c55 | ||
|   | 05f9ad11bb | ||
|   | f06d586680 | ||
|   | 4f45e8125c | ||
|   | cc2843503d | ||
|   | 324a974dec | ||
|   | 4d4ffd70ac | ||
|   | bf98a11b65 | ||
|   | 1117ce4b54 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 57e93b9b4e | ||
|   | 9e4b061ed0 | ||
|   | 1067bef7d6 | ||
|   | 8bff529acd | ||
|   | 4b08677839 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 70997cb551 | ||
|   | bf0ef17e23 | ||
|   | 7dae5107f8 | ||
|   | 2dea88a147 | ||
|   | f44c2a3e4f | ||
|   | 1fad3cbaae | ||
|   | 40d2e3e97c | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 2efabe612e | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 3107cbd6b9 | ||
|   | 3a061ed1c3 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | d4f0e6461a | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 3285687652 | ||
|   | 51c53f64d0 | ||
|   | 1d582f5ad2 | ||
|   | 8a62748e39 | ||
|   | b9290a021b | ||
|   | 129ce93868 | ||
|   | 5f41e5d6d0 | ||
|   | c706d030ea | ||
|   | 34716a34f8 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 6db3d6dfb6 | ||
|   | 38e2853dcf | ||
|   | ba5a540ca3 | ||
|   | fb1e05c2e9 | ||
|   | aba84612a7 | ||
|   | 9bebbf4e03 | ||
|   | e41b3f9c10 | ||
|   | 890dc05022 | ||
|   | 375f86ec82 | ||
|   | db248a69c8 | ||
|   | 5951288159 | ||
|   | 17b92c9db2 | ||
|   | 962d1060d9 | ||
|   | cb2640d961 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 29aeb0f082 | ||
|   | 990347f856 | ||
|   | 7a406c1f13 | ||
|   | 9432af2ab5 | ||
|   | 136b13e7ca | ||
|   | ba1c823fb1 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | f1301a4780 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 7957cd4963 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | ee6590d03f | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | f2a1238b20 | ||
|   | e9ce84f368 | ||
|   | 52e84decb4 | ||
|   | e893002bb6 | ||
|   | 3792103e80 | ||
|   | 7a861c9481 | ||
|   | 942b565224 | ||
|   | 88390d7a9a | ||
|   | 966fc4c5d7 | ||
|   | 84dbdf1196 | ||
|   | 211e7f90d9 | ||
|   | e54b8e3fb2 | ||
|   | 836c89ed33 | ||
|   | c7c73afea1 | ||
|   | 7b9ca63b1e | ||
|   | c464183329 | ||
|   | 389f420cad | ||
|   | 6b2888383c | ||
|   | 3c38a867b4 | ||
|   | 7f5a69f4d8 | ||
|   | bb9ab31d5e | ||
|   | 9def80af8a | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 9256bcdbe4 | ||
|   | 9b775022bc | ||
|   | 32371ed2bd | ||
|   | 8b98c08a81 | ||
|   | 7cf72f7447 | ||
|   | 913385b10d | ||
|   | 7306468d08 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 11e5667778 | ||
|   | 38cc02e261 | ||
|   | d52cf46cc1 | ||
|   | c6110dd996 | ||
|   | 51d8de2c38 | ||
|   | 4455a1aa9d | ||
|   | 040d395ddb | ||
|   | 8296cac636 | ||
|   | 3eafe8b87d | ||
|   | c01512e261 | ||
|   | e5cf3aecd5 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | a8f90b41b7 | ||
|   | b79169b975 | ||
|   | 437d52e2ed | ||
|   | 1329721440 | ||
|   | 6affb4fe97 | ||
|   | 15395686aa | ||
|   | 047bcc78ad | ||
|   | 9df68618f2 | ||
|   | 732db087ab | ||
|   | 0e95b33b6a | ||
|   | 816ae7eb7e | ||
|   | 5a5ff194fa | ||
|   | a60edf9cff | ||
|   | 1c2dbb914e | ||
|   | 9c170c426b | ||
|   | c6239c8ad9 | ||
|   | 159b361bac | ||
|   | 160f64c18e | ||
|   | e5916b3789 | ||
|   | 70982b33c5 | ||
|   | b4d614ad45 | ||
|   | 6d2ef41b37 | ||
|   | e102237aab | ||
|   | 665af87031 | ||
|   | 6f4e439697 | ||
|   | 742dcf35c9 | ||
|   | 9cd70c568c | ||
|   | facabf274f | ||
|   | e3ab51022f | ||
|   | d278367cf9 | ||
|   | a70ced8e90 | ||
|   | 567cedc7cc | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 9b3af6efcd | ||
|   | d9edc1eb1d | ||
|   | 65e46b5cec | ||
|   | e00b5f11cb | ||
|   | 6b53d5f269 | ||
|   | 59c80ab140 | ||
|   | da323aad36 | ||
|   | 7c1611c939 | ||
|   | ab861beabe | ||
|   | d260e93161 | ||
|   | 65a1855606 | ||
|   | c0e08e44a4 | ||
|   | 5c1cebcef4 | ||
|   | af25d3a85e | ||
|   | 8cb7183107 | ||
|   | 1bf228d73e | ||
|   | d952b996e6 | ||
|   | 1e407c4059 | ||
|   | b56d1fa60e | ||
|   | 6340f95bfc | ||
|   | 3c08dacf6c | ||
|   | 2908124ad8 | ||
|   | 3d62faaaf2 | ||
|   | b1efa9700d | ||
|   | 1d08af5747 | ||
|   | 2f82d0db87 | ||
|   | d88159907d | ||
|   | 9ed9fbef65 | ||
|   | 86c2e5bb91 | ||
|   | d9b548de1a | ||
|   | 2271c6cbd8 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | c4d4293c46 | ||
|   | 39bdfb6e0d | ||
|   | 1003fd393e | ||
|   | 2ede3c0864 | ||
|   | 674764a035 | ||
|   | a780e7b936 | ||
|   | 03d0ce1f89 | ||
|   | 4182a0cf4c | ||
|   | 305915611e | ||
|   | b0cd59bed9 | ||
|   | 599dcbaa48 | ||
|   | 2806dc98bd | ||
|   | bdc52dc114 | ||
|   | 3f6b9e554c | ||
|   | f47ad7bf31 | ||
|   | f992f72d31 | ||
|   | a26f1db2cb | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 361ab00c61 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | f5cbcf3452 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 599386190a | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | ec541d3cd0 | ||
|   | 3199819ded | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | ccf04d63ec | ||
|   | b9f5fca333 | ||
|   | b6a330928d | ||
|   | 1c65cb3e36 | ||
|   | dbb8c99efb | ||
|   | 0adcb646fe | ||
|   | a1ef70c0bf | ||
|   | 75cd580c3a | ||
|   | e05acb8d18 | ||
|   | 10af684804 | ||
|   | 3e897727ca | ||
|   | d0570d7fe3 | ||
|   | 5cf1956135 | ||
|   | 0b98a2364b | ||
|   | fff307d4bb | ||
|   | 2b7782ba03 | ||
|   | 96d961ee80 | ||
|   | 9f064d76d9 | ||
|   | 2e39106c4b | ||
|   | 1305006391 | ||
|   | 04650464f3 | ||
|   | 3bc7e1e35c | ||
|   | 7019ddbfc7 | ||
|   | 106d990bd2 | ||
|   | b29eb29556 | ||
|   | aeac1854ed | ||
|   | dbc57dd0d3 | ||
|   | 328a87609e | ||
|   | 5d848f3900 | ||
|   | cf4ed45fe4 | ||
|   | 07293094d5 | ||
|   | 0917696c86 | ||
|   | 030a027366 | ||
|   | 372c488585 | ||
|   | 738b8ff1ee | ||
|   | 1561fc5994 | ||
|   | c84f18545e | ||
|   | 48e4dc75f4 | ||
|   | 63a8d556e5 | ||
|   | e5591618ee | ||
|   | 4794748c73 | ||
|   | 02e7e3b971 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | d2aca3c28b | ||
|   | 11b84a04b3 | ||
|   | f243ce66e7 | ||
|   | baf9b65801 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 55419d2524 | ||
|   | 401d0b1298 | ||
|   | fce7dc0f4e | ||
|   | 35489ef5b7 | ||
|   | 546d494587 | ||
|   | e8afa2c940 | ||
|   | c1ef1bf605 | ||
|   | 4ab0dbe7e3 | ||
|   | 44f86a94f4 | ||
|   | a0278154a3 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 8b7e6b200e | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | d6f6c26725 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | cf66343b31 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | d53689332f | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 4105237027 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 436962e4b8 | ||
|   | a85efa1392 | ||
|   | f0115a5e21 | ||
|   | 80105239dc | ||
|   | baad11288a | ||
|   | 7e50646ede | ||
|   | d4b8e47bcb | ||
|   | 0eefd2922c | ||
|   | 30c0f98691 | ||
|   | 06a7c2e138 | ||
|   | 3537b3de8e | ||
|   | ed6450244d | ||
|   | e813880392 | ||
|   | 9a57efa6d9 | ||
|   | 03ee5eba3b | ||
|   | 295ea79231 | ||
|   | a5486176c1 | ||
|   | de58325fd0 | ||
|   | 1e7932d9c7 | ||
|   | 8ba76df409 | ||
|   | a8f9d20229 | ||
|   | 5e6d1b9ae8 | ||
|   | c5afbaef35 | ||
|   | 3b5a36a09f | ||
|   | fcb20d05d7 | ||
|   | 9e6990c44b | ||
|   | 8f3fd9b0dc | ||
|   | 5b1b4a02d8 | ||
|   | 31de530497 | ||
|   | 16b6b1f2b3 | ||
|   | dba83aa50d | ||
|   | bade054a6a | ||
|   | 34d3485dc9 | ||
|   | a84d066daa | ||
|   | 3360cf27cd | ||
|   | c1a13af611 | ||
|   | 47274a658b | ||
|   | b194334031 | ||
|   | 4136c4a807 | ||
|   | f1c212fe75 | ||
|   | d08cbff4b7 | ||
|   | 0b774475fa | ||
|   | c4f6195df3 | ||
|   | 192cdbe322 | ||
|   | a2a25eb5f8 | ||
|   | 274cf1af1c | ||
|   | 7d11c8b767 | ||
|   | abef6bafe3 | ||
|   | da237a5e2d | ||
|   | 7e50e03cfb | ||
|   | 89d5df20a5 | ||
|   | c09a2a37fe | ||
|   | b5745877ca | ||
|   | c0ac15cad7 | ||
|   | 90ce09be2e | ||
|   | fd39afb374 | ||
|   | 6e04549a9b | ||
|   | 80e56fddd9 | ||
|   | 4daf9e1180 | ||
|   | f72abc0e47 | ||
|   | 9c177f3df2 | ||
|   | a279b32c93 | ||
|   | 51465ba026 | ||
|   | 6a7bdcc533 | ||
|   | fddb3a5f10 | ||
|   | 643c7abc12 | ||
|   | 5715afd44c | ||
|   | d65c1c420e | ||
|   | 38139ee6c9 | ||
|   | 6b96bd0185 | ||
|   | f2b9863eea | ||
|   | f56adce51f | ||
|   | 35598c8064 | ||
|   | a5e716eb5d | ||
|   | e8073b7484 | ||
|   | d6a5fc20bb | ||
|   | e763d43085 | ||
|   | a6904d5249 | ||
|   | 7bcb91d3ca | ||
|   | fb0c1efa41 | ||
|   | 03d243d444 | ||
|   | b91585d1fe | ||
|   | d1fa318cda | ||
|   | 42decae424 | ||
|   | 78bc7c20ed | ||
|   | e6616bdf57 | ||
|   | 35362ed3c7 | ||
|   | cd0b9a8e3f | ||
|   | 110aadd65c | ||
|   | cefe1f34be | ||
|   | d469e2152c | ||
|   | 35c2d47518 | ||
|   | c00634a2cf | ||
|   | d1835e262d | ||
|   | d0f304f0ce | ||
|   | 154abe06a7 | ||
|   | ac41cd378c | ||
|   | d59afda2c9 | ||
|   | 4d213833e2 | ||
|   | e9214d4330 | ||
|   | 6b41bb95b2 | ||
|   | 36de13d543 | ||
|   | 3893def9f4 | ||
|   | ff76c815b1 | ||
|   | 1b9b8912ae | ||
|   | b91b0d17c3 | ||
|   | 579b61a806 | ||
|   | 1e2b484929 | ||
|   | ab7d4fa2a2 | ||
|   | f30c8b8a47 | ||
|   | 25dd19dd8c | ||
|   | fdaebc6315 | ||
|   | f1a05c214e | ||
|   | 9ad32ffee9 | ||
|   | 70f83ab019 | ||
|   | 07e64631f2 | ||
|   | 498416e2e3 | ||
|   | 87c4f908fe | ||
|   | 27e6eaacde | ||
|   | ada47920ca | ||
|   | f2606d62ff | ||
|   | 35032152b3 | ||
|   | 90b545fd69 | ||
|   | 4f7776d1f9 | ||
|   | 03bd0c4c9e | ||
|   | 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 | ||
|   | 5734221c8f | ||
|   | b6e33e93de | ||
|   | 77b441f14c | ||
|   | 297019c22c | ||
|   | f5f2215b47 | ||
|   | 904114740b | ||
|   | d2d3f7810e | ||
|   | 2b07b3a873 | ||
|   | d17280b341 | ||
|   | f523d3f3bc | ||
|   | f6e4a1770e | ||
|   | 31006507c0 | ||
|   | 9ca6a6bf06 | ||
|   | afdacf14b7 | ||
|   | 5da18ba535 | ||
|   | e6cc937ac2 | ||
|   | 87091a2e03 | ||
|   | d23bc1e02a | ||
|   | 86fcd9208e | ||
|   | f2b97a889c | ||
|   | 97f91102fe | ||
|   | 07b04578c8 | ||
|   | 31f3c1996b | ||
|   | f4116e7300 | ||
|   | 5e5239c16e | ||
|   | 3adfcd1d13 | ||
|   | 3eb43a5413 | ||
|   | 80f41e2ac1 | ||
|   | 9e0b0b4210 | ||
|   | f3380d3184 | ||
|   | 54bc91ea2b | ||
|   | 59d67d3140 | ||
|   | 7b4c307c46 | ||
|   | 92484be87f | ||
|   | 56b8f8b07d | ||
|   | 722de35037 | ||
|   | d93f76c1af | ||
|   | cba0dd5e17 | ||
|   | 7bb25917f8 | ||
|   | a2e2d5ba77 | ||
|   | 61e05cb50e | ||
|   | 49e82adc6c | ||
|   | e4e668b327 | ||
|   | 8028c85c67 | ||
|   | 28cb9cae51 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 7f2eb64131 | ||
|   | c5ff6df7e6 | ||
|   | e2b2982f95 | ||
|   | a6e307010f | ||
|   | c636e35467 | ||
|   | 3d26bd0532 | ||
|   | 16130e46dd | ||
|   | 9f703085ba | ||
|   | 0af09f13cf | ||
|   | cd8619113a | ||
|   | 4bf6d9f80b | ||
|   | a559b2c20c | ||
|   | 72411abfcd | ||
|   | 491c3f1dc0 | ||
|   | d2ffc4df6c | ||
|   | 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 | 
| @@ -30,7 +30,7 @@ while : | |||||||
|   touch patreon.cache && \ |   touch patreon.cache && \ | ||||||
|   rm patreon.cache && \ |   rm patreon.cache && \ | ||||||
|   cat patreon.raw.cache | \ |   cat patreon.raw.cache | \ | ||||||
|   jq -r '(.data|map(select(.relationships.currently_entitled_tiers.data[]))|map(.relationships.user.data.id))as$data|.included|map(select(.attributes.hide_pledges==false))|map(select(.id as$id|$data|contains([$id])))|map(.attributes|[.full_name,.thumb_url,.url]|@tsv)|.[]|@text' >> patreon.cache && \ |   jq -r '(.data|map(select(.relationships.currently_entitled_tiers.data[]))|map(.relationships.user.data.id))as$data|.included|map(select(.id as$id|$data|contains([$id])))|map(.attributes|[.full_name,.thumb_url,.url]|@tsv)|.[]|@text' >> patreon.cache && \ | ||||||
|   echo '<table><tr>' >> patreon.md.cache && \ |   echo '<table><tr>' >> patreon.md.cache && \ | ||||||
|   cat patreon.cache | \ |   cat patreon.cache | \ | ||||||
|   awk -F'\t' '{print $2,$1}' | \ |   awk -F'\t' '{print $2,$1}' | \ | ||||||
|   | |||||||
| @@ -7,27 +7,51 @@ maintainer: | |||||||
|   repository_url: https://github.com/syuilo/misskey # Repository URL |   repository_url: https://github.com/syuilo/misskey # Repository URL | ||||||
|   feedback_url: https://github.com/syuilo/misskey/issues # Feedback URL (e.g. github issue) |   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: | mongodb: | ||||||
|   host: localhost |   host: localhost | ||||||
| @@ -36,11 +60,6 @@ mongodb: | |||||||
|   user: example-misskey-user |   user: example-misskey-user | ||||||
|   pass: example-misskey-pass |   pass: example-misskey-pass | ||||||
|  |  | ||||||
| redis: |  | ||||||
|   host: localhost |  | ||||||
|   port: 6379 |  | ||||||
|   pass: example-pass |  | ||||||
|  |  | ||||||
| # Drive capacity of a local user (MB) | # Drive capacity of a local user (MB) | ||||||
| localDriveCapacityMb: 256 | localDriveCapacityMb: 256 | ||||||
|  |  | ||||||
| @@ -98,46 +117,50 @@ drive: | |||||||
| # Below settings are optional | # Below settings are optional | ||||||
| # | # | ||||||
|  |  | ||||||
| # TLS | # Redis | ||||||
| # https: | #redis: | ||||||
| #   # path for certification | #  host: localhost | ||||||
| #   key: example-tls-key | #  port: 6379 | ||||||
| #   cert: example-tls-cert | #  pass: example-pass | ||||||
|  |  | ||||||
| # Elasticsearch | # Elasticsearch | ||||||
| # elasticsearch: | #elasticsearch: | ||||||
| #   host: localhost | #  host: localhost | ||||||
| #   port: 9200 | #  port: 9200 | ||||||
| #   pass: null | #  pass: null | ||||||
|  |  | ||||||
| # reCAPTCHA | # reCAPTCHA | ||||||
| # recaptcha: | #recaptcha: | ||||||
| #   site_key: example-site-key | #  site_key: example-site-key | ||||||
| #  secret_key: example-secret-key | #  secret_key: example-secret-key | ||||||
|  |  | ||||||
| # ServiceWorker | # ServiceWorker | ||||||
| # sw: | #sw: | ||||||
| #   # Public key of VAPID | #  # Public key of VAPID | ||||||
| #   public_key: example-sw-public-key | #  public_key: example-sw-public-key | ||||||
|  | # | ||||||
| #   # Private key of VAPID | #  # Private key of VAPID | ||||||
| #   private_key: example-sw-private-key | #  private_key: example-sw-private-key | ||||||
|  |  | ||||||
| # google_maps_api_key: example-google-maps-api-key |  | ||||||
|  |  | ||||||
| # Twitter integration | # Twitter integration | ||||||
| # You need to set the oauth callback url as : https://<your-misskey-instance>/api/tw/cb | # You need to set the oauth callback url as : https://<your-misskey-instance>/api/tw/cb | ||||||
| # twitter: | #twitter: | ||||||
| #   consumer_key: example-twitter-consumer-key | #  consumer_key: example-twitter-consumer-key | ||||||
| #   consumer_secret: example-twitter-consumer-secret-key | #  consumer_secret: example-twitter-consumer-secret-key | ||||||
|  |  | ||||||
| # Ghost | # Ghost | ||||||
| # Ghost account is an account used for the purpose of delegating | # Ghost account is an account used for the purpose of delegating | ||||||
| # followers when putting users in the list. | # followers when putting users in the list. | ||||||
| # ghost: user-id-of-your-ghost-account | #ghost: user-id-of-your-ghost-account | ||||||
|  |  | ||||||
| # Clustering | # Clustering | ||||||
| # clusterLimit: 1 | #clusterLimit: 1 | ||||||
|  |  | ||||||
| # Summaly proxy | # Summaly proxy | ||||||
| # summalyProxy: "http://example.com" | #summalyProxy: "http://example.com" | ||||||
|  |  | ||||||
|  | # User recommendation | ||||||
|  | #user_recommendation: | ||||||
|  | #  external: true | ||||||
|  | #  engine: http://vinayaka.distsn.org/cgi-bin/vinayaka-user-match-misskey-api.cgi?{{host}}+{{user}}+{{limit}}+{{offset}} | ||||||
|  | #  timeout: 300000 | ||||||
|   | |||||||
							
								
								
									
										13
									
								
								.config/mongo_initdb_example.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								.config/mongo_initdb_example.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | |||||||
|  | var user = { | ||||||
|  | 	user: 'example-misskey-user', | ||||||
|  | 	pwd: 'example-misskey-pass', | ||||||
|  | 	roles: [ | ||||||
|  | 	    { | ||||||
|  | 		    role: 'readWrite', | ||||||
|  | 		    db: 'misskey' | ||||||
|  | 	    } | ||||||
|  | 	] | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | db.createUser(user); | ||||||
|  |  | ||||||
							
								
								
									
										12
									
								
								.dockerignore
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										12
									
								
								.dockerignore
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,12 @@ | |||||||
|  | .autogen | ||||||
|  | .git | ||||||
|  | .github | ||||||
|  | .travis | ||||||
|  | .vscode | ||||||
|  | Dockerfile | ||||||
|  | build/ | ||||||
|  | docker-compose.yml | ||||||
|  | node_modules/ | ||||||
|  | mongo/ | ||||||
|  | redis/ | ||||||
|  | elasticsearch/ | ||||||
							
								
								
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,5 +1,6 @@ | |||||||
| /.config/* | /.config/* | ||||||
| !/.config/example.yml | !/.config/example.yml | ||||||
|  | !/.config/mongo_initdb_example.js | ||||||
| /.vscode | /.vscode | ||||||
| /node_modules | /node_modules | ||||||
| /build | /build | ||||||
| @@ -12,3 +13,6 @@ npm-debug.log | |||||||
| run.bat | run.bat | ||||||
| api-docs.json | api-docs.json | ||||||
| *.log | *.log | ||||||
|  | /redis | ||||||
|  | /mongo | ||||||
|  | /elasticsearch | ||||||
|   | |||||||
| @@ -1,12 +1,8 @@ | |||||||
| maintainer: '@syuilo' | maintainer: | ||||||
| url: 'https://misskey.xyz' |   name: syuilo | ||||||
| secondary_url: 'https://himasaku.net' |   url: 'https://syuilo.com' | ||||||
|  | url: 'http://misskey.local' | ||||||
| port: 80 | port: 80 | ||||||
| https: |  | ||||||
|   enable: false |  | ||||||
|   key: null |  | ||||||
|   cert: null |  | ||||||
|   ca: null |  | ||||||
| mongodb: | mongodb: | ||||||
|   host: localhost |   host: localhost | ||||||
|   port: 27017 |   port: 27017 | ||||||
| @@ -21,6 +17,3 @@ elasticsearch: | |||||||
|   host: localhost |   host: localhost | ||||||
|   port: 9200 |   port: 9200 | ||||||
|   pass: '' |   pass: '' | ||||||
| recaptcha: |  | ||||||
|   site_key: hima |  | ||||||
|   secret_key: saku |  | ||||||
|   | |||||||
| @@ -1,12 +1,8 @@ | |||||||
| maintainer: '@syuilo' | maintainer: | ||||||
| url: 'https://misskey.xyz' |   name: syuilo | ||||||
| secondary_url: 'https://himasaku.net' |   url: 'https://syuilo.com' | ||||||
|  | url: 'http://misskey.local' | ||||||
| port: 80 | port: 80 | ||||||
| https: |  | ||||||
|   enable: false |  | ||||||
|   key: null |  | ||||||
|   cert: null |  | ||||||
|   ca: null |  | ||||||
| mongodb: | mongodb: | ||||||
|   host: localhost |   host: localhost | ||||||
|   port: 27017 |   port: 27017 | ||||||
| @@ -21,6 +17,3 @@ elasticsearch: | |||||||
|   host: localhost |   host: localhost | ||||||
|   port: 9200 |   port: 9200 | ||||||
|   pass: '' |   pass: '' | ||||||
| recaptcha: |  | ||||||
|   site_key: hima |  | ||||||
|   secret_key: saku |  | ||||||
|   | |||||||
							
								
								
									
										88
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										88
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -5,6 +5,94 @@ ChangeLog | |||||||
|  |  | ||||||
| This document describes breaking changes only. | This document describes breaking changes only. | ||||||
|  |  | ||||||
|  | 10.0.0 | ||||||
|  | ------ | ||||||
|  |  | ||||||
|  | ストリーミングAPIに破壊的変更があります。運営者がすべきことはありません。 | ||||||
|  |  | ||||||
|  | 変更は以下の通りです | ||||||
|  |  | ||||||
|  | * ストリーミングでやり取りする際の snake_case が全て camelCase に | ||||||
|  | * リバーシのストリームエンドポイント名が reversi → gamesReversi、reversiGame → gamesReversiGame に | ||||||
|  | * ストリーミングの個々のエンドポイントが廃止され、一旦元となるストリームに接続してから、個々のチャンネル(今までのエンドポイント)に接続します。詳細は後述します。 | ||||||
|  | * ストリームから流れてくる、キャプチャした投稿の更新イベントに投稿自体のデータは含まれず、代わりにアクションが設定されるようになります。詳細は後述します。 | ||||||
|  | * ストリームに接続する際に追加で指定していたパラメータ(トークン除く)が、URLにクエリとして含むのではなくチャンネル接続時にパラメータ指定するように | ||||||
|  |  | ||||||
|  | ### 個々のエンドポイントが廃止されることによる新しいストリーミングAPIの利用方法 | ||||||
|  | 具体的には、まず https://example.misskey/streaming にwebsocket接続します。 | ||||||
|  | 次に、例えば「messaging」ストリーム(チャンネルと呼びます)に接続したいときは、ストリームに次のようなデータを送信します: | ||||||
|  | ``` javascript | ||||||
|  | { | ||||||
|  |   type: 'connect', | ||||||
|  |   body: { | ||||||
|  |     channel: 'messaging', | ||||||
|  |     id: 'foobar', | ||||||
|  |     params: { | ||||||
|  |       otherparty: 'xxxxxxxxxxxx' | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  | ここで、`id`にはそのチャンネルとやり取りするための任意のIDを設定します。 | ||||||
|  | IDはチャンネルごとではなく「チャンネルの接続ごと」です。なぜなら、同じチャンネルに異なるパラメータで複数接続するケースもあるからです。 | ||||||
|  | `params`はチャンネルに接続する際のパラメータです。チャンネルによって接続時に必要とされるパラメータは異なります。パラメータ不要のチャンネルに接続する際は、このプロパティは省略可能です。 | ||||||
|  |  | ||||||
|  | チャンネルにメッセージを送信するには、次のようなデータを送信します: | ||||||
|  | ``` javascript | ||||||
|  | { | ||||||
|  |   type: 'channel', | ||||||
|  |   body: { | ||||||
|  |     id: 'foobar', | ||||||
|  |     type: 'something', | ||||||
|  |     body: { | ||||||
|  |       some: 'thing' | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  | ここで、`id`にはチャンネルに接続するときに指定したIDを設定します。 | ||||||
|  |  | ||||||
|  | 逆に、チャンネルからメッセージが流れてくると、次のようなデータが受信されます: | ||||||
|  | ``` javascript | ||||||
|  | { | ||||||
|  |   type: 'channel', | ||||||
|  |   body: { | ||||||
|  |     id: 'foobar', | ||||||
|  |     type: 'something', | ||||||
|  |     body: { | ||||||
|  |       some: 'thing' | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  | ここで、`id`にはチャンネルに接続するときに指定したIDが設定されています。 | ||||||
|  |  | ||||||
|  | ### 投稿のキャプチャに関する変更 | ||||||
|  | 投稿の更新イベントに投稿情報は含まれなくなりました。代わりに、その投稿が「リアクションされた」「アンケートに投票された」「削除された」といったアクション情報が設定されます。 | ||||||
|  |  | ||||||
|  | 具体的には次のようなデータが受信されます: | ||||||
|  | ``` javascript | ||||||
|  | { | ||||||
|  |   type: 'noteUpdated', | ||||||
|  |   body: { | ||||||
|  |     id: 'xxxxxxxxxxx', | ||||||
|  |     type: 'reacted', | ||||||
|  |     body: { | ||||||
|  |       reaction: 'hmm' | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | * reacted ... 投稿にリアクションされた。`reaction`プロパティにリアクションコードが含まれます。 | ||||||
|  | * pollVoted ... アンケートに投票された。`choice`プロパティに選択肢ID、`userId`に投票者IDが含まれます。 | ||||||
|  |  | ||||||
|  | 9.0.0 | ||||||
|  | ----- | ||||||
|  |  | ||||||
|  | Misskey v8.64.0 を使っている方は、9.0.0に際しては特にすべきことはありません。 | ||||||
|  | Misskey v8.64.0 に満たないバージョンをお使いの方は、一旦8.64.0にアップデートして(そして起動して)から9.0.0に再度アップデートしてください。 | ||||||
|  |  | ||||||
| 8.0.0 | 8.0.0 | ||||||
| ----- | ----- | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										28
									
								
								Dockerfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								Dockerfile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,28 @@ | |||||||
|  | FROM alpine:latest AS base | ||||||
|  |  | ||||||
|  | ENV NODE_ENV=production | ||||||
|  |  | ||||||
|  | RUN apk add --no-cache nodejs nodejs-npm | ||||||
|  | RUN apk add vips fftw --update-cache --repository https://dl-3.alpinelinux.org/alpine/edge/testing/ | ||||||
|  | WORKDIR /misskey | ||||||
|  | COPY . ./ | ||||||
|  |  | ||||||
|  | FROM base AS builder | ||||||
|  |  | ||||||
|  | RUN apk add --no-cache	gcc g++ python autoconf automake file make nasm | ||||||
|  | RUN apk add vips-dev fftw-dev --update-cache --repository https://dl-3.alpinelinux.org/alpine/edge/testing/ | ||||||
|  | RUN npm install \ | ||||||
|  |     && npm install -g node-gyp \ | ||||||
|  |     && node-gyp configure \ | ||||||
|  |     && node-gyp build \ | ||||||
|  |     && npm run build | ||||||
|  |  | ||||||
|  | FROM base AS runner | ||||||
|  |  | ||||||
|  | COPY --from=builder /misskey/built ./built | ||||||
|  | COPY --from=builder /misskey/node_modules ./node_modules | ||||||
|  |  | ||||||
|  | RUN apk add --no-cache tini | ||||||
|  | ENTRYPOINT ["/sbin/tini", "--"] | ||||||
|  |  | ||||||
|  | CMD ["npm", "start"] | ||||||
							
								
								
									
										14
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								README.md
									
									
									
									
									
								
							| @@ -71,19 +71,21 @@ Please see [Contribution guide](./CONTRIBUTING.md). | |||||||
| ---------------------------------------------------------------- | ---------------------------------------------------------------- | ||||||
| <!-- PATREON_START --> | <!-- PATREON_START --> | ||||||
| <table><tr> | <table><tr> | ||||||
|  | <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/619786/32cf01444db24e578cd1982c197f6fc6/1?token-time=2145916800&token-hash=CXe9AqlZy9AsYfiWd3OBYVOzvODoN47Litz0Tu4BFpU%3D" alt="Gargron"></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/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/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/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="Axella"></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/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://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://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> | <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> | </tr><tr> | ||||||
| <td><a href="https://www.patreon.com/user?u=12731202">negao</a></td> | <td><a href="https://www.patreon.com/mastodon">Gargron</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=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/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/user?u=3384329">べすれい</a></td> | ||||||
| <td><a href="https://www.patreon.com/gutfuckllc">gutfuckllc</a></td> | <td><a href="https://www.patreon.com/gutfuckllc">gutfuckllc</a></td> | ||||||
| <td><a href="https://www.patreon.com/user?u=12718187">Peter G.</a></td> | <td><a href="https://www.patreon.com/user?u=12718187">Peter G.</a></td> | ||||||
| @@ -91,19 +93,17 @@ Please see [Contribution guide](./CONTRIBUTING.md). | |||||||
| </tr></table> | </tr></table> | ||||||
| <table><tr> | <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/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/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/4503830/ccf2cc867ea64de0b524bb2e24b9a1cb/1?token-time=2145916800&token-hash=S1zP0QyLU52Dqq6dtc9qNYyWfW86XrYHiR4NMbeOrnA%3D" alt="dansup"></td> | ||||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12531784/93a45137841849329ba692da92ac7c60/1?token-time=2145916800&token-hash=tMosUojzUYJCH_3t--tvYA-SMCyrS__hzSndyaRSnbo%3D" alt="Takashi Shibuya"></td> | <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12531784/93a45137841849329ba692da92ac7c60/1?token-time=2145916800&token-hash=tMosUojzUYJCH_3t--tvYA-SMCyrS__hzSndyaRSnbo%3D" alt="Takashi Shibuya"></td> | ||||||
| </tr><tr> | </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=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/hiratake">Hiratake</a></td> | ||||||
| <td><a href="https://www.patreon.com/dansup">dansup</a></td> | <td><a href="https://www.patreon.com/dansup">dansup</a></td> | ||||||
| <td><a href="https://www.patreon.com/user?u=12531784">Takashi Shibuya</a></td> | <td><a href="https://www.patreon.com/user?u=12531784">Takashi Shibuya</a></td> | ||||||
| </tr></table> | </tr></table> | ||||||
|  |  | ||||||
| **Last updated:** Sun, 02 Sep 2018 05:30:06 UTC | **Last updated:** Tue, 02 Oct 2018 09:25:07 UTC | ||||||
| <!-- PATREON_END --> | <!-- PATREON_END --> | ||||||
|  |  | ||||||
| :four_leaf_clover: Copyright | :four_leaf_clover: Copyright | ||||||
|   | |||||||
							
								
								
									
										52
									
								
								docker-compose.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								docker-compose.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,52 @@ | |||||||
|  | version: "3" | ||||||
|  |  | ||||||
|  | services: | ||||||
|  |   web: | ||||||
|  |     build: . | ||||||
|  |     restart: always | ||||||
|  |     links: | ||||||
|  |       - mongo | ||||||
|  |       - redis | ||||||
|  | #      - es | ||||||
|  |     ports: | ||||||
|  |       - "127.0.0.1:3000:3000" | ||||||
|  |     networks: | ||||||
|  |       - internal_network | ||||||
|  |       - external_network | ||||||
|  |  | ||||||
|  |   redis: | ||||||
|  |     restart: always | ||||||
|  |     image: redis:4.0-alpine | ||||||
|  |     networks: | ||||||
|  |       - internal_network | ||||||
|  | ### Uncomment to enable Redis persistance | ||||||
|  | #    volumes: | ||||||
|  | #      - ./redis:/data | ||||||
|  |  | ||||||
|  |   mongo: | ||||||
|  |     restart: always | ||||||
|  |     image: mongo:4.1-bionic | ||||||
|  |     networks: | ||||||
|  |       - internal_network | ||||||
|  |     environment: | ||||||
|  |       MONGO_INITDB_DATABASE: "misskey" | ||||||
|  |     volumes: | ||||||
|  |       - ./.config/mongo_initdb.js:/docker-entrypoint-initdb.d/mongo_initdb.js:ro | ||||||
|  | ### Uncomment to enable MongoDB persistance | ||||||
|  | #      - ./mongo:/data | ||||||
|  |  | ||||||
|  | #  es: | ||||||
|  | #    restart: always | ||||||
|  | #    image: docker.elastic.co/elasticsearch/elasticsearch-oss:6.4.2 | ||||||
|  | #    environment: | ||||||
|  | #      - "ES_JAVA_OPTS=-Xms512m -Xmx512m" | ||||||
|  | #    networks: | ||||||
|  | #      - internal_network | ||||||
|  | #### Uncomment to enable ES persistence | ||||||
|  | ##    volumes: | ||||||
|  | ##      - ./elasticsearch:/usr/share/elasticsearch/data | ||||||
|  |  | ||||||
|  | networks: | ||||||
|  |   internal_network: | ||||||
|  |     internal: true | ||||||
|  |   external_network: | ||||||
							
								
								
									
										47
									
								
								docs/docker.en.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								docs/docker.en.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,47 @@ | |||||||
|  | Docker Guide | ||||||
|  | ================================================================ | ||||||
|  |  | ||||||
|  | This guide describes how to install and setup Misskey with Docker. | ||||||
|  |  | ||||||
|  | [Japanese version also available - 日本語版もあります](./docker.ja.md) | ||||||
|  |  | ||||||
|  | ---------------------------------------------------------------- | ||||||
|  |  | ||||||
|  | *1.* Make configuration files | ||||||
|  | ---------------------------------------------------------------- | ||||||
|  | 1. `cp .config/example.yml .config/default.yml` Copy the `.config/example.yml` and rename it to `default.yml`. | ||||||
|  | 2. `cp .config/mongo_initdb_example.js .config/mongo_initdb.js` Copy the `.config/mongo_initdb_example.js` and rename it to `mongo_initdb.js`. | ||||||
|  | 2. Edit `default.yml` and `mongo_initdb.js`. | ||||||
|  |  | ||||||
|  | *2.* Configure Docker | ||||||
|  | ---------------------------------------------------------------- | ||||||
|  | Edit `docker-compose.yml`. | ||||||
|  |  | ||||||
|  | *3.* Build Misskey | ||||||
|  | ---------------------------------------------------------------- | ||||||
|  | Build misskey with the following: | ||||||
|  |  | ||||||
|  | `docker-compose build` | ||||||
|  |  | ||||||
|  | *4.* That is it. | ||||||
|  | ---------------------------------------------------------------- | ||||||
|  | Well done! Now, you have an environment that run to Misskey. | ||||||
|  |  | ||||||
|  | ### Launch normally | ||||||
|  | Just `docker-compose up -d`. GLHF! | ||||||
|  |  | ||||||
|  | ### Way to Update to latest version of your Misskey | ||||||
|  | 1. `git fetch` | ||||||
|  | 2. `git stash` | ||||||
|  | 3. `git checkout $(git tag -l | grep -v 'rc[0-9]*$' | sort -V | tail -n 1)` | ||||||
|  | 4. `git stash pop` | ||||||
|  | 5. `docker-compose build` | ||||||
|  | 6. Check [ChangeLog](../CHANGELOG.md) for migration information | ||||||
|  | 7. `docker-compose stop && docker-compose up -d` | ||||||
|  |  | ||||||
|  | ### Way to execute cli command: | ||||||
|  | `docker-compose run --rm web node cli/mark-admin @example` | ||||||
|  |  | ||||||
|  | ---------------------------------------------------------------- | ||||||
|  |  | ||||||
|  | If you have any questions or troubles, feel free to contact us! | ||||||
							
								
								
									
										48
									
								
								docs/docker.ja.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								docs/docker.ja.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,48 @@ | |||||||
|  | Dockerを使ったMisskey構築方法 | ||||||
|  | ================================================================ | ||||||
|  |  | ||||||
|  | このガイドはDockerを使ったMisskeyセットアップ方法について解説します。 | ||||||
|  |  | ||||||
|  | [英語版もあります - English version also available](./docker.en.md) | ||||||
|  |  | ||||||
|  | ---------------------------------------------------------------- | ||||||
|  |  | ||||||
|  | *1.* 設定ファイルを作成する | ||||||
|  | ---------------------------------------------------------------- | ||||||
|  | 1. `cp .config/example.yml .config/default.yml` `.config/example.yml`をコピーし名前を`default.yml`にする | ||||||
|  | 2. `cp .config/mongo_initdb_example.js .config/mongo_initdb.js` `.config/mongo_initdb_example.js`をコピーし名前を`mongo_initdb.js`にする | ||||||
|  | 3. `default.yml`と`mongo_initdb.js`を編集する | ||||||
|  |  | ||||||
|  | *2.* Dockerの設定 | ||||||
|  | ---------------------------------------------------------------- | ||||||
|  | `docker-compose.yml`を編集してください。 | ||||||
|  |  | ||||||
|  | *3.* Misskeyのビルド | ||||||
|  | ---------------------------------------------------------------- | ||||||
|  | 次のコマンドでMisskeyをビルドしてください: | ||||||
|  |  | ||||||
|  | `docker-compose build` | ||||||
|  |  | ||||||
|  | *4.* 以上です! | ||||||
|  | ---------------------------------------------------------------- | ||||||
|  | お疲れ様でした。これでMisskeyを動かす準備は整いました。 | ||||||
|  |  | ||||||
|  | ### 通常起動 | ||||||
|  | `docker-compose up -d`するだけです。GLHF! | ||||||
|  |  | ||||||
|  | ### Misskeyを最新バージョンにアップデートする方法: | ||||||
|  | 1. `git fetch` | ||||||
|  | 2. `git stash` | ||||||
|  | 3. `git checkout $(git tag -l | grep -v 'rc[0-9]*$' | sort -V | tail -n 1)` | ||||||
|  | 4. `git stash pop` | ||||||
|  | 5. `docker-compose build` | ||||||
|  | 6. [ChangeLog](../CHANGELOG.md)でマイグレーション情報を確認する | ||||||
|  | 7. `docker-compose stop && docker-compose up -d` | ||||||
|  |  | ||||||
|  | ### cliコマンドを実行する方法: | ||||||
|  |  | ||||||
|  | `docker-compose run --rm web node cli/mark-admin @example` | ||||||
|  |  | ||||||
|  | ---------------------------------------------------------------- | ||||||
|  |  | ||||||
|  | なにかお困りのことがありましたらお気軽にご連絡ください。 | ||||||
| @@ -24,11 +24,11 @@ Please install and setup these softwares: | |||||||
| #### Dependencies :package: | #### Dependencies :package: | ||||||
| * **[Node.js](https://nodejs.org/en/)** | * **[Node.js](https://nodejs.org/en/)** | ||||||
| * **[MongoDB](https://www.mongodb.com/)** >= 3.6 | * **[MongoDB](https://www.mongodb.com/)** >= 3.6 | ||||||
| * **[Redis](https://redis.io/)** |  | ||||||
|  |  | ||||||
| ##### Optional | ##### Optional | ||||||
| * [Elasticsearch](https://www.elastic.co/) - used to provide searching feature instead of MongoDB | * [Redis](https://redis.io/) | ||||||
|  |   * Redis is optional, but we strongly recommended to install it | ||||||
|  | * [Elasticsearch](https://www.elastic.co/) - required to enable the search feature | ||||||
|  |  | ||||||
| *3.* Setup MongoDB | *3.* Setup MongoDB | ||||||
| ---------------------------------------------------------------- | ---------------------------------------------------------------- | ||||||
|   | |||||||
| @@ -24,10 +24,17 @@ adduser --disabled-password --disabled-login misskey | |||||||
| #### 依存関係 :package: | #### 依存関係 :package: | ||||||
| * **[Node.js](https://nodejs.org/en/)** | * **[Node.js](https://nodejs.org/en/)** | ||||||
| * **[MongoDB](https://www.mongodb.com/)** (3.6以上) | * **[MongoDB](https://www.mongodb.com/)** (3.6以上) | ||||||
| * **[Redis](https://redis.io/)** |  | ||||||
|  |  | ||||||
| ##### オプション | ##### オプション | ||||||
| * [Elasticsearch](https://www.elastic.co/) - 検索機能を向上させるために用います。 | * [Redis](https://redis.io/) | ||||||
|  | 	* Redisはオプションですが、インストールすることを強く推奨します。 | ||||||
|  | 	* インストールしなくていいのは、あなたのインスタンスが自分専用のときだけとお考えください。 | ||||||
|  | 	* 具体的には、Redisをインストールしないと、次の事が出来なくなります: | ||||||
|  | 		* Misskeyプロセスを複数起動しての負荷分散 | ||||||
|  | 		* レートリミット | ||||||
|  | 		* Twitter連携 | ||||||
|  | * [Elasticsearch](https://www.elastic.co/) | ||||||
|  | 	* 検索機能を有効にするためにはインストールが必要です。 | ||||||
|  |  | ||||||
| *3.* MongoDBの設定 | *3.* MongoDBの設定 | ||||||
| ---------------------------------------------------------------- | ---------------------------------------------------------------- | ||||||
|   | |||||||
| @@ -2,7 +2,6 @@ | |||||||
|  * Gulp tasks |  * Gulp tasks | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| import * as fs from 'fs'; |  | ||||||
| import * as gulp from 'gulp'; | import * as gulp from 'gulp'; | ||||||
| import * as gutil from 'gulp-util'; | import * as gutil from 'gulp-util'; | ||||||
| import * as ts from 'gulp-typescript'; | import * as ts from 'gulp-typescript'; | ||||||
| @@ -166,9 +165,7 @@ gulp.task('build:client:pug', [ | |||||||
| 			.pipe(pug({ | 			.pipe(pug({ | ||||||
| 				locals: { | 				locals: { | ||||||
| 					themeColor: constants.themeColor, | 					themeColor: constants.themeColor, | ||||||
| 					facss: fa.dom.css(), | 					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') |  | ||||||
| 				} | 				} | ||||||
| 			})) | 			})) | ||||||
| 			.pipe(htmlmin({ | 			.pipe(htmlmin({ | ||||||
|   | |||||||
| @@ -264,6 +264,41 @@ common/views/components/connect-failed.troubleshooter.vue: | |||||||
| common/views/components/media-banner.vue: | common/views/components/media-banner.vue: | ||||||
|   sensitive: "閲覧注意" |   sensitive: "閲覧注意" | ||||||
|   click-to-show: "クリックして表示" |   click-to-show: "クリックして表示" | ||||||
|  | common/views/components/theme.vue: | ||||||
|  |   light-theme: "非ダークモード時に使用するテーマ" | ||||||
|  |   dark-theme: "ダークモード時に使用するテーマ" | ||||||
|  |   light-themes: "明るいテーマ" | ||||||
|  |   dark-themes: "暗いテーマ" | ||||||
|  |   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: "保存しました" | ||||||
|  |   manage-themes: "テーマの管理" | ||||||
|  |   builtin-themes: "標準テーマ" | ||||||
|  |   my-themes: "マイテーマ" | ||||||
|  |   installed-themes: "インストールされたテーマ" | ||||||
|  |   select-theme: "テーマを選択してください" | ||||||
|  |   uninstall: "アンインストール" | ||||||
|  |   uninstalled: "「{}」をアンインストールしました" | ||||||
|  |   author: "作者" | ||||||
|  |   desc: "説明" | ||||||
|  |   export: "エクスポート" | ||||||
|  |   import: "インポート" | ||||||
|  |   import-by-code: "またはコードをペースト" | ||||||
|  |   theme-name-required: "テーマ名は必須です。" | ||||||
| common/views/components/cw-button.vue: | common/views/components/cw-button.vue: | ||||||
|   hide: "隠す" |   hide: "隠す" | ||||||
|   show: "もっと見る" |   show: "もっと見る" | ||||||
| @@ -300,7 +335,9 @@ common/views/components/note-menu.vue: | |||||||
|   detail: "詳細" |   detail: "詳細" | ||||||
|   copy-link: "リンクをコピー" |   copy-link: "リンクをコピー" | ||||||
|   favorite: "お気に入り" |   favorite: "お気に入り" | ||||||
|  |   unfavorite: "お気に入り解除" | ||||||
|   pin: "ピン留め" |   pin: "ピン留め" | ||||||
|  |   unpin: "ピン留め解除" | ||||||
|   delete: "削除" |   delete: "削除" | ||||||
|   delete-confirm: "この投稿を削除しますか?" |   delete-confirm: "この投稿を削除しますか?" | ||||||
|   remote: "投稿元で見る" |   remote: "投稿元で見る" | ||||||
| @@ -379,6 +416,25 @@ common/views/components/visibility-chooser.vue: | |||||||
| common/views/components/trends.vue: | common/views/components/trends.vue: | ||||||
|   count: "{}人が投稿" |   count: "{}人が投稿" | ||||||
|   empty: "トレンドなし" |   empty: "トレンドなし" | ||||||
|  | common/views/components/profile-editor.vue: | ||||||
|  |   title: "プロフィール" | ||||||
|  |   name: "名前" | ||||||
|  |   account: "アカウント" | ||||||
|  |   location: "場所" | ||||||
|  |   description: "自己紹介" | ||||||
|  |   birthday: "誕生日" | ||||||
|  |   avatar: "アイコン" | ||||||
|  |   banner: "バナー" | ||||||
|  |   is-cat: "このアカウントはCatです" | ||||||
|  |   is-bot: "このアカウントはBotです" | ||||||
|  |   is-locked: "フォローを承認制にする" | ||||||
|  |   careful-bot: "Botからのフォローだけ承認制にする" | ||||||
|  |   advanced: "その他" | ||||||
|  |   privacy: "プライバシー" | ||||||
|  |   save: "保存" | ||||||
|  |   saved: "プロフィールを保存しました" | ||||||
|  |   uploading: "アップロード中" | ||||||
|  |   upload-failed: "アップロードに失敗しました" | ||||||
| common/views/widgets/broadcast.vue: | common/views/widgets/broadcast.vue: | ||||||
|   fetching: "確認中" |   fetching: "確認中" | ||||||
|   no-broadcasts: "お知らせはありません" |   no-broadcasts: "お知らせはありません" | ||||||
| @@ -439,6 +495,7 @@ common/views/pages/follow.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| desktop: | desktop: | ||||||
|   banner-crop-title: "バナーとして表示する部分を選択" |   banner-crop-title: "バナーとして表示する部分を選択" | ||||||
| @@ -477,13 +534,13 @@ desktop/views/components/charts.vue: | |||||||
|     notes: "投稿の増減 (統合)" |     notes: "投稿の増減 (統合)" | ||||||
|     local-notes: "投稿の増減 (ローカル)" |     local-notes: "投稿の増減 (ローカル)" | ||||||
|     remote-notes: "投稿の増減 (リモート)" |     remote-notes: "投稿の増減 (リモート)" | ||||||
|     notes-total: "投稿の累計" |     notes-total: "投稿の積算" | ||||||
|     users: "ユーザーの増減" |     users: "ユーザーの増減" | ||||||
|     users-total: "ユーザーの累計" |     users-total: "ユーザーの積算" | ||||||
|     drive: "ドライブ使用量の増減" |     drive: "ドライブ使用量の増減" | ||||||
|     drive-total: "ドライブ使用量の累計" |     drive-total: "ドライブ使用量の積算" | ||||||
|     drive-files: "ドライブのファイル数の増減" |     drive-files: "ドライブのファイル数の増減" | ||||||
|     drive-files-total: "ドライブのファイル数の累計" |     drive-files-total: "ドライブのファイル数の積算" | ||||||
|     network-requests: "リクエスト" |     network-requests: "リクエスト" | ||||||
|     network-time: "応答時間" |     network-time: "応答時間" | ||||||
|     network-usage: "通信量" |     network-usage: "通信量" | ||||||
| @@ -565,6 +622,7 @@ desktop/views/components/follow-button.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| desktop/views/components/followers-window.vue: | desktop/views/components/followers-window.vue: | ||||||
|   followers: "{} のフォロワー" |   followers: "{} のフォロワー" | ||||||
| @@ -601,7 +659,7 @@ desktop/views/components/note-detail.vue: | |||||||
|   location: "位置情報" |   location: "位置情報" | ||||||
|   renote: "Renote" |   renote: "Renote" | ||||||
|   add-reaction: "リアクション" |   add-reaction: "リアクション" | ||||||
| desktop/views/components/notes.note.vue: | desktop/views/components/note.vue: | ||||||
|   reposted-by: "{}がRenote" |   reposted-by: "{}がRenote" | ||||||
|   reply: "返信" |   reply: "返信" | ||||||
|   renote: "Renote" |   renote: "Renote" | ||||||
| @@ -675,6 +733,7 @@ desktop/views/components/settings.vue: | |||||||
|   2fa: "二段階認証" |   2fa: "二段階認証" | ||||||
|   other: "その他" |   other: "その他" | ||||||
|   license: "ライセンス" |   license: "ライセンス" | ||||||
|  |   theme: "テーマ" | ||||||
|   behaviour: "動作" |   behaviour: "動作" | ||||||
|   fetch-on-scroll: "スクロールで自動読み込み" |   fetch-on-scroll: "スクロールで自動読み込み" | ||||||
|   fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込みます。" |   fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込みます。" | ||||||
| @@ -686,30 +745,36 @@ desktop/views/components/settings.vue: | |||||||
|   advanced: "詳細設定" |   advanced: "詳細設定" | ||||||
|   api-via-stream: "ストリームを経由したAPIリクエスト" |   api-via-stream: "ストリームを経由したAPIリクエスト" | ||||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" |   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||||
|  |   deck-nav: "デッキ内ナビゲーション" | ||||||
|  |   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||||
|  |   deck-default: "デッキをデフォルトのUIにする" | ||||||
|   display: "デザインと表示" |   display: "デザインと表示" | ||||||
|   customize: "ホームをカスタマイズ" |   customize: "ホームをカスタマイズ" | ||||||
|  |   wallpaper: "壁紙" | ||||||
|   choose-wallpaper: "壁紙を選択" |   choose-wallpaper: "壁紙を選択" | ||||||
|   delete-wallpaper: "壁紙を削除" |   delete-wallpaper: "壁紙を削除" | ||||||
|   dark-mode: "ダークモード" |   dark-mode: "ダークモード" | ||||||
|  |   use-shadow: "UIに影を使用" | ||||||
|  |   rounded-corners: "UIの角を丸める" | ||||||
|   circle-icons: "円形のアイコンを使用" |   circle-icons: "円形のアイコンを使用" | ||||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" |   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" |  | ||||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" |   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" |   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||||
|   show-clock-on-header: "右上に時計を表示する" |   show-clock-on-header: "右上に時計を表示する" | ||||||
|   show-reply-target: "リプライ先を表示する" |   show-reply-target: "リプライ先を表示する" | ||||||
|  |   timeline: "タイムライン" | ||||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" |   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" |   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" |   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||||
|   show-maps: "マップの自動展開" |   show-maps: "マップの自動展開" | ||||||
|   show-maps-desc: "位置情報が添付された投稿のマップを自動的に展開します。" |   deck-column-align: "デッキのカラムの位置" | ||||||
|  |   deck-column-align-center: "中央" | ||||||
|  |   deck-column-align-left: "左" | ||||||
|   sound: "サウンド" |   sound: "サウンド" | ||||||
|   enable-sounds: "サウンドを有効にする" |   enable-sounds: "サウンドを有効にする" | ||||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" |   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||||
|   volume: "ボリューム" |   volume: "ボリューム" | ||||||
|   test: "テスト" |   test: "テスト" | ||||||
|   mobile: "モバイル" |  | ||||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" |  | ||||||
|   language: "言語" |   language: "言語" | ||||||
|   pick-language: "言語を選択" |   pick-language: "言語を選択" | ||||||
|   recommended: "推奨" |   recommended: "推奨" | ||||||
| @@ -745,6 +810,10 @@ desktop/views/components/settings.vue: | |||||||
|   tools: "ツール" |   tools: "ツール" | ||||||
|   task-manager: "タスクマネージャ" |   task-manager: "タスクマネージャ" | ||||||
|   third-parties: "サードパーティ" |   third-parties: "サードパーティ" | ||||||
|  |   navbar-position: "ナビゲーションバーの位置" | ||||||
|  |   navbar-position-top: "上" | ||||||
|  |   navbar-position-left: "左" | ||||||
|  |   navbar-position-right: "右" | ||||||
| desktop/views/components/settings.2fa.vue: | desktop/views/components/settings.2fa.vue: | ||||||
|   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" |   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" | ||||||
|   detail: "詳細..." |   detail: "詳細..." | ||||||
| @@ -784,20 +853,6 @@ desktop/views/components/settings.password.vue: | |||||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" |   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||||
|   not-match: "新しいパスワードが一致しません" |   not-match: "新しいパスワードが一致しません" | ||||||
|   changed: "パスワードを変更しました" |   changed: "パスワードを変更しました" | ||||||
| desktop/views/components/settings.profile.vue: |  | ||||||
|   avatar: "アイコン" |  | ||||||
|   choice-avatar: "画像を選択" |  | ||||||
|   name: "名前" |  | ||||||
|   location: "場所" |  | ||||||
|   description: "自己紹介" |  | ||||||
|   birthday: "誕生日" |  | ||||||
|   save: "保存" |  | ||||||
|   locked-account: "アカウントの保護" |  | ||||||
|   is-locked: "フォローを承認制にする" |  | ||||||
|   other: "その他" |  | ||||||
|   is-bot: "このアカウントはBotです" |  | ||||||
|   is-cat: "このアカウントはCatです" |  | ||||||
|   profile-updated: "プロフィールを更新しました" |  | ||||||
| desktop/views/components/sub-note-content.vue: | desktop/views/components/sub-note-content.vue: | ||||||
|   private: "この投稿は非公開です" |   private: "この投稿は非公開です" | ||||||
|   deleted: "この投稿は削除されました" |   deleted: "この投稿は削除されました" | ||||||
| @@ -896,10 +951,8 @@ desktop/views/pages/deck/deck.tl-column.vue: | |||||||
|   is-media-only: "メディア投稿のみ" |   is-media-only: "メディア投稿のみ" | ||||||
|   is-media-view: "メディアビュー" |   is-media-view: "メディアビュー" | ||||||
|   edit: "オプション" |   edit: "オプション" | ||||||
| desktop/views/pages/deck/deck.note.vue: | desktop/views/pages/deck/deck.user-column.vue: | ||||||
|   reposted-by: "{}がRenote" |   pinned-notes: "ピン留めされた投稿" | ||||||
|   private: "この投稿は非公開です" |  | ||||||
|   deleted: "この投稿は削除されました" |  | ||||||
| desktop/views/pages/stats/stats.vue: | desktop/views/pages/stats/stats.vue: | ||||||
|   all-users: "全てのユーザー" |   all-users: "全てのユーザー" | ||||||
|   original-users: "このインスタンスのユーザー" |   original-users: "このインスタンスのユーザー" | ||||||
| @@ -1034,6 +1087,8 @@ mobile/views/components/drive.file-detail.vue: | |||||||
|   hash: "ハッシュ (md5)" |   hash: "ハッシュ (md5)" | ||||||
|   exif: "EXIF" |   exif: "EXIF" | ||||||
|   nsfw: "閲覧注意" |   nsfw: "閲覧注意" | ||||||
|  |   mark-as-sensitive: "閲覧注意に設定" | ||||||
|  |   unmark-as-sensitive: "閲覧注意を解除" | ||||||
| mobile/views/components/media-image.vue: | mobile/views/components/media-image.vue: | ||||||
|   sensitive: "閲覧注意" |   sensitive: "閲覧注意" | ||||||
|   click-to-show: "クリックして表示" |   click-to-show: "クリックして表示" | ||||||
| @@ -1044,6 +1099,7 @@ mobile/views/components/follow-button.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| mobile/views/components/friends-maker.vue: | mobile/views/components/friends-maker.vue: | ||||||
|   title: "気になるユーザーをフォロー" |   title: "気になるユーザーをフォロー" | ||||||
| @@ -1173,23 +1229,6 @@ mobile/views/pages/notifications.vue: | |||||||
|   read-all: "すべての通知を既読にしますか?" |   read-all: "すべての通知を既読にしますか?" | ||||||
| mobile/views/pages/games/reversi.vue: | mobile/views/pages/games/reversi.vue: | ||||||
|   reversi: "リバーシ" |   reversi: "リバーシ" | ||||||
| mobile/views/pages/settings/settings.profile.vue: |  | ||||||
|   title: "プロフィール" |  | ||||||
|   name: "名前" |  | ||||||
|   account: "アカウント" |  | ||||||
|   location: "場所" |  | ||||||
|   description: "自己紹介" |  | ||||||
|   birthday: "誕生日" |  | ||||||
|   avatar: "アイコン" |  | ||||||
|   banner: "バナー" |  | ||||||
|   is-cat: "このアカウントはCatです" |  | ||||||
|   is-locked: "フォローを承認制にする" |  | ||||||
|   advanced: "その他" |  | ||||||
|   privacy: "プライバシー" |  | ||||||
|   save: "保存" |  | ||||||
|   saved: "プロフィールを保存しました" |  | ||||||
|   uploading: "アップロード中" |  | ||||||
|   upload-failed: "アップロードに失敗しました" |  | ||||||
| mobile/views/pages/search.vue: | mobile/views/pages/search.vue: | ||||||
|   search: "検索" |   search: "検索" | ||||||
|   empty: "「{}」に関する投稿は見つかりませんでした。" |   empty: "「{}」に関する投稿は見つかりませんでした。" | ||||||
| @@ -1219,6 +1258,7 @@ mobile/views/pages/settings.vue: | |||||||
|   notification-position: "通知の表示" |   notification-position: "通知の表示" | ||||||
|   notification-position-bottom: "下" |   notification-position-bottom: "下" | ||||||
|   notification-position-top: "上" |   notification-position-top: "上" | ||||||
|  |   theme: "テーマ" | ||||||
|   behavior: "動作" |   behavior: "動作" | ||||||
|   fetch-on-scroll: "スクロールで自動読み込み" |   fetch-on-scroll: "スクロールで自動読み込み" | ||||||
|   note-visibility: "投稿の公開範囲" |   note-visibility: "投稿の公開範囲" | ||||||
|   | |||||||
| @@ -3,44 +3,44 @@ meta: | |||||||
|   lang: "Deutsch" |   lang: "Deutsch" | ||||||
|   divider: "" |   divider: "" | ||||||
| common: | common: | ||||||
|   misskey: "A ⭐ of fediverse" |   misskey: "Ein ⭐ des Fediversums" | ||||||
|   about-title: "A ⭐ of fediverse." |   about-title: "Ein ⭐ des Fediversums." | ||||||
|   about: "Misskeyを見つけていただき、ありがとうございます。Misskeyは、地球で生まれた<b>分散マイクロブログSNS</b>です。Fediverse(様々なSNSで構成される宇宙)の中に存在するため、他のSNSと相互に繋がっています。暫し都会の喧騒から離れて、新しいインターネットにダイブしてみませんか。" |   about: "Misskeyを見つけていただき、ありがとうございます。Misskeyは、地球で生まれた<b>分散マイクロブログSNS</b>です。Fediverse(様々なSNSで構成される宇宙)の中に存在するため、他のSNSと相互に繋がっています。暫し都会の喧騒から離れて、新しいインターネットにダイブしてみませんか。" | ||||||
|   intro: |   intro: | ||||||
|     title: "Misskeyって?" |     title: "Was ist Misskey?" | ||||||
|     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" |     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" | ||||||
|     features: "特徴" |     features: "Funktionen" | ||||||
|     rich-contents: "投稿" |     rich-contents: "Notizen" | ||||||
|     rich-contents-desc: "自分の考え、話題の出来事、皆と共有したいことについて発信してください。必要であれば、様々な構文を使って投稿を装飾したり、好きな画像、動画などのファイルやアンケートを添付することもできます。" |     rich-contents-desc: "自分の考え、話題の出来事、皆と共有したいことについて発信してください。必要であれば、様々な構文を使って投稿を装飾したり、好きな画像、動画などのファイルやアンケートを添付することもできます。" | ||||||
|     reaction: "リアクション" |     reaction: "Reaktionen" | ||||||
|     reaction-desc: "あなたの気持ちを伝える最も簡単な方法です。Misskeyは、他のユーザーの投稿に様々なリアクションを付けることができます。いちどMisskeyのリアクション機能を体験してしまうと、もう「いいね」の概念しか存在しないSNSには戻れなくなるかもしれません。" |     reaction-desc: "あなたの気持ちを伝える最も簡単な方法です。Misskeyは、他のユーザーの投稿に様々なリアクションを付けることができます。いちどMisskeyのリアクション機能を体験してしまうと、もう「いいね」の概念しか存在しないSNSには戻れなくなるかもしれません。" | ||||||
|     ui: "インターフェース" |     ui: "Benutzeroberfläche" | ||||||
|     ui-desc: "どのようなUIが使いやすいかは人それぞれです。だから、Misskeyは自由度の高いUIを持っています。レイアウトやデザインを調整したり、カスタマイズ可能な様々なウィジェットを配置したりして、自分だけのホームを作ってください。" |     ui-desc: "どのようなUIが使いやすいかは人それぞれです。だから、Misskeyは自由度の高いUIを持っています。レイアウトやデザインを調整したり、カスタマイズ可能な様々なウィジェットを配置したりして、自分だけのホームを作ってください。" | ||||||
|     drive: "ドライブ" |     drive: "Drive" | ||||||
|     drive-desc: "以前投稿したことのある画像をまた投稿したくなったことはありませんか?もしくは、アップロードしたファイルをフォルダ分けして整理したくなったことはありませんか?Misskeyの根幹に組み込まれたドライブ機能によってそれらが解決します。ファイルの共有も簡単です。" |     drive-desc: "以前投稿したことのある画像をまた投稿したくなったことはありませんか?もしくは、アップロードしたファイルをフォルダ分けして整理したくなったことはありませんか?Misskeyの根幹に組み込まれたドライブ機能によってそれらが解決します。ファイルの共有も簡単です。" | ||||||
|     outro: "他にもMisskeyにしかない機能はまだまだあるので、ぜひあなた自身の目で確かめてください。Misskeyは分散型SNSなので、このインスタンスが気に入らなければ他のインスタンスを試すこともできます。それでは、GLHF!" |     outro: "他にもMisskeyにしかない機能はまだまだあるので、ぜひあなた自身の目で確かめてください。Misskeyは分散型SNSなので、このインスタンスが気に入らなければ他のインスタンスを試すこともできます。それでは、GLHF!" | ||||||
|   adblock: |   adblock: | ||||||
|     detected: "広告ブロッカーを無効にしてください" |     detected: "Bitte deaktivieren Sie den Werbeblocker." | ||||||
|     warning: "<strong>Misskeyは広告を掲載していません</strong>が、広告をブロックする機能が有効だと一部の機能が利用できなかったり、不具合が発生する場合があります。" |     warning: "<strong>Misskeyは広告を掲載していません</strong>が、広告をブロックする機能が有効だと一部の機能が利用できなかったり、不具合が発生する場合があります。" | ||||||
|   application-authorization: "アプリの連携" |   application-authorization: "Autorisierte Anwendungen" | ||||||
|   close: "閉じる" |   close: "Schließen" | ||||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" |   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||||
|   got-it: "わかった" |   got-it: "Verstanden!" | ||||||
|   customization-tips: |   customization-tips: | ||||||
|     title: "カスタマイズのヒント" |     title: "Anpassung-Tipps" | ||||||
|     paragraph1: "ホームのカスタマイズでは、ウィジェットを追加/削除したり、ドラッグ&ドロップして並べ替えたりすることができます。" |     paragraph1: "ホームのカスタマイズでは、ウィジェットを追加/削除したり、ドラッグ&ドロップして並べ替えたりすることができます。" | ||||||
|     paragraph2: "一部のウィジェットは、<strong><strong>右</strong>クリック</strong>することで表示を変更することができます。" |     paragraph2: "一部のウィジェットは、<strong><strong>右</strong>クリック</strong>することで表示を変更することができます。" | ||||||
|     paragraph3: "ウィジェットを削除するには、ヘッダーの<strong>「ゴミ箱」</strong>と書かれたエリアにウィジェットをドラッグ&ドロップします。" |     paragraph3: "ウィジェットを削除するには、ヘッダーの<strong>「ゴミ箱」</strong>と書かれたエリアにウィジェットをドラッグ&ドロップします。" | ||||||
|     paragraph4: "カスタマイズを終了するには、右上の「完了」をクリックします。" |     paragraph4: "カスタマイズを終了するには、右上の「完了」をクリックします。" | ||||||
|     gotit: "Got it!" |     gotit: "Verstanden!" | ||||||
|   notification: |   notification: | ||||||
|     file-uploaded: "ファイルがアップロードされました" |     file-uploaded: "Datei hochgeladen!" | ||||||
|     message-from: "{}さんからメッセージ:" |     message-from: "Nachricht von {}:" | ||||||
|     reversi-invited: "対局への招待があります" |     reversi-invited: "対局への招待があります" | ||||||
|     reversi-invited-by: "{}さんから" |     reversi-invited-by: "Eingeladen von {}:" | ||||||
|     notified-by: "{}さんから" |     notified-by: "Benachrichtigt von {}:" | ||||||
|     reply-from: "{}さんから返信:" |     reply-from: "Antwort von {}:" | ||||||
|     quoted-by: "{}さんが引用:" |     quoted-by: "Zitiert von {}:" | ||||||
|   time: |   time: | ||||||
|     unknown: "Unbekannt" |     unknown: "Unbekannt" | ||||||
|     future: "Zukunft" |     future: "Zukunft" | ||||||
| @@ -52,8 +52,8 @@ common: | |||||||
|     weeks_ago: "vor {0} Woche{0:n}" |     weeks_ago: "vor {0} Woche{0:n}" | ||||||
|     months_ago: "vor {0} Monat{0:en}" |     months_ago: "vor {0} Monat{0:en}" | ||||||
|     years_ago: "vor {} Jahr{0:en}" |     years_ago: "vor {} Jahr{0:en}" | ||||||
|   month-and-day: "{month}月 {day}日" |   month-and-day: "{day}/{month}" | ||||||
|   trash: "ゴミ箱" |   trash: "Papierkorb" | ||||||
|   weekday-short: |   weekday-short: | ||||||
|     sunday: "So" |     sunday: "So" | ||||||
|     monday: "Mo" |     monday: "Mo" | ||||||
| @@ -63,15 +63,15 @@ common: | |||||||
|     friday: "Fr" |     friday: "Fr" | ||||||
|     saturday: "Sa" |     saturday: "Sa" | ||||||
|   weekday: |   weekday: | ||||||
|     sunday: "日曜日" |     sunday: "Sonntag" | ||||||
|     monday: "月曜日" |     monday: "Montag" | ||||||
|     tuesday: "火曜日" |     tuesday: "Dienstag" | ||||||
|     wednesday: "水曜日" |     wednesday: "Mittwoch" | ||||||
|     thursday: "木曜日" |     thursday: "Donnerstag" | ||||||
|     friday: "金曜日" |     friday: "Freitag" | ||||||
|     saturday: "土曜日" |     saturday: "Samstag" | ||||||
|   reactions: |   reactions: | ||||||
|     like: "いいね" |     like: "Gefällt mir" | ||||||
|     love: "Lieben" |     love: "Lieben" | ||||||
|     laugh: "Lachen" |     laugh: "Lachen" | ||||||
|     hmm: "Hmm...?" |     hmm: "Hmm...?" | ||||||
| @@ -82,14 +82,14 @@ common: | |||||||
|     rip: "RIP" |     rip: "RIP" | ||||||
|     pudding: "Pudding" |     pudding: "Pudding" | ||||||
|   note-visibility: |   note-visibility: | ||||||
|     public: "公開" |     public: "Öffentlich" | ||||||
|     home: "ホーム" |     home: "Startseite" | ||||||
|     home-desc: "ホームタイムラインにのみ公開" |     home-desc: "Nur auf die Startseite posten" | ||||||
|     followers: "フォロワー" |     followers: "Abonnenten" | ||||||
|     followers-desc: "自分のフォロワーにのみ公開" |     followers-desc: "Nur für diejenigen sichtbar, die dir folgen" | ||||||
|     specified: "ダイレクト" |     specified: "Direkt" | ||||||
|     specified-desc: "指定したユーザーにのみ公開" |     specified-desc: "Nur für bestimmte Benutzer posten" | ||||||
|     private: "非公開" |     private: "Privat" | ||||||
|   note-placeholders: |   note-placeholders: | ||||||
|     a: "Was machst du gerade?" |     a: "Was machst du gerade?" | ||||||
|     b: "Was ist so passiert?" |     b: "Was ist so passiert?" | ||||||
| @@ -97,34 +97,34 @@ common: | |||||||
|     d: "Willst du etwas sagen?" |     d: "Willst du etwas sagen?" | ||||||
|     e: "Schreib hier etwas!" |     e: "Schreib hier etwas!" | ||||||
|     f: "Warte darauf, das du schreibst." |     f: "Warte darauf, das du schreibst." | ||||||
|   search: "検索" |   search: "Suche" | ||||||
|   delete: "Löschen" |   delete: "Löschen" | ||||||
|   loading: "Laden" |   loading: "Laden" | ||||||
|   ok: "OK" |   ok: "OK" | ||||||
|   update-available-title: "更新があります" |   update-available-title: "Aktualisierung verfügbar" | ||||||
|   update-available: "Eine neue Version von Misskey ist verfügbar ({newer}, aktuell ist {current}). Lade die Seite neu um die aktuelle Version zu laden" |   update-available: "Eine neue Version von Misskey ist verfügbar ({newer}, aktuell ist {current}). Lade die Seite neu um die aktuelle Version zu laden" | ||||||
|   my-token-regenerated: "Dein Token wurde generiert. Du wirst jetzt abgemeldet." |   my-token-regenerated: "Dein Token wurde generiert. Du wirst jetzt abgemeldet." | ||||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" |   i-like-sushi: "Ich bevorzuge Sushi anstelle von Pudding" | ||||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" |   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" |   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||||
|   verified-user: "公式アカウント" |   verified-user: "Verifizierter Benutzer" | ||||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" |   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" |   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" |   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||||
|   show-full-acct: "ユーザー名のホストを省略しない" |   show-full-acct: "ユーザー名のホストを省略しない" | ||||||
|   reduce-motion: "UIの動きを減らす" |   reduce-motion: "Animationen der Benutzeroberfläche reduzieren" | ||||||
|   this-setting-is-this-device-only: "このデバイスのみ" |   this-setting-is-this-device-only: "Nur auf diesem Gerät" | ||||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' |   do-not-use-in-production: 'Dies ist eine Entwicklungsversion. Nicht in einer Produktionsumgebung verwenden.' | ||||||
|   reversi: |   reversi: | ||||||
|     drawn: "引き分け" |     drawn: "Unentschieden" | ||||||
|     my-turn: "あなたのターンです" |     my-turn: "Du bist am Zug" | ||||||
|     opponent-turn: "相手のターンです" |     opponent-turn: "Dein Gegner ist an der Reihe" | ||||||
|     turn-of: "{}のターンです" |     turn-of: "{} ist am Zug" | ||||||
|     past-turn-of: "{}のターン" |     past-turn-of: "Zug von {}" | ||||||
|     won: "{}の勝ち" |     won: "{} hat gewonnen!" | ||||||
|     black: "黒" |     black: "Schwarz" | ||||||
|     white: "白" |     white: "Weiß" | ||||||
|     total: "合計" |     total: "Gesamt" | ||||||
|     this-turn: "{}ターン目" |     this-turn: "{}ターン目" | ||||||
|   widgets: |   widgets: | ||||||
|     analog-clock: "Analoge Uhr" |     analog-clock: "Analoge Uhr" | ||||||
| @@ -142,23 +142,23 @@ common: | |||||||
|     broadcast: "ブロードキャスト" |     broadcast: "ブロードキャスト" | ||||||
|     notifications: "Benachrichtigungen" |     notifications: "Benachrichtigungen" | ||||||
|     users: "Empfohlene Benutzer" |     users: "Empfohlene Benutzer" | ||||||
|     polls: "アンケート" |     polls: "Umfrage" | ||||||
|     post-form: "Beitragsform" |     post-form: "Beitragsform" | ||||||
|     messaging: "Nachrichten" |     messaging: "Nachrichten" | ||||||
|     server: "Server-Info" |     server: "Server-Info" | ||||||
|     donation: "Spenden" |     donation: "Spenden" | ||||||
|     nav: "Navigation" |     nav: "Navigation" | ||||||
|     tips: "Tipps" |     tips: "Tipps" | ||||||
|     hashtags: "ハッシュタグ" |     hashtags: "Hashtags" | ||||||
|   deck: |   deck: | ||||||
|     widgets: "Widget hinzufügen:" |     widgets: "Widget hinzufügen:" | ||||||
|     home: "Startseite" |     home: "Startseite" | ||||||
|     local: "Lokal" |     local: "Lokal" | ||||||
|     hybrid: "ソーシャル" |     hybrid: "ソーシャル" | ||||||
|     hashtag: "ハッシュタグ" |     hashtag: "Hashtag" | ||||||
|     global: "Global" |     global: "Global" | ||||||
|     mentions: "あなた宛て" |     mentions: "Erwähnungen" | ||||||
|     direct: "ダイレクト投稿" |     direct: "Direktnachrichten" | ||||||
|     notifications: "Mitteilungen" |     notifications: "Mitteilungen" | ||||||
|     list: "Listen" |     list: "Listen" | ||||||
|     swap-left: "Nach links" |     swap-left: "Nach links" | ||||||
| @@ -175,67 +175,67 @@ auth/views/form.vue: | |||||||
|   permission-ask: "このアプリは次の権限を要求しています:" |   permission-ask: "このアプリは次の権限を要求しています:" | ||||||
|   account-read: "アカウントの情報を見る。" |   account-read: "アカウントの情報を見る。" | ||||||
|   account-write: "アカウントの情報を操作する。" |   account-write: "アカウントの情報を操作する。" | ||||||
|   note-write: "投稿する。" |   note-write: "Senden." | ||||||
|   like-write: "いいねしたりいいね解除する。" |   like-write: "いいねしたりいいね解除する。" | ||||||
|   following-write: "フォローしたりフォロー解除する。" |   following-write: "フォローしたりフォロー解除する。" | ||||||
|   drive-read: "ドライブを見る。" |   drive-read: "ドライブを見る。" | ||||||
|   drive-write: "ドライブを操作する。" |   drive-write: "ドライブを操作する。" | ||||||
|   notification-read: "通知を見る。" |   notification-read: "通知を見る。" | ||||||
|   notification-write: "通知を操作する。" |   notification-write: "通知を操作する。" | ||||||
|   cancel: "キャンセル" |   cancel: "Abbrechen" | ||||||
|   accept: "アクセスを許可" |   accept: "Zugriff erlauben." | ||||||
| auth/views/index.vue: | auth/views/index.vue: | ||||||
|   loading: "読み込み中" |   loading: "Lädt" | ||||||
|   denied: "アプリケーションの連携をキャンセルしました。" |   denied: "Autorisierung der Anwendung wurde verweigert." | ||||||
|   denied-paragraph: "このアプリがあなたのアカウントにアクセスすることはありません。" |   denied-paragraph: "このアプリがあなたのアカウントにアクセスすることはありません。" | ||||||
|   already-authorized: "このアプリは既に連携済みです" |   already-authorized: "Diese Anwendung ist bereits autorisiert." | ||||||
|   allowed: "アプリケーションの連携を許可しました" |   allowed: "Autorisierung der Anwendung wurde erlaubt." | ||||||
|   callback-url: "アプリケーションに戻っています" |   callback-url: "アプリケーションに戻っています" | ||||||
|   please-go-back: "アプリケーションに戻って、やっていってください。" |   please-go-back: "Bitte gehen Sie zurück zur Anwendung." | ||||||
|   error: "セッションが存在しません。" |   error: "Sitzung ist nicht vorhanden." | ||||||
|   sign-in: "サインインしてください" |   sign-in: "Bitte melde dich an." | ||||||
| common/views/components/games/reversi/reversi.vue: | common/views/components/games/reversi/reversi.vue: | ||||||
|   matching: |   matching: | ||||||
|     waiting-for: "{}を待っています" |     waiting-for: "Warten auf {}" | ||||||
|     cancel: "キャンセル" |     cancel: "Abbrechen" | ||||||
| common/views/components/games/reversi/reversi.game.vue: | common/views/components/games/reversi/reversi.game.vue: | ||||||
|   surrender: "投了" |   surrender: "Aufgeben" | ||||||
|   surrendered: "投了により" |   surrendered: "投了により" | ||||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" |   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||||
|   looped-map: "ループマップ" |   looped-map: "ループマップ" | ||||||
|   can-put-everywhere: "どこでも置けるモード" |   can-put-everywhere: "どこでも置けるモード" | ||||||
| common/views/components/games/reversi/reversi.index.vue: | common/views/components/games/reversi/reversi.index.vue: | ||||||
|   title: "Misskey Reversi" |   title: "Misskey Reversi" | ||||||
|   sub-title: "他のMisskeyユーザーとリバーシで対戦しよう" |   sub-title: "Spiele Reversi mit deinen Freunden!" | ||||||
|   invite: "招待" |   invite: "Einladen" | ||||||
|   rule: "遊び方" |   rule: "Spielanleitung" | ||||||
|   rule-desc: "リバーシは、相手と交互に石をボードに置いて、相手の石を挟んで自分の色に変えてゆき、最終的に残った石が多い方が勝ちというボードゲームです。" |   rule-desc: "リバーシは、相手と交互に石をボードに置いて、相手の石を挟んで自分の色に変えてゆき、最終的に残った石が多い方が勝ちというボードゲームです。" | ||||||
|   mode-invite: "招待" |   mode-invite: "Einladen" | ||||||
|   mode-invite-desc: "指定したユーザーと対戦するモードです。" |   mode-invite-desc: "指定したユーザーと対戦するモードです。" | ||||||
|   invitations: "対局の招待があります!" |   invitations: "対局の招待があります!" | ||||||
|   my-games: "自分の対局" |   my-games: "自分の対局" | ||||||
|   all-games: "みんなの対局" |   all-games: "Alle Spiele" | ||||||
|   enter-username: "ユーザー名を入力してください" |   enter-username: "Bitte gib einen Benutzernamen ein" | ||||||
|   game-state: |   game-state: | ||||||
|     ended: "終了" |     ended: "Fertig" | ||||||
|     playing: "進行中" |     playing: "進行中" | ||||||
| common/views/components/games/reversi/reversi.room.vue: | common/views/components/games/reversi/reversi.room.vue: | ||||||
|   settings-of-the-game: "ゲームの設定" |   settings-of-the-game: "Spieleinstellungen" | ||||||
|   choose-map: "マップを選択" |   choose-map: "Wähle eine Karte" | ||||||
|   random: "ランダム" |   random: "Zufällige Auswahl" | ||||||
|   black-or-white: "先手/後手" |   black-or-white: "Schwarz/Weiß" | ||||||
|   black-is: "{}が黒" |   black-is: "Schwarz ist {}" | ||||||
|   rules: "ルール" |   rules: "Regeln" | ||||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" |   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||||
|   looped-map: "ループマップ" |   looped-map: "ループマップ" | ||||||
|   can-put-everywhere: "どこでも置けるモード" |   can-put-everywhere: "どこでも置けるモード" | ||||||
|   settings-of-the-bot: "Botの設定" |   settings-of-the-bot: "Botの設定" | ||||||
|   this-game-is-started-soon: "ゲームは数秒後に開始されます" |   this-game-is-started-soon: "ゲームは数秒後に開始されます" | ||||||
|   waiting-for-other: "相手の準備が完了するのを待っています" |   waiting-for-other: "Warte auf den Gegner" | ||||||
|   waiting-for-me: "あなたの準備が完了するのを待っています" |   waiting-for-me: "あなたの準備が完了するのを待っています" | ||||||
|   waiting-for-both: "準備中" |   waiting-for-both: "準備中" | ||||||
|   cancel: "キャンセル" |   cancel: "Abbrechen" | ||||||
|   ready: "準備完了" |   ready: "Bereit" | ||||||
|   cancel-ready: "準備続行" |   cancel-ready: "準備続行" | ||||||
| common/views/components/connect-failed.vue: | common/views/components/connect-failed.vue: | ||||||
|   title: "Verbindung zum Server ist fehlgeschlagen" |   title: "Verbindung zum Server ist fehlgeschlagen" | ||||||
| @@ -262,8 +262,43 @@ common/views/components/connect-failed.troubleshooter.vue: | |||||||
|   flush: "Cache leeren" |   flush: "Cache leeren" | ||||||
|   set-version: "Version angeben" |   set-version: "Version angeben" | ||||||
| common/views/components/media-banner.vue: | common/views/components/media-banner.vue: | ||||||
|   sensitive: "閲覧注意" |   sensitive: "Dieser Inhalt ist NSFW" | ||||||
|   click-to-show: "クリックして表示" |   click-to-show: "Klicke zum den Inhalt anzusehen" | ||||||
|  | common/views/components/theme.vue: | ||||||
|  |   light-theme: "Thema" | ||||||
|  |   dark-theme: "Thema während des Nachtmodus" | ||||||
|  |   light-themes: "Helles Thema" | ||||||
|  |   dark-themes: "Dunkles Thema" | ||||||
|  |   install-a-theme: "テーマのインストール" | ||||||
|  |   theme-code: "テーマコード" | ||||||
|  |   install: "Anwenden" | ||||||
|  |   installed: "\"{}\" wurde installiert" | ||||||
|  |   create-a-theme: "Thema erstellen" | ||||||
|  |   save-created-theme: "Thema speichern" | ||||||
|  |   primary-color: "Primäre Farbe" | ||||||
|  |   secondary-color: "Sekundäre Farbe" | ||||||
|  |   text-color: "Textfarbe" | ||||||
|  |   base-theme: "Basisthema" | ||||||
|  |   base-theme-light: "Hell" | ||||||
|  |   base-theme-dark: "Dunkel" | ||||||
|  |   theme-name: "Name des Themas" | ||||||
|  |   preview-created-theme: "Vorschau" | ||||||
|  |   invalid-theme: "Thema ist ungültig" | ||||||
|  |   already-installed: "Thema ist bereits installiert" | ||||||
|  |   saved: "保存しました" | ||||||
|  |   manage-themes: "テーマの管理" | ||||||
|  |   builtin-themes: "標準テーマ" | ||||||
|  |   my-themes: "マイテーマ" | ||||||
|  |   installed-themes: "インストールされたテーマ" | ||||||
|  |   select-theme: "テーマを選択してください" | ||||||
|  |   uninstall: "アンインストール" | ||||||
|  |   uninstalled: "「{}」をアンインストールしました" | ||||||
|  |   author: "Autor" | ||||||
|  |   desc: "説明" | ||||||
|  |   export: "Exportieren" | ||||||
|  |   import: "Importieren" | ||||||
|  |   import-by-code: "またはコードをペースト" | ||||||
|  |   theme-name-required: "テーマ名は必須です。" | ||||||
| common/views/components/cw-button.vue: | common/views/components/cw-button.vue: | ||||||
|   hide: "隠す" |   hide: "隠す" | ||||||
|   show: "もっと見る" |   show: "もっと見る" | ||||||
| @@ -300,7 +335,9 @@ common/views/components/note-menu.vue: | |||||||
|   detail: "詳細" |   detail: "詳細" | ||||||
|   copy-link: "リンクをコピー" |   copy-link: "リンクをコピー" | ||||||
|   favorite: "Diese Anmerkung favorisieren" |   favorite: "Diese Anmerkung favorisieren" | ||||||
|  |   unfavorite: "Entfavorisieren" | ||||||
|   pin: "An die Profilseite pinnen" |   pin: "An die Profilseite pinnen" | ||||||
|  |   unpin: "ピン留め解除" | ||||||
|   delete: "Löschen" |   delete: "Löschen" | ||||||
|   delete-confirm: "Diesen Post löschen?" |   delete-confirm: "Diesen Post löschen?" | ||||||
|   remote: "Auf Quelle anzeigen" |   remote: "Auf Quelle anzeigen" | ||||||
| @@ -325,7 +362,7 @@ common/views/components/signin.vue: | |||||||
|   token: "Token" |   token: "Token" | ||||||
|   signing-in: "Melde an..." |   signing-in: "Melde an..." | ||||||
|   signin: "Anmelden" |   signin: "Anmelden" | ||||||
|   or: "または" |   or: "Oder" | ||||||
|   signin-with-twitter: "Twitterでログイン" |   signin-with-twitter: "Twitterでログイン" | ||||||
|   login-failed: "ログインできませんでした。ユーザー名とパスワードを確認してください。" |   login-failed: "ログインできませんでした。ユーザー名とパスワードを確認してください。" | ||||||
| common/views/components/signup.vue: | common/views/components/signup.vue: | ||||||
| @@ -379,6 +416,25 @@ common/views/components/visibility-chooser.vue: | |||||||
| common/views/components/trends.vue: | common/views/components/trends.vue: | ||||||
|   count: "{}人が投稿" |   count: "{}人が投稿" | ||||||
|   empty: "トレンドなし" |   empty: "トレンドなし" | ||||||
|  | common/views/components/profile-editor.vue: | ||||||
|  |   title: "プロフィール" | ||||||
|  |   name: "名前" | ||||||
|  |   account: "アカウント" | ||||||
|  |   location: "場所" | ||||||
|  |   description: "自己紹介" | ||||||
|  |   birthday: "誕生日" | ||||||
|  |   avatar: "アイコン" | ||||||
|  |   banner: "バナー" | ||||||
|  |   is-cat: "このアカウントはCatです" | ||||||
|  |   is-bot: "このアカウントはBotです" | ||||||
|  |   is-locked: "フォローを承認制にする" | ||||||
|  |   careful-bot: "Botからのフォローだけ承認制にする" | ||||||
|  |   advanced: "その他" | ||||||
|  |   privacy: "プライバシー" | ||||||
|  |   save: "保存" | ||||||
|  |   saved: "プロフィールを保存しました" | ||||||
|  |   uploading: "アップロード中" | ||||||
|  |   upload-failed: "アップロードに失敗しました" | ||||||
| common/views/widgets/broadcast.vue: | common/views/widgets/broadcast.vue: | ||||||
|   fetching: "Laden" |   fetching: "Laden" | ||||||
|   no-broadcasts: "Keine Broadcasts" |   no-broadcasts: "Keine Broadcasts" | ||||||
| @@ -439,6 +495,7 @@ common/views/pages/follow.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| desktop: | desktop: | ||||||
|   banner-crop-title: "バナーとして表示する部分を選択" |   banner-crop-title: "バナーとして表示する部分を選択" | ||||||
| @@ -472,21 +529,21 @@ desktop/views/components/charts.vue: | |||||||
|   notes: "投稿" |   notes: "投稿" | ||||||
|   users: "ユーザー" |   users: "ユーザー" | ||||||
|   drive: "ドライブ" |   drive: "ドライブ" | ||||||
|   network: "ネットワーク" |   network: "Netzwerk" | ||||||
|   charts: |   charts: | ||||||
|     notes: "投稿の増減 (統合)" |     notes: "投稿の増減 (統合)" | ||||||
|     local-notes: "投稿の増減 (ローカル)" |     local-notes: "投稿の増減 (ローカル)" | ||||||
|     remote-notes: "投稿の増減 (リモート)" |     remote-notes: "投稿の増減 (リモート)" | ||||||
|     notes-total: "投稿の累計" |     notes-total: "投稿の積算" | ||||||
|     users: "ユーザーの増減" |     users: "ユーザーの増減" | ||||||
|     users-total: "ユーザーの累計" |     users-total: "ユーザーの積算" | ||||||
|     drive: "ドライブ使用量の増減" |     drive: "ドライブ使用量の増減" | ||||||
|     drive-total: "ドライブ使用量の累計" |     drive-total: "ドライブ使用量の積算" | ||||||
|     drive-files: "ドライブのファイル数の増減" |     drive-files: "ドライブのファイル数の増減" | ||||||
|     drive-files-total: "ドライブのファイル数の累計" |     drive-files-total: "ドライブのファイル数の積算" | ||||||
|     network-requests: "リクエスト" |     network-requests: "Anfragen" | ||||||
|     network-time: "応答時間" |     network-time: "Antwortzeit" | ||||||
|     network-usage: "通信量" |     network-usage: "Datenverkehr" | ||||||
| desktop/views/components/choose-file-from-drive-window.vue: | desktop/views/components/choose-file-from-drive-window.vue: | ||||||
|   choose-file: "Datei auswählen" |   choose-file: "Datei auswählen" | ||||||
|   upload: "Dateien von deinem PC hochladen" |   upload: "Dateien von deinem PC hochladen" | ||||||
| @@ -565,6 +622,7 @@ desktop/views/components/follow-button.vue: | |||||||
|   following: "Folge ich" |   following: "Folge ich" | ||||||
|   follow: "Folgen" |   follow: "Folgen" | ||||||
|   request-pending: "Ausstehend" |   request-pending: "Ausstehend" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "Follower-Anfragen" |   follow-request: "Follower-Anfragen" | ||||||
| desktop/views/components/followers-window.vue: | desktop/views/components/followers-window.vue: | ||||||
|   followers: "{} のフォロワー" |   followers: "{} のフォロワー" | ||||||
| @@ -601,25 +659,25 @@ desktop/views/components/note-detail.vue: | |||||||
|   location: "Ort" |   location: "Ort" | ||||||
|   renote: "Anmerkung" |   renote: "Anmerkung" | ||||||
|   add-reaction: "Reaktion hinzufügen" |   add-reaction: "Reaktion hinzufügen" | ||||||
| desktop/views/components/notes.note.vue: | desktop/views/components/note.vue: | ||||||
|   reposted-by: "Auch geteilt von" |   reposted-by: "{}がRenote" | ||||||
|   reply: "Antworten" |   reply: "返信" | ||||||
|   renote: "Anmerken" |   renote: "Renote" | ||||||
|   add-reaction: "Eine Reaktion hinzufügen" |   add-reaction: "リアクション" | ||||||
|   detail: "Zeige Details" |   detail: "詳細" | ||||||
|   private: "Dieser Beitrag ist eine privat" |   private: "この投稿は非公開です" | ||||||
|   deleted: "Dieser Beitrag wurde entfernt" |   deleted: "この投稿は削除されました" | ||||||
| desktop/views/components/notes.vue: | desktop/views/components/notes.vue: | ||||||
|   error: "Laden fehlgeschlagen." |   error: "Laden fehlgeschlagen." | ||||||
|   retry: "Erneut versuchen" |   retry: "Erneut versuchen" | ||||||
|   load-more: "もっと読み込む" |   load-more: "Mehr laden" | ||||||
| desktop/views/components/notifications.vue: | desktop/views/components/notifications.vue: | ||||||
|   more: "Mehr" |   more: "Mehr" | ||||||
|   empty: "Keine Benachrichtigungen" |   empty: "Keine Benachrichtigungen" | ||||||
| desktop/views/components/post-form.vue: | desktop/views/components/post-form.vue: | ||||||
|   add-visible-user: "+ユーザーを追加" |   add-visible-user: "+Nutzer hinzufügen" | ||||||
|   attach-location-information: "位置情報を添付する" |   attach-location-information: "位置情報を添付する" | ||||||
|   hide-contents: "内容を隠す" |   hide-contents: "Inhalt verstecken" | ||||||
|   reply-placeholder: "Antworte auf diese Anmerkung..." |   reply-placeholder: "Antworte auf diese Anmerkung..." | ||||||
|   quote-placeholder: "Zitiere diese Anmerkung..." |   quote-placeholder: "Zitiere diese Anmerkung..." | ||||||
|   submit: "Beitragsform" |   submit: "Beitragsform" | ||||||
| @@ -640,10 +698,10 @@ desktop/views/components/post-form.vue: | |||||||
|   text-remain: "{} Zeichen verbleibend" |   text-remain: "{} Zeichen verbleibend" | ||||||
|   recent-tags: "最近" |   recent-tags: "最近" | ||||||
|   click-to-tagging: "クリックでタグ付け" |   click-to-tagging: "クリックでタグ付け" | ||||||
|   visibility: "公開範囲" |   visibility: "Sichtbarkeit" | ||||||
|   geolocation-alert: "お使いの端末は位置情報に対応していません" |   geolocation-alert: "お使いの端末は位置情報に対応していません" | ||||||
|   error: "エラー" |   error: "Fehler" | ||||||
|   enter-username: "ユーザー名を入力してください" |   enter-username: "Bitte gib einen Benutzernamen ein..." | ||||||
|   annotations: "内容への注釈 (オプション)" |   annotations: "内容への注釈 (オプション)" | ||||||
| desktop/views/components/post-form-window.vue: | desktop/views/components/post-form-window.vue: | ||||||
|   note: "Neue Notiz" |   note: "Neue Notiz" | ||||||
| @@ -675,6 +733,7 @@ desktop/views/components/settings.vue: | |||||||
|   2fa: "Zwei-Faktor-Authentifizierung" |   2fa: "Zwei-Faktor-Authentifizierung" | ||||||
|   other: "Anderes" |   other: "Anderes" | ||||||
|   license: "Lizenz" |   license: "Lizenz" | ||||||
|  |   theme: "テーマ" | ||||||
|   behaviour: "Verhalten" |   behaviour: "Verhalten" | ||||||
|   fetch-on-scroll: "Aktualisieren beim scrollen" |   fetch-on-scroll: "Aktualisieren beim scrollen" | ||||||
|   fetch-on-scroll-desc: "Wenn du runterscrollst empfängt die Seite automatisch zusätzliche Inhalte." |   fetch-on-scroll-desc: "Wenn du runterscrollst empfängt die Seite automatisch zusätzliche Inhalte." | ||||||
| @@ -686,30 +745,36 @@ desktop/views/components/settings.vue: | |||||||
|   advanced: "Erweiterte Einstellungen" |   advanced: "Erweiterte Einstellungen" | ||||||
|   api-via-stream: "API-Anfrage via stream" |   api-via-stream: "API-Anfrage via stream" | ||||||
|   api-via-stream-desc: "API-Anfrage über WebSocket statt native Aktualisierungs-API (für bessere Leistung). Diese Einstellung wird im Browser gespeichert." |   api-via-stream-desc: "API-Anfrage über WebSocket statt native Aktualisierungs-API (für bessere Leistung). Diese Einstellung wird im Browser gespeichert." | ||||||
|  |   deck-nav: "デッキ内ナビゲーション" | ||||||
|  |   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||||
|  |   deck-default: "デッキをデフォルトのUIにする" | ||||||
|   display: "Erscheinungsbild und Anzeige" |   display: "Erscheinungsbild und Anzeige" | ||||||
|   customize: "Startseite anpassen" |   customize: "Startseite anpassen" | ||||||
|  |   wallpaper: "壁紙" | ||||||
|   choose-wallpaper: "壁紙を選択" |   choose-wallpaper: "壁紙を選択" | ||||||
|   delete-wallpaper: "壁紙を削除" |   delete-wallpaper: "壁紙を削除" | ||||||
|   dark-mode: "Nacht Modus" |   dark-mode: "Nacht Modus" | ||||||
|  |   use-shadow: "UIに影を使用" | ||||||
|  |   rounded-corners: "Abgerundete Ecken" | ||||||
|   circle-icons: "Kreisförmige Icons" |   circle-icons: "Kreisförmige Icons" | ||||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" |   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||||
|   gradient-window-header: "Übergang in Fensterköpfen" |  | ||||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" |   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" |   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||||
|   show-clock-on-header: "右上に時計を表示する" |   show-clock-on-header: "右上に時計を表示する" | ||||||
|   show-reply-target: "Zeige Antworten" |   show-reply-target: "Zeige Antworten" | ||||||
|  |   timeline: "タイムライン" | ||||||
|   show-my-renotes: "Zeige meine Reposts auf der Zeitleiste" |   show-my-renotes: "Zeige meine Reposts auf der Zeitleiste" | ||||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" |   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" |   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||||
|   show-maps: "Karte anzeigen" |   show-maps: "Karte anzeigen" | ||||||
|   show-maps-desc: "Zeige den Standort zu diesem Beitrag automatisch an." |   deck-column-align: "デッキのカラムの位置" | ||||||
|  |   deck-column-align-center: "中央" | ||||||
|  |   deck-column-align-left: "左" | ||||||
|   sound: "Ton" |   sound: "Ton" | ||||||
|   enable-sounds: "Ton aktivieren" |   enable-sounds: "Ton aktivieren" | ||||||
|   enable-sounds-desc: "Spiel einen Ton ab beim Erhalten eines Beitrags bzw. einer Nachricht. Diese Einstellung wird im Browser gespeichert." |   enable-sounds-desc: "Spiel einen Ton ab beim Erhalten eines Beitrags bzw. einer Nachricht. Diese Einstellung wird im Browser gespeichert." | ||||||
|   volume: "Lautstärke" |   volume: "Lautstärke" | ||||||
|   test: "Test" |   test: "Test" | ||||||
|   mobile: "Mobil" |  | ||||||
|   disable-via-mobile: "Diesen Beitrag nicht mit 'vom Handy' absenden" |  | ||||||
|   language: "Sprache" |   language: "Sprache" | ||||||
|   pick-language: "Sprache auswählen" |   pick-language: "Sprache auswählen" | ||||||
|   recommended: "Empfohlen" |   recommended: "Empfohlen" | ||||||
| @@ -745,6 +810,10 @@ desktop/views/components/settings.vue: | |||||||
|   tools: "Werkzeuge" |   tools: "Werkzeuge" | ||||||
|   task-manager: "Taskmanager" |   task-manager: "Taskmanager" | ||||||
|   third-parties: "サードパーティ" |   third-parties: "サードパーティ" | ||||||
|  |   navbar-position: "ナビゲーションバーの位置" | ||||||
|  |   navbar-position-top: "上" | ||||||
|  |   navbar-position-left: "左" | ||||||
|  |   navbar-position-right: "右" | ||||||
| desktop/views/components/settings.2fa.vue: | desktop/views/components/settings.2fa.vue: | ||||||
|   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" |   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" | ||||||
|   detail: "詳細..." |   detail: "詳細..." | ||||||
| @@ -778,26 +847,12 @@ desktop/views/components/settings.drive.vue: | |||||||
| desktop/views/components/settings.mute.vue: | desktop/views/components/settings.mute.vue: | ||||||
|   no-users: "ミュートしているユーザーはいません" |   no-users: "ミュートしているユーザーはいません" | ||||||
| desktop/views/components/settings.password.vue: | desktop/views/components/settings.password.vue: | ||||||
|   reset: "パスワードを変更する" |   reset: "Passwort ändern" | ||||||
|   enter-current-password: "Derzeitiges Passwort eingeben" |   enter-current-password: "Derzeitiges Passwort eingeben" | ||||||
|   enter-new-password: "Neues Passwort eingeben" |   enter-new-password: "Neues Passwort eingeben" | ||||||
|   enter-new-password-again: "Neues Passwort erneut eingeben" |   enter-new-password-again: "Neues Passwort erneut eingeben" | ||||||
|   not-match: "新しいパスワードが一致しません" |   not-match: "Passwörter stimmen nicht überein." | ||||||
|   changed: "パスワードを変更しました" |   changed: "Passwort geändert" | ||||||
| desktop/views/components/settings.profile.vue: |  | ||||||
|   avatar: "アイコン" |  | ||||||
|   choice-avatar: "画像を選択" |  | ||||||
|   name: "名前" |  | ||||||
|   location: "場所" |  | ||||||
|   description: "自己紹介" |  | ||||||
|   birthday: "誕生日" |  | ||||||
|   save: "Profil aktualisieren" |  | ||||||
|   locked-account: "アカウントの保護" |  | ||||||
|   is-locked: "フォローを承認制にする" |  | ||||||
|   other: "その他" |  | ||||||
|   is-bot: "このアカウントはBotです" |  | ||||||
|   is-cat: "このアカウントはCatです" |  | ||||||
|   profile-updated: "プロフィールを更新しました" |  | ||||||
| desktop/views/components/sub-note-content.vue: | desktop/views/components/sub-note-content.vue: | ||||||
|   private: "この投稿は非公開です" |   private: "この投稿は非公開です" | ||||||
|   deleted: "この投稿は削除されました" |   deleted: "この投稿は削除されました" | ||||||
| @@ -857,7 +912,7 @@ desktop/views/components/user-preview.vue: | |||||||
| desktop/views/components/users-list.vue: | desktop/views/components/users-list.vue: | ||||||
|   all: "すべて" |   all: "すべて" | ||||||
|   iknow: "知り合い" |   iknow: "知り合い" | ||||||
|   load-more: "もっと" |   load-more: "Mehr" | ||||||
|   fetching: "Lade…" |   fetching: "Lade…" | ||||||
| desktop/views/components/users-list-item.vue: | desktop/views/components/users-list-item.vue: | ||||||
|   followed: "フォローされています" |   followed: "フォローされています" | ||||||
| @@ -896,10 +951,8 @@ desktop/views/pages/deck/deck.tl-column.vue: | |||||||
|   is-media-only: "メディア投稿のみ" |   is-media-only: "メディア投稿のみ" | ||||||
|   is-media-view: "メディアビュー" |   is-media-view: "メディアビュー" | ||||||
|   edit: "オプション" |   edit: "オプション" | ||||||
| desktop/views/pages/deck/deck.note.vue: | desktop/views/pages/deck/deck.user-column.vue: | ||||||
|   reposted-by: "{}がRenote" |   pinned-notes: "ピン留めされた投稿" | ||||||
|   private: "この投稿は非公開です" |  | ||||||
|   deleted: "この投稿は削除されました" |  | ||||||
| desktop/views/pages/stats/stats.vue: | desktop/views/pages/stats/stats.vue: | ||||||
|   all-users: "全てのユーザー" |   all-users: "全てのユーザー" | ||||||
|   original-users: "このインスタンスのユーザー" |   original-users: "このインスタンスのユーザー" | ||||||
| @@ -1034,6 +1087,8 @@ mobile/views/components/drive.file-detail.vue: | |||||||
|   hash: "ハッシュ (md5)" |   hash: "ハッシュ (md5)" | ||||||
|   exif: "EXIF" |   exif: "EXIF" | ||||||
|   nsfw: "閲覧注意" |   nsfw: "閲覧注意" | ||||||
|  |   mark-as-sensitive: "閲覧注意に設定" | ||||||
|  |   unmark-as-sensitive: "閲覧注意を解除" | ||||||
| mobile/views/components/media-image.vue: | mobile/views/components/media-image.vue: | ||||||
|   sensitive: "閲覧注意" |   sensitive: "閲覧注意" | ||||||
|   click-to-show: "クリックして表示" |   click-to-show: "クリックして表示" | ||||||
| @@ -1044,6 +1099,7 @@ mobile/views/components/follow-button.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| mobile/views/components/friends-maker.vue: | mobile/views/components/friends-maker.vue: | ||||||
|   title: "気になるユーザーをフォロー" |   title: "気になるユーザーをフォロー" | ||||||
| @@ -1117,19 +1173,19 @@ mobile/views/components/ui.nav.vue: | |||||||
| mobile/views/components/user-timeline.vue: | mobile/views/components/user-timeline.vue: | ||||||
|   no-notes: "このユーザーは投稿していないようです。" |   no-notes: "このユーザーは投稿していないようです。" | ||||||
|   no-notes-with-media: "メディア付き投稿はありません。" |   no-notes-with-media: "メディア付き投稿はありません。" | ||||||
|   load-more: "もっと" |   load-more: "Mehr" | ||||||
| mobile/views/components/users-list.vue: | mobile/views/components/users-list.vue: | ||||||
|   all: "すべて" |   all: "すべて" | ||||||
|   known: "知り合い" |   known: "知り合い" | ||||||
|   load-more: "もっと" |   load-more: "Mehr" | ||||||
| mobile/views/pages/favorites.vue: | mobile/views/pages/favorites.vue: | ||||||
|   title: "お気に入り" |   title: "Favoriten" | ||||||
| mobile/views/pages/user-lists.vue: | mobile/views/pages/user-lists.vue: | ||||||
|   title: "リスト" |   title: "リスト" | ||||||
|   enter-list-name: "リスト名を入力してください" |   enter-list-name: "リスト名を入力してください" | ||||||
| mobile/views/pages/drive.vue: | mobile/views/pages/drive.vue: | ||||||
|   drive: "ドライブ" |   drive: "ドライブ" | ||||||
|   more: "もっと見る" |   more: "Mehr laden" | ||||||
| mobile/views/pages/signup.vue: | mobile/views/pages/signup.vue: | ||||||
|   lets-start: "📦 始めましょう" |   lets-start: "📦 始めましょう" | ||||||
| mobile/views/pages/followers.vue: | mobile/views/pages/followers.vue: | ||||||
| @@ -1173,23 +1229,6 @@ mobile/views/pages/notifications.vue: | |||||||
|   read-all: "すべての通知を既読にしますか?" |   read-all: "すべての通知を既読にしますか?" | ||||||
| mobile/views/pages/games/reversi.vue: | mobile/views/pages/games/reversi.vue: | ||||||
|   reversi: "リバーシ" |   reversi: "リバーシ" | ||||||
| mobile/views/pages/settings/settings.profile.vue: |  | ||||||
|   title: "Profil" |  | ||||||
|   name: "名前" |  | ||||||
|   account: "アカウント" |  | ||||||
|   location: "場所" |  | ||||||
|   description: "自己紹介" |  | ||||||
|   birthday: "誕生日" |  | ||||||
|   avatar: "アイコン" |  | ||||||
|   banner: "バナー" |  | ||||||
|   is-cat: "このアカウントはCatです" |  | ||||||
|   is-locked: "フォローを承認制にする" |  | ||||||
|   advanced: "その他" |  | ||||||
|   privacy: "プライバシー" |  | ||||||
|   save: "保存" |  | ||||||
|   saved: "Profil wurde aktualisiert" |  | ||||||
|   uploading: "アップロード中" |  | ||||||
|   upload-failed: "アップロードに失敗しました" |  | ||||||
| mobile/views/pages/search.vue: | mobile/views/pages/search.vue: | ||||||
|   search: "検索" |   search: "検索" | ||||||
|   empty: "「{}」に関する投稿は見つかりませんでした。" |   empty: "「{}」に関する投稿は見つかりませんでした。" | ||||||
| @@ -1219,6 +1258,7 @@ mobile/views/pages/settings.vue: | |||||||
|   notification-position: "通知の表示" |   notification-position: "通知の表示" | ||||||
|   notification-position-bottom: "下" |   notification-position-bottom: "下" | ||||||
|   notification-position-top: "上" |   notification-position-top: "上" | ||||||
|  |   theme: "テーマ" | ||||||
|   behavior: "動作" |   behavior: "動作" | ||||||
|   fetch-on-scroll: "スクロールで自動読み込み" |   fetch-on-scroll: "スクロールで自動読み込み" | ||||||
|   note-visibility: "投稿の公開範囲" |   note-visibility: "投稿の公開範囲" | ||||||
| @@ -1259,7 +1299,7 @@ mobile/views/pages/user/home.vue: | |||||||
|   recent-notes: "最近の投稿" |   recent-notes: "最近の投稿" | ||||||
|   images: "画像" |   images: "画像" | ||||||
|   activity: "アクティビティ" |   activity: "アクティビティ" | ||||||
|   keywords: "キーワード" |   keywords: "Schlagwörter" | ||||||
|   domains: "頻出ドメイン" |   domains: "頻出ドメイン" | ||||||
|   frequently-replied-users: "よく会話するユーザー" |   frequently-replied-users: "よく会話するユーザー" | ||||||
|   followers-you-know: "知り合いのフォロワー" |   followers-you-know: "知り合いのフォロワー" | ||||||
|   | |||||||
| @@ -109,8 +109,8 @@ common: | |||||||
|   use-contrast-reversi-stones: "Make the stone color clear in reversi" |   use-contrast-reversi-stones: "Make the stone color clear in reversi" | ||||||
|   verified-user: "Verified account" |   verified-user: "Verified account" | ||||||
|   disable-animated-mfm: "Disable animated texts in a post" |   disable-animated-mfm: "Disable animated texts in a post" | ||||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" |   always-show-nsfw: "Always show NSFW contents" | ||||||
|   always-mark-nsfw: "Always post with a warning about media attachment" |   always-mark-nsfw: "Always mark posts with media attachments as NSFW" | ||||||
|   show-full-acct: "Do not omit the hostname from the username" |   show-full-acct: "Do not omit the hostname from the username" | ||||||
|   reduce-motion: "Reduce motion in UI" |   reduce-motion: "Reduce motion in UI" | ||||||
|   this-setting-is-this-device-only: "Only for this device" |   this-setting-is-this-device-only: "Only for this device" | ||||||
| @@ -158,7 +158,7 @@ common: | |||||||
|     hashtag: "Hashtag" |     hashtag: "Hashtag" | ||||||
|     global: "Global" |     global: "Global" | ||||||
|     mentions: "Mentions" |     mentions: "Mentions" | ||||||
|     direct: "ダイレクト投稿" |     direct: "Direct post" | ||||||
|     notifications: "Notifications" |     notifications: "Notifications" | ||||||
|     list: "Lists" |     list: "Lists" | ||||||
|     swap-left: "Move to the left" |     swap-left: "Move to the left" | ||||||
| @@ -264,6 +264,41 @@ common/views/components/connect-failed.troubleshooter.vue: | |||||||
| common/views/components/media-banner.vue: | common/views/components/media-banner.vue: | ||||||
|   sensitive: "NSFW" |   sensitive: "NSFW" | ||||||
|   click-to-show: "Click to show" |   click-to-show: "Click to show" | ||||||
|  | common/views/components/theme.vue: | ||||||
|  |   light-theme: "Theme" | ||||||
|  |   dark-theme: "Theme during dark mode" | ||||||
|  |   light-themes: "Light theme" | ||||||
|  |   dark-themes: "Dark theme" | ||||||
|  |   install-a-theme: "Install a theme" | ||||||
|  |   theme-code: "Theme code" | ||||||
|  |   install: "Install" | ||||||
|  |   installed: "\"{}\" has been installed" | ||||||
|  |   create-a-theme: "Create a theme" | ||||||
|  |   save-created-theme: "Save a theme" | ||||||
|  |   primary-color: "Primary color" | ||||||
|  |   secondary-color: "Secondary color" | ||||||
|  |   text-color: "Text color" | ||||||
|  |   base-theme: "Base theme" | ||||||
|  |   base-theme-light: "Light" | ||||||
|  |   base-theme-dark: "Dark" | ||||||
|  |   theme-name: "Theme name" | ||||||
|  |   preview-created-theme: "Preview" | ||||||
|  |   invalid-theme: "Not valid theme" | ||||||
|  |   already-installed: "This theme is already installed." | ||||||
|  |   saved: "Saved" | ||||||
|  |   manage-themes: "Themes manager" | ||||||
|  |   builtin-themes: "Standard themes" | ||||||
|  |   my-themes: "My themes" | ||||||
|  |   installed-themes: "Installed themes" | ||||||
|  |   select-theme: "Select your theme" | ||||||
|  |   uninstall: "Uninstall" | ||||||
|  |   uninstalled: "\"{}\" has been uninstalled" | ||||||
|  |   author: "Author" | ||||||
|  |   desc: "Description" | ||||||
|  |   export: "Export" | ||||||
|  |   import: "Import" | ||||||
|  |   import-by-code: "or paste code" | ||||||
|  |   theme-name-required: "Theme name is required" | ||||||
| common/views/components/cw-button.vue: | common/views/components/cw-button.vue: | ||||||
|   hide: "Hide" |   hide: "Hide" | ||||||
|   show: "See more" |   show: "See more" | ||||||
| @@ -300,7 +335,9 @@ common/views/components/note-menu.vue: | |||||||
|   detail: "Details" |   detail: "Details" | ||||||
|   copy-link: "Copy link" |   copy-link: "Copy link" | ||||||
|   favorite: "Favorite this note" |   favorite: "Favorite this note" | ||||||
|  |   unfavorite: "Unfavorite" | ||||||
|   pin: "Pin to your profile" |   pin: "Pin to your profile" | ||||||
|  |   unpin: "Unpin" | ||||||
|   delete: "Delete" |   delete: "Delete" | ||||||
|   delete-confirm: "Delete this post?" |   delete-confirm: "Delete this post?" | ||||||
|   remote: "Show original note" |   remote: "Show original note" | ||||||
| @@ -379,6 +416,25 @@ common/views/components/visibility-chooser.vue: | |||||||
| common/views/components/trends.vue: | common/views/components/trends.vue: | ||||||
|   count: "{} users mentioned" |   count: "{} users mentioned" | ||||||
|   empty: "No popular hashtag trends" |   empty: "No popular hashtag trends" | ||||||
|  | common/views/components/profile-editor.vue: | ||||||
|  |   title: "Profile" | ||||||
|  |   name: "Name" | ||||||
|  |   account: "Account" | ||||||
|  |   location: "Location" | ||||||
|  |   description: "About me" | ||||||
|  |   birthday: "Birthday" | ||||||
|  |   avatar: "Avatar" | ||||||
|  |   banner: "Banner" | ||||||
|  |   is-cat: "This account is a Cat" | ||||||
|  |   is-bot: "This account is a Bot" | ||||||
|  |   is-locked: "Follower requests require approval" | ||||||
|  |   careful-bot: "Follower requests from bots require approval" | ||||||
|  |   advanced: "Advanced" | ||||||
|  |   privacy: "Privacy" | ||||||
|  |   save: "Update profile" | ||||||
|  |   saved: "Profile updated successfully" | ||||||
|  |   uploading: "Uploading" | ||||||
|  |   upload-failed: "Failed to upload" | ||||||
| common/views/widgets/broadcast.vue: | common/views/widgets/broadcast.vue: | ||||||
|   fetching: "Fetching" |   fetching: "Fetching" | ||||||
|   no-broadcasts: "No announcements" |   no-broadcasts: "No announcements" | ||||||
| @@ -426,7 +482,7 @@ common/views/widgets/tips.vue: | |||||||
|   tips-line10: "Using the Time Machine widget makes it easy to trace back to the past timeline." |   tips-line10: "Using the Time Machine widget makes it easy to trace back to the past timeline." | ||||||
|   tips-line11: "You can pin posts to user page by clicking on \"...\"" |   tips-line11: "You can pin posts to user page by clicking on \"...\"" | ||||||
|   tips-line13: "All the files attached to the post are saved to Drive." |   tips-line13: "All the files attached to the post are saved to Drive." | ||||||
|   tips-line14: "While customizing the home, you can right click on the widget and change the design." |   tips-line14: "While customizing your home layout, you can right click on a widget to change its design." | ||||||
|   tips-line17: "Surrounding the text with ** ** will highlight it." |   tips-line17: "Surrounding the text with ** ** will highlight it." | ||||||
|   tips-line19: "Several windows can be detached outside the browser." |   tips-line19: "Several windows can be detached outside the browser." | ||||||
|   tips-line20: "The percentage of the calendar widget shows the percentage of time elapsed." |   tips-line20: "The percentage of the calendar widget shows the percentage of time elapsed." | ||||||
| @@ -439,6 +495,7 @@ common/views/pages/follow.vue: | |||||||
|   following: "Following" |   following: "Following" | ||||||
|   follow: "Follow" |   follow: "Follow" | ||||||
|   request-pending: "Pending follow request" |   request-pending: "Pending follow request" | ||||||
|  |   follow-processing: "Processing follow" | ||||||
|   follow-request: "Follow request" |   follow-request: "Follow request" | ||||||
| desktop: | desktop: | ||||||
|   banner-crop-title: "Crop the part that appears as a banner" |   banner-crop-title: "Crop the part that appears as a banner" | ||||||
| @@ -477,13 +534,13 @@ desktop/views/components/charts.vue: | |||||||
|     notes: "The number of posts: increase/decrease (Combined)" |     notes: "The number of posts: increase/decrease (Combined)" | ||||||
|     local-notes: "The number of posts: increase/decrease (Local)" |     local-notes: "The number of posts: increase/decrease (Local)" | ||||||
|     remote-notes: "The number of posts: increase/decrease (Remote)" |     remote-notes: "The number of posts: increase/decrease (Remote)" | ||||||
|     notes-total: "The number of posts: cumulative total" |     notes-total: "Total posts" | ||||||
|     users: "The number of users: increase/decrease" |     users: "The number of users: increase/decrease" | ||||||
|     users-total: "The number of users: cumulative total" |     users-total: "Total users" | ||||||
|     drive: "Capacity used as the storage: increase/decrease" |     drive: "Capacity used as the storage: increase/decrease" | ||||||
|     drive-total: "Capacity used as the storage: cumulative total" |     drive-total: "Total usage of Drive" | ||||||
|     drive-files: "The number of files on the storage: increase/decrease" |     drive-files: "The number of files on the storage: increase/decrease" | ||||||
|     drive-files-total: "The number of files on the storage: cumulative total" |     drive-files-total: "Total number of files on Drive" | ||||||
|     network-requests: "Requests" |     network-requests: "Requests" | ||||||
|     network-time: "Response time" |     network-time: "Response time" | ||||||
|     network-usage: "Traffic" |     network-usage: "Traffic" | ||||||
| @@ -565,6 +622,7 @@ desktop/views/components/follow-button.vue: | |||||||
|   following: "Following" |   following: "Following" | ||||||
|   follow: "Follow" |   follow: "Follow" | ||||||
|   request-pending: "Pending follow request" |   request-pending: "Pending follow request" | ||||||
|  |   follow-processing: "Processing follow" | ||||||
|   follow-request: "Follow request" |   follow-request: "Follow request" | ||||||
| desktop/views/components/followers-window.vue: | desktop/views/components/followers-window.vue: | ||||||
|   followers: "{}'s followers" |   followers: "{}'s followers" | ||||||
| @@ -601,14 +659,14 @@ desktop/views/components/note-detail.vue: | |||||||
|   location: "Location" |   location: "Location" | ||||||
|   renote: "Repost" |   renote: "Repost" | ||||||
|   add-reaction: "Add a reaction" |   add-reaction: "Add a reaction" | ||||||
| desktop/views/components/notes.note.vue: | desktop/views/components/note.vue: | ||||||
|   reposted-by: "Reposted by {}" |   reposted-by: "Reposted by {}" | ||||||
|   reply: "Reply" |   reply: "Reply" | ||||||
|   renote: "Repost" |   renote: "Renote" | ||||||
|   add-reaction: "Add a reaction" |   add-reaction: "Add a reaction" | ||||||
|   detail: "Show details" |   detail: "Details" | ||||||
|   private: "Post is private" |   private: "This post is private" | ||||||
|   deleted: "Post has been deleted" |   deleted: "This post has been deleted" | ||||||
| desktop/views/components/notes.vue: | desktop/views/components/notes.vue: | ||||||
|   error: "Loading failed." |   error: "Loading failed." | ||||||
|   retry: "Retry" |   retry: "Retry" | ||||||
| @@ -675,6 +733,7 @@ desktop/views/components/settings.vue: | |||||||
|   2fa: "Two-factor authentication" |   2fa: "Two-factor authentication" | ||||||
|   other: "Other" |   other: "Other" | ||||||
|   license: "License" |   license: "License" | ||||||
|  |   theme: "Theme" | ||||||
|   behaviour: "Behavior" |   behaviour: "Behavior" | ||||||
|   fetch-on-scroll: "Endless loading on scroll" |   fetch-on-scroll: "Endless loading on scroll" | ||||||
|   fetch-on-scroll-desc: "When you scroll down the page, it automatically fetches additional content." |   fetch-on-scroll-desc: "When you scroll down the page, it automatically fetches additional content." | ||||||
| @@ -686,30 +745,36 @@ desktop/views/components/settings.vue: | |||||||
|   advanced: "Advanced settings" |   advanced: "Advanced settings" | ||||||
|   api-via-stream: "API request via stream" |   api-via-stream: "API request via stream" | ||||||
|   api-via-stream-desc: "API request is performed via the WebSocket connection instead of native fetch API (for better performance). This setting is stored in the browser." |   api-via-stream-desc: "API request is performed via the WebSocket connection instead of native fetch API (for better performance). This setting is stored in the browser." | ||||||
|  |   deck-nav: "デッキ内ナビゲーション" | ||||||
|  |   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||||
|  |   deck-default: "デッキをデフォルトのUIにする" | ||||||
|   display: "Design and display" |   display: "Design and display" | ||||||
|   customize: "Customize home layout" |   customize: "Customize home layout" | ||||||
|  |   wallpaper: "Wallpaper" | ||||||
|   choose-wallpaper: "Choose a background" |   choose-wallpaper: "Choose a background" | ||||||
|   delete-wallpaper: "Remove background" |   delete-wallpaper: "Remove background" | ||||||
|   dark-mode: "Dark Mode" |   dark-mode: "Dark Mode" | ||||||
|  |   use-shadow: "Use shadows in the UI" | ||||||
|  |   rounded-corners: "Round corners of UI" | ||||||
|   circle-icons: "Use circle icons" |   circle-icons: "Use circle icons" | ||||||
|   contrasted-acct: "Add contrast to username" |   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" |   post-form-on-timeline: "Display post form at the top of the timeline" | ||||||
|   suggest-recent-hashtags: "Show recent popular hashtags on the post form" |   suggest-recent-hashtags: "Show recent popular hashtags on the post form" | ||||||
|   show-clock-on-header: "Show clock on upper-right" |   show-clock-on-header: "Show clock on upper-right" | ||||||
|   show-reply-target: "Display reply target" |   show-reply-target: "Display reply target" | ||||||
|  |   timeline: "Timeline" | ||||||
|   show-my-renotes: "Show my renotes in the timeline" |   show-my-renotes: "Show my renotes in the timeline" | ||||||
|   show-renoted-my-notes: "Show renoted my posts in timelines" |   show-renoted-my-notes: "Show renoted my posts in timelines" | ||||||
|   show-local-renotes: "Show renoted local posts in timelines" |   show-local-renotes: "Show renoted local posts in timelines" | ||||||
|   show-maps: "Display a map to show the location" |   show-maps: "Display a map to show the location" | ||||||
|   show-maps-desc: "If there comes a post contains location information, show a map to display the location." |   deck-column-align: "Deck column alignment" | ||||||
|  |   deck-column-align-center: "Center" | ||||||
|  |   deck-column-align-left: "Left" | ||||||
|   sound: "Sound" |   sound: "Sound" | ||||||
|   enable-sounds: "Enable sound" |   enable-sounds: "Enable sound" | ||||||
|   enable-sounds-desc: "Play a sound when you receive a post/message. This setting is stored in the browser." |   enable-sounds-desc: "Play a sound when you receive a post/message. This setting is stored in the browser." | ||||||
|   volume: "Volume" |   volume: "Volume" | ||||||
|   test: "Test" |   test: "Test" | ||||||
|   mobile: "Mobile" |  | ||||||
|   disable-via-mobile: "Don't mark the post as 'from mobile'" |  | ||||||
|   language: "Language" |   language: "Language" | ||||||
|   pick-language: "Select a language" |   pick-language: "Select a language" | ||||||
|   recommended: "Recommended" |   recommended: "Recommended" | ||||||
| @@ -745,6 +810,10 @@ desktop/views/components/settings.vue: | |||||||
|   tools: "Tools" |   tools: "Tools" | ||||||
|   task-manager: "Task Manager" |   task-manager: "Task Manager" | ||||||
|   third-parties: "Third-parties" |   third-parties: "Third-parties" | ||||||
|  |   navbar-position: "Navigation bar position" | ||||||
|  |   navbar-position-top: "Top" | ||||||
|  |   navbar-position-left: "Left" | ||||||
|  |   navbar-position-right: "Right" | ||||||
| desktop/views/components/settings.2fa.vue: | desktop/views/components/settings.2fa.vue: | ||||||
|   intro: "If you set up 2-step verification, you will not only need a password at sign-in, but also a pre-registered physical device (such as your smartphone), which will improve security." |   intro: "If you set up 2-step verification, you will not only need a password at sign-in, but also a pre-registered physical device (such as your smartphone), which will improve security." | ||||||
|   detail: "Details…" |   detail: "Details…" | ||||||
| @@ -784,20 +853,6 @@ desktop/views/components/settings.password.vue: | |||||||
|   enter-new-password-again: "Enter new password again" |   enter-new-password-again: "Enter new password again" | ||||||
|   not-match: "The new passwords do not match" |   not-match: "The new passwords do not match" | ||||||
|   changed: "Password updated" |   changed: "Password updated" | ||||||
| desktop/views/components/settings.profile.vue: |  | ||||||
|   avatar: "Avatar" |  | ||||||
|   choice-avatar: "Select an image" |  | ||||||
|   name: "Name" |  | ||||||
|   location: "Location" |  | ||||||
|   description: "Description" |  | ||||||
|   birthday: "Birthday" |  | ||||||
|   save: "Update profile" |  | ||||||
|   locked-account: "Protect your account" |  | ||||||
|   is-locked: "Follow request needs approval" |  | ||||||
|   other: "Other" |  | ||||||
|   is-bot: "This account is a Bot" |  | ||||||
|   is-cat: "This account is a Cat" |  | ||||||
|   profile-updated: "Your profile has been updated" |  | ||||||
| desktop/views/components/sub-note-content.vue: | desktop/views/components/sub-note-content.vue: | ||||||
|   private: "This post is private" |   private: "This post is private" | ||||||
|   deleted: "This post has been deleted" |   deleted: "This post has been deleted" | ||||||
| @@ -830,7 +885,7 @@ desktop/views/components/ui.header.account.vue: | |||||||
|   admin: "Admin" |   admin: "Admin" | ||||||
|   settings: "Settings" |   settings: "Settings" | ||||||
|   signout: "Sign out" |   signout: "Sign out" | ||||||
|   dark: "Submerge in dark" |   dark: "Toggle dark mode" | ||||||
| desktop/views/components/ui.header.nav.vue: | desktop/views/components/ui.header.nav.vue: | ||||||
|   home: "Home" |   home: "Home" | ||||||
|   deck: "Deck" |   deck: "Deck" | ||||||
| @@ -896,10 +951,8 @@ desktop/views/pages/deck/deck.tl-column.vue: | |||||||
|   is-media-only: "Only media posts" |   is-media-only: "Only media posts" | ||||||
|   is-media-view: "Media view" |   is-media-view: "Media view" | ||||||
|   edit: "Options" |   edit: "Options" | ||||||
| desktop/views/pages/deck/deck.note.vue: | desktop/views/pages/deck/deck.user-column.vue: | ||||||
|   reposted-by: "Reposted by {}" |   pinned-notes: "Pinned posts" | ||||||
|   private: "This post is private" |  | ||||||
|   deleted: "This post has been deleted" |  | ||||||
| desktop/views/pages/stats/stats.vue: | desktop/views/pages/stats/stats.vue: | ||||||
|   all-users: "All Users" |   all-users: "All Users" | ||||||
|   original-users: "Users on this instance" |   original-users: "Users on this instance" | ||||||
| @@ -914,7 +967,7 @@ desktop/views/pages/welcome.vue: | |||||||
|   signup-button: "Sign up" |   signup-button: "Sign up" | ||||||
|   timeline: "Timeline" |   timeline: "Timeline" | ||||||
|   announcements: "Announcements" |   announcements: "Announcements" | ||||||
|   photos: "Recent uploaded" |   photos: "Recent Images" | ||||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." |   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||||
|   info: "Information" |   info: "Information" | ||||||
| desktop/views/pages/drive.vue: | desktop/views/pages/drive.vue: | ||||||
| @@ -1034,6 +1087,8 @@ mobile/views/components/drive.file-detail.vue: | |||||||
|   hash: "Hash (md5)" |   hash: "Hash (md5)" | ||||||
|   exif: "EXIF" |   exif: "EXIF" | ||||||
|   nsfw: "NSFW" |   nsfw: "NSFW" | ||||||
|  |   mark-as-sensitive: "Mark as 'sensitive'" | ||||||
|  |   unmark-as-sensitive: "Unmark as 'sensitive'" | ||||||
| mobile/views/components/media-image.vue: | mobile/views/components/media-image.vue: | ||||||
|   sensitive: "NSFW" |   sensitive: "NSFW" | ||||||
|   click-to-show: "Click to show" |   click-to-show: "Click to show" | ||||||
| @@ -1044,6 +1099,7 @@ mobile/views/components/follow-button.vue: | |||||||
|   following: "Following" |   following: "Following" | ||||||
|   follow: "Follow" |   follow: "Follow" | ||||||
|   request-pending: "Pending follow request" |   request-pending: "Pending follow request" | ||||||
|  |   follow-processing: "Processing follow" | ||||||
|   follow-request: "Follow request" |   follow-request: "Follow request" | ||||||
| mobile/views/components/friends-maker.vue: | mobile/views/components/friends-maker.vue: | ||||||
|   title: "Let's follow them" |   title: "Let's follow them" | ||||||
| @@ -1116,7 +1172,7 @@ mobile/views/components/ui.nav.vue: | |||||||
|   about: "About Misskey" |   about: "About Misskey" | ||||||
| mobile/views/components/user-timeline.vue: | mobile/views/components/user-timeline.vue: | ||||||
|   no-notes: "It seems this user hasn't posted anything yet." |   no-notes: "It seems this user hasn't posted anything yet." | ||||||
|   no-notes-with-media: "There are no posts attaching media" |   no-notes-with-media: "There are no notes with media attachments" | ||||||
|   load-more: "More" |   load-more: "More" | ||||||
| mobile/views/components/users-list.vue: | mobile/views/components/users-list.vue: | ||||||
|   all: "All" |   all: "All" | ||||||
| @@ -1173,23 +1229,6 @@ mobile/views/pages/notifications.vue: | |||||||
|   read-all: "Do you wish to mark all notifications as read?" |   read-all: "Do you wish to mark all notifications as read?" | ||||||
| mobile/views/pages/games/reversi.vue: | mobile/views/pages/games/reversi.vue: | ||||||
|   reversi: "Reversi" |   reversi: "Reversi" | ||||||
| mobile/views/pages/settings/settings.profile.vue: |  | ||||||
|   title: "Profile" |  | ||||||
|   name: "Name" |  | ||||||
|   account: "Account" |  | ||||||
|   location: "Location" |  | ||||||
|   description: "Biography" |  | ||||||
|   birthday: "Birthday" |  | ||||||
|   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" |  | ||||||
|   upload-failed: "Failed to upload" |  | ||||||
| mobile/views/pages/search.vue: | mobile/views/pages/search.vue: | ||||||
|   search: "Search" |   search: "Search" | ||||||
|   empty: "No posts were found for '{}'" |   empty: "No posts were found for '{}'" | ||||||
| @@ -1219,6 +1258,7 @@ mobile/views/pages/settings.vue: | |||||||
|   notification-position: "Notification style" |   notification-position: "Notification style" | ||||||
|   notification-position-bottom: "Bottom" |   notification-position-bottom: "Bottom" | ||||||
|   notification-position-top: "Top" |   notification-position-top: "Top" | ||||||
|  |   theme: "Theme" | ||||||
|   behavior: "Behavior" |   behavior: "Behavior" | ||||||
|   fetch-on-scroll: "Endless loading on scroll" |   fetch-on-scroll: "Endless loading on scroll" | ||||||
|   note-visibility: "Post visibility" |   note-visibility: "Post visibility" | ||||||
|   | |||||||
| @@ -264,6 +264,41 @@ common/views/components/connect-failed.troubleshooter.vue: | |||||||
| common/views/components/media-banner.vue: | common/views/components/media-banner.vue: | ||||||
|   sensitive: "閲覧注意" |   sensitive: "閲覧注意" | ||||||
|   click-to-show: "クリックして表示" |   click-to-show: "クリックして表示" | ||||||
|  | common/views/components/theme.vue: | ||||||
|  |   light-theme: "非ダークモード時に使用するテーマ" | ||||||
|  |   dark-theme: "ダークモード時に使用するテーマ" | ||||||
|  |   light-themes: "明るいテーマ" | ||||||
|  |   dark-themes: "暗いテーマ" | ||||||
|  |   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: "保存しました" | ||||||
|  |   manage-themes: "テーマの管理" | ||||||
|  |   builtin-themes: "標準テーマ" | ||||||
|  |   my-themes: "マイテーマ" | ||||||
|  |   installed-themes: "インストールされたテーマ" | ||||||
|  |   select-theme: "テーマを選択してください" | ||||||
|  |   uninstall: "アンインストール" | ||||||
|  |   uninstalled: "「{}」をアンインストールしました" | ||||||
|  |   author: "作者" | ||||||
|  |   desc: "説明" | ||||||
|  |   export: "エクスポート" | ||||||
|  |   import: "インポート" | ||||||
|  |   import-by-code: "またはコードをペースト" | ||||||
|  |   theme-name-required: "テーマ名は必須です。" | ||||||
| common/views/components/cw-button.vue: | common/views/components/cw-button.vue: | ||||||
|   hide: "隠す" |   hide: "隠す" | ||||||
|   show: "もっと見る" |   show: "もっと見る" | ||||||
| @@ -300,7 +335,9 @@ common/views/components/note-menu.vue: | |||||||
|   detail: "Detalles" |   detail: "Detalles" | ||||||
|   copy-link: "Copiar enlace" |   copy-link: "Copiar enlace" | ||||||
|   favorite: "Me gusta esta nota" |   favorite: "Me gusta esta nota" | ||||||
|  |   unfavorite: "お気に入り解除" | ||||||
|   pin: "Fijar en el perfil" |   pin: "Fijar en el perfil" | ||||||
|  |   unpin: "ピン留め解除" | ||||||
|   delete: "Borrar" |   delete: "Borrar" | ||||||
|   delete-confirm: "¿Seguro que quieres borrar la publicación?" |   delete-confirm: "¿Seguro que quieres borrar la publicación?" | ||||||
|   remote: "Ver el original" |   remote: "Ver el original" | ||||||
| @@ -379,6 +416,25 @@ common/views/components/visibility-chooser.vue: | |||||||
| common/views/components/trends.vue: | common/views/components/trends.vue: | ||||||
|   count: "{}人が投稿" |   count: "{}人が投稿" | ||||||
|   empty: "トレンドなし" |   empty: "トレンドなし" | ||||||
|  | common/views/components/profile-editor.vue: | ||||||
|  |   title: "プロフィール" | ||||||
|  |   name: "名前" | ||||||
|  |   account: "アカウント" | ||||||
|  |   location: "場所" | ||||||
|  |   description: "自己紹介" | ||||||
|  |   birthday: "誕生日" | ||||||
|  |   avatar: "アイコン" | ||||||
|  |   banner: "バナー" | ||||||
|  |   is-cat: "このアカウントはCatです" | ||||||
|  |   is-bot: "このアカウントはBotです" | ||||||
|  |   is-locked: "フォローを承認制にする" | ||||||
|  |   careful-bot: "Botからのフォローだけ承認制にする" | ||||||
|  |   advanced: "その他" | ||||||
|  |   privacy: "プライバシー" | ||||||
|  |   save: "保存" | ||||||
|  |   saved: "プロフィールを保存しました" | ||||||
|  |   uploading: "アップロード中" | ||||||
|  |   upload-failed: "アップロードに失敗しました" | ||||||
| common/views/widgets/broadcast.vue: | common/views/widgets/broadcast.vue: | ||||||
|   fetching: "Recuperando" |   fetching: "Recuperando" | ||||||
|   no-broadcasts: "Sin emisión" |   no-broadcasts: "Sin emisión" | ||||||
| @@ -439,6 +495,7 @@ common/views/pages/follow.vue: | |||||||
|   following: "Siguiendo" |   following: "Siguiendo" | ||||||
|   follow: "Seguir" |   follow: "Seguir" | ||||||
|   request-pending: "Solicitud pendiente" |   request-pending: "Solicitud pendiente" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "Solicitar suscripción" |   follow-request: "Solicitar suscripción" | ||||||
| desktop: | desktop: | ||||||
|   banner-crop-title: "Corta la parte que aparece como un banner" |   banner-crop-title: "Corta la parte que aparece como un banner" | ||||||
| @@ -477,13 +534,13 @@ desktop/views/components/charts.vue: | |||||||
|     notes: "Número de publicaciones: aumentar/disminuir (Combinado)" |     notes: "Número de publicaciones: aumentar/disminuir (Combinado)" | ||||||
|     local-notes: "Número de publicaciones: aumentar/disminuir (Local)" |     local-notes: "Número de publicaciones: aumentar/disminuir (Local)" | ||||||
|     remote-notes: "Número de publicaciones: aumentar/disminuir (Remoto)" |     remote-notes: "Número de publicaciones: aumentar/disminuir (Remoto)" | ||||||
|     notes-total: "Número de publicaciones: Acumulativo total" |     notes-total: "投稿の積算" | ||||||
|     users: "Número de usuarios: aumentar/disminuir" |     users: "Número de usuarios: aumentar/disminuir" | ||||||
|     users-total: "Número de usuarios: Acumulativo total" |     users-total: "ユーザーの積算" | ||||||
|     drive: "Capacidad de almacenamiento usada: aumentar/disminuir" |     drive: "Capacidad de almacenamiento usada: aumentar/disminuir" | ||||||
|     drive-total: "Capacidad de almacenamiento usada: Acumulativa total" |     drive-total: "ドライブ使用量の積算" | ||||||
|     drive-files: "Número de archivos almacenados: aumentar/disminuir" |     drive-files: "Número de archivos almacenados: aumentar/disminuir" | ||||||
|     drive-files-total: "Número de archivos almacenados: Acumulativo total" |     drive-files-total: "ドライブのファイル数の積算" | ||||||
|     network-requests: "リクエスト" |     network-requests: "リクエスト" | ||||||
|     network-time: "応答時間" |     network-time: "応答時間" | ||||||
|     network-usage: "通信量" |     network-usage: "通信量" | ||||||
| @@ -565,6 +622,7 @@ desktop/views/components/follow-button.vue: | |||||||
|   following: "Siguiendo" |   following: "Siguiendo" | ||||||
|   follow: "Sigue" |   follow: "Sigue" | ||||||
|   request-pending: "Pendiente de aprobación" |   request-pending: "Pendiente de aprobación" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "Solicitud de seguir" |   follow-request: "Solicitud de seguir" | ||||||
| desktop/views/components/followers-window.vue: | desktop/views/components/followers-window.vue: | ||||||
|   followers: "{} seguidores" |   followers: "{} seguidores" | ||||||
| @@ -601,14 +659,14 @@ desktop/views/components/note-detail.vue: | |||||||
|   location: "Localización" |   location: "Localización" | ||||||
|   renote: "Republicar" |   renote: "Republicar" | ||||||
|   add-reaction: "Agregar una reacción" |   add-reaction: "Agregar una reacción" | ||||||
| desktop/views/components/notes.note.vue: | desktop/views/components/note.vue: | ||||||
|   reposted-by: "Republicado por {}" |   reposted-by: "{}がRenote" | ||||||
|   reply: "Responder" |   reply: "返信" | ||||||
|   renote: "Republicar" |   renote: "Renote" | ||||||
|   add-reaction: "Agregar una reacción" |   add-reaction: "リアクション" | ||||||
|   detail: "Mostrar detalles" |   detail: "詳細" | ||||||
|   private: "Esta publicación es privada" |   private: "この投稿は非公開です" | ||||||
|   deleted: "Esta publicación ha sido borrada" |   deleted: "この投稿は削除されました" | ||||||
| desktop/views/components/notes.vue: | desktop/views/components/notes.vue: | ||||||
|   error: "Error al cargar." |   error: "Error al cargar." | ||||||
|   retry: "Reintentar" |   retry: "Reintentar" | ||||||
| @@ -675,6 +733,7 @@ desktop/views/components/settings.vue: | |||||||
|   2fa: "Autenticación de Doble-Factor" |   2fa: "Autenticación de Doble-Factor" | ||||||
|   other: "Otros" |   other: "Otros" | ||||||
|   license: "Licencia" |   license: "Licencia" | ||||||
|  |   theme: "テーマ" | ||||||
|   behaviour: "Acciones" |   behaviour: "Acciones" | ||||||
|   fetch-on-scroll: "Desplazamiento infinito" |   fetch-on-scroll: "Desplazamiento infinito" | ||||||
|   fetch-on-scroll-desc: "Cuando te deslizas al final de la página nuevo contenido se carga automáticamente." |   fetch-on-scroll-desc: "Cuando te deslizas al final de la página nuevo contenido se carga automáticamente." | ||||||
| @@ -686,30 +745,36 @@ desktop/views/components/settings.vue: | |||||||
|   advanced: "Configuración avanzada" |   advanced: "Configuración avanzada" | ||||||
|   api-via-stream: "Solicitar API por medio de un stream" |   api-via-stream: "Solicitar API por medio de un stream" | ||||||
|   api-via-stream-desc: "Las peticiones de las API se realizan por conexiones WebSocket en lugar de las tradicionales (para una mejora en el rendimiento). Esta función depende del navegador." |   api-via-stream-desc: "Las peticiones de las API se realizan por conexiones WebSocket en lugar de las tradicionales (para una mejora en el rendimiento). Esta función depende del navegador." | ||||||
|  |   deck-nav: "デッキ内ナビゲーション" | ||||||
|  |   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||||
|  |   deck-default: "デッキをデフォルトのUIにする" | ||||||
|   display: "Diseño y pantalla" |   display: "Diseño y pantalla" | ||||||
|   customize: "Personaliza la página principal" |   customize: "Personaliza la página principal" | ||||||
|  |   wallpaper: "壁紙" | ||||||
|   choose-wallpaper: "Elije un fondo" |   choose-wallpaper: "Elije un fondo" | ||||||
|   delete-wallpaper: "Suprimir fondo" |   delete-wallpaper: "Suprimir fondo" | ||||||
|   dark-mode: "Modo Nocturno" |   dark-mode: "Modo Nocturno" | ||||||
|  |   use-shadow: "UIに影を使用" | ||||||
|  |   rounded-corners: "UIの角を丸める" | ||||||
|   circle-icons: "Usar iconos circulares" |   circle-icons: "Usar iconos circulares" | ||||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" |   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" |   post-form-on-timeline: "Mostrar el formulario de las entradas encima de la línea de tiempo" | ||||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" |   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||||
|   show-clock-on-header: "右上に時計を表示する" |   show-clock-on-header: "右上に時計を表示する" | ||||||
|   show-reply-target: "リプライ先を表示する" |   show-reply-target: "リプライ先を表示する" | ||||||
|  |   timeline: "タイムライン" | ||||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" |   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" |   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" |   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||||
|   show-maps: "マップの自動展開" |   show-maps: "マップの自動展開" | ||||||
|   show-maps-desc: "位置情報が添付された投稿のマップを自動的に展開します。" |   deck-column-align: "デッキのカラムの位置" | ||||||
|  |   deck-column-align-center: "中央" | ||||||
|  |   deck-column-align-left: "左" | ||||||
|   sound: "サウンド" |   sound: "サウンド" | ||||||
|   enable-sounds: "サウンドを有効にする" |   enable-sounds: "サウンドを有効にする" | ||||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" |   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||||
|   volume: "ボリューム" |   volume: "ボリューム" | ||||||
|   test: "テスト" |   test: "テスト" | ||||||
|   mobile: "モバイル" |  | ||||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" |  | ||||||
|   language: "言語" |   language: "言語" | ||||||
|   pick-language: "言語を選択" |   pick-language: "言語を選択" | ||||||
|   recommended: "推奨" |   recommended: "推奨" | ||||||
| @@ -745,6 +810,10 @@ desktop/views/components/settings.vue: | |||||||
|   tools: "Herramientas" |   tools: "Herramientas" | ||||||
|   task-manager: "Navegador de tareas" |   task-manager: "Navegador de tareas" | ||||||
|   third-parties: "Servicios externos" |   third-parties: "Servicios externos" | ||||||
|  |   navbar-position: "ナビゲーションバーの位置" | ||||||
|  |   navbar-position-top: "上" | ||||||
|  |   navbar-position-left: "左" | ||||||
|  |   navbar-position-right: "右" | ||||||
| desktop/views/components/settings.2fa.vue: | desktop/views/components/settings.2fa.vue: | ||||||
|   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" |   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" | ||||||
|   detail: "Ver detalles..." |   detail: "Ver detalles..." | ||||||
| @@ -784,20 +853,6 @@ desktop/views/components/settings.password.vue: | |||||||
|   enter-new-password-again: "Ingresar nueva contraseña de nuevo" |   enter-new-password-again: "Ingresar nueva contraseña de nuevo" | ||||||
|   not-match: "Las nuevas contraseñas no se corresponden consigo mismas" |   not-match: "Las nuevas contraseñas no se corresponden consigo mismas" | ||||||
|   changed: "Contraseña actualizada" |   changed: "Contraseña actualizada" | ||||||
| desktop/views/components/settings.profile.vue: |  | ||||||
|   avatar: "Avatar" |  | ||||||
|   choice-avatar: "Escoger una imagen" |  | ||||||
|   name: "Nombre" |  | ||||||
|   location: "Localización" |  | ||||||
|   description: "Descripción" |  | ||||||
|   birthday: "Fecha de nacimiento" |  | ||||||
|   save: "Perfil actualizado" |  | ||||||
|   locked-account: "Protege tu cuenta" |  | ||||||
|   is-locked: "フォローを承認制にする" |  | ||||||
|   other: "その他" |  | ||||||
|   is-bot: "このアカウントはBotです" |  | ||||||
|   is-cat: "このアカウントはCatです" |  | ||||||
|   profile-updated: "プロフィールを更新しました" |  | ||||||
| desktop/views/components/sub-note-content.vue: | desktop/views/components/sub-note-content.vue: | ||||||
|   private: "この投稿は非公開です" |   private: "この投稿は非公開です" | ||||||
|   deleted: "この投稿は削除されました" |   deleted: "この投稿は削除されました" | ||||||
| @@ -896,10 +951,8 @@ desktop/views/pages/deck/deck.tl-column.vue: | |||||||
|   is-media-only: "メディア投稿のみ" |   is-media-only: "メディア投稿のみ" | ||||||
|   is-media-view: "メディアビュー" |   is-media-view: "メディアビュー" | ||||||
|   edit: "オプション" |   edit: "オプション" | ||||||
| desktop/views/pages/deck/deck.note.vue: | desktop/views/pages/deck/deck.user-column.vue: | ||||||
|   reposted-by: "{}がRenote" |   pinned-notes: "ピン留めされた投稿" | ||||||
|   private: "この投稿は非公開です" |  | ||||||
|   deleted: "この投稿は削除されました" |  | ||||||
| desktop/views/pages/stats/stats.vue: | desktop/views/pages/stats/stats.vue: | ||||||
|   all-users: "全てのユーザー" |   all-users: "全てのユーザー" | ||||||
|   original-users: "このインスタンスのユーザー" |   original-users: "このインスタンスのユーザー" | ||||||
| @@ -1034,6 +1087,8 @@ mobile/views/components/drive.file-detail.vue: | |||||||
|   hash: "ハッシュ (md5)" |   hash: "ハッシュ (md5)" | ||||||
|   exif: "EXIF" |   exif: "EXIF" | ||||||
|   nsfw: "閲覧注意" |   nsfw: "閲覧注意" | ||||||
|  |   mark-as-sensitive: "閲覧注意に設定" | ||||||
|  |   unmark-as-sensitive: "閲覧注意を解除" | ||||||
| mobile/views/components/media-image.vue: | mobile/views/components/media-image.vue: | ||||||
|   sensitive: "閲覧注意" |   sensitive: "閲覧注意" | ||||||
|   click-to-show: "クリックして表示" |   click-to-show: "クリックして表示" | ||||||
| @@ -1044,6 +1099,7 @@ mobile/views/components/follow-button.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| mobile/views/components/friends-maker.vue: | mobile/views/components/friends-maker.vue: | ||||||
|   title: "気になるユーザーをフォロー" |   title: "気になるユーザーをフォロー" | ||||||
| @@ -1173,23 +1229,6 @@ mobile/views/pages/notifications.vue: | |||||||
|   read-all: "すべての通知を既読にしますか?" |   read-all: "すべての通知を既読にしますか?" | ||||||
| mobile/views/pages/games/reversi.vue: | mobile/views/pages/games/reversi.vue: | ||||||
|   reversi: "リバーシ" |   reversi: "リバーシ" | ||||||
| mobile/views/pages/settings/settings.profile.vue: |  | ||||||
|   title: "プロフィール" |  | ||||||
|   name: "名前" |  | ||||||
|   account: "アカウント" |  | ||||||
|   location: "場所" |  | ||||||
|   description: "自己紹介" |  | ||||||
|   birthday: "誕生日" |  | ||||||
|   avatar: "アイコン" |  | ||||||
|   banner: "バナー" |  | ||||||
|   is-cat: "このアカウントはCatです" |  | ||||||
|   is-locked: "フォローを承認制にする" |  | ||||||
|   advanced: "その他" |  | ||||||
|   privacy: "プライバシー" |  | ||||||
|   save: "保存" |  | ||||||
|   saved: "プロフィールを保存しました" |  | ||||||
|   uploading: "アップロード中" |  | ||||||
|   upload-failed: "アップロードに失敗しました" |  | ||||||
| mobile/views/pages/search.vue: | mobile/views/pages/search.vue: | ||||||
|   search: "検索" |   search: "検索" | ||||||
|   empty: "「{}」に関する投稿は見つかりませんでした。" |   empty: "「{}」に関する投稿は見つかりませんでした。" | ||||||
| @@ -1219,6 +1258,7 @@ mobile/views/pages/settings.vue: | |||||||
|   notification-position: "通知の表示" |   notification-position: "通知の表示" | ||||||
|   notification-position-bottom: "下" |   notification-position-bottom: "下" | ||||||
|   notification-position-top: "上" |   notification-position-top: "上" | ||||||
|  |   theme: "テーマ" | ||||||
|   behavior: "動作" |   behavior: "動作" | ||||||
|   fetch-on-scroll: "スクロールで自動読み込み" |   fetch-on-scroll: "スクロールで自動読み込み" | ||||||
|   note-visibility: "投稿の公開範囲" |   note-visibility: "投稿の公開範囲" | ||||||
|   | |||||||
| @@ -5,11 +5,11 @@ meta: | |||||||
| common: | common: | ||||||
|   misskey: "Une ⭐ du fédiverse" |   misskey: "Une ⭐ du fédiverse" | ||||||
|   about-title: "Une ⭐ du fédivers." |   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 ?" |   about: "Merci d’avoir choisis Misskey. Misskey est une <b>plateforme de micro-blogging distribuée</b> née sur Terre et fait partie du Fédiverse (un univers composé de diverses plateformes de réseaux sociaux organisées), elle est connectée mutuellement avec d’autres plateformes de réseaux sociaux. Désirez-vous prendre une pause, un court instant, loin de l’agitation de la ville et plonger dans un Internet d’un nouveau genre ?" | ||||||
|   intro: |   intro: | ||||||
|     title: "C’est quoi Misskey ?" |     title: "C’est quoi Misskey ?" | ||||||
|     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" |     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" | ||||||
|     features: "Fonctionnalités" |     features: "Options" | ||||||
|     rich-contents: "Notes" |     rich-contents: "Notes" | ||||||
|     rich-contents-desc: "自分の考え、話題の出来事、皆と共有したいことについて発信してください。必要であれば、様々な構文を使って投稿を装飾したり、好きな画像、動画などのファイルやアンケートを添付することもできます。" |     rich-contents-desc: "自分の考え、話題の出来事、皆と共有したいことについて発信してください。必要であれば、様々な構文を使って投稿を装飾したり、好きな画像、動画などのファイルやアンケートを添付することもできます。" | ||||||
|     reaction: "Réactions" |     reaction: "Réactions" | ||||||
| @@ -32,9 +32,9 @@ common: | |||||||
|     paragraph2: "Vous pouvez changer l'affichage en <strong>cliquant droit</strong> sur certains widgets." |     paragraph2: "Vous pouvez changer l'affichage en <strong>cliquant droit</strong> sur certains widgets." | ||||||
|     paragraph3: "Pour supprimer un widget, <strong>glissez et déposez le widget sur la zone étiquetée « Corbeille »</strong> dans l'en-tête." |     paragraph3: "Pour supprimer un widget, <strong>glissez et déposez le widget sur la zone étiquetée « Corbeille »</strong> dans l'en-tête." | ||||||
|     paragraph4: "Pour terminer la personnalisation, cliquez sur \"Terminer\" dans le coin supérieur droit." |     paragraph4: "Pour terminer la personnalisation, cliquez sur \"Terminer\" dans le coin supérieur droit." | ||||||
|     gotit: "Compris!" |     gotit: "Compris !" | ||||||
|   notification: |   notification: | ||||||
|     file-uploaded: "Le fichier a été téléversé !" |     file-uploaded: "Le fichier a été transféré !" | ||||||
|     message-from: "Message de {} :" |     message-from: "Message de {} :" | ||||||
|     reversi-invited: "Invité à jouer" |     reversi-invited: "Invité à jouer" | ||||||
|     reversi-invited-by: "Invité par {} :" |     reversi-invited-by: "Invité par {} :" | ||||||
| @@ -43,7 +43,7 @@ common: | |||||||
|     quoted-by: "Cité·e par {} :" |     quoted-by: "Cité·e par {} :" | ||||||
|   time: |   time: | ||||||
|     unknown: "inconnu" |     unknown: "inconnu" | ||||||
|     future: "à l'instant" |     future: "à l’instant" | ||||||
|     just_now: "à l'instant" |     just_now: "à l'instant" | ||||||
|     seconds_ago: "Il y a {} seconde·s" |     seconds_ago: "Il y a {} seconde·s" | ||||||
|     minutes_ago: "Il y a {} minute·s" |     minutes_ago: "Il y a {} minute·s" | ||||||
| @@ -52,7 +52,7 @@ common: | |||||||
|     weeks_ago: "Il y a {} semaines·s" |     weeks_ago: "Il y a {} semaines·s" | ||||||
|     months_ago: "Il y a {} mois" |     months_ago: "Il y a {} mois" | ||||||
|     years_ago: "Il y a {} an·s" |     years_ago: "Il y a {} an·s" | ||||||
|   month-and-day: "{month}/{day}" |   month-and-day: "{month} mois/{day} jour" | ||||||
|   trash: "Corbeille" |   trash: "Corbeille" | ||||||
|   weekday-short: |   weekday-short: | ||||||
|     sunday: "D" |     sunday: "D" | ||||||
| @@ -83,17 +83,17 @@ common: | |||||||
|     pudding: "Pudding" |     pudding: "Pudding" | ||||||
|   note-visibility: |   note-visibility: | ||||||
|     public: "Public" |     public: "Public" | ||||||
|     home: "Accueil" |     home: "Principal" | ||||||
|     home-desc: "Publier sur le fil local uniquement" |     home-desc: "Publier sur le fil principal uniquement" | ||||||
|     followers: "Abonnés·es" |     followers: "Abonnés·es" | ||||||
|     followers-desc: "Publier à vos abonnés·es uniquement" |     followers-desc: "Publier à vos abonnés·es uniquement" | ||||||
|     specified: "Direct" |     specified: "Direct" | ||||||
|     specified-desc: "Publier aux utilisateurs·trices mentionnés·es" |     specified-desc: "Publier uniquement aux utilisateurs·rices mentionnés·es" | ||||||
|     private: "Privé" |     private: "Privé" | ||||||
|   note-placeholders: |   note-placeholders: | ||||||
|     a: "Que faites-vous maintenant ?" |     a: "Que faites-vous maintenant ?" | ||||||
|     b: "Quoi de neuf ?" |     b: "Quoi de neuf ?" | ||||||
|     c: "Qu'avez-vous en tête ?" |     c: "Qu’avez-vous en tête ?" | ||||||
|     d: "Désirez-vous publier quelques mots ?" |     d: "Désirez-vous publier quelques mots ?" | ||||||
|     e: "Écrivez ici" |     e: "Écrivez ici" | ||||||
|     f: "En attente de vos écrits" |     f: "En attente de vos écrits" | ||||||
| @@ -103,15 +103,15 @@ common: | |||||||
|   ok: "OK" |   ok: "OK" | ||||||
|   update-available-title: "Mise à jour disponible" |   update-available-title: "Mise à jour disponible" | ||||||
|   update-available: "Une nouvelle version de Misskey est disponible ({newer}, version actuelle: {current}). Veuillez recharger la page pour appliquer la mise à jour." |   update-available: "Une nouvelle version de Misskey est disponible ({newer}, version actuelle: {current}). Veuillez recharger la page pour appliquer la mise à jour." | ||||||
|   my-token-regenerated: "Votre token vient d'être généré, vous allez maintenant être déconnecté." |   my-token-regenerated: "Votre jeton vient d’être généré, vous allez maintenant être déconnecté." | ||||||
|   i-like-sushi: "Je préfère les sushis plutôt que le pudding" |   i-like-sushi: "Je préfère les sushis plutôt que le pudding" | ||||||
|   show-reversi-board-labels: "Afficher les étiquettes des lignes et colonnes dans Reversi" |   show-reversi-board-labels: "Afficher les étiquettes des lignes et colonnes dans Reversi" | ||||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" |   use-contrast-reversi-stones: "Icône avec contraste sur Reversi" | ||||||
|   verified-user: "Compte vérifié" |   verified-user: "Compte vérifié" | ||||||
|   disable-animated-mfm: "Désactiver les textes animés dans les publications" |   disable-animated-mfm: "Désactiver les textes animés dans les publications" | ||||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" |   always-show-nsfw: "Toujours afficher les contenus sensibles" | ||||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" |   always-mark-nsfw: "Toujours marquer les notes ayant des attachements comme sensibles" | ||||||
|   show-full-acct: "ユーザー名のホストを省略しない" |   show-full-acct: "Afficher l’adresse complète de l’utilisateur" | ||||||
|   reduce-motion: "Réduire les animations dans l’interface utilisateur" |   reduce-motion: "Réduire les animations dans l’interface utilisateur" | ||||||
|   this-setting-is-this-device-only: "Uniquement sur cet appareil" |   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.' |   do-not-use-in-production: 'Il s’agit d’une version de développement. Ne pas utiliser dans un environnement de production.' | ||||||
| @@ -120,7 +120,7 @@ common: | |||||||
|     my-turn: "C’est votre tour" |     my-turn: "C’est votre tour" | ||||||
|     opponent-turn: "Tour de l’adversaire" |     opponent-turn: "Tour de l’adversaire" | ||||||
|     turn-of: "C’est le tour de {}" |     turn-of: "C’est le tour de {}" | ||||||
|     past-turn-of: "C'est au tour de {}" |     past-turn-of: "C’est au tour de {}" | ||||||
|     won: "{} a gagné" |     won: "{} a gagné" | ||||||
|     black: "Noirs" |     black: "Noirs" | ||||||
|     white: "Blancs" |     white: "Blancs" | ||||||
| @@ -136,7 +136,7 @@ common: | |||||||
|     memo: "Pense-bête" |     memo: "Pense-bête" | ||||||
|     trends: "Tendances" |     trends: "Tendances" | ||||||
|     photo-stream: "Flux de photos" |     photo-stream: "Flux de photos" | ||||||
|     posts-monitor: "Graphe des publications" |     posts-monitor: "Graph des publications" | ||||||
|     slideshow: "Diaporama" |     slideshow: "Diaporama" | ||||||
|     version: "Version" |     version: "Version" | ||||||
|     broadcast: "Diffusion" |     broadcast: "Diffusion" | ||||||
| @@ -149,16 +149,16 @@ common: | |||||||
|     donation: "Dons" |     donation: "Dons" | ||||||
|     nav: "Navigation" |     nav: "Navigation" | ||||||
|     tips: "Conseils" |     tips: "Conseils" | ||||||
|     hashtags: "Étiquettes" |     hashtags: "Hashtags" | ||||||
|   deck: |   deck: | ||||||
|     widgets: "Widgets" |     widgets: "Widgets" | ||||||
|     home: "Accueil" |     home: "Accueil" | ||||||
|     local: "Local" |     local: "Local" | ||||||
|     hybrid: "Social" |     hybrid: "Social" | ||||||
|     hashtag: "ハッシュタグ" |     hashtag: "Hashtag" | ||||||
|     global: "Global" |     global: "Global" | ||||||
|     mentions: "Mentions" |     mentions: "Mentions" | ||||||
|     direct: "ダイレクト投稿" |     direct: "Messages directs" | ||||||
|     notifications: "Notifications" |     notifications: "Notifications" | ||||||
|     list: "Liste" |     list: "Liste" | ||||||
|     swap-left: "Déplacer à gauche" |     swap-left: "Déplacer à gauche" | ||||||
| @@ -189,7 +189,7 @@ auth/views/index.vue: | |||||||
|   denied: "L'autorisation de l'application a été refusée." |   denied: "L'autorisation de l'application a été refusée." | ||||||
|   denied-paragraph: "Cette application ne va pas accéder à votre compte." |   denied-paragraph: "Cette application ne va pas accéder à votre compte." | ||||||
|   already-authorized: "Cette application est déjà autorisée" |   already-authorized: "Cette application est déjà autorisée" | ||||||
|   allowed: "アプリケーションの連携を許可しました" |   allowed: "Permissions autorisées de l’application." | ||||||
|   callback-url: "Retour vers l'application" |   callback-url: "Retour vers l'application" | ||||||
|   please-go-back: "Veillez retourner à l'application." |   please-go-back: "Veillez retourner à l'application." | ||||||
|   error: "La session n'existe pas." |   error: "La session n'existe pas." | ||||||
| @@ -254,7 +254,7 @@ common/views/components/connect-failed.troubleshooter.vue: | |||||||
|   no-network: "Aucune connexion au réseau" |   no-network: "Aucune connexion au réseau" | ||||||
|   no-network-desc: "Veuillez vérifier que vous êtes bien connecté au réseau." |   no-network-desc: "Veuillez vérifier que vous êtes bien connecté au réseau." | ||||||
|   no-internet: "Aucune connexion internet." |   no-internet: "Aucune connexion internet." | ||||||
|   no-internet-desc: "Veuillez vérifier que vous êtes bien connecté à internet." |   no-internet-desc: "Assurez-vous que vous êtes bien connectés à internet." | ||||||
|   no-server: "Impossible de se connecter au serveur" |   no-server: "Impossible de se connecter au serveur" | ||||||
|   no-server-desc: "Votre connexion semble correcte, mais il a été impossible de vous connecter au serveur de Misskey. Il se peut que le serveur soit hors-ligne ou en maintenance, veuillez ressayer plus tard." |   no-server-desc: "Votre connexion semble correcte, mais il a été impossible de vous connecter au serveur de Misskey. Il se peut que le serveur soit hors-ligne ou en maintenance, veuillez ressayer plus tard." | ||||||
|   success: "Connexion au serveur de Misskey réussie !" |   success: "Connexion au serveur de Misskey réussie !" | ||||||
| @@ -264,6 +264,41 @@ common/views/components/connect-failed.troubleshooter.vue: | |||||||
| common/views/components/media-banner.vue: | common/views/components/media-banner.vue: | ||||||
|   sensitive: "Contenu sensible" |   sensitive: "Contenu sensible" | ||||||
|   click-to-show: "Cliquer pour afficher" |   click-to-show: "Cliquer pour afficher" | ||||||
|  | common/views/components/theme.vue: | ||||||
|  |   light-theme: "Thème durant le mode clair" | ||||||
|  |   dark-theme: "Thème durant le mode sombre" | ||||||
|  |   light-themes: "Thème clair" | ||||||
|  |   dark-themes: "Thème sombre" | ||||||
|  |   install-a-theme: "Installer un thème" | ||||||
|  |   theme-code: "Code du thème" | ||||||
|  |   install: "Installation" | ||||||
|  |   installed: "« {} » a été installé" | ||||||
|  |   create-a-theme: "Créer un thème" | ||||||
|  |   save-created-theme: "Enregistrer le thème" | ||||||
|  |   primary-color: "Couleur primaire" | ||||||
|  |   secondary-color: "Couleur secondaire" | ||||||
|  |   text-color: "Couleur du texte" | ||||||
|  |   base-theme: "Thème de base" | ||||||
|  |   base-theme-light: "Clair" | ||||||
|  |   base-theme-dark: "Sombre" | ||||||
|  |   theme-name: "Nom du Thème" | ||||||
|  |   preview-created-theme: "Prévisualisation" | ||||||
|  |   invalid-theme: "Thème n’est pas valide." | ||||||
|  |   already-installed: "Le thème est déjà installé." | ||||||
|  |   saved: "enregistré" | ||||||
|  |   manage-themes: "Gestion des thèmes" | ||||||
|  |   builtin-themes: "Thèmes standards" | ||||||
|  |   my-themes: "Mes thèmes" | ||||||
|  |   installed-themes: "Thèmes installés" | ||||||
|  |   select-theme: "Veuillez sélectionner un thème" | ||||||
|  |   uninstall: "Désinstaller" | ||||||
|  |   uninstalled: "« {} » a été désinstallé" | ||||||
|  |   author: "Auteur" | ||||||
|  |   desc: "Description" | ||||||
|  |   export: "Exporter" | ||||||
|  |   import: "Importer" | ||||||
|  |   import-by-code: "Ou coller du code" | ||||||
|  |   theme-name-required: "Nom du thème est obligatoire." | ||||||
| common/views/components/cw-button.vue: | common/views/components/cw-button.vue: | ||||||
|   hide: "Masquer" |   hide: "Masquer" | ||||||
|   show: "Voir plus" |   show: "Voir plus" | ||||||
| @@ -294,13 +329,15 @@ common/views/components/nav.vue: | |||||||
|   wiki: "Wiki" |   wiki: "Wiki" | ||||||
|   donors: "Donateur·rice·s" |   donors: "Donateur·rice·s" | ||||||
|   repository: "Dépôt" |   repository: "Dépôt" | ||||||
|   develop: "Développeur·se·s" |   develop: "Développeurs" | ||||||
|   feedback: "Remarques" |   feedback: "Suggestions" | ||||||
| common/views/components/note-menu.vue: | common/views/components/note-menu.vue: | ||||||
|   detail: "Détails" |   detail: "Détails" | ||||||
|   copy-link: "Copier le lien" |   copy-link: "Copier le lien" | ||||||
|   favorite: "Mettre cette note en favoris" |   favorite: "Mettre cette note en favoris" | ||||||
|  |   unfavorite: "Retirer des favoris" | ||||||
|   pin: "Épingler sur votre profil" |   pin: "Épingler sur votre profil" | ||||||
|  |   unpin: "Désépingler" | ||||||
|   delete: "Supprimer" |   delete: "Supprimer" | ||||||
|   delete-confirm: "Supprimer cette publication ?" |   delete-confirm: "Supprimer cette publication ?" | ||||||
|   remote: "Afficher la note originale" |   remote: "Afficher la note originale" | ||||||
| @@ -374,11 +411,30 @@ common/views/components/visibility-chooser.vue: | |||||||
|   followers: "Abonné·e·s" |   followers: "Abonné·e·s" | ||||||
|   followers-desc: "Publier à vos abonné·e·s uniquement" |   followers-desc: "Publier à vos abonné·e·s uniquement" | ||||||
|   specified: "Direct" |   specified: "Direct" | ||||||
|   specified-desc: "Publier aux utilisateur·rice·s mentionné·e·s" |   specified-desc: "Publier uniquement aux utilisateurs·rices mentionné·e·s" | ||||||
|   private: "Privé" |   private: "Privé" | ||||||
| common/views/components/trends.vue: | common/views/components/trends.vue: | ||||||
|   count: "{} utilisateurs·trices mentionnés·es" |   count: "{} utilisateurs·rices mentionnés·es" | ||||||
|   empty: "Aucune tendance" |   empty: "Aucune tendance" | ||||||
|  | common/views/components/profile-editor.vue: | ||||||
|  |   title: "Profil" | ||||||
|  |   name: "Nom" | ||||||
|  |   account: "Compte" | ||||||
|  |   location: "Lieu" | ||||||
|  |   description: "À propos de moi" | ||||||
|  |   birthday: "Date de naissance" | ||||||
|  |   avatar: "Avatar" | ||||||
|  |   banner: "Bannière" | ||||||
|  |   is-cat: "Ce compte est un Chat" | ||||||
|  |   is-bot: "Ce compte est un Bot" | ||||||
|  |   is-locked: "Demandes d’abonnements requièrent l’approbation" | ||||||
|  |   careful-bot: "Botからのフォローだけ承認制にする" | ||||||
|  |   advanced: "Avancé" | ||||||
|  |   privacy: "Vie privée" | ||||||
|  |   save: "Mettre à jour le profil" | ||||||
|  |   saved: "Profil mis à jour avec succès" | ||||||
|  |   uploading: "En cours d'envoi …" | ||||||
|  |   upload-failed: "Échec de l'envoi" | ||||||
| common/views/widgets/broadcast.vue: | common/views/widgets/broadcast.vue: | ||||||
|   fetching: "Récupération" |   fetching: "Récupération" | ||||||
|   no-broadcasts: "Aucune annonce" |   no-broadcasts: "Aucune annonce" | ||||||
| @@ -398,10 +454,10 @@ common/views/widgets/photo-stream.vue: | |||||||
|   title: "Flux de photos" |   title: "Flux de photos" | ||||||
|   no-photos: "Pas de photo" |   no-photos: "Pas de photo" | ||||||
| common/views/widgets/posts-monitor.vue: | common/views/widgets/posts-monitor.vue: | ||||||
|   title: "Graphe des publications" |   title: "Graph des publications" | ||||||
|   toggle: "Basculer entre les vues" |   toggle: "Basculer entre les vues" | ||||||
| common/views/widgets/hashtags.vue: | common/views/widgets/hashtags.vue: | ||||||
|   title: "Étiquettes" |   title: "Hashtags" | ||||||
| common/views/widgets/server.vue: | common/views/widgets/server.vue: | ||||||
|   title: "Informations sur le serveur" |   title: "Informations sur le serveur" | ||||||
|   toggle: "Afficher les vues" |   toggle: "Afficher les vues" | ||||||
| @@ -420,7 +476,7 @@ common/views/widgets/tips.vue: | |||||||
|   tips-line4: "Vous pouvez coller des images à partir du presse-papier sur la fenêtre de la note" |   tips-line4: "Vous pouvez coller des images à partir du presse-papier sur la fenêtre de la note" | ||||||
|   tips-line5: "Vous pouvez téléverser des fichiers sur le Drive en faisant un glisser-déposer" |   tips-line5: "Vous pouvez téléverser des fichiers sur le Drive en faisant un glisser-déposer" | ||||||
|   tips-line6: "Vous pouvez déplacer un dossier en le glissant dans le Drive" |   tips-line6: "Vous pouvez déplacer un dossier en le glissant dans le Drive" | ||||||
|   tips-line7: "ドライブでフォルダをドラッグしてフォルダ移動できます" |   tips-line7: "Vous pouvez déplacer des dossiers en les glissant dans le Drive" | ||||||
|   tips-line8: "Vous pouvez personnaliser l'Accueil via les paramètres" |   tips-line8: "Vous pouvez personnaliser l'Accueil via les paramètres" | ||||||
|   tips-line9: "Misskey est sous licence AGPLv3" |   tips-line9: "Misskey est sous licence AGPLv3" | ||||||
|   tips-line10: "タイムマシンウィジェットを利用すると、簡単に過去のタイムラインに遡れます" |   tips-line10: "タイムマシンウィジェットを利用すると、簡単に過去のタイムラインに遡れます" | ||||||
| @@ -428,7 +484,7 @@ common/views/widgets/tips.vue: | |||||||
|   tips-line13: "Tous les fichiers attachés à cette publication sont sauvegardés dans le Drive" |   tips-line13: "Tous les fichiers attachés à cette publication sont sauvegardés dans le Drive" | ||||||
|   tips-line14: "ホームのカスタマイズ中、ウィジェットを右クリックしてデザインを変更できます" |   tips-line14: "ホームのカスタマイズ中、ウィジェットを右クリックしてデザインを変更できます" | ||||||
|   tips-line17: "Vous pouvez mettre un texte en surbrillance en le mettant entre ** **" |   tips-line17: "Vous pouvez mettre un texte en surbrillance en le mettant entre ** **" | ||||||
|   tips-line19: "いくつかのウィンドウはブラウザの外に切り離すことができます" |   tips-line19: "Plusieurs fenêtres peuvent être détachées en dehors du navigateur." | ||||||
|   tips-line20: "カレンダーウィジェットのパーセンテージは、経過の割合を示しています" |   tips-line20: "カレンダーウィジェットのパーセンテージは、経過の割合を示しています" | ||||||
|   tips-line21: "Vous pouvez aussi utiliser l'API pour développer des Bots." |   tips-line21: "Vous pouvez aussi utiliser l'API pour développer des Bots." | ||||||
|   tips-line23: "Mayu est mignone avec ses sourcils." |   tips-line23: "Mayu est mignone avec ses sourcils." | ||||||
| @@ -439,6 +495,7 @@ common/views/pages/follow.vue: | |||||||
|   following: "Suit" |   following: "Suit" | ||||||
|   follow: "Suivre" |   follow: "Suivre" | ||||||
|   request-pending: "Demande d'abonnement en attente" |   request-pending: "Demande d'abonnement en attente" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "Demande d'abonnement" |   follow-request: "Demande d'abonnement" | ||||||
| desktop: | desktop: | ||||||
|   banner-crop-title: "Découpez la partie qui apparaitra comme bannière" |   banner-crop-title: "Découpez la partie qui apparaitra comme bannière" | ||||||
| @@ -451,7 +508,7 @@ desktop: | |||||||
|   uploading-avatar: "Téléversement du nouvel avatar" |   uploading-avatar: "Téléversement du nouvel avatar" | ||||||
|   avatar-updated: "L'avatar est mis à jour" |   avatar-updated: "L'avatar est mis à jour" | ||||||
|   choose-avatar: "Choisir un avatar" |   choose-avatar: "Choisir un avatar" | ||||||
|   invalid-filetype: "この形式のファイルはサポートされていません" |   invalid-filetype: "Ce format de fichier n’est pas pris en charge" | ||||||
| desktop/views/components/activity.chart.vue: | desktop/views/components/activity.chart.vue: | ||||||
|   total: "Noirs ... Total" |   total: "Noirs ... Total" | ||||||
|   notes: "Bleu ... Notes" |   notes: "Bleu ... Notes" | ||||||
| @@ -477,13 +534,13 @@ desktop/views/components/charts.vue: | |||||||
|     notes: "投稿の増減 (統合)" |     notes: "投稿の増減 (統合)" | ||||||
|     local-notes: "投稿の増減 (ローカル)" |     local-notes: "投稿の増減 (ローカル)" | ||||||
|     remote-notes: "投稿の増減 (リモート)" |     remote-notes: "投稿の増減 (リモート)" | ||||||
|     notes-total: "投稿の累計" |     notes-total: "Total des notes" | ||||||
|     users: "Nombre d’utilisateurs·trices : augmentation/diminution" |     users: "Nombre d’utilisateurs·trices : augmentation/diminution" | ||||||
|     users-total: "Nombre total d’utilisateurs·trices : total cumulé" |     users-total: "ユーザーの積算" | ||||||
|     drive: "ドライブ使用量の増減" |     drive: "ドライブ使用量の増減" | ||||||
|     drive-total: "ドライブ使用量の累計" |     drive-total: "ドライブ使用量の積算" | ||||||
|     drive-files: "ドライブのファイル数の増減" |     drive-files: "ドライブのファイル数の増減" | ||||||
|     drive-files-total: "ドライブのファイル数の累計" |     drive-files-total: "ドライブのファイル数の積算" | ||||||
|     network-requests: "Requêtes" |     network-requests: "Requêtes" | ||||||
|     network-time: "Temps de réponse" |     network-time: "Temps de réponse" | ||||||
|     network-usage: "Traffic" |     network-usage: "Traffic" | ||||||
| @@ -545,7 +602,7 @@ desktop/views/components/drive.vue: | |||||||
|   unable-to-process: "L'opération n'a pas pu être complétée" |   unable-to-process: "L'opération n'a pas pu être complétée" | ||||||
|   circular-reference-detected: "Le dossier de destination est un sous-dossier du dossier que vous souhaitez déplacer." |   circular-reference-detected: "Le dossier de destination est un sous-dossier du dossier que vous souhaitez déplacer." | ||||||
|   unhandled-error: "Erreur inconnue" |   unhandled-error: "Erreur inconnue" | ||||||
|   url-upload: "Uploader d'un URL" |   url-upload: "Téléverser via une URL" | ||||||
|   url-of-file: "URL de l'image que vous souhaitez uploader." |   url-of-file: "URL de l'image que vous souhaitez uploader." | ||||||
|   url-upload-requested: "Upload requested" |   url-upload-requested: "Upload requested" | ||||||
|   may-take-time: "L'upload de votre fichier peut prendre un certain temps." |   may-take-time: "L'upload de votre fichier peut prendre un certain temps." | ||||||
| @@ -553,8 +610,8 @@ desktop/views/components/drive.vue: | |||||||
|   folder-name: "Nom du dossier" |   folder-name: "Nom du dossier" | ||||||
|   contextmenu: |   contextmenu: | ||||||
|     create-folder: "Créer un dossier" |     create-folder: "Créer un dossier" | ||||||
|     upload: "Uploader un fichier" |     upload: "Transférer un fichier" | ||||||
|     url-upload: "Uploader d'un URL" |     url-upload: "Transférer à partir d’une URL" | ||||||
| desktop/views/components/media-image.vue: | desktop/views/components/media-image.vue: | ||||||
|   sensitive: "Le contenu est NSFW" |   sensitive: "Le contenu est NSFW" | ||||||
|   click-to-show: "Cliquer pour afficher" |   click-to-show: "Cliquer pour afficher" | ||||||
| @@ -565,6 +622,7 @@ desktop/views/components/follow-button.vue: | |||||||
|   following: "Abonnements" |   following: "Abonnements" | ||||||
|   follow: "Suivre" |   follow: "Suivre" | ||||||
|   request-pending: "En attente d'approbation" |   request-pending: "En attente d'approbation" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "Demande d'abonnement" |   follow-request: "Demande d'abonnement" | ||||||
| desktop/views/components/followers-window.vue: | desktop/views/components/followers-window.vue: | ||||||
|   followers: "{} abonné·e·s" |   followers: "{} abonné·e·s" | ||||||
| @@ -601,14 +659,14 @@ desktop/views/components/note-detail.vue: | |||||||
|   location: "Géolocalisation" |   location: "Géolocalisation" | ||||||
|   renote: "Republier" |   renote: "Republier" | ||||||
|   add-reaction: "Ajouter votre reaction" |   add-reaction: "Ajouter votre reaction" | ||||||
| desktop/views/components/notes.note.vue: | desktop/views/components/note.vue: | ||||||
|   reposted-by: "Reposté par {}" |   reposted-by: "Partagé par {}" | ||||||
|   reply: "Répondre" |   reply: "Répondre" | ||||||
|   renote: "Republier" |   renote: "Partager" | ||||||
|   add-reaction: "Ajouter votre reaction" |   add-reaction: "リアクション" | ||||||
|   detail: "Afficher les détails" |   detail: "詳細" | ||||||
|   private: "cette publication est privée" |   private: "この投稿は非公開です" | ||||||
|   deleted: "cette publication a été supprimée" |   deleted: "この投稿は削除されました" | ||||||
| desktop/views/components/notes.vue: | desktop/views/components/notes.vue: | ||||||
|   error: "Échec du chargement." |   error: "Échec du chargement." | ||||||
|   retry: "Réessayer" |   retry: "Réessayer" | ||||||
| @@ -620,21 +678,21 @@ desktop/views/components/post-form.vue: | |||||||
|   add-visible-user: "+Ajouter un utilisateur" |   add-visible-user: "+Ajouter un utilisateur" | ||||||
|   attach-location-information: "Attacher des informations de localisation" |   attach-location-information: "Attacher des informations de localisation" | ||||||
|   hide-contents: "Masquer les contenus" |   hide-contents: "Masquer les contenus" | ||||||
|   reply-placeholder: "Répondre à cette note" |   reply-placeholder: "Répondre à cette note …" | ||||||
|   quote-placeholder: "Citer cette note" |   quote-placeholder: "Citer cette note …" | ||||||
|   submit: "Poster" |   submit: "Publier" | ||||||
|   reply: "Répondre" |   reply: "Répondre" | ||||||
|   renote: "Republier" |   renote: "Republier" | ||||||
|   posted: "Posté!" |   posted: "Publié !" | ||||||
|   replied: "Répondu!" |   replied: "Répondu !" | ||||||
|   reposted: "Reposté!" |   reposted: "Reposté !" | ||||||
|   note-failed: "La note à échoué" |   note-failed: "La note à échoué" | ||||||
|   reply-failed: "La réponse à échoué" |   reply-failed: "La réponse à échoué" | ||||||
|   renote-failed: "La renote à échoué" |   renote-failed: "Échec lors de la republication" | ||||||
|   posting: "Publication..." |   posting: "Publication …" | ||||||
|   attach-media-from-local: "Joindre un media depuis votre PC" |   attach-media-from-local: "Joindre un média depuis votre appareil" | ||||||
|   attach-media-from-drive: "Joindre un media depuis votre Drive" |   attach-media-from-drive: "Joindre un média depuis votre Drive" | ||||||
|   attach-cancel: "Annuler la jointure de fichier" |   attach-cancel: "Annuler le fichier attaché" | ||||||
|   insert-a-kao: "v('ω')v" |   insert-a-kao: "v('ω')v" | ||||||
|   create-poll: "Créer un sondage" |   create-poll: "Créer un sondage" | ||||||
|   text-remain: "{} charactères restants" |   text-remain: "{} charactères restants" | ||||||
| @@ -649,15 +707,15 @@ desktop/views/components/post-form-window.vue: | |||||||
|   note: "Nouvelle note" |   note: "Nouvelle note" | ||||||
|   reply: "Répondre" |   reply: "Répondre" | ||||||
|   attaches: "{} media joint(s)" |   attaches: "{} media joint(s)" | ||||||
|   uploading-media: "Upload du media {}" |   uploading-media: "Transfert du média {}" | ||||||
| desktop/views/components/progress-dialog.vue: | desktop/views/components/progress-dialog.vue: | ||||||
|   waiting: "En attente" |   waiting: "En attente" | ||||||
| desktop/views/components/renote-form.vue: | desktop/views/components/renote-form.vue: | ||||||
|   quote: "Citer..." |   quote: "Citer..." | ||||||
|   cancel: "Annuler" |   cancel: "Annuler" | ||||||
|   renote: "Republier" |   renote: "Republier" | ||||||
|   reposting: "Repost en cours..." |   reposting: "Republication en cours …" | ||||||
|   success: "Reposté!" |   success: "Republié !" | ||||||
|   failure: "La renote a échoué" |   failure: "La renote a échoué" | ||||||
| desktop/views/components/renote-form-window.vue: | desktop/views/components/renote-form-window.vue: | ||||||
|   title: "Êtes vous sûr de vouloir renote cette note?" |   title: "Êtes vous sûr de vouloir renote cette note?" | ||||||
| @@ -675,6 +733,7 @@ desktop/views/components/settings.vue: | |||||||
|   2fa: "Vérification en deux étapes" |   2fa: "Vérification en deux étapes" | ||||||
|   other: "Autres" |   other: "Autres" | ||||||
|   license: "License" |   license: "License" | ||||||
|  |   theme: "Thèmes" | ||||||
|   behaviour: "Comportement" |   behaviour: "Comportement" | ||||||
|   fetch-on-scroll: "Chargement lors du défilement" |   fetch-on-scroll: "Chargement lors du défilement" | ||||||
|   fetch-on-scroll-desc: "Chargement automatique du contenu lors du défilement de la page." |   fetch-on-scroll-desc: "Chargement automatique du contenu lors du défilement de la page." | ||||||
| @@ -686,30 +745,36 @@ desktop/views/components/settings.vue: | |||||||
|   advanced: "Paramètres avancés" |   advanced: "Paramètres avancés" | ||||||
|   api-via-stream: "Requête API via le flux" |   api-via-stream: "Requête API via le flux" | ||||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" |   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||||
|  |   deck-nav: "デッキ内ナビゲーション" | ||||||
|  |   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||||
|  |   deck-default: "デッキをデフォルトのUIにする" | ||||||
|   display: "Affichage et design" |   display: "Affichage et design" | ||||||
|   customize: "Personnaliser l'Accueil" |   customize: "Personnaliser l'Accueil" | ||||||
|  |   wallpaper: "壁紙" | ||||||
|   choose-wallpaper: "Sélectionner un fond d'écran" |   choose-wallpaper: "Sélectionner un fond d'écran" | ||||||
|   delete-wallpaper: "Supprimer le fond d'écran" |   delete-wallpaper: "Supprimer le fond d'écran" | ||||||
|   dark-mode: "Mode nuit" |   dark-mode: "Mode nuit" | ||||||
|  |   use-shadow: "Utiliser les ombres dans l'interface utilisateur" | ||||||
|  |   rounded-corners: "Coins arrondis" | ||||||
|   circle-icons: "Utiliser des icônes circulaires" |   circle-icons: "Utiliser des icônes circulaires" | ||||||
|   contrasted-acct: "Nom d’utilisateur contrasté" |   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: "Afficher le formulaire en haut du fil" |   post-form-on-timeline: "Afficher le formulaire en haut du fil" | ||||||
|   suggest-recent-hashtags: "Afficher les hashtags populaires dans le champs de saisie" |   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-clock-on-header: "Afficher l'horloge à droite sur le coté supérieur" | ||||||
|   show-reply-target: "Afficher les réponses" |   show-reply-target: "Afficher les réponses" | ||||||
|  |   timeline: "タイムライン" | ||||||
|   show-my-renotes: "Afficher mes republications dans le fil" |   show-my-renotes: "Afficher mes republications dans le fil" | ||||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" |   show-renoted-my-notes: "Afficher mes republications dans les fils" | ||||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" |   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||||
|   show-maps: "Afficher la carte" |   show-maps: "Afficher la carte" | ||||||
|   show-maps-desc: "位置情報が添付された投稿のマップを自動的に展開します。" |   deck-column-align: "デッキのカラムの位置" | ||||||
|  |   deck-column-align-center: "中央" | ||||||
|  |   deck-column-align-left: "左" | ||||||
|   sound: "Son" |   sound: "Son" | ||||||
|   enable-sounds: "Activer le son" |   enable-sounds: "Activer le son" | ||||||
|   enable-sounds-desc: "Jouer un son lorsque vous recevez un message. Ce paramètre est sauvegardé dans le navigateur." |   enable-sounds-desc: "Jouer un son lorsque vous recevez un message. Ce paramètre est sauvegardé dans le navigateur." | ||||||
|   volume: "Volume" |   volume: "Volume" | ||||||
|   test: "Test" |   test: "Test" | ||||||
|   mobile: "Mobile" |  | ||||||
|   disable-via-mobile: "Enlever la mention publié via 'un périphérique mobile'" |  | ||||||
|   language: "Langue" |   language: "Langue" | ||||||
|   pick-language: "Sélectionner une langue" |   pick-language: "Sélectionner une langue" | ||||||
|   recommended: "Recommandé" |   recommended: "Recommandé" | ||||||
| @@ -741,10 +806,14 @@ desktop/views/components/settings.vue: | |||||||
|   debug-mode: "Activer le mode debug" |   debug-mode: "Activer le mode debug" | ||||||
|   debug-mode-desc: "Ce paramètre est stocké dans le navigateur." |   debug-mode-desc: "Ce paramètre est stocké dans le navigateur." | ||||||
|   experimental: "Activer les fonctionnalités expérimentales" |   experimental: "Activer les fonctionnalités expérimentales" | ||||||
|   experimental-desc: "実験的機能を有効にするとMisskeyの動作が不安定になる可能性があります。この設定はブラウザに記憶されます。" |   experimental-desc: "L’activation des fonctionnalités expérimentales peuvent rendre le client Misskey instable. Ce paramètre est stocké dans le navigateur." | ||||||
|   tools: "Outils" |   tools: "Outils" | ||||||
|   task-manager: "Gestionnaire de tâches" |   task-manager: "Gestionnaire de tâches" | ||||||
|   third-parties: "Services tiers" |   third-parties: "Services tiers" | ||||||
|  |   navbar-position: "ナビゲーションバーの位置" | ||||||
|  |   navbar-position-top: "En haut" | ||||||
|  |   navbar-position-left: "à gauche" | ||||||
|  |   navbar-position-right: "à droite" | ||||||
| desktop/views/components/settings.2fa.vue: | desktop/views/components/settings.2fa.vue: | ||||||
|   intro: "Si vous configurez la vérication en deux étapes vous aurez non seulement besoin de votre mot de passe mais aussi un appareil déjà pré-enregistré(tel que votre smartphone) ce qui ameliora grandement la sécurité de votre compte." |   intro: "Si vous configurez la vérication en deux étapes vous aurez non seulement besoin de votre mot de passe mais aussi un appareil déjà pré-enregistré(tel que votre smartphone) ce qui ameliora grandement la sécurité de votre compte." | ||||||
|   detail: "Voir les détails..." |   detail: "Voir les détails..." | ||||||
| @@ -784,20 +853,6 @@ desktop/views/components/settings.password.vue: | |||||||
|   enter-new-password-again: "Entrez à nouveau le nouveau mot de passe" |   enter-new-password-again: "Entrez à nouveau le nouveau mot de passe" | ||||||
|   not-match: "Le nouveau mot de passe ne correspond pas." |   not-match: "Le nouveau mot de passe ne correspond pas." | ||||||
|   changed: "Mot de passe modifié avec succès" |   changed: "Mot de passe modifié avec succès" | ||||||
| desktop/views/components/settings.profile.vue: |  | ||||||
|   avatar: "Avatar" |  | ||||||
|   choice-avatar: "Choose an image" |  | ||||||
|   name: "Nom" |  | ||||||
|   location: "Localisation" |  | ||||||
|   description: "Description" |  | ||||||
|   birthday: "Date de naissance" |  | ||||||
|   save: "Mettre à jour le profil" |  | ||||||
|   locked-account: "Protéger votre compte" |  | ||||||
|   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" |  | ||||||
|   profile-updated: "Profil mis à jour" |  | ||||||
| desktop/views/components/sub-note-content.vue: | desktop/views/components/sub-note-content.vue: | ||||||
|   private: "cette publication est privée" |   private: "cette publication est privée" | ||||||
|   deleted: "cette publication a été supprimée" |   deleted: "cette publication a été supprimée" | ||||||
| @@ -811,15 +866,15 @@ desktop/views/components/timeline.vue: | |||||||
|   hybrid: "Social" |   hybrid: "Social" | ||||||
|   global: "Global" |   global: "Global" | ||||||
|   mentions: "Mentions" |   mentions: "Mentions" | ||||||
|   messages: "メッセージ" |   messages: "Messages" | ||||||
|   list: "Listes" |   list: "Listes" | ||||||
|   hashtag: "ハッシュタグ" |   hashtag: "Hashtag" | ||||||
|   add-tag-timeline: "ハッシュタグを追加" |   add-tag-timeline: "Ajouter un fil de hashtags" | ||||||
|   add-list: "リストを追加" |   add-list: "Ajouter une nouvelle liste" | ||||||
|   list-name: "リスト名" |   list-name: "Nom de la liste" | ||||||
| desktop/views/components/ui.header.vue: | desktop/views/components/ui.header.vue: | ||||||
|   welcome-back: "Content de vous revoir !" |   welcome-back: "Content de vous revoir !" | ||||||
|   adjective: "さん" |   adjective: "M." | ||||||
| desktop/views/components/ui.header.account.vue: | desktop/views/components/ui.header.account.vue: | ||||||
|   profile: "Votre profil" |   profile: "Votre profil" | ||||||
|   drive: "Drive" |   drive: "Drive" | ||||||
| @@ -839,7 +894,7 @@ desktop/views/components/ui.header.nav.vue: | |||||||
| desktop/views/components/ui.header.notifications.vue: | desktop/views/components/ui.header.notifications.vue: | ||||||
|   title: "Notifications" |   title: "Notifications" | ||||||
| desktop/views/components/ui.header.post.vue: | desktop/views/components/ui.header.post.vue: | ||||||
|   post: "Composer un nouveau post" |   post: "Rédiger une nouvelle publication" | ||||||
| desktop/views/components/ui.header.search.vue: | desktop/views/components/ui.header.search.vue: | ||||||
|   placeholder: "Chercher" |   placeholder: "Chercher" | ||||||
| desktop/views/components/received-follow-requests-window.vue: | desktop/views/components/received-follow-requests-window.vue: | ||||||
| @@ -872,9 +927,9 @@ desktop/views/pages/admin/admin.vue: | |||||||
| desktop/views/pages/admin/admin.dashboard.vue: | desktop/views/pages/admin/admin.dashboard.vue: | ||||||
|   dashboard: "Tableau de bord" |   dashboard: "Tableau de bord" | ||||||
|   all-users: "Toutes les utilisateurrices" |   all-users: "Toutes les utilisateurrices" | ||||||
|   original-users: "Utilisateurrices sur cette instance" |   original-users: "Utilisateur·rice·s sur cette instance" | ||||||
|   all-notes: "Toutes les publications" |   all-notes: "Toutes les publications" | ||||||
|   original-notes: "Publication sur cette instance" |   original-notes: "Publications sur cette instance" | ||||||
|   invite: "Invitation" |   invite: "Invitation" | ||||||
| desktop/views/pages/admin/admin.suspend-user.vue: | desktop/views/pages/admin/admin.suspend-user.vue: | ||||||
|   suspend-user: "Suspendre un·e utilisateur·rice" |   suspend-user: "Suspendre un·e utilisateur·rice" | ||||||
| @@ -896,15 +951,13 @@ desktop/views/pages/deck/deck.tl-column.vue: | |||||||
|   is-media-only: "Les publications médias uniquement" |   is-media-only: "Les publications médias uniquement" | ||||||
|   is-media-view: "Vue média" |   is-media-view: "Vue média" | ||||||
|   edit: "Options" |   edit: "Options" | ||||||
| desktop/views/pages/deck/deck.note.vue: | desktop/views/pages/deck/deck.user-column.vue: | ||||||
|   reposted-by: "Reposté par {}" |   pinned-notes: "ピン留めされた投稿" | ||||||
|   private: "cette publication est privée" |  | ||||||
|   deleted: "cette publication a été supprimée" |  | ||||||
| desktop/views/pages/stats/stats.vue: | desktop/views/pages/stats/stats.vue: | ||||||
|   all-users: "Toutes les utilisateurrices" |   all-users: "Toutes les utilisateurrices" | ||||||
|   original-users: "Utilisateurrices sur cette instance" |   original-users: "Utilisateur·rice·s sur cette instance" | ||||||
|   all-notes: "Toutes les publications" |   all-notes: "Toutes les publications" | ||||||
|   original-notes: "Publication sur cette instance" |   original-notes: "Publications sur cette instance" | ||||||
| desktop/views/pages/welcome.vue: | desktop/views/pages/welcome.vue: | ||||||
|   about: "à propos" |   about: "à propos" | ||||||
|   gotit: "J'ai compris !" |   gotit: "J'ai compris !" | ||||||
| @@ -930,9 +983,9 @@ desktop/views/pages/selectdrive.vue: | |||||||
|   title: "Choisir fichier(s)" |   title: "Choisir fichier(s)" | ||||||
|   ok: "OK" |   ok: "OK" | ||||||
|   cancel: "Annuler" |   cancel: "Annuler" | ||||||
|   upload: "Uploader un ou plusieurs fichier(s) depuis votre PC" |   upload: "Téléverser des fichiers à partir de votre ordinateur" | ||||||
| desktop/views/pages/search.vue: | desktop/views/pages/search.vue: | ||||||
|   not-available: "検索機能はインスタンスの設定で無効になっています。" |   not-available: "La fonction de recherche est désactivée dans les paramètres de l’instance." | ||||||
|   not-found: "Aucun message trouvé pour '{}'" |   not-found: "Aucun message trouvé pour '{}'" | ||||||
| desktop/views/pages/share.vue: | desktop/views/pages/share.vue: | ||||||
|   share-with: "Partager avec {}" |   share-with: "Partager avec {}" | ||||||
| @@ -947,13 +1000,13 @@ desktop/views/pages/user/user.followers-you-know.vue: | |||||||
|   loading: "Chargement en cours" |   loading: "Chargement en cours" | ||||||
|   no-users: "Pas d'utilisateurs" |   no-users: "Pas d'utilisateurs" | ||||||
| desktop/views/pages/user/user.friends.vue: | desktop/views/pages/user/user.friends.vue: | ||||||
|   title: "Personnes qui répondent le plus" |   title: "Mentions fréquentes" | ||||||
|   loading: "Chargement en cours" |   loading: "Chargement en cours" | ||||||
|   no-users: "Pas d'utilisateurs" |   no-users: "Pas d'utilisateurs" | ||||||
| desktop/views/pages/user/user.vue: | desktop/views/pages/user/user.vue: | ||||||
|   is-suspended: "Ce compte a été suspendu." |   is-suspended: "Ce compte a été suspendu." | ||||||
|   is-remote: "Cet utilisateur n'est pas un utilisateur de Misskey. Certaines informations peuvent être erronées" |   is-remote: "Cet utilisateur n'est pas un utilisateur Misskey. Certaines informations peuvent ne pas refléter ce profil dans sa totalité." | ||||||
|   view-remote: "Voir les informations détaillées" |   view-remote: "Consulter le profil complet" | ||||||
| desktop/views/pages/user/user.home.vue: | desktop/views/pages/user/user.home.vue: | ||||||
|   last-used-at: "Last used at" |   last-used-at: "Last used at" | ||||||
| desktop/views/pages/user/user.photos.vue: | desktop/views/pages/user/user.photos.vue: | ||||||
| @@ -961,7 +1014,7 @@ desktop/views/pages/user/user.photos.vue: | |||||||
|   loading: "Chargement en cours" |   loading: "Chargement en cours" | ||||||
|   no-photos: "Pas de photos" |   no-photos: "Pas de photos" | ||||||
| desktop/views/pages/user/user.profile.vue: | desktop/views/pages/user/user.profile.vue: | ||||||
|   follows-you: "Vous suis" |   follows-you: "Vous suit" | ||||||
|   stalk: "Traquer" |   stalk: "Traquer" | ||||||
|   stalking: "ストーキングしています" |   stalking: "ストーキングしています" | ||||||
|   unstalk: "ストーク解除" |   unstalk: "ストーク解除" | ||||||
| @@ -990,8 +1043,8 @@ desktop/views/widgets/polls.vue: | |||||||
|   refresh: "Afficher d'autres" |   refresh: "Afficher d'autres" | ||||||
|   nothing: "Rien" |   nothing: "Rien" | ||||||
| desktop/views/widgets/post-form.vue: | desktop/views/widgets/post-form.vue: | ||||||
|   title: "Post" |   title: "Publication" | ||||||
|   note: "Post" |   note: "Publication" | ||||||
| desktop/views/widgets/profile.vue: | desktop/views/widgets/profile.vue: | ||||||
|   update-banner: "Cliquer pour éditer votre bannière" |   update-banner: "Cliquer pour éditer votre bannière" | ||||||
|   update-avatar: "Cliquer pour éditer votre avatar" |   update-avatar: "Cliquer pour éditer votre avatar" | ||||||
| @@ -1034,6 +1087,8 @@ mobile/views/components/drive.file-detail.vue: | |||||||
|   hash: "Hash (md5)" |   hash: "Hash (md5)" | ||||||
|   exif: "EXIF" |   exif: "EXIF" | ||||||
|   nsfw: "CW" |   nsfw: "CW" | ||||||
|  |   mark-as-sensitive: "閲覧注意に設定" | ||||||
|  |   unmark-as-sensitive: "閲覧注意を解除" | ||||||
| mobile/views/components/media-image.vue: | mobile/views/components/media-image.vue: | ||||||
|   sensitive: "Le contenu est NSFW" |   sensitive: "Le contenu est NSFW" | ||||||
|   click-to-show: "Cliquer pour afficher" |   click-to-show: "Cliquer pour afficher" | ||||||
| @@ -1044,6 +1099,7 @@ mobile/views/components/follow-button.vue: | |||||||
|   following: "Abonnements" |   following: "Abonnements" | ||||||
|   follow: "Suivre" |   follow: "Suivre" | ||||||
|   request-pending: "En attente d'approbation" |   request-pending: "En attente d'approbation" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "Demande d'abonnement" |   follow-request: "Demande d'abonnement" | ||||||
| mobile/views/components/friends-maker.vue: | mobile/views/components/friends-maker.vue: | ||||||
|   title: "Abonnez-vous aux utilisateurs" |   title: "Abonnez-vous aux utilisateurs" | ||||||
| @@ -1052,7 +1108,7 @@ mobile/views/components/friends-maker.vue: | |||||||
|   refresh: "Voir plus" |   refresh: "Voir plus" | ||||||
|   close: "Fermer" |   close: "Fermer" | ||||||
| mobile/views/components/note.vue: | mobile/views/components/note.vue: | ||||||
|   reposted-by: "Renoté par {}" |   reposted-by: "Republié par {}" | ||||||
|   private: "cette publication est privée" |   private: "cette publication est privée" | ||||||
|   deleted: "cette publication a été supprimée" |   deleted: "cette publication a été supprimée" | ||||||
|   location: "Géolocalisation" |   location: "Géolocalisation" | ||||||
| @@ -1079,7 +1135,7 @@ mobile/views/components/notifications.vue: | |||||||
|   empty: "Pas de notifications" |   empty: "Pas de notifications" | ||||||
| mobile/views/components/post-form.vue: | mobile/views/components/post-form.vue: | ||||||
|   add-visible-user: "Ajouter un utilisateur" |   add-visible-user: "Ajouter un utilisateur" | ||||||
|   submit: "Poster" |   submit: "Publier" | ||||||
|   reply: "Répondre" |   reply: "Répondre" | ||||||
|   renote: "Republier" |   renote: "Republier" | ||||||
|   quote-placeholder: "Citer ce billet ... (Facultatif)" |   quote-placeholder: "Citer ce billet ... (Facultatif)" | ||||||
| @@ -1131,7 +1187,7 @@ mobile/views/pages/drive.vue: | |||||||
|   drive: "Drive" |   drive: "Drive" | ||||||
|   more: "Afficher plus ..." |   more: "Afficher plus ..." | ||||||
| mobile/views/pages/signup.vue: | mobile/views/pages/signup.vue: | ||||||
|   lets-start: "Commençons ! 📦" |   lets-start: "Votre compte est prêt ! 📦" | ||||||
| mobile/views/pages/followers.vue: | mobile/views/pages/followers.vue: | ||||||
|   followers-of: "Abonné·e·s de {}" |   followers-of: "Abonné·e·s de {}" | ||||||
| mobile/views/pages/following.vue: | mobile/views/pages/following.vue: | ||||||
| @@ -1142,7 +1198,7 @@ mobile/views/pages/home.vue: | |||||||
|   hybrid: "Social" |   hybrid: "Social" | ||||||
|   global: "Global" |   global: "Global" | ||||||
|   mentions: "Mentions" |   mentions: "Mentions" | ||||||
|   messages: "メッセージ" |   messages: "Messages" | ||||||
| mobile/views/pages/tag.vue: | mobile/views/pages/tag.vue: | ||||||
|   no-posts-found: "Pas de message avec un hashtag {} trouvé." |   no-posts-found: "Pas de message avec un hashtag {} trouvé." | ||||||
| mobile/views/pages/welcome.vue: | mobile/views/pages/welcome.vue: | ||||||
| @@ -1173,23 +1229,6 @@ mobile/views/pages/notifications.vue: | |||||||
|   read-all: "Êtes vous sûr de vouloir marqués toutes les notifications non-lus en tant que lus?" |   read-all: "Êtes vous sûr de vouloir marqués toutes les notifications non-lus en tant que lus?" | ||||||
| mobile/views/pages/games/reversi.vue: | mobile/views/pages/games/reversi.vue: | ||||||
|   reversi: "Reversi" |   reversi: "Reversi" | ||||||
| mobile/views/pages/settings/settings.profile.vue: |  | ||||||
|   title: "Profil" |  | ||||||
|   name: "Nom" |  | ||||||
|   account: "Compte" |  | ||||||
|   location: "Lieu" |  | ||||||
|   description: "Description" |  | ||||||
|   birthday: "Date de naissance" |  | ||||||
|   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" |  | ||||||
|   upload-failed: "Échec de l'envoi" |  | ||||||
| mobile/views/pages/search.vue: | mobile/views/pages/search.vue: | ||||||
|   search: "Chercher" |   search: "Chercher" | ||||||
|   empty: "Aucun message trouvé pour '{}' " |   empty: "Aucun message trouvé pour '{}' " | ||||||
| @@ -1219,6 +1258,7 @@ mobile/views/pages/settings.vue: | |||||||
|   notification-position: "Style de notification" |   notification-position: "Style de notification" | ||||||
|   notification-position-bottom: "en bas" |   notification-position-bottom: "en bas" | ||||||
|   notification-position-top: "en haut" |   notification-position-top: "en haut" | ||||||
|  |   theme: "Thème" | ||||||
|   behavior: "Comportement" |   behavior: "Comportement" | ||||||
|   fetch-on-scroll: "Chargement lors du défilement" |   fetch-on-scroll: "Chargement lors du défilement" | ||||||
|   note-visibility: "Visibilité de la publication" |   note-visibility: "Visibilité de la publication" | ||||||
| @@ -1245,7 +1285,7 @@ mobile/views/pages/settings.vue: | |||||||
|   sound: "Sons" |   sound: "Sons" | ||||||
|   enable-sounds: "Activer les sons" |   enable-sounds: "Activer les sons" | ||||||
| mobile/views/pages/user.vue: | mobile/views/pages/user.vue: | ||||||
|   follows-you: "vous suit" |   follows-you: "Vous suit" | ||||||
|   following: "Abonnements" |   following: "Abonnements" | ||||||
|   followers: "Abonné·e·s" |   followers: "Abonné·e·s" | ||||||
|   notes: "Notes" |   notes: "Notes" | ||||||
| @@ -1253,8 +1293,8 @@ mobile/views/pages/user.vue: | |||||||
|   timeline: "Fil d'actualité" |   timeline: "Fil d'actualité" | ||||||
|   media: "Media" |   media: "Media" | ||||||
|   is-suspended: "This account has been suspended." |   is-suspended: "This account has been suspended." | ||||||
|   is-remote: "Cet utilisateur n'est pas un utilisateur de Misskey. Certaines informations peuvent être erronées " |   is-remote: "Ceci est le profil d’un utilisateur·rice distant·e. Certaines informations peuvent ne pas refléter ce profil dans sa totalité." | ||||||
|   view-remote: "Voir les informations détaillées" |   view-remote: "Consulter son profil complet" | ||||||
| mobile/views/pages/user/home.vue: | mobile/views/pages/user/home.vue: | ||||||
|   recent-notes: "Notes récentes" |   recent-notes: "Notes récentes" | ||||||
|   images: "Images" |   images: "Images" | ||||||
| @@ -1278,7 +1318,7 @@ mobile/views/pages/user/home.photos.vue: | |||||||
|   no-photos: "Pas de photos" |   no-photos: "Pas de photos" | ||||||
| docs: | docs: | ||||||
|   edit-this-page-on-github: "Vous avez trouvé une erreur ou vous voulez contribuer à la documentation?" |   edit-this-page-on-github: "Vous avez trouvé une erreur ou vous voulez contribuer à la documentation?" | ||||||
|   edit-this-page-on-github-link: "Modifiez cette page sur github!" |   edit-this-page-on-github-link: "Éditez cette page sur Github !" | ||||||
|   api: |   api: | ||||||
|     entities: |     entities: | ||||||
|       properties: "Propriétés" |       properties: "Propriétés" | ||||||
|   | |||||||
| @@ -264,6 +264,41 @@ common/views/components/connect-failed.troubleshooter.vue: | |||||||
| common/views/components/media-banner.vue: | common/views/components/media-banner.vue: | ||||||
|   sensitive: "閲覧注意" |   sensitive: "閲覧注意" | ||||||
|   click-to-show: "クリックして表示" |   click-to-show: "クリックして表示" | ||||||
|  | common/views/components/theme.vue: | ||||||
|  |   light-theme: "非ダークモード時に使用するテーマ" | ||||||
|  |   dark-theme: "ダークモード時に使用するテーマ" | ||||||
|  |   light-themes: "明るいテーマ" | ||||||
|  |   dark-themes: "暗いテーマ" | ||||||
|  |   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: "保存しました" | ||||||
|  |   manage-themes: "テーマの管理" | ||||||
|  |   builtin-themes: "標準テーマ" | ||||||
|  |   my-themes: "マイテーマ" | ||||||
|  |   installed-themes: "インストールされたテーマ" | ||||||
|  |   select-theme: "テーマを選択してください" | ||||||
|  |   uninstall: "アンインストール" | ||||||
|  |   uninstalled: "「{}」をアンインストールしました" | ||||||
|  |   author: "作者" | ||||||
|  |   desc: "説明" | ||||||
|  |   export: "エクスポート" | ||||||
|  |   import: "インポート" | ||||||
|  |   import-by-code: "またはコードをペースト" | ||||||
|  |   theme-name-required: "テーマ名は必須です。" | ||||||
| common/views/components/cw-button.vue: | common/views/components/cw-button.vue: | ||||||
|   hide: "隠す" |   hide: "隠す" | ||||||
|   show: "もっと見る" |   show: "もっと見る" | ||||||
| @@ -300,7 +335,9 @@ common/views/components/note-menu.vue: | |||||||
|   detail: "詳細" |   detail: "詳細" | ||||||
|   copy-link: "リンクをコピー" |   copy-link: "リンクをコピー" | ||||||
|   favorite: "お気に入り" |   favorite: "お気に入り" | ||||||
|  |   unfavorite: "お気に入り解除" | ||||||
|   pin: "ピン留め" |   pin: "ピン留め" | ||||||
|  |   unpin: "ピン留め解除" | ||||||
|   delete: "削除" |   delete: "削除" | ||||||
|   delete-confirm: "この投稿を削除しますか?" |   delete-confirm: "この投稿を削除しますか?" | ||||||
|   remote: "投稿元で見る" |   remote: "投稿元で見る" | ||||||
| @@ -379,6 +416,25 @@ common/views/components/visibility-chooser.vue: | |||||||
| common/views/components/trends.vue: | common/views/components/trends.vue: | ||||||
|   count: "{}人が投稿" |   count: "{}人が投稿" | ||||||
|   empty: "トレンドなし" |   empty: "トレンドなし" | ||||||
|  | common/views/components/profile-editor.vue: | ||||||
|  |   title: "プロフィール" | ||||||
|  |   name: "名前" | ||||||
|  |   account: "アカウント" | ||||||
|  |   location: "場所" | ||||||
|  |   description: "自己紹介" | ||||||
|  |   birthday: "誕生日" | ||||||
|  |   avatar: "アイコン" | ||||||
|  |   banner: "バナー" | ||||||
|  |   is-cat: "このアカウントはCatです" | ||||||
|  |   is-bot: "このアカウントはBotです" | ||||||
|  |   is-locked: "フォローを承認制にする" | ||||||
|  |   careful-bot: "Botからのフォローだけ承認制にする" | ||||||
|  |   advanced: "その他" | ||||||
|  |   privacy: "プライバシー" | ||||||
|  |   save: "保存" | ||||||
|  |   saved: "プロフィールを保存しました" | ||||||
|  |   uploading: "アップロード中" | ||||||
|  |   upload-failed: "アップロードに失敗しました" | ||||||
| common/views/widgets/broadcast.vue: | common/views/widgets/broadcast.vue: | ||||||
|   fetching: "確認中" |   fetching: "確認中" | ||||||
|   no-broadcasts: "お知らせはありません" |   no-broadcasts: "お知らせはありません" | ||||||
| @@ -439,6 +495,7 @@ common/views/pages/follow.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| desktop: | desktop: | ||||||
|   banner-crop-title: "バナーとして表示する部分を選択" |   banner-crop-title: "バナーとして表示する部分を選択" | ||||||
| @@ -477,13 +534,13 @@ desktop/views/components/charts.vue: | |||||||
|     notes: "投稿の増減 (統合)" |     notes: "投稿の増減 (統合)" | ||||||
|     local-notes: "投稿の増減 (ローカル)" |     local-notes: "投稿の増減 (ローカル)" | ||||||
|     remote-notes: "投稿の増減 (リモート)" |     remote-notes: "投稿の増減 (リモート)" | ||||||
|     notes-total: "投稿の累計" |     notes-total: "投稿の積算" | ||||||
|     users: "ユーザーの増減" |     users: "ユーザーの増減" | ||||||
|     users-total: "ユーザーの累計" |     users-total: "ユーザーの積算" | ||||||
|     drive: "ドライブ使用量の増減" |     drive: "ドライブ使用量の増減" | ||||||
|     drive-total: "ドライブ使用量の累計" |     drive-total: "ドライブ使用量の積算" | ||||||
|     drive-files: "ドライブのファイル数の増減" |     drive-files: "ドライブのファイル数の増減" | ||||||
|     drive-files-total: "ドライブのファイル数の累計" |     drive-files-total: "ドライブのファイル数の積算" | ||||||
|     network-requests: "リクエスト" |     network-requests: "リクエスト" | ||||||
|     network-time: "応答時間" |     network-time: "応答時間" | ||||||
|     network-usage: "通信量" |     network-usage: "通信量" | ||||||
| @@ -565,6 +622,7 @@ desktop/views/components/follow-button.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| desktop/views/components/followers-window.vue: | desktop/views/components/followers-window.vue: | ||||||
|   followers: "{} のフォロワー" |   followers: "{} のフォロワー" | ||||||
| @@ -601,7 +659,7 @@ desktop/views/components/note-detail.vue: | |||||||
|   location: "位置情報" |   location: "位置情報" | ||||||
|   renote: "Renote" |   renote: "Renote" | ||||||
|   add-reaction: "リアクション" |   add-reaction: "リアクション" | ||||||
| desktop/views/components/notes.note.vue: | desktop/views/components/note.vue: | ||||||
|   reposted-by: "{}がRenote" |   reposted-by: "{}がRenote" | ||||||
|   reply: "返信" |   reply: "返信" | ||||||
|   renote: "Renote" |   renote: "Renote" | ||||||
| @@ -675,6 +733,7 @@ desktop/views/components/settings.vue: | |||||||
|   2fa: "二段階認証" |   2fa: "二段階認証" | ||||||
|   other: "その他" |   other: "その他" | ||||||
|   license: "ライセンス" |   license: "ライセンス" | ||||||
|  |   theme: "テーマ" | ||||||
|   behaviour: "動作" |   behaviour: "動作" | ||||||
|   fetch-on-scroll: "スクロールで自動読み込み" |   fetch-on-scroll: "スクロールで自動読み込み" | ||||||
|   fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込みます。" |   fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込みます。" | ||||||
| @@ -686,30 +745,36 @@ desktop/views/components/settings.vue: | |||||||
|   advanced: "詳細設定" |   advanced: "詳細設定" | ||||||
|   api-via-stream: "ストリームを経由したAPIリクエスト" |   api-via-stream: "ストリームを経由したAPIリクエスト" | ||||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" |   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||||
|  |   deck-nav: "デッキ内ナビゲーション" | ||||||
|  |   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||||
|  |   deck-default: "デッキをデフォルトのUIにする" | ||||||
|   display: "デザインと表示" |   display: "デザインと表示" | ||||||
|   customize: "ホームをカスタマイズ" |   customize: "ホームをカスタマイズ" | ||||||
|  |   wallpaper: "壁紙" | ||||||
|   choose-wallpaper: "壁紙を選択" |   choose-wallpaper: "壁紙を選択" | ||||||
|   delete-wallpaper: "壁紙を削除" |   delete-wallpaper: "壁紙を削除" | ||||||
|   dark-mode: "ダークモード" |   dark-mode: "ダークモード" | ||||||
|  |   use-shadow: "UIに影を使用" | ||||||
|  |   rounded-corners: "UIの角を丸める" | ||||||
|   circle-icons: "円形のアイコンを使用" |   circle-icons: "円形のアイコンを使用" | ||||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" |   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" |  | ||||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" |   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" |   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||||
|   show-clock-on-header: "右上に時計を表示する" |   show-clock-on-header: "右上に時計を表示する" | ||||||
|   show-reply-target: "リプライ先を表示する" |   show-reply-target: "リプライ先を表示する" | ||||||
|  |   timeline: "タイムライン" | ||||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" |   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" |   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" |   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||||
|   show-maps: "マップの自動展開" |   show-maps: "マップの自動展開" | ||||||
|   show-maps-desc: "位置情報が添付された投稿のマップを自動的に展開します。" |   deck-column-align: "デッキのカラムの位置" | ||||||
|  |   deck-column-align-center: "中央" | ||||||
|  |   deck-column-align-left: "左" | ||||||
|   sound: "サウンド" |   sound: "サウンド" | ||||||
|   enable-sounds: "サウンドを有効にする" |   enable-sounds: "サウンドを有効にする" | ||||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" |   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||||
|   volume: "ボリューム" |   volume: "ボリューム" | ||||||
|   test: "テスト" |   test: "テスト" | ||||||
|   mobile: "モバイル" |  | ||||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" |  | ||||||
|   language: "言語" |   language: "言語" | ||||||
|   pick-language: "言語を選択" |   pick-language: "言語を選択" | ||||||
|   recommended: "推奨" |   recommended: "推奨" | ||||||
| @@ -745,6 +810,10 @@ desktop/views/components/settings.vue: | |||||||
|   tools: "ツール" |   tools: "ツール" | ||||||
|   task-manager: "タスクマネージャ" |   task-manager: "タスクマネージャ" | ||||||
|   third-parties: "サードパーティ" |   third-parties: "サードパーティ" | ||||||
|  |   navbar-position: "ナビゲーションバーの位置" | ||||||
|  |   navbar-position-top: "上" | ||||||
|  |   navbar-position-left: "左" | ||||||
|  |   navbar-position-right: "右" | ||||||
| desktop/views/components/settings.2fa.vue: | desktop/views/components/settings.2fa.vue: | ||||||
|   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" |   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" | ||||||
|   detail: "詳細..." |   detail: "詳細..." | ||||||
| @@ -784,20 +853,6 @@ desktop/views/components/settings.password.vue: | |||||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" |   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||||
|   not-match: "新しいパスワードが一致しません" |   not-match: "新しいパスワードが一致しません" | ||||||
|   changed: "パスワードを変更しました" |   changed: "パスワードを変更しました" | ||||||
| desktop/views/components/settings.profile.vue: |  | ||||||
|   avatar: "アイコン" |  | ||||||
|   choice-avatar: "画像を選択" |  | ||||||
|   name: "名前" |  | ||||||
|   location: "場所" |  | ||||||
|   description: "自己紹介" |  | ||||||
|   birthday: "誕生日" |  | ||||||
|   save: "保存" |  | ||||||
|   locked-account: "アカウントの保護" |  | ||||||
|   is-locked: "フォローを承認制にする" |  | ||||||
|   other: "その他" |  | ||||||
|   is-bot: "このアカウントはBotです" |  | ||||||
|   is-cat: "このアカウントはCatです" |  | ||||||
|   profile-updated: "プロフィールを更新しました" |  | ||||||
| desktop/views/components/sub-note-content.vue: | desktop/views/components/sub-note-content.vue: | ||||||
|   private: "この投稿は非公開です" |   private: "この投稿は非公開です" | ||||||
|   deleted: "この投稿は削除されました" |   deleted: "この投稿は削除されました" | ||||||
| @@ -896,10 +951,8 @@ desktop/views/pages/deck/deck.tl-column.vue: | |||||||
|   is-media-only: "メディア投稿のみ" |   is-media-only: "メディア投稿のみ" | ||||||
|   is-media-view: "メディアビュー" |   is-media-view: "メディアビュー" | ||||||
|   edit: "オプション" |   edit: "オプション" | ||||||
| desktop/views/pages/deck/deck.note.vue: | desktop/views/pages/deck/deck.user-column.vue: | ||||||
|   reposted-by: "{}がRenote" |   pinned-notes: "ピン留めされた投稿" | ||||||
|   private: "この投稿は非公開です" |  | ||||||
|   deleted: "この投稿は削除されました" |  | ||||||
| desktop/views/pages/stats/stats.vue: | desktop/views/pages/stats/stats.vue: | ||||||
|   all-users: "全てのユーザー" |   all-users: "全てのユーザー" | ||||||
|   original-users: "このインスタンスのユーザー" |   original-users: "このインスタンスのユーザー" | ||||||
| @@ -1034,6 +1087,8 @@ mobile/views/components/drive.file-detail.vue: | |||||||
|   hash: "ハッシュ (md5)" |   hash: "ハッシュ (md5)" | ||||||
|   exif: "EXIF" |   exif: "EXIF" | ||||||
|   nsfw: "閲覧注意" |   nsfw: "閲覧注意" | ||||||
|  |   mark-as-sensitive: "閲覧注意に設定" | ||||||
|  |   unmark-as-sensitive: "閲覧注意を解除" | ||||||
| mobile/views/components/media-image.vue: | mobile/views/components/media-image.vue: | ||||||
|   sensitive: "閲覧注意" |   sensitive: "閲覧注意" | ||||||
|   click-to-show: "クリックして表示" |   click-to-show: "クリックして表示" | ||||||
| @@ -1044,6 +1099,7 @@ mobile/views/components/follow-button.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| mobile/views/components/friends-maker.vue: | mobile/views/components/friends-maker.vue: | ||||||
|   title: "気になるユーザーをフォロー" |   title: "気になるユーザーをフォロー" | ||||||
| @@ -1173,23 +1229,6 @@ mobile/views/pages/notifications.vue: | |||||||
|   read-all: "すべての通知を既読にしますか?" |   read-all: "すべての通知を既読にしますか?" | ||||||
| mobile/views/pages/games/reversi.vue: | mobile/views/pages/games/reversi.vue: | ||||||
|   reversi: "リバーシ" |   reversi: "リバーシ" | ||||||
| mobile/views/pages/settings/settings.profile.vue: |  | ||||||
|   title: "プロフィール" |  | ||||||
|   name: "名前" |  | ||||||
|   account: "アカウント" |  | ||||||
|   location: "場所" |  | ||||||
|   description: "自己紹介" |  | ||||||
|   birthday: "誕生日" |  | ||||||
|   avatar: "アイコン" |  | ||||||
|   banner: "バナー" |  | ||||||
|   is-cat: "このアカウントはCatです" |  | ||||||
|   is-locked: "フォローを承認制にする" |  | ||||||
|   advanced: "その他" |  | ||||||
|   privacy: "プライバシー" |  | ||||||
|   save: "保存" |  | ||||||
|   saved: "プロフィールを保存しました" |  | ||||||
|   uploading: "アップロード中" |  | ||||||
|   upload-failed: "アップロードに失敗しました" |  | ||||||
| mobile/views/pages/search.vue: | mobile/views/pages/search.vue: | ||||||
|   search: "検索" |   search: "検索" | ||||||
|   empty: "「{}」に関する投稿は見つかりませんでした。" |   empty: "「{}」に関する投稿は見つかりませんでした。" | ||||||
| @@ -1219,6 +1258,7 @@ mobile/views/pages/settings.vue: | |||||||
|   notification-position: "通知の表示" |   notification-position: "通知の表示" | ||||||
|   notification-position-bottom: "下" |   notification-position-bottom: "下" | ||||||
|   notification-position-top: "上" |   notification-position-top: "上" | ||||||
|  |   theme: "テーマ" | ||||||
|   behavior: "動作" |   behavior: "動作" | ||||||
|   fetch-on-scroll: "スクロールで自動読み込み" |   fetch-on-scroll: "スクロールで自動読み込み" | ||||||
|   note-visibility: "投稿の公開範囲" |   note-visibility: "投稿の公開範囲" | ||||||
|   | |||||||
| @@ -124,6 +124,10 @@ common: | |||||||
|  |  | ||||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' |   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||||
|  |  | ||||||
|  |   error: | ||||||
|  |     title: '問題が発生しました' | ||||||
|  |     retry: 'やり直す' | ||||||
|  |  | ||||||
|   reversi: |   reversi: | ||||||
|     drawn: "引き分け" |     drawn: "引き分け" | ||||||
|     my-turn: "あなたのターンです" |     my-turn: "あなたのターンです" | ||||||
| @@ -285,6 +289,42 @@ common/views/components/media-banner.vue: | |||||||
|   sensitive: "閲覧注意" |   sensitive: "閲覧注意" | ||||||
|   click-to-show: "クリックして表示" |   click-to-show: "クリックして表示" | ||||||
|  |  | ||||||
|  | common/views/components/theme.vue: | ||||||
|  |   light-theme: "非ダークモード時に使用するテーマ" | ||||||
|  |   dark-theme: "ダークモード時に使用するテーマ" | ||||||
|  |   light-themes: "明るいテーマ" | ||||||
|  |   dark-themes: "暗いテーマ" | ||||||
|  |   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: "保存しました" | ||||||
|  |   manage-themes: "テーマの管理" | ||||||
|  |   builtin-themes: "標準テーマ" | ||||||
|  |   my-themes: "マイテーマ" | ||||||
|  |   installed-themes: "インストールされたテーマ" | ||||||
|  |   select-theme: "テーマを選択してください" | ||||||
|  |   uninstall: "アンインストール" | ||||||
|  |   uninstalled: "「{}」をアンインストールしました" | ||||||
|  |   author: "作者" | ||||||
|  |   desc: "説明" | ||||||
|  |   export: "エクスポート" | ||||||
|  |   import: "インポート" | ||||||
|  |   import-by-code: "またはコードをペースト" | ||||||
|  |   theme-name-required: "テーマ名は必須です。" | ||||||
|  |  | ||||||
| common/views/components/cw-button.vue: | common/views/components/cw-button.vue: | ||||||
|   hide: "隠す" |   hide: "隠す" | ||||||
|   show: "もっと見る" |   show: "もっと見る" | ||||||
| @@ -327,7 +367,9 @@ common/views/components/note-menu.vue: | |||||||
|   detail: "詳細" |   detail: "詳細" | ||||||
|   copy-link: "リンクをコピー" |   copy-link: "リンクをコピー" | ||||||
|   favorite: "お気に入り" |   favorite: "お気に入り" | ||||||
|  |   unfavorite: "お気に入り解除" | ||||||
|   pin: "ピン留め" |   pin: "ピン留め" | ||||||
|  |   unpin: "ピン留め解除" | ||||||
|   delete: "削除" |   delete: "削除" | ||||||
|   delete-confirm: "この投稿を削除しますか?" |   delete-confirm: "この投稿を削除しますか?" | ||||||
|   remote: "投稿元で見る" |   remote: "投稿元で見る" | ||||||
| @@ -418,6 +460,26 @@ common/views/components/trends.vue: | |||||||
|   count: "{}人が投稿" |   count: "{}人が投稿" | ||||||
|   empty: "トレンドなし" |   empty: "トレンドなし" | ||||||
|  |  | ||||||
|  | common/views/components/profile-editor.vue: | ||||||
|  |   title: "プロフィール" | ||||||
|  |   name: "名前" | ||||||
|  |   account: "アカウント" | ||||||
|  |   location: "場所" | ||||||
|  |   description: "自己紹介" | ||||||
|  |   birthday: "誕生日" | ||||||
|  |   avatar: "アイコン" | ||||||
|  |   banner: "バナー" | ||||||
|  |   is-cat: "このアカウントはCatです" | ||||||
|  |   is-bot: "このアカウントはBotです" | ||||||
|  |   is-locked: "フォローを承認制にする" | ||||||
|  |   careful-bot: "Botからのフォローだけ承認制にする" | ||||||
|  |   advanced: "その他" | ||||||
|  |   privacy: "プライバシー" | ||||||
|  |   save: "保存" | ||||||
|  |   saved: "プロフィールを保存しました" | ||||||
|  |   uploading: "アップロード中" | ||||||
|  |   upload-failed: "アップロードに失敗しました" | ||||||
|  |  | ||||||
| common/views/widgets/broadcast.vue: | common/views/widgets/broadcast.vue: | ||||||
|   fetching: "確認中" |   fetching: "確認中" | ||||||
|   no-broadcasts: "お知らせはありません" |   no-broadcasts: "お知らせはありません" | ||||||
| @@ -488,6 +550,7 @@ common/views/pages/follow.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
|  |  | ||||||
| desktop: | desktop: | ||||||
| @@ -531,13 +594,13 @@ desktop/views/components/charts.vue: | |||||||
|     notes: "投稿の増減 (統合)" |     notes: "投稿の増減 (統合)" | ||||||
|     local-notes: "投稿の増減 (ローカル)" |     local-notes: "投稿の増減 (ローカル)" | ||||||
|     remote-notes: "投稿の増減 (リモート)" |     remote-notes: "投稿の増減 (リモート)" | ||||||
|     notes-total: "投稿の累計" |     notes-total: "投稿の積算" | ||||||
|     users: "ユーザーの増減" |     users: "ユーザーの増減" | ||||||
|     users-total: "ユーザーの累計" |     users-total: "ユーザーの積算" | ||||||
|     drive: "ドライブ使用量の増減" |     drive: "ドライブ使用量の増減" | ||||||
|     drive-total: "ドライブ使用量の累計" |     drive-total: "ドライブ使用量の積算" | ||||||
|     drive-files: "ドライブのファイル数の増減" |     drive-files: "ドライブのファイル数の増減" | ||||||
|     drive-files-total: "ドライブのファイル数の累計" |     drive-files-total: "ドライブのファイル数の積算" | ||||||
|     network-requests: "リクエスト" |     network-requests: "リクエスト" | ||||||
|     network-time: "応答時間" |     network-time: "応答時間" | ||||||
|     network-usage: "通信量" |     network-usage: "通信量" | ||||||
| @@ -630,6 +693,7 @@ desktop/views/components/follow-button.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
|  |  | ||||||
| desktop/views/components/followers-window.vue: | desktop/views/components/followers-window.vue: | ||||||
| @@ -678,7 +742,7 @@ desktop/views/components/note-detail.vue: | |||||||
|   renote: "Renote" |   renote: "Renote" | ||||||
|   add-reaction: "リアクション" |   add-reaction: "リアクション" | ||||||
|  |  | ||||||
| desktop/views/components/notes.note.vue: | desktop/views/components/note.vue: | ||||||
|   reposted-by: "{}がRenote" |   reposted-by: "{}がRenote" | ||||||
|   reply: "返信" |   reply: "返信" | ||||||
|   renote: "Renote" |   renote: "Renote" | ||||||
| @@ -761,6 +825,7 @@ desktop/views/components/settings.vue: | |||||||
|   2fa: "二段階認証" |   2fa: "二段階認証" | ||||||
|   other: "その他" |   other: "その他" | ||||||
|   license: "ライセンス" |   license: "ライセンス" | ||||||
|  |   theme: "テーマ" | ||||||
|  |  | ||||||
|   behaviour: "動作" |   behaviour: "動作" | ||||||
|   fetch-on-scroll: "スクロールで自動読み込み" |   fetch-on-scroll: "スクロールで自動読み込み" | ||||||
| @@ -773,24 +838,32 @@ desktop/views/components/settings.vue: | |||||||
|   advanced: "詳細設定" |   advanced: "詳細設定" | ||||||
|   api-via-stream: "ストリームを経由したAPIリクエスト" |   api-via-stream: "ストリームを経由したAPIリクエスト" | ||||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" |   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||||
|  |   deck-nav: "デッキ内ナビゲーション" | ||||||
|  |   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||||
|  |   deck-default: "デッキをデフォルトのUIにする" | ||||||
|  |  | ||||||
|   display: "デザインと表示" |   display: "デザインと表示" | ||||||
|   customize: "ホームをカスタマイズ" |   customize: "ホームをカスタマイズ" | ||||||
|  |   wallpaper: "壁紙" | ||||||
|   choose-wallpaper: "壁紙を選択" |   choose-wallpaper: "壁紙を選択" | ||||||
|   delete-wallpaper: "壁紙を削除" |   delete-wallpaper: "壁紙を削除" | ||||||
|   dark-mode: "ダークモード" |   dark-mode: "ダークモード" | ||||||
|  |   use-shadow: "UIに影を使用" | ||||||
|  |   rounded-corners: "UIの角を丸める" | ||||||
|   circle-icons: "円形のアイコンを使用" |   circle-icons: "円形のアイコンを使用" | ||||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" |   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" |  | ||||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" |   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" |   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||||
|   show-clock-on-header: "右上に時計を表示する" |   show-clock-on-header: "右上に時計を表示する" | ||||||
|   show-reply-target: "リプライ先を表示する" |   show-reply-target: "リプライ先を表示する" | ||||||
|  |   timeline: "タイムライン" | ||||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" |   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" |   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" |   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||||
|   show-maps: "マップの自動展開" |   show-maps: "マップの自動展開" | ||||||
|   show-maps-desc: "位置情報が添付された投稿のマップを自動的に展開します。" |   deck-column-align: "デッキのカラムの位置" | ||||||
|  |   deck-column-align-center: "中央" | ||||||
|  |   deck-column-align-left: "左" | ||||||
|  |  | ||||||
|   sound: "サウンド" |   sound: "サウンド" | ||||||
|   enable-sounds: "サウンドを有効にする" |   enable-sounds: "サウンドを有効にする" | ||||||
| @@ -798,9 +871,6 @@ desktop/views/components/settings.vue: | |||||||
|   volume: "ボリューム" |   volume: "ボリューム" | ||||||
|   test: "テスト" |   test: "テスト" | ||||||
|  |  | ||||||
|   mobile: "モバイル" |  | ||||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" |  | ||||||
|  |  | ||||||
|   language: "言語" |   language: "言語" | ||||||
|   pick-language: "言語を選択" |   pick-language: "言語を選択" | ||||||
|   recommended: "推奨" |   recommended: "推奨" | ||||||
| @@ -842,6 +912,11 @@ desktop/views/components/settings.vue: | |||||||
|   task-manager: "タスクマネージャ" |   task-manager: "タスクマネージャ" | ||||||
|   third-parties: "サードパーティ" |   third-parties: "サードパーティ" | ||||||
|  |  | ||||||
|  |   navbar-position: "ナビゲーションバーの位置" | ||||||
|  |   navbar-position-top: "上" | ||||||
|  |   navbar-position-left: "左" | ||||||
|  |   navbar-position-right: "右" | ||||||
|  |  | ||||||
| desktop/views/components/settings.2fa.vue: | desktop/views/components/settings.2fa.vue: | ||||||
|   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" |   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" | ||||||
|   detail: "詳細..." |   detail: "詳細..." | ||||||
| @@ -887,21 +962,6 @@ desktop/views/components/settings.password.vue: | |||||||
|   not-match: "新しいパスワードが一致しません" |   not-match: "新しいパスワードが一致しません" | ||||||
|   changed: "パスワードを変更しました" |   changed: "パスワードを変更しました" | ||||||
|  |  | ||||||
| desktop/views/components/settings.profile.vue: |  | ||||||
|   avatar: "アイコン" |  | ||||||
|   choice-avatar: "画像を選択" |  | ||||||
|   name: "名前" |  | ||||||
|   location: "場所" |  | ||||||
|   description: "自己紹介" |  | ||||||
|   birthday: "誕生日" |  | ||||||
|   save: "保存" |  | ||||||
|   locked-account: "アカウントの保護" |  | ||||||
|   is-locked: "フォローを承認制にする" |  | ||||||
|   other: "その他" |  | ||||||
|   is-bot: "このアカウントはBotです" |  | ||||||
|   is-cat: "このアカウントはCatです" |  | ||||||
|   profile-updated: "プロフィールを更新しました" |  | ||||||
|  |  | ||||||
| desktop/views/components/sub-note-content.vue: | desktop/views/components/sub-note-content.vue: | ||||||
|   private: "この投稿は非公開です" |   private: "この投稿は非公開です" | ||||||
|   deleted: "この投稿は削除されました" |   deleted: "この投稿は削除されました" | ||||||
| @@ -1022,10 +1082,8 @@ desktop/views/pages/deck/deck.tl-column.vue: | |||||||
|   is-media-view: "メディアビュー" |   is-media-view: "メディアビュー" | ||||||
|   edit: "オプション" |   edit: "オプション" | ||||||
|  |  | ||||||
| desktop/views/pages/deck/deck.note.vue: | desktop/views/pages/deck/deck.user-column.vue: | ||||||
|   reposted-by: "{}がRenote" |   pinned-notes: "ピン留めされた投稿" | ||||||
|   private: "この投稿は非公開です" |  | ||||||
|   deleted: "この投稿は削除されました" |  | ||||||
|  |  | ||||||
| desktop/views/pages/stats/stats.vue: | desktop/views/pages/stats/stats.vue: | ||||||
|   all-users: "全てのユーザー" |   all-users: "全てのユーザー" | ||||||
| @@ -1192,6 +1250,8 @@ mobile/views/components/drive.file-detail.vue: | |||||||
|   hash: "ハッシュ (md5)" |   hash: "ハッシュ (md5)" | ||||||
|   exif: "EXIF" |   exif: "EXIF" | ||||||
|   nsfw: "閲覧注意" |   nsfw: "閲覧注意" | ||||||
|  |   mark-as-sensitive: "閲覧注意に設定" | ||||||
|  |   unmark-as-sensitive: "閲覧注意を解除" | ||||||
|  |  | ||||||
| mobile/views/components/media-image.vue: | mobile/views/components/media-image.vue: | ||||||
|   sensitive: "閲覧注意" |   sensitive: "閲覧注意" | ||||||
| @@ -1205,6 +1265,7 @@ mobile/views/components/follow-button.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
|  |  | ||||||
| mobile/views/components/friends-maker.vue: | mobile/views/components/friends-maker.vue: | ||||||
| @@ -1367,24 +1428,6 @@ mobile/views/pages/notifications.vue: | |||||||
| mobile/views/pages/games/reversi.vue: | mobile/views/pages/games/reversi.vue: | ||||||
|   reversi: "リバーシ" |   reversi: "リバーシ" | ||||||
|  |  | ||||||
| mobile/views/pages/settings/settings.profile.vue: |  | ||||||
|   title: "プロフィール" |  | ||||||
|   name: "名前" |  | ||||||
|   account: "アカウント" |  | ||||||
|   location: "場所" |  | ||||||
|   description: "自己紹介" |  | ||||||
|   birthday: "誕生日" |  | ||||||
|   avatar: "アイコン" |  | ||||||
|   banner: "バナー" |  | ||||||
|   is-cat: "このアカウントはCatです" |  | ||||||
|   is-locked: "フォローを承認制にする" |  | ||||||
|   advanced: "その他" |  | ||||||
|   privacy: "プライバシー" |  | ||||||
|   save: "保存" |  | ||||||
|   saved: "プロフィールを保存しました" |  | ||||||
|   uploading: "アップロード中" |  | ||||||
|   upload-failed: "アップロードに失敗しました" |  | ||||||
|  |  | ||||||
| mobile/views/pages/search.vue: | mobile/views/pages/search.vue: | ||||||
|   search: "検索" |   search: "検索" | ||||||
|   empty: "「{}」に関する投稿は見つかりませんでした。" |   empty: "「{}」に関する投稿は見つかりませんでした。" | ||||||
| @@ -1416,6 +1459,7 @@ mobile/views/pages/settings.vue: | |||||||
|   notification-position: "通知の表示" |   notification-position: "通知の表示" | ||||||
|   notification-position-bottom: "下" |   notification-position-bottom: "下" | ||||||
|   notification-position-top: "上" |   notification-position-top: "上" | ||||||
|  |   theme: "テーマ" | ||||||
|   behavior: "動作" |   behavior: "動作" | ||||||
|   fetch-on-scroll: "スクロールで自動読み込み" |   fetch-on-scroll: "スクロールで自動読み込み" | ||||||
|   note-visibility: "投稿の公開範囲" |   note-visibility: "投稿の公開範囲" | ||||||
|   | |||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -3,20 +3,20 @@ meta: | |||||||
|   lang: "한국어" |   lang: "한국어" | ||||||
|   divider: "" |   divider: "" | ||||||
| common: | common: | ||||||
|   misskey: "A ⭐ of fediverse" |   misskey: "연합우주의 ⭐" | ||||||
|   about-title: "A ⭐ of fediverse." |   about-title: "연합우주의 ⭐." | ||||||
|   about: "Misskey를 찾아 주셔서 감사합니다. Misskey은 지구에서 태어난 <b>분산 마이크로 블로그 SNS </b> 입니다. Fediverse (다양한 SNS로 구성되는 우주)에 존재하는 다른 SNS와 상호 연결되어 있습니다. 잠시 도시의 번잡함에서 벗어나 새로운 인터넷에 다이브 해 보지 않겠습니까." |   about: "Misskey를 찾아 주셔서 감사합니다. Misskey은 지구에서 태어난 <b>분산 마이크로 블로그 SNS </b> 입니다. Fediverse (다양한 SNS로 구성되는 우주)에 존재하는 다른 SNS와 상호 연결되어 있습니다. 잠시 도시의 번잡함에서 벗어나 새로운 인터넷에 다이브 해 보지 않겠습니까." | ||||||
|   intro: |   intro: | ||||||
|     title: "Misskeyって?" |     title: "Misskey란?" | ||||||
|     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" |     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" | ||||||
|     features: "特徴" |     features: "특징" | ||||||
|     rich-contents: "投稿" |     rich-contents: "게시" | ||||||
|     rich-contents-desc: "自分の考え、話題の出来事、皆と共有したいことについて発信してください。必要であれば、様々な構文を使って投稿を装飾したり、好きな画像、動画などのファイルやアンケートを添付することもできます。" |     rich-contents-desc: "自分の考え、話題の出来事、皆と共有したいことについて発信してください。必要であれば、様々な構文を使って投稿を装飾したり、好きな画像、動画などのファイルやアンケートを添付することもできます。" | ||||||
|     reaction: "リアクション" |     reaction: "반응" | ||||||
|     reaction-desc: "あなたの気持ちを伝える最も簡単な方法です。Misskeyは、他のユーザーの投稿に様々なリアクションを付けることができます。いちどMisskeyのリアクション機能を体験してしまうと、もう「いいね」の概念しか存在しないSNSには戻れなくなるかもしれません。" |     reaction-desc: "あなたの気持ちを伝える最も簡単な方法です。Misskeyは、他のユーザーの投稿に様々なリアクションを付けることができます。いちどMisskeyのリアクション機能を体験してしまうと、もう「いいね」の概念しか存在しないSNSには戻れなくなるかもしれません。" | ||||||
|     ui: "インターフェース" |     ui: "인터페이스" | ||||||
|     ui-desc: "どのようなUIが使いやすいかは人それぞれです。だから、Misskeyは自由度の高いUIを持っています。レイアウトやデザインを調整したり、カスタマイズ可能な様々なウィジェットを配置したりして、自分だけのホームを作ってください。" |     ui-desc: "どのようなUIが使いやすいかは人それぞれです。だから、Misskeyは自由度の高いUIを持っています。レイアウトやデザインを調整したり、カスタマイズ可能な様々なウィジェットを配置したりして、自分だけのホームを作ってください。" | ||||||
|     drive: "ドライブ" |     drive: "드라이브" | ||||||
|     drive-desc: "以前投稿したことのある画像をまた投稿したくなったことはありませんか?もしくは、アップロードしたファイルをフォルダ分けして整理したくなったことはありませんか?Misskeyの根幹に組み込まれたドライブ機能によってそれらが解決します。ファイルの共有も簡単です。" |     drive-desc: "以前投稿したことのある画像をまた投稿したくなったことはありませんか?もしくは、アップロードしたファイルをフォルダ分けして整理したくなったことはありませんか?Misskeyの根幹に組み込まれたドライブ機能によってそれらが解決します。ファイルの共有も簡単です。" | ||||||
|     outro: "他にもMisskeyにしかない機能はまだまだあるので、ぜひあなた自身の目で確かめてください。Misskeyは分散型SNSなので、このインスタンスが気に入らなければ他のインスタンスを試すこともできます。それでは、GLHF!" |     outro: "他にもMisskeyにしかない機能はまだまだあるので、ぜひあなた自身の目で確かめてください。Misskeyは分散型SNSなので、このインスタンスが気に入らなければ他のインスタンスを試すこともできます。それでは、GLHF!" | ||||||
|   adblock: |   adblock: | ||||||
| @@ -71,7 +71,7 @@ common: | |||||||
|     friday: "금요일" |     friday: "금요일" | ||||||
|     saturday: "토요일" |     saturday: "토요일" | ||||||
|   reactions: |   reactions: | ||||||
|     like: "いいね" |     like: "좋아요" | ||||||
|     love: "좋아" |     love: "좋아" | ||||||
|     laugh: "크크" |     laugh: "크크" | ||||||
|     hmm: "음..." |     hmm: "음..." | ||||||
| @@ -82,14 +82,14 @@ common: | |||||||
|     rip: "RIP" |     rip: "RIP" | ||||||
|     pudding: "Pudding" |     pudding: "Pudding" | ||||||
|   note-visibility: |   note-visibility: | ||||||
|     public: "公開" |     public: "공개" | ||||||
|     home: "ホーム" |     home: "홈" | ||||||
|     home-desc: "ホームタイムラインにのみ公開" |     home-desc: "홈 타임라인에만 공개" | ||||||
|     followers: "フォロワー" |     followers: "팔로워" | ||||||
|     followers-desc: "自分のフォロワーにのみ公開" |     followers-desc: "자신의 팔로워에게만 공개" | ||||||
|     specified: "ダイレクト" |     specified: "다이렉트" | ||||||
|     specified-desc: "指定したユーザーにのみ公開" |     specified-desc: "지정한 사용자에게만 공개" | ||||||
|     private: "非公開" |     private: "비공개" | ||||||
|   note-placeholders: |   note-placeholders: | ||||||
|     a: "지금 어떻게하고있어?" |     a: "지금 어떻게하고있어?" | ||||||
|     b: "뭔가 있었습니까?" |     b: "뭔가 있었습니까?" | ||||||
| @@ -107,14 +107,14 @@ common: | |||||||
|   i-like-sushi: "나는(푸딩보다 오히려)스시가 좋아" |   i-like-sushi: "나는(푸딩보다 오히려)스시가 좋아" | ||||||
|   show-reversi-board-labels: "리버시 보드의 행과 열 레이블을 표시" |   show-reversi-board-labels: "리버시 보드의 행과 열 레이블을 표시" | ||||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" |   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||||
|   verified-user: "公式アカウント" |   verified-user: "공식 계정" | ||||||
|   disable-animated-mfm: "게시물의 문자 애니메이션을 비활성화 할" |   disable-animated-mfm: "게시물의 문자 애니메이션을 비활성화 할" | ||||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" |   always-show-nsfw: "항상 열람주의 미디어를 표시" | ||||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" |   always-mark-nsfw: "항상 미디어를 열람주의로 설정하여 게시" | ||||||
|   show-full-acct: "ユーザー名のホストを省略しない" |   show-full-acct: "ユーザー名のホストを省略しない" | ||||||
|   reduce-motion: "UIの動きを減らす" |   reduce-motion: "UIの動きを減らす" | ||||||
|   this-setting-is-this-device-only: "このデバイスのみ" |   this-setting-is-this-device-only: "이 장치만" | ||||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' |   do-not-use-in-production: '이것은 개발 빌드입니다. 프로덕션 환경에서 사용하지 마십시오.' | ||||||
|   reversi: |   reversi: | ||||||
|     drawn: "무승부" |     drawn: "무승부" | ||||||
|     my-turn: "당신의 차례입니다" |     my-turn: "당신의 차례입니다" | ||||||
| @@ -155,19 +155,19 @@ common: | |||||||
|     home: "홈" |     home: "홈" | ||||||
|     local: "로컬" |     local: "로컬" | ||||||
|     hybrid: "소셜" |     hybrid: "소셜" | ||||||
|     hashtag: "ハッシュタグ" |     hashtag: "해시태그" | ||||||
|     global: "글로벌" |     global: "글로벌" | ||||||
|     mentions: "あなた宛て" |     mentions: "あなた宛て" | ||||||
|     direct: "ダイレクト投稿" |     direct: "ダイレクト投稿" | ||||||
|     notifications: "통지" |     notifications: "통지" | ||||||
|     list: "목록" |     list: "목록" | ||||||
|     swap-left: "左に移動" |     swap-left: "왼쪽으로 이동" | ||||||
|     swap-right: "右に移動" |     swap-right: "오른쪽으로 이동" | ||||||
|     swap-up: "上に移動" |     swap-up: "위로 이동" | ||||||
|     swap-down: "下に移動" |     swap-down: "아래로 이동" | ||||||
|     remove: "カラムを削除" |     remove: "칼럼 제거" | ||||||
|     add-column: "カラムを追加" |     add-column: "칼럼 추가" | ||||||
|     rename: "名前を変更" |     rename: "이름 변경" | ||||||
|     stack-left: "左に重ねる" |     stack-left: "左に重ねる" | ||||||
|     pop-right: "右に出す" |     pop-right: "右に出す" | ||||||
| auth/views/form.vue: | auth/views/form.vue: | ||||||
| @@ -248,22 +248,57 @@ common/views/components/connect-failed.troubleshooter.vue: | |||||||
|   checking-network: "ネットワーク接続を確認中" |   checking-network: "ネットワーク接続を確認中" | ||||||
|   internet: "インターネット接続" |   internet: "インターネット接続" | ||||||
|   checking-internet: "インターネット接続を確認中" |   checking-internet: "インターネット接続を確認中" | ||||||
|   server: "サーバー接続" |   server: "서버 연결" | ||||||
|   checking-server: "サーバー接続を確認中" |   checking-server: "サーバー接続を確認中" | ||||||
|   finding: "問題を調べています" |   finding: "問題を調べています" | ||||||
|   no-network: "ネットワークに接続されていません" |   no-network: "ネットワークに接続されていません" | ||||||
|   no-network-desc: "お使いのPCのネットワーク接続が正常か確認してください。" |   no-network-desc: "お使いのPCのネットワーク接続が正常か確認してください。" | ||||||
|   no-internet: "インターネットに接続されていません" |   no-internet: "インターネットに接続されていません" | ||||||
|   no-internet-desc: "ネットワークには接続されていますが、インターネットには接続されていないようです。お使いのPCのインターネット接続が正常か確認してください。" |   no-internet-desc: "ネットワークには接続されていますが、インターネットには接続されていないようです。お使いのPCのインターネット接続が正常か確認してください。" | ||||||
|   no-server: "Misskeyのサーバーに接続できません" |   no-server: "Misskey 서버에 연결할 수 없습니다." | ||||||
|   no-server-desc: "お使いのPCのインターネット接続は正常ですが、Misskeyのサーバーには接続できませんでした。サーバーがダウンまたはメンテナンスしている可能性があるので、しばらくしてから再度御アクセスください。" |   no-server-desc: "お使いのPCのインターネット接続は正常ですが、Misskeyのサーバーには接続できませんでした。サーバーがダウンまたはメンテナンスしている可能性があるので、しばらくしてから再度御アクセスください。" | ||||||
|   success: "Misskeyのサーバーに接続できました" |   success: "Misskeyのサーバーに接続できました" | ||||||
|   success-desc: "正常に接続できるようです。ページを再度読み込みしてください。" |   success-desc: "正常に接続できるようです。ページを再度読み込みしてください。" | ||||||
|   flush: "キャッシュの削除" |   flush: "캐시 삭제" | ||||||
|   set-version: "バージョン指定" |   set-version: "버전 지정" | ||||||
| common/views/components/media-banner.vue: | common/views/components/media-banner.vue: | ||||||
|   sensitive: "閲覧注意" |   sensitive: "열람주의" | ||||||
|   click-to-show: "クリックして表示" |   click-to-show: "클릭하여 표시" | ||||||
|  | common/views/components/theme.vue: | ||||||
|  |   light-theme: "非ダークモード時に使用するテーマ" | ||||||
|  |   dark-theme: "ダークモード時に使用するテーマ" | ||||||
|  |   light-themes: "밝은 테마" | ||||||
|  |   dark-themes: "어두운 테마" | ||||||
|  |   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: "保存しました" | ||||||
|  |   manage-themes: "テーマの管理" | ||||||
|  |   builtin-themes: "標準テーマ" | ||||||
|  |   my-themes: "マイテーマ" | ||||||
|  |   installed-themes: "インストールされたテーマ" | ||||||
|  |   select-theme: "テーマを選択してください" | ||||||
|  |   uninstall: "アンインストール" | ||||||
|  |   uninstalled: "「{}」をアンインストールしました" | ||||||
|  |   author: "作者" | ||||||
|  |   desc: "説明" | ||||||
|  |   export: "エクスポート" | ||||||
|  |   import: "インポート" | ||||||
|  |   import-by-code: "またはコードをペースト" | ||||||
|  |   theme-name-required: "テーマ名は必須です。" | ||||||
| common/views/components/cw-button.vue: | common/views/components/cw-button.vue: | ||||||
|   hide: "隠す" |   hide: "隠す" | ||||||
|   show: "もっと見る" |   show: "もっと見る" | ||||||
| @@ -273,7 +308,7 @@ common/views/components/messaging.vue: | |||||||
|   no-history: "履歴はありません" |   no-history: "履歴はありません" | ||||||
| common/views/components/messaging-room.vue: | common/views/components/messaging-room.vue: | ||||||
|   empty: "このユーザーと話したことはありません" |   empty: "このユーザーと話したことはありません" | ||||||
|   more: "もっと読む" |   more: "더 보기" | ||||||
|   no-history: "これより過去の履歴はありません" |   no-history: "これより過去の履歴はありません" | ||||||
|   resize-form: "ドラッグしてフォームの広さを調整" |   resize-form: "ドラッグしてフォームの広さを調整" | ||||||
|   new-message: "新しいメッセージがあります" |   new-message: "新しいメッセージがあります" | ||||||
| @@ -288,19 +323,21 @@ common/views/components/messaging-room.message.vue: | |||||||
|   is-read: "읽음" |   is-read: "읽음" | ||||||
|   deleted: "このメッセージは削除されました" |   deleted: "このメッセージは削除されました" | ||||||
| common/views/components/nav.vue: | common/views/components/nav.vue: | ||||||
|   about: "Misskeyについて" |   about: "Misskey에 대하여" | ||||||
|   stats: "統計" |   stats: "통계" | ||||||
|   status: "ステータス" |   status: "ステータス" | ||||||
|   wiki: "Wiki" |   wiki: "Wiki" | ||||||
|   donors: "ドナー" |   donors: "기증자" | ||||||
|   repository: "リポジトリ" |   repository: "저장소" | ||||||
|   develop: "開発者" |   develop: "개발자" | ||||||
|   feedback: "フィードバック" |   feedback: "피드백" | ||||||
| common/views/components/note-menu.vue: | common/views/components/note-menu.vue: | ||||||
|   detail: "詳細" |   detail: "詳細" | ||||||
|   copy-link: "リンクをコピー" |   copy-link: "링크 복사" | ||||||
|   favorite: "お気に入り" |   favorite: "お気に入り" | ||||||
|  |   unfavorite: "お気に入り解除" | ||||||
|   pin: "ピン留め" |   pin: "ピン留め" | ||||||
|  |   unpin: "ピン留め解除" | ||||||
|   delete: "削除" |   delete: "削除" | ||||||
|   delete-confirm: "この投稿を削除しますか?" |   delete-confirm: "この投稿を削除しますか?" | ||||||
|   remote: "投稿元で見る" |   remote: "投稿元で見る" | ||||||
| @@ -379,6 +416,25 @@ common/views/components/visibility-chooser.vue: | |||||||
| common/views/components/trends.vue: | common/views/components/trends.vue: | ||||||
|   count: "{}人が投稿" |   count: "{}人が投稿" | ||||||
|   empty: "トレンドなし" |   empty: "トレンドなし" | ||||||
|  | common/views/components/profile-editor.vue: | ||||||
|  |   title: "プロフィール" | ||||||
|  |   name: "名前" | ||||||
|  |   account: "アカウント" | ||||||
|  |   location: "場所" | ||||||
|  |   description: "自己紹介" | ||||||
|  |   birthday: "誕生日" | ||||||
|  |   avatar: "アイコン" | ||||||
|  |   banner: "バナー" | ||||||
|  |   is-cat: "このアカウントはCatです" | ||||||
|  |   is-bot: "このアカウントはBotです" | ||||||
|  |   is-locked: "フォローを承認制にする" | ||||||
|  |   careful-bot: "Botからのフォローだけ承認制にする" | ||||||
|  |   advanced: "その他" | ||||||
|  |   privacy: "プライバシー" | ||||||
|  |   save: "保存" | ||||||
|  |   saved: "プロフィールを保存しました" | ||||||
|  |   uploading: "アップロード中" | ||||||
|  |   upload-failed: "アップロードに失敗しました" | ||||||
| common/views/widgets/broadcast.vue: | common/views/widgets/broadcast.vue: | ||||||
|   fetching: "確認中" |   fetching: "確認中" | ||||||
|   no-broadcasts: "お知らせはありません" |   no-broadcasts: "お知らせはありません" | ||||||
| @@ -439,6 +495,7 @@ common/views/pages/follow.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| desktop: | desktop: | ||||||
|   banner-crop-title: "バナーとして表示する部分を選択" |   banner-crop-title: "バナーとして表示する部分を選択" | ||||||
| @@ -477,13 +534,13 @@ desktop/views/components/charts.vue: | |||||||
|     notes: "投稿の増減 (統合)" |     notes: "投稿の増減 (統合)" | ||||||
|     local-notes: "投稿の増減 (ローカル)" |     local-notes: "投稿の増減 (ローカル)" | ||||||
|     remote-notes: "投稿の増減 (リモート)" |     remote-notes: "投稿の増減 (リモート)" | ||||||
|     notes-total: "投稿の累計" |     notes-total: "投稿の積算" | ||||||
|     users: "ユーザーの増減" |     users: "ユーザーの増減" | ||||||
|     users-total: "ユーザーの累計" |     users-total: "ユーザーの積算" | ||||||
|     drive: "ドライブ使用量の増減" |     drive: "ドライブ使用量の増減" | ||||||
|     drive-total: "ドライブ使用量の累計" |     drive-total: "ドライブ使用量の積算" | ||||||
|     drive-files: "ドライブのファイル数の増減" |     drive-files: "ドライブのファイル数の増減" | ||||||
|     drive-files-total: "ドライブのファイル数の累計" |     drive-files-total: "ドライブのファイル数の積算" | ||||||
|     network-requests: "リクエスト" |     network-requests: "リクエスト" | ||||||
|     network-time: "応答時間" |     network-time: "応答時間" | ||||||
|     network-usage: "通信量" |     network-usage: "通信量" | ||||||
| @@ -565,6 +622,7 @@ desktop/views/components/follow-button.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| desktop/views/components/followers-window.vue: | desktop/views/components/followers-window.vue: | ||||||
|   followers: "{} のフォロワー" |   followers: "{} のフォロワー" | ||||||
| @@ -601,7 +659,7 @@ desktop/views/components/note-detail.vue: | |||||||
|   location: "位置情報" |   location: "位置情報" | ||||||
|   renote: "Renote" |   renote: "Renote" | ||||||
|   add-reaction: "リアクション" |   add-reaction: "リアクション" | ||||||
| desktop/views/components/notes.note.vue: | desktop/views/components/note.vue: | ||||||
|   reposted-by: "{}がRenote" |   reposted-by: "{}がRenote" | ||||||
|   reply: "返信" |   reply: "返信" | ||||||
|   renote: "Renote" |   renote: "Renote" | ||||||
| @@ -675,6 +733,7 @@ desktop/views/components/settings.vue: | |||||||
|   2fa: "二段階認証" |   2fa: "二段階認証" | ||||||
|   other: "その他" |   other: "その他" | ||||||
|   license: "ライセンス" |   license: "ライセンス" | ||||||
|  |   theme: "テーマ" | ||||||
|   behaviour: "動作" |   behaviour: "動作" | ||||||
|   fetch-on-scroll: "スクロールで自動読み込み" |   fetch-on-scroll: "スクロールで自動読み込み" | ||||||
|   fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込みます。" |   fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込みます。" | ||||||
| @@ -686,30 +745,36 @@ desktop/views/components/settings.vue: | |||||||
|   advanced: "詳細設定" |   advanced: "詳細設定" | ||||||
|   api-via-stream: "ストリームを経由したAPIリクエスト" |   api-via-stream: "ストリームを経由したAPIリクエスト" | ||||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" |   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||||
|  |   deck-nav: "デッキ内ナビゲーション" | ||||||
|  |   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||||
|  |   deck-default: "デッキをデフォルトのUIにする" | ||||||
|   display: "デザインと表示" |   display: "デザインと表示" | ||||||
|   customize: "ホームをカスタマイズ" |   customize: "ホームをカスタマイズ" | ||||||
|  |   wallpaper: "壁紙" | ||||||
|   choose-wallpaper: "壁紙を選択" |   choose-wallpaper: "壁紙を選択" | ||||||
|   delete-wallpaper: "壁紙を削除" |   delete-wallpaper: "壁紙を削除" | ||||||
|   dark-mode: "ダークモード" |   dark-mode: "ダークモード" | ||||||
|  |   use-shadow: "UIに影を使用" | ||||||
|  |   rounded-corners: "UIの角を丸める" | ||||||
|   circle-icons: "円形のアイコンを使用" |   circle-icons: "円形のアイコンを使用" | ||||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" |   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" |  | ||||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" |   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" |   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||||
|   show-clock-on-header: "右上に時計を表示する" |   show-clock-on-header: "右上に時計を表示する" | ||||||
|   show-reply-target: "リプライ先を表示する" |   show-reply-target: "リプライ先を表示する" | ||||||
|  |   timeline: "タイムライン" | ||||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" |   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" |   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" |   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||||
|   show-maps: "マップの自動展開" |   show-maps: "マップの自動展開" | ||||||
|   show-maps-desc: "位置情報が添付された投稿のマップを自動的に展開します。" |   deck-column-align: "デッキのカラムの位置" | ||||||
|  |   deck-column-align-center: "中央" | ||||||
|  |   deck-column-align-left: "左" | ||||||
|   sound: "サウンド" |   sound: "サウンド" | ||||||
|   enable-sounds: "サウンドを有効にする" |   enable-sounds: "サウンドを有効にする" | ||||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" |   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||||
|   volume: "ボリューム" |   volume: "ボリューム" | ||||||
|   test: "テスト" |   test: "テスト" | ||||||
|   mobile: "モバイル" |  | ||||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" |  | ||||||
|   language: "言語" |   language: "言語" | ||||||
|   pick-language: "言語を選択" |   pick-language: "言語を選択" | ||||||
|   recommended: "推奨" |   recommended: "推奨" | ||||||
| @@ -745,6 +810,10 @@ desktop/views/components/settings.vue: | |||||||
|   tools: "ツール" |   tools: "ツール" | ||||||
|   task-manager: "タスクマネージャ" |   task-manager: "タスクマネージャ" | ||||||
|   third-parties: "サードパーティ" |   third-parties: "サードパーティ" | ||||||
|  |   navbar-position: "ナビゲーションバーの位置" | ||||||
|  |   navbar-position-top: "上" | ||||||
|  |   navbar-position-left: "左" | ||||||
|  |   navbar-position-right: "右" | ||||||
| desktop/views/components/settings.2fa.vue: | desktop/views/components/settings.2fa.vue: | ||||||
|   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" |   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" | ||||||
|   detail: "詳細..." |   detail: "詳細..." | ||||||
| @@ -784,20 +853,6 @@ desktop/views/components/settings.password.vue: | |||||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" |   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||||
|   not-match: "新しいパスワードが一致しません" |   not-match: "新しいパスワードが一致しません" | ||||||
|   changed: "パスワードを変更しました" |   changed: "パスワードを変更しました" | ||||||
| desktop/views/components/settings.profile.vue: |  | ||||||
|   avatar: "アイコン" |  | ||||||
|   choice-avatar: "画像を選択" |  | ||||||
|   name: "名前" |  | ||||||
|   location: "場所" |  | ||||||
|   description: "自己紹介" |  | ||||||
|   birthday: "誕生日" |  | ||||||
|   save: "保存" |  | ||||||
|   locked-account: "アカウントの保護" |  | ||||||
|   is-locked: "フォローを承認制にする" |  | ||||||
|   other: "その他" |  | ||||||
|   is-bot: "このアカウントはBotです" |  | ||||||
|   is-cat: "このアカウントはCatです" |  | ||||||
|   profile-updated: "プロフィールを更新しました" |  | ||||||
| desktop/views/components/sub-note-content.vue: | desktop/views/components/sub-note-content.vue: | ||||||
|   private: "この投稿は非公開です" |   private: "この投稿は非公開です" | ||||||
|   deleted: "この投稿は削除されました" |   deleted: "この投稿は削除されました" | ||||||
| @@ -896,10 +951,8 @@ desktop/views/pages/deck/deck.tl-column.vue: | |||||||
|   is-media-only: "メディア投稿のみ" |   is-media-only: "メディア投稿のみ" | ||||||
|   is-media-view: "メディアビュー" |   is-media-view: "メディアビュー" | ||||||
|   edit: "オプション" |   edit: "オプション" | ||||||
| desktop/views/pages/deck/deck.note.vue: | desktop/views/pages/deck/deck.user-column.vue: | ||||||
|   reposted-by: "{}がRenote" |   pinned-notes: "ピン留めされた投稿" | ||||||
|   private: "この投稿は非公開です" |  | ||||||
|   deleted: "この投稿は削除されました" |  | ||||||
| desktop/views/pages/stats/stats.vue: | desktop/views/pages/stats/stats.vue: | ||||||
|   all-users: "全てのユーザー" |   all-users: "全てのユーザー" | ||||||
|   original-users: "このインスタンスのユーザー" |   original-users: "このインスタンスのユーザー" | ||||||
| @@ -1034,6 +1087,8 @@ mobile/views/components/drive.file-detail.vue: | |||||||
|   hash: "ハッシュ (md5)" |   hash: "ハッシュ (md5)" | ||||||
|   exif: "EXIF" |   exif: "EXIF" | ||||||
|   nsfw: "閲覧注意" |   nsfw: "閲覧注意" | ||||||
|  |   mark-as-sensitive: "閲覧注意に設定" | ||||||
|  |   unmark-as-sensitive: "閲覧注意を解除" | ||||||
| mobile/views/components/media-image.vue: | mobile/views/components/media-image.vue: | ||||||
|   sensitive: "閲覧注意" |   sensitive: "閲覧注意" | ||||||
|   click-to-show: "クリックして表示" |   click-to-show: "クリックして表示" | ||||||
| @@ -1044,6 +1099,7 @@ mobile/views/components/follow-button.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| mobile/views/components/friends-maker.vue: | mobile/views/components/friends-maker.vue: | ||||||
|   title: "気になるユーザーをフォロー" |   title: "気になるユーザーをフォロー" | ||||||
| @@ -1173,23 +1229,6 @@ mobile/views/pages/notifications.vue: | |||||||
|   read-all: "すべての通知を既読にしますか?" |   read-all: "すべての通知を既読にしますか?" | ||||||
| mobile/views/pages/games/reversi.vue: | mobile/views/pages/games/reversi.vue: | ||||||
|   reversi: "リバーシ" |   reversi: "リバーシ" | ||||||
| mobile/views/pages/settings/settings.profile.vue: |  | ||||||
|   title: "プロフィール" |  | ||||||
|   name: "名前" |  | ||||||
|   account: "アカウント" |  | ||||||
|   location: "場所" |  | ||||||
|   description: "自己紹介" |  | ||||||
|   birthday: "誕生日" |  | ||||||
|   avatar: "アイコン" |  | ||||||
|   banner: "バナー" |  | ||||||
|   is-cat: "このアカウントはCatです" |  | ||||||
|   is-locked: "フォローを承認制にする" |  | ||||||
|   advanced: "その他" |  | ||||||
|   privacy: "プライバシー" |  | ||||||
|   save: "保存" |  | ||||||
|   saved: "プロフィールを保存しました" |  | ||||||
|   uploading: "アップロード中" |  | ||||||
|   upload-failed: "アップロードに失敗しました" |  | ||||||
| mobile/views/pages/search.vue: | mobile/views/pages/search.vue: | ||||||
|   search: "検索" |   search: "検索" | ||||||
|   empty: "「{}」に関する投稿は見つかりませんでした。" |   empty: "「{}」に関する投稿は見つかりませんでした。" | ||||||
| @@ -1219,6 +1258,7 @@ mobile/views/pages/settings.vue: | |||||||
|   notification-position: "通知の表示" |   notification-position: "通知の表示" | ||||||
|   notification-position-bottom: "下" |   notification-position-bottom: "下" | ||||||
|   notification-position-top: "上" |   notification-position-top: "上" | ||||||
|  |   theme: "テーマ" | ||||||
|   behavior: "動作" |   behavior: "動作" | ||||||
|   fetch-on-scroll: "スクロールで自動読み込み" |   fetch-on-scroll: "スクロールで自動読み込み" | ||||||
|   note-visibility: "投稿の公開範囲" |   note-visibility: "投稿の公開範囲" | ||||||
|   | |||||||
| @@ -264,6 +264,41 @@ common/views/components/connect-failed.troubleshooter.vue: | |||||||
| common/views/components/media-banner.vue: | common/views/components/media-banner.vue: | ||||||
|   sensitive: "閲覧注意" |   sensitive: "閲覧注意" | ||||||
|   click-to-show: "クリックして表示" |   click-to-show: "クリックして表示" | ||||||
|  | common/views/components/theme.vue: | ||||||
|  |   light-theme: "非ダークモード時に使用するテーマ" | ||||||
|  |   dark-theme: "ダークモード時に使用するテーマ" | ||||||
|  |   light-themes: "明るいテーマ" | ||||||
|  |   dark-themes: "暗いテーマ" | ||||||
|  |   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: "保存しました" | ||||||
|  |   manage-themes: "テーマの管理" | ||||||
|  |   builtin-themes: "標準テーマ" | ||||||
|  |   my-themes: "マイテーマ" | ||||||
|  |   installed-themes: "インストールされたテーマ" | ||||||
|  |   select-theme: "テーマを選択してください" | ||||||
|  |   uninstall: "アンインストール" | ||||||
|  |   uninstalled: "「{}」をアンインストールしました" | ||||||
|  |   author: "作者" | ||||||
|  |   desc: "説明" | ||||||
|  |   export: "エクスポート" | ||||||
|  |   import: "インポート" | ||||||
|  |   import-by-code: "またはコードをペースト" | ||||||
|  |   theme-name-required: "テーマ名は必須です。" | ||||||
| common/views/components/cw-button.vue: | common/views/components/cw-button.vue: | ||||||
|   hide: "隠す" |   hide: "隠す" | ||||||
|   show: "もっと見る" |   show: "もっと見る" | ||||||
| @@ -300,7 +335,9 @@ common/views/components/note-menu.vue: | |||||||
|   detail: "詳細" |   detail: "詳細" | ||||||
|   copy-link: "リンクをコピー" |   copy-link: "リンクをコピー" | ||||||
|   favorite: "Deze notitie toevoegen aan favorieten" |   favorite: "Deze notitie toevoegen aan favorieten" | ||||||
|  |   unfavorite: "お気に入り解除" | ||||||
|   pin: "Vastmaken aan profielpagina" |   pin: "Vastmaken aan profielpagina" | ||||||
|  |   unpin: "ピン留め解除" | ||||||
|   delete: "削除" |   delete: "削除" | ||||||
|   delete-confirm: "この投稿を削除しますか?" |   delete-confirm: "この投稿を削除しますか?" | ||||||
|   remote: "Origineel tonen" |   remote: "Origineel tonen" | ||||||
| @@ -379,6 +416,25 @@ common/views/components/visibility-chooser.vue: | |||||||
| common/views/components/trends.vue: | common/views/components/trends.vue: | ||||||
|   count: "{}人が投稿" |   count: "{}人が投稿" | ||||||
|   empty: "トレンドなし" |   empty: "トレンドなし" | ||||||
|  | common/views/components/profile-editor.vue: | ||||||
|  |   title: "プロフィール" | ||||||
|  |   name: "名前" | ||||||
|  |   account: "アカウント" | ||||||
|  |   location: "場所" | ||||||
|  |   description: "自己紹介" | ||||||
|  |   birthday: "誕生日" | ||||||
|  |   avatar: "アイコン" | ||||||
|  |   banner: "バナー" | ||||||
|  |   is-cat: "このアカウントはCatです" | ||||||
|  |   is-bot: "このアカウントはBotです" | ||||||
|  |   is-locked: "フォローを承認制にする" | ||||||
|  |   careful-bot: "Botからのフォローだけ承認制にする" | ||||||
|  |   advanced: "その他" | ||||||
|  |   privacy: "プライバシー" | ||||||
|  |   save: "保存" | ||||||
|  |   saved: "プロフィールを保存しました" | ||||||
|  |   uploading: "アップロード中" | ||||||
|  |   upload-failed: "アップロードに失敗しました" | ||||||
| common/views/widgets/broadcast.vue: | common/views/widgets/broadcast.vue: | ||||||
|   fetching: "Bezig met ophalen" |   fetching: "Bezig met ophalen" | ||||||
|   no-broadcasts: "Geen uitzendingen" |   no-broadcasts: "Geen uitzendingen" | ||||||
| @@ -439,6 +495,7 @@ common/views/pages/follow.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| desktop: | desktop: | ||||||
|   banner-crop-title: "バナーとして表示する部分を選択" |   banner-crop-title: "バナーとして表示する部分を選択" | ||||||
| @@ -477,13 +534,13 @@ desktop/views/components/charts.vue: | |||||||
|     notes: "投稿の増減 (統合)" |     notes: "投稿の増減 (統合)" | ||||||
|     local-notes: "投稿の増減 (ローカル)" |     local-notes: "投稿の増減 (ローカル)" | ||||||
|     remote-notes: "投稿の増減 (リモート)" |     remote-notes: "投稿の増減 (リモート)" | ||||||
|     notes-total: "投稿の累計" |     notes-total: "投稿の積算" | ||||||
|     users: "ユーザーの増減" |     users: "ユーザーの増減" | ||||||
|     users-total: "ユーザーの累計" |     users-total: "ユーザーの積算" | ||||||
|     drive: "ドライブ使用量の増減" |     drive: "ドライブ使用量の増減" | ||||||
|     drive-total: "ドライブ使用量の累計" |     drive-total: "ドライブ使用量の積算" | ||||||
|     drive-files: "ドライブのファイル数の増減" |     drive-files: "ドライブのファイル数の増減" | ||||||
|     drive-files-total: "ドライブのファイル数の累計" |     drive-files-total: "ドライブのファイル数の積算" | ||||||
|     network-requests: "リクエスト" |     network-requests: "リクエスト" | ||||||
|     network-time: "応答時間" |     network-time: "応答時間" | ||||||
|     network-usage: "通信量" |     network-usage: "通信量" | ||||||
| @@ -565,6 +622,7 @@ desktop/views/components/follow-button.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "Volgen" |   follow: "Volgen" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| desktop/views/components/followers-window.vue: | desktop/views/components/followers-window.vue: | ||||||
|   followers: "Volgers van {}" |   followers: "Volgers van {}" | ||||||
| @@ -601,12 +659,12 @@ desktop/views/components/note-detail.vue: | |||||||
|   location: "Locatie" |   location: "Locatie" | ||||||
|   renote: "Renote" |   renote: "Renote" | ||||||
|   add-reaction: "リアクション" |   add-reaction: "リアクション" | ||||||
| desktop/views/components/notes.note.vue: | desktop/views/components/note.vue: | ||||||
|   reposted-by: "Hergeplaatst door {}" |   reposted-by: "{}がRenote" | ||||||
|   reply: "Antwoord" |   reply: "返信" | ||||||
|   renote: "Renote" |   renote: "Renote" | ||||||
|   add-reaction: "Reactie toevoegen" |   add-reaction: "リアクション" | ||||||
|   detail: "Details tonen" |   detail: "詳細" | ||||||
|   private: "この投稿は非公開です" |   private: "この投稿は非公開です" | ||||||
|   deleted: "この投稿は削除されました" |   deleted: "この投稿は削除されました" | ||||||
| desktop/views/components/notes.vue: | desktop/views/components/notes.vue: | ||||||
| @@ -675,6 +733,7 @@ desktop/views/components/settings.vue: | |||||||
|   2fa: "Authenticatie in twee stappen" |   2fa: "Authenticatie in twee stappen" | ||||||
|   other: "Overig" |   other: "Overig" | ||||||
|   license: "Licentie" |   license: "Licentie" | ||||||
|  |   theme: "テーマ" | ||||||
|   behaviour: "Gedrag" |   behaviour: "Gedrag" | ||||||
|   fetch-on-scroll: "Ophalen bij scrollen" |   fetch-on-scroll: "Ophalen bij scrollen" | ||||||
|   fetch-on-scroll-desc: "Als je omlaag scrolt, wordt de rest van de inhoud automatisch opgehaald." |   fetch-on-scroll-desc: "Als je omlaag scrolt, wordt de rest van de inhoud automatisch opgehaald." | ||||||
| @@ -686,30 +745,36 @@ desktop/views/components/settings.vue: | |||||||
|   advanced: "Geavanceerde instellingen" |   advanced: "Geavanceerde instellingen" | ||||||
|   api-via-stream: "API-verzoek via stream" |   api-via-stream: "API-verzoek via stream" | ||||||
|   api-via-stream-desc: "API-verzoek wordt uitgevoerd via de WebSocket-verbinding i.p.v. de ingebouwde ophaal-API (voor verbeterde prestaties). Deze instelling wordt opgeslagen in je browser." |   api-via-stream-desc: "API-verzoek wordt uitgevoerd via de WebSocket-verbinding i.p.v. de ingebouwde ophaal-API (voor verbeterde prestaties). Deze instelling wordt opgeslagen in je browser." | ||||||
|  |   deck-nav: "デッキ内ナビゲーション" | ||||||
|  |   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||||
|  |   deck-default: "デッキをデフォルトのUIにする" | ||||||
|   display: "Ontwerp en weergave" |   display: "Ontwerp en weergave" | ||||||
|   customize: "Startpagina aanpassen" |   customize: "Startpagina aanpassen" | ||||||
|  |   wallpaper: "壁紙" | ||||||
|   choose-wallpaper: "壁紙を選択" |   choose-wallpaper: "壁紙を選択" | ||||||
|   delete-wallpaper: "壁紙を削除" |   delete-wallpaper: "壁紙を削除" | ||||||
|   dark-mode: "Donkere modus" |   dark-mode: "Donkere modus" | ||||||
|  |   use-shadow: "UIに影を使用" | ||||||
|  |   rounded-corners: "UIの角を丸める" | ||||||
|   circle-icons: "Ronde pictogrammen gebruiken" |   circle-icons: "Ronde pictogrammen gebruiken" | ||||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" |   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||||
|   gradient-window-header: "Kleurverloop gebruiken op vensterkoppen" |  | ||||||
|   post-form-on-timeline: "Berichtformulier boven de tijdlijn tonen" |   post-form-on-timeline: "Berichtformulier boven de tijdlijn tonen" | ||||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" |   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||||
|   show-clock-on-header: "右上に時計を表示する" |   show-clock-on-header: "右上に時計を表示する" | ||||||
|   show-reply-target: "Antwoord-knop tonen" |   show-reply-target: "Antwoord-knop tonen" | ||||||
|  |   timeline: "タイムライン" | ||||||
|   show-my-renotes: "Mijn renote tonen op de tijdlijn" |   show-my-renotes: "Mijn renote tonen op de tijdlijn" | ||||||
|   show-renoted-my-notes: "Mijn gerenote bericht tonen op de tijdlijn" |   show-renoted-my-notes: "Mijn gerenote bericht tonen op de tijdlijn" | ||||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" |   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||||
|   show-maps: "Kaart tonen" |   show-maps: "Kaart tonen" | ||||||
|   show-maps-desc: "Kaart van bijgevoegde locatie tonen." |   deck-column-align: "デッキのカラムの位置" | ||||||
|  |   deck-column-align-center: "中央" | ||||||
|  |   deck-column-align-left: "左" | ||||||
|   sound: "Geluid" |   sound: "Geluid" | ||||||
|   enable-sounds: "Geluid inschakelen" |   enable-sounds: "Geluid inschakelen" | ||||||
|   enable-sounds-desc: "Een geluid afspelen bij het ontvangen van een bericht. Deze instelling wordt opgeslagen in je browser." |   enable-sounds-desc: "Een geluid afspelen bij het ontvangen van een bericht. Deze instelling wordt opgeslagen in je browser." | ||||||
|   volume: "Volume" |   volume: "Volume" | ||||||
|   test: "Testen" |   test: "Testen" | ||||||
|   mobile: "Mobiel" |  | ||||||
|   disable-via-mobile: "Berichten niet markeren als 'via mobiel'" |  | ||||||
|   language: "Taal" |   language: "Taal" | ||||||
|   pick-language: "Selecteer een taal" |   pick-language: "Selecteer een taal" | ||||||
|   recommended: "Aanbevolen" |   recommended: "Aanbevolen" | ||||||
| @@ -745,6 +810,10 @@ desktop/views/components/settings.vue: | |||||||
|   tools: "Hulpmiddelen" |   tools: "Hulpmiddelen" | ||||||
|   task-manager: "Taakbeheer" |   task-manager: "Taakbeheer" | ||||||
|   third-parties: "Derde partij" |   third-parties: "Derde partij" | ||||||
|  |   navbar-position: "ナビゲーションバーの位置" | ||||||
|  |   navbar-position-top: "上" | ||||||
|  |   navbar-position-left: "左" | ||||||
|  |   navbar-position-right: "右" | ||||||
| desktop/views/components/settings.2fa.vue: | desktop/views/components/settings.2fa.vue: | ||||||
|   intro: "Als je verificatie in twee stappen instelt, dan heb je niet alleen een wachtwoord nodig bij het inloggen, maar ook een geregistreerd fysiek apparaat (zoals je smartphone). Dit verhoogt de veiligheid. " |   intro: "Als je verificatie in twee stappen instelt, dan heb je niet alleen een wachtwoord nodig bij het inloggen, maar ook een geregistreerd fysiek apparaat (zoals je smartphone). Dit verhoogt de veiligheid. " | ||||||
|   detail: "Details bekijken..." |   detail: "Details bekijken..." | ||||||
| @@ -784,20 +853,6 @@ desktop/views/components/settings.password.vue: | |||||||
|   enter-new-password-again: "Voer je nieuwe wachtwoord nogmaals in" |   enter-new-password-again: "Voer je nieuwe wachtwoord nogmaals in" | ||||||
|   not-match: "Het nieuwe wachtwoord komt niet overeen" |   not-match: "Het nieuwe wachtwoord komt niet overeen" | ||||||
|   changed: "Wachtwoord bijgewerkt" |   changed: "Wachtwoord bijgewerkt" | ||||||
| desktop/views/components/settings.profile.vue: |  | ||||||
|   avatar: "Gebruikersafbeelding" |  | ||||||
|   choice-avatar: "Kies een afbeelding" |  | ||||||
|   name: "Naam" |  | ||||||
|   location: "Locatie" |  | ||||||
|   description: "Omschrijving" |  | ||||||
|   birthday: "Geboortedatum" |  | ||||||
|   save: "Profiel bijwerken" |  | ||||||
|   locked-account: "アカウントの保護" |  | ||||||
|   is-locked: "フォローを承認制にする" |  | ||||||
|   other: "その他" |  | ||||||
|   is-bot: "Dit account is een Bot" |  | ||||||
|   is-cat: "Dit account is een Kat" |  | ||||||
|   profile-updated: "プロフィールを更新しました" |  | ||||||
| desktop/views/components/sub-note-content.vue: | desktop/views/components/sub-note-content.vue: | ||||||
|   private: "この投稿は非公開です" |   private: "この投稿は非公開です" | ||||||
|   deleted: "この投稿は削除されました" |   deleted: "この投稿は削除されました" | ||||||
| @@ -896,10 +951,8 @@ desktop/views/pages/deck/deck.tl-column.vue: | |||||||
|   is-media-only: "メディア投稿のみ" |   is-media-only: "メディア投稿のみ" | ||||||
|   is-media-view: "メディアビュー" |   is-media-view: "メディアビュー" | ||||||
|   edit: "オプション" |   edit: "オプション" | ||||||
| desktop/views/pages/deck/deck.note.vue: | desktop/views/pages/deck/deck.user-column.vue: | ||||||
|   reposted-by: "{}がRenote" |   pinned-notes: "ピン留めされた投稿" | ||||||
|   private: "この投稿は非公開です" |  | ||||||
|   deleted: "この投稿は削除されました" |  | ||||||
| desktop/views/pages/stats/stats.vue: | desktop/views/pages/stats/stats.vue: | ||||||
|   all-users: "全てのユーザー" |   all-users: "全てのユーザー" | ||||||
|   original-users: "このインスタンスのユーザー" |   original-users: "このインスタンスのユーザー" | ||||||
| @@ -1034,6 +1087,8 @@ mobile/views/components/drive.file-detail.vue: | |||||||
|   hash: "Hash (md5)" |   hash: "Hash (md5)" | ||||||
|   exif: "EXIF" |   exif: "EXIF" | ||||||
|   nsfw: "閲覧注意" |   nsfw: "閲覧注意" | ||||||
|  |   mark-as-sensitive: "閲覧注意に設定" | ||||||
|  |   unmark-as-sensitive: "閲覧注意を解除" | ||||||
| mobile/views/components/media-image.vue: | mobile/views/components/media-image.vue: | ||||||
|   sensitive: "閲覧注意" |   sensitive: "閲覧注意" | ||||||
|   click-to-show: "クリックして表示" |   click-to-show: "クリックして表示" | ||||||
| @@ -1044,6 +1099,7 @@ mobile/views/components/follow-button.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "Volgen" |   follow: "Volgen" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| mobile/views/components/friends-maker.vue: | mobile/views/components/friends-maker.vue: | ||||||
|   title: "気になるユーザーをフォロー" |   title: "気になるユーザーをフォロー" | ||||||
| @@ -1173,23 +1229,6 @@ mobile/views/pages/notifications.vue: | |||||||
|   read-all: "Weet je zeker dat je alle meldingen wilt markeren als gelezen?" |   read-all: "Weet je zeker dat je alle meldingen wilt markeren als gelezen?" | ||||||
| mobile/views/pages/games/reversi.vue: | mobile/views/pages/games/reversi.vue: | ||||||
|   reversi: "リバーシ" |   reversi: "リバーシ" | ||||||
| mobile/views/pages/settings/settings.profile.vue: |  | ||||||
|   title: "Profiel" |  | ||||||
|   name: "Naam" |  | ||||||
|   account: "Account" |  | ||||||
|   location: "Locatie" |  | ||||||
|   description: "Omschrijving" |  | ||||||
|   birthday: "Geboortedatum" |  | ||||||
|   avatar: "Gebruikersafbeelding" |  | ||||||
|   banner: "Omslagfoto" |  | ||||||
|   is-cat: "Dit account is een Kat" |  | ||||||
|   is-locked: "フォローを承認制にする" |  | ||||||
|   advanced: "その他" |  | ||||||
|   privacy: "プライバシー" |  | ||||||
|   save: "Profiel bijwerken" |  | ||||||
|   saved: "Profiel bijgewerkt" |  | ||||||
|   uploading: "Bezig met uploaden" |  | ||||||
|   upload-failed: "Upload mislukt" |  | ||||||
| mobile/views/pages/search.vue: | mobile/views/pages/search.vue: | ||||||
|   search: "Zoeken" |   search: "Zoeken" | ||||||
|   empty: "Geen berichten gevonden voor '{}'" |   empty: "Geen berichten gevonden voor '{}'" | ||||||
| @@ -1219,6 +1258,7 @@ mobile/views/pages/settings.vue: | |||||||
|   notification-position: "通知の表示" |   notification-position: "通知の表示" | ||||||
|   notification-position-bottom: "下" |   notification-position-bottom: "下" | ||||||
|   notification-position-top: "上" |   notification-position-top: "上" | ||||||
|  |   theme: "テーマ" | ||||||
|   behavior: "Gedrag" |   behavior: "Gedrag" | ||||||
|   fetch-on-scroll: "Ophalen bij scrollen" |   fetch-on-scroll: "Ophalen bij scrollen" | ||||||
|   note-visibility: "投稿の公開範囲" |   note-visibility: "投稿の公開範囲" | ||||||
|   | |||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -264,6 +264,41 @@ common/views/components/connect-failed.troubleshooter.vue: | |||||||
| common/views/components/media-banner.vue: | common/views/components/media-banner.vue: | ||||||
|   sensitive: "閲覧注意" |   sensitive: "閲覧注意" | ||||||
|   click-to-show: "クリックして表示" |   click-to-show: "クリックして表示" | ||||||
|  | common/views/components/theme.vue: | ||||||
|  |   light-theme: "非ダークモード時に使用するテーマ" | ||||||
|  |   dark-theme: "ダークモード時に使用するテーマ" | ||||||
|  |   light-themes: "明るいテーマ" | ||||||
|  |   dark-themes: "暗いテーマ" | ||||||
|  |   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: "保存しました" | ||||||
|  |   manage-themes: "テーマの管理" | ||||||
|  |   builtin-themes: "標準テーマ" | ||||||
|  |   my-themes: "マイテーマ" | ||||||
|  |   installed-themes: "インストールされたテーマ" | ||||||
|  |   select-theme: "テーマを選択してください" | ||||||
|  |   uninstall: "アンインストール" | ||||||
|  |   uninstalled: "「{}」をアンインストールしました" | ||||||
|  |   author: "作者" | ||||||
|  |   desc: "説明" | ||||||
|  |   export: "エクスポート" | ||||||
|  |   import: "インポート" | ||||||
|  |   import-by-code: "またはコードをペースト" | ||||||
|  |   theme-name-required: "テーマ名は必須です。" | ||||||
| common/views/components/cw-button.vue: | common/views/components/cw-button.vue: | ||||||
|   hide: "隠す" |   hide: "隠す" | ||||||
|   show: "もっと見る" |   show: "もっと見る" | ||||||
| @@ -300,7 +335,9 @@ common/views/components/note-menu.vue: | |||||||
|   detail: "詳細" |   detail: "詳細" | ||||||
|   copy-link: "リンクをコピー" |   copy-link: "リンクをコピー" | ||||||
|   favorite: "Dodaj do ulubionych" |   favorite: "Dodaj do ulubionych" | ||||||
|  |   unfavorite: "お気に入り解除" | ||||||
|   pin: "Przypnij do profilu" |   pin: "Przypnij do profilu" | ||||||
|  |   unpin: "ピン留め解除" | ||||||
|   delete: "Usuń" |   delete: "Usuń" | ||||||
|   delete-confirm: "Czy na pewno chcesz usunąć ten wpis?" |   delete-confirm: "Czy na pewno chcesz usunąć ten wpis?" | ||||||
|   remote: "Pokaż oryginał" |   remote: "Pokaż oryginał" | ||||||
| @@ -379,6 +416,25 @@ common/views/components/visibility-chooser.vue: | |||||||
| common/views/components/trends.vue: | common/views/components/trends.vue: | ||||||
|   count: "{}人が投稿" |   count: "{}人が投稿" | ||||||
|   empty: "トレンドなし" |   empty: "トレンドなし" | ||||||
|  | common/views/components/profile-editor.vue: | ||||||
|  |   title: "プロフィール" | ||||||
|  |   name: "名前" | ||||||
|  |   account: "アカウント" | ||||||
|  |   location: "場所" | ||||||
|  |   description: "自己紹介" | ||||||
|  |   birthday: "誕生日" | ||||||
|  |   avatar: "アイコン" | ||||||
|  |   banner: "バナー" | ||||||
|  |   is-cat: "このアカウントはCatです" | ||||||
|  |   is-bot: "このアカウントはBotです" | ||||||
|  |   is-locked: "フォローを承認制にする" | ||||||
|  |   careful-bot: "Botからのフォローだけ承認制にする" | ||||||
|  |   advanced: "その他" | ||||||
|  |   privacy: "プライバシー" | ||||||
|  |   save: "保存" | ||||||
|  |   saved: "プロフィールを保存しました" | ||||||
|  |   uploading: "アップロード中" | ||||||
|  |   upload-failed: "アップロードに失敗しました" | ||||||
| common/views/widgets/broadcast.vue: | common/views/widgets/broadcast.vue: | ||||||
|   fetching: "Sprawdzanie" |   fetching: "Sprawdzanie" | ||||||
|   no-broadcasts: "Brak transmisji" |   no-broadcasts: "Brak transmisji" | ||||||
| @@ -439,6 +495,7 @@ common/views/pages/follow.vue: | |||||||
|   following: "Śledzisz" |   following: "Śledzisz" | ||||||
|   follow: "Śledź" |   follow: "Śledź" | ||||||
|   request-pending: "Oczekiwanie na pozwolenie" |   request-pending: "Oczekiwanie na pozwolenie" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "Poproś o śledzenie" |   follow-request: "Poproś o śledzenie" | ||||||
| desktop: | desktop: | ||||||
|   banner-crop-title: "バナーとして表示する部分を選択" |   banner-crop-title: "バナーとして表示する部分を選択" | ||||||
| @@ -477,13 +534,13 @@ desktop/views/components/charts.vue: | |||||||
|     notes: "投稿の増減 (統合)" |     notes: "投稿の増減 (統合)" | ||||||
|     local-notes: "投稿の増減 (ローカル)" |     local-notes: "投稿の増減 (ローカル)" | ||||||
|     remote-notes: "投稿の増減 (リモート)" |     remote-notes: "投稿の増減 (リモート)" | ||||||
|     notes-total: "投稿の累計" |     notes-total: "投稿の積算" | ||||||
|     users: "ユーザーの増減" |     users: "ユーザーの増減" | ||||||
|     users-total: "ユーザーの累計" |     users-total: "ユーザーの積算" | ||||||
|     drive: "ドライブ使用量の増減" |     drive: "ドライブ使用量の増減" | ||||||
|     drive-total: "ドライブ使用量の累計" |     drive-total: "ドライブ使用量の積算" | ||||||
|     drive-files: "ドライブのファイル数の増減" |     drive-files: "ドライブのファイル数の増減" | ||||||
|     drive-files-total: "ドライブのファイル数の累計" |     drive-files-total: "ドライブのファイル数の積算" | ||||||
|     network-requests: "リクエスト" |     network-requests: "リクエスト" | ||||||
|     network-time: "応答時間" |     network-time: "応答時間" | ||||||
|     network-usage: "通信量" |     network-usage: "通信量" | ||||||
| @@ -565,6 +622,7 @@ desktop/views/components/follow-button.vue: | |||||||
|   following: "Śledzisz" |   following: "Śledzisz" | ||||||
|   follow: "Śledź" |   follow: "Śledź" | ||||||
|   request-pending: "Oczekiwanie na pozwolenie" |   request-pending: "Oczekiwanie na pozwolenie" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "Poproś o śledzenie" |   follow-request: "Poproś o śledzenie" | ||||||
| desktop/views/components/followers-window.vue: | desktop/views/components/followers-window.vue: | ||||||
|   followers: "Śledzący" |   followers: "Śledzący" | ||||||
| @@ -601,14 +659,14 @@ desktop/views/components/note-detail.vue: | |||||||
|   location: "Informacje o lokalizacji" |   location: "Informacje o lokalizacji" | ||||||
|   renote: "Udostępnienie" |   renote: "Udostępnienie" | ||||||
|   add-reaction: "Dodaj reakcję" |   add-reaction: "Dodaj reakcję" | ||||||
| desktop/views/components/notes.note.vue: | desktop/views/components/note.vue: | ||||||
|   reposted-by: "Udostępniono przez {}" |   reposted-by: "{}がRenote" | ||||||
|   reply: "Odpowiedz" |   reply: "返信" | ||||||
|   renote: "Udostępnij" |   renote: "Renote" | ||||||
|   add-reaction: "Dodaj reakcję" |   add-reaction: "リアクション" | ||||||
|   detail: "Pokaż szczegóły" |   detail: "詳細" | ||||||
|   private: "ten wpis jest prywatny" |   private: "この投稿は非公開です" | ||||||
|   deleted: "ten wpis został usunięty" |   deleted: "この投稿は削除されました" | ||||||
| desktop/views/components/notes.vue: | desktop/views/components/notes.vue: | ||||||
|   error: "Ładowanie nie powiodło się." |   error: "Ładowanie nie powiodło się." | ||||||
|   retry: "Spróbuj ponownie" |   retry: "Spróbuj ponownie" | ||||||
| @@ -675,6 +733,7 @@ desktop/views/components/settings.vue: | |||||||
|   2fa: "Uwierzytelnianie dwuetapowe" |   2fa: "Uwierzytelnianie dwuetapowe" | ||||||
|   other: "Inne" |   other: "Inne" | ||||||
|   license: "Licencja" |   license: "Licencja" | ||||||
|  |   theme: "テーマ" | ||||||
|   behaviour: "Zachowanie" |   behaviour: "Zachowanie" | ||||||
|   fetch-on-scroll: "Automatycznie ładuj po przeciągnięciu w dół" |   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." |   fetch-on-scroll-desc: "Po przewinięciu na dół strony automatycznie zostaną załadowane nowe treści." | ||||||
| @@ -686,30 +745,36 @@ desktop/views/components/settings.vue: | |||||||
|   advanced: "Ustawienia zaawansowane" |   advanced: "Ustawienia zaawansowane" | ||||||
|   api-via-stream: "ストリームを経由したAPIリクエスト" |   api-via-stream: "ストリームを経由したAPIリクエスト" | ||||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" |   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||||
|  |   deck-nav: "デッキ内ナビゲーション" | ||||||
|  |   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||||
|  |   deck-default: "デッキをデフォルトのUIにする" | ||||||
|   display: "Wygląd i wyświetlanie" |   display: "Wygląd i wyświetlanie" | ||||||
|   customize: "Dostosuj stronę główną" |   customize: "Dostosuj stronę główną" | ||||||
|  |   wallpaper: "壁紙" | ||||||
|   choose-wallpaper: "Wybierz tło" |   choose-wallpaper: "Wybierz tło" | ||||||
|   delete-wallpaper: "Usuń tło" |   delete-wallpaper: "Usuń tło" | ||||||
|   dark-mode: "Tryb ciemny" |   dark-mode: "Tryb ciemny" | ||||||
|  |   use-shadow: "UIに影を使用" | ||||||
|  |   rounded-corners: "UIの角を丸める" | ||||||
|   circle-icons: "Używaj okrągłych ikon" |   circle-icons: "Używaj okrągłych ikon" | ||||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" |   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" |   post-form-on-timeline: "Wyświetlaj formularz tworzenia wpisu w górnej części osi czasu" | ||||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" |   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||||
|   show-clock-on-header: "右上に時計を表示する" |   show-clock-on-header: "右上に時計を表示する" | ||||||
|   show-reply-target: "Pokazuj cel odpowiedzi" |   show-reply-target: "Pokazuj cel odpowiedzi" | ||||||
|  |   timeline: "タイムライン" | ||||||
|   show-my-renotes: "Pokazuj moje udostępnienia na osi czasu" |   show-my-renotes: "Pokazuj moje udostępnienia na osi czasu" | ||||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" |   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" |   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||||
|   show-maps: "Automatycznie pokazuj mapę" |   show-maps: "Automatycznie pokazuj mapę" | ||||||
|   show-maps-desc: "Mapa będzie automatycznie rozwijana dla wpisów zawierających informacje o lokalizacji." |   deck-column-align: "デッキのカラムの位置" | ||||||
|  |   deck-column-align-center: "中央" | ||||||
|  |   deck-column-align-left: "左" | ||||||
|   sound: "Dźwięk" |   sound: "Dźwięk" | ||||||
|   enable-sounds: "Włącz dźwięk" |   enable-sounds: "Włącz dźwięk" | ||||||
|   enable-sounds-desc: "Odtwarzaj dźwięk przy wstawianiu wpisów, wysyłaniu lub otrzymywaniu wiadomości. Opcja ta jest zapamiętywana przez przeglądarkę." |   enable-sounds-desc: "Odtwarzaj dźwięk przy wstawianiu wpisów, wysyłaniu lub otrzymywaniu wiadomości. Opcja ta jest zapamiętywana przez przeglądarkę." | ||||||
|   volume: "Głośność" |   volume: "Głośność" | ||||||
|   test: "Test" |   test: "Test" | ||||||
|   mobile: "Wersja mobilna" |  | ||||||
|   disable-via-mobile: "Nie oznaczaj wpisów jako „wysłane z telefonu”" |  | ||||||
|   language: "Język" |   language: "Język" | ||||||
|   pick-language: "Wybierz język" |   pick-language: "Wybierz język" | ||||||
|   recommended: "Zalecane" |   recommended: "Zalecane" | ||||||
| @@ -745,6 +810,10 @@ desktop/views/components/settings.vue: | |||||||
|   tools: "Narzędzia" |   tools: "Narzędzia" | ||||||
|   task-manager: "Menedżer zadań" |   task-manager: "Menedżer zadań" | ||||||
|   third-parties: "Autorzy trzeci" |   third-parties: "Autorzy trzeci" | ||||||
|  |   navbar-position: "ナビゲーションバーの位置" | ||||||
|  |   navbar-position-top: "上" | ||||||
|  |   navbar-position-left: "左" | ||||||
|  |   navbar-position-right: "右" | ||||||
| desktop/views/components/settings.2fa.vue: | desktop/views/components/settings.2fa.vue: | ||||||
|   intro: "Jeżeli skonfigurujesz uwierzytelnianie dwuetapowe, aby zablokować się będziesz potrzebować (oprócz hasła) kodu ze skonfigurowanego urządzenia (np. smartfonu), co zwiększy bezpieczeństwo." |   intro: "Jeżeli skonfigurujesz uwierzytelnianie dwuetapowe, aby zablokować się będziesz potrzebować (oprócz hasła) kodu ze skonfigurowanego urządzenia (np. smartfonu), co zwiększy bezpieczeństwo." | ||||||
|   detail: "Zobacz szczegóły…" |   detail: "Zobacz szczegóły…" | ||||||
| @@ -784,20 +853,6 @@ desktop/views/components/settings.password.vue: | |||||||
|   enter-new-password-again: "Wprowadź ponownie nowe hasło" |   enter-new-password-again: "Wprowadź ponownie nowe hasło" | ||||||
|   not-match: "Nowe hasła nie pasują do siebie" |   not-match: "Nowe hasła nie pasują do siebie" | ||||||
|   changed: "Pomyślnie zmieniono hasło" |   changed: "Pomyślnie zmieniono hasło" | ||||||
| desktop/views/components/settings.profile.vue: |  | ||||||
|   avatar: "Awatar" |  | ||||||
|   choice-avatar: "Wybierz obraz" |  | ||||||
|   name: "Nazwa" |  | ||||||
|   location: "Lokalizacja" |  | ||||||
|   description: "Opis" |  | ||||||
|   birthday: "Data urodzenia" |  | ||||||
|   save: "Aktualizuj profil" |  | ||||||
|   locked-account: "Zabezpiecz swoje konto" |  | ||||||
|   is-locked: "フォローを承認制にする" |  | ||||||
|   other: "Inne" |  | ||||||
|   is-bot: "To konto jest prowadzone przez bota" |  | ||||||
|   is-cat: "To konto jest prowadzone przez kota" |  | ||||||
|   profile-updated: "Zaktualizowano profil" |  | ||||||
| desktop/views/components/sub-note-content.vue: | desktop/views/components/sub-note-content.vue: | ||||||
|   private: "ten wpis jest prywatny" |   private: "ten wpis jest prywatny" | ||||||
|   deleted: "ten wpis został usunięty" |   deleted: "ten wpis został usunięty" | ||||||
| @@ -896,10 +951,8 @@ desktop/views/pages/deck/deck.tl-column.vue: | |||||||
|   is-media-only: "Tylko wpisy z zawartością multimedialną" |   is-media-only: "Tylko wpisy z zawartością multimedialną" | ||||||
|   is-media-view: "Widok multimediów" |   is-media-view: "Widok multimediów" | ||||||
|   edit: "Opcje" |   edit: "Opcje" | ||||||
| desktop/views/pages/deck/deck.note.vue: | desktop/views/pages/deck/deck.user-column.vue: | ||||||
|   reposted-by: "Udostępniono przez {}" |   pinned-notes: "ピン留めされた投稿" | ||||||
|   private: "ten wpis jest prywatny" |  | ||||||
|   deleted: "ten wpis został usunięty" |  | ||||||
| desktop/views/pages/stats/stats.vue: | desktop/views/pages/stats/stats.vue: | ||||||
|   all-users: "全てのユーザー" |   all-users: "全てのユーザー" | ||||||
|   original-users: "このインスタンスのユーザー" |   original-users: "このインスタンスのユーザー" | ||||||
| @@ -1034,6 +1087,8 @@ mobile/views/components/drive.file-detail.vue: | |||||||
|   hash: "Hash (md5)" |   hash: "Hash (md5)" | ||||||
|   exif: "EXIF" |   exif: "EXIF" | ||||||
|   nsfw: "閲覧注意" |   nsfw: "閲覧注意" | ||||||
|  |   mark-as-sensitive: "閲覧注意に設定" | ||||||
|  |   unmark-as-sensitive: "閲覧注意を解除" | ||||||
| mobile/views/components/media-image.vue: | mobile/views/components/media-image.vue: | ||||||
|   sensitive: "To jest zawartość NSFW" |   sensitive: "To jest zawartość NSFW" | ||||||
|   click-to-show: "Naciśnij aby wyświetlić" |   click-to-show: "Naciśnij aby wyświetlić" | ||||||
| @@ -1044,6 +1099,7 @@ mobile/views/components/follow-button.vue: | |||||||
|   following: "Śledzisz" |   following: "Śledzisz" | ||||||
|   follow: "Śledź" |   follow: "Śledź" | ||||||
|   request-pending: "Oczekiwanie na pozwolenie" |   request-pending: "Oczekiwanie na pozwolenie" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "Poproś o śledzenie" |   follow-request: "Poproś o śledzenie" | ||||||
| mobile/views/components/friends-maker.vue: | mobile/views/components/friends-maker.vue: | ||||||
|   title: "Zacznij śledzić ludzi takich jak Ty" |   title: "Zacznij śledzić ludzi takich jak Ty" | ||||||
| @@ -1173,23 +1229,6 @@ mobile/views/pages/notifications.vue: | |||||||
|   read-all: "Czy na pewno chcesz oznaczyć wszystkie powiadomienia jako przeczytane?" |   read-all: "Czy na pewno chcesz oznaczyć wszystkie powiadomienia jako przeczytane?" | ||||||
| mobile/views/pages/games/reversi.vue: | mobile/views/pages/games/reversi.vue: | ||||||
|   reversi: "Reversi" |   reversi: "Reversi" | ||||||
| mobile/views/pages/settings/settings.profile.vue: |  | ||||||
|   title: "Profil" |  | ||||||
|   name: "Nazwa" |  | ||||||
|   account: "Konto" |  | ||||||
|   location: "Lokalizacja" |  | ||||||
|   description: "Opis" |  | ||||||
|   birthday: "Data urodzenia" |  | ||||||
|   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" |  | ||||||
|   upload-failed: "Wysyłanie nie powiodło się" |  | ||||||
| mobile/views/pages/search.vue: | mobile/views/pages/search.vue: | ||||||
|   search: "Szukaj" |   search: "Szukaj" | ||||||
|   empty: "Nie znaleziono wpisów zawierających '{}'" |   empty: "Nie znaleziono wpisów zawierających '{}'" | ||||||
| @@ -1219,6 +1258,7 @@ mobile/views/pages/settings.vue: | |||||||
|   notification-position: "通知の表示" |   notification-position: "通知の表示" | ||||||
|   notification-position-bottom: "下" |   notification-position-bottom: "下" | ||||||
|   notification-position-top: "上" |   notification-position-top: "上" | ||||||
|  |   theme: "テーマ" | ||||||
|   behavior: "Zachowanie" |   behavior: "Zachowanie" | ||||||
|   fetch-on-scroll: "Automatycznie ładuj po przeciągnięciu w dół" |   fetch-on-scroll: "Automatycznie ładuj po przeciągnięciu w dół" | ||||||
|   note-visibility: "投稿の公開範囲" |   note-visibility: "投稿の公開範囲" | ||||||
|   | |||||||
| @@ -264,6 +264,41 @@ common/views/components/connect-failed.troubleshooter.vue: | |||||||
| common/views/components/media-banner.vue: | common/views/components/media-banner.vue: | ||||||
|   sensitive: "閲覧注意" |   sensitive: "閲覧注意" | ||||||
|   click-to-show: "クリックして表示" |   click-to-show: "クリックして表示" | ||||||
|  | common/views/components/theme.vue: | ||||||
|  |   light-theme: "非ダークモード時に使用するテーマ" | ||||||
|  |   dark-theme: "ダークモード時に使用するテーマ" | ||||||
|  |   light-themes: "明るいテーマ" | ||||||
|  |   dark-themes: "暗いテーマ" | ||||||
|  |   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: "保存しました" | ||||||
|  |   manage-themes: "テーマの管理" | ||||||
|  |   builtin-themes: "標準テーマ" | ||||||
|  |   my-themes: "マイテーマ" | ||||||
|  |   installed-themes: "インストールされたテーマ" | ||||||
|  |   select-theme: "テーマを選択してください" | ||||||
|  |   uninstall: "アンインストール" | ||||||
|  |   uninstalled: "「{}」をアンインストールしました" | ||||||
|  |   author: "作者" | ||||||
|  |   desc: "説明" | ||||||
|  |   export: "エクスポート" | ||||||
|  |   import: "インポート" | ||||||
|  |   import-by-code: "またはコードをペースト" | ||||||
|  |   theme-name-required: "テーマ名は必須です。" | ||||||
| common/views/components/cw-button.vue: | common/views/components/cw-button.vue: | ||||||
|   hide: "隠す" |   hide: "隠す" | ||||||
|   show: "もっと見る" |   show: "もっと見る" | ||||||
| @@ -300,7 +335,9 @@ common/views/components/note-menu.vue: | |||||||
|   detail: "詳細" |   detail: "詳細" | ||||||
|   copy-link: "リンクをコピー" |   copy-link: "リンクをコピー" | ||||||
|   favorite: "お気に入り" |   favorite: "お気に入り" | ||||||
|  |   unfavorite: "お気に入り解除" | ||||||
|   pin: "ピン留め" |   pin: "ピン留め" | ||||||
|  |   unpin: "ピン留め解除" | ||||||
|   delete: "削除" |   delete: "削除" | ||||||
|   delete-confirm: "この投稿を削除しますか?" |   delete-confirm: "この投稿を削除しますか?" | ||||||
|   remote: "投稿元で見る" |   remote: "投稿元で見る" | ||||||
| @@ -379,6 +416,25 @@ common/views/components/visibility-chooser.vue: | |||||||
| common/views/components/trends.vue: | common/views/components/trends.vue: | ||||||
|   count: "{}人が投稿" |   count: "{}人が投稿" | ||||||
|   empty: "トレンドなし" |   empty: "トレンドなし" | ||||||
|  | common/views/components/profile-editor.vue: | ||||||
|  |   title: "プロフィール" | ||||||
|  |   name: "名前" | ||||||
|  |   account: "アカウント" | ||||||
|  |   location: "場所" | ||||||
|  |   description: "自己紹介" | ||||||
|  |   birthday: "誕生日" | ||||||
|  |   avatar: "アイコン" | ||||||
|  |   banner: "バナー" | ||||||
|  |   is-cat: "このアカウントはCatです" | ||||||
|  |   is-bot: "このアカウントはBotです" | ||||||
|  |   is-locked: "フォローを承認制にする" | ||||||
|  |   careful-bot: "Botからのフォローだけ承認制にする" | ||||||
|  |   advanced: "その他" | ||||||
|  |   privacy: "プライバシー" | ||||||
|  |   save: "保存" | ||||||
|  |   saved: "プロフィールを保存しました" | ||||||
|  |   uploading: "アップロード中" | ||||||
|  |   upload-failed: "アップロードに失敗しました" | ||||||
| common/views/widgets/broadcast.vue: | common/views/widgets/broadcast.vue: | ||||||
|   fetching: "確認中" |   fetching: "確認中" | ||||||
|   no-broadcasts: "お知らせはありません" |   no-broadcasts: "お知らせはありません" | ||||||
| @@ -439,6 +495,7 @@ common/views/pages/follow.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| desktop: | desktop: | ||||||
|   banner-crop-title: "バナーとして表示する部分を選択" |   banner-crop-title: "バナーとして表示する部分を選択" | ||||||
| @@ -477,13 +534,13 @@ desktop/views/components/charts.vue: | |||||||
|     notes: "投稿の増減 (統合)" |     notes: "投稿の増減 (統合)" | ||||||
|     local-notes: "投稿の増減 (ローカル)" |     local-notes: "投稿の増減 (ローカル)" | ||||||
|     remote-notes: "投稿の増減 (リモート)" |     remote-notes: "投稿の増減 (リモート)" | ||||||
|     notes-total: "投稿の累計" |     notes-total: "投稿の積算" | ||||||
|     users: "ユーザーの増減" |     users: "ユーザーの増減" | ||||||
|     users-total: "ユーザーの累計" |     users-total: "ユーザーの積算" | ||||||
|     drive: "ドライブ使用量の増減" |     drive: "ドライブ使用量の増減" | ||||||
|     drive-total: "ドライブ使用量の累計" |     drive-total: "ドライブ使用量の積算" | ||||||
|     drive-files: "ドライブのファイル数の増減" |     drive-files: "ドライブのファイル数の増減" | ||||||
|     drive-files-total: "ドライブのファイル数の累計" |     drive-files-total: "ドライブのファイル数の積算" | ||||||
|     network-requests: "リクエスト" |     network-requests: "リクエスト" | ||||||
|     network-time: "応答時間" |     network-time: "応答時間" | ||||||
|     network-usage: "通信量" |     network-usage: "通信量" | ||||||
| @@ -565,6 +622,7 @@ desktop/views/components/follow-button.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| desktop/views/components/followers-window.vue: | desktop/views/components/followers-window.vue: | ||||||
|   followers: "{} のフォロワー" |   followers: "{} のフォロワー" | ||||||
| @@ -601,7 +659,7 @@ desktop/views/components/note-detail.vue: | |||||||
|   location: "位置情報" |   location: "位置情報" | ||||||
|   renote: "Renote" |   renote: "Renote" | ||||||
|   add-reaction: "リアクション" |   add-reaction: "リアクション" | ||||||
| desktop/views/components/notes.note.vue: | desktop/views/components/note.vue: | ||||||
|   reposted-by: "{}がRenote" |   reposted-by: "{}がRenote" | ||||||
|   reply: "返信" |   reply: "返信" | ||||||
|   renote: "Renote" |   renote: "Renote" | ||||||
| @@ -675,6 +733,7 @@ desktop/views/components/settings.vue: | |||||||
|   2fa: "二段階認証" |   2fa: "二段階認証" | ||||||
|   other: "その他" |   other: "その他" | ||||||
|   license: "ライセンス" |   license: "ライセンス" | ||||||
|  |   theme: "テーマ" | ||||||
|   behaviour: "動作" |   behaviour: "動作" | ||||||
|   fetch-on-scroll: "スクロールで自動読み込み" |   fetch-on-scroll: "スクロールで自動読み込み" | ||||||
|   fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込みます。" |   fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込みます。" | ||||||
| @@ -686,30 +745,36 @@ desktop/views/components/settings.vue: | |||||||
|   advanced: "詳細設定" |   advanced: "詳細設定" | ||||||
|   api-via-stream: "ストリームを経由したAPIリクエスト" |   api-via-stream: "ストリームを経由したAPIリクエスト" | ||||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" |   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||||
|  |   deck-nav: "デッキ内ナビゲーション" | ||||||
|  |   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||||
|  |   deck-default: "デッキをデフォルトのUIにする" | ||||||
|   display: "デザインと表示" |   display: "デザインと表示" | ||||||
|   customize: "ホームをカスタマイズ" |   customize: "ホームをカスタマイズ" | ||||||
|  |   wallpaper: "壁紙" | ||||||
|   choose-wallpaper: "壁紙を選択" |   choose-wallpaper: "壁紙を選択" | ||||||
|   delete-wallpaper: "壁紙を削除" |   delete-wallpaper: "壁紙を削除" | ||||||
|   dark-mode: "ダークモード" |   dark-mode: "ダークモード" | ||||||
|  |   use-shadow: "UIに影を使用" | ||||||
|  |   rounded-corners: "UIの角を丸める" | ||||||
|   circle-icons: "円形のアイコンを使用" |   circle-icons: "円形のアイコンを使用" | ||||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" |   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" |  | ||||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" |   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" |   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||||
|   show-clock-on-header: "右上に時計を表示する" |   show-clock-on-header: "右上に時計を表示する" | ||||||
|   show-reply-target: "リプライ先を表示する" |   show-reply-target: "リプライ先を表示する" | ||||||
|  |   timeline: "タイムライン" | ||||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" |   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" |   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" |   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||||
|   show-maps: "マップの自動展開" |   show-maps: "マップの自動展開" | ||||||
|   show-maps-desc: "位置情報が添付された投稿のマップを自動的に展開します。" |   deck-column-align: "デッキのカラムの位置" | ||||||
|  |   deck-column-align-center: "中央" | ||||||
|  |   deck-column-align-left: "左" | ||||||
|   sound: "サウンド" |   sound: "サウンド" | ||||||
|   enable-sounds: "サウンドを有効にする" |   enable-sounds: "サウンドを有効にする" | ||||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" |   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||||
|   volume: "ボリューム" |   volume: "ボリューム" | ||||||
|   test: "テスト" |   test: "テスト" | ||||||
|   mobile: "モバイル" |  | ||||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" |  | ||||||
|   language: "言語" |   language: "言語" | ||||||
|   pick-language: "言語を選択" |   pick-language: "言語を選択" | ||||||
|   recommended: "推奨" |   recommended: "推奨" | ||||||
| @@ -745,6 +810,10 @@ desktop/views/components/settings.vue: | |||||||
|   tools: "ツール" |   tools: "ツール" | ||||||
|   task-manager: "タスクマネージャ" |   task-manager: "タスクマネージャ" | ||||||
|   third-parties: "サードパーティ" |   third-parties: "サードパーティ" | ||||||
|  |   navbar-position: "ナビゲーションバーの位置" | ||||||
|  |   navbar-position-top: "上" | ||||||
|  |   navbar-position-left: "左" | ||||||
|  |   navbar-position-right: "右" | ||||||
| desktop/views/components/settings.2fa.vue: | desktop/views/components/settings.2fa.vue: | ||||||
|   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" |   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" | ||||||
|   detail: "詳細..." |   detail: "詳細..." | ||||||
| @@ -784,20 +853,6 @@ desktop/views/components/settings.password.vue: | |||||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" |   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||||
|   not-match: "新しいパスワードが一致しません" |   not-match: "新しいパスワードが一致しません" | ||||||
|   changed: "パスワードを変更しました" |   changed: "パスワードを変更しました" | ||||||
| desktop/views/components/settings.profile.vue: |  | ||||||
|   avatar: "アイコン" |  | ||||||
|   choice-avatar: "画像を選択" |  | ||||||
|   name: "名前" |  | ||||||
|   location: "場所" |  | ||||||
|   description: "自己紹介" |  | ||||||
|   birthday: "誕生日" |  | ||||||
|   save: "保存" |  | ||||||
|   locked-account: "アカウントの保護" |  | ||||||
|   is-locked: "フォローを承認制にする" |  | ||||||
|   other: "その他" |  | ||||||
|   is-bot: "このアカウントはBotです" |  | ||||||
|   is-cat: "このアカウントはCatです" |  | ||||||
|   profile-updated: "プロフィールを更新しました" |  | ||||||
| desktop/views/components/sub-note-content.vue: | desktop/views/components/sub-note-content.vue: | ||||||
|   private: "この投稿は非公開です" |   private: "この投稿は非公開です" | ||||||
|   deleted: "この投稿は削除されました" |   deleted: "この投稿は削除されました" | ||||||
| @@ -896,10 +951,8 @@ desktop/views/pages/deck/deck.tl-column.vue: | |||||||
|   is-media-only: "メディア投稿のみ" |   is-media-only: "メディア投稿のみ" | ||||||
|   is-media-view: "メディアビュー" |   is-media-view: "メディアビュー" | ||||||
|   edit: "オプション" |   edit: "オプション" | ||||||
| desktop/views/pages/deck/deck.note.vue: | desktop/views/pages/deck/deck.user-column.vue: | ||||||
|   reposted-by: "{}がRenote" |   pinned-notes: "ピン留めされた投稿" | ||||||
|   private: "この投稿は非公開です" |  | ||||||
|   deleted: "この投稿は削除されました" |  | ||||||
| desktop/views/pages/stats/stats.vue: | desktop/views/pages/stats/stats.vue: | ||||||
|   all-users: "全てのユーザー" |   all-users: "全てのユーザー" | ||||||
|   original-users: "このインスタンスのユーザー" |   original-users: "このインスタンスのユーザー" | ||||||
| @@ -1034,6 +1087,8 @@ mobile/views/components/drive.file-detail.vue: | |||||||
|   hash: "ハッシュ (md5)" |   hash: "ハッシュ (md5)" | ||||||
|   exif: "EXIF" |   exif: "EXIF" | ||||||
|   nsfw: "閲覧注意" |   nsfw: "閲覧注意" | ||||||
|  |   mark-as-sensitive: "閲覧注意に設定" | ||||||
|  |   unmark-as-sensitive: "閲覧注意を解除" | ||||||
| mobile/views/components/media-image.vue: | mobile/views/components/media-image.vue: | ||||||
|   sensitive: "閲覧注意" |   sensitive: "閲覧注意" | ||||||
|   click-to-show: "クリックして表示" |   click-to-show: "クリックして表示" | ||||||
| @@ -1044,6 +1099,7 @@ mobile/views/components/follow-button.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| mobile/views/components/friends-maker.vue: | mobile/views/components/friends-maker.vue: | ||||||
|   title: "気になるユーザーをフォロー" |   title: "気になるユーザーをフォロー" | ||||||
| @@ -1173,23 +1229,6 @@ mobile/views/pages/notifications.vue: | |||||||
|   read-all: "すべての通知を既読にしますか?" |   read-all: "すべての通知を既読にしますか?" | ||||||
| mobile/views/pages/games/reversi.vue: | mobile/views/pages/games/reversi.vue: | ||||||
|   reversi: "リバーシ" |   reversi: "リバーシ" | ||||||
| mobile/views/pages/settings/settings.profile.vue: |  | ||||||
|   title: "プロフィール" |  | ||||||
|   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: | mobile/views/pages/search.vue: | ||||||
|   search: "Pesquisar" |   search: "Pesquisar" | ||||||
|   empty: "「{}」に関する投稿は見つかりませんでした。" |   empty: "「{}」に関する投稿は見つかりませんでした。" | ||||||
| @@ -1219,6 +1258,7 @@ mobile/views/pages/settings.vue: | |||||||
|   notification-position: "通知の表示" |   notification-position: "通知の表示" | ||||||
|   notification-position-bottom: "下" |   notification-position-bottom: "下" | ||||||
|   notification-position-top: "上" |   notification-position-top: "上" | ||||||
|  |   theme: "テーマ" | ||||||
|   behavior: "動作" |   behavior: "動作" | ||||||
|   fetch-on-scroll: "スクロールで自動読み込み" |   fetch-on-scroll: "スクロールで自動読み込み" | ||||||
|   note-visibility: "投稿の公開範囲" |   note-visibility: "投稿の公開範囲" | ||||||
|   | |||||||
| @@ -3,9 +3,9 @@ meta: | |||||||
|   lang: "Русский язык" |   lang: "Русский язык" | ||||||
|   divider: "" |   divider: "" | ||||||
| common: | common: | ||||||
|   misskey: "A ⭐ of fediverse" |   misskey: "Мы — ⭐ fediverse" | ||||||
|   about-title: "A ⭐ of fediverse." |   about-title: "Мы — ⭐ fediverse" | ||||||
|   about: "Misskeyを見つけていただき、ありがとうございます。Misskeyは、地球で生まれた<b>分散マイクロブログSNS</b>です。Fediverse(様々なSNSで構成される宇宙)の中に存在するため、他のSNSと相互に繋がっています。暫し都会の喧騒から離れて、新しいインターネットにダイブしてみませんか。" |   about: "Спасибо, что нашли Misskey. Misskey — это <b>децентрализованная платформа для микроблоггинга</b> родом с планеты Земля. Поскольку она существует внутри Fediverse (вселенной различных социальных платформ), она связана с другими платформами. Отдохните от шума большого города — и познакомьтесь с новым интернетом." | ||||||
|   intro: |   intro: | ||||||
|     title: "Misskeyって?" |     title: "Misskeyって?" | ||||||
|     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" |     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" | ||||||
| @@ -264,6 +264,41 @@ common/views/components/connect-failed.troubleshooter.vue: | |||||||
| common/views/components/media-banner.vue: | common/views/components/media-banner.vue: | ||||||
|   sensitive: "閲覧注意" |   sensitive: "閲覧注意" | ||||||
|   click-to-show: "クリックして表示" |   click-to-show: "クリックして表示" | ||||||
|  | common/views/components/theme.vue: | ||||||
|  |   light-theme: "非ダークモード時に使用するテーマ" | ||||||
|  |   dark-theme: "ダークモード時に使用するテーマ" | ||||||
|  |   light-themes: "明るいテーマ" | ||||||
|  |   dark-themes: "暗いテーマ" | ||||||
|  |   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: "保存しました" | ||||||
|  |   manage-themes: "テーマの管理" | ||||||
|  |   builtin-themes: "標準テーマ" | ||||||
|  |   my-themes: "マイテーマ" | ||||||
|  |   installed-themes: "インストールされたテーマ" | ||||||
|  |   select-theme: "テーマを選択してください" | ||||||
|  |   uninstall: "アンインストール" | ||||||
|  |   uninstalled: "「{}」をアンインストールしました" | ||||||
|  |   author: "作者" | ||||||
|  |   desc: "説明" | ||||||
|  |   export: "エクスポート" | ||||||
|  |   import: "インポート" | ||||||
|  |   import-by-code: "またはコードをペースト" | ||||||
|  |   theme-name-required: "テーマ名は必須です。" | ||||||
| common/views/components/cw-button.vue: | common/views/components/cw-button.vue: | ||||||
|   hide: "隠す" |   hide: "隠す" | ||||||
|   show: "もっと見る" |   show: "もっと見る" | ||||||
| @@ -300,7 +335,9 @@ common/views/components/note-menu.vue: | |||||||
|   detail: "詳細" |   detail: "詳細" | ||||||
|   copy-link: "リンクをコピー" |   copy-link: "リンクをコピー" | ||||||
|   favorite: "お気に入り" |   favorite: "お気に入り" | ||||||
|  |   unfavorite: "お気に入り解除" | ||||||
|   pin: "ピン留め" |   pin: "ピン留め" | ||||||
|  |   unpin: "ピン留め解除" | ||||||
|   delete: "削除" |   delete: "削除" | ||||||
|   delete-confirm: "この投稿を削除しますか?" |   delete-confirm: "この投稿を削除しますか?" | ||||||
|   remote: "投稿元で見る" |   remote: "投稿元で見る" | ||||||
| @@ -379,6 +416,25 @@ common/views/components/visibility-chooser.vue: | |||||||
| common/views/components/trends.vue: | common/views/components/trends.vue: | ||||||
|   count: "{}人が投稿" |   count: "{}人が投稿" | ||||||
|   empty: "トレンドなし" |   empty: "トレンドなし" | ||||||
|  | common/views/components/profile-editor.vue: | ||||||
|  |   title: "プロフィール" | ||||||
|  |   name: "名前" | ||||||
|  |   account: "アカウント" | ||||||
|  |   location: "場所" | ||||||
|  |   description: "自己紹介" | ||||||
|  |   birthday: "誕生日" | ||||||
|  |   avatar: "アイコン" | ||||||
|  |   banner: "バナー" | ||||||
|  |   is-cat: "このアカウントはCatです" | ||||||
|  |   is-bot: "このアカウントはBotです" | ||||||
|  |   is-locked: "フォローを承認制にする" | ||||||
|  |   careful-bot: "Botからのフォローだけ承認制にする" | ||||||
|  |   advanced: "その他" | ||||||
|  |   privacy: "プライバシー" | ||||||
|  |   save: "保存" | ||||||
|  |   saved: "プロフィールを保存しました" | ||||||
|  |   uploading: "アップロード中" | ||||||
|  |   upload-failed: "アップロードに失敗しました" | ||||||
| common/views/widgets/broadcast.vue: | common/views/widgets/broadcast.vue: | ||||||
|   fetching: "確認中" |   fetching: "確認中" | ||||||
|   no-broadcasts: "お知らせはありません" |   no-broadcasts: "お知らせはありません" | ||||||
| @@ -439,6 +495,7 @@ common/views/pages/follow.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| desktop: | desktop: | ||||||
|   banner-crop-title: "バナーとして表示する部分を選択" |   banner-crop-title: "バナーとして表示する部分を選択" | ||||||
| @@ -477,13 +534,13 @@ desktop/views/components/charts.vue: | |||||||
|     notes: "投稿の増減 (統合)" |     notes: "投稿の増減 (統合)" | ||||||
|     local-notes: "投稿の増減 (ローカル)" |     local-notes: "投稿の増減 (ローカル)" | ||||||
|     remote-notes: "投稿の増減 (リモート)" |     remote-notes: "投稿の増減 (リモート)" | ||||||
|     notes-total: "投稿の累計" |     notes-total: "投稿の積算" | ||||||
|     users: "ユーザーの増減" |     users: "ユーザーの増減" | ||||||
|     users-total: "ユーザーの累計" |     users-total: "ユーザーの積算" | ||||||
|     drive: "ドライブ使用量の増減" |     drive: "ドライブ使用量の増減" | ||||||
|     drive-total: "ドライブ使用量の累計" |     drive-total: "ドライブ使用量の積算" | ||||||
|     drive-files: "ドライブのファイル数の増減" |     drive-files: "ドライブのファイル数の増減" | ||||||
|     drive-files-total: "ドライブのファイル数の累計" |     drive-files-total: "ドライブのファイル数の積算" | ||||||
|     network-requests: "リクエスト" |     network-requests: "リクエスト" | ||||||
|     network-time: "応答時間" |     network-time: "応答時間" | ||||||
|     network-usage: "通信量" |     network-usage: "通信量" | ||||||
| @@ -565,6 +622,7 @@ desktop/views/components/follow-button.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| desktop/views/components/followers-window.vue: | desktop/views/components/followers-window.vue: | ||||||
|   followers: "{} のフォロワー" |   followers: "{} のフォロワー" | ||||||
| @@ -601,7 +659,7 @@ desktop/views/components/note-detail.vue: | |||||||
|   location: "位置情報" |   location: "位置情報" | ||||||
|   renote: "Renote" |   renote: "Renote" | ||||||
|   add-reaction: "リアクション" |   add-reaction: "リアクション" | ||||||
| desktop/views/components/notes.note.vue: | desktop/views/components/note.vue: | ||||||
|   reposted-by: "{}がRenote" |   reposted-by: "{}がRenote" | ||||||
|   reply: "返信" |   reply: "返信" | ||||||
|   renote: "Renote" |   renote: "Renote" | ||||||
| @@ -675,6 +733,7 @@ desktop/views/components/settings.vue: | |||||||
|   2fa: "二段階認証" |   2fa: "二段階認証" | ||||||
|   other: "その他" |   other: "その他" | ||||||
|   license: "ライセンス" |   license: "ライセンス" | ||||||
|  |   theme: "テーマ" | ||||||
|   behaviour: "動作" |   behaviour: "動作" | ||||||
|   fetch-on-scroll: "スクロールで自動読み込み" |   fetch-on-scroll: "スクロールで自動読み込み" | ||||||
|   fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込みます。" |   fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込みます。" | ||||||
| @@ -686,30 +745,36 @@ desktop/views/components/settings.vue: | |||||||
|   advanced: "詳細設定" |   advanced: "詳細設定" | ||||||
|   api-via-stream: "ストリームを経由したAPIリクエスト" |   api-via-stream: "ストリームを経由したAPIリクエスト" | ||||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" |   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||||
|  |   deck-nav: "デッキ内ナビゲーション" | ||||||
|  |   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||||
|  |   deck-default: "デッキをデフォルトのUIにする" | ||||||
|   display: "デザインと表示" |   display: "デザインと表示" | ||||||
|   customize: "ホームをカスタマイズ" |   customize: "ホームをカスタマイズ" | ||||||
|  |   wallpaper: "壁紙" | ||||||
|   choose-wallpaper: "壁紙を選択" |   choose-wallpaper: "壁紙を選択" | ||||||
|   delete-wallpaper: "壁紙を削除" |   delete-wallpaper: "壁紙を削除" | ||||||
|   dark-mode: "ダークモード" |   dark-mode: "ダークモード" | ||||||
|  |   use-shadow: "UIに影を使用" | ||||||
|  |   rounded-corners: "UIの角を丸める" | ||||||
|   circle-icons: "円形のアイコンを使用" |   circle-icons: "円形のアイコンを使用" | ||||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" |   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" |  | ||||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" |   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" |   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||||
|   show-clock-on-header: "右上に時計を表示する" |   show-clock-on-header: "右上に時計を表示する" | ||||||
|   show-reply-target: "リプライ先を表示する" |   show-reply-target: "リプライ先を表示する" | ||||||
|  |   timeline: "タイムライン" | ||||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" |   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" |   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" |   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||||
|   show-maps: "マップの自動展開" |   show-maps: "マップの自動展開" | ||||||
|   show-maps-desc: "位置情報が添付された投稿のマップを自動的に展開します。" |   deck-column-align: "デッキのカラムの位置" | ||||||
|  |   deck-column-align-center: "中央" | ||||||
|  |   deck-column-align-left: "左" | ||||||
|   sound: "サウンド" |   sound: "サウンド" | ||||||
|   enable-sounds: "サウンドを有効にする" |   enable-sounds: "サウンドを有効にする" | ||||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" |   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||||
|   volume: "ボリューム" |   volume: "ボリューム" | ||||||
|   test: "テスト" |   test: "テスト" | ||||||
|   mobile: "モバイル" |  | ||||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" |  | ||||||
|   language: "言語" |   language: "言語" | ||||||
|   pick-language: "言語を選択" |   pick-language: "言語を選択" | ||||||
|   recommended: "推奨" |   recommended: "推奨" | ||||||
| @@ -745,6 +810,10 @@ desktop/views/components/settings.vue: | |||||||
|   tools: "ツール" |   tools: "ツール" | ||||||
|   task-manager: "タスクマネージャ" |   task-manager: "タスクマネージャ" | ||||||
|   third-parties: "サードパーティ" |   third-parties: "サードパーティ" | ||||||
|  |   navbar-position: "ナビゲーションバーの位置" | ||||||
|  |   navbar-position-top: "上" | ||||||
|  |   navbar-position-left: "左" | ||||||
|  |   navbar-position-right: "右" | ||||||
| desktop/views/components/settings.2fa.vue: | desktop/views/components/settings.2fa.vue: | ||||||
|   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" |   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" | ||||||
|   detail: "詳細..." |   detail: "詳細..." | ||||||
| @@ -784,20 +853,6 @@ desktop/views/components/settings.password.vue: | |||||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" |   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||||
|   not-match: "新しいパスワードが一致しません" |   not-match: "新しいパスワードが一致しません" | ||||||
|   changed: "パスワードを変更しました" |   changed: "パスワードを変更しました" | ||||||
| desktop/views/components/settings.profile.vue: |  | ||||||
|   avatar: "アイコン" |  | ||||||
|   choice-avatar: "画像を選択" |  | ||||||
|   name: "名前" |  | ||||||
|   location: "場所" |  | ||||||
|   description: "自己紹介" |  | ||||||
|   birthday: "誕生日" |  | ||||||
|   save: "保存" |  | ||||||
|   locked-account: "アカウントの保護" |  | ||||||
|   is-locked: "フォローを承認制にする" |  | ||||||
|   other: "その他" |  | ||||||
|   is-bot: "このアカウントはBotです" |  | ||||||
|   is-cat: "このアカウントはCatです" |  | ||||||
|   profile-updated: "プロフィールを更新しました" |  | ||||||
| desktop/views/components/sub-note-content.vue: | desktop/views/components/sub-note-content.vue: | ||||||
|   private: "この投稿は非公開です" |   private: "この投稿は非公開です" | ||||||
|   deleted: "この投稿は削除されました" |   deleted: "この投稿は削除されました" | ||||||
| @@ -896,10 +951,8 @@ desktop/views/pages/deck/deck.tl-column.vue: | |||||||
|   is-media-only: "メディア投稿のみ" |   is-media-only: "メディア投稿のみ" | ||||||
|   is-media-view: "メディアビュー" |   is-media-view: "メディアビュー" | ||||||
|   edit: "オプション" |   edit: "オプション" | ||||||
| desktop/views/pages/deck/deck.note.vue: | desktop/views/pages/deck/deck.user-column.vue: | ||||||
|   reposted-by: "{}がRenote" |   pinned-notes: "ピン留めされた投稿" | ||||||
|   private: "この投稿は非公開です" |  | ||||||
|   deleted: "この投稿は削除されました" |  | ||||||
| desktop/views/pages/stats/stats.vue: | desktop/views/pages/stats/stats.vue: | ||||||
|   all-users: "全てのユーザー" |   all-users: "全てのユーザー" | ||||||
|   original-users: "このインスタンスのユーザー" |   original-users: "このインスタンスのユーザー" | ||||||
| @@ -1034,6 +1087,8 @@ mobile/views/components/drive.file-detail.vue: | |||||||
|   hash: "ハッシュ (md5)" |   hash: "ハッシュ (md5)" | ||||||
|   exif: "EXIF" |   exif: "EXIF" | ||||||
|   nsfw: "閲覧注意" |   nsfw: "閲覧注意" | ||||||
|  |   mark-as-sensitive: "閲覧注意に設定" | ||||||
|  |   unmark-as-sensitive: "閲覧注意を解除" | ||||||
| mobile/views/components/media-image.vue: | mobile/views/components/media-image.vue: | ||||||
|   sensitive: "閲覧注意" |   sensitive: "閲覧注意" | ||||||
|   click-to-show: "クリックして表示" |   click-to-show: "クリックして表示" | ||||||
| @@ -1044,6 +1099,7 @@ mobile/views/components/follow-button.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| mobile/views/components/friends-maker.vue: | mobile/views/components/friends-maker.vue: | ||||||
|   title: "気になるユーザーをフォロー" |   title: "気になるユーザーをフォロー" | ||||||
| @@ -1173,23 +1229,6 @@ mobile/views/pages/notifications.vue: | |||||||
|   read-all: "すべての通知を既読にしますか?" |   read-all: "すべての通知を既読にしますか?" | ||||||
| mobile/views/pages/games/reversi.vue: | mobile/views/pages/games/reversi.vue: | ||||||
|   reversi: "リバーシ" |   reversi: "リバーシ" | ||||||
| mobile/views/pages/settings/settings.profile.vue: |  | ||||||
|   title: "プロフィール" |  | ||||||
|   name: "名前" |  | ||||||
|   account: "アカウント" |  | ||||||
|   location: "場所" |  | ||||||
|   description: "自己紹介" |  | ||||||
|   birthday: "誕生日" |  | ||||||
|   avatar: "アイコン" |  | ||||||
|   banner: "バナー" |  | ||||||
|   is-cat: "このアカウントはCatです" |  | ||||||
|   is-locked: "フォローを承認制にする" |  | ||||||
|   advanced: "その他" |  | ||||||
|   privacy: "プライバシー" |  | ||||||
|   save: "保存" |  | ||||||
|   saved: "プロフィールを保存しました" |  | ||||||
|   uploading: "アップロード中" |  | ||||||
|   upload-failed: "アップロードに失敗しました" |  | ||||||
| mobile/views/pages/search.vue: | mobile/views/pages/search.vue: | ||||||
|   search: "検索" |   search: "検索" | ||||||
|   empty: "「{}」に関する投稿は見つかりませんでした。" |   empty: "「{}」に関する投稿は見つかりませんでした。" | ||||||
| @@ -1219,6 +1258,7 @@ mobile/views/pages/settings.vue: | |||||||
|   notification-position: "通知の表示" |   notification-position: "通知の表示" | ||||||
|   notification-position-bottom: "下" |   notification-position-bottom: "下" | ||||||
|   notification-position-top: "上" |   notification-position-top: "上" | ||||||
|  |   theme: "テーマ" | ||||||
|   behavior: "動作" |   behavior: "動作" | ||||||
|   fetch-on-scroll: "スクロールで自動読み込み" |   fetch-on-scroll: "スクロールで自動読み込み" | ||||||
|   note-visibility: "投稿の公開範囲" |   note-visibility: "投稿の公開範囲" | ||||||
|   | |||||||
| @@ -264,6 +264,41 @@ common/views/components/connect-failed.troubleshooter.vue: | |||||||
| common/views/components/media-banner.vue: | common/views/components/media-banner.vue: | ||||||
|   sensitive: "閲覧注意" |   sensitive: "閲覧注意" | ||||||
|   click-to-show: "クリックして表示" |   click-to-show: "クリックして表示" | ||||||
|  | common/views/components/theme.vue: | ||||||
|  |   light-theme: "非ダークモード時に使用するテーマ" | ||||||
|  |   dark-theme: "ダークモード時に使用するテーマ" | ||||||
|  |   light-themes: "明るいテーマ" | ||||||
|  |   dark-themes: "暗いテーマ" | ||||||
|  |   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: "保存しました" | ||||||
|  |   manage-themes: "テーマの管理" | ||||||
|  |   builtin-themes: "標準テーマ" | ||||||
|  |   my-themes: "マイテーマ" | ||||||
|  |   installed-themes: "インストールされたテーマ" | ||||||
|  |   select-theme: "テーマを選択してください" | ||||||
|  |   uninstall: "アンインストール" | ||||||
|  |   uninstalled: "「{}」をアンインストールしました" | ||||||
|  |   author: "作者" | ||||||
|  |   desc: "説明" | ||||||
|  |   export: "エクスポート" | ||||||
|  |   import: "インポート" | ||||||
|  |   import-by-code: "またはコードをペースト" | ||||||
|  |   theme-name-required: "テーマ名は必須です。" | ||||||
| common/views/components/cw-button.vue: | common/views/components/cw-button.vue: | ||||||
|   hide: "隠す" |   hide: "隠す" | ||||||
|   show: "もっと見る" |   show: "もっと見る" | ||||||
| @@ -300,7 +335,9 @@ common/views/components/note-menu.vue: | |||||||
|   detail: "詳細" |   detail: "詳細" | ||||||
|   copy-link: "リンクをコピー" |   copy-link: "リンクをコピー" | ||||||
|   favorite: "お気に入り" |   favorite: "お気に入り" | ||||||
|  |   unfavorite: "お気に入り解除" | ||||||
|   pin: "ピン留め" |   pin: "ピン留め" | ||||||
|  |   unpin: "ピン留め解除" | ||||||
|   delete: "削除" |   delete: "削除" | ||||||
|   delete-confirm: "この投稿を削除しますか?" |   delete-confirm: "この投稿を削除しますか?" | ||||||
|   remote: "投稿元で見る" |   remote: "投稿元で見る" | ||||||
| @@ -379,6 +416,25 @@ common/views/components/visibility-chooser.vue: | |||||||
| common/views/components/trends.vue: | common/views/components/trends.vue: | ||||||
|   count: "{}人が投稿" |   count: "{}人が投稿" | ||||||
|   empty: "トレンドなし" |   empty: "トレンドなし" | ||||||
|  | common/views/components/profile-editor.vue: | ||||||
|  |   title: "プロフィール" | ||||||
|  |   name: "名前" | ||||||
|  |   account: "アカウント" | ||||||
|  |   location: "場所" | ||||||
|  |   description: "自己紹介" | ||||||
|  |   birthday: "誕生日" | ||||||
|  |   avatar: "アイコン" | ||||||
|  |   banner: "バナー" | ||||||
|  |   is-cat: "このアカウントはCatです" | ||||||
|  |   is-bot: "このアカウントはBotです" | ||||||
|  |   is-locked: "フォローを承認制にする" | ||||||
|  |   careful-bot: "Botからのフォローだけ承認制にする" | ||||||
|  |   advanced: "その他" | ||||||
|  |   privacy: "プライバシー" | ||||||
|  |   save: "保存" | ||||||
|  |   saved: "プロフィールを保存しました" | ||||||
|  |   uploading: "アップロード中" | ||||||
|  |   upload-failed: "アップロードに失敗しました" | ||||||
| common/views/widgets/broadcast.vue: | common/views/widgets/broadcast.vue: | ||||||
|   fetching: "確認中" |   fetching: "確認中" | ||||||
|   no-broadcasts: "お知らせはありません" |   no-broadcasts: "お知らせはありません" | ||||||
| @@ -439,6 +495,7 @@ common/views/pages/follow.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| desktop: | desktop: | ||||||
|   banner-crop-title: "バナーとして表示する部分を選択" |   banner-crop-title: "バナーとして表示する部分を選択" | ||||||
| @@ -477,13 +534,13 @@ desktop/views/components/charts.vue: | |||||||
|     notes: "投稿の増減 (統合)" |     notes: "投稿の増減 (統合)" | ||||||
|     local-notes: "投稿の増減 (ローカル)" |     local-notes: "投稿の増減 (ローカル)" | ||||||
|     remote-notes: "投稿の増減 (リモート)" |     remote-notes: "投稿の増減 (リモート)" | ||||||
|     notes-total: "投稿の累計" |     notes-total: "投稿の積算" | ||||||
|     users: "ユーザーの増減" |     users: "ユーザーの増減" | ||||||
|     users-total: "ユーザーの累計" |     users-total: "ユーザーの積算" | ||||||
|     drive: "ドライブ使用量の増減" |     drive: "ドライブ使用量の増減" | ||||||
|     drive-total: "ドライブ使用量の累計" |     drive-total: "ドライブ使用量の積算" | ||||||
|     drive-files: "ドライブのファイル数の増減" |     drive-files: "ドライブのファイル数の増減" | ||||||
|     drive-files-total: "ドライブのファイル数の累計" |     drive-files-total: "ドライブのファイル数の積算" | ||||||
|     network-requests: "リクエスト" |     network-requests: "リクエスト" | ||||||
|     network-time: "応答時間" |     network-time: "応答時間" | ||||||
|     network-usage: "通信量" |     network-usage: "通信量" | ||||||
| @@ -565,6 +622,7 @@ desktop/views/components/follow-button.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| desktop/views/components/followers-window.vue: | desktop/views/components/followers-window.vue: | ||||||
|   followers: "{} のフォロワー" |   followers: "{} のフォロワー" | ||||||
| @@ -601,7 +659,7 @@ desktop/views/components/note-detail.vue: | |||||||
|   location: "位置情報" |   location: "位置情報" | ||||||
|   renote: "Renote" |   renote: "Renote" | ||||||
|   add-reaction: "リアクション" |   add-reaction: "リアクション" | ||||||
| desktop/views/components/notes.note.vue: | desktop/views/components/note.vue: | ||||||
|   reposted-by: "{}がRenote" |   reposted-by: "{}がRenote" | ||||||
|   reply: "返信" |   reply: "返信" | ||||||
|   renote: "Renote" |   renote: "Renote" | ||||||
| @@ -675,6 +733,7 @@ desktop/views/components/settings.vue: | |||||||
|   2fa: "二段階認証" |   2fa: "二段階認証" | ||||||
|   other: "その他" |   other: "その他" | ||||||
|   license: "ライセンス" |   license: "ライセンス" | ||||||
|  |   theme: "テーマ" | ||||||
|   behaviour: "動作" |   behaviour: "動作" | ||||||
|   fetch-on-scroll: "スクロールで自動読み込み" |   fetch-on-scroll: "スクロールで自動読み込み" | ||||||
|   fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込みます。" |   fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込みます。" | ||||||
| @@ -686,30 +745,36 @@ desktop/views/components/settings.vue: | |||||||
|   advanced: "詳細設定" |   advanced: "詳細設定" | ||||||
|   api-via-stream: "ストリームを経由したAPIリクエスト" |   api-via-stream: "ストリームを経由したAPIリクエスト" | ||||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" |   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||||
|  |   deck-nav: "デッキ内ナビゲーション" | ||||||
|  |   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||||
|  |   deck-default: "デッキをデフォルトのUIにする" | ||||||
|   display: "デザインと表示" |   display: "デザインと表示" | ||||||
|   customize: "ホームをカスタマイズ" |   customize: "ホームをカスタマイズ" | ||||||
|  |   wallpaper: "壁紙" | ||||||
|   choose-wallpaper: "壁紙を選択" |   choose-wallpaper: "壁紙を選択" | ||||||
|   delete-wallpaper: "壁紙を削除" |   delete-wallpaper: "壁紙を削除" | ||||||
|   dark-mode: "ダークモード" |   dark-mode: "ダークモード" | ||||||
|  |   use-shadow: "UIに影を使用" | ||||||
|  |   rounded-corners: "UIの角を丸める" | ||||||
|   circle-icons: "円形のアイコンを使用" |   circle-icons: "円形のアイコンを使用" | ||||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" |   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" |  | ||||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" |   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" |   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||||
|   show-clock-on-header: "右上に時計を表示する" |   show-clock-on-header: "右上に時計を表示する" | ||||||
|   show-reply-target: "リプライ先を表示する" |   show-reply-target: "リプライ先を表示する" | ||||||
|  |   timeline: "タイムライン" | ||||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" |   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" |   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" |   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||||
|   show-maps: "マップの自動展開" |   show-maps: "マップの自動展開" | ||||||
|   show-maps-desc: "位置情報が添付された投稿のマップを自動的に展開します。" |   deck-column-align: "デッキのカラムの位置" | ||||||
|  |   deck-column-align-center: "中央" | ||||||
|  |   deck-column-align-left: "左" | ||||||
|   sound: "サウンド" |   sound: "サウンド" | ||||||
|   enable-sounds: "サウンドを有効にする" |   enable-sounds: "サウンドを有効にする" | ||||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" |   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||||
|   volume: "ボリューム" |   volume: "ボリューム" | ||||||
|   test: "テスト" |   test: "テスト" | ||||||
|   mobile: "モバイル" |  | ||||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" |  | ||||||
|   language: "言語" |   language: "言語" | ||||||
|   pick-language: "言語を選択" |   pick-language: "言語を選択" | ||||||
|   recommended: "推奨" |   recommended: "推奨" | ||||||
| @@ -745,6 +810,10 @@ desktop/views/components/settings.vue: | |||||||
|   tools: "ツール" |   tools: "ツール" | ||||||
|   task-manager: "タスクマネージャ" |   task-manager: "タスクマネージャ" | ||||||
|   third-parties: "サードパーティ" |   third-parties: "サードパーティ" | ||||||
|  |   navbar-position: "ナビゲーションバーの位置" | ||||||
|  |   navbar-position-top: "上" | ||||||
|  |   navbar-position-left: "左" | ||||||
|  |   navbar-position-right: "右" | ||||||
| desktop/views/components/settings.2fa.vue: | desktop/views/components/settings.2fa.vue: | ||||||
|   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" |   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" | ||||||
|   detail: "詳細..." |   detail: "詳細..." | ||||||
| @@ -784,20 +853,6 @@ desktop/views/components/settings.password.vue: | |||||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" |   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||||
|   not-match: "新しいパスワードが一致しません" |   not-match: "新しいパスワードが一致しません" | ||||||
|   changed: "パスワードを変更しました" |   changed: "パスワードを変更しました" | ||||||
| desktop/views/components/settings.profile.vue: |  | ||||||
|   avatar: "アイコン" |  | ||||||
|   choice-avatar: "画像を選択" |  | ||||||
|   name: "名前" |  | ||||||
|   location: "場所" |  | ||||||
|   description: "自己紹介" |  | ||||||
|   birthday: "誕生日" |  | ||||||
|   save: "保存" |  | ||||||
|   locked-account: "アカウントの保護" |  | ||||||
|   is-locked: "フォローを承認制にする" |  | ||||||
|   other: "その他" |  | ||||||
|   is-bot: "このアカウントはBotです" |  | ||||||
|   is-cat: "このアカウントはCatです" |  | ||||||
|   profile-updated: "プロフィールを更新しました" |  | ||||||
| desktop/views/components/sub-note-content.vue: | desktop/views/components/sub-note-content.vue: | ||||||
|   private: "この投稿は非公開です" |   private: "この投稿は非公開です" | ||||||
|   deleted: "この投稿は削除されました" |   deleted: "この投稿は削除されました" | ||||||
| @@ -896,10 +951,8 @@ desktop/views/pages/deck/deck.tl-column.vue: | |||||||
|   is-media-only: "メディア投稿のみ" |   is-media-only: "メディア投稿のみ" | ||||||
|   is-media-view: "メディアビュー" |   is-media-view: "メディアビュー" | ||||||
|   edit: "オプション" |   edit: "オプション" | ||||||
| desktop/views/pages/deck/deck.note.vue: | desktop/views/pages/deck/deck.user-column.vue: | ||||||
|   reposted-by: "{}がRenote" |   pinned-notes: "ピン留めされた投稿" | ||||||
|   private: "この投稿は非公開です" |  | ||||||
|   deleted: "この投稿は削除されました" |  | ||||||
| desktop/views/pages/stats/stats.vue: | desktop/views/pages/stats/stats.vue: | ||||||
|   all-users: "全てのユーザー" |   all-users: "全てのユーザー" | ||||||
|   original-users: "このインスタンスのユーザー" |   original-users: "このインスタンスのユーザー" | ||||||
| @@ -1034,6 +1087,8 @@ mobile/views/components/drive.file-detail.vue: | |||||||
|   hash: "ハッシュ (md5)" |   hash: "ハッシュ (md5)" | ||||||
|   exif: "EXIF" |   exif: "EXIF" | ||||||
|   nsfw: "閲覧注意" |   nsfw: "閲覧注意" | ||||||
|  |   mark-as-sensitive: "閲覧注意に設定" | ||||||
|  |   unmark-as-sensitive: "閲覧注意を解除" | ||||||
| mobile/views/components/media-image.vue: | mobile/views/components/media-image.vue: | ||||||
|   sensitive: "閲覧注意" |   sensitive: "閲覧注意" | ||||||
|   click-to-show: "クリックして表示" |   click-to-show: "クリックして表示" | ||||||
| @@ -1044,6 +1099,7 @@ mobile/views/components/follow-button.vue: | |||||||
|   following: "フォロー中" |   following: "フォロー中" | ||||||
|   follow: "フォロー" |   follow: "フォロー" | ||||||
|   request-pending: "フォロー許可待ち" |   request-pending: "フォロー許可待ち" | ||||||
|  |   follow-processing: "フォロー処理中" | ||||||
|   follow-request: "フォロー申請" |   follow-request: "フォロー申請" | ||||||
| mobile/views/components/friends-maker.vue: | mobile/views/components/friends-maker.vue: | ||||||
|   title: "気になるユーザーをフォロー" |   title: "気になるユーザーをフォロー" | ||||||
| @@ -1173,23 +1229,6 @@ mobile/views/pages/notifications.vue: | |||||||
|   read-all: "すべての通知を既読にしますか?" |   read-all: "すべての通知を既読にしますか?" | ||||||
| mobile/views/pages/games/reversi.vue: | mobile/views/pages/games/reversi.vue: | ||||||
|   reversi: "リバーシ" |   reversi: "リバーシ" | ||||||
| mobile/views/pages/settings/settings.profile.vue: |  | ||||||
|   title: "プロフィール" |  | ||||||
|   name: "名前" |  | ||||||
|   account: "アカウント" |  | ||||||
|   location: "場所" |  | ||||||
|   description: "自己紹介" |  | ||||||
|   birthday: "誕生日" |  | ||||||
|   avatar: "アイコン" |  | ||||||
|   banner: "バナー" |  | ||||||
|   is-cat: "このアカウントはCatです" |  | ||||||
|   is-locked: "フォローを承認制にする" |  | ||||||
|   advanced: "その他" |  | ||||||
|   privacy: "プライバシー" |  | ||||||
|   save: "保存" |  | ||||||
|   saved: "プロフィールを保存しました" |  | ||||||
|   uploading: "アップロード中" |  | ||||||
|   upload-failed: "アップロードに失敗しました" |  | ||||||
| mobile/views/pages/search.vue: | mobile/views/pages/search.vue: | ||||||
|   search: "検索" |   search: "検索" | ||||||
|   empty: "「{}」に関する投稿は見つかりませんでした。" |   empty: "「{}」に関する投稿は見つかりませんでした。" | ||||||
| @@ -1219,6 +1258,7 @@ mobile/views/pages/settings.vue: | |||||||
|   notification-position: "通知の表示" |   notification-position: "通知の表示" | ||||||
|   notification-position-bottom: "下" |   notification-position-bottom: "下" | ||||||
|   notification-position-top: "上" |   notification-position-top: "上" | ||||||
|  |   theme: "テーマ" | ||||||
|   behavior: "動作" |   behavior: "動作" | ||||||
|   fetch-on-scroll: "スクロールで自動読み込み" |   fetch-on-scroll: "スクロールで自動読み込み" | ||||||
|   note-visibility: "投稿の公開範囲" |   note-visibility: "投稿の公開範囲" | ||||||
|   | |||||||
							
								
								
									
										95
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										95
									
								
								package.json
									
									
									
									
									
								
							| @@ -1,8 +1,8 @@ | |||||||
| { | { | ||||||
| 	"name": "misskey", | 	"name": "misskey", | ||||||
| 	"author": "syuilo <i@syuilo.com>", | 	"author": "syuilo <i@syuilo.com>", | ||||||
| 	"version": "8.56.0", | 	"version": "10.28.0", | ||||||
| 	"clientVersion": "1.0.9912", | 	"clientVersion": "1.0.10776", | ||||||
| 	"codename": "nighthike", | 	"codename": "nighthike", | ||||||
| 	"main": "./built/index.js", | 	"main": "./built/index.js", | ||||||
| 	"private": true, | 	"private": true, | ||||||
| @@ -20,26 +20,27 @@ | |||||||
| 		"format": "gulp format" | 		"format": "gulp format" | ||||||
| 	}, | 	}, | ||||||
| 	"dependencies": { | 	"dependencies": { | ||||||
| 		"@fortawesome/fontawesome-svg-core": "1.2.4", | 		"@fortawesome/fontawesome-svg-core": "1.2.6", | ||||||
| 		"@fortawesome/free-brands-svg-icons": "5.3.1", | 		"@fortawesome/free-brands-svg-icons": "5.4.1", | ||||||
| 		"@fortawesome/free-regular-svg-icons": "5.3.1", | 		"@fortawesome/free-regular-svg-icons": "5.4.1", | ||||||
| 		"@fortawesome/free-solid-svg-icons": "5.3.1", | 		"@fortawesome/free-solid-svg-icons": "5.4.1", | ||||||
| 		"@koa/cors": "2.2.2", | 		"@koa/cors": "2.2.2", | ||||||
| 		"@prezzemolo/rap": "0.1.2", | 		"@prezzemolo/rap": "0.1.2", | ||||||
| 		"@prezzemolo/zip": "0.0.3", | 		"@prezzemolo/zip": "0.0.3", | ||||||
| 		"@types/bcryptjs": "2.4.1", | 		"@types/bcryptjs": "2.4.2", | ||||||
|  | 		"@types/chai-http": "3.0.5", | ||||||
| 		"@types/dateformat": "1.0.1", | 		"@types/dateformat": "1.0.1", | ||||||
| 		"@types/debug": "0.0.30", | 		"@types/debug": "0.0.31", | ||||||
| 		"@types/deep-equal": "1.0.1", | 		"@types/deep-equal": "1.0.1", | ||||||
| 		"@types/double-ended-queue": "2.1.0", | 		"@types/double-ended-queue": "2.1.0", | ||||||
| 		"@types/elasticsearch": "5.0.26", | 		"@types/elasticsearch": "5.0.28", | ||||||
| 		"@types/file-type": "5.2.1", | 		"@types/file-type": "5.2.1", | ||||||
| 		"@types/gulp": "3.8.36", | 		"@types/gulp": "3.8.36", | ||||||
| 		"@types/gulp-htmlmin": "1.3.32", | 		"@types/gulp-htmlmin": "1.3.32", | ||||||
| 		"@types/gulp-mocha": "0.0.32", | 		"@types/gulp-mocha": "0.0.32", | ||||||
| 		"@types/gulp-rename": "0.0.33", | 		"@types/gulp-rename": "0.0.33", | ||||||
| 		"@types/gulp-replace": "0.0.31", | 		"@types/gulp-replace": "0.0.31", | ||||||
| 		"@types/gulp-uglify": "3.0.5", | 		"@types/gulp-uglify": "3.0.6", | ||||||
| 		"@types/gulp-util": "3.0.34", | 		"@types/gulp-util": "3.0.34", | ||||||
| 		"@types/is-root": "1.0.0", | 		"@types/is-root": "1.0.0", | ||||||
| 		"@types/is-url": "1.2.28", | 		"@types/is-url": "1.2.28", | ||||||
| @@ -48,56 +49,60 @@ | |||||||
| 		"@types/koa-bodyparser": "5.0.1", | 		"@types/koa-bodyparser": "5.0.1", | ||||||
| 		"@types/koa-compress": "2.0.8", | 		"@types/koa-compress": "2.0.8", | ||||||
| 		"@types/koa-favicon": "2.0.19", | 		"@types/koa-favicon": "2.0.19", | ||||||
| 		"@types/koa-logger": "3.1.0", | 		"@types/koa-logger": "3.1.1", | ||||||
| 		"@types/koa-mount": "3.0.1", | 		"@types/koa-mount": "3.0.1", | ||||||
| 		"@types/koa-multer": "1.0.0", | 		"@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-send": "4.1.1", | ||||||
| 		"@types/koa-views": "2.0.3", | 		"@types/koa-views": "2.0.3", | ||||||
| 		"@types/koa__cors": "2.2.3", | 		"@types/koa__cors": "2.2.3", | ||||||
| 		"@types/minio": "7.0.0", | 		"@types/minio": "7.0.0", | ||||||
| 		"@types/mkdirp": "0.5.2", | 		"@types/mkdirp": "0.5.2", | ||||||
| 		"@types/mocha": "5.2.3", | 		"@types/mocha": "5.2.3", | ||||||
| 		"@types/mongodb": "3.1.7", | 		"@types/mongodb": "3.1.12", | ||||||
| 		"@types/ms": "0.7.30", | 		"@types/ms": "0.7.30", | ||||||
| 		"@types/node": "10.10.1", | 		"@types/node": "10.12.0", | ||||||
| 		"@types/portscanner": "2.1.0", | 		"@types/portscanner": "2.1.0", | ||||||
| 		"@types/pug": "2.0.4", | 		"@types/pug": "2.0.4", | ||||||
| 		"@types/qrcode": "1.2.0", | 		"@types/qrcode": "1.3.0", | ||||||
| 		"@types/ratelimiter": "2.1.28", | 		"@types/ratelimiter": "2.1.28", | ||||||
| 		"@types/redis": "2.8.6", | 		"@types/redis": "2.8.7", | ||||||
| 		"@types/request": "2.47.1", | 		"@types/request": "2.47.1", | ||||||
| 		"@types/request-promise-native": "1.0.15", | 		"@types/request-promise-native": "1.0.15", | ||||||
| 		"@types/rimraf": "2.0.2", | 		"@types/rimraf": "2.0.2", | ||||||
| 		"@types/seedrandom": "2.4.27", | 		"@types/seedrandom": "2.4.27", | ||||||
| 		"@types/sharp": "0.17.10", | 		"@types/sharp": "0.21.0", | ||||||
| 		"@types/showdown": "1.7.5", | 		"@types/showdown": "1.7.5", | ||||||
| 		"@types/single-line-log": "1.1.0", | 		"@types/single-line-log": "1.1.0", | ||||||
| 		"@types/speakeasy": "2.0.2", | 		"@types/speakeasy": "2.0.2", | ||||||
| 		"@types/systeminformation": "3.23.0", | 		"@types/systeminformation": "3.23.0", | ||||||
|  | 		"@types/tinycolor2": "1.4.1", | ||||||
| 		"@types/tmp": "0.0.33", | 		"@types/tmp": "0.0.33", | ||||||
| 		"@types/uuid": "3.4.4", | 		"@types/uuid": "3.4.4", | ||||||
| 		"@types/webpack": "4.4.11", | 		"@types/webpack": "4.4.17", | ||||||
| 		"@types/webpack-stream": "3.2.10", | 		"@types/webpack-stream": "3.2.10", | ||||||
| 		"@types/websocket": "0.0.40", | 		"@types/websocket": "0.0.40", | ||||||
| 		"@types/ws": "6.0.1", | 		"@types/ws": "6.0.1", | ||||||
| 		"animejs": "2.2.0", | 		"animejs": "2.2.0", | ||||||
|  | 		"autobind-decorator": "2.1.0", | ||||||
| 		"autosize": "4.0.2", | 		"autosize": "4.0.2", | ||||||
| 		"autwh": "0.1.0", | 		"autwh": "0.1.0", | ||||||
| 		"bcryptjs": "2.4.3", | 		"bcryptjs": "2.4.3", | ||||||
| 		"bee-queue": "1.2.2", | 		"bee-queue": "1.2.2", | ||||||
| 		"bootstrap-vue": "2.0.0-rc.11", | 		"bootstrap-vue": "2.0.0-rc.11", | ||||||
| 		"cafy": "11.3.0", | 		"cafy": "11.3.0", | ||||||
|  | 		"chai": "4.2.0", | ||||||
|  | 		"chai-http": "4.2.0", | ||||||
| 		"chalk": "2.4.1", | 		"chalk": "2.4.1", | ||||||
| 		"chart.js": "2.7.2", | 		"chart.js": "2.7.3", | ||||||
| 		"commander": "2.17.1", | 		"commander": "2.19.0", | ||||||
| 		"crc-32": "1.2.0", | 		"crc-32": "1.2.0", | ||||||
| 		"css-loader": "1.0.0", | 		"css-loader": "1.0.0", | ||||||
| 		"dateformat": "3.0.3", | 		"dateformat": "3.0.3", | ||||||
| 		"debug": "4.0.1", | 		"debug": "4.1.0", | ||||||
| 		"deep-equal": "1.0.1", | 		"deep-equal": "1.0.1", | ||||||
| 		"deepcopy": "0.6.3", | 		"deepcopy": "0.6.3", | ||||||
| 		"diskusage": "0.2.4", | 		"diskusage": "0.2.5", | ||||||
| 		"dompurify": "1.0.5", | 		"dompurify": "1.0.5", | ||||||
| 		"double-ended-queue": "2.1.0-0", | 		"double-ended-queue": "2.1.0-0", | ||||||
| 		"elasticsearch": "15.1.1", | 		"elasticsearch": "15.1.1", | ||||||
| @@ -107,12 +112,12 @@ | |||||||
| 		"eslint-plugin-vue": "4.7.1", | 		"eslint-plugin-vue": "4.7.1", | ||||||
| 		"eventemitter3": "3.1.0", | 		"eventemitter3": "3.1.0", | ||||||
| 		"exif-js": "2.3.0", | 		"exif-js": "2.3.0", | ||||||
| 		"file-loader": "1.1.11", | 		"file-loader": "2.0.0", | ||||||
| 		"file-type": "9.0.0", | 		"file-type": "10.0.0", | ||||||
| 		"fuckadblock": "3.2.1", | 		"fuckadblock": "3.2.1", | ||||||
| 		"gulp": "3.9.1", | 		"gulp": "3.9.1", | ||||||
| 		"gulp-cssnano": "2.1.3", | 		"gulp-cssnano": "2.1.3", | ||||||
| 		"gulp-htmlmin": "4.0.0", | 		"gulp-htmlmin": "5.0.1", | ||||||
| 		"gulp-imagemin": "4.1.0", | 		"gulp-imagemin": "4.1.0", | ||||||
| 		"gulp-mocha": "6.0.0", | 		"gulp-mocha": "6.0.0", | ||||||
| 		"gulp-pug": "4.0.1", | 		"gulp-pug": "4.0.1", | ||||||
| @@ -132,14 +137,16 @@ | |||||||
| 		"is-root": "2.0.0", | 		"is-root": "2.0.0", | ||||||
| 		"is-url": "1.2.4", | 		"is-url": "1.2.4", | ||||||
| 		"js-yaml": "3.12.0", | 		"js-yaml": "3.12.0", | ||||||
| 		"jsdom": "11.12.0", | 		"jsdom": "12.2.0", | ||||||
|  | 		"json5": "2.1.0", | ||||||
|  | 		"json5-loader": "1.0.1", | ||||||
| 		"koa": "2.5.1", | 		"koa": "2.5.1", | ||||||
| 		"koa-bodyparser": "4.2.1", | 		"koa-bodyparser": "4.2.1", | ||||||
| 		"koa-compress": "3.0.0", | 		"koa-compress": "3.0.0", | ||||||
| 		"koa-favicon": "2.0.1", | 		"koa-favicon": "2.0.1", | ||||||
| 		"koa-json-body": "5.3.0", | 		"koa-json-body": "5.3.0", | ||||||
| 		"koa-logger": "3.2.0", | 		"koa-logger": "3.2.0", | ||||||
| 		"koa-mount": "3.0.0", | 		"koa-mount": "4.0.0", | ||||||
| 		"koa-multer": "1.0.2", | 		"koa-multer": "1.0.2", | ||||||
| 		"koa-router": "7.4.0", | 		"koa-router": "7.4.0", | ||||||
| 		"koa-send": "5.0.0", | 		"koa-send": "5.0.0", | ||||||
| @@ -153,10 +160,10 @@ | |||||||
| 		"mkdirp": "0.5.1", | 		"mkdirp": "0.5.1", | ||||||
| 		"mocha": "5.2.0", | 		"mocha": "5.2.0", | ||||||
| 		"moji": "0.5.1", | 		"moji": "0.5.1", | ||||||
| 		"mongodb": "3.1.1", | 		"mongodb": "3.1.8", | ||||||
| 		"monk": "6.0.6", | 		"monk": "6.0.6", | ||||||
| 		"ms": "2.1.1", | 		"ms": "2.1.1", | ||||||
| 		"nan": "2.11.0", | 		"nan": "2.11.1", | ||||||
| 		"nested-property": "0.0.7", | 		"nested-property": "0.0.7", | ||||||
| 		"nprogress": "0.2.0", | 		"nprogress": "0.2.0", | ||||||
| 		"object-assign-deep": "0.4.0", | 		"object-assign-deep": "0.4.0", | ||||||
| @@ -165,13 +172,14 @@ | |||||||
| 		"parse5": "5.1.0", | 		"parse5": "5.1.0", | ||||||
| 		"portscanner": "2.2.0", | 		"portscanner": "2.2.0", | ||||||
| 		"progress-bar-webpack-plugin": "1.11.0", | 		"progress-bar-webpack-plugin": "1.11.0", | ||||||
|  | 		"promise-limit": "2.7.0", | ||||||
| 		"promise-sequential": "1.1.1", | 		"promise-sequential": "1.1.1", | ||||||
| 		"pug": "2.0.3", | 		"pug": "2.0.3", | ||||||
| 		"punycode": "2.1.1", | 		"punycode": "2.1.1", | ||||||
| 		"qrcode": "1.2.2", | 		"qrcode": "1.3.0", | ||||||
| 		"ratelimiter": "3.2.0", | 		"ratelimiter": "3.2.0", | ||||||
| 		"recaptcha-promise": "0.1.3", | 		"recaptcha-promise": "0.1.3", | ||||||
| 		"reconnecting-websocket": "3.2.2", | 		"reconnecting-websocket": "4.1.10", | ||||||
| 		"redis": "2.8.0", | 		"redis": "2.8.0", | ||||||
| 		"request": "2.88.0", | 		"request": "2.88.0", | ||||||
| 		"request-promise-native": "1.0.5", | 		"request-promise-native": "1.0.5", | ||||||
| @@ -181,37 +189,42 @@ | |||||||
| 		"s-age": "1.1.2", | 		"s-age": "1.1.2", | ||||||
| 		"sass-loader": "7.1.0", | 		"sass-loader": "7.1.0", | ||||||
| 		"seedrandom": "2.4.4", | 		"seedrandom": "2.4.4", | ||||||
| 		"sharp": "0.20.7", | 		"sharp": "0.21.0", | ||||||
| 		"showdown": "1.8.6", | 		"showdown": "1.8.7", | ||||||
| 		"showdown-highlightjs-extension": "0.1.2", | 		"showdown-highlightjs-extension": "0.1.2", | ||||||
| 		"single-line-log": "1.1.2", | 		"single-line-log": "1.1.2", | ||||||
| 		"speakeasy": "2.0.0", | 		"speakeasy": "2.0.0", | ||||||
| 		"stringz": "1.0.0", | 		"stringz": "1.0.0", | ||||||
| 		"style-loader": "0.23.0", | 		"style-loader": "0.23.1", | ||||||
| 		"stylus": "0.54.5", | 		"stylus": "0.54.5", | ||||||
| 		"stylus-loader": "3.0.2", | 		"stylus-loader": "3.0.2", | ||||||
| 		"summaly": "2.2.0", | 		"summaly": "2.2.0", | ||||||
| 		"systeminformation": "3.45.6", | 		"systeminformation": "3.45.7", | ||||||
| 		"syuilo-password-strength": "0.0.1", | 		"syuilo-password-strength": "0.0.1", | ||||||
| 		"textarea-caret": "3.1.0", | 		"textarea-caret": "3.1.0", | ||||||
|  | 		"tinycolor2": "1.4.1", | ||||||
| 		"tmp": "0.0.33", | 		"tmp": "0.0.33", | ||||||
| 		"ts-loader": "4.4.1", | 		"ts-loader": "4.4.1", | ||||||
| 		"ts-node": "7.0.1", | 		"ts-node": "7.0.1", | ||||||
| 		"tslint": "5.10.0", | 		"tslint": "5.10.0", | ||||||
| 		"typescript": "2.9.2", | 		"typescript": "2.9.2", | ||||||
| 		"typescript-eslint-parser": "18.0.0", | 		"typescript-eslint-parser": "20.0.0", | ||||||
| 		"uglify-es": "3.3.9", | 		"uglify-es": "3.3.9", | ||||||
| 		"url-loader": "1.1.1", | 		"url-loader": "1.1.2", | ||||||
| 		"uuid": "3.3.2", | 		"uuid": "3.3.2", | ||||||
| 		"v-animate-css": "0.0.2", | 		"v-animate-css": "0.0.2", | ||||||
| 		"vue": "2.5.17", | 		"vue": "2.5.17", | ||||||
| 		"vue-chartjs": "3.4.0", | 		"vue-chartjs": "3.4.0", | ||||||
|  | 		"vue-color": "2.7.0", | ||||||
|  | 		"vue-content-loading": "1.5.3", | ||||||
| 		"vue-cropperjs": "2.2.2", | 		"vue-cropperjs": "2.2.2", | ||||||
| 		"vue-js-modal": "1.3.26", | 		"vue-js-modal": "1.3.26", | ||||||
| 		"vue-json-tree-view": "2.1.4", | 		"vue-json-tree-view": "2.1.4", | ||||||
| 		"vue-loader": "15.4.2", | 		"vue-loader": "15.4.2", | ||||||
| 		"vue-router": "3.0.1", | 		"vue-router": "3.0.1", | ||||||
| 		"vue-style-loader": "4.1.2", | 		"vue-style-loader": "4.1.2", | ||||||
|  | 		"vue-svg-inline-loader": "1.2.1", | ||||||
|  | 		"vue-sweetalert2": "1.5.6", | ||||||
| 		"vue-template-compiler": "2.5.17", | 		"vue-template-compiler": "2.5.17", | ||||||
| 		"vuedraggable": "2.16.0", | 		"vuedraggable": "2.16.0", | ||||||
| 		"vuewordcloud": "18.7.11", | 		"vuewordcloud": "18.7.11", | ||||||
| @@ -219,10 +232,10 @@ | |||||||
| 		"vuex-persistedstate": "2.5.4", | 		"vuex-persistedstate": "2.5.4", | ||||||
| 		"web-push": "3.3.3", | 		"web-push": "3.3.3", | ||||||
| 		"webfinger.js": "2.6.6", | 		"webfinger.js": "2.6.6", | ||||||
| 		"webpack": "4.19.1", | 		"webpack": "4.21.0", | ||||||
| 		"webpack-cli": "3.1.0", | 		"webpack-cli": "3.1.2", | ||||||
| 		"websocket": "1.0.26", | 		"websocket": "1.0.28", | ||||||
| 		"ws": "6.0.0", | 		"ws": "6.1.0", | ||||||
| 		"xev": "2.0.1" | 		"xev": "2.0.1" | ||||||
| 	}, | 	}, | ||||||
| 	"greenkeeper": { | 	"greenkeeper": { | ||||||
|   | |||||||
| @@ -27,7 +27,7 @@ body | |||||||
| 	z-index 65536 | 	z-index 65536 | ||||||
|  |  | ||||||
| 	.bar | 	.bar | ||||||
| 		background $theme-color | 		background var(--primary) | ||||||
|  |  | ||||||
| 		position fixed | 		position fixed | ||||||
| 		z-index 65537 | 		z-index 65537 | ||||||
| @@ -44,7 +44,7 @@ body | |||||||
| 		right 0px | 		right 0px | ||||||
| 		width 100px | 		width 100px | ||||||
| 		height 100% | 		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 | 		opacity 1 | ||||||
|  |  | ||||||
| 		transform rotate(3deg) translate(0px, -4px) | 		transform rotate(3deg) translate(0px, -4px) | ||||||
| @@ -64,8 +64,8 @@ body | |||||||
| 		box-sizing border-box | 		box-sizing border-box | ||||||
|  |  | ||||||
| 		border solid 2px transparent | 		border solid 2px transparent | ||||||
| 		border-top-color $theme-color | 		border-top-color var(--primary) | ||||||
| 		border-left-color $theme-color | 		border-left-color var(--primary) | ||||||
| 		border-radius 50% | 		border-radius 50% | ||||||
|  |  | ||||||
| 		animation progress-spinner 400ms linear infinite | 		animation progress-spinner 400ms linear infinite | ||||||
| @@ -130,3 +130,29 @@ pre | |||||||
|  |  | ||||||
| [data-fa] | [data-fa] | ||||||
| 	display inline-block | 	display inline-block | ||||||
|  |  | ||||||
|  | .swal2-container | ||||||
|  | 	z-index 10000 !important | ||||||
|  |  | ||||||
|  | 	&.swal2-shown | ||||||
|  | 		background-color rgba(0, 0, 0, 0.5) !important | ||||||
|  |  | ||||||
|  | .swal2-popup | ||||||
|  | 	background var(--face) !important | ||||||
|  |  | ||||||
|  | .swal2-content | ||||||
|  | 	color var(--text) !important | ||||||
|  |  | ||||||
|  | .swal2-confirm | ||||||
|  | 	background-color var(--primary) !important | ||||||
|  | 	border-left-color var(--primary) !important | ||||||
|  | 	border-right-color var(--primary) !important | ||||||
|  | 	color var(--primaryForeground) !important | ||||||
|  |  | ||||||
|  | 	&:hover | ||||||
|  | 		background-image none !important | ||||||
|  | 		background-color var(--primaryDarken5) !important | ||||||
|  |  | ||||||
|  | 	&:active | ||||||
|  | 		background-image none !important | ||||||
|  | 		background-color var(--primaryDarken5) !important | ||||||
|   | |||||||
| @@ -10,7 +10,8 @@ export default Vue.extend({ | |||||||
| 	computed: { | 	computed: { | ||||||
| 		keymap(): any { | 		keymap(): any { | ||||||
| 			return { | 			return { | ||||||
| 				'h|slash': this.help | 				'h|slash': this.help, | ||||||
|  | 				'd': this.dark | ||||||
| 			}; | 			}; | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| @@ -18,6 +19,13 @@ export default Vue.extend({ | |||||||
| 	methods: { | 	methods: { | ||||||
| 		help() { | 		help() { | ||||||
| 			window.open(`${url}/docs/${lang}/keyboard-shortcut`, '_blank'); | 			window.open(`${url}/docs/${lang}/keyboard-shortcut`, '_blank'); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		dark() { | ||||||
|  | 			this.$store.commit('device/set', { | ||||||
|  | 				key: 'darkmode', | ||||||
|  | 				value: !this.$store.state.device.darkmode | ||||||
|  | 			}); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| }); | }); | ||||||
|   | |||||||
| @@ -34,9 +34,6 @@ html | |||||||
| 		//- FontAwesome style | 		//- FontAwesome style | ||||||
| 		style #{facss} | 		style #{facss} | ||||||
|  |  | ||||||
| 		//- highlight.js style |  | ||||||
| 		style #{hljscss} |  | ||||||
|  |  | ||||||
| 	body | 	body | ||||||
| 		noscript: p | 		noscript: p | ||||||
| 			| JavaScriptを有効にしてください | 			| JavaScriptを有効にしてください | ||||||
|   | |||||||
| @@ -20,6 +20,15 @@ | |||||||
|  |  | ||||||
| 	const langs = LANGS; | 	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 | 	//#region Load settings | ||||||
| 	let settings = null; | 	let settings = null; | ||||||
| 	const vuex = localStorage.getItem('vuex'); | 	const vuex = localStorage.getItem('vuex'); | ||||||
| @@ -84,13 +93,6 @@ | |||||||
| 		app = isMobile ? 'mobile' : 'desktop'; | 		app = isMobile ? 'mobile' : 'desktop'; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	// Dark/Light |  | ||||||
| 	if (settings) { |  | ||||||
| 		if (settings.device.darkmode) { |  | ||||||
| 			document.documentElement.setAttribute('data-darkmode', 'true'); |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	// Script version | 	// Script version | ||||||
| 	const ver = localStorage.getItem('v') || VERSION; | 	const ver = localStorage.getItem('v') || VERSION; | ||||||
|  |  | ||||||
| @@ -140,7 +142,7 @@ | |||||||
| 		localStorage.setItem('shouldFlush', 'false'); | 		localStorage.setItem('shouldFlush', 'false'); | ||||||
|  |  | ||||||
| 		// Random | 		// Random | ||||||
| 		localStorage.setItem('salt', Math.random().toString()); | 		localStorage.setItem('salt', Math.random().toString().substr(2, 8)); | ||||||
|  |  | ||||||
| 		// Clear cache (service worker) | 		// Clear cache (service worker) | ||||||
| 		try { | 		try { | ||||||
|   | |||||||
| @@ -46,6 +46,16 @@ const getKeyMap = keymap => Object.entries(keymap).map(([patterns, callback]): a | |||||||
|  |  | ||||||
| const ignoreElemens = ['input', 'textarea']; | const ignoreElemens = ['input', 'textarea']; | ||||||
|  |  | ||||||
|  | function match(e: KeyboardEvent, patterns: action['patterns']): boolean { | ||||||
|  | 	const key = e.code.toLowerCase(); | ||||||
|  | 	return patterns.some(pattern => pattern.which.includes(key) && | ||||||
|  | 		pattern.ctrl == e.ctrlKey && | ||||||
|  | 		pattern.shift == e.shiftKey && | ||||||
|  | 		pattern.alt == e.altKey && | ||||||
|  | 		e.metaKey == false | ||||||
|  | 	); | ||||||
|  | } | ||||||
|  |  | ||||||
| export default { | export default { | ||||||
| 	install(Vue) { | 	install(Vue) { | ||||||
| 		Vue.directive('hotkey', { | 		Vue.directive('hotkey', { | ||||||
| @@ -55,36 +65,27 @@ export default { | |||||||
| 				const actions = getKeyMap(binding.value); | 				const actions = getKeyMap(binding.value); | ||||||
|  |  | ||||||
| 				// flatten | 				// flatten | ||||||
| 				const reservedKeys = concat(concat(actions.map(a => a.patterns.map(p => p.which)))); | 				const reservedKeys = concat(actions.map(a => a.patterns)); | ||||||
|  |  | ||||||
| 				el.dataset.reservedKeys = reservedKeys.map(key => `'${key}'`).join(' '); | 				el._misskey_reservedKeys = reservedKeys; | ||||||
|  |  | ||||||
| 				el._keyHandler = e => { | 				el._keyHandler = (e: KeyboardEvent) => { | ||||||
| 					const key = e.code.toLowerCase(); | 					const targetReservedKeys = document.activeElement ? ((document.activeElement as any)._misskey_reservedKeys || []) : []; | ||||||
|  |  | ||||||
| 					const targetReservedKeys = document.activeElement ? ((document.activeElement as any).dataset || {}).reservedKeys || '' : ''; |  | ||||||
| 					if (document.activeElement && ignoreElemens.some(el => document.activeElement.matches(el))) return; | 					if (document.activeElement && ignoreElemens.some(el => document.activeElement.matches(el))) return; | ||||||
|  |  | ||||||
| 					for (const action of actions) { | 					for (const action of actions) { | ||||||
| 						if (el._hotkey_global && targetReservedKeys.includes(`'${key}'`)) break; | 						const matched = match(e, action.patterns); | ||||||
|  |  | ||||||
| 						const matched = action.patterns.some(pattern => { |  | ||||||
| 							const matched = pattern.which.includes(key) && |  | ||||||
| 								pattern.ctrl == e.ctrlKey && |  | ||||||
| 								pattern.shift == e.shiftKey && |  | ||||||
| 								pattern.alt == e.altKey; |  | ||||||
|  |  | ||||||
| 							if (matched) { |  | ||||||
| 								e.preventDefault(); |  | ||||||
| 								e.stopPropagation(); |  | ||||||
| 								action.callback(e); |  | ||||||
| 								return true; |  | ||||||
| 							} else { |  | ||||||
| 								return false; |  | ||||||
| 							} |  | ||||||
| 						}); |  | ||||||
|  |  | ||||||
| 						if (matched) { | 						if (matched) { | ||||||
|  | 							if (el._hotkey_global) { | ||||||
|  | 								if (match(e, targetReservedKeys)) { | ||||||
|  | 									return; | ||||||
|  | 								} | ||||||
|  | 							} | ||||||
|  |  | ||||||
|  | 							e.preventDefault(); | ||||||
|  | 							e.stopPropagation(); | ||||||
|  | 							action.callback(e); | ||||||
| 							break; | 							break; | ||||||
| 						} | 						} | ||||||
| 					} | 					} | ||||||
|   | |||||||
| @@ -13,21 +13,21 @@ type Notification = { | |||||||
|  |  | ||||||
| export default function(type, data): Notification { | export default function(type, data): Notification { | ||||||
| 	switch (type) { | 	switch (type) { | ||||||
| 		case 'drive_file_created': | 		case 'driveFileCreated': | ||||||
| 			return { | 			return { | ||||||
| 				title: '%i18n:common.notification.file-uploaded%', | 				title: '%i18n:common.notification.file-uploaded%', | ||||||
| 				body: data.name, | 				body: data.name, | ||||||
| 				icon: data.url | 				icon: data.url | ||||||
| 			}; | 			}; | ||||||
|  |  | ||||||
| 		case 'unread_messaging_message': | 		case 'unreadMessagingMessage': | ||||||
| 			return { | 			return { | ||||||
| 				title: '%i18n:common.notification.message-from%'.split("{}")[0] + `${getUserName(data.user)}` + '%i18n:common.notification.message-from%'.split("{}")[1] , | 				title: '%i18n:common.notification.message-from%'.split("{}")[0] + `${getUserName(data.user)}` + '%i18n:common.notification.message-from%'.split("{}")[1] , | ||||||
| 				body: data.text, // TODO: getMessagingMessageSummary(data), | 				body: data.text, // TODO: getMessagingMessageSummary(data), | ||||||
| 				icon: data.user.avatarUrl | 				icon: data.user.avatarUrl | ||||||
| 			}; | 			}; | ||||||
|  |  | ||||||
| 		case 'reversi_invited': | 		case 'reversiInvited': | ||||||
| 			return { | 			return { | ||||||
| 				title: '%i18n:common.notification.reversi-invited%', | 				title: '%i18n:common.notification.reversi-invited%', | ||||||
| 				body: '%i18n:common.notification.reversi-invited-by%'.split("{}")[0] + `${getUserName(data.parent)}` + '%i18n:common.notification.reversi-invited-by%'.split("{}")[1], | 				body: '%i18n:common.notification.reversi-invited-by%'.split("{}")[0] + `${getUserName(data.parent)}` + '%i18n:common.notification.reversi-invited-by%'.split("{}")[1], | ||||||
|   | |||||||
| @@ -1,8 +1,8 @@ | |||||||
| require('fuckadblock'); |  | ||||||
|  |  | ||||||
| declare const fuckAdBlock: any; | declare const fuckAdBlock: any; | ||||||
|  |  | ||||||
| export default (os) => { | export default (os) => { | ||||||
|  | 	require('fuckadblock'); | ||||||
|  |  | ||||||
| 	function adBlockDetected() { | 	function adBlockDetected() { | ||||||
| 		os.apis.dialog({ | 		os.apis.dialog({ | ||||||
| 			title: '%fa:exclamation-triangle%%i18n:common.adblock.detected%', | 			title: '%fa:exclamation-triangle%%i18n:common.adblock.detected%', | ||||||
|   | |||||||
							
								
								
									
										8
									
								
								src/client/app/common/scripts/get-md5.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								src/client/app/common/scripts/get-md5.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | |||||||
|  | const crypto = require('crypto'); | ||||||
|  |  | ||||||
|  | export default (data: ArrayBuffer) => { | ||||||
|  |   const buf = new Buffer(data); | ||||||
|  |   const hash = crypto.createHash("md5"); | ||||||
|  |   hash.update(buf); | ||||||
|  |   return hash.digest("hex"); | ||||||
|  | }; | ||||||
							
								
								
									
										182
									
								
								src/client/app/common/scripts/note-mixin.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										182
									
								
								src/client/app/common/scripts/note-mixin.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,182 @@ | |||||||
|  | import parse from '../../../../mfm/parse'; | ||||||
|  | import { sum } from '../../../../prelude/array'; | ||||||
|  | import MkNoteMenu from '../views/components/note-menu.vue'; | ||||||
|  | import MkReactionPicker from '../views/components/reaction-picker.vue'; | ||||||
|  | import Ok from '../views/components/ok.vue'; | ||||||
|  |  | ||||||
|  | function focus(el, fn) { | ||||||
|  | 	const target = fn(el); | ||||||
|  | 	if (target) { | ||||||
|  | 		if (target.hasAttribute('tabindex')) { | ||||||
|  | 			target.focus(); | ||||||
|  | 		} else { | ||||||
|  | 			focus(target, fn); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type Opts = { | ||||||
|  | 	mobile?: boolean; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export default (opts: Opts = {}) => ({ | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			showContent: false | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	computed: { | ||||||
|  | 		keymap(): any { | ||||||
|  | 			return { | ||||||
|  | 				'r': () => this.reply(true), | ||||||
|  | 				'e|a|plus': () => this.react(true), | ||||||
|  | 				'q': () => this.renote(true), | ||||||
|  | 				'f|b': this.favorite, | ||||||
|  | 				'delete|ctrl+d': this.del, | ||||||
|  | 				'ctrl+q': this.renoteDirectly, | ||||||
|  | 				'up|k|shift+tab': this.focusBefore, | ||||||
|  | 				'down|j|tab': this.focusAfter, | ||||||
|  | 				'shift+up': () => this.$emit('parentFocus', 'up'), | ||||||
|  | 				'shift+down': () => this.$emit('parentFocus', 'down'), | ||||||
|  | 				'shift+left': () => this.$emit('parentFocus', 'left'), | ||||||
|  | 				'shift+right': () => this.$emit('parentFocus', 'right'), | ||||||
|  | 				'esc': this.blur, | ||||||
|  | 				'm|o': () => this.menu(true), | ||||||
|  | 				's': this.toggleShowContent, | ||||||
|  | 				'1': () => this.reactDirectly('like'), | ||||||
|  | 				'2': () => this.reactDirectly('love'), | ||||||
|  | 				'3': () => this.reactDirectly('laugh'), | ||||||
|  | 				'4': () => this.reactDirectly('hmm'), | ||||||
|  | 				'5': () => this.reactDirectly('surprise'), | ||||||
|  | 				'6': () => this.reactDirectly('congrats'), | ||||||
|  | 				'7': () => this.reactDirectly('angry'), | ||||||
|  | 				'8': () => this.reactDirectly('confused'), | ||||||
|  | 				'9': () => this.reactDirectly('rip'), | ||||||
|  | 				'0': () => this.reactDirectly('pudding'), | ||||||
|  | 			}; | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		isRenote(): boolean { | ||||||
|  | 			return (this.note.renote && | ||||||
|  | 				this.note.text == null && | ||||||
|  | 				this.note.fileIds.length == 0 && | ||||||
|  | 				this.note.poll == null); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		appearNote(): any { | ||||||
|  | 			return this.isRenote ? this.note.renote : this.note; | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		reactionsCount(): number { | ||||||
|  | 			return this.appearNote.reactionCounts | ||||||
|  | 				? sum(Object.values(this.appearNote.reactionCounts)) | ||||||
|  | 				: 0; | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		title(): string { | ||||||
|  | 			return new Date(this.appearNote.createdAt).toLocaleString(); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		urls(): string[] { | ||||||
|  | 			if (this.appearNote.text) { | ||||||
|  | 				const ast = parse(this.appearNote.text); | ||||||
|  | 				return ast | ||||||
|  | 					.filter(t => (t.type == 'url' || t.type == 'link') && !t.silent) | ||||||
|  | 					.map(t => t.url); | ||||||
|  | 			} else { | ||||||
|  | 				return null; | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	methods: { | ||||||
|  | 		reply(viaKeyboard = false) { | ||||||
|  | 			(this as any).apis.post({ | ||||||
|  | 				reply: this.appearNote, | ||||||
|  | 				animation: !viaKeyboard, | ||||||
|  | 				cb: () => { | ||||||
|  | 					this.focus(); | ||||||
|  | 				} | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		renote(viaKeyboard = false) { | ||||||
|  | 			(this as any).apis.post({ | ||||||
|  | 				renote: this.appearNote, | ||||||
|  | 				animation: !viaKeyboard, | ||||||
|  | 				cb: () => { | ||||||
|  | 					this.focus(); | ||||||
|  | 				} | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		renoteDirectly() { | ||||||
|  | 			(this as any).api('notes/create', { | ||||||
|  | 				renoteId: this.appearNote.id | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		react(viaKeyboard = false) { | ||||||
|  | 			this.blur(); | ||||||
|  | 			(this as any).os.new(MkReactionPicker, { | ||||||
|  | 				source: this.$refs.reactButton, | ||||||
|  | 				note: this.appearNote, | ||||||
|  | 				showFocus: viaKeyboard, | ||||||
|  | 				animation: !viaKeyboard, | ||||||
|  | 				compact: opts.mobile, | ||||||
|  | 				big: opts.mobile | ||||||
|  | 			}).$once('closed', this.focus); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		reactDirectly(reaction) { | ||||||
|  | 			(this as any).api('notes/reactions/create', { | ||||||
|  | 				noteId: this.appearNote.id, | ||||||
|  | 				reaction: reaction | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		favorite() { | ||||||
|  | 			(this as any).api('notes/favorites/create', { | ||||||
|  | 				noteId: this.appearNote.id | ||||||
|  | 			}).then(() => { | ||||||
|  | 				(this as any).os.new(Ok); | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		del() { | ||||||
|  | 			(this as any).api('notes/delete', { | ||||||
|  | 				noteId: this.appearNote.id | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		menu(viaKeyboard = false) { | ||||||
|  | 			(this as any).os.new(MkNoteMenu, { | ||||||
|  | 				source: this.$refs.menuButton, | ||||||
|  | 				note: this.appearNote, | ||||||
|  | 				animation: !viaKeyboard, | ||||||
|  | 				compact: opts.mobile, | ||||||
|  | 			}).$once('closed', this.focus); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		toggleShowContent() { | ||||||
|  | 			this.showContent = !this.showContent; | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		focus() { | ||||||
|  | 			this.$el.focus(); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		blur() { | ||||||
|  | 			this.$el.blur(); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		focusBefore() { | ||||||
|  | 			focus(this.$el, e => e.previousElementSibling); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		focusAfter() { | ||||||
|  | 			focus(this.$el, e => e.nextElementSibling); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | }); | ||||||
							
								
								
									
										128
									
								
								src/client/app/common/scripts/note-subscriber.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										128
									
								
								src/client/app/common/scripts/note-subscriber.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,128 @@ | |||||||
|  | import Vue from 'vue'; | ||||||
|  |  | ||||||
|  | export default prop => ({ | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			connection: null | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	computed: { | ||||||
|  | 		$_ns_note_(): any { | ||||||
|  | 			return this[prop]; | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		$_ns_isRenote(): boolean { | ||||||
|  | 			return (this.$_ns_note_.renote != null && | ||||||
|  | 				this.$_ns_note_.text == null && | ||||||
|  | 				this.$_ns_note_.fileIds.length == 0 && | ||||||
|  | 				this.$_ns_note_.poll == null); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		$_ns_target(): any { | ||||||
|  | 			return this.$_ns_isRenote ? this.$_ns_note_.renote : this.$_ns_note_; | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	created() { | ||||||
|  | 		if (this.$store.getters.isSignedIn) { | ||||||
|  | 			this.connection = (this as any).os.stream; | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	mounted() { | ||||||
|  | 		this.capture(true); | ||||||
|  |  | ||||||
|  | 		if (this.$store.getters.isSignedIn) { | ||||||
|  | 			this.connection.on('_connected_', this.onStreamConnected); | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	beforeDestroy() { | ||||||
|  | 		this.decapture(true); | ||||||
|  |  | ||||||
|  | 		if (this.$store.getters.isSignedIn) { | ||||||
|  | 			this.connection.off('_connected_', this.onStreamConnected); | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	methods: { | ||||||
|  | 		capture(withHandler = false) { | ||||||
|  | 			if (this.$store.getters.isSignedIn) { | ||||||
|  | 				const data = { | ||||||
|  | 					id: this.$_ns_target.id | ||||||
|  | 				} as any; | ||||||
|  |  | ||||||
|  | 				if ( | ||||||
|  | 					(this.$_ns_target.visibleUserIds || []).includes(this.$store.state.i.id) || | ||||||
|  | 					(this.$_ns_target.mentions || []).includes(this.$store.state.i.id) | ||||||
|  | 				) { | ||||||
|  | 					data.read = true; | ||||||
|  | 				} | ||||||
|  |  | ||||||
|  | 				this.connection.send('sn', data); | ||||||
|  | 				if (withHandler) this.connection.on('noteUpdated', this.onStreamNoteUpdated); | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		decapture(withHandler = false) { | ||||||
|  | 			if (this.$store.getters.isSignedIn) { | ||||||
|  | 				this.connection.send('un', { | ||||||
|  | 					id: this.$_ns_target.id | ||||||
|  | 				}); | ||||||
|  | 				if (withHandler) this.connection.off('noteUpdated', this.onStreamNoteUpdated); | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		onStreamConnected() { | ||||||
|  | 			this.capture(); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		onStreamNoteUpdated(data) { | ||||||
|  | 			const { type, id, body } = data; | ||||||
|  |  | ||||||
|  | 			if (id !== this.$_ns_target.id) return; | ||||||
|  |  | ||||||
|  | 			switch (type) { | ||||||
|  | 				case 'reacted': { | ||||||
|  | 					const reaction = body.reaction; | ||||||
|  |  | ||||||
|  | 					if (this.$_ns_target.reactionCounts == null) { | ||||||
|  | 						Vue.set(this.$_ns_target, 'reactionCounts', {}); | ||||||
|  | 					} | ||||||
|  |  | ||||||
|  | 					if (this.$_ns_target.reactionCounts[reaction] == null) { | ||||||
|  | 						Vue.set(this.$_ns_target.reactionCounts, reaction, 0); | ||||||
|  | 					} | ||||||
|  |  | ||||||
|  | 					this.$_ns_target.reactionCounts[reaction]++; | ||||||
|  |  | ||||||
|  | 					if (body.userId == this.$store.state.i.id) { | ||||||
|  | 						Vue.set(this.$_ns_target, 'myReaction', reaction); | ||||||
|  | 					} | ||||||
|  | 					break; | ||||||
|  | 				} | ||||||
|  |  | ||||||
|  | 				case 'pollVoted': { | ||||||
|  | 					if (body.userId == this.$store.state.i.id) return; | ||||||
|  | 					const choice = body.choice; | ||||||
|  | 					this.$_ns_target.poll.choices.find(c => c.id === choice).votes++; | ||||||
|  | 					break; | ||||||
|  | 				} | ||||||
|  |  | ||||||
|  | 				case 'deleted': { | ||||||
|  | 					Vue.set(this.$_ns_target, 'deletedAt', body.deletedAt); | ||||||
|  | 					this.$_ns_target.text = null; | ||||||
|  | 					this.$_ns_target.tags = []; | ||||||
|  | 					this.$_ns_target.fileIds = []; | ||||||
|  | 					this.$_ns_target.poll = null; | ||||||
|  | 					this.$_ns_target.geo = null; | ||||||
|  | 					this.$_ns_target.cw = null; | ||||||
|  | 					break; | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			this.$emit(`update:${prop}`, this.$_ns_note_); | ||||||
|  | 		}, | ||||||
|  | 	} | ||||||
|  | }); | ||||||
							
								
								
									
										303
									
								
								src/client/app/common/scripts/stream.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										303
									
								
								src/client/app/common/scripts/stream.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,303 @@ | |||||||
|  | import autobind from 'autobind-decorator'; | ||||||
|  | import { EventEmitter } from 'eventemitter3'; | ||||||
|  | import ReconnectingWebsocket from 'reconnecting-websocket'; | ||||||
|  | import { wsUrl } from '../../config'; | ||||||
|  | import MiOS from '../../mios'; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Misskey stream connection | ||||||
|  |  */ | ||||||
|  | export default class Stream extends EventEmitter { | ||||||
|  | 	private stream: ReconnectingWebsocket; | ||||||
|  | 	public state: string; | ||||||
|  | 	private sharedConnectionPools: Pool[] = []; | ||||||
|  | 	private sharedConnections: SharedConnection[] = []; | ||||||
|  | 	private nonSharedConnections: NonSharedConnection[] = []; | ||||||
|  |  | ||||||
|  | 	constructor(os: MiOS) { | ||||||
|  | 		super(); | ||||||
|  |  | ||||||
|  | 		this.state = 'initializing'; | ||||||
|  |  | ||||||
|  | 		const user = os.store.state.i; | ||||||
|  |  | ||||||
|  | 		this.stream = new ReconnectingWebsocket(wsUrl + (user ? `?i=${user.token}` : '')); | ||||||
|  | 		this.stream.addEventListener('open', this.onOpen); | ||||||
|  | 		this.stream.addEventListener('close', this.onClose); | ||||||
|  | 		this.stream.addEventListener('message', this.onMessage); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@autobind | ||||||
|  | 	public useSharedConnection(channel: string): SharedConnection { | ||||||
|  | 		let pool = this.sharedConnectionPools.find(p => p.channel === channel); | ||||||
|  |  | ||||||
|  | 		if (pool == null) { | ||||||
|  | 			pool = new Pool(this, channel); | ||||||
|  | 			this.sharedConnectionPools.push(pool); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		const connection = new SharedConnection(this, channel, pool); | ||||||
|  | 		this.sharedConnections.push(connection); | ||||||
|  | 		return connection; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@autobind | ||||||
|  | 	public removeSharedConnection(connection: SharedConnection) { | ||||||
|  | 		this.sharedConnections = this.sharedConnections.filter(c => c !== connection); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@autobind | ||||||
|  | 	public removeSharedConnectionPool(pool: Pool) { | ||||||
|  | 		this.sharedConnectionPools = this.sharedConnectionPools.filter(p => p !== pool); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@autobind | ||||||
|  | 	public connectToChannel(channel: string, params?: any): NonSharedConnection { | ||||||
|  | 		const connection = new NonSharedConnection(this, channel, params); | ||||||
|  | 		this.nonSharedConnections.push(connection); | ||||||
|  | 		return connection; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@autobind | ||||||
|  | 	public disconnectToChannel(connection: NonSharedConnection) { | ||||||
|  | 		this.nonSharedConnections = this.nonSharedConnections.filter(c => c !== connection); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * Callback of when open connection | ||||||
|  | 	 */ | ||||||
|  | 	@autobind | ||||||
|  | 	private onOpen() { | ||||||
|  | 		const isReconnect = this.state == 'reconnecting'; | ||||||
|  |  | ||||||
|  | 		this.state = 'connected'; | ||||||
|  | 		this.emit('_connected_'); | ||||||
|  |  | ||||||
|  | 		// チャンネル再接続 | ||||||
|  | 		if (isReconnect) { | ||||||
|  | 			this.sharedConnectionPools.forEach(p => { | ||||||
|  | 				p.connect(); | ||||||
|  | 			}); | ||||||
|  | 			this.nonSharedConnections.forEach(c => { | ||||||
|  | 				c.connect(); | ||||||
|  | 			}); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * Callback of when close connection | ||||||
|  | 	 */ | ||||||
|  | 	@autobind | ||||||
|  | 	private onClose() { | ||||||
|  | 		if (this.state == 'connected') { | ||||||
|  | 			this.state = 'reconnecting'; | ||||||
|  | 			this.emit('_disconnected_'); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * Callback of when received a message from connection | ||||||
|  | 	 */ | ||||||
|  | 	@autobind | ||||||
|  | 	private onMessage(message) { | ||||||
|  | 		const { type, body } = JSON.parse(message.data); | ||||||
|  |  | ||||||
|  | 		if (type == 'channel') { | ||||||
|  | 			const id = body.id; | ||||||
|  |  | ||||||
|  | 			let connections: Connection[]; | ||||||
|  |  | ||||||
|  | 			connections = this.sharedConnections.filter(c => c.id === id); | ||||||
|  |  | ||||||
|  | 			if (connections.length === 0) { | ||||||
|  | 				connections = [this.nonSharedConnections.find(c => c.id === id)]; | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			connections.filter(c => c != null).forEach(c => { | ||||||
|  | 				c.emit(body.type, body.body); | ||||||
|  | 			}); | ||||||
|  | 		} else { | ||||||
|  | 			this.emit(type, body); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * Send a message to connection | ||||||
|  | 	 */ | ||||||
|  | 	@autobind | ||||||
|  | 	public send(typeOrPayload, payload?) { | ||||||
|  | 		const data = payload === undefined ? typeOrPayload : { | ||||||
|  | 			type: typeOrPayload, | ||||||
|  | 			body: payload | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		this.stream.send(JSON.stringify(data)); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * Close this connection | ||||||
|  | 	 */ | ||||||
|  | 	@autobind | ||||||
|  | 	public close() { | ||||||
|  | 		this.stream.removeEventListener('open', this.onOpen); | ||||||
|  | 		this.stream.removeEventListener('message', this.onMessage); | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | class Pool { | ||||||
|  | 	public channel: string; | ||||||
|  | 	public id: string; | ||||||
|  | 	protected stream: Stream; | ||||||
|  | 	public users = 0; | ||||||
|  | 	private disposeTimerId: any; | ||||||
|  | 	private isConnected = false; | ||||||
|  |  | ||||||
|  | 	constructor(stream: Stream, channel: string) { | ||||||
|  | 		this.channel = channel; | ||||||
|  | 		this.stream = stream; | ||||||
|  |  | ||||||
|  | 		this.id = Math.random().toString().substr(2, 8); | ||||||
|  |  | ||||||
|  | 		this.stream.on('_disconnected_', this.onStreamDisconnected); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@autobind | ||||||
|  | 	private onStreamDisconnected() { | ||||||
|  | 		this.isConnected = false; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@autobind | ||||||
|  | 	public inc() { | ||||||
|  | 		if (this.users === 0 && !this.isConnected) { | ||||||
|  | 			this.connect(); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		this.users++; | ||||||
|  |  | ||||||
|  | 		// タイマー解除 | ||||||
|  | 		if (this.disposeTimerId) { | ||||||
|  | 			clearTimeout(this.disposeTimerId); | ||||||
|  | 			this.disposeTimerId = null; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@autobind | ||||||
|  | 	public dec() { | ||||||
|  | 		this.users--; | ||||||
|  |  | ||||||
|  | 		// そのコネクションの利用者が誰もいなくなったら | ||||||
|  | 		if (this.users === 0) { | ||||||
|  | 			// また直ぐに再利用される可能性があるので、一定時間待ち、 | ||||||
|  | 			// 新たな利用者が現れなければコネクションを切断する | ||||||
|  | 			this.disposeTimerId = setTimeout(() => { | ||||||
|  | 				this.disconnect(); | ||||||
|  | 			}, 3000); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@autobind | ||||||
|  | 	public connect() { | ||||||
|  | 		if (this.isConnected) return; | ||||||
|  | 		this.isConnected = true; | ||||||
|  | 		this.stream.send('connect', { | ||||||
|  | 			channel: this.channel, | ||||||
|  | 			id: this.id | ||||||
|  | 		}); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@autobind | ||||||
|  | 	private disconnect() { | ||||||
|  | 		this.stream.off('_disconnected_', this.onStreamDisconnected); | ||||||
|  | 		this.stream.send('disconnect', { id: this.id }); | ||||||
|  | 		this.stream.removeSharedConnectionPool(this); | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | abstract class Connection extends EventEmitter { | ||||||
|  | 	public channel: string; | ||||||
|  | 	protected stream: Stream; | ||||||
|  | 	public abstract id: string; | ||||||
|  |  | ||||||
|  | 	constructor(stream: Stream, channel: string) { | ||||||
|  | 		super(); | ||||||
|  |  | ||||||
|  | 		this.stream = stream; | ||||||
|  | 		this.channel = channel; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@autobind | ||||||
|  | 	public send(id: string, typeOrPayload, payload?) { | ||||||
|  | 		const type = payload === undefined ? typeOrPayload.type : typeOrPayload; | ||||||
|  | 		const body = payload === undefined ? typeOrPayload.body : payload; | ||||||
|  |  | ||||||
|  | 		this.stream.send('ch', { | ||||||
|  | 			id: id, | ||||||
|  | 			type: type, | ||||||
|  | 			body: body | ||||||
|  | 		}); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	public abstract dispose(): void; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | class SharedConnection extends Connection { | ||||||
|  | 	private pool: Pool; | ||||||
|  |  | ||||||
|  | 	public get id(): string { | ||||||
|  | 		return this.pool.id; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	constructor(stream: Stream, channel: string, pool: Pool) { | ||||||
|  | 		super(stream, channel); | ||||||
|  |  | ||||||
|  | 		this.pool = pool; | ||||||
|  | 		this.pool.inc(); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@autobind | ||||||
|  | 	public send(typeOrPayload, payload?) { | ||||||
|  | 		super.send(this.pool.id, typeOrPayload, payload); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@autobind | ||||||
|  | 	public dispose() { | ||||||
|  | 		this.pool.dec(); | ||||||
|  | 		this.removeAllListeners(); | ||||||
|  | 		this.stream.removeSharedConnection(this); | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | class NonSharedConnection extends Connection { | ||||||
|  | 	public id: string; | ||||||
|  | 	protected params: any; | ||||||
|  |  | ||||||
|  | 	constructor(stream: Stream, channel: string, params?: any) { | ||||||
|  | 		super(stream, channel); | ||||||
|  |  | ||||||
|  | 		this.params = params; | ||||||
|  | 		this.id = Math.random().toString().substr(2, 8); | ||||||
|  |  | ||||||
|  | 		this.connect(); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@autobind | ||||||
|  | 	public connect() { | ||||||
|  | 		this.stream.send('connect', { | ||||||
|  | 			channel: this.channel, | ||||||
|  | 			id: this.id, | ||||||
|  | 			params: this.params | ||||||
|  | 		}); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@autobind | ||||||
|  | 	public send(typeOrPayload, payload?) { | ||||||
|  | 		super.send(this.id, typeOrPayload, payload); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@autobind | ||||||
|  | 	public dispose() { | ||||||
|  | 		this.removeAllListeners(); | ||||||
|  | 		this.stream.send('disconnect', { id: this.id }); | ||||||
|  | 		this.stream.disconnectToChannel(this); | ||||||
|  | 	} | ||||||
|  | } | ||||||
| @@ -1,34 +0,0 @@ | |||||||
| import Stream from './stream'; |  | ||||||
| import StreamManager from './stream-manager'; |  | ||||||
| import MiOS from '../../../mios'; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Drive stream connection |  | ||||||
|  */ |  | ||||||
| export class DriveStream extends Stream { |  | ||||||
| 	constructor(os: MiOS, me) { |  | ||||||
| 		super(os, 'drive', { |  | ||||||
| 			i: me.token |  | ||||||
| 		}); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| export class DriveStreamManager extends StreamManager<DriveStream> { |  | ||||||
| 	private me; |  | ||||||
| 	private os: MiOS; |  | ||||||
|  |  | ||||||
| 	constructor(os: MiOS, me) { |  | ||||||
| 		super(); |  | ||||||
|  |  | ||||||
| 		this.me = me; |  | ||||||
| 		this.os = os; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	public getConnection() { |  | ||||||
| 		if (this.connection == null) { |  | ||||||
| 			this.connection = new DriveStream(this.os, this.me); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		return this.connection; |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @@ -1,13 +0,0 @@ | |||||||
| import Stream from '../../stream'; |  | ||||||
| import MiOS from '../../../../../mios'; |  | ||||||
|  |  | ||||||
| export class ReversiGameStream extends Stream { |  | ||||||
| 	constructor(os: MiOS, me, game) { |  | ||||||
| 		super(os, 'games/reversi-game', me ? { |  | ||||||
| 			i: me.token, |  | ||||||
| 			game: game.id |  | ||||||
| 		} : { |  | ||||||
| 			game: game.id |  | ||||||
| 		}); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @@ -1,31 +0,0 @@ | |||||||
| import StreamManager from '../../stream-manager'; |  | ||||||
| import Stream from '../../stream'; |  | ||||||
| import MiOS from '../../../../../mios'; |  | ||||||
|  |  | ||||||
| export class ReversiStream extends Stream { |  | ||||||
| 	constructor(os: MiOS, me) { |  | ||||||
| 		super(os, 'games/reversi', { |  | ||||||
| 			i: me.token |  | ||||||
| 		}); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| export class ReversiStreamManager extends StreamManager<ReversiStream> { |  | ||||||
| 	private me; |  | ||||||
| 	private os: MiOS; |  | ||||||
|  |  | ||||||
| 	constructor(os: MiOS, me) { |  | ||||||
| 		super(); |  | ||||||
|  |  | ||||||
| 		this.me = me; |  | ||||||
| 		this.os = os; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	public getConnection() { |  | ||||||
| 		if (this.connection == null) { |  | ||||||
| 			this.connection = new ReversiStream(this.os, this.me); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		return this.connection; |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @@ -1,34 +0,0 @@ | |||||||
| import Stream from './stream'; |  | ||||||
| import StreamManager from './stream-manager'; |  | ||||||
| import MiOS from '../../../mios'; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Global timeline stream connection |  | ||||||
|  */ |  | ||||||
| export class GlobalTimelineStream extends Stream { |  | ||||||
| 	constructor(os: MiOS, me) { |  | ||||||
| 		super(os, 'global-timeline', { |  | ||||||
| 			i: me.token |  | ||||||
| 		}); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| export class GlobalTimelineStreamManager extends StreamManager<GlobalTimelineStream> { |  | ||||||
| 	private me; |  | ||||||
| 	private os: MiOS; |  | ||||||
|  |  | ||||||
| 	constructor(os: MiOS, me) { |  | ||||||
| 		super(); |  | ||||||
|  |  | ||||||
| 		this.me = me; |  | ||||||
| 		this.os = os; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	public getConnection() { |  | ||||||
| 		if (this.connection == null) { |  | ||||||
| 			this.connection = new GlobalTimelineStream(this.os, this.me); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		return this.connection; |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @@ -1,13 +0,0 @@ | |||||||
| 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) |  | ||||||
| 		}); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @@ -1,126 +0,0 @@ | |||||||
| import Stream from './stream'; |  | ||||||
| import StreamManager from './stream-manager'; |  | ||||||
| import MiOS from '../../../mios'; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Home stream connection |  | ||||||
|  */ |  | ||||||
| export class HomeStream extends Stream { |  | ||||||
| 	constructor(os: MiOS, me) { |  | ||||||
| 		super(os, '', { |  | ||||||
| 			i: me.token |  | ||||||
| 		}); |  | ||||||
|  |  | ||||||
| 		// 最終利用日時を更新するため定期的にaliveメッセージを送信 |  | ||||||
| 		setInterval(() => { |  | ||||||
| 			this.send({ type: 'alive' }); |  | ||||||
| 			me.lastUsedAt = new Date(); |  | ||||||
| 		}, 1000 * 60); |  | ||||||
|  |  | ||||||
| 		// 自分の情報が更新されたとき |  | ||||||
| 		this.on('meUpdated', i => { |  | ||||||
| 			if (os.debug) { |  | ||||||
| 				console.log('I updated:', i); |  | ||||||
| 			} |  | ||||||
|  |  | ||||||
| 			os.store.dispatch('mergeMe', i); |  | ||||||
| 		}); |  | ||||||
|  |  | ||||||
| 		this.on('read_all_notifications', () => { |  | ||||||
| 			os.store.dispatch('mergeMe', { |  | ||||||
| 				hasUnreadNotification: false |  | ||||||
| 			}); |  | ||||||
| 		}); |  | ||||||
|  |  | ||||||
| 		this.on('unread_notification', () => { |  | ||||||
| 			os.store.dispatch('mergeMe', { |  | ||||||
| 				hasUnreadNotification: true |  | ||||||
| 			}); |  | ||||||
| 		}); |  | ||||||
|  |  | ||||||
| 		this.on('read_all_messaging_messages', () => { |  | ||||||
| 			os.store.dispatch('mergeMe', { |  | ||||||
| 				hasUnreadMessagingMessage: false |  | ||||||
| 			}); |  | ||||||
| 		}); |  | ||||||
|  |  | ||||||
| 		this.on('unread_messaging_message', () => { |  | ||||||
| 			os.store.dispatch('mergeMe', { |  | ||||||
| 				hasUnreadMessagingMessage: true |  | ||||||
| 			}); |  | ||||||
| 		}); |  | ||||||
|  |  | ||||||
| 		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, |  | ||||||
| 				value: x.value |  | ||||||
| 			}); |  | ||||||
| 		}); |  | ||||||
|  |  | ||||||
| 		this.on('home_updated', x => { |  | ||||||
| 			os.store.commit('settings/setHome', x); |  | ||||||
| 		}); |  | ||||||
|  |  | ||||||
| 		this.on('mobile_home_updated', x => { |  | ||||||
| 			os.store.commit('settings/setMobileHome', x); |  | ||||||
| 		}); |  | ||||||
|  |  | ||||||
| 		this.on('widgetUpdated', x => { |  | ||||||
| 			os.store.commit('settings/setWidget', { |  | ||||||
| 				id: x.id, |  | ||||||
| 				data: x.data |  | ||||||
| 			}); |  | ||||||
| 		}); |  | ||||||
|  |  | ||||||
| 		// トークンが再生成されたとき |  | ||||||
| 		// このままではMisskeyが利用できないので強制的にサインアウトさせる |  | ||||||
| 		this.on('my_token_regenerated', () => { |  | ||||||
| 			alert('%i18n:common.my-token-regenerated%'); |  | ||||||
| 			os.signout(); |  | ||||||
| 		}); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| export class HomeStreamManager extends StreamManager<HomeStream> { |  | ||||||
| 	private me; |  | ||||||
| 	private os: MiOS; |  | ||||||
|  |  | ||||||
| 	constructor(os: MiOS, me) { |  | ||||||
| 		super(); |  | ||||||
|  |  | ||||||
| 		this.me = me; |  | ||||||
| 		this.os = os; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	public getConnection() { |  | ||||||
| 		if (this.connection == null) { |  | ||||||
| 			this.connection = new HomeStream(this.os, this.me); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		return this.connection; |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @@ -1,34 +0,0 @@ | |||||||
| import Stream from './stream'; |  | ||||||
| import StreamManager from './stream-manager'; |  | ||||||
| import MiOS from '../../../mios'; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Hybrid timeline stream connection |  | ||||||
|  */ |  | ||||||
| export class HybridTimelineStream extends Stream { |  | ||||||
| 	constructor(os: MiOS, me) { |  | ||||||
| 		super(os, 'hybrid-timeline', { |  | ||||||
| 			i: me.token |  | ||||||
| 		}); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| export class HybridTimelineStreamManager extends StreamManager<HybridTimelineStream> { |  | ||||||
| 	private me; |  | ||||||
| 	private os: MiOS; |  | ||||||
|  |  | ||||||
| 	constructor(os: MiOS, me) { |  | ||||||
| 		super(); |  | ||||||
|  |  | ||||||
| 		this.me = me; |  | ||||||
| 		this.os = os; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	public getConnection() { |  | ||||||
| 		if (this.connection == null) { |  | ||||||
| 			this.connection = new HybridTimelineStream(this.os, this.me); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		return this.connection; |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @@ -1,34 +0,0 @@ | |||||||
| import Stream from './stream'; |  | ||||||
| import StreamManager from './stream-manager'; |  | ||||||
| import MiOS from '../../../mios'; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Local timeline stream connection |  | ||||||
|  */ |  | ||||||
| export class LocalTimelineStream extends Stream { |  | ||||||
| 	constructor(os: MiOS, me) { |  | ||||||
| 		super(os, 'local-timeline', me ? { |  | ||||||
| 			i: me.token |  | ||||||
| 		} : {}); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| export class LocalTimelineStreamManager extends StreamManager<LocalTimelineStream> { |  | ||||||
| 	private me; |  | ||||||
| 	private os: MiOS; |  | ||||||
|  |  | ||||||
| 	constructor(os: MiOS, me) { |  | ||||||
| 		super(); |  | ||||||
|  |  | ||||||
| 		this.me = me; |  | ||||||
| 		this.os = os; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	public getConnection() { |  | ||||||
| 		if (this.connection == null) { |  | ||||||
| 			this.connection = new LocalTimelineStream(this.os, this.me); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		return this.connection; |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @@ -1,34 +0,0 @@ | |||||||
| import Stream from './stream'; |  | ||||||
| import StreamManager from './stream-manager'; |  | ||||||
| import MiOS from '../../../mios'; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Messaging index stream connection |  | ||||||
|  */ |  | ||||||
| export class MessagingIndexStream extends Stream { |  | ||||||
| 	constructor(os: MiOS, me) { |  | ||||||
| 		super(os, 'messaging-index', { |  | ||||||
| 			i: me.token |  | ||||||
| 		}); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| export class MessagingIndexStreamManager extends StreamManager<MessagingIndexStream> { |  | ||||||
| 	private me; |  | ||||||
| 	private os: MiOS; |  | ||||||
|  |  | ||||||
| 	constructor(os: MiOS, me) { |  | ||||||
| 		super(); |  | ||||||
|  |  | ||||||
| 		this.me = me; |  | ||||||
| 		this.os = os; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	public getConnection() { |  | ||||||
| 		if (this.connection == null) { |  | ||||||
| 			this.connection = new MessagingIndexStream(this.os, this.me); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		return this.connection; |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @@ -1,20 +0,0 @@ | |||||||
| import Stream from './stream'; |  | ||||||
| import MiOS from '../../../mios'; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Messaging stream connection |  | ||||||
|  */ |  | ||||||
| export class MessagingStream extends Stream { |  | ||||||
| 	constructor(os: MiOS, me, otherparty) { |  | ||||||
| 		super(os, 'messaging', { |  | ||||||
| 			i: me.token, |  | ||||||
| 			otherparty |  | ||||||
| 		}); |  | ||||||
|  |  | ||||||
| 		(this as any).on('_connected_', () => { |  | ||||||
| 			this.send({ |  | ||||||
| 				i: me.token |  | ||||||
| 			}); |  | ||||||
| 		}); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @@ -1,30 +0,0 @@ | |||||||
| import Stream from './stream'; |  | ||||||
| import StreamManager from './stream-manager'; |  | ||||||
| import MiOS from '../../../mios'; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Notes stats stream connection |  | ||||||
|  */ |  | ||||||
| export class NotesStatsStream extends Stream { |  | ||||||
| 	constructor(os: MiOS) { |  | ||||||
| 		super(os, 'notes-stats'); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| export class NotesStatsStreamManager extends StreamManager<NotesStatsStream> { |  | ||||||
| 	private os: MiOS; |  | ||||||
|  |  | ||||||
| 	constructor(os: MiOS) { |  | ||||||
| 		super(); |  | ||||||
|  |  | ||||||
| 		this.os = os; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	public getConnection() { |  | ||||||
| 		if (this.connection == null) { |  | ||||||
| 			this.connection = new NotesStatsStream(this.os); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		return this.connection; |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @@ -1,30 +0,0 @@ | |||||||
| import Stream from './stream'; |  | ||||||
| import StreamManager from './stream-manager'; |  | ||||||
| import MiOS from '../../../mios'; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Server stats stream connection |  | ||||||
|  */ |  | ||||||
| export class ServerStatsStream extends Stream { |  | ||||||
| 	constructor(os: MiOS) { |  | ||||||
| 		super(os, 'server-stats'); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| export class ServerStatsStreamManager extends StreamManager<ServerStatsStream> { |  | ||||||
| 	private os: MiOS; |  | ||||||
|  |  | ||||||
| 	constructor(os: MiOS) { |  | ||||||
| 		super(); |  | ||||||
|  |  | ||||||
| 		this.os = os; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	public getConnection() { |  | ||||||
| 		if (this.connection == null) { |  | ||||||
| 			this.connection = new ServerStatsStream(this.os); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		return this.connection; |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @@ -1,109 +0,0 @@ | |||||||
| import { EventEmitter } from 'eventemitter3'; |  | ||||||
| import * as uuid from 'uuid'; |  | ||||||
| import Connection from './stream'; |  | ||||||
| import { erase } from '../../../../../prelude/array'; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * ストリーム接続を管理するクラス |  | ||||||
|  * 複数の場所から同じストリームを利用する際、接続をまとめたりする |  | ||||||
|  */ |  | ||||||
| export default abstract class StreamManager<T extends Connection> extends EventEmitter { |  | ||||||
| 	private _connection: T = null; |  | ||||||
|  |  | ||||||
| 	private disposeTimerId: any; |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * コネクションを必要としているユーザー |  | ||||||
| 	 */ |  | ||||||
| 	private users = []; |  | ||||||
|  |  | ||||||
| 	protected set connection(connection: T) { |  | ||||||
| 		this._connection = connection; |  | ||||||
|  |  | ||||||
| 		if (this._connection == null) { |  | ||||||
| 			this.emit('disconnected'); |  | ||||||
| 		} else { |  | ||||||
| 			this.emit('connected', this._connection); |  | ||||||
|  |  | ||||||
| 			this._connection.on('_connected_', () => { |  | ||||||
| 				this.emit('_connected_'); |  | ||||||
| 			}); |  | ||||||
|  |  | ||||||
| 			this._connection.on('_disconnected_', () => { |  | ||||||
| 				this.emit('_disconnected_'); |  | ||||||
| 			}); |  | ||||||
|  |  | ||||||
| 			this._connection.user = 'Managed'; |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	protected get connection() { |  | ||||||
| 		return this._connection; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * コネクションを持っているか否か |  | ||||||
| 	 */ |  | ||||||
| 	public get hasConnection() { |  | ||||||
| 		return this._connection != null; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	public get state(): string { |  | ||||||
| 		if (!this.hasConnection) return 'no-connection'; |  | ||||||
| 		return this._connection.state; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * コネクションを要求します |  | ||||||
| 	 */ |  | ||||||
| 	public abstract getConnection(): T; |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * 現在接続しているコネクションを取得します |  | ||||||
| 	 */ |  | ||||||
| 	public borrow() { |  | ||||||
| 		return this._connection; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * コネクションを要求するためのユーザーIDを発行します |  | ||||||
| 	 */ |  | ||||||
| 	public use() { |  | ||||||
| 		// タイマー解除 |  | ||||||
| 		if (this.disposeTimerId) { |  | ||||||
| 			clearTimeout(this.disposeTimerId); |  | ||||||
| 			this.disposeTimerId = null; |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		// ユーザーID生成 |  | ||||||
| 		const userId = uuid(); |  | ||||||
|  |  | ||||||
| 		this.users.push(userId); |  | ||||||
|  |  | ||||||
| 		this._connection.user = `Managed (${ this.users.length })`; |  | ||||||
|  |  | ||||||
| 		return userId; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * コネクションを利用し終わってもう必要ないことを通知します |  | ||||||
| 	 * @param userId use で発行したユーザーID |  | ||||||
| 	 */ |  | ||||||
| 	public dispose(userId) { |  | ||||||
| 		this.users = erase(userId, this.users); |  | ||||||
|  |  | ||||||
| 		this._connection.user = `Managed (${ this.users.length })`; |  | ||||||
|  |  | ||||||
| 		// 誰もコネクションの利用者がいなくなったら |  | ||||||
| 		if (this.users.length == 0) { |  | ||||||
| 			// また直ぐに再利用される可能性があるので、一定時間待ち、 |  | ||||||
| 			// 新たな利用者が現れなければコネクションを切断する |  | ||||||
| 			this.disposeTimerId = setTimeout(() => { |  | ||||||
| 				this.disposeTimerId = null; |  | ||||||
|  |  | ||||||
| 				this.connection.close(); |  | ||||||
| 				this.connection = null; |  | ||||||
| 			}, 3000); |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @@ -1,137 +0,0 @@ | |||||||
| import { EventEmitter } from 'eventemitter3'; |  | ||||||
| import * as uuid from 'uuid'; |  | ||||||
| import * as ReconnectingWebsocket from 'reconnecting-websocket'; |  | ||||||
| import { wsUrl } from '../../../config'; |  | ||||||
| import MiOS from '../../../mios'; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Misskey stream connection |  | ||||||
|  */ |  | ||||||
| export default class Connection extends EventEmitter { |  | ||||||
| 	public state: string; |  | ||||||
| 	private buffer: any[]; |  | ||||||
| 	public socket: ReconnectingWebsocket; |  | ||||||
| 	public name: string; |  | ||||||
| 	public connectedAt: Date; |  | ||||||
| 	public user: string = null; |  | ||||||
| 	public in: number = 0; |  | ||||||
| 	public out: number = 0; |  | ||||||
| 	public inout: Array<{ |  | ||||||
| 		type: 'in' | 'out', |  | ||||||
| 		at: Date, |  | ||||||
| 		data: string |  | ||||||
| 	}> = []; |  | ||||||
| 	public id: string; |  | ||||||
| 	public isSuspended = false; |  | ||||||
| 	private os: MiOS; |  | ||||||
|  |  | ||||||
| 	constructor(os: MiOS, endpoint, params?) { |  | ||||||
| 		super(); |  | ||||||
|  |  | ||||||
| 		//#region BIND |  | ||||||
| 		this.onOpen =    this.onOpen.bind(this); |  | ||||||
| 		this.onClose =   this.onClose.bind(this); |  | ||||||
| 		this.onMessage = this.onMessage.bind(this); |  | ||||||
| 		this.send =      this.send.bind(this); |  | ||||||
| 		this.close =     this.close.bind(this); |  | ||||||
| 		//#endregion |  | ||||||
|  |  | ||||||
| 		this.id = uuid(); |  | ||||||
| 		this.os = os; |  | ||||||
| 		this.name = endpoint; |  | ||||||
| 		this.state = 'initializing'; |  | ||||||
| 		this.buffer = []; |  | ||||||
|  |  | ||||||
| 		const query = params |  | ||||||
| 			? Object.keys(params) |  | ||||||
| 				.map(k => `${encodeURIComponent(k)}=${encodeURIComponent(params[k])}`) |  | ||||||
| 				.join('&') |  | ||||||
| 			: null; |  | ||||||
|  |  | ||||||
| 		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); |  | ||||||
|  |  | ||||||
| 		// Register this connection for debugging |  | ||||||
| 		this.os.registerStreamConnection(this); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * Callback of when open connection |  | ||||||
| 	 */ |  | ||||||
| 	private onOpen() { |  | ||||||
| 		this.state = 'connected'; |  | ||||||
| 		this.emit('_connected_'); |  | ||||||
|  |  | ||||||
| 		this.connectedAt = new Date(); |  | ||||||
|  |  | ||||||
| 		// バッファーを処理 |  | ||||||
| 		const _buffer = [].concat(this.buffer); // Shallow copy |  | ||||||
| 		this.buffer = []; // Clear buffer |  | ||||||
| 		_buffer.forEach(data => { |  | ||||||
| 			this.send(data); // Resend each buffered messages |  | ||||||
|  |  | ||||||
| 			if (this.os.debug) { |  | ||||||
| 				this.out++; |  | ||||||
| 				this.inout.push({ type: 'out', at: new Date(), data }); |  | ||||||
| 			} |  | ||||||
| 		}); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * Callback of when close connection |  | ||||||
| 	 */ |  | ||||||
| 	private onClose() { |  | ||||||
| 		this.state = 'reconnecting'; |  | ||||||
| 		this.emit('_disconnected_'); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * Callback of when received a message from connection |  | ||||||
| 	 */ |  | ||||||
| 	private onMessage(message) { |  | ||||||
| 		if (this.isSuspended) return; |  | ||||||
|  |  | ||||||
| 		if (this.os.debug) { |  | ||||||
| 			this.in++; |  | ||||||
| 			this.inout.push({ type: 'in', at: new Date(), data: message.data }); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		try { |  | ||||||
| 			const msg = JSON.parse(message.data); |  | ||||||
| 			if (msg.type) this.emit(msg.type, msg.body); |  | ||||||
| 		} catch (e) { |  | ||||||
| 			// noop |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * Send a message to connection |  | ||||||
| 	 */ |  | ||||||
| 	public send(data) { |  | ||||||
| 		if (this.isSuspended) return; |  | ||||||
|  |  | ||||||
| 		// まだ接続が確立されていなかったらバッファリングして次に接続した時に送信する |  | ||||||
| 		if (this.state != 'connected') { |  | ||||||
| 			this.buffer.push(data); |  | ||||||
| 			return; |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		if (this.os.debug) { |  | ||||||
| 			this.out++; |  | ||||||
| 			this.inout.push({ type: 'out', at: new Date(), data }); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		this.socket.send(JSON.stringify(data)); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * Close this connection |  | ||||||
| 	 */ |  | ||||||
| 	public close() { |  | ||||||
| 		this.os.unregisterStreamConnection(this); |  | ||||||
| 		this.socket.removeEventListener('open', this.onOpen); |  | ||||||
| 		this.socket.removeEventListener('message', this.onMessage); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @@ -1,17 +0,0 @@ | |||||||
| import Stream from './stream'; |  | ||||||
| import MiOS from '../../mios'; |  | ||||||
|  |  | ||||||
| export class UserListStream extends Stream { |  | ||||||
| 	constructor(os: MiOS, me, listId) { |  | ||||||
| 		super(os, 'user-list', { |  | ||||||
| 			i: me.token, |  | ||||||
| 			listId |  | ||||||
| 		}); |  | ||||||
|  |  | ||||||
| 		(this as any).on('_connected_', () => { |  | ||||||
| 			this.send({ |  | ||||||
| 				i: me.token |  | ||||||
| 			}); |  | ||||||
| 		}); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @@ -259,15 +259,13 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' | .mk-autocomplete | ||||||
|  |  | ||||||
| root(isDark) |  | ||||||
| 	position fixed | 	position fixed | ||||||
| 	z-index 65535 | 	z-index 65535 | ||||||
| 	max-width 100% | 	max-width 100% | ||||||
| 	margin-top calc(1em + 8px) | 	margin-top calc(1em + 8px) | ||||||
| 	overflow hidden | 	overflow hidden | ||||||
| 	background isDark ? #313543 : #fff | 	background var(--faceHeader) | ||||||
| 	border solid 1px rgba(#000, 0.1) | 	border solid 1px rgba(#000, 0.1) | ||||||
| 	border-radius 4px | 	border-radius 4px | ||||||
| 	transition top 0.1s ease, left 0.1s ease | 	transition top 0.1s ease, left 0.1s ease | ||||||
| @@ -299,16 +297,16 @@ root(isDark) | |||||||
| 				text-overflow ellipsis | 				text-overflow ellipsis | ||||||
|  |  | ||||||
| 			&:hover | 			&:hover | ||||||
| 				background isDark ? rgba(#fff, 0.1) : rgba(#000, 0.1) | 				background var(--autocompleteItemHoverBg) | ||||||
|  |  | ||||||
| 			&[data-selected='true'] | 			&[data-selected='true'] | ||||||
| 				background $theme-color | 				background var(--primary) | ||||||
|  |  | ||||||
| 				&, * | 				&, * | ||||||
| 					color #fff !important | 					color #fff !important | ||||||
|  |  | ||||||
| 			&:active | 			&:active | ||||||
| 				background darken($theme-color, 10%) | 				background var(--primaryDarken10) | ||||||
|  |  | ||||||
| 				&, * | 				&, * | ||||||
| 					color #fff !important | 					color #fff !important | ||||||
| @@ -325,15 +323,15 @@ root(isDark) | |||||||
|  |  | ||||||
| 		.name | 		.name | ||||||
| 			margin 0 8px 0 0 | 			margin 0 8px 0 0 | ||||||
| 			color isDark ? rgba(#fff, 0.8) : rgba(#000, 0.8) | 			color var(--autocompleteItemText) | ||||||
|  |  | ||||||
| 		.username | 		.username | ||||||
| 			color isDark ? rgba(#fff, 0.3) : rgba(#000, 0.3) | 			color var(--autocompleteItemTextSub) | ||||||
|  |  | ||||||
| 	> .hashtags > li | 	> .hashtags > li | ||||||
|  |  | ||||||
| 		.name | 		.name | ||||||
| 			color isDark ? rgba(#fff, 0.8) : rgba(#000, 0.8) | 			color var(--autocompleteItemText) | ||||||
|  |  | ||||||
| 	> .emojis > li | 	> .emojis > li | ||||||
|  |  | ||||||
| @@ -343,15 +341,9 @@ root(isDark) | |||||||
| 			width 24px | 			width 24px | ||||||
|  |  | ||||||
| 		.name | 		.name | ||||||
| 			color isDark ? rgba(#fff, 0.8) : rgba(#000, 0.8) | 			color var(--autocompleteItemText) | ||||||
|  |  | ||||||
| 		.alias | 		.alias | ||||||
| 			margin 0 0 0 8px | 			margin 0 0 0 8px | ||||||
| 			color isDark ? rgba(#fff, 0.3) : rgba(#000, 0.3) | 			color var(--autocompleteItemTextSub) | ||||||
|  |  | ||||||
| .mk-autocomplete[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .mk-autocomplete:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -58,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: { | 	methods: { | ||||||
| 		onClick(e) { | 		onClick(e) { | ||||||
| 			this.$emit('click', e); | 			this.$emit('click', e); | ||||||
| @@ -67,8 +72,7 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
|  | .mk-avatar | ||||||
| root(isDark) |  | ||||||
| 	display inline-block | 	display inline-block | ||||||
| 	vertical-align bottom | 	vertical-align bottom | ||||||
|  |  | ||||||
| @@ -79,7 +83,7 @@ root(isDark) | |||||||
| 	&.cat::before, | 	&.cat::before, | ||||||
| 	&.cat::after | 	&.cat::after | ||||||
| 		background #df548f | 		background #df548f | ||||||
| 		border solid 4px isDark ? #e0eefd : #202224 | 		border solid 4px currentColor | ||||||
| 		box-sizing border-box | 		box-sizing border-box | ||||||
| 		content '' | 		content '' | ||||||
| 		display inline-block | 		display inline-block | ||||||
| @@ -105,9 +109,4 @@ root(isDark) | |||||||
| 		transition border-radius 1s ease | 		transition border-radius 1s ease | ||||||
| 		z-index 1 | 		z-index 1 | ||||||
|  |  | ||||||
| .mk-avatar[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .mk-avatar:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -39,7 +39,7 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' |  | ||||||
|  |  | ||||||
| .mk-connect-failed | .mk-connect-failed | ||||||
| 	width 100% | 	width 100% | ||||||
| @@ -70,17 +70,17 @@ export default Vue.extend({ | |||||||
| 		display block | 		display block | ||||||
| 		margin 1em auto 0 auto | 		margin 1em auto 0 auto | ||||||
| 		padding 8px 10px | 		padding 8px 10px | ||||||
| 		color $theme-color-foreground | 		color var(--primaryForeground) | ||||||
| 		background $theme-color | 		background var(--primary) | ||||||
|  |  | ||||||
| 		&:focus | 		&:focus | ||||||
| 			outline solid 3px rgba($theme-color, 0.3) | 			outline solid 3px var(--primaryAlpha03) | ||||||
|  |  | ||||||
| 		&:hover | 		&:hover | ||||||
| 			background lighten($theme-color, 10%) | 			background var(--primaryLighten10) | ||||||
|  |  | ||||||
| 		&:active | 		&:active | ||||||
| 			background darken($theme-color, 10%) | 			background var(--primaryDarken10) | ||||||
|  |  | ||||||
| 	> .thanks | 	> .thanks | ||||||
| 		display block | 		display block | ||||||
|   | |||||||
| @@ -22,23 +22,17 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| root(isDark) | .nrvgflfuaxwgkxoynpnumyookecqrrvh | ||||||
| 	display inline-block | 	display inline-block | ||||||
| 	padding 4px 8px | 	padding 4px 8px | ||||||
| 	font-size 0.7em | 	font-size 0.7em | ||||||
| 	color isDark ? #393f4f : #fff | 	color var(--cwButtonFg) | ||||||
| 	background isDark ? #687390 : #b1b9c1 | 	background var(--cwButtonBg) | ||||||
| 	border-radius 2px | 	border-radius 2px | ||||||
| 	cursor pointer | 	cursor pointer | ||||||
| 	user-select none | 	user-select none | ||||||
|  |  | ||||||
| 	&:hover | 	&:hover | ||||||
| 		background isDark ? #707b97 : #bbc4ce | 		background var(--cwButtonHoverBg) | ||||||
|  |  | ||||||
| .nrvgflfuaxwgkxoynpnumyookecqrrvh[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .nrvgflfuaxwgkxoynpnumyookecqrrvh:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' |  | ||||||
|  |  | ||||||
| .a | .a | ||||||
| 	display block | 	display block | ||||||
| @@ -18,8 +18,8 @@ | |||||||
| 		display block | 		display block | ||||||
| 		//fill #151513 | 		//fill #151513 | ||||||
| 		//color #fff | 		//color #fff | ||||||
| 		fill $theme-color | 		fill var(--primary) | ||||||
| 		color $theme-color-foreground | 		color var(--primaryForeground) | ||||||
|  |  | ||||||
| 		.octo-arm | 		.octo-arm | ||||||
| 			transform-origin 130px 106px | 			transform-origin 130px 106px | ||||||
|   | |||||||
| @@ -186,9 +186,8 @@ export default Vue.extend({ | |||||||
| 		if (this.game.isStarted && !this.game.isEnded) { | 		if (this.game.isStarted && !this.game.isEnded) { | ||||||
| 			this.pollingClock = setInterval(() => { | 			this.pollingClock = setInterval(() => { | ||||||
| 				const crc32 = CRC32.str(this.logs.map(x => x.pos.toString()).join('')); | 				const crc32 = CRC32.str(this.logs.map(x => x.pos.toString()).join('')); | ||||||
| 				this.connection.send({ | 				this.connection.send('check', { | ||||||
| 					type: 'check', | 					crc32: crc32 | ||||||
| 					crc32 |  | ||||||
| 				}); | 				}); | ||||||
| 			}, 3000); | 			}, 3000); | ||||||
| 		} | 		} | ||||||
| @@ -224,9 +223,8 @@ export default Vue.extend({ | |||||||
| 				sound.play(); | 				sound.play(); | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 			this.connection.send({ | 			this.connection.send('set', { | ||||||
| 				type: 'set', | 				pos: pos | ||||||
| 				pos |  | ||||||
| 			}); | 			}); | ||||||
|  |  | ||||||
| 			this.checkEnd(); | 			this.checkEnd(); | ||||||
| @@ -304,9 +302,7 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' | .xqnhankfuuilcwvhgsopeqncafzsquya | ||||||
|  |  | ||||||
| root(isDark) |  | ||||||
| 	text-align center | 	text-align center | ||||||
|  |  | ||||||
| 	> .go-index | 	> .go-index | ||||||
| @@ -319,7 +315,7 @@ root(isDark) | |||||||
|  |  | ||||||
| 	> header | 	> header | ||||||
| 		padding 8px | 		padding 8px | ||||||
| 		border-bottom dashed 1px isDark ? #4c5761 : #c4cdd4 | 		border-bottom dashed 1px var(--reversiGameHeaderLine) | ||||||
|  |  | ||||||
| 		a | 		a | ||||||
| 			color inherit | 			color inherit | ||||||
| @@ -386,30 +382,30 @@ root(isDark) | |||||||
| 						user-select none | 						user-select none | ||||||
|  |  | ||||||
| 					&.empty | 					&.empty | ||||||
| 						border solid 2px isDark ? #51595f : #eee | 						border solid 2px var(--reversiGameEmptyCell) | ||||||
|  |  | ||||||
| 					&.empty.can | 					&.empty.can | ||||||
| 						background isDark ? #51595f : #eee | 						background var(--reversiGameEmptyCell) | ||||||
|  |  | ||||||
| 					&.empty.myTurn | 					&.empty.myTurn | ||||||
| 						border-color isDark ? #6a767f : #ddd | 						border-color var(--reversiGameEmptyCellMyTurn) | ||||||
|  |  | ||||||
| 						&.can | 						&.can | ||||||
| 							background isDark ? #51595f : #eee | 							background var(--reversiGameEmptyCellCanPut) | ||||||
| 							cursor pointer | 							cursor pointer | ||||||
|  |  | ||||||
| 							&:hover | 							&:hover | ||||||
| 								border-color darken($theme-color, 10%) | 								border-color var(--primaryDarken10) | ||||||
| 								background $theme-color | 								background var(--primary) | ||||||
|  |  | ||||||
| 							&:active | 							&:active | ||||||
| 								background darken($theme-color, 10%) | 								background var(--primaryDarken10) | ||||||
|  |  | ||||||
| 					&.prev | 					&.prev | ||||||
| 						box-shadow 0 0 0 4px rgba($theme-color, 0.7) | 						box-shadow 0 0 0 4px var(--primaryAlpha07) | ||||||
|  |  | ||||||
| 					&.isEnded | 					&.isEnded | ||||||
| 						border-color isDark ? #6a767f : #ddd | 						border-color var(--reversiGameEmptyCellMyTurn) | ||||||
|  |  | ||||||
| 					&.none | 					&.none | ||||||
| 						border-color transparent !important | 						border-color transparent !important | ||||||
| @@ -458,10 +454,4 @@ root(isDark) | |||||||
| 			margin 0 8px | 			margin 0 8px | ||||||
| 			min-width 70px | 			min-width 70px | ||||||
|  |  | ||||||
| .xqnhankfuuilcwvhgsopeqncafzsquya[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .xqnhankfuuilcwvhgsopeqncafzsquya:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -9,7 +9,6 @@ | |||||||
| import Vue from 'vue'; | import Vue from 'vue'; | ||||||
| import XGame from './reversi.game.vue'; | import XGame from './reversi.game.vue'; | ||||||
| import XRoom from './reversi.room.vue'; | import XRoom from './reversi.room.vue'; | ||||||
| import { ReversiGameStream } from '../../../../scripts/streaming/games/reversi/reversi-game'; |  | ||||||
|  |  | ||||||
| export default Vue.extend({ | export default Vue.extend({ | ||||||
| 	components: { | 	components: { | ||||||
| @@ -34,12 +33,13 @@ export default Vue.extend({ | |||||||
| 	}, | 	}, | ||||||
| 	created() { | 	created() { | ||||||
| 		this.g = this.game; | 		this.g = this.game; | ||||||
| 		this.connection = new ReversiGameStream((this as any).os, this.$store.state.i, this.game); | 		this.connection = (this as any).os.stream.connectToChannel('gamesReversiGame', { | ||||||
|  | 			gameId: this.game.id | ||||||
|  | 		}); | ||||||
| 		this.connection.on('started', this.onStarted); | 		this.connection.on('started', this.onStarted); | ||||||
| 	}, | 	}, | ||||||
| 	beforeDestroy() { | 	beforeDestroy() { | ||||||
| 		this.connection.off('started', this.onStarted); | 		this.connection.dispose(); | ||||||
| 		this.connection.close(); |  | ||||||
| 	}, | 	}, | ||||||
| 	methods: { | 	methods: { | ||||||
| 		onStarted(game) { | 		onStarted(game) { | ||||||
|   | |||||||
| @@ -59,15 +59,13 @@ export default Vue.extend({ | |||||||
| 			myGames: [], | 			myGames: [], | ||||||
| 			matching: null, | 			matching: null, | ||||||
| 			invitations: [], | 			invitations: [], | ||||||
| 			connection: null, | 			connection: null | ||||||
| 			connectionId: null |  | ||||||
| 		}; | 		}; | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| 	mounted() { | 	mounted() { | ||||||
| 		if (this.$store.getters.isSignedIn) { | 		if (this.$store.getters.isSignedIn) { | ||||||
| 			this.connection = (this as any).os.streams.reversiStream.getConnection(); | 			this.connection = (this as any).os.stream.useSharedConnection('gamesReversi'); | ||||||
| 			this.connectionId = (this as any).os.streams.reversiStream.use(); |  | ||||||
|  |  | ||||||
| 			this.connection.on('invited', this.onInvited); | 			this.connection.on('invited', this.onInvited); | ||||||
|  |  | ||||||
| @@ -90,8 +88,7 @@ export default Vue.extend({ | |||||||
|  |  | ||||||
| 	beforeDestroy() { | 	beforeDestroy() { | ||||||
| 		if (this.connection) { | 		if (this.connection) { | ||||||
| 			this.connection.off('invited', this.onInvited); | 			this.connection.dispose(); | ||||||
| 			(this as any).os.streams.reversiStream.dispose(this.connectionId); |  | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| @@ -138,9 +135,7 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' | .phgnkghfpyvkrvwiajkiuoxyrdaqpzcx | ||||||
|  |  | ||||||
| root(isDark) |  | ||||||
| 	> h1 | 	> h1 | ||||||
| 		margin 0 | 		margin 0 | ||||||
| 		padding 24px | 		padding 24px | ||||||
| @@ -148,7 +143,7 @@ root(isDark) | |||||||
| 		text-align center | 		text-align center | ||||||
| 		font-weight normal | 		font-weight normal | ||||||
| 		color #fff | 		color #fff | ||||||
| 		background linear-gradient(to bottom, isDark ? #45730e : #8bca3e, isDark ? #464300 : #d6cf31) | 		background linear-gradient(to bottom, var(--reversiBannerGradientStart), var(--reversiBannerGradientEnd)) | ||||||
|  |  | ||||||
| 		& + p | 		& + p | ||||||
| 			margin 0 | 			margin 0 | ||||||
| @@ -156,7 +151,7 @@ root(isDark) | |||||||
| 			margin-bottom 12px | 			margin-bottom 12px | ||||||
| 			text-align center | 			text-align center | ||||||
| 			font-size 14px | 			font-size 14px | ||||||
| 			border-bottom solid 1px isDark ? #535f65 : #d3d9dc | 			border-bottom solid 1px var(--faceDivider) | ||||||
|  |  | ||||||
| 	> .play | 	> .play | ||||||
| 		margin 0 auto | 		margin 0 auto | ||||||
| @@ -171,14 +166,14 @@ root(isDark) | |||||||
| 				padding 16px | 				padding 16px | ||||||
| 				font-size 14px | 				font-size 14px | ||||||
| 				text-align left | 				text-align left | ||||||
| 				background isDark ? #282c37 : #f5f5f5 | 				background var(--reversiDescBg) | ||||||
| 				border-radius 8px | 				border-radius 8px | ||||||
|  |  | ||||||
| 	> section | 	> section | ||||||
| 		margin 0 auto | 		margin 0 auto | ||||||
| 		padding 0 16px 16px 16px | 		padding 0 16px 16px 16px | ||||||
| 		max-width 500px | 		max-width 500px | ||||||
| 		border-top solid 1px isDark ? #535f65 : #d3d9dc | 		border-top solid 1px var(--faceDivider) | ||||||
|  |  | ||||||
| 		> h2 | 		> h2 | ||||||
| 			margin 0 | 			margin 0 | ||||||
| @@ -189,9 +184,9 @@ root(isDark) | |||||||
| 	.invitation | 	.invitation | ||||||
| 		margin 8px 0 | 		margin 8px 0 | ||||||
| 		padding 8px | 		padding 8px | ||||||
| 		color isDark ? #fff : #677f84 | 		color var(--text) | ||||||
| 		background isDark ? #282c37 : #fff | 		background var(--face) | ||||||
| 		box-shadow 0 2px 16px rgba(#000, isDark ? 0.7 : 0.15) | 		box-shadow 0 2px 16px var(--reversiListItemShadow) | ||||||
| 		border-radius 6px | 		border-radius 6px | ||||||
| 		cursor pointer | 		cursor pointer | ||||||
|  |  | ||||||
| @@ -200,13 +195,13 @@ root(isDark) | |||||||
| 			user-select none | 			user-select none | ||||||
|  |  | ||||||
| 		&:focus | 		&:focus | ||||||
| 			border-color $theme-color | 			border-color var(--primary) | ||||||
|  |  | ||||||
| 		&:hover | 		&:hover | ||||||
| 			background isDark ? #313543 : #f5f5f5 | 			box-shadow 0 0 0 100px inset rgba(0, 0, 0, 0.05) | ||||||
|  |  | ||||||
| 		&:active | 		&:active | ||||||
| 			background isDark ? #1e222b : #eee | 			box-shadow 0 0 0 100px inset rgba(0, 0, 0, 0.1) | ||||||
|  |  | ||||||
| 		> .avatar | 		> .avatar | ||||||
| 			width 32px | 			width 32px | ||||||
| @@ -221,9 +216,9 @@ root(isDark) | |||||||
| 		display block | 		display block | ||||||
| 		margin 8px 0 | 		margin 8px 0 | ||||||
| 		padding 8px | 		padding 8px | ||||||
| 		color isDark ? #fff : #677f84 | 		color var(--text) | ||||||
| 		background isDark ? #282c37 : #fff | 		background var(--face) | ||||||
| 		box-shadow 0 2px 16px rgba(#000, isDark ? 0.7 : 0.15) | 		box-shadow 0 2px 16px var(--reversiListItemShadow) | ||||||
| 		border-radius 6px | 		border-radius 6px | ||||||
| 		cursor pointer | 		cursor pointer | ||||||
|  |  | ||||||
| @@ -232,10 +227,10 @@ root(isDark) | |||||||
| 			user-select none | 			user-select none | ||||||
|  |  | ||||||
| 		&:hover | 		&:hover | ||||||
| 			background isDark ? #313543 : #f5f5f5 | 			box-shadow 0 0 0 100px inset rgba(0, 0, 0, 0.05) | ||||||
|  |  | ||||||
| 		&:active | 		&:active | ||||||
| 			background isDark ? #1e222b : #eee | 			box-shadow 0 0 0 100px inset rgba(0, 0, 0, 0.1) | ||||||
|  |  | ||||||
| 		> .avatar | 		> .avatar | ||||||
| 			width 32px | 			width 32px | ||||||
| @@ -246,10 +241,4 @@ root(isDark) | |||||||
| 			margin 0 8px | 			margin 0 8px | ||||||
| 			line-height 32px | 			line-height 32px | ||||||
|  |  | ||||||
| .phgnkghfpyvkrvwiajkiuoxyrdaqpzcx[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .phgnkghfpyvkrvwiajkiuoxyrdaqpzcx:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -47,9 +47,9 @@ | |||||||
| 			</header> | 			</header> | ||||||
|  |  | ||||||
| 			<div> | 			<div> | ||||||
| 				<mk-switch v-model="game.settings.isLlotheo" @change="updateSettings" text="%i18n:@is-llotheo%"/> | 				<ui-switch v-model="game.settings.isLlotheo" @change="updateSettings">%i18n:@is-llotheo%</ui-switch> | ||||||
| 				<mk-switch v-model="game.settings.loopedBoard" @change="updateSettings" text="%i18n:@looped-map%"/> | 				<ui-switch v-model="game.settings.loopedBoard" @change="updateSettings">%i18n:@looped-map%</ui-switch> | ||||||
| 				<mk-switch v-model="game.settings.canPutEverywhere" @change="updateSettings" text="%i18n:@can-put-everywhere%"/> | 				<ui-switch v-model="game.settings.canPutEverywhere" @change="updateSettings">%i18n:@can-put-everywhere%</ui-switch> | ||||||
| 			</div> | 			</div> | ||||||
| 		</div> | 		</div> | ||||||
|  |  | ||||||
| @@ -60,7 +60,7 @@ | |||||||
|  |  | ||||||
| 			<div> | 			<div> | ||||||
| 				<template v-for="item in form"> | 				<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"> | 					<div class="card" v-if="item.type == 'radio'" :key="item.id"> | ||||||
| 						<header> | 						<header> | ||||||
| @@ -149,9 +149,9 @@ export default Vue.extend({ | |||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| 	created() { | 	created() { | ||||||
| 		this.connection.on('change-accepts', this.onChangeAccepts); | 		this.connection.on('changeAccepts', this.onChangeAccepts); | ||||||
| 		this.connection.on('update-settings', this.onUpdateSettings); | 		this.connection.on('updateSettings', this.onUpdateSettings); | ||||||
| 		this.connection.on('init-form', this.onInitForm); | 		this.connection.on('initForm', this.onInitForm); | ||||||
| 		this.connection.on('message', this.onMessage); | 		this.connection.on('message', this.onMessage); | ||||||
|  |  | ||||||
| 		if (this.game.user1Id != this.$store.state.i.id && this.game.settings.form1) this.form = this.game.settings.form1; | 		if (this.game.user1Id != this.$store.state.i.id && this.game.settings.form1) this.form = this.game.settings.form1; | ||||||
| @@ -159,9 +159,9 @@ export default Vue.extend({ | |||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| 	beforeDestroy() { | 	beforeDestroy() { | ||||||
| 		this.connection.off('change-accepts', this.onChangeAccepts); | 		this.connection.off('changeAccepts', this.onChangeAccepts); | ||||||
| 		this.connection.off('update-settings', this.onUpdateSettings); | 		this.connection.off('updateSettings', this.onUpdateSettings); | ||||||
| 		this.connection.off('init-form', this.onInitForm); | 		this.connection.off('initForm', this.onInitForm); | ||||||
| 		this.connection.off('message', this.onMessage); | 		this.connection.off('message', this.onMessage); | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| @@ -171,15 +171,11 @@ export default Vue.extend({ | |||||||
| 		}, | 		}, | ||||||
|  |  | ||||||
| 		accept() { | 		accept() { | ||||||
| 			this.connection.send({ | 			this.connection.send('accept', {}); | ||||||
| 				type: 'accept' |  | ||||||
| 			}); |  | ||||||
| 		}, | 		}, | ||||||
|  |  | ||||||
| 		cancel() { | 		cancel() { | ||||||
| 			this.connection.send({ | 			this.connection.send('cancelAccept', {}); | ||||||
| 				type: 'cancel-accept' |  | ||||||
| 			}); |  | ||||||
| 		}, | 		}, | ||||||
|  |  | ||||||
| 		onChangeAccepts(accepts) { | 		onChangeAccepts(accepts) { | ||||||
| @@ -189,8 +185,7 @@ export default Vue.extend({ | |||||||
| 		}, | 		}, | ||||||
|  |  | ||||||
| 		updateSettings() { | 		updateSettings() { | ||||||
| 			this.connection.send({ | 			this.connection.send('updateSettings', { | ||||||
| 				type: 'update-settings', |  | ||||||
| 				settings: this.game.settings | 				settings: this.game.settings | ||||||
| 			}); | 			}); | ||||||
| 		}, | 		}, | ||||||
| @@ -216,8 +211,7 @@ export default Vue.extend({ | |||||||
| 		}, | 		}, | ||||||
|  |  | ||||||
| 		onChangeForm(item) { | 		onChangeForm(item) { | ||||||
| 			this.connection.send({ | 			this.connection.send('updateForm', { | ||||||
| 				type: 'update-form', |  | ||||||
| 				id: item.id, | 				id: item.id, | ||||||
| 				value: item.value | 				value: item.value | ||||||
| 			}); | 			}); | ||||||
| @@ -238,9 +232,9 @@ export default Vue.extend({ | |||||||
| 			const y = Math.floor(pos / this.game.settings.map[0].length); | 			const y = Math.floor(pos / this.game.settings.map[0].length); | ||||||
| 			const newPixel = | 			const newPixel = | ||||||
| 				pixel == ' ' ? '-' : | 				pixel == ' ' ? '-' : | ||||||
| 					pixel == '-' ? 'b' : | 				pixel == '-' ? 'b' : | ||||||
| 						pixel == 'b' ? 'w' : | 				pixel == 'b' ? 'w' : | ||||||
| 							' '; | 				' '; | ||||||
| 			const line = this.game.settings.map[y].split(''); | 			const line = this.game.settings.map[y].split(''); | ||||||
| 			line[x] = newPixel; | 			line[x] = newPixel; | ||||||
| 			this.$set(this.game.settings.map, y, line.join('')); | 			this.$set(this.game.settings.map, y, line.join('')); | ||||||
| @@ -252,11 +246,9 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' | .urbixznjwwuukfsckrwzwsqzsxornqij | ||||||
|  |  | ||||||
| root(isDark) |  | ||||||
| 	text-align center | 	text-align center | ||||||
| 	background isDark ? #191b22 : #f9f9f9 | 	background var(--bg) | ||||||
|  |  | ||||||
| 	> header | 	> header | ||||||
| 		padding 8px | 		padding 8px | ||||||
| @@ -273,10 +265,10 @@ root(isDark) | |||||||
| 					> select | 					> select | ||||||
| 						width 100% | 						width 100% | ||||||
| 						padding 12px 14px | 						padding 12px 14px | ||||||
| 						background isDark ? #282C37 : #fff | 						background var(--face) | ||||||
| 						border 1px solid isDark ? #6a707d : #dcdfe6 | 						border 1px solid var(--reversiMapSelectBorder) | ||||||
| 						border-radius 4px | 						border-radius 4px | ||||||
| 						color isDark ? #fff : #606266 | 						color var(--text) | ||||||
| 						cursor pointer | 						cursor pointer | ||||||
| 						transition border-color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1) | 						transition border-color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1) | ||||||
| 						-webkit-appearance none | 						-webkit-appearance none | ||||||
| @@ -284,17 +276,18 @@ root(isDark) | |||||||
| 						appearance none | 						appearance none | ||||||
|  |  | ||||||
| 						&:hover | 						&:hover | ||||||
| 							border-color isDark ? #a7aebd : #c0c4cc | 							border-color var(--reversiMapSelectHoverBorder) | ||||||
|  |  | ||||||
| 						&:focus | 						&:focus | ||||||
| 						&:active | 						&:active | ||||||
| 							border-color $theme-color | 							border-color var(--primary) | ||||||
|  |  | ||||||
| 				> div | 				> div | ||||||
| 					> .random | 					> .random | ||||||
| 						padding 32px 0 | 						padding 32px 0 | ||||||
| 						font-size 64px | 						font-size 64px | ||||||
| 						color isDark ? #4e5961 : #d8d8d8 | 						color var(--text) | ||||||
|  | 						opacity 0.7 | ||||||
|  |  | ||||||
| 					> .board | 					> .board | ||||||
| 						display grid | 						display grid | ||||||
| @@ -302,11 +295,11 @@ root(isDark) | |||||||
| 						width 300px | 						width 300px | ||||||
| 						height 300px | 						height 300px | ||||||
| 						margin 0 auto | 						margin 0 auto | ||||||
| 						color isDark ? #fff : #444 | 						color var(--text) | ||||||
|  |  | ||||||
| 						> div | 						> div | ||||||
| 							background transparent | 							background transparent | ||||||
| 							border solid 2px isDark ? #6a767f : #ddd | 							border solid 2px var(--faceDivider) | ||||||
| 							border-radius 6px | 							border-radius 6px | ||||||
| 							overflow hidden | 							overflow hidden | ||||||
| 							cursor pointer | 							cursor pointer | ||||||
| @@ -331,32 +324,26 @@ root(isDark) | |||||||
| 		.card | 		.card | ||||||
| 			max-width 400px | 			max-width 400px | ||||||
| 			border-radius 4px | 			border-radius 4px | ||||||
| 			background isDark ? #282C37 : #fff | 			background var(--face) | ||||||
| 			color isDark ? #fff : #303133 | 			color var(--text) | ||||||
| 			box-shadow 0 2px 12px 0 rgba(#000, isDark ? 0.7 : 0.1) | 			box-shadow 0 2px 12px 0 var(--reversiRoomFormShadow) | ||||||
|  |  | ||||||
| 			> header | 			> header | ||||||
| 				padding 18px 20px | 				padding 18px 20px | ||||||
| 				border-bottom 1px solid isDark ? #1c2023 : #ebeef5 | 				border-bottom 1px solid var(--faceDivider) | ||||||
|  |  | ||||||
| 			> div | 			> div | ||||||
| 				padding 20px | 				padding 20px | ||||||
| 				color isDark ? #fff : #606266 | 				color var(--text) | ||||||
|  |  | ||||||
| 	> footer | 	> footer | ||||||
| 		position sticky | 		position sticky | ||||||
| 		bottom 0 | 		bottom 0 | ||||||
| 		padding 16px | 		padding 16px | ||||||
| 		background rgba(isDark ? #191b22 : #fff, 0.9) | 		background var(--reversiRoomFooterBg) | ||||||
| 		border-top solid 1px isDark ? #606266 : #c4cdd4 | 		border-top solid 1px var(--faceDivider) | ||||||
|  |  | ||||||
| 		> .status | 		> .status | ||||||
| 			margin 0 0 16px 0 | 			margin 0 0 16px 0 | ||||||
|  |  | ||||||
| .urbixznjwwuukfsckrwzwsqzsxornqij[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .urbixznjwwuukfsckrwzwsqzsxornqij:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -47,7 +47,6 @@ export default Vue.extend({ | |||||||
| 			game: null, | 			game: null, | ||||||
| 			matching: null, | 			matching: null, | ||||||
| 			connection: null, | 			connection: null, | ||||||
| 			connectionId: null, |  | ||||||
| 			pingClock: null | 			pingClock: null | ||||||
| 		}; | 		}; | ||||||
| 	}, | 	}, | ||||||
| @@ -66,15 +65,13 @@ export default Vue.extend({ | |||||||
| 		this.fetch(); | 		this.fetch(); | ||||||
|  |  | ||||||
| 		if (this.$store.getters.isSignedIn) { | 		if (this.$store.getters.isSignedIn) { | ||||||
| 			this.connection = (this as any).os.streams.reversiStream.getConnection(); | 			this.connection = (this as any).os.stream.useSharedConnection('gamesReversi'); | ||||||
| 			this.connectionId = (this as any).os.streams.reversiStream.use(); |  | ||||||
|  |  | ||||||
| 			this.connection.on('matched', this.onMatched); | 			this.connection.on('matched', this.onMatched); | ||||||
|  |  | ||||||
| 			this.pingClock = setInterval(() => { | 			this.pingClock = setInterval(() => { | ||||||
| 				if (this.matching) { | 				if (this.matching) { | ||||||
| 					this.connection.send({ | 					this.connection.send('ping', { | ||||||
| 						type: 'ping', |  | ||||||
| 						id: this.matching.id | 						id: this.matching.id | ||||||
| 					}); | 					}); | ||||||
| 				} | 				} | ||||||
| @@ -84,9 +81,7 @@ export default Vue.extend({ | |||||||
|  |  | ||||||
| 	beforeDestroy() { | 	beforeDestroy() { | ||||||
| 		if (this.connection) { | 		if (this.connection) { | ||||||
| 			this.connection.off('matched', this.onMatched); | 			this.connection.dispose(); | ||||||
| 			(this as any).os.streams.reversiStream.dispose(this.connectionId); |  | ||||||
|  |  | ||||||
| 			clearInterval(this.pingClock); | 			clearInterval(this.pingClock); | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| @@ -156,11 +151,9 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' | .vchtoekanapleubgzioubdtmlkribzfd | ||||||
|  | 	color var(--text) | ||||||
| root(isDark) | 	background var(--bg) | ||||||
| 	color isDark ? #fff : #677f84 |  | ||||||
| 	background isDark ? #191b22 : #fff |  | ||||||
|  |  | ||||||
| 	> .matching | 	> .matching | ||||||
| 		> h1 | 		> h1 | ||||||
| @@ -177,10 +170,4 @@ root(isDark) | |||||||
| 			text-align center | 			text-align center | ||||||
| 			border-top dashed 1px #c4cdd4 | 			border-top dashed 1px #c4cdd4 | ||||||
|  |  | ||||||
| .vchtoekanapleubgzioubdtmlkribzfd[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .vchtoekanapleubgzioubdtmlkribzfd:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -26,7 +26,7 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| root(isDark) | .mk-google | ||||||
| 	display flex | 	display flex | ||||||
| 	margin 8px 0 | 	margin 8px 0 | ||||||
|  |  | ||||||
| @@ -37,31 +37,25 @@ root(isDark) | |||||||
| 		height 40px | 		height 40px | ||||||
| 		font-family sans-serif | 		font-family sans-serif | ||||||
| 		font-size 16px | 		font-size 16px | ||||||
| 		color isDark ? #dee4e8 : #55595c | 		color var(--googleSearchFg) | ||||||
| 		background isDark ? #191b22 : #fff | 		background var(--googleSearchBg) | ||||||
| 		border solid 1px isDark ? #495156 : #dadada | 		border solid 1px var(--googleSearchBorder) | ||||||
| 		border-radius 4px 0 0 4px | 		border-radius 4px 0 0 4px | ||||||
|  |  | ||||||
| 		&:hover | 		&:hover | ||||||
| 			border-color isDark ? #777c86 : #b0b0b0 | 			border-color var(--googleSearchHoverBorder) | ||||||
|  |  | ||||||
| 	> button | 	> button | ||||||
| 		flex-shrink 0 | 		flex-shrink 0 | ||||||
| 		padding 0 16px | 		padding 0 16px | ||||||
| 		border solid 1px isDark ? #495156 : #dadada | 		border solid 1px var(--googleSearchBorder) | ||||||
| 		border-left none | 		border-left none | ||||||
| 		border-radius 0 4px 4px 0 | 		border-radius 0 4px 4px 0 | ||||||
|  |  | ||||||
| 		&:hover | 		&:hover | ||||||
| 			background-color isDark ? #2e3440 : #eee | 			background-color var(--googleSearchHoverButton) | ||||||
|  |  | ||||||
| 		&:active | 		&:active | ||||||
| 			box-shadow 0 2px 4px rgba(#000, 0.15) inset | 			box-shadow 0 2px 4px rgba(#000, 0.15) inset | ||||||
|  |  | ||||||
| .mk-google[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .mk-google:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -1,5 +1,9 @@ | |||||||
| import Vue from 'vue'; | import Vue from 'vue'; | ||||||
|  |  | ||||||
|  | import profileEditor from './profile-editor.vue'; | ||||||
|  | import noteSkeleton from './note-skeleton.vue'; | ||||||
|  | import theme from './theme.vue'; | ||||||
|  | import instance from './instance.vue'; | ||||||
| import cwButton from './cw-button.vue'; | import cwButton from './cw-button.vue'; | ||||||
| import tagCloud from './tag-cloud.vue'; | import tagCloud from './tag-cloud.vue'; | ||||||
| import trends from './trends.vue'; | import trends from './trends.vue'; | ||||||
| @@ -29,7 +33,6 @@ import messagingRoom from './messaging-room.vue'; | |||||||
| import urlPreview from './url-preview.vue'; | import urlPreview from './url-preview.vue'; | ||||||
| import twitterSetting from './twitter-setting.vue'; | import twitterSetting from './twitter-setting.vue'; | ||||||
| import fileTypeIcon from './file-type-icon.vue'; | import fileTypeIcon from './file-type-icon.vue'; | ||||||
| import Switch from './switch.vue'; |  | ||||||
| import Reversi from './games/reversi/reversi.vue'; | import Reversi from './games/reversi/reversi.vue'; | ||||||
| import welcomeTimeline from './welcome-timeline.vue'; | import welcomeTimeline from './welcome-timeline.vue'; | ||||||
| import uiInput from './ui/input.vue'; | import uiInput from './ui/input.vue'; | ||||||
| @@ -43,6 +46,10 @@ import uiSelect from './ui/select.vue'; | |||||||
| import formButton from './ui/form/button.vue'; | import formButton from './ui/form/button.vue'; | ||||||
| import formRadio from './ui/form/radio.vue'; | import formRadio from './ui/form/radio.vue'; | ||||||
|  |  | ||||||
|  | Vue.component('mk-profile-editor', profileEditor); | ||||||
|  | Vue.component('mk-note-skeleton', noteSkeleton); | ||||||
|  | Vue.component('mk-theme', theme); | ||||||
|  | Vue.component('mk-instance', instance); | ||||||
| Vue.component('mk-cw-button', cwButton); | Vue.component('mk-cw-button', cwButton); | ||||||
| Vue.component('mk-tag-cloud', tagCloud); | Vue.component('mk-tag-cloud', tagCloud); | ||||||
| Vue.component('mk-trends', trends); | Vue.component('mk-trends', trends); | ||||||
| @@ -72,7 +79,6 @@ Vue.component('mk-messaging-room', messagingRoom); | |||||||
| Vue.component('mk-url-preview', urlPreview); | Vue.component('mk-url-preview', urlPreview); | ||||||
| Vue.component('mk-twitter-setting', twitterSetting); | Vue.component('mk-twitter-setting', twitterSetting); | ||||||
| Vue.component('mk-file-type-icon', fileTypeIcon); | Vue.component('mk-file-type-icon', fileTypeIcon); | ||||||
| Vue.component('mk-switch', Switch); |  | ||||||
| Vue.component('mk-reversi', Reversi); | Vue.component('mk-reversi', Reversi); | ||||||
| Vue.component('mk-welcome-timeline', welcomeTimeline); | Vue.component('mk-welcome-timeline', welcomeTimeline); | ||||||
| Vue.component('ui-input', uiInput); | 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> | ||||||
| @@ -43,7 +43,7 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| root(isDark) | .mk-media-banner | ||||||
| 	width 100% | 	width 100% | ||||||
| 	border-radius 4px | 	border-radius 4px | ||||||
| 	margin-top 4px | 	margin-top 4px | ||||||
| @@ -71,7 +71,7 @@ root(isDark) | |||||||
| 			font-size 1.6em | 			font-size 1.6em | ||||||
|  |  | ||||||
| 	> .download | 	> .download | ||||||
| 		background isDark ? #21242d : #f7f7f7 | 		background var(--noteAttachedFile) | ||||||
|  |  | ||||||
| 	> .sensitive | 	> .sensitive | ||||||
| 		background #111 | 		background #111 | ||||||
| @@ -82,9 +82,4 @@ root(isDark) | |||||||
| 			display block | 			display block | ||||||
| 			width 100% | 			width 100% | ||||||
|  |  | ||||||
| .mk-media-banner[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .mk-media-banner:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -117,10 +117,8 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' | .onchrpzrvnoruiaenfcqvccjfuupzzwv | ||||||
|  | 	$bg-color = var(--popupBg) | ||||||
| root(isDark) |  | ||||||
| 	$bg-color = isDark ? #2c303c : #fff |  | ||||||
| 	$border-color = rgba(27, 31, 35, 0.15) | 	$border-color = rgba(27, 31, 35, 0.15) | ||||||
|  |  | ||||||
| 	position initial | 	position initial | ||||||
| @@ -132,7 +130,7 @@ root(isDark) | |||||||
| 		z-index 10000 | 		z-index 10000 | ||||||
| 		width 100% | 		width 100% | ||||||
| 		height 100% | 		height 100% | ||||||
| 		background rgba(#000, isDark ? 0.5 : 0.1) | 		background var(--modalBackdrop) | ||||||
| 		opacity 0 | 		opacity 0 | ||||||
|  |  | ||||||
| 	> .popover | 	> .popover | ||||||
| @@ -179,26 +177,20 @@ root(isDark) | |||||||
| 			display block | 			display block | ||||||
| 			padding 8px 16px | 			padding 8px 16px | ||||||
| 			width 100% | 			width 100% | ||||||
| 			color isDark ? #d6dce2 : #111 | 			color var(--popupFg) | ||||||
|  |  | ||||||
| 			&:hover | 			&:hover | ||||||
| 				color $theme-color-foreground | 				color var(--primaryForeground) | ||||||
| 				background $theme-color | 				background var(--primary) | ||||||
| 				text-decoration none | 				text-decoration none | ||||||
|  |  | ||||||
| 			&:active | 			&:active | ||||||
| 				color $theme-color-foreground | 				color var(--primaryForeground) | ||||||
| 				background darken($theme-color, 10%) | 				background var(--primaryDarken10) | ||||||
|  |  | ||||||
| 		> div | 		> div | ||||||
| 			margin 8px 0 | 			margin 8px 0 | ||||||
| 			height 1px | 			height 1px | ||||||
| 			background isDark ? #1c2023 : #eee | 			background var(--faceDivider) | ||||||
|  |  | ||||||
| .onchrpzrvnoruiaenfcqvccjfuupzzwv[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .onchrpzrvnoruiaenfcqvccjfuupzzwv:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -195,9 +195,7 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' | .mk-messaging-form | ||||||
|  |  | ||||||
| root(isDark) |  | ||||||
| 	> textarea | 	> textarea | ||||||
| 		cursor auto | 		cursor auto | ||||||
| 		display block | 		display block | ||||||
| @@ -209,10 +207,10 @@ root(isDark) | |||||||
| 		padding 8px | 		padding 8px | ||||||
| 		resize none | 		resize none | ||||||
| 		font-size 1em | 		font-size 1em | ||||||
| 		color isDark ? #fff : #000 | 		color var(--inputText) | ||||||
| 		outline none | 		outline none | ||||||
| 		border none | 		border none | ||||||
| 		border-top solid 1px isDark ? #4b5056 : #eee | 		border-top solid 1px var(--faceDivider) | ||||||
| 		border-radius 0 | 		border-radius 0 | ||||||
| 		box-shadow none | 		box-shadow none | ||||||
| 		background transparent | 		background transparent | ||||||
| @@ -234,10 +232,10 @@ root(isDark) | |||||||
| 		transition color 0.1s ease | 		transition color 0.1s ease | ||||||
|  |  | ||||||
| 		&:hover | 		&:hover | ||||||
| 			color $theme-color | 			color var(--primary) | ||||||
|  |  | ||||||
| 		&:active | 		&:active | ||||||
| 			color darken($theme-color, 10%) | 			color var(--primaryDarken10) | ||||||
| 			transition color 0s ease | 			transition color 0s ease | ||||||
|  |  | ||||||
| 	.files | 	.files | ||||||
| @@ -293,19 +291,13 @@ root(isDark) | |||||||
| 		transition color 0.1s ease | 		transition color 0.1s ease | ||||||
|  |  | ||||||
| 		&:hover | 		&:hover | ||||||
| 			color $theme-color | 			color var(--primary) | ||||||
|  |  | ||||||
| 		&:active | 		&:active | ||||||
| 			color darken($theme-color, 10%) | 			color var(--primaryDarken10) | ||||||
| 			transition color 0s ease | 			transition color 0s ease | ||||||
|  |  | ||||||
| 	input[type=file] | 	input[type=file] | ||||||
| 		display none | 		display none | ||||||
|  |  | ||||||
| .mk-messaging-form[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .mk-messaging-form:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -59,10 +59,8 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' | .message | ||||||
|  | 	$me-balloon-color = var(--primary) | ||||||
| root(isDark) |  | ||||||
| 	$me-balloon-color = $theme-color |  | ||||||
|  |  | ||||||
| 	padding 10px 12px 10px 12px | 	padding 10px 12px 10px 12px | ||||||
| 	background-color transparent | 	background-color transparent | ||||||
| @@ -179,7 +177,7 @@ root(isDark) | |||||||
| 			display block | 			display block | ||||||
| 			margin 2px 0 0 0 | 			margin 2px 0 0 0 | ||||||
| 			font-size 10px | 			font-size 10px | ||||||
| 			color isDark ? rgba(#fff, 0.4) : rgba(#000, 0.4) | 			color var(--messagingRoomMessageInfo) | ||||||
|  |  | ||||||
| 			> [data-fa] | 			> [data-fa] | ||||||
| 				margin-left 4px | 				margin-left 4px | ||||||
| @@ -192,7 +190,7 @@ root(isDark) | |||||||
| 			padding-left 66px | 			padding-left 66px | ||||||
|  |  | ||||||
| 			> .balloon | 			> .balloon | ||||||
| 				$color = isDark ? #2d3338 : #eee | 				$color = var(--messagingRoomMessageBg) | ||||||
| 				float left | 				float left | ||||||
| 				background $color | 				background $color | ||||||
|  |  | ||||||
| @@ -208,8 +206,7 @@ root(isDark) | |||||||
|  |  | ||||||
| 				> .content | 				> .content | ||||||
| 					> .text | 					> .text | ||||||
| 						if isDark | 							color var(--messagingRoomMessageFg) | ||||||
| 							color #fff |  | ||||||
|  |  | ||||||
| 			> footer | 			> footer | ||||||
| 				text-align left | 				text-align left | ||||||
| @@ -250,18 +247,9 @@ root(isDark) | |||||||
|  |  | ||||||
| 				> .read | 				> .read | ||||||
| 					user-select none | 					user-select none | ||||||
| 					margin 0 4px 0 0 |  | ||||||
| 					color isDark ? rgba(#fff, 0.5) : rgba(#000, 0.5) |  | ||||||
| 					font-size 11px |  | ||||||
|  |  | ||||||
| 	&[data-is-deleted] | 	&[data-is-deleted] | ||||||
| 		> .balloon | 		> .balloon | ||||||
| 			opacity 0.5 | 			opacity 0.5 | ||||||
|  |  | ||||||
| .message[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .message:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -30,7 +30,6 @@ | |||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import Vue from 'vue'; | import Vue from 'vue'; | ||||||
| import { MessagingStream } from '../../scripts/streaming/messaging'; |  | ||||||
| import XMessage from './messaging-room.message.vue'; | import XMessage from './messaging-room.message.vue'; | ||||||
| import XForm from './messaging-room.form.vue'; | import XForm from './messaging-room.form.vue'; | ||||||
| import { url } from '../../../config'; | import { url } from '../../../config'; | ||||||
| @@ -72,7 +71,7 @@ export default Vue.extend({ | |||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| 	mounted() { | 	mounted() { | ||||||
| 		this.connection = new MessagingStream((this as any).os, this.$store.state.i, this.user.id); | 		this.connection = (this as any).os.stream.connectToChannel('messaging', { otherparty: this.user.id }); | ||||||
|  |  | ||||||
| 		this.connection.on('message', this.onMessage); | 		this.connection.on('message', this.onMessage); | ||||||
| 		this.connection.on('read', this.onRead); | 		this.connection.on('read', this.onRead); | ||||||
| @@ -92,9 +91,7 @@ export default Vue.extend({ | |||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| 	beforeDestroy() { | 	beforeDestroy() { | ||||||
| 		this.connection.off('message', this.onMessage); | 		this.connection.dispose(); | ||||||
| 		this.connection.off('read', this.onRead); |  | ||||||
| 		this.connection.close(); |  | ||||||
|  |  | ||||||
| 		if (this.isNaked) { | 		if (this.isNaked) { | ||||||
| 			window.removeEventListener('scroll', this.onScroll); | 			window.removeEventListener('scroll', this.onScroll); | ||||||
| @@ -177,8 +174,7 @@ export default Vue.extend({ | |||||||
|  |  | ||||||
| 			this.messages.push(message); | 			this.messages.push(message); | ||||||
| 			if (message.userId != this.$store.state.i.id && !document.hidden) { | 			if (message.userId != this.$store.state.i.id && !document.hidden) { | ||||||
| 				this.connection.send({ | 				this.connection.send('read', { | ||||||
| 					type: 'read', |  | ||||||
| 					id: message.id | 					id: message.id | ||||||
| 				}); | 				}); | ||||||
| 			} | 			} | ||||||
| @@ -250,8 +246,7 @@ export default Vue.extend({ | |||||||
| 			if (document.hidden) return; | 			if (document.hidden) return; | ||||||
| 			this.messages.forEach(message => { | 			this.messages.forEach(message => { | ||||||
| 				if (message.userId !== this.$store.state.i.id && !message.isRead) { | 				if (message.userId !== this.$store.state.i.id && !message.isRead) { | ||||||
| 					this.connection.send({ | 					this.connection.send('read', { | ||||||
| 						type: 'read', |  | ||||||
| 						id: message.id | 						id: message.id | ||||||
| 					}); | 					}); | ||||||
| 				} | 				} | ||||||
| @@ -262,14 +257,12 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' | .mk-messaging-room | ||||||
|  |  | ||||||
| root(isDark) |  | ||||||
| 	display flex | 	display flex | ||||||
| 	flex 1 | 	flex 1 | ||||||
| 	flex-direction column | 	flex-direction column | ||||||
| 	height 100% | 	height 100% | ||||||
| 	background isDark ? #191b22 : #fff | 	background var(--messagingRoomBg) | ||||||
|  |  | ||||||
| 	> .body | 	> .body | ||||||
| 		width 100% | 		width 100% | ||||||
| @@ -277,24 +270,15 @@ root(isDark) | |||||||
| 		margin 0 auto | 		margin 0 auto | ||||||
| 		flex 1 | 		flex 1 | ||||||
|  |  | ||||||
| 		> .init | 		> .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 |  | ||||||
|  |  | ||||||
| 		> .empty | 		> .empty | ||||||
| 			width 100% | 			width 100% | ||||||
| 			margin 0 | 			margin 0 | ||||||
| 			padding 16px 8px 8px 8px | 			padding 16px 8px 8px 8px | ||||||
| 			text-align center | 			text-align center | ||||||
| 			font-size 0.8em | 			font-size 0.8em | ||||||
| 			color rgba(isDark ? #fff : #000, 0.4) | 			color var(--messagingRoomInfo) | ||||||
|  | 			opacity 0.5 | ||||||
|  |  | ||||||
| 			[data-fa] | 			[data-fa] | ||||||
| 				margin-right 4px | 				margin-right 4px | ||||||
| @@ -305,7 +289,8 @@ root(isDark) | |||||||
| 			padding 16px | 			padding 16px | ||||||
| 			text-align center | 			text-align center | ||||||
| 			font-size 0.8em | 			font-size 0.8em | ||||||
| 			color rgba(isDark ? #fff : #000, 0.4) | 			color var(--messagingRoomInfo) | ||||||
|  | 			opacity 0.5 | ||||||
|  |  | ||||||
| 			[data-fa] | 			[data-fa] | ||||||
| 				margin-right 4px | 				margin-right 4px | ||||||
| @@ -349,7 +334,7 @@ root(isDark) | |||||||
| 				left 0 | 				left 0 | ||||||
| 				right 0 | 				right 0 | ||||||
| 				margin 0 auto | 				margin 0 auto | ||||||
| 				background rgba(isDark ? #fff : #000, 0.1) | 				background var(--messagingRoomDateDividerLine) | ||||||
|  |  | ||||||
| 			> span | 			> span | ||||||
| 				display inline-block | 				display inline-block | ||||||
| @@ -357,8 +342,8 @@ root(isDark) | |||||||
| 				padding 0 16px | 				padding 0 16px | ||||||
| 				//font-weight bold | 				//font-weight bold | ||||||
| 				line-height 32px | 				line-height 32px | ||||||
| 				color rgba(isDark ? #fff : #000, 0.3) | 				color var(--messagingRoomDateDividerText) | ||||||
| 				background isDark ? #191b22 : #fff | 				background var(--messagingRoomBg) | ||||||
|  |  | ||||||
| 	> footer | 	> footer | ||||||
| 		position -webkit-sticky | 		position -webkit-sticky | ||||||
| @@ -369,7 +354,7 @@ root(isDark) | |||||||
| 		max-width 600px | 		max-width 600px | ||||||
| 		margin 0 auto | 		margin 0 auto | ||||||
| 		padding 0 | 		padding 0 | ||||||
| 		background rgba(isDark ? #282c37 : #fff, 0.95) | 		background var(--messagingRoomBg) | ||||||
| 		background-clip content-box | 		background-clip content-box | ||||||
|  |  | ||||||
| 		> .new-message | 		> .new-message | ||||||
| @@ -386,15 +371,15 @@ root(isDark) | |||||||
| 				cursor pointer | 				cursor pointer | ||||||
| 				line-height 32px | 				line-height 32px | ||||||
| 				font-size 12px | 				font-size 12px | ||||||
| 				color $theme-color-foreground | 				color var(--primaryForeground) | ||||||
| 				background $theme-color | 				background var(--primary) | ||||||
| 				border-radius 16px | 				border-radius 16px | ||||||
|  |  | ||||||
| 				&:hover | 				&:hover | ||||||
| 					background lighten($theme-color, 10%) | 					background var(--primaryLighten10) | ||||||
|  |  | ||||||
| 				&:active | 				&:active | ||||||
| 					background darken($theme-color, 10%) | 					background var(--primaryDarken10) | ||||||
|  |  | ||||||
| 				> [data-fa] | 				> [data-fa] | ||||||
| 					position absolute | 					position absolute | ||||||
| @@ -410,10 +395,4 @@ root(isDark) | |||||||
| 	transition opacity 0.5s | 	transition opacity 0.5s | ||||||
| 	opacity 0 | 	opacity 0 | ||||||
|  |  | ||||||
| .mk-messaging-room[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .mk-messaging-room:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -71,13 +71,11 @@ export default Vue.extend({ | |||||||
| 			messages: [], | 			messages: [], | ||||||
| 			q: null, | 			q: null, | ||||||
| 			result: [], | 			result: [], | ||||||
| 			connection: null, | 			connection: null | ||||||
| 			connectionId: null |  | ||||||
| 		}; | 		}; | ||||||
| 	}, | 	}, | ||||||
| 	mounted() { | 	mounted() { | ||||||
| 		this.connection = (this as any).os.streams.messagingIndexStream.getConnection(); | 		this.connection = (this as any).os.stream.useSharedConnection('messagingIndex'); | ||||||
| 		this.connectionId = (this as any).os.streams.messagingIndexStream.use(); |  | ||||||
|  |  | ||||||
| 		this.connection.on('message', this.onMessage); | 		this.connection.on('message', this.onMessage); | ||||||
| 		this.connection.on('read', this.onRead); | 		this.connection.on('read', this.onRead); | ||||||
| @@ -88,9 +86,7 @@ export default Vue.extend({ | |||||||
| 		}); | 		}); | ||||||
| 	}, | 	}, | ||||||
| 	beforeDestroy() { | 	beforeDestroy() { | ||||||
| 		this.connection.off('message', this.onMessage); | 		this.connection.dispose(); | ||||||
| 		this.connection.off('read', this.onRead); |  | ||||||
| 		(this as any).os.streams.messagingIndexStream.dispose(this.connectionId); |  | ||||||
| 	}, | 	}, | ||||||
| 	methods: { | 	methods: { | ||||||
| 		getAcct, | 		getAcct, | ||||||
| @@ -167,9 +163,7 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' | .mk-messaging | ||||||
|  |  | ||||||
| root(isDark) |  | ||||||
|  |  | ||||||
| 	&[data-compact] | 	&[data-compact] | ||||||
| 		font-size 0.8em | 		font-size 0.8em | ||||||
| @@ -204,12 +198,10 @@ root(isDark) | |||||||
| 		left 0 | 		left 0 | ||||||
| 		z-index 1 | 		z-index 1 | ||||||
| 		width 100% | 		width 100% | ||||||
| 		background #fff |  | ||||||
| 		box-shadow 0 0px 2px rgba(#000, 0.2) | 		box-shadow 0 0px 2px rgba(#000, 0.2) | ||||||
|  |  | ||||||
| 		> .form | 		> .form | ||||||
| 			padding 8px | 			background rgba(0, 0, 0, 0.02) | ||||||
| 			background isDark ? #282c37 : #f7f7f7 |  | ||||||
|  |  | ||||||
| 			> label | 			> label | ||||||
| 				display block | 				display block | ||||||
| @@ -229,32 +221,22 @@ root(isDark) | |||||||
| 					bottom 0 | 					bottom 0 | ||||||
| 					left 0 | 					left 0 | ||||||
| 					width 1em | 					width 1em | ||||||
| 					line-height 56px | 					line-height 48px | ||||||
| 					margin auto | 					margin auto | ||||||
| 					color #555 | 					color #555 | ||||||
|  |  | ||||||
| 			> input | 			> input | ||||||
| 				margin 0 | 				margin 0 | ||||||
| 				padding 0 0 0 32px | 				padding 0 0 0 42px | ||||||
| 				width 100% | 				width 100% | ||||||
| 				font-size 1em | 				font-size 1em | ||||||
| 				line-height 38px | 				line-height 48px | ||||||
| 				color #000 | 				color var(--faceText) | ||||||
| 				outline none | 				outline none | ||||||
| 				background isDark ? #191b22 : #fff | 				background transparent | ||||||
| 				border solid 1px isDark ? #495156 : #eee | 				border none | ||||||
| 				border-radius 5px | 				border-radius 5px | ||||||
| 				box-shadow none | 				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 | 		> .result | ||||||
| 			display block | 			display block | ||||||
| @@ -287,7 +269,7 @@ root(isDark) | |||||||
| 					&:hover | 					&:hover | ||||||
| 					&:focus | 					&:focus | ||||||
| 						color #fff | 						color #fff | ||||||
| 						background $theme-color | 						background var(--primary) | ||||||
|  |  | ||||||
| 						.name | 						.name | ||||||
| 							color #fff | 							color #fff | ||||||
| @@ -297,7 +279,7 @@ root(isDark) | |||||||
|  |  | ||||||
| 					&:active | 					&:active | ||||||
| 						color #fff | 						color #fff | ||||||
| 						background darken($theme-color, 10%) | 						background var(--primaryDarken10) | ||||||
|  |  | ||||||
| 						.name | 						.name | ||||||
| 							color #fff | 							color #fff | ||||||
| @@ -329,21 +311,21 @@ root(isDark) | |||||||
| 		> a | 		> a | ||||||
| 			display block | 			display block | ||||||
| 			text-decoration none | 			text-decoration none | ||||||
| 			background isDark ? #282c37 : #fff | 			background var(--face) | ||||||
| 			border-bottom solid 1px isDark ? #1c2023 : #eee | 			border-bottom solid 1px var(--faceDivider) | ||||||
|  |  | ||||||
| 			* | 			* | ||||||
| 				pointer-events none | 				pointer-events none | ||||||
| 				user-select none | 				user-select none | ||||||
|  |  | ||||||
| 			&:hover | 			&:hover | ||||||
| 				background isDark ? #1e2129 : #fafafa | 				box-shadow 0 0 0 100px inset rgba(0, 0, 0, 0.05) | ||||||
|  |  | ||||||
| 				> .avatar | 				.avatar | ||||||
| 					filter saturate(200%) | 					filter saturate(200%) | ||||||
|  |  | ||||||
| 			&:active | 			&:active | ||||||
| 				background isDark ? #14161b : #eee | 				box-shadow 0 0 0 100px inset rgba(0, 0, 0, 0.1) | ||||||
|  |  | ||||||
| 			&[data-is-read] | 			&[data-is-read] | ||||||
| 			&[data-is-me] | 			&[data-is-me] | ||||||
| @@ -383,17 +365,17 @@ root(isDark) | |||||||
| 						overflow hidden | 						overflow hidden | ||||||
| 						text-overflow ellipsis | 						text-overflow ellipsis | ||||||
| 						font-size 1em | 						font-size 1em | ||||||
| 						color isDark ? #fff : rgba(#000, 0.9) | 						color var(--noteHeaderName) | ||||||
| 						font-weight bold | 						font-weight bold | ||||||
| 						transition all 0.1s ease | 						transition all 0.1s ease | ||||||
|  |  | ||||||
| 					> .username | 					> .username | ||||||
| 						margin 0 8px | 						margin 0 8px | ||||||
| 						color isDark ? #606984 : rgba(#000, 0.5) | 						color var(--noteHeaderAcct) | ||||||
|  |  | ||||||
| 					> .mk-time | 					> .mk-time | ||||||
| 						margin 0 0 0 auto | 						margin 0 0 0 auto | ||||||
| 						color isDark ? #606984 : rgba(#000, 0.5) | 						color var(--noteHeaderInfo) | ||||||
| 						font-size 80% | 						font-size 80% | ||||||
|  |  | ||||||
| 				> .avatar | 				> .avatar | ||||||
| @@ -413,10 +395,10 @@ root(isDark) | |||||||
| 						overflow hidden | 						overflow hidden | ||||||
| 						overflow-wrap break-word | 						overflow-wrap break-word | ||||||
| 						font-size 1.1em | 						font-size 1.1em | ||||||
| 						color isDark ? #fff : rgba(#000, 0.8) | 						color var(--faceText) | ||||||
|  |  | ||||||
| 						.me | 						.me | ||||||
| 							color isDark ? rgba(#fff, 0.7) : rgba(#000, 0.4) | 							opacity 0.7 | ||||||
|  |  | ||||||
| 					> .image | 					> .image | ||||||
| 						display block | 						display block | ||||||
| @@ -461,10 +443,4 @@ root(isDark) | |||||||
| 					> .avatar | 					> .avatar | ||||||
| 						margin 0 12px 0 0 | 						margin 0 12px 0 0 | ||||||
|  |  | ||||||
| .mk-messaging[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .mk-messaging:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -95,7 +95,8 @@ export default Vue.component('misskey-flavored-markdown', { | |||||||
| 					return [createElement(MkUrl, { | 					return [createElement(MkUrl, { | ||||||
| 						props: { | 						props: { | ||||||
| 							url: token.content, | 							url: token.content, | ||||||
| 							target: '_blank' | 							target: '_blank', | ||||||
|  | 							style: 'color:var(--mfmLink);' | ||||||
| 						} | 						} | ||||||
| 					})]; | 					})]; | ||||||
| 				} | 				} | ||||||
| @@ -106,30 +107,31 @@ export default Vue.component('misskey-flavored-markdown', { | |||||||
| 							class: 'link', | 							class: 'link', | ||||||
| 							href: token.url, | 							href: token.url, | ||||||
| 							target: '_blank', | 							target: '_blank', | ||||||
| 							title: token.url | 							title: token.url, | ||||||
|  | 							style: 'color:var(--mfmLink);' | ||||||
| 						} | 						} | ||||||
| 					}, token.title)]; | 					}, token.title)]; | ||||||
| 				} | 				} | ||||||
|  |  | ||||||
| 				case 'mention': { | 				case 'mention': { | ||||||
| 					return (createElement as any)('a', { | 					return (createElement as any)('router-link', { | ||||||
| 						attrs: { | 						attrs: { | ||||||
| 							href: `${url}/@${getAcct(token)}`, | 							to: `/${token.canonical}`, | ||||||
| 							target: '_blank', | 							dataIsMe: (this as any).i && getAcct((this as any).i) == getAcct(token), | ||||||
| 							dataIsMe: (this as any).i && getAcct((this as any).i) == getAcct(token) | 							style: 'color:var(--mfmMention);' | ||||||
| 						}, | 						}, | ||||||
| 						directives: [{ | 						directives: [{ | ||||||
| 							name: 'user-preview', | 							name: 'user-preview', | ||||||
| 							value: token.content | 							value: token.canonical | ||||||
| 						}] | 						}] | ||||||
| 					}, token.content); | 					}, token.canonical); | ||||||
| 				} | 				} | ||||||
|  |  | ||||||
| 				case 'hashtag': { | 				case 'hashtag': { | ||||||
| 					return [createElement('a', { | 					return [createElement('router-link', { | ||||||
| 						attrs: { | 						attrs: { | ||||||
| 							href: `${url}/tags/${encodeURIComponent(token.hashtag)}`, | 							to: `/tags/${encodeURIComponent(token.hashtag)}`, | ||||||
| 							target: '_blank' | 							style: 'color:var(--mfmHashtag);' | ||||||
| 						} | 						} | ||||||
| 					}, token.content)]; | 					}, token.content)]; | ||||||
| 				} | 				} | ||||||
|   | |||||||
| @@ -2,6 +2,8 @@ | |||||||
| <span class="mk-nav"> | <span class="mk-nav"> | ||||||
| 	<a :href="aboutUrl">%i18n:@about%</a> | 	<a :href="aboutUrl">%i18n:@about%</a> | ||||||
| 	<i>・</i> | 	<i>・</i> | ||||||
|  | 	<a href="/stats">%i18n:@stats%</a> | ||||||
|  | 	<i>・</i> | ||||||
| 	<a :href="repositoryUrl">%i18n:@repository%</a> | 	<a :href="repositoryUrl">%i18n:@repository%</a> | ||||||
| 	<i>・</i> | 	<i>・</i> | ||||||
| 	<a :href="feedbackUrl" target="_blank">%i18n:@feedback%</a> | 	<a :href="feedbackUrl" target="_blank">%i18n:@feedback%</a> | ||||||
|   | |||||||
| @@ -42,9 +42,7 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' | .bvonvjxbwzaiskogyhbwgyxvcgserpmu | ||||||
|  |  | ||||||
| root(isDark) |  | ||||||
| 	display flex | 	display flex | ||||||
| 	align-items baseline | 	align-items baseline | ||||||
| 	white-space nowrap | 	white-space nowrap | ||||||
| @@ -61,7 +59,7 @@ root(isDark) | |||||||
| 		margin 0 .5em 0 0 | 		margin 0 .5em 0 0 | ||||||
| 		padding 0 | 		padding 0 | ||||||
| 		overflow hidden | 		overflow hidden | ||||||
| 		color isDark ? #fff : #627079 | 		color var(--noteHeaderName) | ||||||
| 		font-size 1em | 		font-size 1em | ||||||
| 		font-weight bold | 		font-weight bold | ||||||
| 		text-decoration none | 		text-decoration none | ||||||
| @@ -82,19 +80,19 @@ root(isDark) | |||||||
| 		margin 0 .5em 0 0 | 		margin 0 .5em 0 0 | ||||||
| 		padding 1px 6px | 		padding 1px 6px | ||||||
| 		font-size 80% | 		font-size 80% | ||||||
| 		color isDark ? #758188 : #aaa | 		color var(--noteHeaderBadgeFg) | ||||||
| 		border solid 1px isDark ? #57616f : #ddd | 		background var(--noteHeaderBadgeBg) | ||||||
| 		border-radius 3px | 		border-radius 3px | ||||||
|  |  | ||||||
| 		&.is-admin | 		&.is-admin | ||||||
| 			border-color isDark ? #d42c41 : #f56a7b | 			background var(--noteHeaderAdminBg) | ||||||
| 			color isDark ? #d42c41 : #f56a7b | 			color var(--noteHeaderAdminFg) | ||||||
|  |  | ||||||
| 	> .username | 	> .username | ||||||
| 		margin 0 .5em 0 0 | 		margin 0 .5em 0 0 | ||||||
| 		overflow hidden | 		overflow hidden | ||||||
| 		text-overflow ellipsis | 		text-overflow ellipsis | ||||||
| 		color isDark ? #606984 : #ccc | 		color var(--noteHeaderAcct) | ||||||
| 		flex-shrink 2147483647 | 		flex-shrink 2147483647 | ||||||
|  |  | ||||||
| 	> .info | 	> .info | ||||||
| @@ -102,7 +100,7 @@ root(isDark) | |||||||
| 		font-size 0.9em | 		font-size 0.9em | ||||||
|  |  | ||||||
| 		> * | 		> * | ||||||
| 			color isDark ? #606984 : #c0c0c0 | 			color var(--noteHeaderInfo) | ||||||
|  |  | ||||||
| 		> .mobile | 		> .mobile | ||||||
| 			margin-right 8px | 			margin-right 8px | ||||||
| @@ -110,15 +108,9 @@ root(isDark) | |||||||
| 		> .app | 		> .app | ||||||
| 			margin-right 8px | 			margin-right 8px | ||||||
| 			padding-right 8px | 			padding-right 8px | ||||||
| 			border-right solid 1px isDark ? #1c2023 : #eaeaea | 			border-right solid 1px var(--faceDivider) | ||||||
|  |  | ||||||
| 		> .visibility | 		> .visibility | ||||||
| 			margin-left 8px | 			margin-left 8px | ||||||
|  |  | ||||||
| .bvonvjxbwzaiskogyhbwgyxvcgserpmu[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .bvonvjxbwzaiskogyhbwgyxvcgserpmu:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -8,6 +8,7 @@ | |||||||
| import Vue from 'vue'; | import Vue from 'vue'; | ||||||
| import { url } from '../../../config'; | import { url } from '../../../config'; | ||||||
| import copyToClipboard from '../../../common/scripts/copy-to-clipboard'; | import copyToClipboard from '../../../common/scripts/copy-to-clipboard'; | ||||||
|  | import Ok from './ok.vue'; | ||||||
|  |  | ||||||
| export default Vue.extend({ | export default Vue.extend({ | ||||||
| 	props: ['note', 'source', 'compact'], | 	props: ['note', 'source', 'compact'], | ||||||
| @@ -21,24 +22,8 @@ export default Vue.extend({ | |||||||
| 				icon: '%fa:link%', | 				icon: '%fa:link%', | ||||||
| 				text: '%i18n:@copy-link%', | 				text: '%i18n:@copy-link%', | ||||||
| 				action: this.copyLink | 				action: this.copyLink | ||||||
| 			}, null, { |  | ||||||
| 				icon: '%fa:star%', |  | ||||||
| 				text: '%i18n:@favorite%', |  | ||||||
| 				action: this.favorite |  | ||||||
| 			}]; | 			}]; | ||||||
|  |  | ||||||
| 			if (this.note.userId == this.$store.state.i.id) { |  | ||||||
| 				items.push({ |  | ||||||
| 					icon: '%fa:thumbtack%', |  | ||||||
| 					text: '%i18n:@pin%', |  | ||||||
| 					action: this.pin |  | ||||||
| 				}); |  | ||||||
| 				items.push({ |  | ||||||
| 					icon: '%fa:trash-alt R%', |  | ||||||
| 					text: '%i18n:@delete%', |  | ||||||
| 					action: this.del |  | ||||||
| 				}); |  | ||||||
| 			} |  | ||||||
| 			if (this.note.uri) { | 			if (this.note.uri) { | ||||||
| 				items.push({ | 				items.push({ | ||||||
| 					icon: '%fa:external-link-square-alt%', | 					icon: '%fa:external-link-square-alt%', | ||||||
| @@ -48,9 +33,52 @@ export default Vue.extend({ | |||||||
| 					} | 					} | ||||||
| 				}); | 				}); | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
|  | 			items.push(null); | ||||||
|  |  | ||||||
|  | 			if (this.note.isFavorited) { | ||||||
|  | 				items.push({ | ||||||
|  | 					icon: '%fa:star%', | ||||||
|  | 					text: '%i18n:@unfavorite%', | ||||||
|  | 					action: this.unfavorite | ||||||
|  | 				}); | ||||||
|  | 			} else { | ||||||
|  | 				items.push({ | ||||||
|  | 					icon: '%fa:star%', | ||||||
|  | 					text: '%i18n:@favorite%', | ||||||
|  | 					action: this.favorite | ||||||
|  | 				}); | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			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(null); | ||||||
|  | 				items.push({ | ||||||
|  | 					icon: '%fa:trash-alt R%', | ||||||
|  | 					text: '%i18n:@delete%', | ||||||
|  | 					action: this.del | ||||||
|  | 				}); | ||||||
|  | 			} | ||||||
|  |  | ||||||
| 			return items; | 			return items; | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| 	methods: { | 	methods: { | ||||||
| 		detail() { | 		detail() { | ||||||
| 			this.$router.push(`/notes/${ this.note.id }`); | 			this.$router.push(`/notes/${ this.note.id }`); | ||||||
| @@ -63,6 +91,15 @@ export default Vue.extend({ | |||||||
| 		pin() { | 		pin() { | ||||||
| 			(this as any).api('i/pin', { | 			(this as any).api('i/pin', { | ||||||
| 				noteId: this.note.id | 				noteId: this.note.id | ||||||
|  | 			}).then(() => { | ||||||
|  | 				(this as any).os.new(Ok); | ||||||
|  | 				this.destroyDom(); | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		unpin() { | ||||||
|  | 			(this as any).api('i/unpin', { | ||||||
|  | 				noteId: this.note.id | ||||||
| 			}).then(() => { | 			}).then(() => { | ||||||
| 				this.destroyDom(); | 				this.destroyDom(); | ||||||
| 			}); | 			}); | ||||||
| @@ -81,6 +118,16 @@ export default Vue.extend({ | |||||||
| 			(this as any).api('notes/favorites/create', { | 			(this as any).api('notes/favorites/create', { | ||||||
| 				noteId: this.note.id | 				noteId: this.note.id | ||||||
| 			}).then(() => { | 			}).then(() => { | ||||||
|  | 				(this as any).os.new(Ok); | ||||||
|  | 				this.destroyDom(); | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		unfavorite() { | ||||||
|  | 			(this as any).api('notes/favorites/delete', { | ||||||
|  | 				noteId: this.note.id | ||||||
|  | 			}).then(() => { | ||||||
|  | 				(this as any).os.new(Ok); | ||||||
| 				this.destroyDom(); | 				this.destroyDom(); | ||||||
| 			}); | 			}); | ||||||
| 		}, | 		}, | ||||||
|   | |||||||
							
								
								
									
										52
									
								
								src/client/app/common/views/components/note-skeleton.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								src/client/app/common/views/components/note-skeleton.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,52 @@ | |||||||
|  | <template> | ||||||
|  | <div> | ||||||
|  | 	<vue-content-loading v-if="width" :width="width" :height="100" :primary="primary" :secondary="secondary"> | ||||||
|  | 		<circle cx="30" cy="30" r="30" /> | ||||||
|  | 		<rect x="75" y="13" rx="4" ry="4" :width="150 + r1" height="15" /> | ||||||
|  | 		<rect x="75" y="39" rx="4" ry="4" :width="260 + r2" height="10" /> | ||||||
|  | 		<rect x="75" y="59" rx="4" ry="4" :width="230 + r3" height="10" /> | ||||||
|  | 	</vue-content-loading> | ||||||
|  | </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script lang="ts"> | ||||||
|  | import Vue from 'vue'; | ||||||
|  | import VueContentLoading from 'vue-content-loading'; | ||||||
|  | import * as tinycolor from 'tinycolor2'; | ||||||
|  |  | ||||||
|  | export default Vue.extend({ | ||||||
|  | 	components: { | ||||||
|  | 		VueContentLoading, | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			width: 0, | ||||||
|  | 			r1: (Math.random() * 100) - 50, | ||||||
|  | 			r2: (Math.random() * 100) - 50, | ||||||
|  | 			r3: (Math.random() * 100) - 50 | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	computed: { | ||||||
|  | 		text(): tinycolor.Instance { | ||||||
|  | 			const text = tinycolor(getComputedStyle(document.documentElement).getPropertyValue('--text')); | ||||||
|  | 			return text; | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		primary(): string { | ||||||
|  | 			return '#' + this.text.clone().toHex(); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		secondary(): string { | ||||||
|  | 			return '#' + this.text.clone().darken(20).toHex(); | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	mounted() { | ||||||
|  | 		let width = this.$el.clientWidth; | ||||||
|  | 		if (width < 400) width = 400; | ||||||
|  | 		this.width = width; | ||||||
|  | 	} | ||||||
|  | }); | ||||||
|  | </script> | ||||||
							
								
								
									
										175
									
								
								src/client/app/common/views/components/ok.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										175
									
								
								src/client/app/common/views/components/ok.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,175 @@ | |||||||
|  | <template> | ||||||
|  | <div class="yvbkymdqeusiqucuuloahhiqflzinufs"> | ||||||
|  | 	<div class="bg" ref="bg"></div> | ||||||
|  | 	<div class="body" ref="body"> | ||||||
|  | 		<div class="icon"> | ||||||
|  | 			<div class="circle left"></div> | ||||||
|  | 			<span class="check tip"></span> | ||||||
|  | 			<span class="check long"></span> | ||||||
|  | 			<div class="ring"></div> | ||||||
|  | 			<div class="fix"></div> | ||||||
|  | 			<div class="circle right"></div> | ||||||
|  | 		</div> | ||||||
|  | 	</div> | ||||||
|  | </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script lang="ts"> | ||||||
|  | import Vue from 'vue'; | ||||||
|  | import * as anime from 'animejs'; | ||||||
|  |  | ||||||
|  | export default Vue.extend({ | ||||||
|  | 	mounted() { | ||||||
|  | 		this.$nextTick(() => { | ||||||
|  | 			anime({ | ||||||
|  | 				targets: this.$refs.bg, | ||||||
|  | 				opacity: 1, | ||||||
|  | 				duration: 300, | ||||||
|  | 				easing: 'linear' | ||||||
|  | 			}); | ||||||
|  |  | ||||||
|  | 			anime({ | ||||||
|  | 				targets: this.$refs.body, | ||||||
|  | 				opacity: 1, | ||||||
|  | 				scale: [1.2, 1], | ||||||
|  | 				duration: 300, | ||||||
|  | 				easing: [0, 0.5, 0.5, 1] | ||||||
|  | 			}); | ||||||
|  | 		}); | ||||||
|  |  | ||||||
|  | 		setTimeout(() => { | ||||||
|  | 			anime({ | ||||||
|  | 				targets: this.$refs.bg, | ||||||
|  | 				opacity: 0, | ||||||
|  | 				duration: 300, | ||||||
|  | 				easing: 'linear' | ||||||
|  | 			}); | ||||||
|  |  | ||||||
|  | 			anime({ | ||||||
|  | 				targets: this.$refs.body, | ||||||
|  | 				opacity: 0, | ||||||
|  | 				scale: 0.8, | ||||||
|  | 				duration: 300, | ||||||
|  | 				easing: [0.5, 0, 1, 0.5], | ||||||
|  | 				complete: () => this.destroyDom() | ||||||
|  | 			}); | ||||||
|  | 		}, 1250); | ||||||
|  | 	} | ||||||
|  | }); | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <style lang="stylus" scoped> | ||||||
|  | .yvbkymdqeusiqucuuloahhiqflzinufs | ||||||
|  | 	pointer-events none | ||||||
|  |  | ||||||
|  | 	> .bg | ||||||
|  | 		display block | ||||||
|  | 		position fixed | ||||||
|  | 		z-index 10000 | ||||||
|  | 		top 0 | ||||||
|  | 		left 0 | ||||||
|  | 		width 100% | ||||||
|  | 		height 100% | ||||||
|  | 		background rgba(#000, 0.7) | ||||||
|  | 		opacity 0 | ||||||
|  |  | ||||||
|  | 	> .body | ||||||
|  | 		position fixed | ||||||
|  | 		z-index 10000 | ||||||
|  | 		top 0 | ||||||
|  | 		right 0 | ||||||
|  | 		left 0 | ||||||
|  | 		bottom 0 | ||||||
|  | 		margin auto | ||||||
|  | 		width 150px | ||||||
|  | 		height 150px | ||||||
|  | 		background var(--face) | ||||||
|  | 		border-radius 8px | ||||||
|  | 		opacity 0 | ||||||
|  |  | ||||||
|  | 		> .icon | ||||||
|  | 			display flex | ||||||
|  | 			justify-content center | ||||||
|  | 			position absolute | ||||||
|  | 			top 0 | ||||||
|  | 			right 0 | ||||||
|  | 			left 0 | ||||||
|  | 			bottom 0 | ||||||
|  | 			width 5em | ||||||
|  | 			height 5em | ||||||
|  | 			margin auto | ||||||
|  | 			border .25em solid transparent | ||||||
|  | 			border-radius 50% | ||||||
|  | 			line-height 5em | ||||||
|  | 			cursor default | ||||||
|  | 			box-sizing content-box | ||||||
|  | 			user-select none | ||||||
|  | 			zoom normal | ||||||
|  | 			border-color #a5dc86 | ||||||
|  |  | ||||||
|  | 			> .circle | ||||||
|  | 				position absolute | ||||||
|  | 				width 3.75em | ||||||
|  | 				height 7.5em | ||||||
|  | 				transform rotate(45deg) | ||||||
|  | 				border-radius 50% | ||||||
|  | 				background var(--face) | ||||||
|  |  | ||||||
|  | 				&.left | ||||||
|  | 					top -.4375em | ||||||
|  | 					left -2.0635em | ||||||
|  | 					transform rotate(-45deg) | ||||||
|  | 					transform-origin 3.75em 3.75em | ||||||
|  | 					border-radius 7.5em 0 0 7.5em | ||||||
|  |  | ||||||
|  | 				&.right | ||||||
|  | 					top -.6875em | ||||||
|  | 					left 1.875em | ||||||
|  | 					transform rotate(-45deg) | ||||||
|  | 					transform-origin 0 3.75em | ||||||
|  | 					border-radius 0 7.5em 7.5em 0 | ||||||
|  | 					animation swal2-rotate-success-circular-line 4.25s ease-in | ||||||
|  |  | ||||||
|  | 			> .check | ||||||
|  | 				display block | ||||||
|  | 				position absolute | ||||||
|  | 				height .3125em | ||||||
|  | 				border-radius .125em | ||||||
|  | 				background-color #a5dc86 | ||||||
|  | 				z-index 2 | ||||||
|  |  | ||||||
|  | 				&.tip | ||||||
|  | 					top 2.875em | ||||||
|  | 					left .875em | ||||||
|  | 					width 1.5625em | ||||||
|  | 					transform rotate(45deg) | ||||||
|  | 					animation swal2-animate-success-line-tip .75s | ||||||
|  |  | ||||||
|  | 				&.long | ||||||
|  | 					top 2.375em | ||||||
|  | 					right .5em | ||||||
|  | 					width 2.9375em | ||||||
|  | 					transform rotate(-45deg) | ||||||
|  | 					animation swal2-animate-success-line-long .75s | ||||||
|  |  | ||||||
|  | 			> .fix | ||||||
|  | 				position absolute | ||||||
|  | 				top .5em | ||||||
|  | 				left 1.625em | ||||||
|  | 				width .4375em | ||||||
|  | 				height 5.625em | ||||||
|  | 				transform rotate(-45deg) | ||||||
|  | 				z-index 1 | ||||||
|  | 				background var(--face) | ||||||
|  |  | ||||||
|  | 			> .ring | ||||||
|  | 				position absolute | ||||||
|  | 				top -.25em | ||||||
|  | 				left -.25em | ||||||
|  | 				width 100% | ||||||
|  | 				height 100% | ||||||
|  | 				border .25em solid rgba(165,220,134,.3) | ||||||
|  | 				border-radius 50% | ||||||
|  | 				z-index 2 | ||||||
|  | 				box-sizing content-box | ||||||
|  | </style> | ||||||
| @@ -68,9 +68,7 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' | .mk-poll-editor | ||||||
|  |  | ||||||
| root(isDark) |  | ||||||
| 	padding 8px | 	padding 8px | ||||||
|  |  | ||||||
| 	> .caution | 	> .caution | ||||||
| @@ -103,49 +101,43 @@ root(isDark) | |||||||
| 				padding 6px 8px | 				padding 6px 8px | ||||||
| 				width 300px | 				width 300px | ||||||
| 				font-size 14px | 				font-size 14px | ||||||
| 				color isDark ? #fff : #000 | 				color var(--inputText) | ||||||
| 				background isDark ? #191b22 : #fff | 				background var(--pollEditorInputBg) | ||||||
| 				border solid 1px rgba($theme-color, 0.1) | 				border solid 1px var(--primaryAlpha01) | ||||||
| 				border-radius 4px | 				border-radius 4px | ||||||
|  |  | ||||||
| 				&:hover | 				&:hover | ||||||
| 					border-color rgba($theme-color, 0.2) | 					border-color var(--primaryAlpha02) | ||||||
|  |  | ||||||
| 				&:focus | 				&:focus | ||||||
| 					border-color rgba($theme-color, 0.5) | 					border-color var(--primaryAlpha05) | ||||||
|  |  | ||||||
| 			> button | 			> button | ||||||
| 				padding 4px 8px | 				padding 4px 8px | ||||||
| 				color rgba($theme-color, 0.4) | 				color var(--primaryAlpha04) | ||||||
|  |  | ||||||
| 				&:hover | 				&:hover | ||||||
| 					color rgba($theme-color, 0.6) | 					color var(--primaryAlpha06) | ||||||
|  |  | ||||||
| 				&:active | 				&:active | ||||||
| 					color darken($theme-color, 30%) | 					color var(--primaryDarken30) | ||||||
|  |  | ||||||
| 	> .add | 	> .add | ||||||
| 		margin 8px 0 0 0 | 		margin 8px 0 0 0 | ||||||
| 		vertical-align top | 		vertical-align top | ||||||
| 		color $theme-color | 		color var(--primary) | ||||||
|  |  | ||||||
| 	> .destroy | 	> .destroy | ||||||
| 		position absolute | 		position absolute | ||||||
| 		top 0 | 		top 0 | ||||||
| 		right 0 | 		right 0 | ||||||
| 		padding 4px 8px | 		padding 4px 8px | ||||||
| 		color rgba($theme-color, 0.4) | 		color var(--primaryAlpha04) | ||||||
|  |  | ||||||
| 		&:hover | 		&:hover | ||||||
| 			color rgba($theme-color, 0.6) | 			color var(--primaryAlpha06) | ||||||
|  |  | ||||||
| 		&:active | 		&:active | ||||||
| 			color darken($theme-color, 30%) | 			color var(--primaryDarken30) | ||||||
|  |  | ||||||
| .mk-poll-editor[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .mk-poll-editor:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -67,10 +67,7 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' | .mk-poll | ||||||
|  |  | ||||||
| root(isDark) |  | ||||||
|  |  | ||||||
| 	> ul | 	> ul | ||||||
| 		display block | 		display block | ||||||
| 		margin 0 | 		margin 0 | ||||||
| @@ -82,8 +79,8 @@ root(isDark) | |||||||
| 			margin 4px 0 | 			margin 4px 0 | ||||||
| 			padding 4px 8px | 			padding 4px 8px | ||||||
| 			width 100% | 			width 100% | ||||||
| 			color isDark ? #fff : #000 | 			color var(--pollChoiceText) | ||||||
| 			border solid 1px isDark ? #5e636f : #eee | 			border solid 1px var(--pollChoiceBorder) | ||||||
| 			border-radius 4px | 			border-radius 4px | ||||||
| 			overflow hidden | 			overflow hidden | ||||||
| 			cursor pointer | 			cursor pointer | ||||||
| @@ -99,7 +96,7 @@ root(isDark) | |||||||
| 				top 0 | 				top 0 | ||||||
| 				left 0 | 				left 0 | ||||||
| 				height 100% | 				height 100% | ||||||
| 				background $theme-color | 				background var(--primary) | ||||||
| 				transition width 1s ease | 				transition width 1s ease | ||||||
|  |  | ||||||
| 			> span | 			> span | ||||||
| @@ -110,7 +107,7 @@ root(isDark) | |||||||
| 					margin-left 4px | 					margin-left 4px | ||||||
|  |  | ||||||
| 	> p | 	> p | ||||||
| 		color isDark ? #a3aebf : #000 | 		color var(--text) | ||||||
|  |  | ||||||
| 		a | 		a | ||||||
| 			color inherit | 			color inherit | ||||||
| @@ -125,10 +122,4 @@ root(isDark) | |||||||
| 			&:active | 			&:active | ||||||
| 				background transparent | 				background transparent | ||||||
|  |  | ||||||
| .mk-poll[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .mk-poll:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -49,6 +49,7 @@ | |||||||
| 
 | 
 | ||||||
| 		<div> | 		<div> | ||||||
| 			<ui-switch v-model="isCat" @change="save(false)">%i18n:@is-cat%</ui-switch> | 			<ui-switch v-model="isCat" @change="save(false)">%i18n:@is-cat%</ui-switch> | ||||||
|  | 			<ui-switch v-model="isBot" @change="save(false)">%i18n:@is-bot%</ui-switch> | ||||||
| 			<ui-switch v-model="alwaysMarkNsfw">%i18n:common.always-mark-nsfw%</ui-switch> | 			<ui-switch v-model="alwaysMarkNsfw">%i18n:common.always-mark-nsfw%</ui-switch> | ||||||
| 		</div> | 		</div> | ||||||
| 	</section> | 	</section> | ||||||
| @@ -58,6 +59,7 @@ | |||||||
| 
 | 
 | ||||||
| 		<div> | 		<div> | ||||||
| 			<ui-switch v-model="isLocked" @change="save(false)">%i18n:@is-locked%</ui-switch> | 			<ui-switch v-model="isLocked" @change="save(false)">%i18n:@is-locked%</ui-switch> | ||||||
|  | 			<ui-switch v-model="carefulBot" @change="save(false)">%i18n:@careful-bot%</ui-switch> | ||||||
| 		</div> | 		</div> | ||||||
| 	</section> | 	</section> | ||||||
| </ui-card> | </ui-card> | ||||||
| @@ -65,7 +67,7 @@ | |||||||
| 
 | 
 | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import Vue from 'vue'; | import Vue from 'vue'; | ||||||
| import { apiUrl, host } from '../../../../config'; | import { apiUrl, host } from '../../../config'; | ||||||
| 
 | 
 | ||||||
| export default Vue.extend({ | export default Vue.extend({ | ||||||
| 	data() { | 	data() { | ||||||
| @@ -79,7 +81,9 @@ export default Vue.extend({ | |||||||
| 			avatarId: null, | 			avatarId: null, | ||||||
| 			bannerId: null, | 			bannerId: null, | ||||||
| 			isCat: false, | 			isCat: false, | ||||||
|  | 			isBot: false, | ||||||
| 			isLocked: false, | 			isLocked: false, | ||||||
|  | 			carefulBot: false, | ||||||
| 			saving: false, | 			saving: false, | ||||||
| 			avatarUploading: false, | 			avatarUploading: false, | ||||||
| 			bannerUploading: false | 			bannerUploading: false | ||||||
| @@ -102,7 +106,9 @@ export default Vue.extend({ | |||||||
| 		this.avatarId = this.$store.state.i.avatarId; | 		this.avatarId = this.$store.state.i.avatarId; | ||||||
| 		this.bannerId = this.$store.state.i.bannerId; | 		this.bannerId = this.$store.state.i.bannerId; | ||||||
| 		this.isCat = this.$store.state.i.isCat; | 		this.isCat = this.$store.state.i.isCat; | ||||||
|  | 		this.isBot = this.$store.state.i.isBot; | ||||||
| 		this.isLocked = this.$store.state.i.isLocked; | 		this.isLocked = this.$store.state.i.isLocked; | ||||||
|  | 		this.carefulBot = this.$store.state.i.carefulBot; | ||||||
| 	}, | 	}, | ||||||
| 
 | 
 | ||||||
| 	methods: { | 	methods: { | ||||||
| @@ -161,7 +167,9 @@ export default Vue.extend({ | |||||||
| 				avatarId: this.avatarId, | 				avatarId: this.avatarId, | ||||||
| 				bannerId: this.bannerId, | 				bannerId: this.bannerId, | ||||||
| 				isCat: this.isCat, | 				isCat: this.isCat, | ||||||
| 				isLocked: this.isLocked | 				isBot: this.isBot, | ||||||
|  | 				isLocked: this.isLocked, | ||||||
|  | 				carefulBot: this.carefulBot | ||||||
| 			}).then(i => { | 			}).then(i => { | ||||||
| 				this.saving = false; | 				this.saving = false; | ||||||
| 				this.$store.state.i.avatarId = i.avatarId; | 				this.$store.state.i.avatarId = i.avatarId; | ||||||
| @@ -170,7 +178,10 @@ export default Vue.extend({ | |||||||
| 				this.$store.state.i.bannerUrl = i.bannerUrl; | 				this.$store.state.i.bannerUrl = i.bannerUrl; | ||||||
| 
 | 
 | ||||||
| 				if (notify) { | 				if (notify) { | ||||||
| 					alert('%i18n:@saved%'); | 					this.$swal({ | ||||||
|  | 						type: 'success', | ||||||
|  | 						text: '%i18n:@saved%' | ||||||
|  | 					}); | ||||||
| 				} | 				} | ||||||
| 			}); | 			}); | ||||||
| 		} | 		} | ||||||
| @@ -210,11 +210,9 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' |  | ||||||
|  |  | ||||||
| $border-color = rgba(27, 31, 35, 0.15) | $border-color = rgba(27, 31, 35, 0.15) | ||||||
|  |  | ||||||
| root(isDark) | .mk-reaction-picker | ||||||
| 	position initial | 	position initial | ||||||
|  |  | ||||||
| 	> .backdrop | 	> .backdrop | ||||||
| @@ -224,11 +222,11 @@ root(isDark) | |||||||
| 		z-index 10000 | 		z-index 10000 | ||||||
| 		width 100% | 		width 100% | ||||||
| 		height 100% | 		height 100% | ||||||
| 		background isDark ? rgba(#000, 0.4) : rgba(#000, 0.1) | 		background var(--modalBackdrop) | ||||||
| 		opacity 0 | 		opacity 0 | ||||||
|  |  | ||||||
| 	> .popover | 	> .popover | ||||||
| 		$bgcolor = isDark ? #2c303c : #fff | 		$bgcolor = var(--popupBg) | ||||||
| 		position absolute | 		position absolute | ||||||
| 		z-index 10001 | 		z-index 10001 | ||||||
| 		background $bgcolor | 		background $bgcolor | ||||||
| @@ -281,8 +279,8 @@ root(isDark) | |||||||
| 			margin 0 | 			margin 0 | ||||||
| 			padding 8px 10px | 			padding 8px 10px | ||||||
| 			font-size 14px | 			font-size 14px | ||||||
| 			color isDark ? #d6dce2 : #586069 | 			color var(--popupFg) | ||||||
| 			border-bottom solid 1px isDark ? #1c2023 : #e1e4e8 | 			border-bottom solid 1px var(--faceDivider) | ||||||
|  |  | ||||||
| 		> div | 		> div | ||||||
| 			padding 4px | 			padding 4px | ||||||
| @@ -301,7 +299,7 @@ root(isDark) | |||||||
| 						right 0 | 						right 0 | ||||||
| 						bottom 0 | 						bottom 0 | ||||||
| 						left 0 | 						left 0 | ||||||
| 						border 2px solid rgba($theme-color, 0.3) | 						border 2px solid var(--primaryAlpha03) | ||||||
| 						border-radius 4px | 						border-radius 4px | ||||||
|  |  | ||||||
| 			> button | 			> button | ||||||
| @@ -312,16 +310,10 @@ root(isDark) | |||||||
| 				border-radius 2px | 				border-radius 2px | ||||||
|  |  | ||||||
| 				&:hover | 				&:hover | ||||||
| 					background isDark ? #252731 : #eee | 					background var(--reactionPickerButtonHoverBg) | ||||||
|  |  | ||||||
| 				&:active | 				&:active | ||||||
| 					background $theme-color | 					background var(--primary) | ||||||
| 					box-shadow inset 0 0.15em 0.3em rgba(27, 31, 35, 0.15) | 					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> | </style> | ||||||
|   | |||||||
| @@ -1,16 +1,16 @@ | |||||||
| <template> | <template> | ||||||
| <div class="mk-reactions-viewer"> | <div class="mk-reactions-viewer"> | ||||||
| 	<template v-if="reactions"> | 	<template v-if="reactions"> | ||||||
| 		<span :class="{notReacted}" @click="react('like')" v-if="reactions.like"><mk-reaction-icon reaction="like"/><span>{{ reactions.like }}</span></span> | 		<span :class="{ reacted: note.myReaction == 'like' }" @click="react('like')" v-if="reactions.like"><mk-reaction-icon reaction="like"/><span>{{ reactions.like }}</span></span> | ||||||
| 		<span :class="{notReacted}" @click="react('love')" v-if="reactions.love"><mk-reaction-icon reaction="love"/><span>{{ reactions.love }}</span></span> | 		<span :class="{ reacted: note.myReaction == 'love' }" @click="react('love')" v-if="reactions.love"><mk-reaction-icon reaction="love"/><span>{{ reactions.love }}</span></span> | ||||||
| 		<span :class="{notReacted}" @click="react('laugh')" v-if="reactions.laugh"><mk-reaction-icon reaction="laugh"/><span>{{ reactions.laugh }}</span></span> | 		<span :class="{ reacted: note.myReaction == 'laugh' }" @click="react('laugh')" v-if="reactions.laugh"><mk-reaction-icon reaction="laugh"/><span>{{ reactions.laugh }}</span></span> | ||||||
| 		<span :class="{notReacted}" @click="react('hmm')" v-if="reactions.hmm"><mk-reaction-icon reaction="hmm"/><span>{{ reactions.hmm }}</span></span> | 		<span :class="{ reacted: note.myReaction == 'hmm' }" @click="react('hmm')" v-if="reactions.hmm"><mk-reaction-icon reaction="hmm"/><span>{{ reactions.hmm }}</span></span> | ||||||
| 		<span :class="{notReacted}" @click="react('surprise')" v-if="reactions.surprise"><mk-reaction-icon reaction="surprise"/><span>{{ reactions.surprise }}</span></span> | 		<span :class="{ reacted: note.myReaction == 'surprise' }" @click="react('surprise')" v-if="reactions.surprise"><mk-reaction-icon reaction="surprise"/><span>{{ reactions.surprise }}</span></span> | ||||||
| 		<span :class="{notReacted}" @click="react('congrats')" v-if="reactions.congrats"><mk-reaction-icon reaction="congrats"/><span>{{ reactions.congrats }}</span></span> | 		<span :class="{ reacted: note.myReaction == 'congrats' }" @click="react('congrats')" v-if="reactions.congrats"><mk-reaction-icon reaction="congrats"/><span>{{ reactions.congrats }}</span></span> | ||||||
| 		<span :class="{notReacted}" @click="react('angry')" v-if="reactions.angry"><mk-reaction-icon reaction="angry"/><span>{{ reactions.angry }}</span></span> | 		<span :class="{ reacted: note.myReaction == 'angry' }" @click="react('angry')" v-if="reactions.angry"><mk-reaction-icon reaction="angry"/><span>{{ reactions.angry }}</span></span> | ||||||
| 		<span :class="{notReacted}" @click="react('confused')" v-if="reactions.confused"><mk-reaction-icon reaction="confused"/><span>{{ reactions.confused }}</span></span> | 		<span :class="{ reacted: note.myReaction == 'confused' }" @click="react('confused')" v-if="reactions.confused"><mk-reaction-icon reaction="confused"/><span>{{ reactions.confused }}</span></span> | ||||||
| 		<span :class="{notReacted}" @click="react('rip')" v-if="reactions.rip"><mk-reaction-icon reaction="rip"/><span>{{ reactions.rip }}</span></span> | 		<span :class="{ reacted: note.myReaction == 'rip' }" @click="react('rip')" v-if="reactions.rip"><mk-reaction-icon reaction="rip"/><span>{{ reactions.rip }}</span></span> | ||||||
| 		<span :class="{notReacted}" @click="react('pudding')" v-if="reactions.pudding"><mk-reaction-icon reaction="pudding"/><span>{{ reactions.pudding }}</span></span> | 		<span :class="{ reacted: note.myReaction == 'pudding' }" @click="react('pudding')" v-if="reactions.pudding"><mk-reaction-icon reaction="pudding"/><span>{{ reactions.pudding }}</span></span> | ||||||
| 	</template> | 	</template> | ||||||
| </div> | </div> | ||||||
| </template> | </template> | ||||||
| @@ -22,9 +22,6 @@ export default Vue.extend({ | |||||||
| 	computed: { | 	computed: { | ||||||
| 		reactions(): number { | 		reactions(): number { | ||||||
| 			return this.note.reactionCounts; | 			return this.note.reactionCounts; | ||||||
| 		}, |  | ||||||
| 		notReacted(): boolean { |  | ||||||
| 			return this.note.myReaction == null; |  | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	methods: { | 	methods: { | ||||||
| @@ -39,33 +36,43 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| root(isDark) | .mk-reactions-viewer | ||||||
| 	$borderColor = isDark ? #5e6673 : #eee | 	margin 6px 0 | ||||||
| 	border-top dashed 1px $borderColor |  | ||||||
| 	border-bottom dashed 1px $borderColor |  | ||||||
| 	margin 4px 0 |  | ||||||
|  |  | ||||||
| 	&:empty | 	&:empty | ||||||
| 		display none | 		display none | ||||||
|  |  | ||||||
| 	> span | 	> span | ||||||
| 		margin-right 8px | 		display inline-block | ||||||
|  | 		height 32px | ||||||
|  | 		margin-right 6px | ||||||
|  | 		padding 0 6px | ||||||
|  | 		border-radius 4px | ||||||
|  |  | ||||||
| 		&.notReacted | 		* | ||||||
|  | 			user-select none | ||||||
|  | 			pointer-events none | ||||||
|  |  | ||||||
|  | 		&.reacted | ||||||
|  | 			background var(--primary) | ||||||
|  |  | ||||||
|  | 			> span | ||||||
|  | 				color var(--primaryForeground) | ||||||
|  |  | ||||||
|  | 		&:not(.reacted) | ||||||
| 			cursor pointer | 			cursor pointer | ||||||
|  | 			background var(--reactionViewerButtonBg) | ||||||
|  |  | ||||||
|  | 			&:hover | ||||||
|  | 				background var(--reactionViewerButtonHoverBg) | ||||||
|  |  | ||||||
| 		> .mk-reaction-icon | 		> .mk-reaction-icon | ||||||
| 			font-size 1.4em | 			font-size 1.4em | ||||||
|  |  | ||||||
| 		> span | 		> span | ||||||
| 			margin-left 4px | 			font-size 1.1em | ||||||
| 			font-size 1.2em | 			line-height 32px | ||||||
| 			color isDark ? #d1d5dc : #444 | 			vertical-align middle | ||||||
|  | 			color var(--text) | ||||||
| .mk-reactions-viewer[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .mk-reactions-viewer:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -1,16 +1,16 @@ | |||||||
| <template> | <template> | ||||||
| <form class="mk-signin" :class="{ signing }" @submit.prevent="onSubmit"> | <form class="mk-signin" :class="{ signing }" @submit.prevent="onSubmit"> | ||||||
| 	<div class="avatar" :style="{ backgroundImage: user ? `url('${ user.avatarUrl }')` : null }" v-show="withAvatar"></div> | 	<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>%i18n:@username%</span> | ||||||
| 		<span slot="prefix">@</span> | 		<span slot="prefix">@</span> | ||||||
| 		<span slot="suffix">@{{ host }}</span> | 		<span slot="suffix">@{{ host }}</span> | ||||||
| 	</ui-input> | 	</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>%i18n:@password%</span> | ||||||
| 		<span slot="prefix">%fa:lock%</span> | 		<span slot="prefix">%fa:lock%</span> | ||||||
| 	</ui-input> | 	</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> | 	<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> | 	<p style="margin: 8px 0;">%i18n:@or% <a :href="`${apiUrl}/signin/twitter`">%i18n:@signin-with-twitter%</a></p> | ||||||
| </form> | </form> | ||||||
| @@ -56,7 +56,7 @@ export default Vue.extend({ | |||||||
| 				username: this.username, | 				username: this.username, | ||||||
| 				password: this.password, | 				password: this.password, | ||||||
| 				token: this.user && this.user.twoFactorEnabled ? this.token : undefined | 				token: this.user && this.user.twoFactorEnabled ? this.token : undefined | ||||||
| 			}).then(() => { | 			}, true).then(() => { | ||||||
| 				location.reload(); | 				location.reload(); | ||||||
| 			}).catch(() => { | 			}).catch(() => { | ||||||
| 				alert('%i18n:@login-failed%'); | 				alert('%i18n:@login-failed%'); | ||||||
| @@ -68,7 +68,7 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' |  | ||||||
|  |  | ||||||
| .mk-signin | .mk-signin | ||||||
| 	color #555 | 	color #555 | ||||||
|   | |||||||
| @@ -1,12 +1,12 @@ | |||||||
| <template> | <template> | ||||||
| <form class="mk-signup" @submit.prevent="onSubmit" :autocomplete="Math.random()"> | <form class="mk-signup" @submit.prevent="onSubmit" :autocomplete="Math.random()"> | ||||||
| 	<template v-if="meta"> | 	<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>%i18n:@invitation-code%</span> | ||||||
| 			<span slot="prefix">%fa:id-card-alt%</span> | 			<span slot="prefix">%fa:id-card-alt%</span> | ||||||
| 			<p slot="text" v-html="'%i18n:@invitation-info%'.replace('{}', meta.maintainer.url)"></p> | 			<p slot="text" v-html="'%i18n:@invitation-info%'.replace('{}', meta.maintainer.url)"></p> | ||||||
| 		</ui-input> | 		</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>%i18n:@username%</span> | ||||||
| 			<span slot="prefix">@</span> | 			<span slot="prefix">@</span> | ||||||
| 			<span slot="suffix">@{{ host }}</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 == '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> | 			<p slot="text" v-if="usernameState == 'max-range'" style="color:#FF1161">%fa:exclamation-triangle .fw% %i18n:@too-long%</p> | ||||||
| 		</ui-input> | 		</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>%i18n:@password%</span> | ||||||
| 			<span slot="prefix">%fa:lock%</span> | 			<span slot="prefix">%fa:lock%</span> | ||||||
| 			<div slot="text"> | 			<div slot="text"> | ||||||
| @@ -27,7 +27,7 @@ | |||||||
| 				<p slot="text" v-if="passwordStrength == 'high'" style="color:#3CB7B5">%fa:check .fw% %i18n:@strong-password%</p> | 				<p slot="text" v-if="passwordStrength == 'high'" style="color:#3CB7B5">%fa:check .fw% %i18n:@strong-password%</p> | ||||||
| 			</div> | 			</div> | ||||||
| 		</ui-input> | 		</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>%i18n:@password% (%i18n:@retype%)</span> | ||||||
| 			<span slot="prefix">%fa:lock%</span> | 			<span slot="prefix">%fa:lock%</span> | ||||||
| 			<div slot="text"> | 			<div slot="text"> | ||||||
| @@ -131,11 +131,11 @@ export default Vue.extend({ | |||||||
| 				password: this.password, | 				password: this.password, | ||||||
| 				invitationCode: this.invitationCode, | 				invitationCode: this.invitationCode, | ||||||
| 				'g-recaptcha-response': this.meta.recaptchaSitekey != null ? (window as any).grecaptcha.getResponse() : null | 				'g-recaptcha-response': this.meta.recaptchaSitekey != null ? (window as any).grecaptcha.getResponse() : null | ||||||
| 			}).then(() => { | 			}, true).then(() => { | ||||||
| 				(this as any).api('signin', { | 				(this as any).api('signin', { | ||||||
| 					username: this.username, | 					username: this.username, | ||||||
| 					password: this.password | 					password: this.password | ||||||
| 				}).then(() => { | 				}, true).then(() => { | ||||||
| 					location.href = '/'; | 					location.href = '/'; | ||||||
| 				}); | 				}); | ||||||
| 			}).catch(() => { | 			}).catch(() => { | ||||||
| @@ -151,7 +151,7 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' |  | ||||||
|  |  | ||||||
| .mk-signup | .mk-signup | ||||||
| 	min-width 302px | 	min-width 302px | ||||||
|   | |||||||
| @@ -1,14 +1,14 @@ | |||||||
| <template> | <template> | ||||||
| <div class="mk-stream-indicator"> | <div class="mk-stream-indicator"> | ||||||
| 	<p v-if=" stream.state == 'initializing' "> | 	<p v-if="stream.state == 'initializing'"> | ||||||
| 		%fa:spinner .pulse% | 		%fa:spinner .pulse% | ||||||
| 		<span>%i18n:@connecting%<mk-ellipsis/></span> | 		<span>%i18n:@connecting%<mk-ellipsis/></span> | ||||||
| 	</p> | 	</p> | ||||||
| 	<p v-if=" stream.state == 'reconnecting' "> | 	<p v-if="stream.state == 'reconnecting'"> | ||||||
| 		%fa:spinner .pulse% | 		%fa:spinner .pulse% | ||||||
| 		<span>%i18n:@reconnecting%<mk-ellipsis/></span> | 		<span>%i18n:@reconnecting%<mk-ellipsis/></span> | ||||||
| 	</p> | 	</p> | ||||||
| 	<p v-if=" stream.state == 'connected' "> | 	<p v-if="stream.state == 'connected'"> | ||||||
| 		%fa:check% | 		%fa:check% | ||||||
| 		<span>%i18n:@connected%</span> | 		<span>%i18n:@connected%</span> | ||||||
| 	</p> | 	</p> | ||||||
|   | |||||||
| @@ -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> |  | ||||||
| @@ -63,7 +63,7 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| root(isDark) | .jtivnzhfwquxpsfidertopbmwmchmnmo | ||||||
| 	height 100% | 	height 100% | ||||||
| 	width 100% | 	width 100% | ||||||
|  |  | ||||||
| @@ -81,10 +81,4 @@ root(isDark) | |||||||
| 		height 100% | 		height 100% | ||||||
| 		width 100% | 		width 100% | ||||||
|  |  | ||||||
| .jtivnzhfwquxpsfidertopbmwmchmnmo[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .jtivnzhfwquxpsfidertopbmwmchmnmo:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
							
								
								
									
										343
									
								
								src/client/app/common/views/components/theme.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										343
									
								
								src/client/app/common/views/components/theme.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,343 @@ | |||||||
|  | <template> | ||||||
|  | <div class="nicnklzforebnpfgasiypmpdaaglujqm"> | ||||||
|  | 	<label> | ||||||
|  | 		<span>%i18n:@light-theme%</span> | ||||||
|  | 		<ui-select v-model="light" placeholder="%i18n:@light-theme%"> | ||||||
|  | 			<optgroup label="%i18n:@light-themes%"> | ||||||
|  | 				<option v-for="x in lightThemes" :value="x.id" :key="x.id">{{ x.name }}</option> | ||||||
|  | 			</optgroup> | ||||||
|  | 			<optgroup label="%i18n:@dark-themes%"> | ||||||
|  | 				<option v-for="x in darkThemes" :value="x.id" :key="x.id">{{ x.name }}</option> | ||||||
|  | 			</optgroup> | ||||||
|  | 		</ui-select> | ||||||
|  | 	</label> | ||||||
|  |  | ||||||
|  | 	<label> | ||||||
|  | 		<span>%i18n:@dark-theme%</span> | ||||||
|  | 		<ui-select v-model="dark" placeholder="%i18n:@dark-theme%"> | ||||||
|  | 			<optgroup label="%i18n:@dark-themes%"> | ||||||
|  | 				<option v-for="x in darkThemes" :value="x.id" :key="x.id">{{ x.name }}</option> | ||||||
|  | 			</optgroup> | ||||||
|  | 			<optgroup label="%i18n:@light-themes%"> | ||||||
|  | 				<option v-for="x in lightThemes" :value="x.id" :key="x.id">{{ x.name }}</option> | ||||||
|  | 			</optgroup> | ||||||
|  | 		</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:@manage-themes%</summary> | ||||||
|  | 		<ui-select v-model="selectedThemeId" placeholder="%i18n:@select-theme%"> | ||||||
|  | 			<optgroup label="%i18n:@builtin-themes%"> | ||||||
|  | 				<option v-for="x in builtinThemes" :value="x.id" :key="x.id">{{ x.name }}</option> | ||||||
|  | 			</optgroup> | ||||||
|  | 			<optgroup label="%i18n:@my-themes%"> | ||||||
|  | 				<option v-for="x in installedThemes.filter(t => t.author == this.$store.state.i.username)" :value="x.id" :key="x.id">{{ x.name }}</option> | ||||||
|  | 			</optgroup> | ||||||
|  | 			<optgroup label="%i18n:@installed-themes%"> | ||||||
|  | 				<option v-for="x in installedThemes.filter(t => t.author != this.$store.state.i.username)" :value="x.id" :key="x.id">{{ x.name }}</option> | ||||||
|  | 			</optgroup> | ||||||
|  | 		</ui-select> | ||||||
|  | 		<template v-if="selectedTheme"> | ||||||
|  | 			<ui-input readonly :value="selectedTheme.author"> | ||||||
|  | 				<span>%i18n:@author%</span> | ||||||
|  | 			</ui-input> | ||||||
|  | 			<ui-textarea v-if="selectedTheme.desc" readonly :value="selectedTheme.desc"> | ||||||
|  | 				<span>%i18n:@desc%</span> | ||||||
|  | 			</ui-textarea> | ||||||
|  | 			<ui-textarea readonly :value="selectedThemeCode"> | ||||||
|  | 				<span>%i18n:@theme-code%</span> | ||||||
|  | 			</ui-textarea> | ||||||
|  | 			<ui-button @click="export_()" link :download="`${selectedTheme.name}.misskeytheme`" ref="export">%fa:box% %i18n:@export%</ui-button> | ||||||
|  | 			<ui-button @click="uninstall()" v-if="!builtinThemes.some(t => t.id == selectedTheme.id)">%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 { | ||||||
|  | 			builtinThemes: builtinThemes, | ||||||
|  | 			installThemeCode: null, | ||||||
|  | 			selectedThemeId: null, | ||||||
|  | 			myThemeBase: 'light', | ||||||
|  | 			myThemeName: '', | ||||||
|  | 			myThemeDesc: '', | ||||||
|  | 			myThemePrimary: lightTheme.vars.primary, | ||||||
|  | 			myThemeSecondary: lightTheme.vars.secondary, | ||||||
|  | 			myThemeText: lightTheme.vars.text | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	computed: { | ||||||
|  | 		themes(): Theme[] { | ||||||
|  | 			return builtinThemes.concat(this.$store.state.device.themes); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		darkThemes(): Theme[] { | ||||||
|  | 			return this.themes.filter(t => t.base == 'dark' || t.kind == 'dark'); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		lightThemes(): Theme[] { | ||||||
|  | 			return this.themes.filter(t => t.base == 'light' || t.kind == 'light'); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		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 }); } | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		selectedTheme() { | ||||||
|  | 			if (this.selectedThemeId == null) return null; | ||||||
|  | 			return this.themes.find(x => x.id == this.selectedThemeId); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		selectedThemeCode() { | ||||||
|  | 			if (this.selectedTheme == null) return null; | ||||||
|  | 			return JSON5.stringify(this.selectedTheme, 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) { | ||||||
|  | 				this.$swal({ | ||||||
|  | 					type: 'error', | ||||||
|  | 					text: '%i18n:@invalid-theme%' | ||||||
|  | 				}); | ||||||
|  | 				return; | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			// 後方互換性のため | ||||||
|  | 			if (theme.id == null && theme.meta != null) { | ||||||
|  | 				theme = convertOldThemedefinition(theme); | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			if (theme.id == null) { | ||||||
|  | 				this.$swal({ | ||||||
|  | 					type: 'error', | ||||||
|  | 					text: '%i18n:@invalid-theme%' | ||||||
|  | 				}); | ||||||
|  | 				return; | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			if (this.$store.state.device.themes.some(t => t.id == theme.id)) { | ||||||
|  | 				this.$swal({ | ||||||
|  | 					type: 'info', | ||||||
|  | 					text: '%i18n:@already-installed%' | ||||||
|  | 				}); | ||||||
|  | 				return; | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			const themes = this.$store.state.device.themes.concat(theme); | ||||||
|  | 			this.$store.commit('device/set', { | ||||||
|  | 				key: 'themes', value: themes | ||||||
|  | 			}); | ||||||
|  |  | ||||||
|  | 			this.$swal({ | ||||||
|  | 				type: 'success', | ||||||
|  | 				text: '%i18n:@installed%'.replace('{}', theme.name) | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		uninstall() { | ||||||
|  | 			const theme = this.selectedTheme; | ||||||
|  | 			const themes = this.$store.state.device.themes.filter(t => t.id != theme.id); | ||||||
|  | 			this.$store.commit('device/set', { | ||||||
|  | 				key: 'themes', value: themes | ||||||
|  | 			}); | ||||||
|  |  | ||||||
|  | 			this.$swal({ | ||||||
|  | 				type: 'info', | ||||||
|  | 				text: '%i18n:@uninstalled%'.replace('{}', theme.name) | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		import_() { | ||||||
|  | 			(this.$refs.file as any).click(); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		export_() { | ||||||
|  | 			const blob = new Blob([this.selectedThemeCode], { | ||||||
|  | 				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() == '') { | ||||||
|  | 				this.$swal({ | ||||||
|  | 					type: 'warning', | ||||||
|  | 					text: '%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 | ||||||
|  | 			}); | ||||||
|  |  | ||||||
|  | 			this.$swal({ | ||||||
|  | 				type: 'success', | ||||||
|  | 				text: '%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> | ||||||
| @@ -49,13 +49,14 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| root(isDark) | .csqvmxybqbycalfhkxvyfrgbrdalkaoc | ||||||
| 	> .fetching | 	> .fetching | ||||||
| 	> .empty | 	> .empty | ||||||
| 		margin 0 | 		margin 0 | ||||||
| 		padding 16px | 		padding 16px | ||||||
| 		text-align center | 		text-align center | ||||||
| 		color #aaa | 		color var(--text) | ||||||
|  | 		opacity 0.7 | ||||||
|  |  | ||||||
| 		> [data-fa] | 		> [data-fa] | ||||||
| 			margin-right 4px | 			margin-right 4px | ||||||
| @@ -70,13 +71,13 @@ root(isDark) | |||||||
| 			padding 14px 16px | 			padding 14px 16px | ||||||
|  |  | ||||||
| 			&:not(:last-child) | 			&:not(:last-child) | ||||||
| 				border-bottom solid 1px isDark ? #393f4f : #eee | 				border-bottom solid 1px var(--faceDivider) | ||||||
|  |  | ||||||
| 			> .tag | 			> .tag | ||||||
| 				flex 1 | 				flex 1 | ||||||
| 				overflow hidden | 				overflow hidden | ||||||
| 				font-size 14px | 				font-size 14px | ||||||
| 				color isDark ? #9baec8 : #65727b | 				color var(--text) | ||||||
|  |  | ||||||
| 				> a | 				> a | ||||||
| 					display block | 					display block | ||||||
| @@ -94,10 +95,4 @@ root(isDark) | |||||||
| 			> .chart | 			> .chart | ||||||
| 				height 30px | 				height 30px | ||||||
|  |  | ||||||
| .csqvmxybqbycalfhkxvyfrgbrdalkaoc[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .csqvmxybqbycalfhkxvyfrgbrdalkaoc:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -1,9 +1,7 @@ | |||||||
| <template> | <template> | ||||||
| <div class="ui-button" :class="[styl]"> | <component class="dmtdnykelhudezerjlfpbhgovrgnqqgr" :is="link ? 'a' : 'button'" :class="[styl, { inline, primary }]" :type="type" @click="$emit('click')"> | ||||||
| 	<button :type="type" @click="$emit('click')"> | 	<slot></slot> | ||||||
| 		<slot></slot> | </component> | ||||||
| 	</button> |  | ||||||
| </div> |  | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| @@ -13,70 +11,100 @@ export default Vue.extend({ | |||||||
| 		type: { | 		type: { | ||||||
| 			type: String, | 			type: String, | ||||||
| 			required: false | 			required: false | ||||||
|  | 		}, | ||||||
|  | 		primary: { | ||||||
|  | 			type: Boolean, | ||||||
|  | 			required: false, | ||||||
|  | 			default: false | ||||||
|  | 		}, | ||||||
|  | 		inline: { | ||||||
|  | 			type: Boolean, | ||||||
|  | 			required: false, | ||||||
|  | 			default: false | ||||||
|  | 		}, | ||||||
|  | 		link: { | ||||||
|  | 			type: Boolean, | ||||||
|  | 			required: false, | ||||||
|  | 			default: false | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	data() { | 	data() { | ||||||
| 		return { | 		return { | ||||||
| 			styl: 'fill' | 			styl: 'fill' | ||||||
| 		}; | 		}; | ||||||
| 	}, |  | ||||||
| 	inject: { |  | ||||||
| 		isCardChild: { default: false } |  | ||||||
| 	}, |  | ||||||
| 	created() { |  | ||||||
| 		if (this.isCardChild) { |  | ||||||
| 			this.styl = 'line'; |  | ||||||
| 		} |  | ||||||
| 	} | 	} | ||||||
| }); | }); | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' | .dmtdnykelhudezerjlfpbhgovrgnqqgr | ||||||
|  | 	display block | ||||||
|  | 	width 100% | ||||||
|  | 	margin 0 | ||||||
|  | 	padding 8px | ||||||
|  | 	text-align center | ||||||
|  | 	font-weight normal | ||||||
|  | 	font-size 16px | ||||||
|  | 	border none | ||||||
|  | 	border-radius 6px | ||||||
|  | 	outline none | ||||||
|  | 	box-shadow none | ||||||
|  | 	text-decoration none | ||||||
|  | 	user-select none | ||||||
|  |  | ||||||
| root(isDark, fill) | 	* | ||||||
| 	> button | 		pointer-events none | ||||||
| 		display block |  | ||||||
| 		width 100% | 	&:focus | ||||||
| 		margin 0 | 		&:after | ||||||
| 		padding 0 | 			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 | 		font-weight bold | ||||||
| 		font-size 16px |  | ||||||
| 		line-height 44px |  | ||||||
| 		border none |  | ||||||
| 		border-radius 6px |  | ||||||
| 		outline none |  | ||||||
| 		box-shadow none |  | ||||||
|  |  | ||||||
| 		if fill | 	&.fill | ||||||
| 			color $theme-color-foreground | 		color var(--text) | ||||||
| 			background $theme-color | 		background var(--buttonBg) | ||||||
|  |  | ||||||
|  | 		&:hover | ||||||
|  | 			background var(--buttonHoverBg) | ||||||
|  |  | ||||||
|  | 		&:active | ||||||
|  | 			background var(--buttonActiveBg) | ||||||
|  |  | ||||||
|  | 		&.primary | ||||||
|  | 			color var(--primaryForeground) | ||||||
|  | 			background var(--primary) | ||||||
|  |  | ||||||
| 			&:hover | 			&:hover | ||||||
| 				background lighten($theme-color, 5%) | 				background var(--primaryLighten5) | ||||||
|  |  | ||||||
| 			&:active | 			&:active | ||||||
| 				background darken($theme-color, 5%) | 				background var(--primaryDarken5) | ||||||
| 		else |  | ||||||
| 			color $theme-color |  | ||||||
| 			background none |  | ||||||
|  |  | ||||||
| 			&:hover |  | ||||||
| 				color darken($theme-color, 5%) |  | ||||||
|  |  | ||||||
| 			&:active |  | ||||||
| 				background rgba($theme-color, 0.3) |  | ||||||
|  |  | ||||||
| .ui-button[data-darkmode] |  | ||||||
| 	&.fill |  | ||||||
| 		root(true, true) |  | ||||||
| 	&:not(.fill) | 	&:not(.fill) | ||||||
| 		root(true, false) | 		color var(--primary) | ||||||
|  | 		background none | ||||||
|  |  | ||||||
| .ui-button:not([data-darkmode]) | 		&:hover | ||||||
| 	&.fill | 			color var(--primaryDarken5) | ||||||
| 		root(false, true) |  | ||||||
| 	&:not(.fill) | 		&:active | ||||||
| 		root(false, false) | 			background var(--primaryAlpha03) | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| <template> | <template> | ||||||
| <div class="ui-card"> | <div class="ui-card" :class="{ shadow: $store.state.settings.useShadow }"> | ||||||
| 	<header> | 	<header> | ||||||
| 		<slot name="title"></slot> | 		<slot name="title"></slot> | ||||||
| 	</header> | 	</header> | ||||||
| @@ -20,26 +20,27 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' | .ui-card | ||||||
|  |  | ||||||
| root(isDark) |  | ||||||
| 	margin 16px | 	margin 16px | ||||||
| 	color isDark ? #fff : #000 | 	color var(--faceText) | ||||||
| 	background isDark ? #282C37 : #fff | 	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) | 	border-radius var(--round) | ||||||
|  |  | ||||||
|  | 	&.shadow | ||||||
|  | 		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 | 	> header | ||||||
| 		padding 16px | 		padding 16px | ||||||
| 		font-weight bold | 		font-weight bold | ||||||
| 		font-size 20px | 		font-size 20px | ||||||
| 		color isDark ? #fff : #444 | 		color var(--faceText) | ||||||
|  |  | ||||||
| 		@media (min-width 500px) | 		@media (min-width 500px) | ||||||
| 			padding 24px 32px | 			padding 24px 32px | ||||||
|  |  | ||||||
| 	> section | 	> section | ||||||
| 		padding 20px 16px | 		padding 20px 16px | ||||||
| 		border-top solid 1px isDark ? rgba(#000, 0.3) : rgba(#000, 0.1) | 		border-top solid 1px var(--faceDivider) | ||||||
|  |  | ||||||
| 		@media (min-width 500px) | 		@media (min-width 500px) | ||||||
| 			padding 32px | 			padding 32px | ||||||
| @@ -50,12 +51,5 @@ root(isDark) | |||||||
| 		> header | 		> header | ||||||
| 			margin-bottom 16px | 			margin-bottom 16px | ||||||
| 			font-weight bold | 			font-weight bold | ||||||
| 			color isDark ? #fff : #444 | 			color var(--faceText) | ||||||
|  |  | ||||||
| .ui-card[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .ui-card:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -19,7 +19,7 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' |  | ||||||
|  |  | ||||||
| .ui-form | .ui-form | ||||||
| 	> fieldset | 	> fieldset | ||||||
|   | |||||||
| @@ -25,9 +25,7 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' | .nvemkhtwcnnpkdrwfcbzuwhfulejhmzg | ||||||
|  |  | ||||||
| root(isDark) |  | ||||||
| 	display inline-block | 	display inline-block | ||||||
|  |  | ||||||
| 	& + .nvemkhtwcnnpkdrwfcbzuwhfulejhmzg | 	& + .nvemkhtwcnnpkdrwfcbzuwhfulejhmzg | ||||||
| @@ -38,11 +36,11 @@ root(isDark) | |||||||
| 		margin 0 | 		margin 0 | ||||||
| 		padding 12px 20px | 		padding 12px 20px | ||||||
| 		font-size 14px | 		font-size 14px | ||||||
| 		border 1px solid isDark ? #6d727d : #dcdfe6 | 		border 1px solid var(--formButtonBorder) | ||||||
| 		border-radius 4px | 		border-radius 4px | ||||||
| 		outline none | 		outline none | ||||||
| 		box-shadow none | 		box-shadow none | ||||||
| 		color isDark ? #fff : #606266 | 		color var(--text) | ||||||
| 		transition 0.1s | 		transition 0.1s | ||||||
|  |  | ||||||
| 		* | 		* | ||||||
| @@ -50,40 +48,34 @@ root(isDark) | |||||||
|  |  | ||||||
| 		&:hover | 		&:hover | ||||||
| 		&:focus | 		&:focus | ||||||
| 			color $theme-color | 			color var(--primary) | ||||||
| 			background rgba($theme-color, isDark ? 0.2 : 0.12) | 			background var(--formButtonHoverBg) | ||||||
| 			border-color rgba($theme-color, isDark ? 0.5 : 0.3) | 			border-color var(--formButtonHoverBorder) | ||||||
|  |  | ||||||
| 		&:active | 		&:active | ||||||
| 			color darken($theme-color, 20%) | 			color var(--primaryDarken20) | ||||||
| 			background rgba($theme-color, 0.12) | 			background var(--formButtonActiveBg) | ||||||
| 			border-color $theme-color | 			border-color var(--primary) | ||||||
| 			transition all 0s | 			transition all 0s | ||||||
|  |  | ||||||
| 	&.primary | 	&.primary | ||||||
| 		> button | 		> button | ||||||
| 			border 1px solid $theme-color | 			border 1px solid var(--primary) | ||||||
| 			background $theme-color | 			background var(--primary) | ||||||
| 			color $theme-color-foreground | 			color var(--primaryForeground) | ||||||
|  |  | ||||||
| 			&:hover | 			&:hover | ||||||
| 			&:focus | 			&:focus | ||||||
| 				background lighten($theme-color, 20%) | 				background var(--primaryLighten20) | ||||||
| 				border-color lighten($theme-color, 20%) | 				border-color var(--primaryLighten20) | ||||||
|  |  | ||||||
| 			&:active | 			&:active | ||||||
| 				background darken($theme-color, 20%) | 				background var(--primaryDarken20) | ||||||
| 				border-color darken($theme-color, 20%) | 				border-color var(--primaryDarken20) | ||||||
| 				transition all 0s | 				transition all 0s | ||||||
|  |  | ||||||
| 	&.round | 	&.round | ||||||
| 		> button | 		> button | ||||||
| 			border-radius 64px | 			border-radius 64px | ||||||
|  |  | ||||||
| .nvemkhtwcnnpkdrwfcbzuwhfulejhmzg[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .nvemkhtwcnnpkdrwfcbzuwhfulejhmzg:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -49,9 +49,7 @@ export default Vue.extend({ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| @import '~const.styl' | .uywduthvrdnlpsvsjkqigicixgyfctto | ||||||
|  |  | ||||||
| root(isDark) |  | ||||||
| 	display inline-flex | 	display inline-flex | ||||||
| 	margin 0 16px 0 0 | 	margin 0 16px 0 0 | ||||||
| 	cursor pointer | 	cursor pointer | ||||||
| @@ -62,7 +60,7 @@ root(isDark) | |||||||
|  |  | ||||||
| 	&:hover | 	&:hover | ||||||
| 		> .button | 		> .button | ||||||
| 			border solid 2px isDark ? rgba(#fff, 0.7) : rgba(#000, 0.54) | 			border solid 2px var(--inputLabel) | ||||||
|  |  | ||||||
| 	&.disabled | 	&.disabled | ||||||
| 		opacity 0.6 | 		opacity 0.6 | ||||||
| @@ -70,15 +68,15 @@ root(isDark) | |||||||
|  |  | ||||||
| 	&.checked | 	&.checked | ||||||
| 		> .button | 		> .button | ||||||
| 			border-color $theme-color | 			border-color var(--primary) | ||||||
|  |  | ||||||
| 			&:after | 			&:after | ||||||
| 				background-color $theme-color | 				background-color var(--primary) | ||||||
| 				transform scale(1) | 				transform scale(1) | ||||||
| 				opacity 1 | 				opacity 1 | ||||||
|  |  | ||||||
| 		> .label | 		> .label | ||||||
| 			color $theme-color | 			color var(--primary) | ||||||
|  |  | ||||||
| 	> input | 	> input | ||||||
| 		position absolute | 		position absolute | ||||||
| @@ -93,7 +91,7 @@ root(isDark) | |||||||
| 		width 20px | 		width 20px | ||||||
| 		height 20px | 		height 20px | ||||||
| 		background none | 		background none | ||||||
| 		border solid 2px isDark ? rgba(#fff, 0.6) : rgba(#000, 0.4) | 		border solid 2px var(--radioBorder) | ||||||
| 		border-radius 100% | 		border-radius 100% | ||||||
| 		transition inherit | 		transition inherit | ||||||
|  |  | ||||||
| @@ -117,10 +115,4 @@ root(isDark) | |||||||
| 		line-height 20px | 		line-height 20px | ||||||
| 		cursor pointer | 		cursor pointer | ||||||
|  |  | ||||||
| .uywduthvrdnlpsvsjkqigicixgyfctto[data-darkmode] |  | ||||||
| 	root(true) |  | ||||||
|  |  | ||||||
| .uywduthvrdnlpsvsjkqigicixgyfctto:not([data-darkmode]) |  | ||||||
| 	root(false) |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user