Compare commits
	
		
			1340 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 5fbf3c3f72 | ||
|   | 5c497d7563 | ||
|   | 7ee3f63eff | ||
|   | ee85a76678 | ||
|   | e691524416 | ||
|   | ce0f6f7ebe | ||
|   | dfa5cb567f | ||
|   | bcf854b7bb | ||
|   | be0e811e45 | ||
|   | ab009cfbd7 | ||
|   | 3fc7ebf80b | ||
|   | 8c02c0cb30 | ||
|   | 11c015c24e | ||
|   | d937730ab7 | ||
|   | b2b5b1e4c9 | ||
|   | d84b3088ec | ||
|   | 24f2a4731e | ||
|   | 152fba9ba7 | ||
|   | 3e2edcb815 | ||
|   | 9c8e92b2bc | ||
|   | 24c9e1b8d9 | ||
|   | 127cad8bc1 | ||
|   | 1d4f4b829f | ||
|   | 66d7135a5c | ||
|   | 635eee980d | ||
|   | 23f2370c4b | ||
|   | f2b88002a3 | ||
|   | 6c41265625 | ||
|   | b939cb8b4c | ||
|   | d74710260a | ||
|   | 609a15cfb1 | ||
|   | 644532d4db | ||
|   | e9b0ffef0f | ||
|   | 31a133e7f0 | ||
|   | 277a24f8e0 | ||
|   | 6c07411755 | ||
|   | 6894eee6d4 | ||
|   | babdeb5d6e | ||
|   | 7f08d84989 | ||
|   | 32053d963f | ||
|   | 5994ea9465 | ||
|   | 7384a3825a | ||
|   | e31bf214a7 | ||
|   | 48c143d47c | ||
|   | 35d17d4274 | ||
|   | 1e2b8cab02 | ||
|   | 0a9a45b33b | ||
|   | 63a512306d | ||
|   | 190c0c687c | ||
|   | c7094986c9 | ||
|   | c201a65f82 | ||
|   | dd167a476f | ||
|   | b255bbf62a | ||
|   | e19300f424 | ||
|   | aeb0512eaf | ||
|   | 192abef237 | ||
|   | 2d278c563e | ||
|   | 7de9066dda | ||
|   | 5a2a2371fb | ||
|   | a433a25b16 | ||
|   | 9098aaee3e | ||
|   | ea28b788bc | ||
|   | bd9981b998 | ||
|   | b7f1b087e8 | ||
|   | b0fdf25b24 | ||
|   | 58f6e4cf00 | ||
|   | d6fe396c76 | ||
|   | 5a01c6c9a5 | ||
|   | dc98b2b5c2 | ||
|   | 60626c2a07 | ||
|   | 0459ce07fa | ||
|   | b480865031 | ||
|   | c928d38ec0 | ||
|   | 1f44602f38 | ||
|   | 932d007745 | ||
|   | a1dd839909 | ||
|   | 12b1c6c886 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | e4a4a4a469 | ||
|   | 2ffb8f7cf8 | ||
|   | 25dec8b977 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 8b4ee292b1 | ||
|   | 2f8b64d6fb | ||
|   | b608e594af | ||
|   | 9652440579 | ||
|   | 55d2ae2050 | ||
|   | bdde0c3c63 | ||
|   | 08afa44e09 | ||
|   | 3ec3fa2d1e | ||
|   | df74a4eb20 | ||
|   | fdaf483293 | ||
|   | 5ab4d0c29b | ||
|   | d6fab5fd6c | ||
|   | 8df35650e5 | ||
|   | c5b682dc89 | ||
|   | 86d49c6704 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 9e251b3ea0 | ||
|   | 8630cd8df6 | ||
|   | e42c8859b4 | ||
|   | 3636db3f85 | ||
|   | fd4d03db58 | ||
|   | 2c3ea0cfef | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | bc34b4f198 | ||
|   | e93503066c | ||
|   | c4351acf7c | ||
|   | bffd7bbb3b | ||
|   | aad131c913 | ||
|   | 77faf7a84c | ||
|   | 86a7c4772e | ||
|   | 7430e258b1 | ||
|   | 4efdd90066 | ||
|   | 4c0da272ce | ||
|   | cf48b5348f | ||
|   | aa74262564 | ||
|   | 209383274e | ||
|   | c6b1f206a6 | ||
|   | be504fc1fc | ||
|   | 7118f7fec1 | ||
|   | 7451a735e6 | ||
|   | 604a900664 | ||
|   | d7066de378 | ||
|   | f0bfb051c3 | ||
|   | 54c4eb512f | ||
|   | 3750b4d7d0 | ||
|   | 29c5f8c8e7 | ||
|   | 6b87edf63b | ||
|   | 9b3180d74f | ||
|   | 70331a0383 | ||
|   | 2220b852c0 | ||
|   | e5fa171df5 | ||
|   | d083c10ae3 | ||
|   | 7a37b1c641 | ||
|   | e54449fbdb | ||
|   | b5b384772a | ||
|   | 733755bb5a | ||
|   | d6341d8ab6 | ||
|   | b39384258c | ||
|   | dfa032d3f2 | ||
|   | f28fc08a57 | ||
|   | e20e35c48d | ||
|   | bddb47b0bd | ||
|   | 469b21bb29 | ||
|   | 0a8213b851 | ||
|   | 460a4edb13 | ||
|   | 2855ec0372 | ||
|   | 0f34ed3ccd | ||
|   | cbb73e4e15 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 99de2cd0ae | ||
|   | aed7d06af5 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 2c348b51f1 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 14ac8327cf | ||
|   | c520f17f3b | ||
|   | 6c3d3ed322 | ||
|   | f4cf3840e4 | ||
|   | 3b2f116af0 | ||
|   | bba8f87687 | ||
|   | 41b799b369 | ||
|   | d59c6af32c | ||
|   | 1b5023793a | ||
|   | f01a62c83b | ||
|   | ca84202f4c | ||
|   | 9d7ffd1ae1 | ||
|   | 8f6886db82 | ||
|   | da5e708e0f | ||
|   | ff6993478f | ||
|   | a54950f101 | ||
|   | 6b567fdc05 | ||
|   | a4788fae45 | ||
|   | 1ba1a7aa40 | ||
|   | 835057d970 | ||
|   | 48f39e70c3 | ||
|   | 3314640b01 | ||
|   | 83d9730d93 | ||
|   | 4e6dcd16ac | ||
|   | 6debf45004 | ||
|   | 66b57e11db | ||
|   | 1fc1c8a025 | ||
|   | 6076f52390 | ||
|   | 3f33dbf6e8 | ||
|   | 33f0dd8d43 | ||
|   | 921fb0012b | ||
|   | 2bdad9c411 | ||
|   | 01f60c829d | ||
|   | 1d6c0e1c6f | ||
|   | fb74f1d72b | ||
|   | 33e1c08273 | ||
|   | 23c32f1211 | ||
|   | c8a5d693ed | ||
|   | 4a54d01ca8 | ||
|   | 359a7a7b98 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | aaa25deaa9 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | cd07ae4d2e | ||
|   | 1e8c1efe2f | ||
|   | ce405fc4f6 | ||
|   | 50a6efd568 | ||
|   | 2c6f881093 | ||
|   | e4bf0392af | ||
|   | fcb9133f27 | ||
|   | 5c6f24dc39 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | ce562f3bca | ||
|   | 9ef477f04b | ||
|   | 5268fee5b5 | ||
|   | 68e28faedc | ||
|   | 12f63db62e | ||
|   | 08e1c87fa6 | ||
|   | 8ee962b729 | ||
|   | 3d8b45ecdd | ||
|   | 2347d9cea2 | ||
|   | 8a57f490ce | ||
|   | a880f5cbb8 | ||
|   | df5a7c7e0c | ||
|   | b7b82456d8 | ||
|   | 6b19e54c23 | ||
|   | 75d04858e6 | ||
|   | 9332551791 | ||
|   | 32117a573b | ||
|   | d4d3316d18 | ||
|   | 43a7eb233c | ||
|   | 178093861b | ||
|   | 3fb26534b7 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 19a9fdfd38 | ||
|   | 6438e97324 | ||
|   | b29492e8eb | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 5ab4f10230 | ||
|   | 80b251e12c | ||
|   | bfd8b12a4f | ||
|   | 1c2e94658b | ||
|   | 286da28cd6 | ||
|   | a4ee93a355 | ||
|   | ab56cb1788 | ||
|   | 32435e4d8e | ||
|   | 900cdf9d9a | ||
|   | e79019266f | ||
|   | deee7361f0 | ||
|   | bdcf09c618 | ||
|   | 7b5d6dcd9b | ||
|   | 0595d87759 | ||
|   | fab0a0d6e2 | ||
|   | 3eb6b36866 | ||
|   | 50327158e2 | ||
|   | a99756ef85 | ||
|   | 1c25dbed66 | ||
|   | 7e8c5c0c3c | ||
|   | 0b747b901c | ||
|   | 8dd5051201 | ||
|   | f7b0fedc9d | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 0411d0b242 | ||
|   | 3fcc793269 | ||
|   | fd27a0efef | ||
|   | 4474a2568e | ||
|   | 9d944243a3 | ||
|   | 8ef38ebab1 | ||
|   | f457a23eab | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 5d1eeaf1d8 | ||
|   | 77f732c6a4 | ||
|   | ac07f04ad8 | ||
|   | dddd760efd | ||
|   | 0f7fbacb17 | ||
|   | 2697107770 | ||
|   | e1e1cd0574 | ||
|   | 93786aa510 | ||
|   | d8b9a8715b | ||
|   | e8783b15b1 | ||
|   | 0995d5c5a2 | ||
|   | 0852045928 | ||
|   | 04de0e9a50 | ||
|   | 951b693d17 | ||
|   | 308f357c4f | ||
|   | 206ddd6d36 | ||
|   | b4cf963bd6 | ||
|   | 77b493c9b0 | ||
|   | 95a5ff5625 | ||
|   | 190753aa99 | ||
|   | f778696a76 | ||
|   | ce4fb49d4c | ||
|   | 91b89b79d2 | ||
|   | 3cd3e19199 | ||
|   | ed36ceadbc | ||
|   | 8736c9dfe6 | ||
|   | e44f33bf14 | ||
|   | 6e39b73f07 | ||
|   | 01703e5584 | ||
|   | fee7cb41cb | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | bb14af8b40 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 54b849e548 | ||
|   | 8f50482896 | ||
|   | b3b82e7595 | ||
|   | 9c4e0a4ae6 | ||
|   | 0b656999d8 | ||
|   | 7605a512ba | ||
|   | 2018a29968 | ||
|   | dbf335a05d | ||
|   | ad5a7e9d70 | ||
|   | f8477fa88d | ||
|   | a22ddb05ba | ||
|   | 9455edf2da | ||
|   | 4a2244327f | ||
|   | 708a800a25 | ||
|   | a34193ca16 | ||
|   | a4886975e4 | ||
|   | 8b6a015602 | ||
|   | f915560752 | ||
|   | f2f0910771 | ||
|   | 9316e2ce15 | ||
|   | 128573e73e | ||
|   | 3d132ad803 | ||
|   | 6f671325fa | ||
|   | 7e6ac77341 | ||
|   | 51bafe8259 | ||
|   | f1bbbcfedf | ||
|   | 7d99b154c0 | ||
|   | 575da76235 | ||
|   | c3b3b9b9a6 | ||
|   | 7432de3d33 | ||
|   | 03ce87d710 | ||
|   | 5e9fb8bd84 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 68a205486e | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 94c106a87a | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 1b2a04bd2a | ||
|   | a048939cf1 | ||
|   | 6296846078 | ||
|   | e530d12f7f | ||
|   | adc3c16ef3 | ||
|   | 5458b10774 | ||
|   | 9ad403af00 | ||
|   | 8d7f16caed | ||
|   | e5c20ca9a7 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | bd4a7d8cbb | ||
|   | 5b116737b6 | ||
|   | 8adc799041 | ||
|   | 41e657b64e | ||
|   | f16cda51fb | ||
|   | 886510d721 | ||
|   | 427b3dcd73 | ||
|   | 138fa1454f | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 7ec9b03990 | ||
|   | 65a91c5709 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | e679f47c1a | ||
|   | 337ecafa56 | ||
|   | 2c46098fb5 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 35247af220 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | e71da1f659 | ||
|   | 91daa1958b | ||
|   | 900a9cb34f | ||
|   | 297a7f541e | ||
|   | 049085fb7a | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | f594a2d0f4 | ||
|   | ffd13accca | ||
|   | edf2503ee5 | ||
|   | 4d0c303660 | ||
|   | 49bc00102b | ||
|   | 29f074267c | ||
|   | 7671c37f2a | ||
|   | 91ad9e4c41 | ||
|   | ed48349e39 | ||
|   | 2df02a9d70 | ||
|   | 1d027613e4 | ||
|   | e9de73d2f6 | ||
|   | 7b9b01688c | ||
|   | afcf2fddb1 | ||
|   | 78de3ba691 | ||
|   | 2cfefee94d | ||
|   | d50940cdf8 | ||
|   | e38ee663dc | ||
|   | 5a160a76f7 | ||
|   | c504f27a51 | ||
|   | 3f5155e9b5 | ||
|   | dcb85073da | ||
|   | 2a5f3491a6 | ||
|   | 6f6b01344d | ||
|   | 73810758d9 | ||
|   | 6cb527fd58 | ||
|   | 7316352ff5 | ||
|   | ad76d5d8e2 | ||
|   | 539f307500 | ||
|   | 5f68d08cbc | ||
|   | bc8bea11c0 | ||
|   | 9bb02e5bf6 | ||
|   | ae68e6372c | ||
|   | 69593994ef | ||
|   | cb52ebe65b | ||
|   | 9b989ebac6 | ||
|   | f13bef4ac8 | ||
|   | 29b1aa0d9b | ||
|   | 5aa2e47c49 | ||
|   | 773d104306 | ||
|   | b8e948b009 | ||
|   | 49298d2f3f | ||
|   | ac19567f2b | ||
|   | bc627fc55c | ||
|   | eb6c2d0f73 | ||
|   | 436757c71d | ||
|   | 5d09b7e38b | ||
|   | a8cf67198f | ||
|   | 06539db1a0 | ||
|   | de10890bd8 | ||
|   | 8dc5375d55 | ||
|   | 1d23076191 | ||
|   | cbdc061891 | ||
|   | 9536d76b61 | ||
|   | 7a030901c8 | ||
|   | bcc02047ca | ||
|   | c61616388e | ||
|   | 499486f559 | ||
|   | 179d231fd8 | ||
|   | 2e4a391eda | ||
|   | 3d214fee4b | ||
|   | 509a4c7955 | ||
|   | c754046eaf | ||
|   | 92571d9133 | ||
|   | add425abdb | ||
|   | 1890d9e2ee | ||
|   | 83f2926f0c | ||
|   | 738ced81ec | ||
|   | b22c1ae520 | ||
|   | e2e7489b1f | ||
|   | 6ae7b8303d | ||
|   | 55f40af51c | ||
|   | 7a784cea3b | ||
|   | f86cccec0c | ||
|   | 9d90a28d76 | ||
|   | 1724cf7c17 | ||
|   | d64d92ccf5 | ||
|   | f64ced8677 | ||
|   | db1c0468aa | ||
|   | 77c5d3276a | ||
|   | ec2b1ec3f0 | ||
|   | 85bf76dd98 | ||
|   | bfa326af2c | ||
|   | 534c47935a | ||
|   | 31a6f2b421 | ||
|   | 66c106722c | ||
|   | 9d0204f2fa | ||
|   | fceb0e2158 | ||
|   | 14e7caaa5d | ||
|   | 744e009690 | ||
|   | 713dcd9083 | ||
|   | e03ec67b5c | ||
|   | 7e27e2757f | ||
|   | f05c5ff617 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 1afb26f04a | ||
|   | 7873905cde | ||
|   | 41a9100477 | ||
|   | b8cc1eb993 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | adbbfd9dc2 | ||
|   | 84da99d56c | ||
|   | aaf8f09cfd | ||
|   | 6da464fd1b | ||
|   | efaa41ba49 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 67e8e1d819 | ||
|   | 532f8f8e4c | ||
|   | 0109e8e57c | ||
|   | 6e720b2798 | ||
|   | d3f2a97dd4 | ||
|   | 9f7b04b0ec | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | c4118c78b7 | ||
|   | 84147c558f | ||
|   | 4cb51a2d32 | ||
|   | 4727780a3d | ||
|   | df20f5063d | ||
|   | d2a5f4c5c1 | ||
|   | 64ba85aa9b | ||
|   | 51c33989fe | ||
|   | 4713822122 | ||
|   | e10de62a7a | ||
|   | 14b235e3a4 | ||
|   | eb4aac3902 | ||
|   | 180bf33a28 | ||
|   | 935a254c97 | ||
|   | 3c678f0e92 | ||
|   | a053e1c1de | ||
|   | b8fa1751ba | ||
|   | c4243d54a9 | ||
|   | 1767f54fed | ||
|   | 7e465cdbbe | ||
|   | 47f67fcba9 | ||
|   | 3fff20fb13 | ||
|   | 06a2d87129 | ||
|   | a8076e306a | ||
|   | 05e5829260 | ||
|   | 5a91416f34 | ||
|   | 70db1d0066 | ||
|   | 26c936d19e | ||
|   | 3b0ae3f80d | ||
|   | 2570d85543 | ||
|   | b274c4160e | ||
|   | f9d5d9e30b | ||
|   | 8cdf5ff6df | ||
|   | 409ebf6e14 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | a3d34ba919 | ||
|   | 242bb1a428 | ||
|   | 4a25ed0627 | ||
|   | f65fbf9d55 | ||
|   | 6169acd478 | ||
|   | 481f1a7c36 | ||
|   | 16726789da | ||
|   | e71f650ade | ||
|   | e8a7f571e1 | ||
|   | 3117c8a98f | ||
|   | 90b845f3db | ||
|   | f5dd972e38 | ||
|   | 4b210e1a6a | ||
|   | 1a7eb3c1df | ||
|   | 52f84d8603 | ||
|   | f92d218c0c | ||
|   | 81c5ece8a9 | ||
|   | a97bc38f3e | ||
|   | aacfb5e221 | ||
|   | f88ac3c04e | ||
|   | 1fb53acc46 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | ae3b0d5437 | ||
|   | f9b2da1bb0 | ||
|   | d0bea052ad | ||
|   | c012faa958 | ||
|   | c8cfd1ee65 | ||
|   | e8da0bcd80 | ||
|   | 591ff9095a | ||
|   | 6df91d3078 | ||
|   | 288c14efce | ||
|   | ee8d636ca8 | ||
|   | a3ceecae91 | ||
|   | 5ad89a3b3d | ||
|   | e1089cc18d | ||
|   | f9e780187c | ||
|   | 42cbe96a14 | ||
|   | 1f23b11dcc | ||
|   | ad3b4bbd58 | ||
|   | 455f4ffa27 | ||
|   | 1d867b8aca | ||
|   | 1f9c18e615 | ||
|   | 5bf439851d | ||
|   | 9df3f99a1c | ||
|   | f41232703b | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | abc4e53943 | ||
|   | f846508fc1 | ||
|   | 7343003287 | ||
|   | 25ca3d610b | ||
|   | 9d286786d4 | ||
|   | 91037ebdd6 | ||
|   | 26b2eafea0 | ||
|   | 432beedd94 | ||
|   | 3a919bab45 | ||
|   | 11af9b808d | ||
|   | af35335772 | ||
|   | 7b9047cc82 | ||
|   | 4cad36572c | ||
|   | b5625a4550 | ||
|   | ec41d8053c | ||
|   | 284cfe6989 | ||
|   | ad8f363c5d | ||
|   | 3d3cf73c30 | ||
|   | fd9bd28361 | ||
|   | d2919dece0 | ||
|   | a86442bff7 | ||
|   | 4b915d43cf | ||
|   | b20c3d84a6 | ||
|   | d2bbf5ffc4 | ||
|   | 4ef9411f35 | ||
|   | 168d13d6e6 | ||
|   | 1e921a9fd5 | ||
|   | 9e438ed674 | ||
|   | 3a02a7dad8 | ||
|   | 1744316656 | ||
|   | 1e4a86da8e | ||
|   | 2b31b6a6b0 | ||
|   | c7a3f40eba | ||
|   | 8b9710df9f | ||
|   | ce6f750fa5 | ||
|   | 468eb02ff3 | ||
|   | dfca7f1340 | ||
|   | 7bfa56d199 | ||
|   | c579cbdf10 | ||
|   | 0b3609c775 | ||
|   | be52eb9b3f | ||
|   | 5f5156561f | ||
|   | d47f92f396 | ||
|   | 2a30bc9a56 | ||
|   | a427b7a1af | ||
|   | 05d5e70c58 | ||
|   | 62858caaa4 | ||
|   | b9b48a55ef | ||
|   | 7276ec185b | ||
|   | e063ac10c5 | ||
|   | eca9a7ea13 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 86d9a72bbf | ||
|   | 073707b2d0 | ||
|   | b971fbaac6 | ||
|   | 86795f1091 | ||
|   | 5b9dd4fb80 | ||
|   | 5ff31e197b | ||
|   | 0bd5e64b86 | ||
|   | 3089b56f70 | ||
|   | 46bf0eae40 | ||
|   | 97f411130f | ||
|   | b9ce7bc99d | ||
|   | 9d3ecda43d | ||
|   | 8356f6d128 | ||
|   | 05a084dadf | ||
|   | f338fa552e | ||
|   | 7ab9d01bac | ||
|   | 5b0aaf66eb | ||
|   | 6a4e92a999 | ||
|   | 0a4b652493 | ||
|   | eebc1af672 | ||
|   | 41fa045999 | ||
|   | 4b52c89a75 | ||
|   | 28dcf8bc1e | ||
|   | 5af469282a | ||
|   | 4c58dc61bc | ||
|   | c4bf80c262 | ||
|   | e485e8936f | ||
|   | e495e0d2e6 | ||
|   | 3695e6db15 | ||
|   | ac7df96f68 | ||
|   | cf17a39446 | ||
|   | 87cc5f790c | ||
|   | b03987290c | ||
|   | 1f4969547b | ||
|   | d12d201ef4 | ||
|   | c91a4c9da1 | ||
|   | 1213e95ddd | ||
|   | 90a836d587 | ||
|   | 973c2ebafd | ||
|   | 24f52aee46 | ||
|   | 4d2c0e4161 | ||
|   | b687546fcd | ||
|   | 3c701aaf86 | ||
|   | d50e99c17b | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 41d5e0ab24 | ||
|   | c99e864dbc | ||
|   | f39adfdf87 | ||
|   | 0d1ffb581f | ||
|   | 4add44f3bd | ||
|   | baae9f6f39 | ||
|   | 0a9958f45f | ||
|   | 7e5d25cf2c | ||
|   | 9666e6b4d3 | ||
|   | c937cb94f9 | ||
|   | 5e54d093f5 | ||
|   | c7f099276e | ||
|   | ee4235ba71 | ||
|   | 71066d69fb | ||
|   | 4581376198 | ||
|   | 04ebde62bc | ||
|   | fec47f05cf | ||
|   | b9e2fb74ed | ||
|   | a1d6637dd1 | ||
|   | e6fa5a07ce | ||
|   | eec6226c8d | ||
|   | 356fe8180e | ||
|   | 30c120596a | ||
|   | c6e330ea8d | ||
|   | dca55d12ac | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 4426da6233 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 381fe2f436 | ||
|   | 28cd7a67de | ||
|   | 97f75cea52 | ||
|   | 5e788f0da4 | ||
|   | 1fc9d034d0 | ||
|   | dc8f14c23a | ||
|   | e9717da916 | ||
|   | 73c328f90b | ||
|   | 25a6f7041a | ||
|   | ff278c8bea | ||
|   | 35dd6a5ac3 | ||
|   | 98ea238087 | ||
|   | 3830b0d831 | ||
|   | b6de5a2268 | ||
|   | 77327c7a40 | ||
|   | 26664a8351 | ||
|   | 912964104b | ||
|   | 63653ccb01 | ||
|   | 5df54700b8 | ||
|   | f952dde1d4 | ||
|   | 2c0aac5eed | ||
|   | 4e3a2c4bb8 | ||
|   | 17ccfcfb53 | ||
|   | f2959ada85 | ||
|   | e427c12ac2 | ||
|   | 874837666c | ||
|   | c66532d18f | ||
|   | 2bc572b4cc | ||
|   | 2db01f3d5c | ||
|   | a0a116b7bf | ||
|   | aec7d53414 | ||
|   | 09416c9893 | ||
|   | 0e7fe670aa | ||
|   | bd805f1d88 | ||
|   | b984aecaf2 | ||
|   | 56efffffa3 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 2f92be1da0 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | baa52921a0 | ||
|   | 20e0c44f9a | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | ebc83c8f60 | ||
|   | 2d48d9fd87 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 5eb06a3a52 | ||
|   | 9917a1c7e1 | ||
|   | e9c886e871 | ||
|   | 0074f8da1b | ||
|   | 1c98b51e6a | ||
|   | 837bdb1b43 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 48e034be0e | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | b067162ce6 | ||
|   | db42d5b065 | ||
|   | c41ccf7821 | ||
|   | f5fd523ca7 | ||
|   | 5f9482e7d5 | ||
|   | bb98ee27a1 | ||
|   | 3506dd3656 | ||
|   | 88d0b09c88 | ||
|   | 25b88f89a6 | ||
|   | 85343b80b7 | ||
|   | 6766fbdfb3 | ||
|   | c488fca2f2 | ||
|   | ea51460169 | ||
|   | 80e7af30d0 | ||
|   | 8f20edaed0 | ||
|   | 4d7b2d7215 | ||
|   | d0993a8988 | ||
|   | b68af344cb | ||
|   | 58fdeb50f3 | ||
|   | 1af3c42001 | ||
|   | 8ef066adda | ||
|   | 5cc7fa8e8b | ||
|   | fc998ac57c | ||
|   | 9e4fe16f56 | ||
|   | 0cc00101dc | ||
|   | 227cfd6e2f | ||
|   | 876f659847 | ||
|   | 555501d534 | ||
|   | eb392b1251 | ||
|   | e32bf34830 | ||
|   | 94ff21649d | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 35ff0ab2b6 | ||
|   | c3e3007cd5 | ||
|   | fadc80166b | ||
|   | 9201b5318b | ||
|   | c94a9671a2 | ||
|   | 7b3f52505e | ||
|   | 313afbd6db | ||
|   | 0c4f02f288 | ||
|   | b2d33fba66 | ||
|   | a673393db5 | ||
|   | 9f55d4057d | ||
|   | c00a58fc06 | ||
|   | f49db22311 | ||
|   | 204f43e717 | ||
|   | 77a8894ced | ||
|   | f85122b141 | ||
|   | 0cd07cd605 | ||
|   | eb8604f926 | ||
|   | 8b3cb850a5 | ||
|   | 48d1b9444c | ||
|   | fda0a991a2 | ||
|   | bb61bd0c96 | ||
|   | 10e89e656a | ||
|   | 741756d114 | ||
|   | 4f36ff0233 | ||
|   | 5be69edf2e | ||
|   | 730cdceab1 | ||
|   | fa0600afe0 | ||
|   | fc7db7f23c | ||
|   | e09429f932 | ||
|   | 947cd32e85 | ||
|   | 65a3c7dae4 | ||
|   | 0374f58a11 | ||
|   | a7ff8678b5 | ||
|   | b85ae2f77f | ||
|   | 9f93353519 | ||
|   | 37935ed467 | ||
|   | 8ed9e44a78 | ||
|   | a796a68e8a | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | f2b467c5e7 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 21d22b60b4 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | f76d204e09 | ||
|   | 6775d4da9b | ||
|   | 0264430831 | ||
|   | 76c1077b8e | ||
|   | 6efb4eeb6e | ||
|   | f7eb7322fb | ||
|   | cf8b8bad01 | ||
|   | 07fc3360b6 | ||
|   | 61f57e3f53 | ||
|   | cd8696076e | ||
|   | fb45e7148a | ||
|   | 404823eadb | ||
|   | 324822599a | ||
|   | 053530ed34 | ||
|   | 4f1cb005d7 | ||
|   | f3d2183a23 | ||
|   | cdac86d104 | ||
|   | 291627ac15 | ||
|   | 0025f3b526 | ||
|   | 678e80bb8b | ||
|   | 88c37cdcac | ||
|   | 8ed2ca9018 | ||
|   | 27c99ef894 | ||
|   | 41bed99b4c | ||
|   | b127b772fe | ||
|   | 2698c2d3b5 | ||
|   | 7c984d20d7 | ||
|   | 844085d7a7 | ||
|   | 404cc016e2 | ||
|   | 98f643f98e | ||
|   | 9985f85aad | ||
|   | 959f2cd61d | ||
|   | 2a2ef53e4f | ||
|   | 3648b56fc1 | ||
|   | d422fa58cd | ||
|   | ee7e9b328d | ||
|   | 450c1224fd | ||
|   | 7885d73f80 | ||
|   | 7bdcdcc1ce | ||
|   | d375588f7c | ||
|   | 2484894d43 | ||
|   | d82fe69469 | ||
|   | cb5657e15c | ||
|   | 16e2ee2759 | ||
|   | 5621b280ff | ||
|   | 8cd6efbc38 | ||
|   | 0f4f862840 | ||
|   | 14f74a561c | ||
|   | bd970cf215 | ||
|   | 57052013bb | ||
|   | 8e11e2e3fc | ||
|   | ef58503537 | ||
|   | a46d230308 | ||
|   | e85ac32c2d | ||
|   | a7e27c2419 | ||
|   | a4c9a93b6d | ||
|   | 1f3837a8c6 | ||
|   | d92044cf6a | ||
|   | aa4ef6745a | ||
|   | 865fd25af1 | ||
|   | 2cdcbcc80e | ||
|   | 5ea0f23389 | ||
|   | 196a93dc4d | ||
|   | eb6d9d66cf | ||
|   | 142de603bd | ||
|   | 8ed710965f | ||
|   | dc2a7ca2d5 | ||
|   | 32cdbb70d6 | ||
|   | f2e168bd0a | ||
|   | 311a5cc9e3 | ||
|   | 878f2f9015 | ||
|   | 2923950d40 | ||
|   | 0cd1cd787a | ||
|   | ae8a87c40b | ||
|   | c3597941db | ||
|   | d26524767d | ||
|   | 8d61a52eaa | ||
|   | d5bad25c63 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 165e0a3d54 | ||
|   | e74c1f2ac6 | ||
|   | 42d4e6610f | ||
|   | 4179685bb6 | ||
|   | a81a34cd76 | ||
|   | 118db9b267 | ||
|   | fd67d5cb4c | ||
|   | cb0f95ee7d | ||
|   | 029b92935c | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | bc13538167 | ||
|   | 9b41023c43 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 9f1ede0e3e | ||
|   | fcfd9239c1 | ||
|   | 10e9d3f32f | ||
|   | 11439afde7 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 359d3b4392 | ||
|   | d53d45f797 | ||
|   | c6ea5419ff | ||
|   | 7dcb979983 | ||
|   | 034d529afa | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | fb764abeae | ||
|   | d0bce21993 | ||
|   | 5ba4d0a8c4 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 8864158d85 | ||
|   | 85b8749f02 | ||
|   | b412b4a9ff | ||
|   | 081ad9adcf | ||
|   | 80f2cc6728 | ||
|   | bc627da923 | ||
|   | c1b77365a0 | ||
|   | 7994aa96e2 | ||
|   | ccc79eac91 | ||
|   | f0fbff824b | ||
|   | 7293baa1f9 | ||
|   | 20abea6744 | ||
|   | b666fdcc1a | ||
|   | 70c3357f39 | ||
|   | 9d49636cd1 | ||
|   | 67afe968b4 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 09cc5afad6 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | ab53d80fcf | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 1d520473ed | ||
|   | 4636768810 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 01e9402b2c | ||
|   | 947690870b | ||
|   | dd93551ebf | ||
|   | bf237c3dca | ||
|   | 7e108e9f5c | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 75dbbd115b | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 09ca24b032 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | f3d125a3f9 | ||
|   | 51a9666b91 | ||
|   | 2118fc1f0a | ||
|   | 4182e2bd6d | ||
|   | c349711e0d | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 810b4c7191 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 9f730f23e9 | ||
|   | 8a6c9a9e35 | ||
|   | 3a98f5a419 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 597784a3e8 | ||
|   | 48354ece42 | ||
|   | be8624250d | ||
|   | 168f73e988 | ||
|   | a4d62c7c7a | ||
|   | 83eab954f1 | ||
|   | f934fb171a | ||
|   | fe3d95f394 | ||
|   | 10e5caa766 | ||
|   | 5fb8f5a8c7 | ||
|   | 1673957aa6 | ||
|   | 91db717485 | ||
|   | be90e179c6 | ||
|   | 3b1b8e9493 | ||
|   | 4a1ed5a3ca | ||
|   | 212db199e8 | ||
|   | b57a43b26c | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | a1ba5b1316 | ||
|   | 92457f91ae | ||
|   | e84bae9e84 | ||
|   | 1b2682c228 | ||
|   | 6fa825f15d | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | beae1c2860 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 6f975acbb6 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 5e7bed8db3 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 177510afdf | ||
|   | d912cd3b75 | ||
|   | c426748fe2 | ||
|   | 64d80f8f48 | ||
|   | c1d767b0ae | ||
|   | edeb09eee2 | ||
|   | bdb5081c05 | ||
|   | 7dc410691d | ||
|   | 772b9d0ae7 | ||
|   | b0ff4533e2 | ||
|   | 72a09434e3 | ||
|   | 87df50b7e7 | ||
|   | d3d21be588 | ||
|   | 5b92ebfabd | ||
|   | a9d1d8f034 | ||
|   | 436ded4f4f | ||
|   | de55794761 | ||
|   | a23ef386ea | ||
|   | 572aa662f6 | ||
|   | 8b10bee881 | ||
|   | f492458d85 | ||
|   | d2289039d6 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 019fbf5268 | ||
|   | 8d7b04b0e2 | ||
|   | 6e1f8d0533 | ||
|   | b412d2a30a | ||
|   | cbd9f57468 | ||
|   | 2e0ee21964 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 24b20b8d32 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | d1843e2e27 | ||
|   | 30e7aa23d8 | ||
|   | 9f5c22e7c2 | ||
|   | 4f88739b01 | ||
|   | 18c50c82bc | ||
|   | 0b87b16cba | ||
|   | d454cf7493 | ||
|   | 66e5b36d16 | ||
|   | f582cd5c71 | ||
|   | bf731897a3 | ||
|   | a823792d8d | ||
|   | 9e894dfd55 | ||
|   | bd90ebeafd | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | ee12027739 | ||
|   | e02f3558eb | ||
|   | f410e1c4fa | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | e41bc54d43 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 1599e06ffb | ||
|   | 84c49a23c9 | ||
|   | 95c94758cb | ||
|   | 3bc5c5914b | ||
|   | 69d2cd3b6d | ||
|   | 4bca467bd3 | ||
|   | 20061ae5a1 | ||
|   | 78867c3cc9 | ||
|   | f8911cad32 | ||
|   | dd9a461cf5 | ||
|   | 1516ce86f4 | ||
|   | 58ab04f2f4 | ||
|   | 3e651e3ea2 | ||
|   | b02c00eb41 | ||
|   | a9ee45d977 | ||
|   | 156e66438a | ||
|   | 9ac34badad | ||
|   | fdf145657d | ||
|   | f93e0a624e | ||
|   | c8e3af32be | ||
|   | 62b3a49b5f | ||
|   | be88eee8f6 | ||
|   | e7fb192f5d | ||
|   | 18e2ca89b7 | ||
|   | ec8c388f99 | ||
|   | a1518df41a | ||
|   | 312ef38d62 | ||
|   | ed3e0a9d9c | ||
|   | d7ca93b9fa | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 910dfd6ad2 | ||
|   | 041415519b | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 0ba877fef1 | ||
|   | 839c93961c | ||
|   | 30b1be97dd | ||
|   | 55be57ad21 | ||
|   | 58064ec633 | ||
|   | d63044a15e | ||
|   | 5422697397 | ||
|   | 36c2f8fe5d | ||
|   | 2defddc153 | ||
|   | fb9a219349 | ||
|   | 3b5e4276c8 | ||
|   | fab2e08a0d | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 19e9099a78 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 91c2b07cd8 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | fd00c7bd81 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 8919082179 | ||
|   | 2f7c191547 | ||
|   | 80519dc366 | ||
|   | 4d53c813e4 | ||
|   | 750f479d58 | ||
|   | e9a7e99108 | ||
|   | ebf10b3452 | ||
|   | 5d621f5318 | ||
|   | 35dedfc7e4 | ||
|   | 39094adfcf | ||
|   | 74a25bfaa0 | ||
|   | 04ef2f0c8d | ||
|   | fb99906a8c | ||
|   | da0d3e4129 | ||
|   | 3ffe90146c | ||
|   | 81cea41154 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 3ff4f53bbd | ||
|   | a77f67fc32 | ||
|   | 47c45d48b1 | ||
|   | cdd9585cb8 | ||
|   | db60188847 | ||
|   | 21a2e5f415 | ||
|   | 2377c9b4cb | ||
|   | 296f6b1553 | ||
|   | e15643ca46 | ||
|   | 9632ba40cc | ||
|   | a2cdeeb6c7 | ||
|   | a23857ce3c | ||
|   | 78677b3aa7 | ||
|   | 7dd264953f | ||
|   | 17af9c3ab6 | ||
|   | 4b49f8fbb8 | ||
|   | e253225c66 | ||
|   | 6abb6f90f6 | ||
|   | 9fb2743a38 | ||
|   | 17792716a7 | ||
|   | ae7282358e | ||
|   | abc082f7c0 | ||
|   | bf1163ae84 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | be74ca472a | ||
|   | 31b472fa47 | ||
|   | b502627494 | ||
|   | a8017369d0 | ||
|   | 3f0b5e4318 | ||
|   | aea8f93e02 | ||
|   | 874411990b | ||
|   | 780268f70e | ||
|   | 3a8a374e87 | ||
|   | 488f36d491 | ||
|   | 4d48b0be99 | ||
|   | 44f3888c24 | ||
|   | a76fb4c173 | ||
|   | e4aa003157 | ||
|   | 247f334334 | ||
|   | 509cdae832 | ||
|   | 5ff59b3339 | ||
|   | 2b1a785f24 | ||
|   | 2c0b137848 | ||
|   | ef68e633cf | ||
|   | e9e63ba950 | ||
|   | 3fd6167e71 | ||
|   | 6b0573ded1 | ||
|   | 328dc80324 | ||
|   | 24d8617f81 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | e2c3d4f2fb | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 60229d73c9 | ||
|   | 40235463bc | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | c6cbadc514 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 3c3c67a34c | ||
|   | 72eedd2ff9 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | a7e9d5a60b | ||
|   | c3d081b700 | ||
|   | 57f62c919c | ||
|   | 19bdd4fa2a | ||
|   | 9d8391583f | ||
|   | 6037b0acc5 | ||
|   | 09c5efc161 | ||
|   | 16c2aefe7b | ||
|   | 06cfa207fc | ||
|   | 0be8bbc19f | ||
|   | bad85375de | ||
|   | 6c11a7a6c4 | ||
|   | 6f38c6f339 | ||
|   | fb1d727db9 | ||
|   | d98d286dc4 | ||
|   | 1be279dbaa | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 90e6feeb4c | ||
|   | f1f9f235c7 | ||
|   | eb3f938281 | ||
|   | d6ef923134 | ||
|   | 5b01577810 | ||
|   | 2a111d472a | ||
|   | a8809e89b9 | ||
|   | 1ab9a49d01 | ||
|   | f92c116564 | ||
|   | b54539b647 | ||
|   | 87fc6522fb | ||
|   | b0408d1d6e | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 39779ca8d5 | ||
|   | 8c34f7559d | ||
|   | 740c7c2476 | ||
|   | abd43dd471 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | c24b5410bc | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | cde7d0f463 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 54548c3ed0 | ||
|   | 221d1edf0f | ||
|   | 02e75f9539 | ||
|   | 6bed2ff106 | ||
|   | f3e1e4d1da | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 370f6384d9 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 0105587d04 | ||
|   | e327970ab9 | ||
|   | 9e247f39ff | ||
|   | 09f3a10b46 | ||
|   | c3679a84e5 | ||
|   | 75f8d5e7d9 | ||
|   | 6ba4fa50b9 | ||
|   | f5e130f2a6 | ||
|   | cd5dcd87b0 | ||
|   | 54f319af0e | ||
|   | 96949059cf | ||
|   | 763368db99 | ||
|   | f622ea654f | ||
|   | 70c4e6c287 | ||
|   | d7692e875a | ||
|   | 0a94010668 | ||
|   | 50bd1d9a5d | ||
|   | d45121a93b | ||
|   | a55e3fb225 | ||
|   | 426b2f5858 | ||
|   | 3d10b5e538 | ||
|   | b639599620 | ||
|   | 63c51c6ee0 | ||
|   | f39934c274 | ||
|   | adec1643bf | ||
|   | 229ea7d3ab | ||
|   | 03899f042d | ||
|   | 46d7cee639 | ||
|   | eb0c378138 | ||
|   | 79d1bf30a4 | ||
|   | 5786434f37 | ||
|   | 3633d7ada1 | ||
|   | b95d4aed11 | ||
|   | c2f599a33c | ||
|   | 89361cfce4 | ||
|   | 278a6c504a | ||
|   | e140ddf7be | ||
|   | f00ba4e704 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 8128656a9e | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | f2f7a6de6b | ||
|   | 8651d81b73 | ||
|   | 2458255e22 | ||
|   | ea12c6e2c0 | ||
|   | 2e22bd2ecf | ||
|   | 777cb0033e | ||
|   | 127c126ef5 | ||
|   | 01ff8d171a | ||
|   | 457c23fffa | ||
|   | b07911ec68 | ||
|   | fb211d59a8 | ||
|   | 4e586d35a9 | ||
|   | 52f2461fe6 | ||
|   | ac7dab8b6e | ||
|   | 5e171c2ad1 | ||
|   | b4a139515c | ||
|   | 30219f6b6f | ||
|   | d19e6bdd03 | ||
|   | 65ce0a5e54 | ||
|   | c2659d68dc | ||
|   | 773c7ba14b | ||
|   | 93e617f488 | ||
|   | f7959c073f | ||
|   | 6953970be7 | ||
|   | 1496fdaf80 | ||
|   | 0fc034b1ac | ||
|   | c3312c918e | ||
|   | 5a13964ced | ||
|   | fe07b1cb7f | ||
|   | d805a70508 | ||
|   | 0f0009e0db | ||
|   | 4c4cb2bb17 | ||
|   | fe319a529f | ||
|   | 91bea1f6c7 | ||
|   | 01745f7c65 | ||
|   | 5d3943ffa8 | ||
|   | e66d7babc5 | ||
|   | 80e5645a84 | ||
|   | a766faeae9 | ||
|   | 4d2d226446 | ||
|   | 61e83b10c3 | ||
|   | ed675f0956 | ||
|   | 9cce8ab214 | ||
|   | daa409cd82 | ||
|   | 9d65415fdc | ||
|   | 8c40917cc2 | ||
|   | 871f886702 | ||
|   | f19075c50a | ||
|   | 71da205ab7 | ||
|   | a34cc47a11 | ||
|   | cbddaf1d19 | ||
|   | 1f1ed2da4c | ||
|   | 8d81bd0dc0 | ||
|   | 5773a5bfa6 | ||
|   | 7275a48102 | ||
|   | 8f84dd610c | ||
|   | f1f466ed23 | ||
|   | 0ca5237139 | ||
|   | 20549bfdf0 | ||
|   | d692bb3c52 | ||
|   | 44cd1e9223 | ||
|   | f0fec654ff | ||
|   | 4e04e5e0c0 | ||
|   | 4991fb2769 | ||
|   | 4d90d554f8 | ||
|   | e5468713ac | ||
|   | 77013f982d | ||
|   | 0460cdedd7 | ||
|   | 73f5bf69e8 | ||
|   | 750c0d7df2 | ||
|   | 2fcebdd281 | ||
|   | e4e65a4cd5 | ||
|   | e010ecb03f | ||
|   | fc74db668d | ||
|   | 1bac3418b4 | ||
|   | 53df8c48b7 | ||
|   | 92702fe47e | ||
|   | 017c4c12cd | ||
|   | 830d246ba4 | ||
|   | 6b33afa916 | ||
|   | 69a3efd534 | ||
|   | 2d0adb8f4c | ||
|   | da9d8cb138 | ||
|   | 2acaca8582 | ||
|   | 11cf82c6a4 | ||
|   | 1ef66c962a | ||
|   | 03f20599ba | ||
|   | d150b10b3e | ||
|   | c4f323aae3 | ||
|   | 8297f8ccd0 | ||
|   | f336241576 | ||
|   | f6d9a7e7c3 | ||
|   | 80d1ee7543 | ||
|   | e55a254353 | ||
|   | 555a0f276c | ||
|   | 792632d726 | ||
|   | 9cac293efc | ||
|   | cd8bfca29c | ||
|   | b5b437b878 | ||
|   | cc2947063a | ||
|   | 2864a9027f | ||
|   | e11f547308 | ||
|   | cdce7aa5e2 | ||
|   | 82cea185b2 | ||
|   | f92a4bb195 | ||
|   | 9f4f88df9c | ||
|   | e69803cbd1 | ||
|   | f164661ef2 | ||
|   | c9d993b838 | ||
|   | 65f35dc9f4 | ||
|   | b600d462c1 | ||
|   | fa5a82c9ab | ||
|   | a9885be09e | ||
|   | 7b011f4a91 | ||
|   | 41c404abe6 | ||
|   | 2089a761cf | ||
|   | 0ee2df010d | ||
|   | 466844c016 | ||
|   | bbf9a08649 | ||
|   | c985c66652 | ||
|   | f9dc96320e | ||
|   | 42552789fe | ||
|   | 1a2ffeb0b5 | ||
|   | 4f75493249 | ||
|   | 42193695fb | ||
|   | 02af0de21e | ||
|   | 5f8e10e524 | ||
|   | cee93d746c | ||
|   | 08704a383f | ||
|   | 7c596be638 | ||
|   | 07265f594b | ||
|   | 392cb1ba89 | ||
|   | e6f33e997f | ||
|   | a44387f250 | ||
|   | b1b1b7592b | ||
|   | ca668898f4 | ||
|   | fcd437c89f | ||
|   | 7f7d7edc7f | ||
|   | bd827f946a | ||
|   | ad8aa1c179 | ||
|   | 3ebaf83ce0 | ||
|   | 39b1978ff3 | ||
|   | bddff17e5e | ||
|   | 0ac9120064 | ||
|   | d90f75425f | ||
|   | dec7d537dc | ||
|   | 11e95ea092 | ||
|   | c5e9b69eb3 | ||
|   | 120c11b181 | ||
|   | a1ae832129 | ||
|   | 3a4833818f | ||
|   | 8814fc9c9c | ||
|   | e6e02ece89 | ||
|   | acdf7c244f | ||
|   | a72b6745aa | ||
|   | 24086e9023 | ||
|   | c3d4b5ad38 | ||
|   | cc618a83e5 | ||
|   | 9eaa0b27db | ||
|   | a8835a679e | ||
|   | 656bc6df84 | ||
|   | 019aaf7d82 | ||
|   | 76bafbf398 | ||
|   | 030bcb99b1 | 
| @@ -1,61 +1,136 @@ | ||||
| # サーバーのメンテナ情報 | ||||
| name: example-instance-name # Name of your instance | ||||
| description: example-description # Description of your instance | ||||
|  | ||||
| maintainer: | ||||
|   # メンテナの名前 | ||||
|   name: | ||||
|   name: example-maitainer-name # Your name | ||||
|   url: http://example.com/ # Your contact (http or mailto) | ||||
|   repository_url: https://github.com/syuilo/misskey # Repository URL | ||||
|   feedback_url: https://github.com/syuilo/misskey/issues # Feedback URL (e.g. github issue) | ||||
|  | ||||
|   # メンテナの連絡先(URLかmailto形式のURL) | ||||
|   url: | ||||
| # 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. | ||||
|  | ||||
| # (Misskeyを動かす)URL | ||||
| url: | ||||
| url: http://localhost/ | ||||
|  | ||||
| # 待受ポート | ||||
| port: | ||||
| # A port that your Misskey server should listen. | ||||
| # This value is not a port to use when accessing with a browser. | ||||
| port: 80 | ||||
|  | ||||
| # TLSの設定(利用しない場合は省略してください) | ||||
| https: | ||||
|   # 証明書のパス... | ||||
|   key: | ||||
|   cert: | ||||
|  | ||||
| # MongoDBの設定 | ||||
| mongodb: | ||||
|   host: localhost | ||||
|   port: 27017 | ||||
|   db: misskey | ||||
|   user: | ||||
|   pass: | ||||
|   user: example-misskey-user | ||||
|   pass: example-misskey-pass | ||||
|  | ||||
| # Redisの設定 | ||||
| redis: | ||||
|   host: localhost | ||||
|   port: 6379 | ||||
|   pass: | ||||
|   pass: example-pass | ||||
|  | ||||
| # reCAPTCHAの設定 | ||||
| recaptcha: | ||||
|   site_key: | ||||
|   secret_key: | ||||
| # Drive capacity of a local user (MB) | ||||
| localDriveCapacityMb: 256 | ||||
|  | ||||
| # ServiceWrokerの設定 | ||||
| sw: | ||||
|   # VAPIDの公開鍵 | ||||
|   public_key: | ||||
| # Drive capacity of a remote user (MB) | ||||
| remoteDriveCapacityMb: 8 | ||||
|  | ||||
|   # VAPIDの秘密鍵 | ||||
|   private_key: | ||||
|  | ||||
| # Google Maps API | ||||
| google_maps_api_key: | ||||
|  | ||||
| # Twitterインテグレーションの設定(利用しない場合は省略可能) | ||||
| twitter: | ||||
|   # インテグレーション用アプリのコンシューマーキー | ||||
|   consumer_key: | ||||
|  | ||||
|   # インテグレーション用アプリのコンシューマーシークレット | ||||
|   consumer_secret: | ||||
|  | ||||
| # true にすると、リモートのファイルをキャッシュしなくなります(直リンクします)。 | ||||
| # ストレージ容量を節約することができますが、「リモートメディアを表示しない」設定をオンにしているユーザーは、リモートの画像などは見えなくなります。 | ||||
| # If enabled: | ||||
| #  Server will not cache remote files (Using direct link instead). | ||||
| #  You can save your storage. | ||||
| #  Users cannot see remote images when they turn off "Show media from a remote server" setting. | ||||
| preventCache: false | ||||
|  | ||||
| drive: | ||||
|   storage: 'db' | ||||
|  | ||||
|   # OR | ||||
|  | ||||
|   # storage: 'minio' | ||||
|   # bucket: | ||||
|   # prefix: | ||||
|   # config: | ||||
|   #   endPoint: | ||||
|   #   port: | ||||
|   #   secure: | ||||
|   #   accessKey: | ||||
|   #   secretKey: | ||||
|  | ||||
|   # S3 example | ||||
|   # storage: 'minio' | ||||
|   # bucket: bucket-name | ||||
|   # prefix: files | ||||
|   # config: | ||||
|   #   endPoint: s3-us-west-2.amazonaws.com | ||||
|   #   region: us-west-2 | ||||
|   #   secure: true | ||||
|   #   accessKey: XXX | ||||
|   #   secretKey: YYY | ||||
|  | ||||
|   # S3 example (with CDN, custom domain) | ||||
|   # storage: 'minio' | ||||
|   # bucket: drive.example.com | ||||
|   # prefix: files | ||||
|   # baseUrl: https://drive.example.com | ||||
|   # config: | ||||
|   #   endPoint: s3-us-west-2.amazonaws.com | ||||
|   #   region: us-west-2 | ||||
|   #   secure: true | ||||
|   #   accessKey: XXX | ||||
|   #   secretKey: YYY | ||||
|  | ||||
| # | ||||
| # Below settings are optional | ||||
| # | ||||
|  | ||||
| # TLS | ||||
| # https: | ||||
| #   # path for certification | ||||
| #   key: example-tls-key | ||||
| #   cert: example-tls-cert | ||||
|  | ||||
| # Elasticsearch | ||||
| # elasticsearch: | ||||
| #   host: localhost | ||||
| #   port: 9200 | ||||
| #   pass: null | ||||
|  | ||||
| # reCAPTCHA | ||||
| # recaptcha: | ||||
| #   site_key: example-site-key | ||||
| #  secret_key: example-secret-key | ||||
|  | ||||
| # ServiceWorker | ||||
| # sw: | ||||
| #   # Public key of VAPID | ||||
| #   public_key: example-sw-public-key | ||||
|  | ||||
| #   # Private key of VAPID | ||||
| #   private_key: example-sw-private-key | ||||
|  | ||||
| # google_maps_api_key: example-google-maps-api-key | ||||
|  | ||||
| # Twitter integration | ||||
| # twitter: | ||||
| #   consumer_key: example-twitter-consumer-key | ||||
| #   consumer_secret: example-twitter-consumer-secret-key | ||||
|  | ||||
| # Ghost | ||||
| # Ghost account is an account used for the purpose of delegating | ||||
| # followers when putting users in the list. | ||||
| # ghost: user-id-of-your-ghost-account | ||||
|  | ||||
| # Clustering | ||||
| # clusterLimit: 1 | ||||
|   | ||||
							
								
								
									
										2
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,3 +1,5 @@ | ||||
| *.svg -diff -text | ||||
| *.psd -diff -text | ||||
| *.ai -diff -text | ||||
| yarn.lock -diff -text | ||||
| package-lock.json -diff -text | ||||
|   | ||||
							
								
								
									
										7
									
								
								.github/ISSUE_TEMPLATE
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,7 +0,0 @@ | ||||
| <!-- | ||||
| Misskeyへの貢献ありがとうございます。 | ||||
|  | ||||
| バグの報告や提案などで、可能であれば以下の情報を含めてください。 | ||||
| * お使いのブラウザ | ||||
| * デスクトップ版Misskeyかモバイル版Misskeyか | ||||
| --> | ||||
							
								
								
									
										22
									
								
								.github/ISSUE_TEMPLATE/bug_report.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,22 @@ | ||||
| --- | ||||
| name: Bug Report | ||||
| about: Create a report to help us improve | ||||
| --- | ||||
|  | ||||
| # Summary | ||||
| <!-- Tell us what the bug is --> | ||||
|  | ||||
| # Expected Behavior | ||||
| <!--- Tell us what should happen --> | ||||
|  | ||||
| # Actual Behavior | ||||
| <!--- Tell us what happens instead of the expected behavior --> | ||||
|  | ||||
| # Steps to Reproduce | ||||
| 1. | ||||
| 2. | ||||
| 3. | ||||
|  | ||||
| # Environment | ||||
| <!-- Tell us where on the platform it happens --> | ||||
| <!-- e.g. desktop or mobile version, your browser, your OS --> | ||||
							
								
								
									
										11
									
								
								.github/ISSUE_TEMPLATE/feature_request.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,11 @@ | ||||
| --- | ||||
| name: Feature Request | ||||
| about: Suggest an idea for this project | ||||
| --- | ||||
|  | ||||
| # Summary | ||||
| <!-- Tell us what the suggestion is --> | ||||
|  | ||||
| # Environment | ||||
| <!-- Tell us where on the platform it related --> | ||||
| <!-- e.g. desktop or mobile version, your browser, your OS --> | ||||
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -10,5 +10,4 @@ npm-debug.log | ||||
| *.pem | ||||
| run.bat | ||||
| api-docs.json | ||||
| package-lock.json | ||||
| *.log | ||||
|   | ||||
							
								
								
									
										12
									
								
								.vscode/extensions.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,12 @@ | ||||
| { | ||||
| 	"recommendations": [ | ||||
| 		"ducksoupdev.vue2", | ||||
| 		"editorconfig.editorconfig", | ||||
| 		"eg2.tslint", | ||||
| 		"eg2.vscode-npm-script", | ||||
| 		"hollowtree.vue-snippets", | ||||
| 		"ms-vscode.typescript-javascript-grammar", | ||||
| 		"octref.vetur", | ||||
| 		"sysoev.language-stylus" | ||||
| 	] | ||||
| } | ||||
							
								
								
									
										37
									
								
								CHANGELOG.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,37 @@ | ||||
| ChangeLog | ||||
| ========= | ||||
|  | ||||
| 破壊的変更のみ記載。 | ||||
|  | ||||
| This document describes breaking changes only. | ||||
|  | ||||
| 5.0.0 | ||||
| ----- | ||||
|  | ||||
| ### Migration | ||||
|  | ||||
| 起動する前に、`node cli/migration/5.0.0`してください。 | ||||
|  | ||||
| Please run `node cli/migration/5.0.0` before launch. | ||||
|  | ||||
| 4.0.0 | ||||
| ----- | ||||
|  | ||||
| オセロがリバーシに変更されました。 | ||||
|  | ||||
| Othello is now Reversi. | ||||
|  | ||||
| ### Migration | ||||
|  | ||||
| MongoDBの、`othelloGames`と`othelloMatchings`コレクションをそれぞれ`reversiGames`と`reversiMatchings`にリネームしてください。 | ||||
|  | ||||
| You need to rename `othelloGames` and `othelloMatchings` MongoDB collections to `reversiGames` and `reversiMatchings`. | ||||
|  | ||||
| 3.0.0 | ||||
| ----- | ||||
|  | ||||
| ### Migration | ||||
|  | ||||
| 起動する前に、`node cli/recount-stats`してください。 | ||||
|  | ||||
| Please run `node cli/recount-stats` before launch. | ||||
							
								
								
									
										32
									
								
								README.md
									
									
									
									
									
								
							
							
						
						| @@ -5,29 +5,26 @@ | ||||
|  | ||||
| [![][travis-badge]][travis-link] | ||||
| [![][dependencies-badge]][dependencies-link] | ||||
| [![][himawari-badge]][himasaku] | ||||
| [![][sakurako-badge]][himasaku] | ||||
| [](http://makeapullrequest.com) | ||||
| [](http://makeapullrequest.com) [](https://greenkeeper.io/) | ||||
|  | ||||
| > Lead Maintainer: [syuilo][syuilo-link] | ||||
| **Microblogging. Redefined.** | ||||
|  | ||||
| **[Misskey](https://misskey.xyz)** is a completely open source, | ||||
| ultimately sophisticated professional microblogging software. | ||||
|  | ||||
| <a href="https://www.patreon.com/syuilo"><img src="https://c5.patreon.com/external/logo/become_a_patron_button@2x.png" alt="Become a Patron!" width="160" /></a> | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| :sparkles: Features | ||||
| ---------------------------------------------------------------- | ||||
| * Rich text contents | ||||
| * Reactions | ||||
| * User lists | ||||
| * Customizable column view (known as MisskeyDeck) | ||||
| * Customizable column view (called MisskeyDeck) | ||||
|   * and widgets! | ||||
| * Private messages | ||||
| * Mute | ||||
| * Streaming | ||||
| * ActivityPub compatible | ||||
| * ActivityPub support | ||||
|  | ||||
| and more! You can see it with your own eyes at [misskey.xyz](https://misskey.xyz). | ||||
|  | ||||
| @@ -46,18 +43,15 @@ If you want to... | ||||
|  | ||||
| :heart: Backers & Sponsors | ||||
| ---------------------------------------------------------------- | ||||
| [![Backers][backers-image]][support-url] | ||||
| [![Sponsors][sponsors-image]][support-url] | ||||
|  | ||||
| | ![][ooo-icon] | | ||||
| |:-:| | ||||
| | [ooo][ooo-link] | | ||||
| | <img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/619786/32cf01444db24e578cd1982c197f6fc6/1?token-time=2145916800&token-hash=tB1e_r8RlZ5sFL0KV_e8dugapxatNBRK1Z3h67TO1g8%3D"> | <img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12378075/0156f769e20f412594fa6b87d85fe228/1?token-time=2145916800&token-hash=IsIJRUXszzoD6-7pDnRY8I05T9nSznc4GTaxj7C9SwU%3D"> | <img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/4503830/ccf2cc867ea64de0b524bb2e24b9a1cb/1?token-time=2145916800&token-hash=S1zP0QyLU52Dqq6dtc9qNYyWfW86XrYHiR4NMbeOrnA%3D"> | <img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12531784/93a45137841849329ba692da92ac7c60/1?token-time=2145916800&token-hash=tMosUojzUYJCH_3t--tvYA-SMCyrS__hzSndyaRSnbo%3D"> | | ||||
| |:-:|:-:|:-:|:-:| | ||||
| | [Gargron](https://www.patreon.com/mastodon) | [39ff](https://www.patreon.com/user/creators?u=12378075) | [dansup](https://www.patreon.com/dansup) | [Takashi Shibuya](https://www.patreon.com/user/creators?u=12531784) | | ||||
|  | ||||
| :four_leaf_clover: Copyright | ||||
| ---------------------------------------------------------------- | ||||
| > Copyright (c) 2014-2018 syuilo | ||||
|  | ||||
| Misskey is an open-source software licensed under [GNU AGPLv3](LICENSE). | ||||
| Misskey is an open-source software licensed under the [GNU AGPLv3](LICENSE). | ||||
|  | ||||
| [![][agpl-3.0-badge]][AGPL-3.0] | ||||
|  | ||||
| @@ -67,9 +61,6 @@ Misskey is an open-source software licensed under [GNU AGPLv3](LICENSE). | ||||
| [travis-badge]:       http://img.shields.io/travis/syuilo/misskey/master.svg?style=flat-square | ||||
| [dependencies-link]:  https://david-dm.org/syuilo/misskey | ||||
| [dependencies-badge]: https://img.shields.io/david/syuilo/misskey.svg?style=flat-square | ||||
| [himasaku]:           https://himasaku.net | ||||
| [himawari-badge]:     https://img.shields.io/badge/%E5%8F%A4%E8%B0%B7-%E5%90%91%E6%97%A5%E8%91%B5-1684c5.svg?style=flat-square | ||||
| [sakurako-badge]:     https://img.shields.io/badge/%E5%A4%A7%E5%AE%A4-%E6%AB%BB%E5%AD%90-efb02a.svg?style=flat-square | ||||
|  | ||||
| [backer-url]: #backers | ||||
| [backer-badge]: https://opencollective.com/misskey/backers/badge.svg | ||||
| @@ -81,6 +72,3 @@ Misskey is an open-source software licensed under [GNU AGPLv3](LICENSE). | ||||
|  | ||||
| [syuilo-link]:      https://syuilo.com | ||||
| [syuilo-icon]:      https://avatars2.githubusercontent.com/u/4439005?v=3&s=70 | ||||
|  | ||||
| [ooo-link]:   https://www.patreon.com/user/creators?u=11601413 | ||||
| [ooo-icon]:   https://c10.patreonusercontent.com/3/eyJ2IjoiMSIsInciOjIwMH0%3D/patreon-media/user/11601413/20cb15f209924302b399b99d3c98b850?token-time=2145916800&token-hash=IO31nK6VZCMWBWU2VAk2c824BX2QZ4DNPKyHHZXS0iw%3D | ||||
|   | ||||
							
								
								
									
										41
									
								
								appveyor.yml
									
									
									
									
									
								
							
							
						
						| @@ -1,41 +0,0 @@ | ||||
| # appveyor file | ||||
| # http://www.appveyor.com/docs/appveyor-yml | ||||
|  | ||||
| environment: | ||||
|   matrix: | ||||
|     - nodejs_version: 10.1.0 | ||||
|  | ||||
| cache: | ||||
|   - node_modules | ||||
|  | ||||
| build: off | ||||
|  | ||||
| install: | ||||
|   # Update Node.js | ||||
|   # 標準で入っている Node.js を更新します (2014/11/13 時点では、v0.10.32 が標準) | ||||
|   - ps: Update-NodeJsInstallation (Get-NodeJsLatestBuild $env:nodejs_version) | ||||
|   - node --version | ||||
|  | ||||
|   # Update NPM | ||||
|   - npm install -g npm | ||||
|   - npm --version | ||||
|  | ||||
|   # Update node-gyp | ||||
|   # 必須! node-gyp のバージョンを上げないと、ネイティブモジュールのコンパイルに失敗します | ||||
|   - npm install -g node-gyp | ||||
|  | ||||
|   - npm install | ||||
|  | ||||
| init: | ||||
|   # git clone の際の改行を変換しないようにします | ||||
|   - git config --global core.autocrlf false | ||||
|  | ||||
| before_test: | ||||
|   # 設定ファイルを配置 | ||||
|   - cp ./.travis/default.yml ./.config | ||||
|   - cp ./.travis/test.yml ./.config | ||||
|  | ||||
|   - npm run build | ||||
|  | ||||
| test_script: | ||||
|   - npm test | ||||
| Before Width: | Height: | Size: 4.7 KiB After Width: | Height: | Size: 2.5 KiB | 
| Before Width: | Height: | Size: 6.8 KiB After Width: | Height: | Size: 3.9 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/icons/128.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.5 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/icons/16.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 446 B | 
							
								
								
									
										
											BIN
										
									
								
								assets/icons/192.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 3.8 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/icons/256.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.5 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/icons/32.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 774 B | 
							
								
								
									
										
											BIN
										
									
								
								assets/icons/64.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 1.2 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/title.png
									
									
									
									
									
								
							
							
						
						| Before Width: | Height: | Size: 6.6 KiB After Width: | Height: | Size: 3.8 KiB | 
| @@ -9,7 +9,7 @@ const q = { | ||||
| 	'metadata._user.host': { | ||||
| 		$ne: null | ||||
| 	}, | ||||
| 	'metadata.isMetaOnly': false | ||||
| 	'metadata.withoutChunks': false | ||||
| }; | ||||
|  | ||||
| async function main() { | ||||
| @@ -57,7 +57,7 @@ async function main() { | ||||
|  | ||||
| 					DriveFile.update({ _id: file._id }, { | ||||
| 						$set: { | ||||
| 							'metadata.isMetaOnly': true | ||||
| 							'metadata.withoutChunks': true | ||||
| 						} | ||||
| 					}) | ||||
| 				]).then(async () => { | ||||
|   | ||||
							
								
								
									
										168
									
								
								cli/init.js
									
									
									
									
									
								
							
							
						
						| @@ -1,168 +0,0 @@ | ||||
| const fs = require('fs'); | ||||
| const path = require('path'); | ||||
| const yaml = require('js-yaml'); | ||||
| const inquirer = require('inquirer'); | ||||
| const chalk = require('chalk'); | ||||
|  | ||||
| const configDirPath = `${__dirname}/../.config`; | ||||
| const configPath = `${configDirPath}/default.yml`; | ||||
|  | ||||
| const form = [{ | ||||
| 	type: 'input', | ||||
| 	name: 'maintainerName', | ||||
| 	message: 'Your name:' | ||||
| }, { | ||||
| 	type: 'input', | ||||
| 	name: 'maintainerUrl', | ||||
| 	message: 'Your home page URL or your mailto URL:' | ||||
| }, { | ||||
| 	type: 'input', | ||||
| 	name: 'url', | ||||
| 	message: 'URL you want to run Misskey:', | ||||
| 	validate: function(wannabeurl) { | ||||
| 		return wannabeurl.match('^http\(s?\)://') ? true : | ||||
| 		       'URL needs to start with http:// or https://'; | ||||
| 	} | ||||
| }, { | ||||
| 	type: 'input', | ||||
| 	name: 'port', | ||||
| 	message: 'Listen port (e.g. 443):' | ||||
| }, { | ||||
| 	type: 'confirm', | ||||
| 	name: 'https', | ||||
| 	message: 'Use TLS?', | ||||
| 	default: false | ||||
| }, { | ||||
| 	type: 'input', | ||||
| 	name: 'https_key', | ||||
| 	message: 'Path of tls key:', | ||||
| 	when: ctx => ctx.https | ||||
| }, { | ||||
| 	type: 'input', | ||||
| 	name: 'https_cert', | ||||
| 	message: 'Path of tls cert:', | ||||
| 	when: ctx => ctx.https | ||||
| }, { | ||||
| 	type: 'input', | ||||
| 	name: 'https_ca', | ||||
| 	message: 'Path of tls ca:', | ||||
| 	when: ctx => ctx.https | ||||
| }, { | ||||
| 	type: 'input', | ||||
| 	name: 'mongo_host', | ||||
| 	message: 'MongoDB\'s host:', | ||||
| 	default: 'localhost' | ||||
| }, { | ||||
| 	type: 'input', | ||||
| 	name: 'mongo_port', | ||||
| 	message: 'MongoDB\'s port:', | ||||
| 	default: '27017' | ||||
| }, { | ||||
| 	type: 'input', | ||||
| 	name: 'mongo_db', | ||||
| 	message: 'MongoDB\'s db:', | ||||
| 	default: 'misskey' | ||||
| }, { | ||||
| 	type: 'input', | ||||
| 	name: 'mongo_user', | ||||
| 	message: 'MongoDB\'s user:' | ||||
| }, { | ||||
| 	type: 'password', | ||||
| 	name: 'mongo_pass', | ||||
| 	message: 'MongoDB\'s password:' | ||||
| }, { | ||||
| 	type: 'input', | ||||
| 	name: 'redis_host', | ||||
| 	message: 'Redis\'s host:', | ||||
| 	default: 'localhost' | ||||
| }, { | ||||
| 	type: 'input', | ||||
| 	name: 'redis_port', | ||||
| 	message: 'Redis\'s port:', | ||||
| 	default: '6379' | ||||
| }, { | ||||
| 	type: 'password', | ||||
| 	name: 'redis_pass', | ||||
| 	message: 'Redis\'s password:' | ||||
| }, { | ||||
| 	type: 'confirm', | ||||
| 	name: 'elasticsearch', | ||||
| 	message: 'Use Elasticsearch?', | ||||
| 	default: false | ||||
| }, { | ||||
| 	type: 'input', | ||||
| 	name: 'es_host', | ||||
| 	message: 'Elasticsearch\'s host:', | ||||
| 	default: 'localhost', | ||||
| 	when: ctx => ctx.elasticsearch | ||||
| }, { | ||||
| 	type: 'input', | ||||
| 	name: 'es_port', | ||||
| 	message: 'Elasticsearch\'s port:', | ||||
| 	default: '9200', | ||||
| 	when: ctx => ctx.elasticsearch | ||||
| }, { | ||||
| 	type: 'password', | ||||
| 	name: 'es_pass', | ||||
| 	message: 'Elasticsearch\'s password:', | ||||
| 	when: ctx => ctx.elasticsearch | ||||
| }, { | ||||
| 	type: 'input', | ||||
| 	name: 'recaptcha_site', | ||||
| 	message: 'reCAPTCHA\'s site key:' | ||||
| }, { | ||||
| 	type: 'input', | ||||
| 	name: 'recaptcha_secret', | ||||
| 	message: 'reCAPTCHA\'s secret key:' | ||||
| }]; | ||||
|  | ||||
| inquirer.prompt(form).then(as => { | ||||
| 	// Mapping answers | ||||
| 	const conf = { | ||||
| 		maintainer: { | ||||
| 			name: as['maintainerName'], | ||||
| 			url: as['maintainerUrl'] | ||||
| 		}, | ||||
| 		url: as['url'], | ||||
| 		port: parseInt(as['port'], 10), | ||||
| 		mongodb: { | ||||
| 			host: as['mongo_host'], | ||||
| 			port: parseInt(as['mongo_port'], 10), | ||||
| 			db: as['mongo_db'], | ||||
| 			user: as['mongo_user'], | ||||
| 			pass: as['mongo_pass'] | ||||
| 		}, | ||||
| 		redis: { | ||||
| 			host: as['redis_host'], | ||||
| 			port: parseInt(as['redis_port'], 10), | ||||
| 			pass: as['redis_pass'] | ||||
| 		}, | ||||
| 		elasticsearch: { | ||||
| 			enable: as['elasticsearch'], | ||||
| 			host: as['es_host'] || null, | ||||
| 			port: parseInt(as['es_port'], 10) || null, | ||||
| 			pass: as['es_pass'] || null | ||||
| 		}, | ||||
| 		recaptcha: { | ||||
| 			site_key: as['recaptcha_site'], | ||||
| 			secret_key: as['recaptcha_secret'] | ||||
| 		} | ||||
| 	}; | ||||
|  | ||||
| 	if (as['https']) { | ||||
| 		conf.https = { | ||||
| 			key: as['https_key'] || null, | ||||
| 			cert: as['https_cert'] || null, | ||||
| 			ca: as['https_ca'] || null | ||||
| 		}; | ||||
| 	} | ||||
|  | ||||
| 	console.log(`Thanks. Writing the configuration to ${chalk.bold(path.resolve(configPath))}`); | ||||
|  | ||||
| 	try { | ||||
| 		fs.writeFileSync(configPath, yaml.dump(conf)); | ||||
| 		console.log(chalk.green('Well done.')); | ||||
| 	} catch (e) { | ||||
| 		console.error(e); | ||||
| 	} | ||||
| }); | ||||
							
								
								
									
										23
									
								
								cli/mark-admin.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,23 @@ | ||||
| const mongo = require('mongodb'); | ||||
| const User = require('../built/models/user').default; | ||||
|  | ||||
| const args = process.argv.slice(2); | ||||
|  | ||||
| const user = args[0]; | ||||
|  | ||||
| const q = user.startsWith('@') ? { | ||||
| 	username: user.split('@')[1], | ||||
| 	host: user.split('@')[2] || null | ||||
| } : { _id: new mongo.ObjectID(user) }; | ||||
|  | ||||
| console.log(`Mark as admin ${user}...`); | ||||
|  | ||||
| User.update(q, { | ||||
| 	$set: { | ||||
| 		isAdmin: true | ||||
| 	} | ||||
| }).then(() => { | ||||
| 	console.log(`Done ${user}`); | ||||
| }, e => { | ||||
| 	console.error(e); | ||||
| }); | ||||
							
								
								
									
										23
									
								
								cli/mark-verified.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,23 @@ | ||||
| const mongo = require('mongodb'); | ||||
| const User = require('../built/models/user').default; | ||||
|  | ||||
| const args = process.argv.slice(2); | ||||
|  | ||||
| const user = args[0]; | ||||
|  | ||||
| const q = user.startsWith('@') ? { | ||||
| 	username: user.split('@')[1], | ||||
| 	host: user.split('@')[2] || null | ||||
| } : { _id: new mongo.ObjectID(user) }; | ||||
|  | ||||
| console.log(`Mark as verfied ${user}...`); | ||||
|  | ||||
| User.update(q, { | ||||
| 	$set: { | ||||
| 		isVerified: true | ||||
| 	} | ||||
| }).then(() => { | ||||
| 	console.log(`Done ${user}`); | ||||
| }, e => { | ||||
| 	console.error(e); | ||||
| }); | ||||
| @@ -3,8 +3,8 @@ | ||||
| const chalk = require('chalk'); | ||||
| const sequential = require('promise-sequential'); | ||||
| 
 | ||||
| const { default: User } = require('../built/models/user'); | ||||
| const { default: DriveFile } = require('../built/models/drive-file'); | ||||
| const { default: User } = require('../../built/models/user'); | ||||
| const { default: DriveFile } = require('../../built/models/drive-file'); | ||||
| 
 | ||||
| async function main() { | ||||
| 	const promiseGens = []; | ||||
| @@ -3,8 +3,8 @@ | ||||
| const chalk = require('chalk'); | ||||
| const sequential = require('promise-sequential'); | ||||
| 
 | ||||
| const { default: User } = require('../built/models/user'); | ||||
| const { default: DriveFile } = require('../built/models/drive-file'); | ||||
| const { default: User } = require('../../built/models/user'); | ||||
| const { default: DriveFile } = require('../../built/models/drive-file'); | ||||
| 
 | ||||
| async function main() { | ||||
| 	const promiseGens = []; | ||||
							
								
								
									
										9
									
								
								cli/migration/5.0.0.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,9 @@ | ||||
| const { default: DriveFile } = require('../../built/models/drive-file'); | ||||
|  | ||||
| DriveFile.update({}, { | ||||
| 	$rename: { | ||||
| 		'metadata.isMetaOnly': 'metadata.withoutChunks' | ||||
| 	} | ||||
| }, { | ||||
| 	multi: true | ||||
| }); | ||||
							
								
								
									
										42
									
								
								cli/recount-stats.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,42 @@ | ||||
| const { default: Note } = require('../built/models/note'); | ||||
| const { default: Meta } = require('../built/models/meta'); | ||||
| const { default: User } = require('../built/models/user'); | ||||
|  | ||||
| async function main() { | ||||
| 	const meta = await Meta.findOne({}); | ||||
|  | ||||
| 	const notesCount = await Note.count(); | ||||
|  | ||||
| 	const usersCount = await User.count(); | ||||
|  | ||||
| 	const originalNotesCount = await Note.count({ | ||||
| 		'_user.host': null | ||||
| 	}); | ||||
|  | ||||
| 	const originalUsersCount = await User.count({ | ||||
| 		host: null | ||||
| 	}); | ||||
|  | ||||
| 	const stats = { | ||||
| 		notesCount, | ||||
| 		usersCount, | ||||
| 		originalNotesCount, | ||||
| 		originalUsersCount | ||||
| 	}; | ||||
|  | ||||
| 	if (meta) { | ||||
| 		await Meta.update({}, { | ||||
| 			$set: { | ||||
| 				stats | ||||
| 			} | ||||
| 		}); | ||||
| 	} else { | ||||
| 		await Meta.insert({ | ||||
| 			stats | ||||
| 		}); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| main().then(() => { | ||||
| 	console.log('done'); | ||||
| }).catch(console.error); | ||||
							
								
								
									
										29
									
								
								cli/reset-password.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,29 @@ | ||||
| const mongo = require('mongodb'); | ||||
| const bcrypt = require('bcryptjs'); | ||||
| const User = require('../built/models/user').default; | ||||
|  | ||||
| const args = process.argv.slice(2); | ||||
|  | ||||
| const user = args[0]; | ||||
|  | ||||
| const q = user.startsWith('@') ? { | ||||
| 	username: user.split('@')[1], | ||||
| 	host: user.split('@')[2] || null | ||||
| } : { _id: new mongo.ObjectID(user) }; | ||||
|  | ||||
| console.log(`Resetting password for ${user}...`); | ||||
|  | ||||
| const passwd = 'yo'; | ||||
|  | ||||
| // Generate hash of password | ||||
| const hash = bcrypt.hashSync(passwd); | ||||
|  | ||||
| User.update(q, { | ||||
| 	$set: { | ||||
| 		password: hash | ||||
| 	} | ||||
| }).then(() => { | ||||
| 	console.log(`Password of ${user} is now '${passwd}'`); | ||||
| }, e => { | ||||
| 	console.error(e); | ||||
| }); | ||||
| @@ -14,7 +14,7 @@ RUN pacman -S --noconfirm pacman | ||||
| RUN pacman-db-upgrade | ||||
| RUN pacman -S --noconfirm archlinux-keyring | ||||
| RUN pacman -Syyu --noconfirm | ||||
| RUN pacman -S --noconfirm git nodejs npm mongodb redis imagemagick | ||||
| RUN pacman -S --noconfirm git nodejs npm mongodb redis | ||||
|  | ||||
| COPY misskey.sh /root/misskey.sh | ||||
| RUN chmod u+x /root/misskey.sh | ||||
|   | ||||
| @@ -22,8 +22,4 @@ The list of people who have sent donation for Misskey. | ||||
| 
 | ||||
| --- | ||||
| 
 | ||||
| If your name is missing,  please contact us! | ||||
| 
 | ||||
| If you want to donate to Misskey, please get in touch with [@syuilo][syuilo-link]. | ||||
| 
 | ||||
| [syuilo-link]: https://syuilo.com | ||||
| If your name is missing, please contact us! | ||||
							
								
								
									
										6
									
								
								docs/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,6 @@ | ||||
| # Docs | ||||
| These docs are for contributors of Misskey or admins of instance of Misskey. | ||||
| Docs for users are located in `src/docs`. | ||||
|  | ||||
| これらのドキュメントはMisskeyの開発者またはMisskeyインスタンス運営者向けです。 | ||||
| 利用者向けのドキュメントは`src/docs`にあります。 | ||||
| @@ -1,26 +0,0 @@ | ||||
| # Misskeyにカンパする方法 | ||||
| Misskeyのサポートにご興味をお持ちいただきありがとうございます! | ||||
| Misskeyにカンパをしていただくと、貴方のお名前と好きなURLなどをMisskeyのリポジトリに刻む権利がもらえます。 | ||||
|  | ||||
| Misskeyにカンパして開発・運営をサポートするには、次のいくつかの方法があります: | ||||
|  | ||||
| ## ConoHaカードを購入する | ||||
| (本家)Misskeyは、ConoHaというVPSサービスを利用しています。ConoHaカードを購入して、 | ||||
| カードに記載されているクーポンコードを syuilotan@yahoo.co.jp までお送りいただければ、 | ||||
| そのクーポンをチャージしてサーバーの運営費に充てることができます。 | ||||
|  | ||||
| ConoHaカードについてはこちらをご覧ください: https://www.conoha.jp/conohacard/ | ||||
|  | ||||
| Amazonでも買えます: https://www.amazon.co.jp/dp/B01N9E3416 | ||||
|  | ||||
| ## Amazonギフトカード | ||||
| これは間接的な方法です。 | ||||
|  | ||||
| ## 銀行振込 | ||||
| syuilotan@yahoo.co.jp までお問い合わせください。 | ||||
|  | ||||
| ## 手渡し | ||||
| オフ会を行ったときなどに行使できる方法です。 | ||||
|  | ||||
| ## その他 | ||||
| なにかいいアイデアがあればお教えください。 | ||||
							
								
								
									
										46
									
								
								docs/manage.en.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,46 @@ | ||||
| # Management guide | ||||
|  | ||||
| ## Check the status of the job queue | ||||
| coming soon | ||||
|  | ||||
| ## Mark as 'admin' user | ||||
| ``` shell | ||||
| node cli/mark-admin (User-ID or Username) | ||||
| ``` | ||||
|  | ||||
| ## Mark as 'verified' user | ||||
| ``` shell | ||||
| node cli/mark-verified (User-ID or Username) | ||||
| ``` | ||||
|  | ||||
| ## Suspend users | ||||
| ``` shell | ||||
| node cli/suspend (User-ID or Username) | ||||
| ``` | ||||
| e.g. | ||||
| ``` shell | ||||
| # Use id | ||||
| node cli/suspend 57d01a501fdf2d07be417afe | ||||
|  | ||||
| # Use username | ||||
| node cli/suspend @syuilo | ||||
|  | ||||
| # Use username (remote) | ||||
| node cli/suspend @syuilo@misskey.xyz | ||||
| ``` | ||||
|  | ||||
| ## Reset password | ||||
| ``` shell | ||||
| node cli/reset-password (User-ID or Username) | ||||
| ``` | ||||
|  | ||||
| ## Clean up cached remote files | ||||
| ``` shell | ||||
| node cli/clean-cached-remote-files | ||||
| ``` | ||||
|  | ||||
| ## Clean up unused drive files | ||||
| ``` shell | ||||
| node cli/clean-unused-drive-files | ||||
| ``` | ||||
| > We recommend that you announce a user that unused drive files will be deleted before performing this operation, as it may delete the user's important files. | ||||
| @@ -1,13 +1,46 @@ | ||||
| # 運営ガイド | ||||
|  | ||||
| ## ジョブキューの状態を調べる | ||||
| Misskeyのディレクトリで: | ||||
| coming soon | ||||
|  | ||||
| ## 管理者ユーザーを設定する | ||||
| ``` shell | ||||
| node_modules/kue/bin/kue-dashboard -p 3050 | ||||
| node cli/mark-admin (ユーザーID または ユーザー名) | ||||
| ``` | ||||
|  | ||||
| ## 'verified'ユーザーを設定する | ||||
| ``` shell | ||||
| node cli/mark-verified (ユーザーID または ユーザー名) | ||||
| ``` | ||||
| ポート3050にアクセスするとUIが表示されます | ||||
|  | ||||
| ## ユーザーを凍結する | ||||
| ``` shell | ||||
| node cli/suspend (ユーザーID) | ||||
| node cli/suspend (ユーザーID または ユーザー名) | ||||
| ``` | ||||
| 例: | ||||
| ``` shell | ||||
| # ユーザーID | ||||
| node cli/suspend 57d01a501fdf2d07be417afe | ||||
|  | ||||
| # ユーザー名 | ||||
| node cli/suspend @syuilo | ||||
|  | ||||
| # ユーザー名 (リモート) | ||||
| node cli/suspend @syuilo@misskey.xyz | ||||
| ``` | ||||
|  | ||||
| ## ユーザーのパスワードをリセットする | ||||
| ``` shell | ||||
| node cli/reset-password (ユーザーID または ユーザー名) | ||||
| ``` | ||||
|  | ||||
| ## キャッシュされたリモートファイルをクリーンアップする | ||||
| ``` shell | ||||
| node cli/clean-cached-remote-files | ||||
| ``` | ||||
|  | ||||
| ## 使われていないドライブのファイルをクリーンアップする | ||||
| ``` shell | ||||
| node cli/clean-unused-drive-files | ||||
| ``` | ||||
| > ユーザーの大事なファイルを削除する可能性があるので、この操作を実行する前にユーザーに告知することをお勧めします。 | ||||
|   | ||||
							
								
								
									
										110
									
								
								docs/setup.en.md
									
									
									
									
									
								
							
							
						
						| @@ -8,18 +8,13 @@ This guide describes how to install and setup Misskey. | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| *1.* reCAPTCHA tokens | ||||
| *1.* Create Misskey user | ||||
| ---------------------------------------------------------------- | ||||
| Misskey requires reCAPTCHA tokens. | ||||
| Please visit https://www.google.com/recaptcha/intro/ and generate keys. | ||||
| Running misskey on root is not a good idea so we create a user for that. | ||||
| In debian for exemple : | ||||
|  | ||||
| *(optional)* Generating VAPID keys | ||||
| ---------------------------------------------------------------- | ||||
| If you want to enable ServiceWroker, you need to generate VAPID keys: | ||||
|  | ||||
| ``` shell | ||||
| npm install web-push -g | ||||
| web-push generate-vapid-keys | ||||
| ``` | ||||
| adduser --disabled-password --disabled-login misskey | ||||
| ``` | ||||
|  | ||||
| *2.* Install dependencies | ||||
| @@ -27,25 +22,52 @@ web-push generate-vapid-keys | ||||
| Please install and setup these softwares: | ||||
|  | ||||
| #### Dependencies :package: | ||||
| * *Node.js* and *npm* | ||||
| * **[MongoDB](https://www.mongodb.com/)** | ||||
| * **[Node.js](https://nodejs.org/en/)** | ||||
| * **[MongoDB](https://www.mongodb.com/)** >= 3.6 | ||||
| * **[Redis](https://redis.io/)** | ||||
| * **[ImageMagick](http://www.imagemagick.org/script/index.php)** >= 7.0 | ||||
|  | ||||
| ##### Optional | ||||
| * [Elasticsearch](https://www.elastic.co/) - used to provide searching feature instead of MongoDB | ||||
|  | ||||
| *3.* Install Misskey | ||||
| ---------------------------------------------------------------- | ||||
| 1. `git clone -b master git://github.com/syuilo/misskey.git` | ||||
| 2. `cd misskey` | ||||
| 3. `npm install` | ||||
|  | ||||
| *4.* Prepare configuration | ||||
| *3.* Setup MongoDB | ||||
| ---------------------------------------------------------------- | ||||
| You need to generate config file via `npm run config` command. | ||||
| In root : | ||||
| 1. `mongo` Go to the mongo shell | ||||
| 2. `use misskey` Use the misskey database | ||||
| 3. `db.users.save( {dummy:"dummy"} )` Write dummy data to initialize the db. | ||||
| 4. `db.createUser( { user: "misskey", pwd: "<password>", roles: [ { role: "readWrite", db: "misskey" } ] } )` Create the misskey user. | ||||
| 5. `exit` You're done ! | ||||
|  | ||||
| *5.* Build Misskey | ||||
| *4.* Install Misskey | ||||
| ---------------------------------------------------------------- | ||||
| 1. `su - misskey` Connect to misskey user. | ||||
| 2. `git clone -b master git://github.com/syuilo/misskey.git` Clone the misskey repo from master branch. | ||||
| 3. `cd misskey` Navigate to misskey directory | ||||
| 4. `git checkout $(git tag -l | grep -v 'rc[0-9]*$' | sort -V | tail -n 1)` Checkout to the [latest release](https://github.com/syuilo/misskey/releases/latest) | ||||
| 5. `npm install` Install misskey dependencies. | ||||
|  | ||||
| *(optional)* reCAPTCHA tokens | ||||
| ---------------------------------------------------------------- | ||||
| If you want to enable reCAPTCHA, you need to generate reCAPTCHA tokens: | ||||
| Please visit https://www.google.com/recaptcha/intro/ and generate keys. | ||||
|  | ||||
| *(optional)* Generating VAPID keys | ||||
| ---------------------------------------------------------------- | ||||
| If you want to enable ServiceWroker, you need to generate VAPID keys: | ||||
| Unless you have set your global node_modules location elsewhere, you need to run this in root. | ||||
|  | ||||
| ``` shell | ||||
| npm install web-push -g | ||||
| web-push generate-vapid-keys | ||||
| ``` | ||||
|  | ||||
| *5.* Make configuration file | ||||
| ---------------------------------------------------------------- | ||||
| 1. `cp .config/example.yml .config/default.yml` Copy the `.config/example.yml` and rename it to `default.yml`. | ||||
| 2. Edit `default.yml` | ||||
|  | ||||
| *6.* Build Misskey | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| Build misskey with the following: | ||||
| @@ -61,14 +83,48 @@ If you're still encountering errors about some modules, use node-gyp: | ||||
| 3. `node-gyp build` | ||||
| 4. `npm run build` | ||||
|  | ||||
| *6.* That is it. | ||||
| *7.* That is it. | ||||
| ---------------------------------------------------------------- | ||||
| Well done! Now, you have an environment that run to Misskey. | ||||
|  | ||||
| ### Launch | ||||
| Just `sudo npm start`. GLHF! | ||||
| ### Launch normally | ||||
| Just `npm start`. GLHF! | ||||
|  | ||||
| ### Launch with systemd | ||||
|  | ||||
| 1. Create a systemd service here: `/etc/systemd/system/misskey.service` | ||||
| 2. Edit it, and paste this and save: | ||||
|  | ||||
| ``` | ||||
| [Unit] | ||||
| Description=Misskey daemon | ||||
|  | ||||
| [Service] | ||||
| Type=simple | ||||
| User=misskey | ||||
| ExecStart=/usr/bin/npm start | ||||
| WorkingDirectory=/home/misskey/misskey | ||||
| TimeoutSec=60 | ||||
| StandardOutput=syslog | ||||
| StandardError=syslog | ||||
| SyslogIdentifier=misskey | ||||
| Restart=always | ||||
|  | ||||
| [Install] | ||||
| WantedBy=multi-user.target | ||||
| ``` | ||||
|  | ||||
| 3. `systemctl daemon-reload ; systemctl enable misskey` Reload systemd and enable the misskey service. | ||||
| 4. `systemctl start misskey` Start the misskey service. | ||||
|  | ||||
| You can check if the service is running with `systemctl status misskey`. | ||||
|  | ||||
| ### Way to Update to latest version of your Misskey | ||||
| 1. `git reset --hard && git pull origin master` | ||||
| 2. `npm install` | ||||
| 3. `npm run build` | ||||
| 1. `git fetch` | ||||
| 2. `git checkout $(git tag -l | grep -v 'rc[0-9]*$' | sort -V | tail -n 1)` | ||||
| 3. `npm install` | ||||
| 4. `npm run build` | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| If you have any questions or troubles, feel free to contact us! | ||||
|   | ||||
							
								
								
									
										127
									
								
								docs/setup.ja.md
									
									
									
									
									
								
							
							
						
						| @@ -8,10 +8,48 @@ Misskeyサーバーの構築にご関心をお寄せいただきありがとう | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| *1.* reCAPTCHAトークンの用意 | ||||
| *1.* Misskeyユーザーの作成 | ||||
| ---------------------------------------------------------------- | ||||
| MisskeyはreCAPTCHAトークンを必要とします。 | ||||
| https://www.google.com/recaptcha/intro/ にアクセスしてトークンを生成してください。 | ||||
| Misskeyのrootで実行しない方がよいため、代わりにユーザーを作成します。 | ||||
| Debianの例: | ||||
|  | ||||
| ``` | ||||
| adduser --disabled-password --disabled-login misskey | ||||
| ``` | ||||
|  | ||||
| *2.* 依存関係をインストールする | ||||
| ---------------------------------------------------------------- | ||||
| これらのソフトウェアをインストール・設定してください: | ||||
|  | ||||
| #### 依存関係 :package: | ||||
| * **[Node.js](https://nodejs.org/en/)** | ||||
| * **[MongoDB](https://www.mongodb.com/)** (3.6以上) | ||||
| * **[Redis](https://redis.io/)** | ||||
|  | ||||
| ##### オプション | ||||
| * [Elasticsearch](https://www.elastic.co/) - 検索機能を向上させるために用います。 | ||||
|  | ||||
| *3.* MongoDBの設定 | ||||
| ---------------------------------------------------------------- | ||||
| ルートで: | ||||
| 1. `mongo` mongoシェルを起動 | ||||
| 2. `use misskey` misskeyデータベースを使用 | ||||
| 3. `db.users.save( {dummy:"dummy"} )` ダミーデータを書き込みDBを初期化 | ||||
| 4. `db.createUser( { user: "misskey", pwd: "<password>", roles: [ { role: "readWrite", db: "misskey" } ] } )` misskeyユーザーを作成 | ||||
| 5. `exit` mongoシェルを終了 | ||||
|  | ||||
| *4.* Misskeyのインストール | ||||
| ---------------------------------------------------------------- | ||||
| 1. `su - misskey` misskeyユーザーを使用 | ||||
| 2. `git clone -b master git://github.com/syuilo/misskey.git` masterブランチからMisskeyレポジトリをクローン | ||||
| 3. `cd misskey` misskeyディレクトリに移動 | ||||
| 4. `git checkout $(git tag -l | grep -v 'rc[0-9]*$' | sort -V | tail -n 1)` [最新のリリース](https://github.com/syuilo/misskey/releases/latest)を確認 | ||||
| 5. `npm install` Misskeyの依存パッケージをインストール | ||||
|  | ||||
| *(オプション)* reCAPTCHAトークン | ||||
| ---------------------------------------------------------------- | ||||
| reCAPTCHAを有効にする場合、reCAPTCHAトークンを取得する必要があります。 | ||||
| https://www.google.com/recaptcha/intro/ にアクセスしてトークンを取得してください。 | ||||
|  | ||||
| *(オプション)* VAPIDキーペアの生成 | ||||
| ---------------------------------------------------------------- | ||||
| @@ -22,56 +60,67 @@ npm install web-push -g | ||||
| web-push generate-vapid-keys | ||||
| ``` | ||||
|  | ||||
| *2.* 依存関係をインストールする | ||||
| *5.* 設定ファイルを作成する | ||||
| ---------------------------------------------------------------- | ||||
| これらのソフトウェアをインストール・設定してください: | ||||
| 1. `cp .config/example.yml .config/default.yml` `.config/example.yml`をコピーし名前を`default.yml`にする。 | ||||
| 2. `default.yml` を編集する。 | ||||
|  | ||||
| #### 依存関係 :package: | ||||
| * *Node.js* と *npm* | ||||
| * **[MongoDB](https://www.mongodb.com/)** | ||||
| * **[Redis](https://redis.io/)** | ||||
| * **[ImageMagick](http://www.imagemagick.org/script/index.php)** | ||||
|  | ||||
| ##### オプション | ||||
| * [Elasticsearch](https://www.elastic.co/) - 検索機能を向上させるために用います。 | ||||
|  | ||||
| *3.* Misskeyのインストール | ||||
| *6.* Misskeyのビルド | ||||
| ---------------------------------------------------------------- | ||||
| 1. `git clone -b master git://github.com/syuilo/misskey.git` | ||||
| 2. `cd misskey` | ||||
| 3. `npm install` | ||||
|  | ||||
| *4.* 設定ファイルを用意する | ||||
| ---------------------------------------------------------------- | ||||
| `npm run config`コマンドを利用して、ガイドに従って情報を入力してください。 | ||||
| 次のコマンドでMisskeyをビルドしてください: | ||||
|  | ||||
| *5.* Misskeyのビルド | ||||
| ---------------------------------------------------------------- | ||||
| `npm run build` | ||||
|  | ||||
| Debianをお使いであれば、`build-essential`パッケージをインストールする必要があります。 | ||||
|  | ||||
| 何らかのモジュールでエラーが発生する場合はnode-gypを使ってください: | ||||
| 1. `npm install -g node-gyp` | ||||
| 2. `node-gyp configure` | ||||
| 3. `node-gyp build` | ||||
| 4. `npm run build` | ||||
|  | ||||
| *6.* 以上です! | ||||
| *7.* 以上です! | ||||
| ---------------------------------------------------------------- | ||||
| お疲れ様でした。これでMisskeyを動かす準備は整いました。 | ||||
|  | ||||
| ### 起動 | ||||
| `sudo npm start`するだけです。GLHF! | ||||
| ### 通常起動 | ||||
| `npm start`するだけです。GLHF! | ||||
|  | ||||
| ### systemdを用いた起動 | ||||
| 1. systemdサービスのファイルを作成: `/etc/systemd/system/misskey.service` | ||||
| 2. エディタで開き、以下のコードを貼り付けて保存: | ||||
|  | ||||
| ``` | ||||
| [Unit] | ||||
| Description=Misskey daemon | ||||
|  | ||||
| [Service] | ||||
| Type=simple | ||||
| User=misskey | ||||
| ExecStart=/usr/bin/npm start | ||||
| WorkingDirectory=/home/misskey/misskey | ||||
| TimeoutSec=60 | ||||
| StandardOutput=syslog | ||||
| StandardError=syslog | ||||
| SyslogIdentifier=misskey | ||||
| Restart=always | ||||
|  | ||||
| [Install] | ||||
| WantedBy=multi-user.target | ||||
| ``` | ||||
|  | ||||
| 3. `systemctl daemon-reload ; systemctl enable misskey` systemdを再読み込みしmisskeyサービスを有効化 | ||||
| 4. `systemctl start misskey` misskeyサービスの起動 | ||||
|  | ||||
| `systemctl status misskey`と入力すると、サービスの状態を調べることができます。 | ||||
|  | ||||
| ### Misskeyを最新バージョンにアップデートする方法: | ||||
| 1. `git reset --hard && git pull origin master` | ||||
| 2. `npm install` | ||||
| 3. `npm run build` | ||||
| 1. `git fetch` | ||||
| 2. `git checkout $(git tag -l | grep -v 'rc[0-9]*$' | sort -V | tail -n 1)` | ||||
| 3. `npm install` | ||||
| 4. `npm run build` | ||||
|  | ||||
| ## メモリが足りなくてビルドできない場合 | ||||
| Misskeyの(クライアントの)ビルドには、目安として8GBくらいのメモリを必要とします。 | ||||
| VPSなどでビルドする時は、もしかしたらメモリが足りなくなる可能性があります。 | ||||
| そうなった場合、もしVPSではなくあなたのPCが十分なメモリを搭載しているなら、あなたのPC上でビルドし、生成されたファイルをVPSにFTPでアップロードする方法を採ることができます。 | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| 1. あなたのPC上にMisskeyをインストールする | ||||
| 2. 設定ファイルを用意する。設定ファイルは、サーバーに合わせた設定にします。 | ||||
| 3. npm run webpack | ||||
| 4. built/client をサーバーにアップロードする | ||||
| 5. サーバー上で、npm run gulp | ||||
| 6. 完了 | ||||
| なにかお困りのことがありましたらお気軽にご連絡ください。 | ||||
|   | ||||
| @@ -4,19 +4,19 @@ Misskey's Translation | ||||
| If you find an untranslated part on Misskey: | ||||
| -------------------------------------------- | ||||
|  | ||||
| 1. Look for untranslated parts in the miskey's source code. | ||||
| 1. Look for untranslated parts in the misskey's source code. | ||||
| 	- For instance, if you find an untranslated part in: `src/client/app/mobile/views/pages/home.vue`. | ||||
|  | ||||
| 2. Replace the untranslated portion with a character string of the form `%i18n:@foo%`. | ||||
| 	- In fact, `foo` should be a word that is appropriate for the situation and is easy to understand in English. | ||||
| 	- For example, if the untranslated portion is the following "タイムライン" you must write: `%i18n:@timeline%`. | ||||
|  | ||||
| 3. Open each language file in /locales, check whether the <strong>file name (path)</strong> found in step 1 exists, if not, create it. | ||||
| 3. Open the `locales/ja.yml`, check whether the <strong>file name (path)</strong> found in step 1 exists, if not, create it. | ||||
| 	- Do not put the beginning of the path `src/client/app/` in the locale file. | ||||
| 	- For example, in this case we want to modify untranslated parts of `src/client/app/mobile/views/pages/home.vue`, so the key is `mobile/views/pages/home.vue`. | ||||
|  | ||||
| 4. Add the translated text property using the `foo` keyword below the path that you found or created in step 2. Make sure to type your text in quotation marks. Text should always be inside of quotes. | ||||
| 	-   For example, in this case we add timeline: `timeline: "Timeline"` to `locales/en.yml`, and `timeline: "タイムライン"` to `locales/ja.yml`. | ||||
| 4. Add the text property using the `foo` keyword below the path that you found or created in step 2. Make sure to type your text in quotation marks. Text should always be inside of quotes. | ||||
| 	-   For example, in this case we add timeline: `timeline: "タイムライン"` to `locales/ja.yml`. | ||||
|  | ||||
| 5. And done! | ||||
|  | ||||
|   | ||||
| @@ -11,12 +11,12 @@ Misskey内の未翻訳箇所を見つけたら | ||||
| 	- `foo`は実際にはその場に適したわかりやすい(英語の)名前にしてください。 | ||||
| 	- 例えば未翻訳箇所が「タイムライン」というテキストだった場合、`%i18n:@timeline%`のようにします。 | ||||
|  | ||||
| 3. /locales 内にあるそれぞれの言語ファイルを開き、1.で見つけた<strong>ファイル名(パス)</strong>のキーが存在するか確認し、無ければ作成してください。 | ||||
| 3. `locales/ja.yml`を開き、1.で見つけた<strong>ファイル名(パス)</strong>のキーが存在するか確認し、無ければ作成してください。 | ||||
| 	- パスの`src/client/app/`は省略してください。 | ||||
| 	- 例えば、今回の例では`src/client/app/mobile/views/pages/home.vue`の未翻訳箇所を修正したいので、キーは`mobile/views/pages/home.vue`になります。 | ||||
|  | ||||
| 4. そのキーの直下に2.で置換した`foo`の部分をキーとし、翻訳後のテキストを値とするプロパティを追加します。 | ||||
| 	- 例えば、今回の例で言うと`locales/ja.yml`に`timeline: "タイムライン"`、`locales/en.yml`に`timeline: "Timeline"`を追加します。 | ||||
| 4. そのキーの直下に2.で置換した`foo`の部分をキーとし、テキストを値とするプロパティを追加します。 | ||||
| 	- 例えば、今回の例で言うと`locales/ja.yml`に`timeline: "タイムライン"`を追加します。 | ||||
|  | ||||
| 5. 完了です! | ||||
|  | ||||
|   | ||||
| @@ -1,6 +0,0 @@ | ||||
| How to create indexes | ||||
| ===================== | ||||
|  | ||||
| ``` shell | ||||
| curl -XPOST localhost:9200/misskey -d @path/to/mappings.json | ||||
| ``` | ||||
| @@ -1,65 +0,0 @@ | ||||
| { | ||||
| 	"settings": { | ||||
| 		"analysis": { | ||||
| 			"analyzer": { | ||||
| 				"bigram": { | ||||
| 					"tokenizer": "bigram_tokenizer" | ||||
| 				} | ||||
| 			}, | ||||
| 			"tokenizer": { | ||||
| 				"bigram_tokenizer": { | ||||
| 					"type": "nGram", | ||||
| 					"min_gram": 2, | ||||
| 					"max_gram": 2, | ||||
| 					"token_chars": [ | ||||
| 						"letter", | ||||
| 						"digit" | ||||
| 					] | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	}, | ||||
| 	"mappings": { | ||||
| 		"user": { | ||||
| 			"properties": { | ||||
| 				"username": { | ||||
| 					"type": "string", | ||||
| 					"index": "analyzed", | ||||
| 					"analyzer": "bigram" | ||||
| 				}, | ||||
| 				"name": { | ||||
| 					"type": "string", | ||||
| 					"index": "analyzed", | ||||
| 					"analyzer": "bigram" | ||||
| 				}, | ||||
| 				"bio": { | ||||
| 					"type": "string", | ||||
| 					"index": "analyzed", | ||||
| 					"analyzer": "kuromoji" | ||||
| 				} | ||||
| 			} | ||||
| 		}, | ||||
| 		"post": { | ||||
| 			"properties": { | ||||
| 				"text": { | ||||
| 					"type": "string", | ||||
| 					"index": "analyzed", | ||||
| 					"analyzer": "kuromoji" | ||||
| 				} | ||||
| 			} | ||||
| 		}, | ||||
| 		"drive_file": { | ||||
| 			"properties": { | ||||
| 				"name": { | ||||
| 					"type": "string", | ||||
| 					"index": "analyzed", | ||||
| 					"analyzer": "kuromoji" | ||||
| 				}, | ||||
| 				"user": { | ||||
| 					"type": "string", | ||||
| 					"index": "not_analyzed" | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										46
									
								
								gulpfile.ts
									
									
									
									
									
								
							
							
						
						| @@ -8,21 +8,21 @@ import * as gutil from 'gulp-util'; | ||||
| import * as ts from 'gulp-typescript'; | ||||
| const sourcemaps = require('gulp-sourcemaps'); | ||||
| import tslint from 'gulp-tslint'; | ||||
| import cssnano = require('gulp-cssnano'); | ||||
| const cssnano = require('gulp-cssnano'); | ||||
| const stylus = require('gulp-stylus'); | ||||
| import * as uglifyComposer from 'gulp-uglify/composer'; | ||||
| import pug = require('gulp-pug'); | ||||
| import * as rimraf from 'rimraf'; | ||||
| import chalk from 'chalk'; | ||||
| import imagemin = require('gulp-imagemin'); | ||||
| const imagemin = require('gulp-imagemin'); | ||||
| import * as rename from 'gulp-rename'; | ||||
| import * as mocha from 'gulp-mocha'; | ||||
| import * as replace from 'gulp-replace'; | ||||
| import * as htmlmin from 'gulp-htmlmin'; | ||||
| const uglifyes = require('uglify-es'); | ||||
|  | ||||
| import locales from './locales'; | ||||
| import { fa } from './src/build/fa'; | ||||
| const client = require('./built/client/meta.json'); | ||||
| const locales = require('./locales'); | ||||
| import { fa } from './src/misc/fa'; | ||||
| import config from './src/config'; | ||||
|  | ||||
| const uglify = uglifyComposer(uglifyes, console); | ||||
| @@ -38,8 +38,6 @@ if (isDebug) { | ||||
|  | ||||
| const constants = require('./src/const.json'); | ||||
|  | ||||
| require('./src/client/docs/gulpfile.ts'); | ||||
|  | ||||
| gulp.task('build', [ | ||||
| 	'build:ts', | ||||
| 	'build:copy', | ||||
| @@ -47,8 +45,6 @@ gulp.task('build', [ | ||||
| 	'doc' | ||||
| ]); | ||||
|  | ||||
| gulp.task('rebuild', ['clean', 'build']); | ||||
|  | ||||
| gulp.task('build:ts', () => { | ||||
| 	const tsProject = ts.createProject('./tsconfig.json'); | ||||
|  | ||||
| @@ -85,19 +81,19 @@ gulp.task('lint', () => | ||||
| ); | ||||
|  | ||||
| gulp.task('format', () => | ||||
| gulp.src('./src/**/*.ts') | ||||
| 	.pipe(tslint({ | ||||
| 		formatter: 'verbose', | ||||
| 		fix: true | ||||
| 	})) | ||||
| 	.pipe(tslint.report()) | ||||
| 	gulp.src('./src/**/*.ts') | ||||
| 		.pipe(tslint({ | ||||
| 			formatter: 'verbose', | ||||
| 			fix: true | ||||
| 		})) | ||||
| 		.pipe(tslint.report()) | ||||
| ); | ||||
|  | ||||
| gulp.task('mocha', () => | ||||
| 	gulp.src([]) | ||||
| 	gulp.src('./test/**/*.ts') | ||||
| 		.pipe(mocha({ | ||||
| 			exit: true, | ||||
| 			compilers: 'ts:ts-node/register' | ||||
| 			require: 'ts-node/register' | ||||
| 		} as any)) | ||||
| ); | ||||
|  | ||||
| @@ -118,8 +114,9 @@ gulp.task('build:client', [ | ||||
| 	'copy:client' | ||||
| ]); | ||||
|  | ||||
| gulp.task('build:client:script', () => | ||||
| 	gulp.src(['./src/client/app/boot.js', './src/client/app/safe.js']) | ||||
| gulp.task('build:client:script', () => { | ||||
| 	const client = require('./built/client/meta.json'); | ||||
| 	return gulp.src(['./src/client/app/boot.js', './src/client/app/safe.js']) | ||||
| 		.pipe(replace('VERSION', JSON.stringify(client.version))) | ||||
| 		.pipe(replace('API', JSON.stringify(config.api_url))) | ||||
| 		.pipe(replace('ENV', JSON.stringify(env))) | ||||
| @@ -127,8 +124,8 @@ gulp.task('build:client:script', () => | ||||
| 		.pipe(isProduction ? uglify({ | ||||
| 			toplevel: true | ||||
| 		} as any) : gutil.noop()) | ||||
| 		.pipe(gulp.dest('./built/client/assets/')) as any | ||||
| ); | ||||
| 		.pipe(gulp.dest('./built/client/assets/')); | ||||
| }); | ||||
|  | ||||
| gulp.task('build:client:styles', () => | ||||
| 	gulp.src('./src/client/app/init.css') | ||||
| @@ -201,3 +198,10 @@ gulp.task('build:client:pug', [ | ||||
| 			})) | ||||
| 			.pipe(gulp.dest('./built/client/app/')) | ||||
| ); | ||||
|  | ||||
| gulp.task('doc', () => | ||||
| 	gulp.src('./src/docs/**/*.styl') | ||||
| 		.pipe(stylus()) | ||||
| 		.pipe((cssnano as any)()) | ||||
| 		.pipe(gulp.dest('./built/docs/assets/')) | ||||
| ); | ||||
|   | ||||
							
								
								
									
										1091
									
								
								locales/ca.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										197
									
								
								locales/de.yml
									
									
									
									
									
								
							
							
						
						| @@ -3,9 +3,17 @@ meta: | ||||
|   lang: "Deutsch" | ||||
|   divider: "" | ||||
| common: | ||||
|   misskey: "A planet of fediverse" | ||||
|   misskey: "A ⭐ of fediverse" | ||||
|   about-title: "A ⭐ of fediverse." | ||||
|   about: "Misskeyを見つけていただき、ありがとうございます。Misskeyは、地球で生まれた<b>分散マイクロブログSNS</b>です。Fediverse(様々なSNSで構成される宇宙)の中に存在するため、他のSNSと相互に繋がっています。暫し都会の喧騒から離れて、新しいインターネットにダイブしてみませんか。" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
|     paragraph1: "ホームのカスタマイズでは、ウィジェットを追加/削除したり、ドラッグ&ドロップして並べ替えたりすることができます。" | ||||
|     paragraph2: "一部のウィジェットは、<strong><strong>右</strong>クリック</strong>することで表示を変更することができます。" | ||||
|     paragraph3: "ウィジェットを削除するには、ヘッダーの<strong>「ゴミ箱」</strong>と書かれたエリアにウィジェットをドラッグ&ドロップします。" | ||||
|     paragraph4: "カスタマイズを終了するには、右上の「完了」をクリックします。" | ||||
|     gotit: "Got it!" | ||||
|   name: "Misskey" | ||||
|   time: | ||||
|     unknown: "Unbekannt" | ||||
|     future: "Zukunft" | ||||
| @@ -17,6 +25,7 @@ common: | ||||
|     weeks_ago: "vor {0} Woche{0:n}" | ||||
|     months_ago: "vor {0} Monat{0:en}" | ||||
|     years_ago: "vor {} Jahr{0:en}" | ||||
|   trash: "ゴミ箱" | ||||
|   weekday-short: | ||||
|     sunday: "So" | ||||
|     monday: "Mo" | ||||
| @@ -25,6 +34,14 @@ common: | ||||
|     thursday: "Do" | ||||
|     friday: "Fr" | ||||
|     saturday: "Sa" | ||||
|   weekday: | ||||
|     sunday: "日曜日" | ||||
|     monday: "月曜日" | ||||
|     tuesday: "火曜日" | ||||
|     wednesday: "水曜日" | ||||
|     thursday: "木曜日" | ||||
|     friday: "金曜日" | ||||
|     saturday: "土曜日" | ||||
|   reactions: | ||||
|     like: "Gefällt mir" | ||||
|     love: "Lieben" | ||||
| @@ -42,11 +59,27 @@ common: | ||||
|     d: "Willst du etwas sagen?" | ||||
|     e: "Schreib hier etwas!" | ||||
|     f: "Warte darauf, das du schreibst." | ||||
|   search: "検索" | ||||
|   delete: "Löschen" | ||||
|   loading: "Laden" | ||||
|   ok: "OK" | ||||
|   update-available-title: "更新があります" | ||||
|   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." | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   verified-user: "認証済みのユーザー" | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
|     opponent-turn: "相手のターンです" | ||||
|     turn-of: "{}のターンです" | ||||
|     past-turn-of: "{}のターン" | ||||
|     won: "{}の勝ち" | ||||
|     black: "黒" | ||||
|     white: "白" | ||||
|     total: "合計" | ||||
|     this-turn: "{}ターン目" | ||||
|   widgets: | ||||
|     analog-clock: "Analoge Uhr" | ||||
|     profile: "Profil" | ||||
| @@ -75,6 +108,7 @@ common: | ||||
|     widgets: "Widget hinzufügen:" | ||||
|     home: "Startseite" | ||||
|     local: "Lokal" | ||||
|     hybrid: "ソーシャル" | ||||
|     global: "Global" | ||||
|     notifications: "Mitteilungen" | ||||
|     list: "Listen" | ||||
| @@ -87,6 +121,42 @@ common: | ||||
|     rename: "Umbenennen" | ||||
|     stack-left: "Nach links schichten" | ||||
|     pop-right: "右に出す" | ||||
| common/views/components/games/reversi/reversi.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "他のMisskeyユーザーとリバーシで対戦しよう" | ||||
|   invite: "招待" | ||||
|   rule: "遊び方" | ||||
|   rule-desc: "リバーシは、相手と交互に石をボードに置いて、相手の石を挟んで自分の色に変えてゆき、最終的に残った石が多い方が勝ちというボードゲームです。" | ||||
|   mode-invite: "招待" | ||||
|   mode-invite-desc: "指定したユーザーと対戦するモードです。" | ||||
|   invitations: "対局の招待があります!" | ||||
|   my-games: "自分の対局" | ||||
|   all-games: "みんなの対局" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
|   game-state: | ||||
|     ended: "終了" | ||||
|     playing: "進行中" | ||||
|   matching: | ||||
|     waiting-for: "{}を待っています" | ||||
|     cacnel: "キャンセル" | ||||
| common/views/components/games/reversi/reversi.room.vue: | ||||
|   settings-of-the-game: "ゲームの設定" | ||||
|   choose-map: "マップを選択" | ||||
|   random: "ランダム" | ||||
|   black-or-white: "先手/後手" | ||||
|   black-is: "{}が黒" | ||||
|   rules: "ルール" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
|   settings-of-the-bot: "Botの設定" | ||||
|   this-gane-is-started-soon: "ゲームは数秒後に開始されます" | ||||
|   waiting-for-other: "相手の準備が完了するのを待っています" | ||||
|   waiting-for-me: "あなたの準備が完了するのを待っています" | ||||
|   waiting-for-both: "準備中" | ||||
|   cancel: "キャンセル" | ||||
|   ready: "準備完了" | ||||
|   cancel-ready: "準備続行" | ||||
| common/views/components/connect-failed.vue: | ||||
|   title: "Verbindung zum Server ist fehlgeschlagen" | ||||
|   description: "Es gibt entweder ein Problem mit deiner Internetverbindung, der Server ist nicht erreichbar oder wird gerade gewartet. Bitte versuche es später noch einmal." | ||||
| @@ -216,6 +286,13 @@ common/views/widgets/broadcast.vue: | ||||
|   no-broadcasts: "Keine Broadcasts" | ||||
|   have-a-nice-day: "Schönen Tag!" | ||||
|   next: "Nächster" | ||||
| common/views/widgets/calendar.vue: | ||||
|   year: "{}年" | ||||
|   month: "{}月" | ||||
|   day: "{}日" | ||||
|   today: "今日:" | ||||
|   this-month: "今月:" | ||||
|   this-year: "今年:" | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "Spende" | ||||
|   text: "Um Misskey am Laufen zu halten geben wir Geld für Domain, Server usw. aus. Wir bekommen dafür kein Geld und würden uns freuen, wenn du spenden würdest. Wenn du interessiert bist, dann kontaktiere {}. Danke für deine Unterstützung!" | ||||
| @@ -228,6 +305,7 @@ common/views/widgets/posts-monitor.vue: | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "ハッシュタグ" | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "Serverinformationen" | ||||
|   toggle: "Sicht umschalten" | ||||
| @@ -235,6 +313,37 @@ common/views/widgets/memo.vue: | ||||
|   title: "Notizen" | ||||
|   memo: "Schreib hier!" | ||||
|   save: "Speichern" | ||||
| common/views/widgets/slideshow.vue: | ||||
|   folder-customize-mode: "フォルダを指定するには、カスタマイズモードを終了してください" | ||||
|   folder: "クリックしてフォルダを指定してください" | ||||
|   no-image: "このフォルダには画像がありません" | ||||
| common/views/widgets/tips.vue: | ||||
|   tips-line1: "<kbd>t</kbd>でタイムラインにフォーカスできます" | ||||
|   tips-line2: "<kbd>p</kbd>または<kbd>n</kbd>で投稿フォームを開きます" | ||||
|   tips-line3: "投稿フォームにはファイルをドラッグ&ドロップできます" | ||||
|   tips-line4: "投稿フォームにクリップボードにある画像データをペーストできます" | ||||
|   tips-line5: "ドライブにファイルをドラッグ&ドロップしてアップロードできます" | ||||
|   tips-line6: "ドライブでファイルをドラッグしてフォルダ移動できます" | ||||
|   tips-line7: "ドライブでフォルダをドラッグしてフォルダ移動できます" | ||||
|   tips-line8: "ホームは設定からカスタマイズできます" | ||||
|   tips-line9: "MisskeyはAGPLv3です" | ||||
|   tips-line10: "タイムマシンウィジェットを利用すると、簡単に過去のタイムラインに遡れます" | ||||
|   tips-line11: "投稿の ... をクリックして、投稿をユーザーページにピン留めできます" | ||||
|   tips-line13: "投稿に添付したファイルは全てドライブに保存されます" | ||||
|   tips-line14: "ホームのカスタマイズ中、ウィジェットを右クリックしてデザインを変更できます" | ||||
|   tips-line17: "「**」でテキストを囲むと**強調表示**されます" | ||||
|   tips-line19: "いくつかのウィンドウはブラウザの外に切り離すことができます" | ||||
|   tips-line20: "カレンダーウィジェットのパーセンテージは、経過の割合を示しています" | ||||
|   tips-line21: "APIを利用してbotの開発なども行えます" | ||||
|   tips-line23: "まゆかわいいよまゆ" | ||||
|   tips-line24: "Misskeyは2014年にサービスを開始しました" | ||||
|   tips-line25: "対応ブラウザではMisskeyを開いていなくても通知を受け取れます" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
|   request-pending: "フォロー許可待ち" | ||||
|   follow-request: "フォロー申請" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Schwarz ... komplett" | ||||
|   notes: "Blau ... Hinweise" | ||||
| @@ -270,6 +379,8 @@ desktop/views/components/drive.file.vue: | ||||
|   banner: "Banner" | ||||
|   contextmenu: | ||||
|     rename: "Umbenennen" | ||||
|     mark-as-sensitive: "閲覧注意に設定" | ||||
|     unmark-as-sensitive: "閲覧注意を解除" | ||||
|     copy-url: "URL kopieren" | ||||
|     download: "Download" | ||||
|     else-files: "Anderes…" | ||||
| @@ -313,6 +424,12 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "Ein Verzeichnis erstellen" | ||||
|     upload: "Eine Datei hochladen" | ||||
|     url-upload: "Von einer URL hochladen" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| desktop/views/components/follow-button.vue: | ||||
|   following: "Folge ich" | ||||
|   follow: "Folgen" | ||||
| @@ -333,7 +450,7 @@ desktop/views/components/friends-maker.vue: | ||||
|   refresh: "Mehr" | ||||
|   close: "Schließen" | ||||
| desktop/views/components/game-window.vue: | ||||
|   game: "Othello" | ||||
|   game: "リバーシ" | ||||
| desktop/views/components/home.vue: | ||||
|   done: "Verbunden" | ||||
|   add-widget: "Widget hinzufügen:" | ||||
| @@ -364,10 +481,14 @@ desktop/views/components/notes.note.vue: | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "Laden fehlgeschlagen." | ||||
|   retry: "Erneut versuchen" | ||||
|   load-more: "もっと読み込む" | ||||
| desktop/views/components/notifications.vue: | ||||
|   more: "Mehr" | ||||
|   empty: "Keine Benachrichtigungen" | ||||
| desktop/views/components/post-form.vue: | ||||
|   add-visible-user: "+ユーザーを追加" | ||||
|   attach-location-information: "位置情報を添付する" | ||||
|   hide-contents: "内容を隠す" | ||||
|   reply-placeholder: "Antworte auf diese Anmerkung..." | ||||
|   quote-placeholder: "Zitiere diese Anmerkung..." | ||||
|   submit: "Beitragsform" | ||||
| @@ -383,9 +504,15 @@ desktop/views/components/post-form.vue: | ||||
|   attach-media-from-local: "Medien von deinem PC hinzufügen" | ||||
|   attach-media-from-drive: "Medien von deinem Speicher hinzufügen" | ||||
|   attach-cancel: "Hinzufügen abbrechen" | ||||
|   insert-a-kao: "v(‘ω’)v" | ||||
|   insert-a-kao: "v('ω')v" | ||||
|   create-poll: "Eine Abstimmung erstellen" | ||||
|   text-remain: "{} Zeichen verbleibend" | ||||
|   recent-tags: "最近" | ||||
|   click-to-tagging: "クリックでタグ付け" | ||||
|   visibility: "公開範囲" | ||||
|   geolocation-alert: "お使いの端末は位置情報に対応していません" | ||||
|   error: "エラー" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
| desktop/views/components/post-form-window.vue: | ||||
|   note: "Neue Notiz" | ||||
|   reply: "Antworten" | ||||
| @@ -426,6 +553,8 @@ desktop/views/components/settings.vue: | ||||
|   api-via-stream-desc: "API-Anfrage über WebSocket statt native Aktualisierungs-API (für bessere Leistung). Diese Einstellung wird im Browser gespeichert." | ||||
|   display: "Erscheinungsbild und Anzeige" | ||||
|   customize: "Startseite anpassen" | ||||
|   choose-wallpaper: "壁紙を選択" | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "Nacht Modus" | ||||
|   circle-icons: "Kreisförmige Icons" | ||||
|   gradient-window-header: "Übergang in Fensterköpfen" | ||||
| @@ -504,6 +633,9 @@ desktop/views/components/settings.api.vue: | ||||
|   enter-password: "Bitte Passwort eingeben" | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "連携しているアプリケーションはありません" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "中" | ||||
|   in-use: "使用中" | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "ミュートしているユーザーはいません" | ||||
| desktop/views/components/settings.password.vue: | ||||
| @@ -521,8 +653,12 @@ desktop/views/components/settings.profile.vue: | ||||
|   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: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| @@ -533,15 +669,18 @@ desktop/views/components/taskmanager.vue: | ||||
| desktop/views/components/timeline.vue: | ||||
|   home: "Home" | ||||
|   local: "Lokal" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "Global" | ||||
|   list: "Listen" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "Dein Profil" | ||||
|   drive: "Speicher" | ||||
|   favorites: "Favoriten" | ||||
|   lists: "Listen" | ||||
|   follow-requests: "フォロー申請" | ||||
|   customize: "Anpassen" | ||||
|   customize: "ホームのカスタマイズ" | ||||
|   settings: "Einstellungen" | ||||
|   signout: "Ausloggen" | ||||
|   dark: "Verdunkeln" | ||||
| @@ -580,6 +719,7 @@ desktop/views/components/window.vue: | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "メディア投稿のみ" | ||||
|   is-media-view: "メディアビュー" | ||||
|   edit: "オプション" | ||||
| desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   private: "この投稿は非公開です" | ||||
| @@ -592,6 +732,7 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "やってる" | ||||
|   signup-button: "やる" | ||||
|   timeline: "タイムライン" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Misskey Drive" | ||||
| desktop/views/pages/favorites.vue: | ||||
| @@ -606,6 +747,14 @@ desktop/views/pages/selectdrive.vue: | ||||
|   ok: "OK" | ||||
|   cancel: "Abbrechen" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "検索機能を利用することができません。" | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "Misskeyで共有" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| desktop/views/pages/user-list.users.vue: | ||||
|   users: "ユーザー" | ||||
|   add-user: "ユーザーを追加" | ||||
| @@ -618,7 +767,7 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   title: "よく話すユーザー" | ||||
|   loading: "読み込み中" | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
| @@ -636,6 +785,11 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "ミュートする" | ||||
|   muted: "ミュートしています" | ||||
|   unmute: "ミュート解除" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   is-bot: "このアカウントはBotです" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "投稿" | ||||
|   with-replies: "投稿と返信" | ||||
| @@ -692,6 +846,12 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   move: "移動" | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/follow-button.vue: | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
| @@ -750,6 +910,8 @@ mobile/views/components/sub-note-content.vue: | ||||
| mobile/views/components/timeline.vue: | ||||
|   empty: "投稿がありません" | ||||
|   load-more: "もっと" | ||||
| mobile/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
| mobile/views/components/ui.nav.vue: | ||||
|   timeline: "タイムライン" | ||||
|   notifications: "通知" | ||||
| @@ -780,6 +942,8 @@ mobile/views/pages/user-lists.vue: | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   more: "もっと見る" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "📦 始めましょう" | ||||
| mobile/views/pages/followers.vue: | ||||
|   followers-of: "{}のフォロワー" | ||||
| mobile/views/pages/following.vue: | ||||
| @@ -787,7 +951,16 @@ mobile/views/pages/following.vue: | ||||
| mobile/views/pages/home.vue: | ||||
|   home: "ホーム" | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| mobile/views/pages/welcome.vue: | ||||
|   signup: "新規登録" | ||||
| mobile/views/pages/widgets.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
| mobile/views/pages/widgets/activity.vue: | ||||
|   activity: "アクティビティ" | ||||
| mobile/views/pages/messaging.vue: | ||||
|   messaging: "メッセージ" | ||||
| mobile/views/pages/messaging-room.vue: | ||||
| @@ -803,6 +976,8 @@ mobile/views/pages/note.vue: | ||||
| mobile/views/pages/notifications.vue: | ||||
|   notifications: "通知" | ||||
|   read-all: "すべての通知を既読にしますか?" | ||||
| mobile/views/pages/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "Profil" | ||||
|   name: "名前" | ||||
| @@ -900,11 +1075,17 @@ docs: | ||||
|       properties: "プロパティ" | ||||
|     endpoints: | ||||
|       params: "パラメータ" | ||||
|       no-params: "パラメータはありません" | ||||
|       res: "レスポンス" | ||||
|       require-credential: "このエンドポイントは認証情報が必須です。" | ||||
|       require-permission: "このエンドポイントは{permission}の権限を必要とします。" | ||||
|       has-limit: "レートリミットがあります。" | ||||
|       duration-limit: "直近{duration}ミリ秒の間のこのエンドポイントへのリクエスト数の合計が{max}を超える場合はリクエストできません。" | ||||
|       min-interval-limit: "前回のリクエストから{interval}ミリ秒経っていない場合はリクエストできません。" | ||||
|       show-src: "このエンドポイントのソースコードも閲覧できます。" | ||||
|       show-src-link: "コードをGitHubで見る" | ||||
|       generated: "このドキュメントはAPI定義に基づき自動生成されています。" | ||||
|     props: | ||||
|       name: "名前" | ||||
|       type: "型" | ||||
|       optional: "オプション" | ||||
|       description: "説明" | ||||
|       yes: "はい" | ||||
|       no: "いいえ" | ||||
|   | ||||
							
								
								
									
										471
									
								
								locales/en.yml
									
									
									
									
									
								
							
							
						
						| @@ -3,13 +3,21 @@ meta: | ||||
|   lang: "English" | ||||
|   divider: "" | ||||
| common: | ||||
|   misskey: "A planet of fediverse" | ||||
|   about-title: "A ⭐ of fediverse." | ||||
|   about: "Thanks for finding Misskey. Misskey is a <b>decentralized microblogging platform</b> born on Earth. Since it exists within Fediverse (a universe where various social media platforms are organized) it is mutually linked with other social media platforms. Why don't you take a short break from the hustle and bustle of the city, and dive into a new Internet?" | ||||
|   misskey: "A ⭐ of the fediverse" | ||||
|   about-title: "A ⭐ of the fediverse." | ||||
|   about: "Thank you for finding Misskey. Misskey is a <b>decentralized microblogging platform</b> born on Earth. Since it exists within the Fediverse (a universe where various social media platforms are organized), it is mutually linked with other social media platforms. Why don't you take a short break from the hustle and bustle of the city, and dive into a new Internet?" | ||||
|   customization-tips: | ||||
|     title: "Customization tips" | ||||
|     paragraph1: "Home customization allows you to add/delete, drag and drop and rearrange widgets." | ||||
|     paragraph2: "You can change the display by <strong>right clicking</strong> on some widgets." | ||||
|     paragraph3: "To delete a widget, <strong>drag and drop the widget onto the area labeled \"Trash\"</strong> in the header." | ||||
|     paragraph4: "To finish the customization, click \"Finish\" in the upper right." | ||||
|     gotit: "Got it!" | ||||
|   name: "Misskey" | ||||
|   time: | ||||
|     unknown: "unknown" | ||||
|     future: "future" | ||||
|     just_now: "just now" | ||||
|     just_now: "now" | ||||
|     seconds_ago: "{}s ago" | ||||
|     minutes_ago: "{}m ago" | ||||
|     hours_ago: "{}h ago" | ||||
| @@ -17,6 +25,7 @@ common: | ||||
|     weeks_ago: "{}week(s) ago" | ||||
|     months_ago: "{}month(s) ago" | ||||
|     years_ago: "{}year(s) ago" | ||||
|   trash: "Trash" | ||||
|   weekday-short: | ||||
|     sunday: "S" | ||||
|     monday: "M" | ||||
| @@ -25,6 +34,14 @@ common: | ||||
|     thursday: "T" | ||||
|     friday: "F" | ||||
|     saturday: "S" | ||||
|   weekday: | ||||
|     sunday: "Sunday" | ||||
|     monday: "Monday" | ||||
|     tuesday: "Tuesday" | ||||
|     wednesday: "Wednesday" | ||||
|     thursday: "Thursday" | ||||
|     friday: "Friday" | ||||
|     saturday: "Saturday" | ||||
|   reactions: | ||||
|     like: "Like" | ||||
|     love: "Love" | ||||
| @@ -39,14 +56,30 @@ common: | ||||
|     a: "What are you doing?" | ||||
|     b: "What's happening?" | ||||
|     c: "What’s on your mind?" | ||||
|     d: "Do you want to say something?" | ||||
|     e: "Write here!" | ||||
|     f: "Waiting for your writing." | ||||
|     d: "What do you wish to say?" | ||||
|     e: "Write here" | ||||
|     f: "Waiting for your writing..." | ||||
|   search: "Search" | ||||
|   delete: "Delete" | ||||
|   loading: "Loading" | ||||
|   ok: "OK" | ||||
|   update-available-title: "Update available" | ||||
|   update-available: "A new version of Misskey is now available({newer}, the current version is {current}). Reload the page to apply updates." | ||||
|   my-token-regenerated: "Your token has been renewed so you will be signed out." | ||||
|   my-token-regenerated: "Your token has been regenerated, so you will be signed out." | ||||
|   i-like-sushi: "I prefer sushi rather than pudding" | ||||
|   show-reversi-board-labels: "Show row and column labels in Reversi" | ||||
|   verified-user: "Verified user" | ||||
|   reversi: | ||||
|     drawn: "Draw" | ||||
|     my-turn: "Your turn" | ||||
|     opponent-turn: "Opponent's turn" | ||||
|     turn-of: "{}'s turn" | ||||
|     past-turn-of: "{}'s turn" | ||||
|     won: "{} won" | ||||
|     black: "Black" | ||||
|     white: "White" | ||||
|     total: "Total" | ||||
|     this-turn: "Turn {}" | ||||
|   widgets: | ||||
|     analog-clock: "Analog clock" | ||||
|     profile: "Profile" | ||||
| @@ -56,7 +89,7 @@ common: | ||||
|     rss: "RSS reader" | ||||
|     memo: "Sticky note" | ||||
|     trends: "Trends" | ||||
|     photo-stream: "Photo stream" | ||||
|     photo-stream: "Photostream" | ||||
|     posts-monitor: "Chart of posts" | ||||
|     slideshow: "Slideshow" | ||||
|     version: "Version" | ||||
| @@ -67,7 +100,7 @@ common: | ||||
|     post-form: "Post form" | ||||
|     messaging: "Messages" | ||||
|     server: "Server info" | ||||
|     donation: "Donation" | ||||
|     donation: "Request for donations" | ||||
|     nav: "Navigation" | ||||
|     tips: "Tips" | ||||
|     hashtags: "Hashtags" | ||||
| @@ -75,21 +108,58 @@ common: | ||||
|     widgets: "Widgets" | ||||
|     home: "Home" | ||||
|     local: "Local" | ||||
|     hybrid: "Social" | ||||
|     global: "Global" | ||||
|     notifications: "Notifications" | ||||
|     list: "List" | ||||
|     swap-left: "Move left" | ||||
|     swap-right: "Move right" | ||||
|     swap-up: "Move upward" | ||||
|     list: "Lists" | ||||
|     swap-left: "Move to the left" | ||||
|     swap-right: "Move to the right" | ||||
|     swap-up: "Move up" | ||||
|     swap-down: "Move downward" | ||||
|     remove: "Remove" | ||||
|     add-column: "Add a column" | ||||
|     rename: "Rename" | ||||
|     stack-left: "Stack to left" | ||||
|     pop-right: "Pop to right" | ||||
|     stack-left: "Stack to the left" | ||||
|     pop-right: "Dock on the right" | ||||
| common/views/components/games/reversi/reversi.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "Play reversi with your friends!" | ||||
|   invite: "Invite" | ||||
|   rule: "How to play" | ||||
|   rule-desc: "Reversi is a strategy board game for two players, played on an 8×8 uncheckered board. There are sixty-four identical game pieces called disks (often spelled \"discs\"), which are light on one side and dark on the other. Players take turns placing disks on the board with their assigned color facing up. During a play, any disks of the opponent's color that are in a straight line and bounded by the disk just placed and another disk of the current player's color are turned over to the current player's color. The object of the game is to have the majority of disks turned to display your color when the last playable empty square is filled." | ||||
|   mode-invite: "Invite" | ||||
|   mode-invite-desc: "Invite to the game a user" | ||||
|   invitations: "You received invitation!" | ||||
|   my-games: "My games" | ||||
|   all-games: "All games" | ||||
|   enter-username: "Enter username" | ||||
|   game-state: | ||||
|     ended: "Ended" | ||||
|     playing: "In Progress" | ||||
|   matching: | ||||
|     waiting-for: "Waiting for {}" | ||||
|     cacnel: "Cancel" | ||||
| common/views/components/games/reversi/reversi.room.vue: | ||||
|   settings-of-the-game: "Game settings" | ||||
|   choose-map: "Choose a map" | ||||
|   random: "Random" | ||||
|   black-or-white: "Black/White" | ||||
|   black-is: "Black is {}" | ||||
|   rules: "Rules" | ||||
|   is-llotheo: "The lesser one wins" | ||||
|   looped-map: "Looped map" | ||||
|   can-put-everywhere: "Can put everywhere" | ||||
|   settings-of-the-bot: "Bot settings" | ||||
|   this-gane-is-started-soon: "This game will start soon" | ||||
|   waiting-for-other: "Waiting for the other party's preparation" | ||||
|   waiting-for-me: "Waiting for the your preparation" | ||||
|   waiting-for-both: "Waiting for yours" | ||||
|   cancel: "Cancel" | ||||
|   ready: "Ready" | ||||
|   cancel-ready: "Cancel \"Ready\"" | ||||
| common/views/components/connect-failed.vue: | ||||
|   title: "Unable to connect to the server" | ||||
|   description: "There is a problem either with your Internet connection, or the server may be down or under maintenance. Please {try again} later." | ||||
|   description: "There is a problem with your Internet connection, or the server may be down or under maintenance. Please try again later." | ||||
|   thanks: "Thank you for using Misskey." | ||||
|   troubleshoot: "Troubleshoot" | ||||
| common/views/components/connect-failed.troubleshooter.vue: | ||||
| @@ -102,11 +172,11 @@ common/views/components/connect-failed.troubleshooter.vue: | ||||
|   checking-server: "Checking server connection" | ||||
|   finding: "Searching for issues" | ||||
|   no-network: "No connection" | ||||
|   no-network-desc: "Please make sure you are connected to the network." | ||||
|   no-network-desc: "Please make sure that you have a network connection." | ||||
|   no-internet: "There is no Internet connection" | ||||
|   no-internet-desc: "Please make sure you are connected to the Internet." | ||||
|   no-server: "Unable to connect to the Misskey server" | ||||
|   no-server-desc: "The network connection of your PC is normal, but you could not connect to the Misskey server. There is a possibility that the server is either down or under maintenance, please try again later." | ||||
|   no-server-desc: "The network connection of your device is normal, but you could not connect to the Misskey server. There is a possibility that the server is either down, or under maintenance, please try again later." | ||||
|   success: "Successfully connected to the Misskey server" | ||||
|   success-desc: "It seems to be able to connect. Please reload the page." | ||||
|   flush: "Clean cache" | ||||
| @@ -114,17 +184,17 @@ common/views/components/connect-failed.troubleshooter.vue: | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "Find a user" | ||||
|   you: "You" | ||||
|   no-history: "No history" | ||||
|   no-history: "Without history" | ||||
| common/views/components/messaging-room.vue: | ||||
|   empty: "You haven't messaged this user" | ||||
|   empty: "No conversations" | ||||
|   more: "Read more" | ||||
|   no-history: "There is no more history" | ||||
|   no-history: "There is no further history" | ||||
|   resize-form: "Drag to resize" | ||||
|   new-message: "New message" | ||||
| common/views/components/messaging-room.form.vue: | ||||
|   input-message-here: "Enter message here" | ||||
|   send: "Send" | ||||
|   attach-from-local: "Attach files from your PC" | ||||
|   attach-from-local: "Attach files from your device" | ||||
|   attach-from-drive: "Attach files from your Drive" | ||||
| common/views/components/messaging-room.message.vue: | ||||
|   is-read: "Read" | ||||
| @@ -140,10 +210,10 @@ common/views/components/nav.vue: | ||||
|   feedback: "Feedback" | ||||
| common/views/components/note-menu.vue: | ||||
|   favorite: "Favorite this note" | ||||
|   pin: "Pin to profile page" | ||||
|   pin: "Pin to your profile page" | ||||
|   delete: "Delete" | ||||
|   delete-confirm: "Are you sure you want to delete this post?" | ||||
|   remote: "Show on origin" | ||||
|   remote: "Show original note" | ||||
| common/views/components/poll.vue: | ||||
|   vote-to: "Vote for '{}'" | ||||
|   vote-count: "{} votes" | ||||
| @@ -152,13 +222,13 @@ common/views/components/poll.vue: | ||||
|   show-result: "Show results" | ||||
|   voted: "Voted" | ||||
| common/views/components/poll-editor.vue: | ||||
|   no-only-one-choice: "You need to enter two or more choices." | ||||
|   no-only-one-choice: "At least two choices are required for this survey." | ||||
|   choice-n: "Choice {}" | ||||
|   remove: "Remove this choice" | ||||
|   remove: "Delete this choice" | ||||
|   add: "+ Add a choice" | ||||
|   destroy: "Cancel this poll" | ||||
|   destroy: "Discard the poll" | ||||
| common/views/components/reaction-picker.vue: | ||||
|   choose-reaction: "Choose a reaction" | ||||
|   choose-reaction: "Express a reaction" | ||||
| common/views/components/signin.vue: | ||||
|   username: "Username" | ||||
|   password: "Password" | ||||
| @@ -183,9 +253,9 @@ common/views/components/signup.vue: | ||||
|   retype-placeholder: "Confirm your password" | ||||
|   password-matched: "OK" | ||||
|   password-not-matched: "Doesn't match" | ||||
|   recaptcha: "Verify" | ||||
|   recaptcha: "Verification" | ||||
|   create: "Create an Account" | ||||
|   some-error: "Account creation failed for some reason. Please try again." | ||||
|   some-error: "An attempt at account creation has failed for some reason. Please try again." | ||||
| common/views/components/special-message.vue: | ||||
|   new-year: "Happy New Year!" | ||||
|   christmas: "Merry Christmas!" | ||||
| @@ -194,7 +264,7 @@ common/views/components/stream-indicator.vue: | ||||
|   reconnecting: "Reconnecting" | ||||
|   connected: "Connected" | ||||
| common/views/components/twitter-setting.vue: | ||||
|   description: "If you connect your Twitter account to your Misskey account, you will be able to see your Twitter account information on your profile and you can sign-in using Twitter." | ||||
|   description: "Once you connect your Twitter account to your Misskey account, you will be able to see information about your Twitter account on your profile, and you will be able to sign-in using Twitter." | ||||
|   connected-to: "You are connected to this Twitter account" | ||||
|   detail: "Details..." | ||||
|   reconnect: "Reconnect" | ||||
| @@ -213,14 +283,21 @@ common/views/components/visibility-chooser.vue: | ||||
|   private: "Private" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "Fetching" | ||||
|   no-broadcasts: "No broadcasts" | ||||
|   no-broadcasts: "No announcements" | ||||
|   have-a-nice-day: "Have a nice day!" | ||||
|   next: "Next" | ||||
| common/views/widgets/calendar.vue: | ||||
|   year: "Year {}" | ||||
|   month: "Month {}" | ||||
|   day: "Day {}" | ||||
|   today: "Today: " | ||||
|   this-month: "This month: " | ||||
|   this-year: "This year: " | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "Donation" | ||||
|   text: "To keep Misskey up and running we spend money for our domain name, servers and so on. Since we don't get money from advertisements, we count on donations from all of you. If you're interested contact {}. Thank you for your contribution!" | ||||
|   title: "Request for donations" | ||||
|   text: "To keep Misskey up and running, we have to spend money on our domain name, the server costs and so on. Since we don't receive money from advertisements, we count on donations from all of you. If you're interested in helping, contact {}. Thank you for your contribution!" | ||||
| common/views/widgets/photo-stream.vue: | ||||
|   title: "Photostream" | ||||
|   title: "Photo stream" | ||||
|   no-photos: "No photos" | ||||
| common/views/widgets/posts-monitor.vue: | ||||
|   title: "Chart of posts" | ||||
| @@ -228,6 +305,7 @@ common/views/widgets/posts-monitor.vue: | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "Hashtags" | ||||
|   count: "{} users mentioned" | ||||
|   empty: "No popular hashtag trends" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "Server info" | ||||
|   toggle: "Toggle views" | ||||
| @@ -235,11 +313,42 @@ common/views/widgets/memo.vue: | ||||
|   title: "Sticky note" | ||||
|   memo: "Write here!" | ||||
|   save: "Save" | ||||
| common/views/widgets/slideshow.vue: | ||||
|   folder-customize-mode: "To specify a folder, please exit customize mode" | ||||
|   folder: "Please click and specify a folder" | ||||
|   no-image: "There is no image in this folder" | ||||
| common/views/widgets/tips.vue: | ||||
|   tips-line1: "You can focus on the timeline with <kbd>t</kbd>." | ||||
|   tips-line2: "Open posting form with <kbd>p</kbd> or <kbd>n</kbd>." | ||||
|   tips-line3: "You can drag and drop files on the post form." | ||||
|   tips-line4: "You can paste an image from the clipboard into the submission form." | ||||
|   tips-line5: "You can upload files by dragging and dropping them to Drive." | ||||
|   tips-line6: "You can move a folder by dragging it within the Drive." | ||||
|   tips-line7: "You can move folders by dragging them within the Drive." | ||||
|   tips-line8: "Home can be customized from the settings." | ||||
|   tips-line9: "Misskey is licensed under AGPLv3." | ||||
|   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-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-line17: "Surrounding the text with ** ** will highlight it." | ||||
|   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-line21: "You can also use the API to develop bots." | ||||
|   tips-line23: "Mayu is so cute with its eyebrows." | ||||
|   tips-line24: "Misskey started in 2014." | ||||
|   tips-line25: "You can receive notification even if Misskey is not open in a compatible browser." | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "Signed in as {}" | ||||
|   following: "Following" | ||||
|   follow: "Follow" | ||||
|   request-pending: "Pending follow request" | ||||
|   follow-request: "Follow request" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Black ... Total" | ||||
|   notes: "Blue ... Notes" | ||||
|   replies: "Red ... Replies" | ||||
|   renotes: "Green ... Renotes" | ||||
|   renotes: "Green ... Repost" | ||||
| desktop/views/components/activity.vue: | ||||
|   title: "Activity" | ||||
|   toggle: "Toggle views" | ||||
| @@ -249,27 +358,29 @@ desktop/views/components/calendar.vue: | ||||
|   next: "Next month" | ||||
|   go: "Click to navigate" | ||||
| desktop/views/components/choose-file-from-drive-window.vue: | ||||
|   choose-file: "Choosing files" | ||||
|   upload: "Upload files from your PC" | ||||
|   choose-file: "Choose files" | ||||
|   upload: "Upload files from your device" | ||||
|   cancel: "Cancel" | ||||
|   ok: "OK" | ||||
|   choose-prompt: "Choose a file" | ||||
|   choose-prompt: "Choose files" | ||||
| desktop/views/components/choose-folder-from-drive-window.vue: | ||||
|   cancel: "Cancel" | ||||
|   ok: "OK" | ||||
|   choose-prompt: "Choose a Folder" | ||||
|   choose-prompt: "Choose a folder" | ||||
| desktop/views/components/crop-window.vue: | ||||
|   skip: "Skip cropping" | ||||
|   cancel: "Cancel" | ||||
|   ok: "OK" | ||||
| desktop/views/components/drive-window.vue: | ||||
|   used: "used" | ||||
|   drive: "Drive" | ||||
|   drive: "Media storage" | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "Avatar" | ||||
|   banner: "Banner" | ||||
|   contextmenu: | ||||
|     rename: "Rename" | ||||
|     mark-as-sensitive: "Mark as 'sensitive'" | ||||
|     unmark-as-sensitive: "Unmark as 'sensitive'" | ||||
|     copy-url: "Copy URL" | ||||
|     download: "Download" | ||||
|     else-files: "Others" | ||||
| @@ -292,13 +403,13 @@ desktop/views/components/drive.folder.vue: | ||||
|     rename-folder: "Rename folder" | ||||
|     input-new-folder-name: "Enter new name" | ||||
| desktop/views/components/drive.nav-folder.vue: | ||||
|   drive: "Drive" | ||||
|   drive: "Media storage" | ||||
| desktop/views/components/drive.vue: | ||||
|   search: "Search" | ||||
|   load-more: "Load more" | ||||
|   empty-draghover: "Drop Welcome!" | ||||
|   empty-drive: "Your drive is empty" | ||||
|   empty-drive-description: "You can also upload by right clicking and selecting \"Upload file\" or you can drag and drop a file onto the window." | ||||
|   empty-draghover: "Drop it here, don't I look cute?" | ||||
|   empty-drive: "Your media storage is empty" | ||||
|   empty-drive-description: "Right-click to open the menu, or drag and drop a file onto here for uploading." | ||||
|   empty-folder: "This folder is empty" | ||||
|   unable-to-process: "The operation could not be completed." | ||||
|   circular-reference-detected: "The destination folder is a subfolder of the folder you wish to move." | ||||
| @@ -313,10 +424,16 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "Create a folder" | ||||
|     upload: "Upload a file" | ||||
|     url-upload: "Upload from a URL" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "The content is NSFW" | ||||
|   click-to-show: "Click to show" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "The content is NSFW" | ||||
|   click-to-show: "Click to show" | ||||
| desktop/views/components/follow-button.vue: | ||||
|   following: "Following" | ||||
|   follow: "Follow" | ||||
|   request-pending: "フォロー許可待ち" | ||||
|   request-pending: "Pending follow request" | ||||
|   follow-request: "Follow request" | ||||
| desktop/views/components/followers-window.vue: | ||||
|   followers: "{}'s followers" | ||||
| @@ -329,13 +446,13 @@ desktop/views/components/following.vue: | ||||
| desktop/views/components/friends-maker.vue: | ||||
|   title: "Recommended users:" | ||||
|   empty: "Couldn't find any recommended users." | ||||
|   fetching: "Loading…" | ||||
|   fetching: "Loading" | ||||
|   refresh: "More" | ||||
|   close: "Close" | ||||
| desktop/views/components/game-window.vue: | ||||
|   game: "Othello" | ||||
|   game: "Reversi" | ||||
| desktop/views/components/home.vue: | ||||
|   done: "Submit" | ||||
|   done: "Done" | ||||
|   add-widget: "Add widget:" | ||||
|   add: "Add" | ||||
| desktop/views/input-dialog.vue: | ||||
| @@ -347,8 +464,8 @@ desktop/views/components/messaging-window.vue: | ||||
|   title: "Messaging" | ||||
| desktop/views/components/note-detail.vue: | ||||
|   more: "Load more conversations" | ||||
|   private: "this post is private" | ||||
|   deleted: "this post has been deleted" | ||||
|   private: "This post is private" | ||||
|   deleted: "This post has been removed" | ||||
|   reposted-by: "Reposted by {}" | ||||
|   location: "Location" | ||||
|   renote: "Repost" | ||||
| @@ -359,15 +476,19 @@ desktop/views/components/notes.note.vue: | ||||
|   renote: "Repost" | ||||
|   add-reaction: "Add a reaction" | ||||
|   detail: "Show details" | ||||
|   private: "this post is private" | ||||
|   deleted: "this post has been deleted" | ||||
|   private: "This post is private" | ||||
|   deleted: "The post has been deleted" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "Loading failed." | ||||
|   retry: "Retry" | ||||
|   load-more: "Read more" | ||||
| desktop/views/components/notifications.vue: | ||||
|   more: "More" | ||||
|   empty: "No notifications" | ||||
|   empty: "No notifications!" | ||||
| desktop/views/components/post-form.vue: | ||||
|   add-visible-user: "+Add a user" | ||||
|   attach-location-information: "Attach location information" | ||||
|   hide-contents: "Hide contents" | ||||
|   reply-placeholder: "Reply to this note..." | ||||
|   quote-placeholder: "Quote this note..." | ||||
|   submit: "Post" | ||||
| @@ -376,16 +497,22 @@ desktop/views/components/post-form.vue: | ||||
|   posted: "Posted!" | ||||
|   replied: "Replied!" | ||||
|   reposted: "Reposted!" | ||||
|   note-failed: "Failed to note" | ||||
|   note-failed: "Failed to post the note" | ||||
|   reply-failed: "Failed to reply" | ||||
|   renote-failed: "Failed to repost" | ||||
|   posting: "Posting" | ||||
|   attach-media-from-local: "Attach media from your PC" | ||||
|   attach-media-from-local: "Attach media from your device" | ||||
|   attach-media-from-drive: "Attach media from your Drive" | ||||
|   attach-cancel: "Cancel attachment" | ||||
|   insert-a-kao: "v(‘ω’)v" | ||||
|   insert-a-kao: "v('ω')v" | ||||
|   create-poll: "Create a poll" | ||||
|   text-remain: "{} characters remaining" | ||||
|   recent-tags: "Recent" | ||||
|   click-to-tagging: "Click to tagging" | ||||
|   visibility: "Visibility" | ||||
|   geolocation-alert: "Your device does not support geolocalization." | ||||
|   error: "Error" | ||||
|   enter-username: "Please enter a username..." | ||||
| desktop/views/components/post-form-window.vue: | ||||
|   note: "New note" | ||||
|   reply: "Reply" | ||||
| @@ -417,15 +544,17 @@ desktop/views/components/settings.vue: | ||||
|   other: "Other" | ||||
|   license: "License" | ||||
|   behaviour: "Behavior" | ||||
|   fetch-on-scroll: "Fetch on scroll" | ||||
|   fetch-on-scroll-desc: "When you scroll down the page automatically fetches additional content." | ||||
|   fetch-on-scroll: "Endless loading on scroll" | ||||
|   fetch-on-scroll-desc: "When you scroll down the page, it automatically fetches additional content." | ||||
|   auto-popout: "Auto pop-out window" | ||||
|   auto-popout-desc: "Pop-out an opened window if possible. This setting is stored in the browser." | ||||
|   auto-popout-desc: "Pops-out a newly opened window (onto a new tab), if possible. This setting is stored in the browser." | ||||
|   advanced: "Advanced settings" | ||||
|   api-via-stream: "API request via stream" | ||||
|   api-via-stream-desc: "API request is performed via the WebSocket connection instead of native fetch API (for better performance). This setting is stored in the browser." | ||||
|   display: "Design and display" | ||||
|   customize: "Customize Home" | ||||
|   customize: "Customize home layout" | ||||
|   choose-wallpaper: "Choose a background" | ||||
|   delete-wallpaper: "Remove background" | ||||
|   dark-mode: "Dark Mode" | ||||
|   circle-icons: "Use circle icons" | ||||
|   gradient-window-header: "Use gradients on window headers" | ||||
| @@ -445,15 +574,15 @@ desktop/views/components/settings.vue: | ||||
|   language: "Language" | ||||
|   pick-language: "Select a language" | ||||
|   recommended: "Recommended" | ||||
|   auto: "Auto" | ||||
|   auto: "Automatic" | ||||
|   specify-language: "Specify language" | ||||
|   language-desc: "You need to reload the page for the changes to take effect." | ||||
|   cache: "Cache" | ||||
|   clean-cache: "Cleanup" | ||||
|   clean-cache: "Clear cache" | ||||
|   cache-warn: "The cache of account info/posts/replies/messages/settings stored in the browser will be deleted. You need to reload the page after cleaning up." | ||||
|   cache-cleared: "Cache cleared" | ||||
|   cache-cleared-desc: "Please reload the page." | ||||
|   auto-watch: "Auto watch" | ||||
|   auto-watch: "Automatic watch" | ||||
|   auto-watch-desc: "Receive notifications about the post/reply/reaction automatically." | ||||
|   about: "About Misskey" | ||||
|   operator: "The admin of this instance" | ||||
| @@ -461,58 +590,61 @@ desktop/views/components/settings.vue: | ||||
|   version: "Version:" | ||||
|   latest-version: "Latest version:" | ||||
|   update-checking: "Checking for updates" | ||||
|   do-update: "Check for update" | ||||
|   do-update: "Check for updates" | ||||
|   update-settings: "Advanced settings" | ||||
|   prevent-update: "Postpone updates (not recommended)" | ||||
|   prevent-update-desc: "Even if you turn this setting on updates may apply. This setting is valid only for this device." | ||||
|   prevent-update-desc: "Even if you turn this setting on, updates may apply. This setting is enabled only for this device." | ||||
|   no-updates: "No updates available" | ||||
|   no-updates-desc: "Your Misskey is up to date." | ||||
|   update-available: "New version is available!" | ||||
|   update-available: "A new version is available" | ||||
|   update-available-desc: "The updates will apply if you reload the page again." | ||||
|   advanced-settings: "Advanced" | ||||
|   debug-mode: "Enable the debug mode" | ||||
|   debug-mode-desc: "This setting is stored in the browser." | ||||
|   experimental: "Enable experimental features" | ||||
|   experimental-desc: "It would make Misskey client unstable. This setting is stored in the browser." | ||||
|   experimental-desc: "Activating this might make the Misskey client unstable. This setting is stored in the browser." | ||||
|   tools: "Tools" | ||||
|   task-manager: "Task Manager" | ||||
|   third-parties: "Third-party" | ||||
|   third-parties: "Third-parties" | ||||
| desktop/views/components/settings.2fa.vue: | ||||
|   intro: "If you set up 2-step verification, you will need not only 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: "See details..." | ||||
|   url: "https://www.google.com/landing/2step/" | ||||
|   caution: "If you lose access to your device, you won't be able to connect to Misskey anymore!" | ||||
|   register: "Register a device" | ||||
|   already-registered: "A device is already registered" | ||||
|   unregister: "Disable" | ||||
|   unregistered: "Two-step authentication has been disabled." | ||||
|   unregistered: "Two-factor authentication has been disabled." | ||||
|   enter-password: "Enter the password" | ||||
|   authenticator: "First, you need install Google Authenticator on your device:" | ||||
|   authenticator: "First, you need to install Google Authenticator on your device:" | ||||
|   howtoinstall: "How to install" | ||||
|   scan: "And then, scan the QR code:" | ||||
|   done: "Please enter the token displaying on your device:" | ||||
|   submit: "Submit" | ||||
|   success: "Setup completed successfully!" | ||||
|   failed: "Failed to setup. please ensure that the token is correct." | ||||
|   success: "Settings saved!" | ||||
|   failed: "Failed to setup. Please ensure that the token is correct." | ||||
|   info: "From now on, enter the token that is displayed on your device in addition to your password when signing-in to Misskey." | ||||
| desktop/views/components/settings.api.vue: | ||||
|   intro: "To access the API, set this token as the key 'i' of request parameters." | ||||
|   caution: "Please do not show this token to third parties (do not enter it somewhere else other than here) otherwise your account could get compromised." | ||||
|   regeneration-of-token: "In the unlikely event that this token leaks out you can regenerate it." | ||||
|   regeneration-of-token: "In the unlikely event that this token leaks out, you can regenerate it." | ||||
|   regenerate-token: "Regenerate the token" | ||||
|   token: "Token:" | ||||
|   enter-password: "Please enter the password" | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "No linked applications" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "Max " | ||||
|   in-use: " in use." | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "No muted users" | ||||
| desktop/views/components/settings.password.vue: | ||||
|   reset: "Change your password" | ||||
|   reset: "Change password" | ||||
|   enter-current-password: "Enter the current password" | ||||
|   enter-new-password: "Enter the new password" | ||||
|   enter-new-password-again: "Enter the new password again" | ||||
|   not-match: "New password doesn't match" | ||||
|   changed: "Password updated successfully" | ||||
|   enter-new-password-again: "Enter new password again" | ||||
|   not-match: "The new passwords do not match" | ||||
|   changed: "Password updated" | ||||
| desktop/views/components/settings.profile.vue: | ||||
|   avatar: "Avatar" | ||||
|   choice-avatar: "Choose an image" | ||||
| @@ -521,11 +653,15 @@ desktop/views/components/settings.profile.vue: | ||||
|   description: "Description" | ||||
|   birthday: "Birthday" | ||||
|   save: "Update profile" | ||||
|   locked-account: "Protect your account" | ||||
|   is-locked: "Make a note private" | ||||
|   other: "Other" | ||||
|   is-bot: "This account is a Bot" | ||||
|   is-cat: "This account is a Cat" | ||||
|   profile-updated: "Profile updated" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "this post is private" | ||||
|   deleted: "this post has been deleted" | ||||
|   private: "This post is private" | ||||
|   deleted: "This post has been deleted" | ||||
|   media-count: "{} media attached" | ||||
|   poll: "Poll" | ||||
| desktop/views/components/taskmanager.vue: | ||||
| @@ -533,23 +669,26 @@ desktop/views/components/taskmanager.vue: | ||||
| desktop/views/components/timeline.vue: | ||||
|   home: "Home" | ||||
|   local: "Local" | ||||
|   hybrid: "Social" | ||||
|   global: "Global" | ||||
|   list: "Lists" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "Welcome back," | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "Your profile" | ||||
|   drive: "Drive" | ||||
|   drive: "Media storage" | ||||
|   favorites: "Favorites" | ||||
|   lists: "Lists" | ||||
|   follow-requests: "Follow requests" | ||||
|   customize: "Customize" | ||||
|   customize: "Customize home layout" | ||||
|   settings: "Settings" | ||||
|   signout: "Sign out" | ||||
|   dark: "Fall in dark" | ||||
|   dark: "Submerge in dark" | ||||
| desktop/views/components/ui.header.nav.vue: | ||||
|   home: "Home" | ||||
|   deck: "Deck" | ||||
|   messaging: "Messages" | ||||
|   game: "Play Othello" | ||||
|   game: "Games" | ||||
| desktop/views/components/ui.header.notifications.vue: | ||||
|   title: "Notifications" | ||||
| desktop/views/components/ui.header.post.vue: | ||||
| @@ -562,7 +701,7 @@ desktop/views/components/received-follow-requests-window.vue: | ||||
|   reject: "Reject" | ||||
| desktop/views/components/user-lists-window.vue: | ||||
|   title: "User lists" | ||||
|   create-list: "Create list" | ||||
|   create-list: "Create new list" | ||||
| desktop/views/components/user-preview.vue: | ||||
|   notes: "Posts" | ||||
|   following: "Following" | ||||
| @@ -575,29 +714,31 @@ desktop/views/components/users-list.vue: | ||||
| desktop/views/components/users-list-item.vue: | ||||
|   followed: "Follows you" | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "Popout" | ||||
|   popout: "Pop-out" | ||||
|   close: "Close" | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "Only media posts" | ||||
|   is-media-view: "Media view" | ||||
|   edit: "Options" | ||||
| desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "Reposted by {}" | ||||
|   private: "this post is private" | ||||
|   deleted: "this post has been deleted" | ||||
|   private: "This post is private" | ||||
|   deleted: "This post has been deleted" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "about" | ||||
|   about: "More details..." | ||||
|   gotit: "Got it!" | ||||
|   signin: "Log In" | ||||
|   signup: "Sign up" | ||||
|   signin-button: "Log in" | ||||
|   signup-button: "Sign up" | ||||
|   timeline: "Timeline" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Misskey Drive" | ||||
|   title: "Misskey storage" | ||||
| desktop/views/pages/favorites.vue: | ||||
|   more: "Load More" | ||||
|   more: "Load more" | ||||
| desktop/views/pages/home-customize.vue: | ||||
|   title: "Customize home" | ||||
|   title: "Customize home layout" | ||||
| desktop/views/pages/note.vue: | ||||
|   prev: "Previous note" | ||||
|   next: "Next note" | ||||
| @@ -605,7 +746,15 @@ desktop/views/pages/selectdrive.vue: | ||||
|   title: "Choose file(s)" | ||||
|   ok: "OK" | ||||
|   cancel: "Cancel" | ||||
|   upload: "Upload files from you PC" | ||||
|   upload: "Upload files from your device" | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "The search function can not be used." | ||||
|   not-found: "No posts were found for '{}'" | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "Share with Misskey" | ||||
|   close: "Close" | ||||
| desktop/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| desktop/views/pages/user-list.users.vue: | ||||
|   users: "User" | ||||
|   add-user: "Add a user" | ||||
| @@ -613,17 +762,17 @@ desktop/views/pages/user-list.users.vue: | ||||
| desktop/views/pages/user/user.followers-you-know.vue: | ||||
|   title: "Followers you know" | ||||
|   loading: "Loading" | ||||
|   no-users: "No users" | ||||
|   no-users: "No followers you know" | ||||
| desktop/views/pages/user/user.friends.vue: | ||||
|   title: "Frequently replied" | ||||
|   title: "Frequent mentions" | ||||
|   loading: "Loading" | ||||
|   no-users: "No users" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "This account has been suspended." | ||||
|   is-remote: "This user is a remote user, so the information is not accurate. " | ||||
|   view-remote: "See accurate information" | ||||
|   is-remote: "This user is a remote user, so the information about them that you see here is not complete. " | ||||
|   view-remote: "See their complete profile" | ||||
| desktop/views/pages/user/user.home.vue: | ||||
|   last-used-at: "Last active: " | ||||
|   last-used-at: "Last active:" | ||||
| desktop/views/pages/user/user.photos.vue: | ||||
|   title: "Photos" | ||||
|   loading: "Loading" | ||||
| @@ -636,11 +785,16 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "Mute" | ||||
|   muted: "Muting" | ||||
|   unmute: "Unmute" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
|   posts: "Notes" | ||||
|   following: "Following" | ||||
|   followers: "Followers" | ||||
|   is-bot: "This account is a Bot" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "Posts" | ||||
|   with-replies: "Posts and replies" | ||||
|   with-replies: "Notes and replies" | ||||
|   with-media: "Media" | ||||
|   empty: "This user has never posted yet." | ||||
|   empty: "This user doesn't seem to have posted anything yet." | ||||
| desktop/views/widgets/messaging.vue: | ||||
|   title: "Messaging" | ||||
| desktop/views/widgets/notifications.vue: | ||||
| @@ -648,7 +802,7 @@ desktop/views/widgets/notifications.vue: | ||||
|   settings: "Settings" | ||||
| desktop/views/widgets/polls.vue: | ||||
|   title: "Polls" | ||||
|   refresh: "Show others" | ||||
|   refresh: "refresh" | ||||
|   nothing: "Nothing" | ||||
| desktop/views/widgets/post-form.vue: | ||||
|   title: "Post" | ||||
| @@ -658,32 +812,32 @@ desktop/views/widgets/profile.vue: | ||||
|   update-avatar: "Click to edit your avatar" | ||||
| desktop/views/widgets/trends.vue: | ||||
|   title: "Trend" | ||||
|   refresh: "Show others" | ||||
|   refresh: "refresh" | ||||
|   nothing: "Nothing" | ||||
| desktop/views/widgets/users.vue: | ||||
|   title: "Recommended users" | ||||
|   refresh: "Show others" | ||||
|   refresh: "refresh" | ||||
|   no-one: "No one" | ||||
| mobile/views/components/drive.vue: | ||||
|   drive: "Drive" | ||||
|   drive: "Media storage" | ||||
|   used: "used" | ||||
|   folder-count: "Folder(s)" | ||||
|   count-separator: ", " | ||||
|   file-count: "File(s)" | ||||
|   load-more: "Load more" | ||||
|   nothing-in-drive: "Nothing" | ||||
|   nothing-in-drive: "There's nothing stored." | ||||
|   folder-is-empty: "This folder is empty" | ||||
|   prompt: "What do you want to do? (Please enter a number): <1 → Upload a file | 2 → Upload a file from a URL | 3 → Create a folder | 4 → Change this folder's name | 5 → Move this folder | 6 → Delete this folder>" | ||||
|   deletion-alert: "Sorry! Deleting a folder is not yet implemented." | ||||
|   folder-name: "Folder name" | ||||
|   root-rename-alert: "You're in the root; it can't be renamed because it's not a folder. Navigate to a folder you want to rename and try again." | ||||
|   root-move-alert: "You're in the root; it can't be moved because it's not a folder. Navigate to a folder you want to move and try again." | ||||
|   url-prompt: "URL of file you want to upload" | ||||
|   uploading: "Upload requested. It may take some time for the upload to complete." | ||||
|   url-prompt: "URL of the file you want to upload" | ||||
|   uploading: "Upload requested. It may take a while for the upload to finish." | ||||
| mobile/views/components/drive-file-detail.vue: | ||||
|   rename: "Rename" | ||||
| mobile/views/components/drive-file-chooser.vue: | ||||
|   select-file: "Choose a file" | ||||
|   select-file: "Choose files" | ||||
| mobile/views/components/drive-folder-chooser.vue: | ||||
|   select-folder: "Choose a folder" | ||||
| mobile/views/components/drive.file-detail.vue: | ||||
| @@ -692,10 +846,16 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   move: "Move" | ||||
|   hash: "Hash (md5)" | ||||
|   exif: "EXIF" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "The content is NSFW" | ||||
|   click-to-show: "Click to show" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "The content is NSFW" | ||||
|   click-to-show: "Click to show" | ||||
| mobile/views/components/follow-button.vue: | ||||
|   following: "Following" | ||||
|   follow: "Follow" | ||||
|   request-pending: "フォロー許可待ち" | ||||
|   request-pending: "Pending follow request" | ||||
|   follow-request: "Follow request" | ||||
| mobile/views/components/friends-maker.vue: | ||||
|   title: "Let's follow users" | ||||
| @@ -707,15 +867,15 @@ mobile/views/components/note.vue: | ||||
|   reposted-by: "Reposted by {}" | ||||
|   more: "See more" | ||||
|   less: "Hide" | ||||
|   private: "this post is private" | ||||
|   deleted: "this post has been deleted" | ||||
|   private: "This post is private" | ||||
|   deleted: "This post has been deleted" | ||||
|   location: "Location" | ||||
| mobile/views/components/note-detail.vue: | ||||
|   reply: "Reply" | ||||
|   reaction: "Reaction" | ||||
|   reposted-by: "Reposted by {}" | ||||
|   private: "this post is private" | ||||
|   deleted: "this post has been deleted" | ||||
|   private: "This post is private" | ||||
|   deleted: "This post has been deleted" | ||||
|   location: "Location" | ||||
| mobile/views/components/note-preview.vue: | ||||
|   admin: "admin" | ||||
| @@ -726,7 +886,7 @@ mobile/views/components/note-sub.vue: | ||||
|   bot: "bot" | ||||
|   cat: "cat" | ||||
| mobile/views/components/notes.vue: | ||||
|   failed: "Failed to load." | ||||
|   failed: "Failed to load" | ||||
|   retry: "Retry" | ||||
| mobile/views/components/notifications.vue: | ||||
|   more: "More" | ||||
| @@ -735,21 +895,23 @@ mobile/views/components/post-form.vue: | ||||
|   add-visible-user: "Add a user" | ||||
|   submit: "Post" | ||||
|   reply: "Reply" | ||||
|   renote: "Repost" | ||||
|   renote: "Renote" | ||||
|   quote-placeholder: "Quote this post... (optional)" | ||||
|   reply-placeholder: "Reply to this note..." | ||||
|   cw-placeholder: "Comments about content (optional)" | ||||
|   location-alert: "Your device does not support location services" | ||||
|   location-alert: "Your device does not provide location services" | ||||
|   error: "Error" | ||||
|   username-prompt: "Enter user name" | ||||
| mobile/views/components/sub-note-content.vue: | ||||
|   private: "this post is private" | ||||
|   deleted: "this post has been deleted" | ||||
|   private: "This post is private" | ||||
|   deleted: "This post has been deleted" | ||||
|   media-count: "{} media attached" | ||||
|   poll: "Poll" | ||||
| mobile/views/components/timeline.vue: | ||||
|   empty: "No notes" | ||||
|   load-more: "More" | ||||
| mobile/views/components/ui.header.vue: | ||||
|   welcome-back: "Welcome back, " | ||||
| mobile/views/components/ui.nav.vue: | ||||
|   timeline: "Timeline" | ||||
|   notifications: "Notifications" | ||||
| @@ -765,8 +927,8 @@ mobile/views/components/ui.nav.vue: | ||||
|   settings: "Settings" | ||||
|   about: "About Misskey" | ||||
| mobile/views/components/user-timeline.vue: | ||||
|   no-notes: "It seems this user hasn't posted yet" | ||||
|   no-notes-with-media: "There is no notes with attached media" | ||||
|   no-notes: "It seems this user hasn't posted anything yet." | ||||
|   no-notes-with-media: "There are no notes with media attachments" | ||||
|   load-more: "More" | ||||
| mobile/views/components/users-list.vue: | ||||
|   all: "All" | ||||
| @@ -780,6 +942,8 @@ mobile/views/pages/user-lists.vue: | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "Drive" | ||||
|   more: "Load more" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "Let's start! 📦" | ||||
| mobile/views/pages/followers.vue: | ||||
|   followers-of: "Followers of {}" | ||||
| mobile/views/pages/following.vue: | ||||
| @@ -787,7 +951,16 @@ mobile/views/pages/following.vue: | ||||
| mobile/views/pages/home.vue: | ||||
|   home: "Home" | ||||
|   local: "Local" | ||||
|   hybrid: "Social" | ||||
|   global: "Global" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| mobile/views/pages/welcome.vue: | ||||
|   signup: "Sign up" | ||||
| mobile/views/pages/widgets.vue: | ||||
|   dashboard: "Dashboard" | ||||
| mobile/views/pages/widgets/activity.vue: | ||||
|   activity: "Activity" | ||||
| mobile/views/pages/messaging.vue: | ||||
|   messaging: "Messaging" | ||||
| mobile/views/pages/messaging-room.vue: | ||||
| @@ -802,33 +975,35 @@ mobile/views/pages/note.vue: | ||||
|   next: "Next note" | ||||
| mobile/views/pages/notifications.vue: | ||||
|   notifications: "Notifications" | ||||
|   read-all: "Are you sure you want to mark all unread notifications as read?" | ||||
|   read-all: "Do you wish to mark all notifications as read?" | ||||
| mobile/views/pages/reversi.vue: | ||||
|   reversi: "Reversi" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "Profile" | ||||
|   name: "Name" | ||||
|   account: "Account" | ||||
|   location: "Location" | ||||
|   description: "Description" | ||||
|   description: "Biography" | ||||
|   birthday: "Birthday" | ||||
|   avatar: "Avatar" | ||||
|   banner: "Banner" | ||||
|   is-cat: "This account is a Cat" | ||||
|   save: "Update profile" | ||||
|   saved: "Profile updated successfully" | ||||
|   saved: "Profile updated" | ||||
|   uploading: "Uploading" | ||||
|   upload-failed: "Upload failed" | ||||
|   upload-failed: "Failed to upload" | ||||
| mobile/views/pages/search.vue: | ||||
|   search: "Search" | ||||
|   empty: "No posts were found for '{}'" | ||||
| mobile/views/pages/selectdrive.vue: | ||||
|   select-file: "Choose a file" | ||||
|   select-file: "Choose files" | ||||
| mobile/views/pages/settings.vue: | ||||
|   signed-in-as: "Signed in as {}" | ||||
|   lang: "Language" | ||||
|   lang-tip: "You will need to reload the page for the changes to take effect." | ||||
|   recommended: "Recommended" | ||||
|   auto: "Auto" | ||||
|   specify-language: "Specify the language" | ||||
|   specify-language: "Select your language" | ||||
|   design: "Design and display" | ||||
|   dark-mode: "Dark Mode" | ||||
|   i-am-under-limited-internet: "I'm under limited internet" | ||||
| @@ -841,10 +1016,10 @@ mobile/views/pages/settings.vue: | ||||
|   post-style-standard: "Standard" | ||||
|   post-style-smart: "Smart" | ||||
|   behavior: "Behavior" | ||||
|   fetch-on-scroll: "Fetch on scroll" | ||||
|   disable-via-mobile: "Without the \"mobile posts\" flag" | ||||
|   load-raw-images: "Show attached pictures in high-quality" | ||||
|   load-remote-media: "Show media on a remote server" | ||||
|   fetch-on-scroll: "Endless loading on scroll" | ||||
|   disable-via-mobile: "Don't mark the post as 'from mobile'" | ||||
|   load-raw-images: "Show attached images in high-quality" | ||||
|   load-remote-media: "Show media from a remote server" | ||||
|   twitter: "Twitter integration" | ||||
|   twitter-connect: "Connect to your Twitter account" | ||||
|   twitter-reconnect: "Reconnect" | ||||
| @@ -853,39 +1028,39 @@ mobile/views/pages/settings.vue: | ||||
|   version: "Current version:" | ||||
|   latest-version: "Latest version:" | ||||
|   update-checking: "Checking for updates" | ||||
|   check-for-updates: "Check for update" | ||||
|   check-for-updates: "Check for updates" | ||||
|   no-updates: "No updates available" | ||||
|   no-updates-desc: "Your Misskey is up to date." | ||||
|   update-available: "New version is available!" | ||||
|   update-available-desc: "To reload the page and updates are applied." | ||||
|   update-available: "A new version is available" | ||||
|   update-available-desc: "Updates will be applied after reloading the page" | ||||
|   settings: "Settings" | ||||
|   signout: "Sign out" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "Follows you" | ||||
|   following: "Following" | ||||
|   followers: "Followers" | ||||
|   notes: "Posts" | ||||
|   notes: "Notes" | ||||
|   overview: "Overview" | ||||
|   timeline: "Timeline" | ||||
|   media: "Media" | ||||
|   is-suspended: "This account has been suspended." | ||||
|   is-remote: "This user is a remote user, so the information is not accurate. " | ||||
|   view-remote: "See accurate information" | ||||
|   is-remote: "This user is a remote user, so the information you see here is not complete." | ||||
|   view-remote: "See their complete profile" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "Recent notes" | ||||
|   images: "Images" | ||||
|   activity: "Activity" | ||||
|   keywords: "Keywords" | ||||
|   domains: "Domains" | ||||
|   frequently-replied-users: "Frequently talking users" | ||||
|   frequently-replied-users: "Frequently mentioned users" | ||||
|   followers-you-know: "Followers you know" | ||||
|   last-used-at: "Last active:" | ||||
| mobile/views/pages/user/home.followers-you-know.vue: | ||||
|   loading: "Loading" | ||||
|   no-users: "No users" | ||||
|   no-users: "No users you know" | ||||
| mobile/views/pages/user/home.friends.vue: | ||||
|   loading: "Loading" | ||||
|   no-users: "No users" | ||||
|   no-users: "There are no users that you know" | ||||
| mobile/views/pages/user/home.notes.vue: | ||||
|   loading: "Loading" | ||||
|   no-notes: "No notes" | ||||
| @@ -900,11 +1075,17 @@ docs: | ||||
|       properties: "Properties" | ||||
|     endpoints: | ||||
|       params: "Parameters" | ||||
|       no-params: "No parameter." | ||||
|       res: "Response" | ||||
|       require-credential: "This endpoint requires the authentication information." | ||||
|       require-permission: "This endpoint requires {permission} permission." | ||||
|       has-limit: "There is a rate limit." | ||||
|       duration-limit: "You can't request when a frequency of a request in during {duration} milliseconds exceeds {max} times." | ||||
|       min-interval-limit: "You can't request before {interval} milliseconds have passed since the previous request." | ||||
|       show-src: "You can view the source code for this endpoint." | ||||
|       show-src-link: "See the code on GitHub" | ||||
|       generated: "This doc is generated by an API definition." | ||||
|     props: | ||||
|       name: "Name" | ||||
|       type: "Type" | ||||
|       optional: "Optional" | ||||
|       description: "Description" | ||||
|       yes: "Yes" | ||||
|       no: "No" | ||||
|   | ||||
							
								
								
									
										755
									
								
								locales/es.yml
									
									
									
									
									
								
							
							
						
						| @@ -1,223 +1,300 @@ | ||||
| --- | ||||
| meta: | ||||
|   lang: "日本語" | ||||
|   lang: "Español" | ||||
|   divider: "" | ||||
| common: | ||||
|   misskey: "A planet of fediverse" | ||||
|   about-title: "A ⭐ of fediverse." | ||||
|   about: "Misskeyを見つけていただき、ありがとうございます。Misskeyは、地球で生まれた<b>分散マイクロブログSNS</b>です。Fediverse(様々なSNSで構成される宇宙)の中に存在するため、他のSNSと相互に繋がっています。暫し都会の喧騒から離れて、新しいインターネットにダイブしてみませんか。" | ||||
|   misskey: "Una ⭐️ del fediverso" | ||||
|   about-title: "Una ⭐️ del fediverso" | ||||
|   about: "Gracias por encontrae Misskey. Misskey es una <b>plataforma descentralizada de microblogging</b> nacida en la Tierra. Gracias a existir dentro del Fediverso (un universo donde se organizan varias plataformas sociales) se encuentra enlazada mutuamente con otras plataformas sociales. ¿Por què no te tomas un respiro del caos de la ciudad y te sumerges es una nueva manera de entender Internet?" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
|     paragraph1: "ホームのカスタマイズでは、ウィジェットを追加/削除したり、ドラッグ&ドロップして並べ替えたりすることができます。" | ||||
|     paragraph2: "一部のウィジェットは、<strong><strong>右</strong>クリック</strong>することで表示を変更することができます。" | ||||
|     paragraph3: "ウィジェットを削除するには、ヘッダーの<strong>「ゴミ箱」</strong>と書かれたエリアにウィジェットをドラッグ&ドロップします。" | ||||
|     paragraph4: "カスタマイズを終了するには、右上の「完了」をクリックします。" | ||||
|     gotit: "Got it!" | ||||
|   name: "Misskey" | ||||
|   time: | ||||
|     unknown: "なぞのじかん" | ||||
|     future: "未来" | ||||
|     just_now: "たった今" | ||||
|     seconds_ago: "{}秒前" | ||||
|     minutes_ago: "{}分前" | ||||
|     hours_ago: "{}時間前" | ||||
|     days_ago: "{}日前" | ||||
|     weeks_ago: "{}週間前" | ||||
|     months_ago: "{}ヶ月前" | ||||
|     years_ago: "{}年前" | ||||
|     unknown: "Desconocido" | ||||
|     future: "Futuro" | ||||
|     just_now: "Ahora mismo" | ||||
|     seconds_ago: "Hace {}" | ||||
|     minutes_ago: "Hace {} minuto(s)" | ||||
|     hours_ago: "Hace {} hora(s)" | ||||
|     days_ago: "Hace {} dia(s)" | ||||
|     weeks_ago: "Hace {} semana(s)" | ||||
|     months_ago: "Hace {} mes(es)" | ||||
|     years_ago: "Hace {} año(s)" | ||||
|   trash: "ゴミ箱" | ||||
|   weekday-short: | ||||
|     sunday: "日" | ||||
|     monday: "月" | ||||
|     tuesday: "火" | ||||
|     wednesday: "水" | ||||
|     thursday: "木" | ||||
|     friday: "金" | ||||
|     saturday: "土" | ||||
|     sunday: "domingo" | ||||
|     monday: "lunes" | ||||
|     tuesday: "martes" | ||||
|     wednesday: "miércoles" | ||||
|     thursday: "jueves" | ||||
|     friday: "viernes" | ||||
|     saturday: "sábado" | ||||
|   weekday: | ||||
|     sunday: "日曜日" | ||||
|     monday: "月曜日" | ||||
|     tuesday: "火曜日" | ||||
|     wednesday: "水曜日" | ||||
|     thursday: "木曜日" | ||||
|     friday: "金曜日" | ||||
|     saturday: "土曜日" | ||||
|   reactions: | ||||
|     like: "いいね" | ||||
|     love: "しゅき" | ||||
|     laugh: "笑" | ||||
|     hmm: "ふぅ~む" | ||||
|     surprise: "わお" | ||||
|     congrats: "おめでとう" | ||||
|     angry: "おこ" | ||||
|     confused: "こまこまのこまり" | ||||
|     pudding: "Pudding" | ||||
|     like: "me gusta" | ||||
|     love: "amor" | ||||
|     laugh: "risa" | ||||
|     hmm: "hmm" | ||||
|     surprise: "sorpresa" | ||||
|     congrats: "felicidades" | ||||
|     angry: "enfadado" | ||||
|     confused: "confundido" | ||||
|     pudding: "Chafado" | ||||
|   note-placeholders: | ||||
|     a: "今どうしてる?" | ||||
|     b: "何かありましたか?" | ||||
|     c: "何をお考えですか?" | ||||
|     d: "言いたいことは?" | ||||
|     e: "ここに書いてください" | ||||
|     f: "あなたが書くのを待っています..." | ||||
|   delete: "削除" | ||||
|   loading: "読み込み中" | ||||
|   ok: "わかった" | ||||
|   update-available: "Misskeyの新しいバージョンがあります({newer}。現在{current}を利用中)。ページを再度読み込みすると更新が適用されます。" | ||||
|   my-token-regenerated: "あなたのトークンが更新されたのでサインアウトします。" | ||||
|     a: "¿Qué haces?" | ||||
|     b: "¿Qué está pasando?" | ||||
|     c: "¿Qué te pasa por la cabeza?" | ||||
|     d: "¿Quieres decir algo?" | ||||
|     e: "¡Escribe aquí!" | ||||
|     f: "Esperando a que escribas algo..." | ||||
|   search: "検索" | ||||
|   delete: "eliminar" | ||||
|   loading: "cargando" | ||||
|   ok: "OK" | ||||
|   update-available-title: "更新があります" | ||||
|   update-available: "Hay disponible una nueva versión de Misskey ({newer}, la versión actual es {current}). Refresca la página para aplicar las actualizaciones." | ||||
|   my-token-regenerated: "Tu token se ha regenerado vas a ser desconectado." | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   verified-user: "認証済みのユーザー" | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
|     opponent-turn: "相手のターンです" | ||||
|     turn-of: "{}のターンです" | ||||
|     past-turn-of: "{}のターン" | ||||
|     won: "{}の勝ち" | ||||
|     black: "黒" | ||||
|     white: "白" | ||||
|     total: "合計" | ||||
|     this-turn: "{}ターン目" | ||||
|   widgets: | ||||
|     analog-clock: "アナログ時計" | ||||
|     profile: "プロフィール" | ||||
|     calendar: "カレンダー" | ||||
|     timemachine: "カレンダー(タイムマシン)" | ||||
|     activity: "アクティビティ" | ||||
|     rss: "RSSリーダー" | ||||
|     memo: "付箋" | ||||
|     trends: "トレンド" | ||||
|     photo-stream: "フォトストリーム" | ||||
|     posts-monitor: "投稿チャート" | ||||
|     slideshow: "スライドショー" | ||||
|     version: "バージョン" | ||||
|     broadcast: "ブロードキャスト" | ||||
|     notifications: "通知" | ||||
|     users: "おすすめユーザー" | ||||
|     polls: "アンケート" | ||||
|     post-form: "投稿フォーム" | ||||
|     messaging: "メッセージ" | ||||
|     server: "サーバー情報" | ||||
|     donation: "寄付のお願い" | ||||
|     nav: "ナビゲーション" | ||||
|     tips: "ヒント" | ||||
|     hashtags: "ハッシュタグ" | ||||
|     analog-clock: "Reloj analógico" | ||||
|     profile: "Perfil" | ||||
|     calendar: "Calendario" | ||||
|     timemachine: "Calendario (máquina del tiempo)" | ||||
|     activity: "Actividad" | ||||
|     rss: "Lector RSS" | ||||
|     memo: "Notas adhesivas" | ||||
|     trends: "Tendencias" | ||||
|     photo-stream: "Secuencia de fotos" | ||||
|     posts-monitor: "Gráfico de publicaciones" | ||||
|     slideshow: "Diapositivas" | ||||
|     version: "Versión" | ||||
|     broadcast: "Transmisión" | ||||
|     notifications: "Notificaciones" | ||||
|     users: "Usuarios destacados" | ||||
|     polls: "Encuestas" | ||||
|     post-form: "Formulario" | ||||
|     messaging: "Mensajes" | ||||
|     server: "Información del servidor" | ||||
|     donation: "Donaciones" | ||||
|     nav: "Navegación" | ||||
|     tips: "Consejos" | ||||
|     hashtags: "Etiquetas" | ||||
|   deck: | ||||
|     widgets: "ウィジェット" | ||||
|     home: "ホーム" | ||||
|     local: "ローカル" | ||||
|     global: "グローバル" | ||||
|     notifications: "通知" | ||||
|     list: "リスト" | ||||
|     swap-left: "左に移動" | ||||
|     swap-right: "右に移動" | ||||
|     swap-up: "上に移動" | ||||
|     swap-down: "下に移動" | ||||
|     remove: "カラムを削除" | ||||
|     add-column: "カラムを追加" | ||||
|     rename: "名前を変更" | ||||
|     stack-left: "左に重ねる" | ||||
|     pop-right: "右に出す" | ||||
|     widgets: "Accesorios" | ||||
|     home: "Inicio" | ||||
|     local: "Local" | ||||
|     hybrid: "ソーシャル" | ||||
|     global: "Global" | ||||
|     notifications: "Notificaciones" | ||||
|     list: "Listado" | ||||
|     swap-left: "Desplazar a la izq." | ||||
|     swap-right: "Desplazar a la dcha." | ||||
|     swap-up: "Desplazar arriba" | ||||
|     swap-down: "Desplazar abajo" | ||||
|     remove: "Borrar" | ||||
|     add-column: "Añadir columna" | ||||
|     rename: "Renombrar" | ||||
|     stack-left: "A la izqda." | ||||
|     pop-right: "A la dcha." | ||||
| common/views/components/games/reversi/reversi.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "他のMisskeyユーザーとリバーシで対戦しよう" | ||||
|   invite: "招待" | ||||
|   rule: "遊び方" | ||||
|   rule-desc: "リバーシは、相手と交互に石をボードに置いて、相手の石を挟んで自分の色に変えてゆき、最終的に残った石が多い方が勝ちというボードゲームです。" | ||||
|   mode-invite: "招待" | ||||
|   mode-invite-desc: "指定したユーザーと対戦するモードです。" | ||||
|   invitations: "対局の招待があります!" | ||||
|   my-games: "自分の対局" | ||||
|   all-games: "みんなの対局" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
|   game-state: | ||||
|     ended: "終了" | ||||
|     playing: "進行中" | ||||
|   matching: | ||||
|     waiting-for: "{}を待っています" | ||||
|     cacnel: "キャンセル" | ||||
| common/views/components/games/reversi/reversi.room.vue: | ||||
|   settings-of-the-game: "ゲームの設定" | ||||
|   choose-map: "マップを選択" | ||||
|   random: "ランダム" | ||||
|   black-or-white: "先手/後手" | ||||
|   black-is: "{}が黒" | ||||
|   rules: "ルール" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
|   settings-of-the-bot: "Botの設定" | ||||
|   this-gane-is-started-soon: "ゲームは数秒後に開始されます" | ||||
|   waiting-for-other: "相手の準備が完了するのを待っています" | ||||
|   waiting-for-me: "あなたの準備が完了するのを待っています" | ||||
|   waiting-for-both: "準備中" | ||||
|   cancel: "キャンセル" | ||||
|   ready: "準備完了" | ||||
|   cancel-ready: "準備続行" | ||||
| common/views/components/connect-failed.vue: | ||||
|   title: "サーバーに接続できません" | ||||
|   description: "インターネット回線に問題があるか、サーバーがダウンまたはメンテナンスしている可能性があります。しばらくしてから{再度お試し}ください。" | ||||
|   thanks: "いつもMisskeyをご利用いただきありがとうございます。" | ||||
|   troubleshoot: "トラブルシュート" | ||||
|   title: "Imposible conectar al servidor" | ||||
|   description: "Hay un problema en tu conexió o puede que el servidor esté caido o en mantenimiento. Por favor {try again} más tarde." | ||||
|   thanks: "Gracias por usar Misskey." | ||||
|   troubleshoot: "Problemas más frecuentes" | ||||
| common/views/components/connect-failed.troubleshooter.vue: | ||||
|   title: "トラブルシューティング" | ||||
|   network: "ネットワーク接続" | ||||
|   checking-network: "ネットワーク接続を確認中" | ||||
|   internet: "インターネット接続" | ||||
|   checking-internet: "インターネット接続を確認中" | ||||
|   server: "サーバー接続" | ||||
|   checking-server: "サーバー接続を確認中" | ||||
|   finding: "問題を調べています" | ||||
|   no-network: "ネットワークに接続されていません" | ||||
|   no-network-desc: "お使いのPCのネットワーク接続が正常か確認してください。" | ||||
|   no-internet: "インターネットに接続されていません" | ||||
|   no-internet-desc: "ネットワークには接続されていますが、インターネットには接続されていないようです。お使いのPCのインターネット接続が正常か確認してください。" | ||||
|   no-server: "Misskeyのサーバーに接続できません" | ||||
|   no-server-desc: "お使いのPCのインターネット接続は正常ですが、Misskeyのサーバーには接続できませんでした。サーバーがダウンまたはメンテナンスしている可能性があるので、しばらくしてから再度御アクセスください。" | ||||
|   success: "Misskeyのサーバーに接続できました" | ||||
|   success-desc: "正常に接続できるようです。ページを再度読み込みしてください。" | ||||
|   flush: "キャッシュの削除" | ||||
|   set-version: "バージョン指定" | ||||
|   title: "Resolución de problemas" | ||||
|   network: "Conexión de red" | ||||
|   checking-network: "Verificar la conexión a la red" | ||||
|   internet: "Conexión a Internet" | ||||
|   checking-internet: "Comprobando la conexión a Internet" | ||||
|   server: "Conexión al servidor" | ||||
|   checking-server: "Probando la conexión al servidor" | ||||
|   finding: "Buscando cualquier problema" | ||||
|   no-network: "Sin conexión" | ||||
|   no-network-desc: "Por favor, asegurate que estás conectado a una red" | ||||
|   no-internet: "Sin conexión a Internet" | ||||
|   no-internet-desc: "Por favor, asegurate de estar conectado a Internet." | ||||
|   no-server: "Imposible conectarse al servidor de Misskey" | ||||
|   no-server-desc: "La conexión de red de tu PC es correcta, aún así no puedes conectarte al servidor de Misskey. Es posible que el servidor esté caido o en mantenimiento. Por favor vuelve a intentarlo más tarde." | ||||
|   success: "Conectado al servidor de Misskey de manera correcta" | ||||
|   success-desc: "Parece que la conexión ha sido posible. Por favor refresca la página." | ||||
|   flush: "Limpiar la memoria caché" | ||||
|   set-version: "Escoge la versión" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "ユーザーを探す" | ||||
|   you: "あなた" | ||||
|   no-history: "履歴はありません" | ||||
|   search-user: "Encuentra un usuario" | ||||
|   you: "Tu" | ||||
|   no-history: "Sin historial" | ||||
| common/views/components/messaging-room.vue: | ||||
|   empty: "このユーザーと話したことはありません" | ||||
|   more: "もっと読む" | ||||
|   no-history: "これより過去の履歴はありません" | ||||
|   resize-form: "ドラッグしてフォームの広さを調整" | ||||
|   new-message: "新しいメッセージがあります" | ||||
|   empty: "Sin conversaciones" | ||||
|   more: "Leer más" | ||||
|   no-history: "El historial se ha acabado" | ||||
|   resize-form: "Arrastra para redimensionar" | ||||
|   new-message: "Nuevo mensaje" | ||||
| common/views/components/messaging-room.form.vue: | ||||
|   input-message-here: "ここにメッセージを入力" | ||||
|   send: "送信" | ||||
|   attach-from-local: "PCからファイルを添付する" | ||||
|   attach-from-drive: "ドライブからファイルを添付する" | ||||
|   input-message-here: "Escribe el mensaje aquí" | ||||
|   send: "Enviar" | ||||
|   attach-from-local: "Adjunta ficheros desde tu PC" | ||||
|   attach-from-drive: "Adjunta ficheros desde tu disco" | ||||
| common/views/components/messaging-room.message.vue: | ||||
|   is-read: "既読" | ||||
|   deleted: "このメッセージは削除されました" | ||||
|   is-read: "Leer" | ||||
|   deleted: "El mensaje se ha borrado" | ||||
| common/views/components/nav.vue: | ||||
|   about: "Misskeyについて" | ||||
|   stats: "統計" | ||||
|   status: "ステータス" | ||||
|   about: "Sobre" | ||||
|   stats: "Estadísticas" | ||||
|   status: "Estado" | ||||
|   wiki: "Wiki" | ||||
|   donors: "ドナー" | ||||
|   repository: "リポジトリ" | ||||
|   develop: "開発者" | ||||
|   feedback: "フィードバック" | ||||
|   donors: "Donantes" | ||||
|   repository: "Repositorio" | ||||
|   develop: "Desarrolladores" | ||||
|   feedback: "Opiniones" | ||||
| common/views/components/note-menu.vue: | ||||
|   favorite: "お気に入り" | ||||
|   pin: "ピン留め" | ||||
|   delete: "削除" | ||||
|   delete-confirm: "この投稿を削除しますか?" | ||||
|   remote: "投稿元で見る" | ||||
|   favorite: "Me gusta esta nota" | ||||
|   pin: "Fijar en el perfil" | ||||
|   delete: "Borrar" | ||||
|   delete-confirm: "¿Seguro que quieres borrar la publicación?" | ||||
|   remote: "Ver el original" | ||||
| common/views/components/poll.vue: | ||||
|   vote-to: "「{}」に投票する" | ||||
|   vote-count: "{}票" | ||||
|   total-users: "{}人が投票" | ||||
|   vote: "投票する" | ||||
|   show-result: "結果を見る" | ||||
|   voted: "投票済み" | ||||
|   vote-to: "'{}' para votar" | ||||
|   vote-count: "{} votos" | ||||
|   total-users: "{} usuario(s) que ha(n) votado" | ||||
|   vote: "Vota" | ||||
|   show-result: "Mostrar resultados" | ||||
|   voted: "Votado" | ||||
| common/views/components/poll-editor.vue: | ||||
|   no-only-one-choice: "アンケートには、選択肢が最低2つ必要です" | ||||
|   choice-n: "選択肢{}" | ||||
|   remove: "この選択肢を削除" | ||||
|   add: "+選択肢を追加" | ||||
|   destroy: "アンケートを破棄" | ||||
|   no-only-one-choice: "Selecciona dos o más opciones." | ||||
|   choice-n: "{} opcion(es)" | ||||
|   remove: "Borra la opción" | ||||
|   add: "+ Añade una opción" | ||||
|   destroy: "Cancelar la encuesta" | ||||
| common/views/components/reaction-picker.vue: | ||||
|   choose-reaction: "リアクションを選択" | ||||
|   choose-reaction: "Escoge una reacción" | ||||
| common/views/components/signin.vue: | ||||
|   username: "ユーザー名" | ||||
|   password: "パスワード" | ||||
|   token: "トークン" | ||||
|   signing-in: "やってます..." | ||||
|   signin: "サインイン" | ||||
|   username: "Usuario" | ||||
|   password: "Contraseña" | ||||
|   token: "Identificador" | ||||
|   signing-in: "Entrando..." | ||||
|   signin: "Entra" | ||||
| common/views/components/signup.vue: | ||||
|   username: "ユーザー名" | ||||
|   checking: "確認しています..." | ||||
|   available: "利用できます" | ||||
|   unavailable: "既に利用されています" | ||||
|   error: "通信エラー" | ||||
|   invalid-format: "a~z、A~Z、0~9、_が使えます" | ||||
|   too-short: "1文字以上でお願いします!" | ||||
|   too-long: "20文字以内でお願いします" | ||||
|   password: "パスワード" | ||||
|   password-placeholder: "8文字以上を推奨します" | ||||
|   weak-password: "弱いパスワード" | ||||
|   normal-password: "まあまあのパスワード" | ||||
|   strong-password: "強いパスワード" | ||||
|   retype: "再入力" | ||||
|   retype-placeholder: "確認のため再入力してください" | ||||
|   password-matched: "確認されました" | ||||
|   password-not-matched: "一致していません" | ||||
|   recaptcha: "認証" | ||||
|   create: "アカウント作成" | ||||
|   some-error: "何らかの原因によりアカウントの作成に失敗しました。再度お試しください。" | ||||
|   username: "Usuario" | ||||
|   checking: "Comprobando..." | ||||
|   available: "Disponible" | ||||
|   unavailable: "Utilizado" | ||||
|   error: "Error de conexión" | ||||
|   invalid-format: "utiliza letras, números y/o -." | ||||
|   too-short: "¡Mínimo tienes que introducir un caracter!" | ||||
|   too-long: "No puedes usar más de 20 caracteres." | ||||
|   password: "Contraseña" | ||||
|   password-placeholder: "Te recomendamos más de 8 caracteres" | ||||
|   weak-password: "Contraseña débil" | ||||
|   normal-password: "No está mal" | ||||
|   strong-password: "Muy buena contraseña" | ||||
|   retype: "Inténtalo otra vez" | ||||
|   retype-placeholder: "Confirma la contraseña" | ||||
|   password-matched: "OK" | ||||
|   password-not-matched: "Las contraseñas no son las mismas" | ||||
|   recaptcha: "Verificar" | ||||
|   create: "Crea una cuenta" | ||||
|   some-error: "Por algún motivo no se ha podido crear la cuenta. Por favor inténtalo de nuevo." | ||||
| common/views/components/special-message.vue: | ||||
|   new-year: "Happy New Year!" | ||||
|   christmas: "Merry Christmas!" | ||||
|   new-year: "¡Feliz Año Nuevo!" | ||||
|   christmas: "¡Feliz Navidad!" | ||||
| common/views/components/stream-indicator.vue: | ||||
|   connecting: "接続中" | ||||
|   reconnecting: "再接続中" | ||||
|   connected: "接続完了" | ||||
|   connecting: "Conectando" | ||||
|   reconnecting: "Reconectando" | ||||
|   connected: "Conectado" | ||||
| common/views/components/twitter-setting.vue: | ||||
|   description: "お使いのTwitterアカウントをお使いのMisskeyアカウントに接続しておくと、プロフィールでTwitterアカウント情報が表示されるようになったり、Twitterを用いた便利なサインインを利用できるようになります。" | ||||
|   connected-to: "次のTwitterアカウントに接続されています" | ||||
|   detail: "詳細..." | ||||
|   reconnect: "再接続する" | ||||
|   connect: "Twitterと接続する" | ||||
|   disconnect: "切断する" | ||||
|   description: "Si comectas tu cuenta de Twitter con tu cuenta de Misskey podrás ver la información de tu cuemta de Twitter en tu perfil y además podrás entrar usando Twitter." | ||||
|   connected-to: "Estas comectado con las siguientes cuentas de Twitter" | ||||
|   detail: "Detalles..." | ||||
|   reconnect: "Conectar de nuevo" | ||||
|   connect: "Conectate usando Twitter" | ||||
|   disconnect: "Desconectado" | ||||
| common/views/components/uploader.vue: | ||||
|   waiting: "待機中" | ||||
|   waiting: "Un momento" | ||||
| common/views/components/visibility-chooser.vue: | ||||
|   public: "公開" | ||||
|   home: "ホーム" | ||||
|   home-desc: "ホームタイムラインにのみ公開" | ||||
|   followers: "フォロワー" | ||||
|   followers-desc: "自分のフォロワーにのみ公開" | ||||
|   specified: "ダイレクト" | ||||
|   specified-desc: "指定したユーザーにのみ公開" | ||||
|   private: "非公開" | ||||
|   public: "Público" | ||||
|   home: "Inicio" | ||||
|   home-desc: "Publica solo en la página de inicio" | ||||
|   followers: "Seguidores" | ||||
|   followers-desc: "Piblica solo para tus seguidores" | ||||
|   specified: "Directo" | ||||
|   specified-desc: "Publica solo para los seguidores que quieras" | ||||
|   private: "Privada" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "確認中" | ||||
|   no-broadcasts: "お知らせはありません" | ||||
|   have-a-nice-day: "良い一日を!" | ||||
|   next: "次" | ||||
|   fetching: "Recuperando" | ||||
|   no-broadcasts: "Sin emisión" | ||||
|   have-a-nice-day: "¡Buenos dias!" | ||||
|   next: "Siguiente" | ||||
| common/views/widgets/calendar.vue: | ||||
|   year: "{}年" | ||||
|   month: "{}月" | ||||
|   day: "{}日" | ||||
|   today: "今日:" | ||||
|   this-month: "今月:" | ||||
|   this-year: "今年:" | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "寄付のお願い" | ||||
|   title: "Donaciones" | ||||
|   text: "Misskeyの運営にはドメイン、サーバー等のコストが掛かります。Misskeyは広告を掲載したりしないため、収入を皆様からの寄付に頼っています。もしご興味があれば、{}までご連絡ください。ご協力ありがとうございます。" | ||||
| common/views/widgets/photo-stream.vue: | ||||
|   title: "フォトストリーム" | ||||
| @@ -228,6 +305,7 @@ common/views/widgets/posts-monitor.vue: | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "ハッシュタグ" | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "サーバー情報" | ||||
|   toggle: "表示を切り替え" | ||||
| @@ -235,6 +313,37 @@ common/views/widgets/memo.vue: | ||||
|   title: "付箋" | ||||
|   memo: "ここに書いて!" | ||||
|   save: "保存" | ||||
| common/views/widgets/slideshow.vue: | ||||
|   folder-customize-mode: "フォルダを指定するには、カスタマイズモードを終了してください" | ||||
|   folder: "クリックしてフォルダを指定してください" | ||||
|   no-image: "このフォルダには画像がありません" | ||||
| common/views/widgets/tips.vue: | ||||
|   tips-line1: "<kbd>t</kbd>でタイムラインにフォーカスできます" | ||||
|   tips-line2: "<kbd>p</kbd>または<kbd>n</kbd>で投稿フォームを開きます" | ||||
|   tips-line3: "投稿フォームにはファイルをドラッグ&ドロップできます" | ||||
|   tips-line4: "投稿フォームにクリップボードにある画像データをペーストできます" | ||||
|   tips-line5: "ドライブにファイルをドラッグ&ドロップしてアップロードできます" | ||||
|   tips-line6: "ドライブでファイルをドラッグしてフォルダ移動できます" | ||||
|   tips-line7: "ドライブでフォルダをドラッグしてフォルダ移動できます" | ||||
|   tips-line8: "ホームは設定からカスタマイズできます" | ||||
|   tips-line9: "MisskeyはAGPLv3です" | ||||
|   tips-line10: "タイムマシンウィジェットを利用すると、簡単に過去のタイムラインに遡れます" | ||||
|   tips-line11: "投稿の ... をクリックして、投稿をユーザーページにピン留めできます" | ||||
|   tips-line13: "投稿に添付したファイルは全てドライブに保存されます" | ||||
|   tips-line14: "ホームのカスタマイズ中、ウィジェットを右クリックしてデザインを変更できます" | ||||
|   tips-line17: "「**」でテキストを囲むと**強調表示**されます" | ||||
|   tips-line19: "いくつかのウィンドウはブラウザの外に切り離すことができます" | ||||
|   tips-line20: "カレンダーウィジェットのパーセンテージは、経過の割合を示しています" | ||||
|   tips-line21: "APIを利用してbotの開発なども行えます" | ||||
|   tips-line23: "まゆかわいいよまゆ" | ||||
|   tips-line24: "Misskeyは2014年にサービスを開始しました" | ||||
|   tips-line25: "対応ブラウザではMisskeyを開いていなくても通知を受け取れます" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
|   request-pending: "フォロー許可待ち" | ||||
|   follow-request: "フォロー申請" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Black ... Total" | ||||
|   notes: "Blue ... Notes" | ||||
| @@ -257,66 +366,74 @@ desktop/views/components/choose-file-from-drive-window.vue: | ||||
| desktop/views/components/choose-folder-from-drive-window.vue: | ||||
|   cancel: "キャンセル" | ||||
|   ok: "決定" | ||||
|   choose-prompt: "フォルダを選択" | ||||
|   choose-prompt: "Escoge una Carpeta" | ||||
| desktop/views/components/crop-window.vue: | ||||
|   skip: "クロップをスキップ" | ||||
|   cancel: "キャンセル" | ||||
|   ok: "決定" | ||||
|   cancel: "Cancelar" | ||||
|   ok: "OK" | ||||
| desktop/views/components/drive-window.vue: | ||||
|   used: "使用中" | ||||
|   drive: "ドライブ" | ||||
|   used: "usado" | ||||
|   drive: "Disco" | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   avatar: "Avatar" | ||||
|   banner: "Banner" | ||||
|   contextmenu: | ||||
|     rename: "名前を変更" | ||||
|     copy-url: "URLをコピー" | ||||
|     download: "ダウンロード" | ||||
|     else-files: "その他..." | ||||
|     set-as-avatar: "アイコンに設定" | ||||
|     set-as-banner: "バナーに設定" | ||||
|     open-in-app: "アプリで開く" | ||||
|     add-app: "アプリを追加" | ||||
|     rename-file: "ファイル名の変更" | ||||
|     input-new-file-name: "新しいファイル名を入力してください" | ||||
|     copied: "コピー完了" | ||||
|     copied-url-to-clipboard: "URLをクリップボードにコピーしました" | ||||
|     rename: "Renombrar" | ||||
|     mark-as-sensitive: "閲覧注意に設定" | ||||
|     unmark-as-sensitive: "閲覧注意を解除" | ||||
|     copy-url: "Copia la URL" | ||||
|     download: "Descargar" | ||||
|     else-files: "Otros" | ||||
|     set-as-avatar: "Utilizar como avatar" | ||||
|     set-as-banner: "Utilizar como banner" | ||||
|     open-in-app: "Abrir en la aplicación" | ||||
|     add-app: "Añadir aplicación" | ||||
|     rename-file: "Renombra el fichero" | ||||
|     input-new-file-name: "Escribe el nombre nuevo" | ||||
|     copied: "Copiado" | ||||
|     copied-url-to-clipboard: "URL copiada al porta papeles" | ||||
| desktop/views/components/drive.folder.vue: | ||||
|   unable-to-process: "操作を完了できません" | ||||
|   circular-reference-detected: "移動先のフォルダーは、移動するフォルダーのサブフォルダーです。" | ||||
|   unhandled-error: "不明なエラー" | ||||
|   unable-to-process: "La operación no se puede llevar a cabo" | ||||
|   circular-reference-detected: "La carpeta de destino es una sub-carpeta de la carpeta que quieres mover." | ||||
|   unhandled-error: "Error desconocido" | ||||
|   contextmenu: | ||||
|     move-to-this-folder: "このフォルダへ移動" | ||||
|     show-in-new-window: "新しいウィンドウで表示" | ||||
|     rename: "名前を変更" | ||||
|     rename-folder: "フォルダ名の変更" | ||||
|     input-new-folder-name: "新しいフォルダ名を入力してください" | ||||
|     move-to-this-folder: "Mover a esta carpeta" | ||||
|     show-in-new-window: "Abrir en una ventana nueva" | ||||
|     rename: "Renombrar" | ||||
|     rename-folder: "Renombrar carpeta" | ||||
|     input-new-folder-name: "Escribe el nombre nuevo" | ||||
| desktop/views/components/drive.nav-folder.vue: | ||||
|   drive: "ドライブ" | ||||
|   drive: "Disco" | ||||
| desktop/views/components/drive.vue: | ||||
|   search: "検索" | ||||
|   load-more: "もっと読み込む" | ||||
|   empty-draghover: "ドロップですか?いいですよ、ボクはカワイイですからね" | ||||
|   empty-drive: "ドライブには何もありません。" | ||||
|   empty-drive-description: "右クリックして「ファイルをアップロード」を選んだり、ファイルをドラッグ&ドロップすることでもアップロードできます。" | ||||
|   empty-folder: "このフォルダーは空です" | ||||
|   unable-to-process: "操作を完了できません" | ||||
|   circular-reference-detected: "移動先のフォルダーは、移動するフォルダーのサブフォルダーです。" | ||||
|   unhandled-error: "不明なエラー" | ||||
|   url-upload: "URLアップロード" | ||||
|   url-of-file: "アップロードしたいファイルのURL" | ||||
|   url-upload-requested: "アップロードをリクエストしました" | ||||
|   may-take-time: "アップロードが完了するまで時間がかかる場合があります。" | ||||
|   create-folder: "フォルダー作成" | ||||
|   folder-name: "フォルダー名" | ||||
|   search: "Buscar" | ||||
|   load-more: "Cargar más" | ||||
|   empty-draghover: "¡Saluda!" | ||||
|   empty-drive: "Tu disco está vacio" | ||||
|   empty-drive-description: "También puedes subir archivos seleccionándolos y con el botón derecho selecciona \"Subir fichero\" o puedes arrastrarlo hasta la ventana." | ||||
|   empty-folder: "La carpeta está vacia" | ||||
|   unable-to-process: "La operación no se puede llevar a cabo." | ||||
|   circular-reference-detected: "La carpeta de destino es una sub-carpeta de la carpeta que quieres mover." | ||||
|   unhandled-error: "Errer desconocido" | ||||
|   url-upload: "Subir desde una URL" | ||||
|   url-of-file: "URL del fichero que quieres subir" | ||||
|   url-upload-requested: "Subida solicitada" | ||||
|   may-take-time: "Subir el fichero puede tardar un tiempo." | ||||
|   create-folder: "Crear una carpeta" | ||||
|   folder-name: "Nombre de la carpeta" | ||||
|   contextmenu: | ||||
|     create-folder: "フォルダーを作成" | ||||
|     upload: "ファイルをアップロード" | ||||
|     url-upload: "URLからアップロード" | ||||
|     create-folder: "Crear una carpeta" | ||||
|     upload: "Subir fichero" | ||||
|     url-upload: "Subir desde una URL" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| desktop/views/components/follow-button.vue: | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
|   request-pending: "フォロー許可待ち" | ||||
|   following: "Siguiendo" | ||||
|   follow: "Sigue" | ||||
|   request-pending: "Pendiente de aprobación" | ||||
|   follow-request: "フォロー申請" | ||||
| desktop/views/components/followers-window.vue: | ||||
|   followers: "{} のフォロワー" | ||||
| @@ -333,7 +450,7 @@ desktop/views/components/friends-maker.vue: | ||||
|   refresh: "もっと見る" | ||||
|   close: "閉じる" | ||||
| desktop/views/components/game-window.vue: | ||||
|   game: "オセロ" | ||||
|   game: "リバーシ" | ||||
| desktop/views/components/home.vue: | ||||
|   done: "完了" | ||||
|   add-widget: "ウィジェットを追加:" | ||||
| @@ -364,10 +481,14 @@ desktop/views/components/notes.note.vue: | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "読み込みに失敗しました。" | ||||
|   retry: "リトライ" | ||||
|   load-more: "もっと読み込む" | ||||
| desktop/views/components/notifications.vue: | ||||
|   more: "もっと見る" | ||||
|   empty: "ありません!" | ||||
| desktop/views/components/post-form.vue: | ||||
|   add-visible-user: "+ユーザーを追加" | ||||
|   attach-location-information: "位置情報を添付する" | ||||
|   hide-contents: "内容を隠す" | ||||
|   reply-placeholder: "この投稿への返信..." | ||||
|   quote-placeholder: "この投稿を引用..." | ||||
|   submit: "投稿" | ||||
| @@ -381,55 +502,63 @@ desktop/views/components/post-form.vue: | ||||
|   renote-failed: "Renoteに失敗しました" | ||||
|   posting: "投稿中" | ||||
|   attach-media-from-local: "PCからメディアを添付" | ||||
|   attach-media-from-drive: "ドライブからメディアを添付" | ||||
|   attach-cancel: "添付取り消し" | ||||
|   insert-a-kao: "v(‘ω’)v" | ||||
|   create-poll: "アンケートを作成" | ||||
|   text-remain: "残り{}文字" | ||||
|   attach-media-from-drive: "Adjunta multimedia desde tu Disco" | ||||
|   attach-cancel: "Quitar el archivo adjunto" | ||||
|   insert-a-kao: "v('ω')v" | ||||
|   create-poll: "Crea una encuesta" | ||||
|   text-remain: "quedan {} caracteres" | ||||
|   recent-tags: "最近" | ||||
|   click-to-tagging: "クリックでタグ付け" | ||||
|   visibility: "公開範囲" | ||||
|   geolocation-alert: "お使いの端末は位置情報に対応していません" | ||||
|   error: "エラー" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
| desktop/views/components/post-form-window.vue: | ||||
|   note: "新規投稿" | ||||
|   reply: "返信" | ||||
|   attaches: "添付: {}メディア" | ||||
|   uploading-media: "{}個のメディアをアップロード中" | ||||
|   note: "Nota nueva" | ||||
|   reply: "Responder" | ||||
|   attaches: "{} archivo(s) multimedia adjuntados" | ||||
|   uploading-media: "Subiendo {} archivo(s) multimedia" | ||||
| desktop/views/components/progress-dialog.vue: | ||||
|   waiting: "待機中" | ||||
|   waiting: "Un momento" | ||||
| desktop/views/components/renote-form.vue: | ||||
|   quote: "引用する..." | ||||
|   cancel: "キャンセル" | ||||
|   renote: "Renote" | ||||
|   reposting: "しています..." | ||||
|   success: "Renoteしました!" | ||||
|   failure: "Renoteに失敗しました" | ||||
|   quote: "Cita..." | ||||
|   cancel: "Cancelar" | ||||
|   renote: "Volver a publicar" | ||||
|   reposting: "Publicando de nuevo..." | ||||
|   success: "¡Publicado!" | ||||
|   failure: "La publicación ha fallado" | ||||
| desktop/views/components/renote-form-window.vue: | ||||
|   title: "この投稿をRenoteしますか?" | ||||
|   title: "¿Seguro qué quieres volver a publicarlo?" | ||||
| desktop/views/components/settings-window.vue: | ||||
|   settings: "設定" | ||||
|   settings: "Configuración" | ||||
| desktop/views/components/settings.vue: | ||||
|   profile: "プロフィール" | ||||
|   notification: "通知" | ||||
|   apps: "アプリ" | ||||
|   mute: "ミュート" | ||||
|   drive: "ドライブ" | ||||
|   security: "セキュリティ" | ||||
|   signin: "サインイン履歴" | ||||
|   password: "パスワード" | ||||
|   2fa: "二段階認証" | ||||
|   other: "その他" | ||||
|   license: "ライセンス" | ||||
|   behaviour: "動作" | ||||
|   fetch-on-scroll: "スクロールで自動読み込み" | ||||
|   fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込みます。" | ||||
|   auto-popout: "ウィンドウの自動ポップアウト" | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   advanced: "詳細設定" | ||||
|   api-via-stream: "ストリームを経由したAPIリクエスト" | ||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||
|   display: "デザインと表示" | ||||
|   customize: "ホームをカスタマイズ" | ||||
|   dark-mode: "ダークモード" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   profile: "Perfil" | ||||
|   notification: "Notificación" | ||||
|   apps: "Aplicaciones" | ||||
|   mute: "Silenciar" | ||||
|   drive: "Disco" | ||||
|   security: "Seguridad" | ||||
|   signin: "Historial de inicios de sesión" | ||||
|   password: "Contraseña" | ||||
|   2fa: "Autenticación de Doble-Factor" | ||||
|   other: "Otros" | ||||
|   license: "Licencia" | ||||
|   behaviour: "Acciones" | ||||
|   fetch-on-scroll: "Desplazamiento infinito" | ||||
|   fetch-on-scroll-desc: "Cuando te deslizas al final de la página nuevo contenido se carga automáticamente." | ||||
|   auto-popout: "Ventana emergente automática" | ||||
|   auto-popout-desc: "Muestra una ventana emergente si es posible. Esta configuración depende del navegador." | ||||
|   advanced: "Configuración avanzada" | ||||
|   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." | ||||
|   display: "Diseño y pantalla" | ||||
|   customize: "Personaliza la página principal" | ||||
|   choose-wallpaper: "壁紙を選択" | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "Modo Nocturno" | ||||
|   circle-icons: "Usar iconos circulares" | ||||
|   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" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||
|   show-renoted-my-notes: "Renoteされた自分の投稿をタイムラインに表示する" | ||||
| @@ -504,6 +633,9 @@ desktop/views/components/settings.api.vue: | ||||
|   enter-password: "パスワードを入力してください" | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "連携しているアプリケーションはありません" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "中" | ||||
|   in-use: "使用中" | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "ミュートしているユーザーはいません" | ||||
| desktop/views/components/settings.password.vue: | ||||
| @@ -521,8 +653,12 @@ desktop/views/components/settings.profile.vue: | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   profile-updated: "プロフィールを更新しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| @@ -533,15 +669,18 @@ desktop/views/components/taskmanager.vue: | ||||
| desktop/views/components/timeline.vue: | ||||
|   home: "ホーム" | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   list: "リスト" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "プロフィール" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
|   customize: "カスタマイズ" | ||||
|   customize: "ホームのカスタマイズ" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   dark: "闇に飲まれる" | ||||
| @@ -580,6 +719,7 @@ desktop/views/components/window.vue: | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "メディア投稿のみ" | ||||
|   is-media-view: "メディアビュー" | ||||
|   edit: "オプション" | ||||
| desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   private: "この投稿は非公開です" | ||||
| @@ -592,6 +732,7 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "やってる" | ||||
|   signup-button: "やる" | ||||
|   timeline: "タイムライン" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Misskey Drive" | ||||
| desktop/views/pages/favorites.vue: | ||||
| @@ -606,6 +747,14 @@ desktop/views/pages/selectdrive.vue: | ||||
|   ok: "決定" | ||||
|   cancel: "キャンセル" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "検索機能を利用することができません。" | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "Misskeyで共有" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| desktop/views/pages/user-list.users.vue: | ||||
|   users: "ユーザー" | ||||
|   add-user: "ユーザーを追加" | ||||
| @@ -618,7 +767,7 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   title: "よく話すユーザー" | ||||
|   loading: "読み込み中" | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
| @@ -636,6 +785,11 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "ミュートする" | ||||
|   muted: "ミュートしています" | ||||
|   unmute: "ミュート解除" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   is-bot: "このアカウントはBotです" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "投稿" | ||||
|   with-replies: "投稿と返信" | ||||
| @@ -692,6 +846,12 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   move: "移動" | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/follow-button.vue: | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
| @@ -750,6 +910,8 @@ mobile/views/components/sub-note-content.vue: | ||||
| mobile/views/components/timeline.vue: | ||||
|   empty: "投稿がありません" | ||||
|   load-more: "もっと" | ||||
| mobile/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
| mobile/views/components/ui.nav.vue: | ||||
|   timeline: "タイムライン" | ||||
|   notifications: "通知" | ||||
| @@ -780,6 +942,8 @@ mobile/views/pages/user-lists.vue: | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   more: "もっと見る" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "📦 始めましょう" | ||||
| mobile/views/pages/followers.vue: | ||||
|   followers-of: "{}のフォロワー" | ||||
| mobile/views/pages/following.vue: | ||||
| @@ -787,7 +951,16 @@ mobile/views/pages/following.vue: | ||||
| mobile/views/pages/home.vue: | ||||
|   home: "ホーム" | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| mobile/views/pages/welcome.vue: | ||||
|   signup: "新規登録" | ||||
| mobile/views/pages/widgets.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
| mobile/views/pages/widgets/activity.vue: | ||||
|   activity: "アクティビティ" | ||||
| mobile/views/pages/messaging.vue: | ||||
|   messaging: "メッセージ" | ||||
| mobile/views/pages/messaging-room.vue: | ||||
| @@ -803,6 +976,8 @@ mobile/views/pages/note.vue: | ||||
| mobile/views/pages/notifications.vue: | ||||
|   notifications: "通知" | ||||
|   read-all: "すべての通知を既読にしますか?" | ||||
| mobile/views/pages/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
| @@ -900,11 +1075,17 @@ docs: | ||||
|       properties: "プロパティ" | ||||
|     endpoints: | ||||
|       params: "パラメータ" | ||||
|       no-params: "パラメータはありません" | ||||
|       res: "レスポンス" | ||||
|       require-credential: "このエンドポイントは認証情報が必須です。" | ||||
|       require-permission: "このエンドポイントは{permission}の権限を必要とします。" | ||||
|       has-limit: "レートリミットがあります。" | ||||
|       duration-limit: "直近{duration}ミリ秒の間のこのエンドポイントへのリクエスト数の合計が{max}を超える場合はリクエストできません。" | ||||
|       min-interval-limit: "前回のリクエストから{interval}ミリ秒経っていない場合はリクエストできません。" | ||||
|       show-src: "このエンドポイントのソースコードも閲覧できます。" | ||||
|       show-src-link: "コードをGitHubで見る" | ||||
|       generated: "このドキュメントはAPI定義に基づき自動生成されています。" | ||||
|     props: | ||||
|       name: "名前" | ||||
|       type: "型" | ||||
|       optional: "オプション" | ||||
|       description: "説明" | ||||
|       yes: "はい" | ||||
|       no: "いいえ" | ||||
|   | ||||
							
								
								
									
										293
									
								
								locales/fr.yml
									
									
									
									
									
								
							
							
						
						| @@ -3,20 +3,29 @@ meta: | ||||
|   lang: "Français" | ||||
|   divider: "" | ||||
| common: | ||||
|   misskey: "Une planète du fédiverse" | ||||
|   misskey: "Une ⭐ du fédiverse" | ||||
|   about-title: "Une ⭐ du fédiverse." | ||||
|   about: "Merci d'avoir découvert Misskey. Misskey est une <b>plateforme de micro-blogging distribuée</b> née sur Terre. Parce qu'il fait partie du Fédiverse (un univers composé de diverses plateformes de réseaux sociaux organisées), il est mutuellement connecté avec d'autres plateformes de réseaux sociaux. Désirez-vous prendre une pause, pendant un instant, loin de l'agitation de la ville et plonger dans un nouvel Internet ?" | ||||
|   customization-tips: | ||||
|     title: "Conseils de personnalisation" | ||||
|     paragraph1: "La personnalisation à la maison vous permet d'ajouter / supprimer, glisser et déposer et réorganiser les widgets." | ||||
|     paragraph2: "Vous pouvez changer l'affichage en <strong>cliquant droit</strong> sur certains widgets." | ||||
|     paragraph3: "Pour supprimer un widget, <strong>glissez et déposez le widget sur la zone étiquetée \"Corbeille\"</strong> dans l'en-tête." | ||||
|     paragraph4: "Pour terminer la personnalisation, cliquez sur \"Terminer\" dans le coin supérieur droit." | ||||
|     gotit: "Compris!" | ||||
|   name: "Misskey" | ||||
|   time: | ||||
|     unknown: "inconnu" | ||||
|     future: "future" | ||||
|     just_now: "maintenant" | ||||
|     seconds_ago: "Il y a {}seconde(s)" | ||||
|     minutes_ago: "Il y a {}minute(s)" | ||||
|     hours_ago: "Il y a {}heure(s)" | ||||
|     days_ago: "Il y a {}jour(s)" | ||||
|     weeks_ago: "Il y a{}semaines(s)" | ||||
|     months_ago: "Il y a {}mois" | ||||
|     years_ago: "Il y a {}an(s)" | ||||
|     just_now: "à l'instant" | ||||
|     seconds_ago: "Il y a {} seconde·s" | ||||
|     minutes_ago: "Il y a {} minute·s" | ||||
|     hours_ago: "Il y a {} heure·s" | ||||
|     days_ago: "Il y a {} jour·s" | ||||
|     weeks_ago: "Il y a {} semaines·s" | ||||
|     months_ago: "Il y a {} mois" | ||||
|     years_ago: "Il y a {} an·s" | ||||
|   trash: "Corbeille" | ||||
|   weekday-short: | ||||
|     sunday: "D" | ||||
|     monday: "L" | ||||
| @@ -25,33 +34,57 @@ common: | ||||
|     thursday: "J" | ||||
|     friday: "V" | ||||
|     saturday: "S" | ||||
|   weekday: | ||||
|     sunday: "日曜日" | ||||
|     monday: "月曜日" | ||||
|     tuesday: "火曜日" | ||||
|     wednesday: "水曜日" | ||||
|     thursday: "木曜日" | ||||
|     friday: "金曜日" | ||||
|     saturday: "土曜日" | ||||
|   reactions: | ||||
|     like: "Aime" | ||||
|     love: "Adore" | ||||
|     laugh: "Rire" | ||||
|     hmm: "Hmm...?" | ||||
|     hmm: "Hmm ... ?" | ||||
|     surprise: "Wow" | ||||
|     congrats: "Félicitations!" | ||||
|     angry: "En Colère" | ||||
|     congrats: "Félicitations !" | ||||
|     angry: "En colère" | ||||
|     confused: "Confus" | ||||
|     pudding: "Pudding" | ||||
|   note-placeholders: | ||||
|     a: "Que faîtes vous à cet instant ?" | ||||
|     a: "Que faîtes vous maintenant ?" | ||||
|     b: "Quoi de neuf ?" | ||||
|     c: "Qu'avez-vous en tête ?" | ||||
|     d: "Voulez-vous exprimer quelque chose ?" | ||||
|     e: "Écrivez ici" | ||||
|     f: "En attente de vos écrits" | ||||
|   search: "Recherche" | ||||
|   delete: "Supprimer" | ||||
|   loading: "Chargement" | ||||
|   ok: "OK" | ||||
|   update-available: "Une nouvelle version de Misskey est disponible({newer}, version actuelle: {current}). Recharger la page pour appliquer la mise à jour." | ||||
|   update-available-title: "Mise à jour disponible" | ||||
|   update-available: "Une nouvelle version de Misskey est disponible ({newer}, version actuelle: {current}). Veuillez recharger la page pour appliquer la mise à jour." | ||||
|   my-token-regenerated: "Votre token vient d'être généré, vous allez maintenant être déconnecté." | ||||
|   i-like-sushi: "Je préfère les sushis (au pudding)" | ||||
|   show-reversi-board-labels: "Afficher les étiquettes des lignes et colonnes dans Reversi" | ||||
|   verified-user: "Utilisateur·trice vérifié·e" | ||||
|   reversi: | ||||
|     drawn: "Partie nulle" | ||||
|     my-turn: "C’est votre tour" | ||||
|     opponent-turn: "Tour de l’adversaire" | ||||
|     turn-of: "C’est le tour de {}" | ||||
|     past-turn-of: "C'est au tour de {}" | ||||
|     won: "{} a gagné" | ||||
|     black: "黒" | ||||
|     white: "白" | ||||
|     total: "合計" | ||||
|     this-turn: "{}ターン目" | ||||
|   widgets: | ||||
|     analog-clock: "Horloge analogique" | ||||
|     profile: "Profil" | ||||
|     calendar: "Calendrier" | ||||
|     timemachine: "カレンダー(タイムマシン)" | ||||
|     timemachine: "Calendrier (Machine de temps)" | ||||
|     activity: "Activité" | ||||
|     rss: "Lecteur de flux RSS" | ||||
|     memo: "Pense-bête" | ||||
| @@ -70,11 +103,12 @@ common: | ||||
|     donation: "Dons" | ||||
|     nav: "Navigation" | ||||
|     tips: "Conseils" | ||||
|     hashtags: "ハッシュタグ" | ||||
|     hashtags: "Étiquettes" | ||||
|   deck: | ||||
|     widgets: "Widgets" | ||||
|     home: "Accueil" | ||||
|     local: "Local" | ||||
|     hybrid: "Social" | ||||
|     global: "Global" | ||||
|     notifications: "Notifications" | ||||
|     list: "Liste" | ||||
| @@ -87,6 +121,42 @@ common: | ||||
|     rename: "Renommer" | ||||
|     stack-left: "Vers la gauche" | ||||
|     pop-right: "Vers la droite" | ||||
| common/views/components/games/reversi/reversi.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "他のMisskeyユーザーとリバーシで対戦しよう" | ||||
|   invite: "招待" | ||||
|   rule: "遊び方" | ||||
|   rule-desc: "リバーシは、相手と交互に石をボードに置いて、相手の石を挟んで自分の色に変えてゆき、最終的に残った石が多い方が勝ちというボードゲームです。" | ||||
|   mode-invite: "招待" | ||||
|   mode-invite-desc: "指定したユーザーと対戦するモードです。" | ||||
|   invitations: "対局の招待があります!" | ||||
|   my-games: "自分の対局" | ||||
|   all-games: "みんなの対局" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
|   game-state: | ||||
|     ended: "終了" | ||||
|     playing: "進行中" | ||||
|   matching: | ||||
|     waiting-for: "{}を待っています" | ||||
|     cacnel: "キャンセル" | ||||
| common/views/components/games/reversi/reversi.room.vue: | ||||
|   settings-of-the-game: "ゲームの設定" | ||||
|   choose-map: "マップを選択" | ||||
|   random: "ランダム" | ||||
|   black-or-white: "先手/後手" | ||||
|   black-is: "{}が黒" | ||||
|   rules: "ルール" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
|   settings-of-the-bot: "Botの設定" | ||||
|   this-gane-is-started-soon: "ゲームは数秒後に開始されます" | ||||
|   waiting-for-other: "相手の準備が完了するのを待っています" | ||||
|   waiting-for-me: "あなたの準備が完了するのを待っています" | ||||
|   waiting-for-both: "準備中" | ||||
|   cancel: "キャンセル" | ||||
|   ready: "準備完了" | ||||
|   cancel-ready: "準備続行" | ||||
| common/views/components/connect-failed.vue: | ||||
|   title: "Impossible de se connecter au server." | ||||
|   description: "Il y a soit un problème avec votre connexion internet, soit le serveur est hors-ligne ou en maintenance. Veuillez {ressayer} plus tard." | ||||
| @@ -143,7 +213,7 @@ common/views/components/note-menu.vue: | ||||
|   pin: "Épingler sur votre profile" | ||||
|   delete: "Supprimer" | ||||
|   delete-confirm: "Supprimer cette publication ?" | ||||
|   remote: "投稿元で見る" | ||||
|   remote: "Afficher les note originale" | ||||
| common/views/components/poll.vue: | ||||
|   vote-to: "Voter pour '{}'" | ||||
|   vote-count: "{} votes" | ||||
| @@ -206,8 +276,8 @@ common/views/components/visibility-chooser.vue: | ||||
|   public: "Public" | ||||
|   home: "Accueil" | ||||
|   home-desc: "Publier sur le fil d'Accueil uniquement" | ||||
|   followers: "Abonnés" | ||||
|   followers-desc: "Publier à vos abonnés uniquement" | ||||
|   followers: "Abonné·e·s" | ||||
|   followers-desc: "Publier à vos abonné·e·s uniquement" | ||||
|   specified: "Direct" | ||||
|   specified-desc: "Publier aux utilisateurs mentionnés" | ||||
|   private: "Privé" | ||||
| @@ -216,6 +286,13 @@ common/views/widgets/broadcast.vue: | ||||
|   no-broadcasts: "No broadcasts" | ||||
|   have-a-nice-day: "Passez une bonne journée!" | ||||
|   next: "Suivant" | ||||
| common/views/widgets/calendar.vue: | ||||
|   year: "{}年" | ||||
|   month: "{}月" | ||||
|   day: "{}日" | ||||
|   today: "今日:" | ||||
|   this-month: "今月:" | ||||
|   this-year: "今年:" | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "Dons" | ||||
|   text: "Toutes les depences pour couvrir les frais de Misskey sortent directement de notre poche. Nous ne recevons pas d'argent, si vous pouvez nous faire dons d'argent, on vous serait eternellement reconnaissant. Si vous êtes intéressés veuilles contacter {}. Merci pour votre contribution!" | ||||
| @@ -224,10 +301,11 @@ common/views/widgets/photo-stream.vue: | ||||
|   no-photos: "Pas de photos" | ||||
| common/views/widgets/posts-monitor.vue: | ||||
|   title: "Graph des publications" | ||||
|   toggle: "表示を切り替え" | ||||
|   toggle: "Basculer les vues" | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "ハッシュタグ" | ||||
|   count: "{}人が投稿" | ||||
|   title: "Étiquettes" | ||||
|   count: "{} utilisateurs mentionnés" | ||||
|   empty: "Aucune tendance" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "Info sur le serveur" | ||||
|   toggle: "Afficher les vues" | ||||
| @@ -235,8 +313,39 @@ common/views/widgets/memo.vue: | ||||
|   title: "Pense-bête" | ||||
|   memo: "Écrivez ici !" | ||||
|   save: "Enregistrer" | ||||
| common/views/widgets/slideshow.vue: | ||||
|   folder-customize-mode: "フォルダを指定するには、カスタマイズモードを終了してください" | ||||
|   folder: "クリックしてフォルダを指定してください" | ||||
|   no-image: "このフォルダには画像がありません" | ||||
| common/views/widgets/tips.vue: | ||||
|   tips-line1: "<kbd>t</kbd>でタイムラインにフォーカスできます" | ||||
|   tips-line2: "<kbd>p</kbd>または<kbd>n</kbd>で投稿フォームを開きます" | ||||
|   tips-line3: "投稿フォームにはファイルをドラッグ&ドロップできます" | ||||
|   tips-line4: "投稿フォームにクリップボードにある画像データをペーストできます" | ||||
|   tips-line5: "ドライブにファイルをドラッグ&ドロップしてアップロードできます" | ||||
|   tips-line6: "ドライブでファイルをドラッグしてフォルダ移動できます" | ||||
|   tips-line7: "ドライブでフォルダをドラッグしてフォルダ移動できます" | ||||
|   tips-line8: "ホームは設定からカスタマイズできます" | ||||
|   tips-line9: "MisskeyはAGPLv3です" | ||||
|   tips-line10: "タイムマシンウィジェットを利用すると、簡単に過去のタイムラインに遡れます" | ||||
|   tips-line11: "投稿の ... をクリックして、投稿をユーザーページにピン留めできます" | ||||
|   tips-line13: "投稿に添付したファイルは全てドライブに保存されます" | ||||
|   tips-line14: "ホームのカスタマイズ中、ウィジェットを右クリックしてデザインを変更できます" | ||||
|   tips-line17: "「**」でテキストを囲むと**強調表示**されます" | ||||
|   tips-line19: "いくつかのウィンドウはブラウザの外に切り離すことができます" | ||||
|   tips-line20: "カレンダーウィジェットのパーセンテージは、経過の割合を示しています" | ||||
|   tips-line21: "APIを利用してbotの開発なども行えます" | ||||
|   tips-line23: "まゆかわいいよまゆ" | ||||
|   tips-line24: "Misskeyは2014年にサービスを開始しました" | ||||
|   tips-line25: "対応ブラウザではMisskeyを開いていなくても通知を受け取れます" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "Connecté en tant que {}" | ||||
|   following: "Suit" | ||||
|   follow: "Suivre" | ||||
|   request-pending: "Demande d'abonnement en attente" | ||||
|   follow-request: "Demande d'abonnement" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Black ... Total" | ||||
|   total: "Noir ... Total" | ||||
|   notes: "Bleu ... Notes" | ||||
|   replies: "Rouge ... Réponses" | ||||
|   renotes: "Vert ... Partages" | ||||
| @@ -270,6 +379,8 @@ desktop/views/components/drive.file.vue: | ||||
|   banner: "Bannière" | ||||
|   contextmenu: | ||||
|     rename: "Renommer" | ||||
|     mark-as-sensitive: "Marquer comme sensible" | ||||
|     unmark-as-sensitive: "Ne pas marquer comme sensible" | ||||
|     copy-url: "Copier l'URL" | ||||
|     download: "Télécharger" | ||||
|     else-files: "Autres..." | ||||
| @@ -313,15 +424,21 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "Créer un dossier" | ||||
|     upload: "Uploader un fichier" | ||||
|     url-upload: "Uploader d'un URL" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "Le contenu est NSFW" | ||||
|   click-to-show: "Cliquer pour afficher" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "Le contenu est NSFW" | ||||
|   click-to-show: "Cliquer pour afficher" | ||||
| desktop/views/components/follow-button.vue: | ||||
|   following: "Abonnements" | ||||
|   follow: "Suivre" | ||||
|   request-pending: "En attente d'approbation" | ||||
|   follow-request: "Demande d'abonnement" | ||||
| desktop/views/components/followers-window.vue: | ||||
|   followers: "{} abonnés" | ||||
|   followers: "{} abonné·e·s" | ||||
| desktop/views/components/followers.vue: | ||||
|   empty: "Il semble que vous n'avez pas encore d'abonnés." | ||||
|   empty: "Il semble que vous n'avez pas encore d'abonné·e·s." | ||||
| desktop/views/components/following-window.vue: | ||||
|   following: "Suit {}" | ||||
| desktop/views/components/following.vue: | ||||
| @@ -333,7 +450,7 @@ desktop/views/components/friends-maker.vue: | ||||
|   refresh: "Plus" | ||||
|   close: "Fermer" | ||||
| desktop/views/components/game-window.vue: | ||||
|   game: "Othello" | ||||
|   game: "Reversi" | ||||
| desktop/views/components/home.vue: | ||||
|   done: "Envoyer" | ||||
|   add-widget: "Ajouter un widget" | ||||
| @@ -364,10 +481,14 @@ desktop/views/components/notes.note.vue: | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "Échec du chargement." | ||||
|   retry: "Réessayer" | ||||
|   load-more: "Afficher plus" | ||||
| desktop/views/components/notifications.vue: | ||||
|   more: "Plus" | ||||
|   empty: "Pas de notifications" | ||||
| desktop/views/components/post-form.vue: | ||||
|   add-visible-user: "+ユーザーを追加" | ||||
|   attach-location-information: "位置情報を添付する" | ||||
|   hide-contents: "内容を隠す" | ||||
|   reply-placeholder: "Répondre à cette note" | ||||
|   quote-placeholder: "Citer cette note" | ||||
|   submit: "Poster" | ||||
| @@ -383,9 +504,15 @@ desktop/views/components/post-form.vue: | ||||
|   attach-media-from-local: "Joindre un media depuis votre PC" | ||||
|   attach-media-from-drive: "Joindre un media depuis votre Drive" | ||||
|   attach-cancel: "Annuler la jointure de fichier" | ||||
|   insert-a-kao: "v(‘ω’)v" | ||||
|   insert-a-kao: "v('ω')v" | ||||
|   create-poll: "Créer un sondage" | ||||
|   text-remain: "{} charactères restants" | ||||
|   recent-tags: "Récent" | ||||
|   click-to-tagging: "クリックでタグ付け" | ||||
|   visibility: "公開範囲" | ||||
|   geolocation-alert: "お使いの端末は位置情報に対応していません" | ||||
|   error: "エラー" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
| desktop/views/components/post-form-window.vue: | ||||
|   note: "Nouvelle note" | ||||
|   reply: "Répondre" | ||||
| @@ -411,7 +538,7 @@ desktop/views/components/settings.vue: | ||||
|   mute: "Mettre en sourdine" | ||||
|   drive: "Drive" | ||||
|   security: "Sécurité" | ||||
|   signin: "サインイン履歴" | ||||
|   signin: "Historique de connexion" | ||||
|   password: "Mot de Passe" | ||||
|   2fa: "Vérification en deux étapes" | ||||
|   other: "Autres" | ||||
| @@ -426,9 +553,11 @@ desktop/views/components/settings.vue: | ||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||
|   display: "Affichage et design" | ||||
|   customize: "Personnaliser l'Accueil" | ||||
|   choose-wallpaper: "Sélectionner un fond d'écran" | ||||
|   delete-wallpaper: "Supprimer le fond d'écran" | ||||
|   dark-mode: "Mode nuit" | ||||
|   circle-icons: "Utiliser des icônes circulaires" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
|   gradient-window-header: "Utiliser les dégradés sur la barre de titre de la fenêtre" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   show-my-renotes: "Afficher mes republications dans le fil" | ||||
| @@ -441,19 +570,19 @@ desktop/views/components/settings.vue: | ||||
|   volume: "Volume" | ||||
|   test: "Test" | ||||
|   mobile: "Mobile" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   disable-via-mobile: "Enlever la mention publié via 'un périphérique mobile'" | ||||
|   language: "Langue" | ||||
|   pick-language: "Sélectionner une langue" | ||||
|   recommended: "Recommandé" | ||||
|   auto: "Automatique" | ||||
|   specify-language: "Spécifier la langue" | ||||
|   language-desc: "変更はページの再度読み込み後に反映されます。" | ||||
|   language-desc: "Le rechargement de la page est requis afin d'appliquer les modifications." | ||||
|   cache: "Cache" | ||||
|   clean-cache: "Nettoyage" | ||||
|   cache-warn: "クリーンアップを行うと、ブラウザに記憶されたアカウント情報のキャッシュ、書きかけの投稿・返信・メッセージ、およびその他のデータ(設定情報含む)が削除されます。クリーンアップを行った後はページを再度読み込みする必要があります。" | ||||
|   cache-cleared: "Cache nettoyé" | ||||
|   cache-cleared-desc: "Veuillez recharger la page." | ||||
|   auto-watch: "投稿の自動ウォッチ" | ||||
|   auto-watch: "Montre automatique" | ||||
|   auto-watch-desc: "リアクションしたり返信したりした投稿に関する通知を自動的に受け取るようにします。" | ||||
|   about: "À propose de Misskey" | ||||
|   operator: "L'admin de cette instance" | ||||
| @@ -463,12 +592,12 @@ desktop/views/components/settings.vue: | ||||
|   update-checking: "Recherche de mises à jour" | ||||
|   do-update: "Rechercher des mises à jour" | ||||
|   update-settings: "Paramètres avancés" | ||||
|   prevent-update: "アップデートを延期する(非推奨)" | ||||
|   prevent-update: "Reporter les mises à jour (non recommandé)" | ||||
|   prevent-update-desc: "この設定をオンにしてもアップデートが反映される場合があります。この設定はこのデバイスのみ有効です。" | ||||
|   no-updates: "Aucune mise à jour disponible" | ||||
|   no-updates-desc: "Votre Misskey est à jour." | ||||
|   update-available: "Nouvelle version disponible !" | ||||
|   update-available-desc: "ページを再度読み込みすると更新が適用されます。" | ||||
|   update-available-desc: "Les mises à jour seront appliquées une fois la page est rechargée." | ||||
|   advanced-settings: "Réglages avancés" | ||||
|   debug-mode: "Activer le mode debug" | ||||
|   debug-mode-desc: "Ce paramètre est stocké dans le navigateur." | ||||
| @@ -504,6 +633,9 @@ desktop/views/components/settings.api.vue: | ||||
|   enter-password: "Veuillez entrer le mot de passe" | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "Aucune application autorisée" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "中" | ||||
|   in-use: "使用中" | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "Aucun utilisateurs mis en sourdine" | ||||
| desktop/views/components/settings.password.vue: | ||||
| @@ -521,8 +653,12 @@ desktop/views/components/settings.profile.vue: | ||||
|   description: "Description" | ||||
|   birthday: "Date de naissance" | ||||
|   save: "Mettre à jour le profil" | ||||
|   locked-account: "Protéger votre compte" | ||||
|   is-locked: "Rendre la note privée" | ||||
|   other: "Autre" | ||||
|   is-bot: "Ce compte est un Bot" | ||||
|   is-cat: "Ce compte est un Chat" | ||||
|   profile-updated: "プロフィールを更新しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "cette publication est privée" | ||||
|   deleted: "cette publication a été supprimée" | ||||
| @@ -533,15 +669,18 @@ desktop/views/components/taskmanager.vue: | ||||
| desktop/views/components/timeline.vue: | ||||
|   home: "Accueil" | ||||
|   local: "Local" | ||||
|   hybrid: "Social" | ||||
|   global: "Global" | ||||
|   list: "Listes" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "Vous êtes de retour !" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "Votre profil" | ||||
|   drive: "Drive" | ||||
|   favorites: "Favorites" | ||||
|   lists: "Listes" | ||||
|   follow-requests: "Demandes de suivi" | ||||
|   customize: "Modifications" | ||||
|   customize: "Personnaliser l'Accueil" | ||||
|   settings: "Réglages" | ||||
|   signout: "Déconnexion" | ||||
|   dark: "Fall in dark" | ||||
| @@ -566,7 +705,7 @@ desktop/views/components/user-lists-window.vue: | ||||
| desktop/views/components/user-preview.vue: | ||||
|   notes: "Publications" | ||||
|   following: "Abonné à" | ||||
|   followers: "Abonnés" | ||||
|   followers: "Abonné·e·s" | ||||
| desktop/views/components/users-list.vue: | ||||
|   all: "Tout" | ||||
|   iknow: "Vous connaissez" | ||||
| @@ -578,8 +717,9 @@ desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "Fermer" | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "メディア投稿のみ" | ||||
|   is-media-view: "メディアビュー" | ||||
|   is-media-only: "Les publications médias uniquement" | ||||
|   is-media-view: "Vue média" | ||||
|   edit: "Options" | ||||
| desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "Reposté par {}" | ||||
|   private: "cette publication est privée" | ||||
| @@ -592,6 +732,7 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "Se connecter" | ||||
|   signup-button: "S'inscrire" | ||||
|   timeline: "Fil d'actualité" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Lecteur de Misskey" | ||||
| desktop/views/pages/favorites.vue: | ||||
| @@ -606,21 +747,29 @@ desktop/views/pages/selectdrive.vue: | ||||
|   ok: "OK" | ||||
|   cancel: "Annuler" | ||||
|   upload: "Uploader un ou plusieurs fichier(s) depuis votre PC" | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "検索機能を利用することができません。" | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "Misskeyで共有" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| desktop/views/pages/user-list.users.vue: | ||||
|   users: "Utilisateurs" | ||||
|   add-user: "Ajouter un utilisateur" | ||||
|   username: "Nom d'utilisateur" | ||||
| desktop/views/pages/user/user.followers-you-know.vue: | ||||
|   title: "Abonnés que vous connaissez" | ||||
|   title: "Abonné·e·s que vous connaissez" | ||||
|   loading: "Chargement en cours" | ||||
|   no-users: "Pas d'utilisateurs" | ||||
| desktop/views/pages/user/user.friends.vue: | ||||
|   title: "Personnes qui répondent le plus" | ||||
|   loading: "Chargement en cours" | ||||
|   no-users: "Pas d'utilisateurs" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
|   is-suspended: "This account has been suspended." | ||||
|   is-remote: "Cet utilisateur n'est pas un utilisateur de Misskey. Certaines informations peuvent être erronées " | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "Ce compte a été suspendu." | ||||
|   is-remote: "Cet utilisateur n'est pas un utilisateur de Misskey. Certaines informations peuvent être erronées" | ||||
|   view-remote: "Voir les informations détaillées" | ||||
| desktop/views/pages/user/user.home.vue: | ||||
|   last-used-at: "Last used at" | ||||
| @@ -636,6 +785,11 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "Mettre en sourdine" | ||||
|   muted: "Muting" | ||||
|   unmute: "Enlever la sourdine" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
|   posts: "Notes" | ||||
|   following: "Suit" | ||||
|   followers: "Abonné·e·s" | ||||
|   is-bot: "Ce compte est un Bot" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "Publications" | ||||
|   with-replies: "Publications et réponses" | ||||
| @@ -678,7 +832,7 @@ mobile/views/components/drive.vue: | ||||
|   folder-name: "Nom du dossier" | ||||
|   root-rename-alert: "現在いる場所はルートで、フォルダではないため名前の変更はできません。名前を変更したいフォルダに移動してからやってください。" | ||||
|   root-move-alert: "現在いる場所はルートで、フォルダではないため移動はできません。移動したいフォルダに移動してからやってください。" | ||||
|   url-prompt: "アップロードしたいファイルのURL" | ||||
|   url-prompt: "URL du fichier que vous souhaitez téléverser" | ||||
|   uploading: "アップロードをリクエストしました。アップロードが完了するまで時間がかかる場合があります。" | ||||
| mobile/views/components/drive-file-detail.vue: | ||||
|   rename: "Renommer" | ||||
| @@ -692,14 +846,20 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   move: "Déplacer" | ||||
|   hash: "Hash (md5)" | ||||
|   exif: "EXIF" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "Le contenu est NSFW" | ||||
|   click-to-show: "Cliquer pour afficher" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "Le contenu est NSFW" | ||||
|   click-to-show: "Cliquer pour afficher" | ||||
| mobile/views/components/follow-button.vue: | ||||
|   following: "フォロー中" | ||||
|   following: "Abonnements" | ||||
|   follow: "Suivre" | ||||
|   request-pending: "フォロー許可待ち" | ||||
|   request-pending: "En attente d'approbation" | ||||
|   follow-request: "Demande d'abonnement" | ||||
| mobile/views/components/friends-maker.vue: | ||||
|   title: "Abonnez-vous aux utilisateurs" | ||||
|   empty: "おすすめのユーザーは見つかりませんでした。" | ||||
|   empty: "Impossible de trouver des utilisateurs à recommander." | ||||
|   fetching: "Chargement" | ||||
|   refresh: "Voir plus" | ||||
|   close: "Fermer" | ||||
| @@ -746,10 +906,12 @@ mobile/views/components/sub-note-content.vue: | ||||
|   private: "cette publication est privée" | ||||
|   deleted: "cette publication a été supprimée" | ||||
|   media-count: "{} médias attachés" | ||||
|   poll: "アンケート" | ||||
|   poll: "Sondage" | ||||
| mobile/views/components/timeline.vue: | ||||
|   empty: "Pas de notes" | ||||
|   load-more: "Afficher plus" | ||||
| mobile/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
| mobile/views/components/ui.nav.vue: | ||||
|   timeline: "Fil d'actualité" | ||||
|   notifications: "Notifications" | ||||
| @@ -780,14 +942,25 @@ mobile/views/pages/user-lists.vue: | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "Drive" | ||||
|   more: "Afficher plus ..." | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "📦 始めましょう" | ||||
| mobile/views/pages/followers.vue: | ||||
|   followers-of: "Abonnés de {}" | ||||
|   followers-of: "Abonné·e·s de {}" | ||||
| mobile/views/pages/following.vue: | ||||
|   following-of: "Abonnements de {}" | ||||
| mobile/views/pages/home.vue: | ||||
|   home: "Accueil" | ||||
|   local: "Local" | ||||
|   hybrid: "Social" | ||||
|   global: "Global" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| mobile/views/pages/welcome.vue: | ||||
|   signup: "新規登録" | ||||
| mobile/views/pages/widgets.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
| mobile/views/pages/widgets/activity.vue: | ||||
|   activity: "アクティビティ" | ||||
| mobile/views/pages/messaging.vue: | ||||
|   messaging: "Messagerie" | ||||
| mobile/views/pages/messaging-room.vue: | ||||
| @@ -803,6 +976,8 @@ mobile/views/pages/note.vue: | ||||
| mobile/views/pages/notifications.vue: | ||||
|   notifications: "Notifications" | ||||
|   read-all: "Êtes vous sûr de vouloir marqués toutes les notifications non-lus en tant que lus?" | ||||
| mobile/views/pages/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "Profil" | ||||
|   name: "Nom" | ||||
| @@ -842,7 +1017,7 @@ mobile/views/pages/settings.vue: | ||||
|   post-style-smart: "Intelligent" | ||||
|   behavior: "Comportement" | ||||
|   fetch-on-scroll: "Chargement lors du défilement" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   disable-via-mobile: "Ne pas mentionner que ma publication provient d'un 'périphérique mobile'" | ||||
|   load-raw-images: "Afficher les photos jointes en haute qualité" | ||||
|   load-remote-media: "Afficher les médias sur le serveur distant" | ||||
|   twitter: "Intégration à Twitter" | ||||
| @@ -857,14 +1032,14 @@ mobile/views/pages/settings.vue: | ||||
|   no-updates: "Aucune mise à jour disponible" | ||||
|   no-updates-desc: "Votre Misskey est à jour." | ||||
|   update-available: "Nouvelle version disponible !" | ||||
|   update-available-desc: "ページを再度読み込みすると更新が適用されます。" | ||||
|   update-available-desc: "Les mises à jour seront appliquées une fois la page est rechargée." | ||||
|   settings: "Réglages" | ||||
|   signout: "Déconnexion" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "vous suit" | ||||
|   following: "Abonnements" | ||||
|   followers: "Abonnés" | ||||
|   notes: "Posts" | ||||
|   followers: "Abonné·e·s" | ||||
|   notes: "Notes" | ||||
|   overview: "Aperçu" | ||||
|   timeline: "Fil d'actualité" | ||||
|   media: "Media" | ||||
| @@ -878,7 +1053,7 @@ mobile/views/pages/user/home.vue: | ||||
|   keywords: "Mot clés" | ||||
|   domains: "Domaines" | ||||
|   frequently-replied-users: "Utilisateurs qui interagissent souvent" | ||||
|   followers-you-know: "Abonnés que vous connaissez" | ||||
|   followers-you-know: "Abonné·e·s que vous connaissez" | ||||
|   last-used-at: "Dernière connexion il y a" | ||||
| mobile/views/pages/user/home.followers-you-know.vue: | ||||
|   loading: "Chargement" | ||||
| @@ -900,11 +1075,17 @@ docs: | ||||
|       properties: "Propriétés" | ||||
|     endpoints: | ||||
|       params: "Paramètres" | ||||
|       no-params: "Aucun paramètre" | ||||
|       res: "Réponse" | ||||
|       require-credential: "このエンドポイントは認証情報が必須です。" | ||||
|       require-permission: "このエンドポイントは{permission}の権限を必要とします。" | ||||
|       has-limit: "レートリミットがあります。" | ||||
|       duration-limit: "直近{duration}ミリ秒の間のこのエンドポイントへのリクエスト数の合計が{max}を超える場合はリクエストできません。" | ||||
|       min-interval-limit: "前回のリクエストから{interval}ミリ秒経っていない場合はリクエストできません。" | ||||
|       show-src: "このエンドポイントのソースコードも閲覧できます。" | ||||
|       show-src-link: "Consulter le code sur GitHub" | ||||
|       generated: "このドキュメントはAPI定義に基づき自動生成されています。" | ||||
|     props: | ||||
|       name: "Nom" | ||||
|       type: "Type" | ||||
|       optional: "Optionel" | ||||
|       description: "Description" | ||||
|       yes: "Oui" | ||||
|       no: "Non" | ||||
|   | ||||
| @@ -2,11 +2,11 @@ | ||||
|  * Languages Loader | ||||
|  */ | ||||
| 
 | ||||
| import * as fs from 'fs'; | ||||
| import * as yaml from 'js-yaml'; | ||||
| const fs = require('fs'); | ||||
| const yaml = require('js-yaml'); | ||||
| 
 | ||||
| const loadLang = lang => yaml.safeLoad( | ||||
| 	fs.readFileSync(`./locales/${lang}.yml`, 'utf-8')); | ||||
| 	fs.readFileSync(`${__dirname}/${lang}.yml`, 'utf-8')); | ||||
| 
 | ||||
| const native = loadLang('ja'); | ||||
| 
 | ||||
| @@ -15,12 +15,13 @@ const langs = { | ||||
| 	'en': loadLang('en'), | ||||
| 	'fr': loadLang('fr'), | ||||
| 	'ja': native, | ||||
| 	'pl': loadLang('pl') | ||||
| 	'pl': loadLang('pl'), | ||||
| 	'es': loadLang('es') | ||||
| }; | ||||
| 
 | ||||
| Object.entries(langs).map(([, locale]) => { | ||||
| Object.values(langs).forEach(locale => { | ||||
| 	// Extend native language (Japanese)
 | ||||
| 	locale = Object.assign({}, native, locale); | ||||
| }); | ||||
| 
 | ||||
| export default langs; | ||||
| module.exports = langs; | ||||
							
								
								
									
										197
									
								
								locales/it.yml
									
									
									
									
									
								
							
							
						
						| @@ -3,9 +3,17 @@ meta: | ||||
|   lang: "日本語" | ||||
|   divider: "" | ||||
| common: | ||||
|   misskey: "A planet of fediverse" | ||||
|   misskey: "A ⭐ of fediverse" | ||||
|   about-title: "A ⭐ of fediverse." | ||||
|   about: "Misskeyを見つけていただき、ありがとうございます。Misskeyは、地球で生まれた<b>分散マイクロブログSNS</b>です。Fediverse(様々なSNSで構成される宇宙)の中に存在するため、他のSNSと相互に繋がっています。暫し都会の喧騒から離れて、新しいインターネットにダイブしてみませんか。" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
|     paragraph1: "ホームのカスタマイズでは、ウィジェットを追加/削除したり、ドラッグ&ドロップして並べ替えたりすることができます。" | ||||
|     paragraph2: "一部のウィジェットは、<strong><strong>右</strong>クリック</strong>することで表示を変更することができます。" | ||||
|     paragraph3: "ウィジェットを削除するには、ヘッダーの<strong>「ゴミ箱」</strong>と書かれたエリアにウィジェットをドラッグ&ドロップします。" | ||||
|     paragraph4: "カスタマイズを終了するには、右上の「完了」をクリックします。" | ||||
|     gotit: "Got it!" | ||||
|   name: "Misskey" | ||||
|   time: | ||||
|     unknown: "なぞのじかん" | ||||
|     future: "未来" | ||||
| @@ -17,6 +25,7 @@ common: | ||||
|     weeks_ago: "{}週間前" | ||||
|     months_ago: "{}ヶ月前" | ||||
|     years_ago: "{}年前" | ||||
|   trash: "ゴミ箱" | ||||
|   weekday-short: | ||||
|     sunday: "日" | ||||
|     monday: "月" | ||||
| @@ -25,6 +34,14 @@ common: | ||||
|     thursday: "木" | ||||
|     friday: "金" | ||||
|     saturday: "土" | ||||
|   weekday: | ||||
|     sunday: "日曜日" | ||||
|     monday: "月曜日" | ||||
|     tuesday: "火曜日" | ||||
|     wednesday: "水曜日" | ||||
|     thursday: "木曜日" | ||||
|     friday: "金曜日" | ||||
|     saturday: "土曜日" | ||||
|   reactions: | ||||
|     like: "いいね" | ||||
|     love: "しゅき" | ||||
| @@ -42,11 +59,27 @@ common: | ||||
|     d: "言いたいことは?" | ||||
|     e: "ここに書いてください" | ||||
|     f: "あなたが書くのを待っています..." | ||||
|   search: "検索" | ||||
|   delete: "削除" | ||||
|   loading: "読み込み中" | ||||
|   ok: "わかった" | ||||
|   update-available-title: "更新があります" | ||||
|   update-available: "Misskeyの新しいバージョンがあります({newer}。現在{current}を利用中)。ページを再度読み込みすると更新が適用されます。" | ||||
|   my-token-regenerated: "あなたのトークンが更新されたのでサインアウトします。" | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   verified-user: "認証済みのユーザー" | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
|     opponent-turn: "相手のターンです" | ||||
|     turn-of: "{}のターンです" | ||||
|     past-turn-of: "{}のターン" | ||||
|     won: "{}の勝ち" | ||||
|     black: "黒" | ||||
|     white: "白" | ||||
|     total: "合計" | ||||
|     this-turn: "{}ターン目" | ||||
|   widgets: | ||||
|     analog-clock: "アナログ時計" | ||||
|     profile: "プロフィール" | ||||
| @@ -75,6 +108,7 @@ common: | ||||
|     widgets: "ウィジェット" | ||||
|     home: "ホーム" | ||||
|     local: "ローカル" | ||||
|     hybrid: "ソーシャル" | ||||
|     global: "グローバル" | ||||
|     notifications: "通知" | ||||
|     list: "リスト" | ||||
| @@ -87,6 +121,42 @@ common: | ||||
|     rename: "名前を変更" | ||||
|     stack-left: "左に重ねる" | ||||
|     pop-right: "右に出す" | ||||
| common/views/components/games/reversi/reversi.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "他のMisskeyユーザーとリバーシで対戦しよう" | ||||
|   invite: "招待" | ||||
|   rule: "遊び方" | ||||
|   rule-desc: "リバーシは、相手と交互に石をボードに置いて、相手の石を挟んで自分の色に変えてゆき、最終的に残った石が多い方が勝ちというボードゲームです。" | ||||
|   mode-invite: "招待" | ||||
|   mode-invite-desc: "指定したユーザーと対戦するモードです。" | ||||
|   invitations: "対局の招待があります!" | ||||
|   my-games: "自分の対局" | ||||
|   all-games: "みんなの対局" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
|   game-state: | ||||
|     ended: "終了" | ||||
|     playing: "進行中" | ||||
|   matching: | ||||
|     waiting-for: "{}を待っています" | ||||
|     cacnel: "キャンセル" | ||||
| common/views/components/games/reversi/reversi.room.vue: | ||||
|   settings-of-the-game: "ゲームの設定" | ||||
|   choose-map: "マップを選択" | ||||
|   random: "ランダム" | ||||
|   black-or-white: "先手/後手" | ||||
|   black-is: "{}が黒" | ||||
|   rules: "ルール" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
|   settings-of-the-bot: "Botの設定" | ||||
|   this-gane-is-started-soon: "ゲームは数秒後に開始されます" | ||||
|   waiting-for-other: "相手の準備が完了するのを待っています" | ||||
|   waiting-for-me: "あなたの準備が完了するのを待っています" | ||||
|   waiting-for-both: "準備中" | ||||
|   cancel: "キャンセル" | ||||
|   ready: "準備完了" | ||||
|   cancel-ready: "準備続行" | ||||
| common/views/components/connect-failed.vue: | ||||
|   title: "サーバーに接続できません" | ||||
|   description: "インターネット回線に問題があるか、サーバーがダウンまたはメンテナンスしている可能性があります。しばらくしてから{再度お試し}ください。" | ||||
| @@ -216,6 +286,13 @@ common/views/widgets/broadcast.vue: | ||||
|   no-broadcasts: "お知らせはありません" | ||||
|   have-a-nice-day: "良い一日を!" | ||||
|   next: "次" | ||||
| common/views/widgets/calendar.vue: | ||||
|   year: "{}年" | ||||
|   month: "{}月" | ||||
|   day: "{}日" | ||||
|   today: "今日:" | ||||
|   this-month: "今月:" | ||||
|   this-year: "今年:" | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "寄付のお願い" | ||||
|   text: "Misskeyの運営にはドメイン、サーバー等のコストが掛かります。Misskeyは広告を掲載したりしないため、収入を皆様からの寄付に頼っています。もしご興味があれば、{}までご連絡ください。ご協力ありがとうございます。" | ||||
| @@ -228,6 +305,7 @@ common/views/widgets/posts-monitor.vue: | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "ハッシュタグ" | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "サーバー情報" | ||||
|   toggle: "表示を切り替え" | ||||
| @@ -235,6 +313,37 @@ common/views/widgets/memo.vue: | ||||
|   title: "付箋" | ||||
|   memo: "ここに書いて!" | ||||
|   save: "保存" | ||||
| common/views/widgets/slideshow.vue: | ||||
|   folder-customize-mode: "フォルダを指定するには、カスタマイズモードを終了してください" | ||||
|   folder: "クリックしてフォルダを指定してください" | ||||
|   no-image: "このフォルダには画像がありません" | ||||
| common/views/widgets/tips.vue: | ||||
|   tips-line1: "<kbd>t</kbd>でタイムラインにフォーカスできます" | ||||
|   tips-line2: "<kbd>p</kbd>または<kbd>n</kbd>で投稿フォームを開きます" | ||||
|   tips-line3: "投稿フォームにはファイルをドラッグ&ドロップできます" | ||||
|   tips-line4: "投稿フォームにクリップボードにある画像データをペーストできます" | ||||
|   tips-line5: "ドライブにファイルをドラッグ&ドロップしてアップロードできます" | ||||
|   tips-line6: "ドライブでファイルをドラッグしてフォルダ移動できます" | ||||
|   tips-line7: "ドライブでフォルダをドラッグしてフォルダ移動できます" | ||||
|   tips-line8: "ホームは設定からカスタマイズできます" | ||||
|   tips-line9: "MisskeyはAGPLv3です" | ||||
|   tips-line10: "タイムマシンウィジェットを利用すると、簡単に過去のタイムラインに遡れます" | ||||
|   tips-line11: "投稿の ... をクリックして、投稿をユーザーページにピン留めできます" | ||||
|   tips-line13: "投稿に添付したファイルは全てドライブに保存されます" | ||||
|   tips-line14: "ホームのカスタマイズ中、ウィジェットを右クリックしてデザインを変更できます" | ||||
|   tips-line17: "「**」でテキストを囲むと**強調表示**されます" | ||||
|   tips-line19: "いくつかのウィンドウはブラウザの外に切り離すことができます" | ||||
|   tips-line20: "カレンダーウィジェットのパーセンテージは、経過の割合を示しています" | ||||
|   tips-line21: "APIを利用してbotの開発なども行えます" | ||||
|   tips-line23: "まゆかわいいよまゆ" | ||||
|   tips-line24: "Misskeyは2014年にサービスを開始しました" | ||||
|   tips-line25: "対応ブラウザではMisskeyを開いていなくても通知を受け取れます" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
|   request-pending: "フォロー許可待ち" | ||||
|   follow-request: "フォロー申請" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Black ... Total" | ||||
|   notes: "Blue ... Notes" | ||||
| @@ -270,6 +379,8 @@ desktop/views/components/drive.file.vue: | ||||
|   banner: "バナー" | ||||
|   contextmenu: | ||||
|     rename: "名前を変更" | ||||
|     mark-as-sensitive: "閲覧注意に設定" | ||||
|     unmark-as-sensitive: "閲覧注意を解除" | ||||
|     copy-url: "URLをコピー" | ||||
|     download: "ダウンロード" | ||||
|     else-files: "その他..." | ||||
| @@ -313,6 +424,12 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "フォルダーを作成" | ||||
|     upload: "ファイルをアップロード" | ||||
|     url-upload: "URLからアップロード" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| desktop/views/components/follow-button.vue: | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
| @@ -333,7 +450,7 @@ desktop/views/components/friends-maker.vue: | ||||
|   refresh: "もっと見る" | ||||
|   close: "閉じる" | ||||
| desktop/views/components/game-window.vue: | ||||
|   game: "オセロ" | ||||
|   game: "リバーシ" | ||||
| desktop/views/components/home.vue: | ||||
|   done: "完了" | ||||
|   add-widget: "ウィジェットを追加:" | ||||
| @@ -364,10 +481,14 @@ desktop/views/components/notes.note.vue: | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "読み込みに失敗しました。" | ||||
|   retry: "リトライ" | ||||
|   load-more: "もっと読み込む" | ||||
| desktop/views/components/notifications.vue: | ||||
|   more: "もっと見る" | ||||
|   empty: "ありません!" | ||||
| desktop/views/components/post-form.vue: | ||||
|   add-visible-user: "+ユーザーを追加" | ||||
|   attach-location-information: "位置情報を添付する" | ||||
|   hide-contents: "内容を隠す" | ||||
|   reply-placeholder: "この投稿への返信..." | ||||
|   quote-placeholder: "この投稿を引用..." | ||||
|   submit: "投稿" | ||||
| @@ -383,9 +504,15 @@ desktop/views/components/post-form.vue: | ||||
|   attach-media-from-local: "PCからメディアを添付" | ||||
|   attach-media-from-drive: "ドライブからメディアを添付" | ||||
|   attach-cancel: "添付取り消し" | ||||
|   insert-a-kao: "v(‘ω’)v" | ||||
|   insert-a-kao: "v('ω')v" | ||||
|   create-poll: "アンケートを作成" | ||||
|   text-remain: "残り{}文字" | ||||
|   recent-tags: "最近" | ||||
|   click-to-tagging: "クリックでタグ付け" | ||||
|   visibility: "公開範囲" | ||||
|   geolocation-alert: "お使いの端末は位置情報に対応していません" | ||||
|   error: "エラー" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
| desktop/views/components/post-form-window.vue: | ||||
|   note: "新規投稿" | ||||
|   reply: "返信" | ||||
| @@ -426,6 +553,8 @@ desktop/views/components/settings.vue: | ||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||
|   display: "デザインと表示" | ||||
|   customize: "ホームをカスタマイズ" | ||||
|   choose-wallpaper: "壁紙を選択" | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
| @@ -504,6 +633,9 @@ desktop/views/components/settings.api.vue: | ||||
|   enter-password: "パスワードを入力してください" | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "連携しているアプリケーションはありません" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "中" | ||||
|   in-use: "使用中" | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "ミュートしているユーザーはいません" | ||||
| desktop/views/components/settings.password.vue: | ||||
| @@ -521,8 +653,12 @@ desktop/views/components/settings.profile.vue: | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   profile-updated: "プロフィールを更新しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| @@ -533,15 +669,18 @@ desktop/views/components/taskmanager.vue: | ||||
| desktop/views/components/timeline.vue: | ||||
|   home: "ホーム" | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   list: "リスト" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "プロフィール" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
|   customize: "カスタマイズ" | ||||
|   customize: "ホームのカスタマイズ" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   dark: "闇に飲まれる" | ||||
| @@ -580,6 +719,7 @@ desktop/views/components/window.vue: | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "メディア投稿のみ" | ||||
|   is-media-view: "メディアビュー" | ||||
|   edit: "オプション" | ||||
| desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   private: "この投稿は非公開です" | ||||
| @@ -592,6 +732,7 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "やってる" | ||||
|   signup-button: "やる" | ||||
|   timeline: "タイムライン" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Misskey Drive" | ||||
| desktop/views/pages/favorites.vue: | ||||
| @@ -606,6 +747,14 @@ desktop/views/pages/selectdrive.vue: | ||||
|   ok: "決定" | ||||
|   cancel: "キャンセル" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "検索機能を利用することができません。" | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "Misskeyで共有" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| desktop/views/pages/user-list.users.vue: | ||||
|   users: "ユーザー" | ||||
|   add-user: "ユーザーを追加" | ||||
| @@ -618,7 +767,7 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   title: "よく話すユーザー" | ||||
|   loading: "読み込み中" | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
| @@ -636,6 +785,11 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "ミュートする" | ||||
|   muted: "ミュートしています" | ||||
|   unmute: "ミュート解除" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   is-bot: "このアカウントはBotです" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "投稿" | ||||
|   with-replies: "投稿と返信" | ||||
| @@ -692,6 +846,12 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   move: "移動" | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/follow-button.vue: | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
| @@ -750,6 +910,8 @@ mobile/views/components/sub-note-content.vue: | ||||
| mobile/views/components/timeline.vue: | ||||
|   empty: "投稿がありません" | ||||
|   load-more: "もっと" | ||||
| mobile/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
| mobile/views/components/ui.nav.vue: | ||||
|   timeline: "タイムライン" | ||||
|   notifications: "通知" | ||||
| @@ -780,6 +942,8 @@ mobile/views/pages/user-lists.vue: | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   more: "もっと見る" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "📦 始めましょう" | ||||
| mobile/views/pages/followers.vue: | ||||
|   followers-of: "{}のフォロワー" | ||||
| mobile/views/pages/following.vue: | ||||
| @@ -787,7 +951,16 @@ mobile/views/pages/following.vue: | ||||
| mobile/views/pages/home.vue: | ||||
|   home: "ホーム" | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| mobile/views/pages/welcome.vue: | ||||
|   signup: "新規登録" | ||||
| mobile/views/pages/widgets.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
| mobile/views/pages/widgets/activity.vue: | ||||
|   activity: "アクティビティ" | ||||
| mobile/views/pages/messaging.vue: | ||||
|   messaging: "メッセージ" | ||||
| mobile/views/pages/messaging-room.vue: | ||||
| @@ -803,6 +976,8 @@ mobile/views/pages/note.vue: | ||||
| mobile/views/pages/notifications.vue: | ||||
|   notifications: "通知" | ||||
|   read-all: "すべての通知を既読にしますか?" | ||||
| mobile/views/pages/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
| @@ -900,11 +1075,17 @@ docs: | ||||
|       properties: "プロパティ" | ||||
|     endpoints: | ||||
|       params: "パラメータ" | ||||
|       no-params: "パラメータはありません" | ||||
|       res: "レスポンス" | ||||
|       require-credential: "このエンドポイントは認証情報が必須です。" | ||||
|       require-permission: "このエンドポイントは{permission}の権限を必要とします。" | ||||
|       has-limit: "レートリミットがあります。" | ||||
|       duration-limit: "直近{duration}ミリ秒の間のこのエンドポイントへのリクエスト数の合計が{max}を超える場合はリクエストできません。" | ||||
|       min-interval-limit: "前回のリクエストから{interval}ミリ秒経っていない場合はリクエストできません。" | ||||
|       show-src: "このエンドポイントのソースコードも閲覧できます。" | ||||
|       show-src-link: "コードをGitHubで見る" | ||||
|       generated: "このドキュメントはAPI定義に基づき自動生成されています。" | ||||
|     props: | ||||
|       name: "名前" | ||||
|       type: "型" | ||||
|       optional: "オプション" | ||||
|       description: "説明" | ||||
|       yes: "はい" | ||||
|       no: "いいえ" | ||||
|   | ||||
							
								
								
									
										225
									
								
								locales/ja.yml
									
									
									
									
									
								
							
							
						
						| @@ -3,10 +3,17 @@ meta: | ||||
|   divider: "" | ||||
|  | ||||
| common: | ||||
|   misskey: "A planet of fediverse" | ||||
|   misskey: "A ⭐ of fediverse" | ||||
|   about-title: "A ⭐ of fediverse." | ||||
|   about: "Misskeyを見つけていただき、ありがとうございます。Misskeyは、地球で生まれた<b>分散マイクロブログSNS</b>です。Fediverse(様々なSNSで構成される宇宙)の中に存在するため、他のSNSと相互に繋がっています。暫し都会の喧騒から離れて、新しいインターネットにダイブしてみませんか。" | ||||
|  | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
|     paragraph1: "ホームのカスタマイズでは、ウィジェットを追加/削除したり、ドラッグ&ドロップして並べ替えたりすることができます。" | ||||
|     paragraph2: "一部のウィジェットは、<strong><strong>右</strong>クリック</strong>することで表示を変更することができます。" | ||||
|     paragraph3: "ウィジェットを削除するには、ヘッダーの<strong>「ゴミ箱」</strong>と書かれたエリアにウィジェットをドラッグ&ドロップします。" | ||||
|     paragraph4: "カスタマイズを終了するには、右上の「完了」をクリックします。" | ||||
|     gotit: "Got it!" | ||||
|   name: "Misskey" | ||||
|   time: | ||||
|     unknown: "なぞのじかん" | ||||
|     future: "未来" | ||||
| @@ -19,6 +26,8 @@ common: | ||||
|     months_ago: "{}ヶ月前" | ||||
|     years_ago: "{}年前" | ||||
|  | ||||
|   trash: "ゴミ箱" | ||||
|  | ||||
|   weekday-short: | ||||
|     sunday: "日" | ||||
|     monday: "月" | ||||
| @@ -28,6 +37,15 @@ common: | ||||
|     friday: "金" | ||||
|     saturday: "土" | ||||
|  | ||||
|   weekday: | ||||
|     sunday: "日曜日" | ||||
|     monday: "月曜日" | ||||
|     tuesday: "火曜日" | ||||
|     wednesday: "水曜日" | ||||
|     thursday: "木曜日" | ||||
|     friday: "金曜日" | ||||
|     saturday: "土曜日" | ||||
|  | ||||
|   reactions: | ||||
|     like: "いいね" | ||||
|     love: "しゅき" | ||||
| @@ -47,11 +65,28 @@ common: | ||||
|     e: "ここに書いてください" | ||||
|     f: "あなたが書くのを待っています..." | ||||
|  | ||||
|   search: "検索" | ||||
|   delete: "削除" | ||||
|   loading: "読み込み中" | ||||
|   ok: "わかった" | ||||
|   update-available-title: "更新があります" | ||||
|   update-available: "Misskeyの新しいバージョンがあります({newer}。現在{current}を利用中)。ページを再度読み込みすると更新が適用されます。" | ||||
|   my-token-regenerated: "あなたのトークンが更新されたのでサインアウトします。" | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   verified-user: "認証済みのユーザー" | ||||
|  | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
|     opponent-turn: "相手のターンです" | ||||
|     turn-of: "{}のターンです" | ||||
|     past-turn-of: "{}のターン" | ||||
|     won: "{}の勝ち" | ||||
|     black: "黒" | ||||
|     white: "白" | ||||
|     total: "合計" | ||||
|     this-turn: "{}ターン目" | ||||
|  | ||||
|   widgets: | ||||
|     analog-clock: "アナログ時計" | ||||
| @@ -82,6 +117,7 @@ common: | ||||
|     widgets: "ウィジェット" | ||||
|     home: "ホーム" | ||||
|     local: "ローカル" | ||||
|     hybrid: "ソーシャル" | ||||
|     global: "グローバル" | ||||
|     notifications: "通知" | ||||
|     list: "リスト" | ||||
| @@ -95,6 +131,44 @@ common: | ||||
|     stack-left: "左に重ねる" | ||||
|     pop-right: "右に出す" | ||||
|  | ||||
| common/views/components/games/reversi/reversi.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "他のMisskeyユーザーとリバーシで対戦しよう" | ||||
|   invite: "招待" | ||||
|   rule: "遊び方" | ||||
|   rule-desc: "リバーシは、相手と交互に石をボードに置いて、相手の石を挟んで自分の色に変えてゆき、最終的に残った石が多い方が勝ちというボードゲームです。" | ||||
|   mode-invite: "招待" | ||||
|   mode-invite-desc: "指定したユーザーと対戦するモードです。" | ||||
|   invitations: "対局の招待があります!" | ||||
|   my-games: "自分の対局" | ||||
|   all-games: "みんなの対局" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
|   game-state: | ||||
|     ended: "終了" | ||||
|     playing: "進行中" | ||||
|   matching: | ||||
|     waiting-for: "{}を待っています" | ||||
|     cacnel: "キャンセル" | ||||
|  | ||||
| common/views/components/games/reversi/reversi.room.vue: | ||||
|   settings-of-the-game: "ゲームの設定" | ||||
|   choose-map: "マップを選択" | ||||
|   random: "ランダム" | ||||
|   black-or-white: "先手/後手" | ||||
|   black-is: "{}が黒" | ||||
|   rules: "ルール" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
|   settings-of-the-bot: "Botの設定" | ||||
|   this-gane-is-started-soon: "ゲームは数秒後に開始されます" | ||||
|   waiting-for-other: "相手の準備が完了するのを待っています" | ||||
|   waiting-for-me: "あなたの準備が完了するのを待っています" | ||||
|   waiting-for-both: "準備中" | ||||
|   cancel: "キャンセル" | ||||
|   ready: "準備完了" | ||||
|   cancel-ready: "準備続行" | ||||
|  | ||||
| common/views/components/connect-failed.vue: | ||||
|   title: "サーバーに接続できません" | ||||
|   description: "インターネット回線に問題があるか、サーバーがダウンまたはメンテナンスしている可能性があります。しばらくしてから{再度お試し}ください。" | ||||
| @@ -243,6 +317,14 @@ common/views/widgets/broadcast.vue: | ||||
|   have-a-nice-day: "良い一日を!" | ||||
|   next: "次" | ||||
|  | ||||
| common/views/widgets/calendar.vue: | ||||
|   year: "{}年" | ||||
|   month: "{}月" | ||||
|   day: "{}日" | ||||
|   today: "今日:" | ||||
|   this-month: "今月:" | ||||
|   this-year: "今年:" | ||||
|  | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "寄付のお願い" | ||||
|   text: "Misskeyの運営にはドメイン、サーバー等のコストが掛かります。Misskeyは広告を掲載したりしないため、収入を皆様からの寄付に頼っています。もしご興味があれば、{}までご連絡ください。ご協力ありがとうございます。" | ||||
| @@ -269,6 +351,40 @@ common/views/widgets/memo.vue: | ||||
|   memo: "ここに書いて!" | ||||
|   save: "保存" | ||||
|  | ||||
| common/views/widgets/slideshow.vue: | ||||
|   folder-customize-mode: "フォルダを指定するには、カスタマイズモードを終了してください" | ||||
|   folder: "クリックしてフォルダを指定してください" | ||||
|   no-image: "このフォルダには画像がありません" | ||||
|  | ||||
| common/views/widgets/tips.vue: | ||||
|   tips-line1: "<kbd>t</kbd>でタイムラインにフォーカスできます" | ||||
|   tips-line2: "<kbd>p</kbd>または<kbd>n</kbd>で投稿フォームを開きます" | ||||
|   tips-line3: "投稿フォームにはファイルをドラッグ&ドロップできます" | ||||
|   tips-line4: "投稿フォームにクリップボードにある画像データをペーストできます" | ||||
|   tips-line5: "ドライブにファイルをドラッグ&ドロップしてアップロードできます" | ||||
|   tips-line6: "ドライブでファイルをドラッグしてフォルダ移動できます" | ||||
|   tips-line7: "ドライブでフォルダをドラッグしてフォルダ移動できます" | ||||
|   tips-line8: "ホームは設定からカスタマイズできます" | ||||
|   tips-line9: "MisskeyはAGPLv3です" | ||||
|   tips-line10: "タイムマシンウィジェットを利用すると、簡単に過去のタイムラインに遡れます" | ||||
|   tips-line11: "投稿の ... をクリックして、投稿をユーザーページにピン留めできます" | ||||
|   tips-line13: "投稿に添付したファイルは全てドライブに保存されます" | ||||
|   tips-line14: "ホームのカスタマイズ中、ウィジェットを右クリックしてデザインを変更できます" | ||||
|   tips-line17: "「**」でテキストを囲むと**強調表示**されます" | ||||
|   tips-line19: "いくつかのウィンドウはブラウザの外に切り離すことができます" | ||||
|   tips-line20: "カレンダーウィジェットのパーセンテージは、経過の割合を示しています" | ||||
|   tips-line21: "APIを利用してbotの開発なども行えます" | ||||
|   tips-line23: "まゆかわいいよまゆ" | ||||
|   tips-line24: "Misskeyは2014年にサービスを開始しました" | ||||
|   tips-line25: "対応ブラウザではMisskeyを開いていなくても通知を受け取れます" | ||||
|  | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
|   request-pending: "フォロー許可待ち" | ||||
|   follow-request: "フォロー申請" | ||||
|  | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Black ... Total" | ||||
|   notes: "Blue ... Notes" | ||||
| @@ -311,6 +427,8 @@ desktop/views/components/drive.file.vue: | ||||
|   banner: "バナー" | ||||
|   contextmenu: | ||||
|     rename: "名前を変更" | ||||
|     mark-as-sensitive: "閲覧注意に設定" | ||||
|     unmark-as-sensitive: "閲覧注意を解除" | ||||
|     copy-url: "URLをコピー" | ||||
|     download: "ダウンロード" | ||||
|     else-files: "その他..." | ||||
| @@ -358,6 +476,14 @@ desktop/views/components/drive.vue: | ||||
|     upload: "ファイルをアップロード" | ||||
|     url-upload: "URLからアップロード" | ||||
|  | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
|  | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
|  | ||||
| desktop/views/components/follow-button.vue: | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
| @@ -384,7 +510,7 @@ desktop/views/components/friends-maker.vue: | ||||
|   close: "閉じる" | ||||
|  | ||||
| desktop/views/components/game-window.vue: | ||||
|   game: "オセロ" | ||||
|   game: "リバーシ" | ||||
|  | ||||
| desktop/views/components/home.vue: | ||||
|   done: "完了" | ||||
| @@ -422,12 +548,16 @@ desktop/views/components/notes.note.vue: | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "読み込みに失敗しました。" | ||||
|   retry: "リトライ" | ||||
|   load-more: "もっと読み込む" | ||||
|  | ||||
| desktop/views/components/notifications.vue: | ||||
|   more: "もっと見る" | ||||
|   empty: "ありません!" | ||||
|  | ||||
| desktop/views/components/post-form.vue: | ||||
|   add-visible-user: "+ユーザーを追加" | ||||
|   attach-location-information: "位置情報を添付する" | ||||
|   hide-contents: "内容を隠す" | ||||
|   reply-placeholder: "この投稿への返信..." | ||||
|   quote-placeholder: "この投稿を引用..." | ||||
|   submit: "投稿" | ||||
| @@ -443,9 +573,15 @@ desktop/views/components/post-form.vue: | ||||
|   attach-media-from-local: "PCからメディアを添付" | ||||
|   attach-media-from-drive: "ドライブからメディアを添付" | ||||
|   attach-cancel: "添付取り消し" | ||||
|   insert-a-kao: "v(‘ω’)v" | ||||
|   insert-a-kao: "v('ω')v" | ||||
|   create-poll: "アンケートを作成" | ||||
|   text-remain: "残り{}文字" | ||||
|   recent-tags: "最近" | ||||
|   click-to-tagging: "クリックでタグ付け" | ||||
|   visibility: "公開範囲" | ||||
|   geolocation-alert: "お使いの端末は位置情報に対応していません" | ||||
|   error: "エラー" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
|  | ||||
| desktop/views/components/post-form-window.vue: | ||||
|   note: "新規投稿" | ||||
| @@ -494,6 +630,8 @@ desktop/views/components/settings.vue: | ||||
|  | ||||
|   display: "デザインと表示" | ||||
|   customize: "ホームをカスタマイズ" | ||||
|   choose-wallpaper: "壁紙を選択" | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
| @@ -584,6 +722,10 @@ desktop/views/components/settings.api.vue: | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "連携しているアプリケーションはありません" | ||||
|  | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "中" | ||||
|   in-use: "使用中" | ||||
|  | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "ミュートしているユーザーはいません" | ||||
|  | ||||
| @@ -603,8 +745,12 @@ desktop/views/components/settings.profile.vue: | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   profile-updated: "プロフィールを更新しました" | ||||
|  | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
| @@ -618,16 +764,20 @@ desktop/views/components/taskmanager.vue: | ||||
| desktop/views/components/timeline.vue: | ||||
|   home: "ホーム" | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   list: "リスト" | ||||
|  | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
|  | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "プロフィール" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
|   customize: "カスタマイズ" | ||||
|   customize: "ホームのカスタマイズ" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   dark: "闇に飲まれる" | ||||
| @@ -652,6 +802,8 @@ desktop/views/components/received-follow-requests-window.vue: | ||||
|   accept: "承認" | ||||
|   reject: "拒否" | ||||
|  | ||||
|  | ||||
|  | ||||
| desktop/views/components/user-lists-window.vue: | ||||
|   title: "リスト" | ||||
|   create-list: "リストを作成" | ||||
| @@ -677,6 +829,7 @@ desktop/views/components/window.vue: | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "メディア投稿のみ" | ||||
|   is-media-view: "メディアビュー" | ||||
|   edit: "オプション" | ||||
|  | ||||
| desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
| @@ -691,6 +844,7 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "やってる" | ||||
|   signup-button: "やる" | ||||
|   timeline: "タイムライン" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
|  | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Misskey Drive" | ||||
| @@ -711,6 +865,17 @@ desktop/views/pages/selectdrive.vue: | ||||
|   cancel: "キャンセル" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
|  | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "検索機能を利用することができません。" | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
|  | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "Misskeyで共有" | ||||
|   close: "閉じる" | ||||
|  | ||||
| desktop/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
|  | ||||
| desktop/views/pages/user-list.users.vue: | ||||
|   users: "ユーザー" | ||||
|   add-user: "ユーザーを追加" | ||||
| @@ -726,7 +891,7 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   loading: "読み込み中" | ||||
|   no-users: "よく話すユーザーはいません" | ||||
|  | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
| @@ -748,6 +913,12 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   muted: "ミュートしています" | ||||
|   unmute: "ミュート解除" | ||||
|  | ||||
| desktop/views/pages/user/user.header.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|  | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "投稿" | ||||
|   with-replies: "投稿と返信" | ||||
| @@ -817,6 +988,14 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
|  | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
|  | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
|  | ||||
| mobile/views/components/follow-button.vue: | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
| @@ -886,6 +1065,9 @@ mobile/views/components/timeline.vue: | ||||
|   empty: "投稿がありません" | ||||
|   load-more: "もっと" | ||||
|  | ||||
| mobile/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
|  | ||||
| mobile/views/components/ui.nav.vue: | ||||
|   timeline: "タイムライン" | ||||
|   notifications: "通知" | ||||
| @@ -922,6 +1104,9 @@ mobile/views/pages/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   more: "もっと見る" | ||||
|  | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "📦 始めましょう" | ||||
|  | ||||
| mobile/views/pages/followers.vue: | ||||
|   followers-of: "{}のフォロワー" | ||||
|  | ||||
| @@ -931,8 +1116,21 @@ mobile/views/pages/following.vue: | ||||
| mobile/views/pages/home.vue: | ||||
|   home: "ホーム" | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|  | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
|  | ||||
| mobile/views/pages/welcome.vue: | ||||
|   signup: "新規登録" | ||||
|  | ||||
| mobile/views/pages/widgets.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|  | ||||
| mobile/views/pages/widgets/activity.vue: | ||||
|   activity: "アクティビティ" | ||||
|  | ||||
| mobile/views/pages/messaging.vue: | ||||
|   messaging: "メッセージ" | ||||
|  | ||||
| @@ -953,6 +1151,9 @@ mobile/views/pages/notifications.vue: | ||||
|   notifications: "通知" | ||||
|   read-all: "すべての通知を既読にしますか?" | ||||
|  | ||||
| mobile/views/pages/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
|  | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
| @@ -1061,11 +1262,17 @@ docs: | ||||
|       properties: "プロパティ" | ||||
|     endpoints: | ||||
|       params: "パラメータ" | ||||
|       no-params: "パラメータはありません" | ||||
|       res: "レスポンス" | ||||
|       require-credential: "このエンドポイントは認証情報が必須です。" | ||||
|       require-permission: "このエンドポイントは{permission}の権限を必要とします。" | ||||
|       has-limit: "レートリミットがあります。" | ||||
|       duration-limit: "直近{duration}ミリ秒の間のこのエンドポイントへのリクエスト数の合計が{max}を超える場合はリクエストできません。" | ||||
|       min-interval-limit: "前回のリクエストから{interval}ミリ秒経っていない場合はリクエストできません。" | ||||
|       show-src: "このエンドポイントのソースコードも閲覧できます。" | ||||
|       show-src-link: "コードをGitHubで見る" | ||||
|       generated: "このドキュメントはAPI定義に基づき自動生成されています。" | ||||
|     props: | ||||
|       name: "名前" | ||||
|       type: "型" | ||||
|       optional: "オプション" | ||||
|       description: "説明" | ||||
|       yes: "はい" | ||||
|       no: "いいえ" | ||||
|   | ||||
							
								
								
									
										197
									
								
								locales/ko.yml
									
									
									
									
									
								
							
							
						
						| @@ -3,9 +3,17 @@ meta: | ||||
|   lang: "日本語" | ||||
|   divider: "" | ||||
| common: | ||||
|   misskey: "A planet of fediverse" | ||||
|   misskey: "A ⭐ of fediverse" | ||||
|   about-title: "A ⭐ of fediverse." | ||||
|   about: "Misskeyを見つけていただき、ありがとうございます。Misskeyは、地球で生まれた<b>分散マイクロブログSNS</b>です。Fediverse(様々なSNSで構成される宇宙)の中に存在するため、他のSNSと相互に繋がっています。暫し都会の喧騒から離れて、新しいインターネットにダイブしてみませんか。" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
|     paragraph1: "ホームのカスタマイズでは、ウィジェットを追加/削除したり、ドラッグ&ドロップして並べ替えたりすることができます。" | ||||
|     paragraph2: "一部のウィジェットは、<strong><strong>右</strong>クリック</strong>することで表示を変更することができます。" | ||||
|     paragraph3: "ウィジェットを削除するには、ヘッダーの<strong>「ゴミ箱」</strong>と書かれたエリアにウィジェットをドラッグ&ドロップします。" | ||||
|     paragraph4: "カスタマイズを終了するには、右上の「完了」をクリックします。" | ||||
|     gotit: "Got it!" | ||||
|   name: "Misskey" | ||||
|   time: | ||||
|     unknown: "なぞのじかん" | ||||
|     future: "未来" | ||||
| @@ -17,6 +25,7 @@ common: | ||||
|     weeks_ago: "{}週間前" | ||||
|     months_ago: "{}ヶ月前" | ||||
|     years_ago: "{}年前" | ||||
|   trash: "ゴミ箱" | ||||
|   weekday-short: | ||||
|     sunday: "日" | ||||
|     monday: "月" | ||||
| @@ -25,6 +34,14 @@ common: | ||||
|     thursday: "木" | ||||
|     friday: "金" | ||||
|     saturday: "土" | ||||
|   weekday: | ||||
|     sunday: "日曜日" | ||||
|     monday: "月曜日" | ||||
|     tuesday: "火曜日" | ||||
|     wednesday: "水曜日" | ||||
|     thursday: "木曜日" | ||||
|     friday: "金曜日" | ||||
|     saturday: "土曜日" | ||||
|   reactions: | ||||
|     like: "いいね" | ||||
|     love: "しゅき" | ||||
| @@ -42,11 +59,27 @@ common: | ||||
|     d: "言いたいことは?" | ||||
|     e: "ここに書いてください" | ||||
|     f: "あなたが書くのを待っています..." | ||||
|   search: "検索" | ||||
|   delete: "削除" | ||||
|   loading: "読み込み中" | ||||
|   ok: "わかった" | ||||
|   update-available-title: "更新があります" | ||||
|   update-available: "Misskeyの新しいバージョンがあります({newer}。現在{current}を利用中)。ページを再度読み込みすると更新が適用されます。" | ||||
|   my-token-regenerated: "あなたのトークンが更新されたのでサインアウトします。" | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   verified-user: "認証済みのユーザー" | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
|     opponent-turn: "相手のターンです" | ||||
|     turn-of: "{}のターンです" | ||||
|     past-turn-of: "{}のターン" | ||||
|     won: "{}の勝ち" | ||||
|     black: "黒" | ||||
|     white: "白" | ||||
|     total: "合計" | ||||
|     this-turn: "{}ターン目" | ||||
|   widgets: | ||||
|     analog-clock: "アナログ時計" | ||||
|     profile: "プロフィール" | ||||
| @@ -75,6 +108,7 @@ common: | ||||
|     widgets: "ウィジェット" | ||||
|     home: "ホーム" | ||||
|     local: "ローカル" | ||||
|     hybrid: "ソーシャル" | ||||
|     global: "グローバル" | ||||
|     notifications: "通知" | ||||
|     list: "リスト" | ||||
| @@ -87,6 +121,42 @@ common: | ||||
|     rename: "名前を変更" | ||||
|     stack-left: "左に重ねる" | ||||
|     pop-right: "右に出す" | ||||
| common/views/components/games/reversi/reversi.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "他のMisskeyユーザーとリバーシで対戦しよう" | ||||
|   invite: "招待" | ||||
|   rule: "遊び方" | ||||
|   rule-desc: "リバーシは、相手と交互に石をボードに置いて、相手の石を挟んで自分の色に変えてゆき、最終的に残った石が多い方が勝ちというボードゲームです。" | ||||
|   mode-invite: "招待" | ||||
|   mode-invite-desc: "指定したユーザーと対戦するモードです。" | ||||
|   invitations: "対局の招待があります!" | ||||
|   my-games: "自分の対局" | ||||
|   all-games: "みんなの対局" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
|   game-state: | ||||
|     ended: "終了" | ||||
|     playing: "進行中" | ||||
|   matching: | ||||
|     waiting-for: "{}を待っています" | ||||
|     cacnel: "キャンセル" | ||||
| common/views/components/games/reversi/reversi.room.vue: | ||||
|   settings-of-the-game: "ゲームの設定" | ||||
|   choose-map: "マップを選択" | ||||
|   random: "ランダム" | ||||
|   black-or-white: "先手/後手" | ||||
|   black-is: "{}が黒" | ||||
|   rules: "ルール" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
|   settings-of-the-bot: "Botの設定" | ||||
|   this-gane-is-started-soon: "ゲームは数秒後に開始されます" | ||||
|   waiting-for-other: "相手の準備が完了するのを待っています" | ||||
|   waiting-for-me: "あなたの準備が完了するのを待っています" | ||||
|   waiting-for-both: "準備中" | ||||
|   cancel: "キャンセル" | ||||
|   ready: "準備完了" | ||||
|   cancel-ready: "準備続行" | ||||
| common/views/components/connect-failed.vue: | ||||
|   title: "サーバーに接続できません" | ||||
|   description: "インターネット回線に問題があるか、サーバーがダウンまたはメンテナンスしている可能性があります。しばらくしてから{再度お試し}ください。" | ||||
| @@ -216,6 +286,13 @@ common/views/widgets/broadcast.vue: | ||||
|   no-broadcasts: "お知らせはありません" | ||||
|   have-a-nice-day: "良い一日を!" | ||||
|   next: "次" | ||||
| common/views/widgets/calendar.vue: | ||||
|   year: "{}年" | ||||
|   month: "{}月" | ||||
|   day: "{}日" | ||||
|   today: "今日:" | ||||
|   this-month: "今月:" | ||||
|   this-year: "今年:" | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "寄付のお願い" | ||||
|   text: "Misskeyの運営にはドメイン、サーバー等のコストが掛かります。Misskeyは広告を掲載したりしないため、収入を皆様からの寄付に頼っています。もしご興味があれば、{}までご連絡ください。ご協力ありがとうございます。" | ||||
| @@ -228,6 +305,7 @@ common/views/widgets/posts-monitor.vue: | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "ハッシュタグ" | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "サーバー情報" | ||||
|   toggle: "表示を切り替え" | ||||
| @@ -235,6 +313,37 @@ common/views/widgets/memo.vue: | ||||
|   title: "付箋" | ||||
|   memo: "ここに書いて!" | ||||
|   save: "保存" | ||||
| common/views/widgets/slideshow.vue: | ||||
|   folder-customize-mode: "フォルダを指定するには、カスタマイズモードを終了してください" | ||||
|   folder: "クリックしてフォルダを指定してください" | ||||
|   no-image: "このフォルダには画像がありません" | ||||
| common/views/widgets/tips.vue: | ||||
|   tips-line1: "<kbd>t</kbd>でタイムラインにフォーカスできます" | ||||
|   tips-line2: "<kbd>p</kbd>または<kbd>n</kbd>で投稿フォームを開きます" | ||||
|   tips-line3: "投稿フォームにはファイルをドラッグ&ドロップできます" | ||||
|   tips-line4: "投稿フォームにクリップボードにある画像データをペーストできます" | ||||
|   tips-line5: "ドライブにファイルをドラッグ&ドロップしてアップロードできます" | ||||
|   tips-line6: "ドライブでファイルをドラッグしてフォルダ移動できます" | ||||
|   tips-line7: "ドライブでフォルダをドラッグしてフォルダ移動できます" | ||||
|   tips-line8: "ホームは設定からカスタマイズできます" | ||||
|   tips-line9: "MisskeyはAGPLv3です" | ||||
|   tips-line10: "タイムマシンウィジェットを利用すると、簡単に過去のタイムラインに遡れます" | ||||
|   tips-line11: "投稿の ... をクリックして、投稿をユーザーページにピン留めできます" | ||||
|   tips-line13: "投稿に添付したファイルは全てドライブに保存されます" | ||||
|   tips-line14: "ホームのカスタマイズ中、ウィジェットを右クリックしてデザインを変更できます" | ||||
|   tips-line17: "「**」でテキストを囲むと**強調表示**されます" | ||||
|   tips-line19: "いくつかのウィンドウはブラウザの外に切り離すことができます" | ||||
|   tips-line20: "カレンダーウィジェットのパーセンテージは、経過の割合を示しています" | ||||
|   tips-line21: "APIを利用してbotの開発なども行えます" | ||||
|   tips-line23: "まゆかわいいよまゆ" | ||||
|   tips-line24: "Misskeyは2014年にサービスを開始しました" | ||||
|   tips-line25: "対応ブラウザではMisskeyを開いていなくても通知を受け取れます" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
|   request-pending: "フォロー許可待ち" | ||||
|   follow-request: "フォロー申請" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Black ... Total" | ||||
|   notes: "Blue ... Notes" | ||||
| @@ -270,6 +379,8 @@ desktop/views/components/drive.file.vue: | ||||
|   banner: "バナー" | ||||
|   contextmenu: | ||||
|     rename: "名前を変更" | ||||
|     mark-as-sensitive: "閲覧注意に設定" | ||||
|     unmark-as-sensitive: "閲覧注意を解除" | ||||
|     copy-url: "URLをコピー" | ||||
|     download: "ダウンロード" | ||||
|     else-files: "その他..." | ||||
| @@ -313,6 +424,12 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "フォルダーを作成" | ||||
|     upload: "ファイルをアップロード" | ||||
|     url-upload: "URLからアップロード" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| desktop/views/components/follow-button.vue: | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
| @@ -333,7 +450,7 @@ desktop/views/components/friends-maker.vue: | ||||
|   refresh: "もっと見る" | ||||
|   close: "閉じる" | ||||
| desktop/views/components/game-window.vue: | ||||
|   game: "オセロ" | ||||
|   game: "リバーシ" | ||||
| desktop/views/components/home.vue: | ||||
|   done: "完了" | ||||
|   add-widget: "ウィジェットを追加:" | ||||
| @@ -364,10 +481,14 @@ desktop/views/components/notes.note.vue: | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "読み込みに失敗しました。" | ||||
|   retry: "リトライ" | ||||
|   load-more: "もっと読み込む" | ||||
| desktop/views/components/notifications.vue: | ||||
|   more: "もっと見る" | ||||
|   empty: "ありません!" | ||||
| desktop/views/components/post-form.vue: | ||||
|   add-visible-user: "+ユーザーを追加" | ||||
|   attach-location-information: "位置情報を添付する" | ||||
|   hide-contents: "内容を隠す" | ||||
|   reply-placeholder: "この投稿への返信..." | ||||
|   quote-placeholder: "この投稿を引用..." | ||||
|   submit: "投稿" | ||||
| @@ -383,9 +504,15 @@ desktop/views/components/post-form.vue: | ||||
|   attach-media-from-local: "PCからメディアを添付" | ||||
|   attach-media-from-drive: "ドライブからメディアを添付" | ||||
|   attach-cancel: "添付取り消し" | ||||
|   insert-a-kao: "v(‘ω’)v" | ||||
|   insert-a-kao: "v('ω')v" | ||||
|   create-poll: "アンケートを作成" | ||||
|   text-remain: "残り{}文字" | ||||
|   recent-tags: "最近" | ||||
|   click-to-tagging: "クリックでタグ付け" | ||||
|   visibility: "公開範囲" | ||||
|   geolocation-alert: "お使いの端末は位置情報に対応していません" | ||||
|   error: "エラー" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
| desktop/views/components/post-form-window.vue: | ||||
|   note: "新規投稿" | ||||
|   reply: "返信" | ||||
| @@ -426,6 +553,8 @@ desktop/views/components/settings.vue: | ||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||
|   display: "デザインと表示" | ||||
|   customize: "ホームをカスタマイズ" | ||||
|   choose-wallpaper: "壁紙を選択" | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
| @@ -504,6 +633,9 @@ desktop/views/components/settings.api.vue: | ||||
|   enter-password: "パスワードを入力してください" | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "連携しているアプリケーションはありません" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "中" | ||||
|   in-use: "使用中" | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "ミュートしているユーザーはいません" | ||||
| desktop/views/components/settings.password.vue: | ||||
| @@ -521,8 +653,12 @@ desktop/views/components/settings.profile.vue: | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   profile-updated: "プロフィールを更新しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| @@ -533,15 +669,18 @@ desktop/views/components/taskmanager.vue: | ||||
| desktop/views/components/timeline.vue: | ||||
|   home: "ホーム" | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   list: "リスト" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "プロフィール" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
|   customize: "カスタマイズ" | ||||
|   customize: "ホームのカスタマイズ" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   dark: "闇に飲まれる" | ||||
| @@ -580,6 +719,7 @@ desktop/views/components/window.vue: | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "メディア投稿のみ" | ||||
|   is-media-view: "メディアビュー" | ||||
|   edit: "オプション" | ||||
| desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   private: "この投稿は非公開です" | ||||
| @@ -592,6 +732,7 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "やってる" | ||||
|   signup-button: "やる" | ||||
|   timeline: "タイムライン" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Misskey Drive" | ||||
| desktop/views/pages/favorites.vue: | ||||
| @@ -606,6 +747,14 @@ desktop/views/pages/selectdrive.vue: | ||||
|   ok: "決定" | ||||
|   cancel: "キャンセル" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "検索機能を利用することができません。" | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "Misskeyで共有" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| desktop/views/pages/user-list.users.vue: | ||||
|   users: "ユーザー" | ||||
|   add-user: "ユーザーを追加" | ||||
| @@ -618,7 +767,7 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   title: "よく話すユーザー" | ||||
|   loading: "読み込み中" | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
| @@ -636,6 +785,11 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "ミュートする" | ||||
|   muted: "ミュートしています" | ||||
|   unmute: "ミュート解除" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   is-bot: "このアカウントはBotです" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "投稿" | ||||
|   with-replies: "投稿と返信" | ||||
| @@ -692,6 +846,12 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   move: "移動" | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/follow-button.vue: | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
| @@ -750,6 +910,8 @@ mobile/views/components/sub-note-content.vue: | ||||
| mobile/views/components/timeline.vue: | ||||
|   empty: "投稿がありません" | ||||
|   load-more: "もっと" | ||||
| mobile/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
| mobile/views/components/ui.nav.vue: | ||||
|   timeline: "タイムライン" | ||||
|   notifications: "通知" | ||||
| @@ -780,6 +942,8 @@ mobile/views/pages/user-lists.vue: | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   more: "もっと見る" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "📦 始めましょう" | ||||
| mobile/views/pages/followers.vue: | ||||
|   followers-of: "{}のフォロワー" | ||||
| mobile/views/pages/following.vue: | ||||
| @@ -787,7 +951,16 @@ mobile/views/pages/following.vue: | ||||
| mobile/views/pages/home.vue: | ||||
|   home: "ホーム" | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| mobile/views/pages/welcome.vue: | ||||
|   signup: "新規登録" | ||||
| mobile/views/pages/widgets.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
| mobile/views/pages/widgets/activity.vue: | ||||
|   activity: "アクティビティ" | ||||
| mobile/views/pages/messaging.vue: | ||||
|   messaging: "メッセージ" | ||||
| mobile/views/pages/messaging-room.vue: | ||||
| @@ -803,6 +976,8 @@ mobile/views/pages/note.vue: | ||||
| mobile/views/pages/notifications.vue: | ||||
|   notifications: "通知" | ||||
|   read-all: "すべての通知を既読にしますか?" | ||||
| mobile/views/pages/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
| @@ -900,11 +1075,17 @@ docs: | ||||
|       properties: "プロパティ" | ||||
|     endpoints: | ||||
|       params: "パラメータ" | ||||
|       no-params: "パラメータはありません" | ||||
|       res: "レスポンス" | ||||
|       require-credential: "このエンドポイントは認証情報が必須です。" | ||||
|       require-permission: "このエンドポイントは{permission}の権限を必要とします。" | ||||
|       has-limit: "レートリミットがあります。" | ||||
|       duration-limit: "直近{duration}ミリ秒の間のこのエンドポイントへのリクエスト数の合計が{max}を超える場合はリクエストできません。" | ||||
|       min-interval-limit: "前回のリクエストから{interval}ミリ秒経っていない場合はリクエストできません。" | ||||
|       show-src: "このエンドポイントのソースコードも閲覧できます。" | ||||
|       show-src-link: "コードをGitHubで見る" | ||||
|       generated: "このドキュメントはAPI定義に基づき自動生成されています。" | ||||
|     props: | ||||
|       name: "名前" | ||||
|       type: "型" | ||||
|       optional: "オプション" | ||||
|       description: "説明" | ||||
|       yes: "はい" | ||||
|       no: "いいえ" | ||||
|   | ||||
							
								
								
									
										201
									
								
								locales/pl.yml
									
									
									
									
									
								
							
							
						
						| @@ -3,9 +3,17 @@ meta: | ||||
|   lang: "język polski" | ||||
|   divider: "" | ||||
| common: | ||||
|   misskey: "Planeta Fediwersum" | ||||
|   misskey: "⭐ Fediwersum" | ||||
|   about-title: "⭐ Fediwersum" | ||||
|   about: "Dziękujemy za znalezienie Misskey. Misskey jest <b>zdecentralizowaną platformą mikroblogową</b> powstałą na Ziemi. Ponieważ działa ona w Fediwersum (uniwersum, w którego skład wchodzi wiele sieci społecznościowych), jest ona połączona z innymi platformami społecznościowymi. Spróbujesz odpocząć od zatłoczoneo miasta i zanurzyć się w nowym Internecie?" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
|     paragraph1: "ホームのカスタマイズでは、ウィジェットを追加/削除したり、ドラッグ&ドロップして並べ替えたりすることができます。" | ||||
|     paragraph2: "一部のウィジェットは、<strong><strong>右</strong>クリック</strong>することで表示を変更することができます。" | ||||
|     paragraph3: "ウィジェットを削除するには、ヘッダーの<strong>「ゴミ箱」</strong>と書かれたエリアにウィジェットをドラッグ&ドロップします。" | ||||
|     paragraph4: "カスタマイズを終了するには、右上の「完了」をクリックします。" | ||||
|     gotit: "Got it!" | ||||
|   name: "Misskey" | ||||
|   time: | ||||
|     unknown: "nieznany" | ||||
|     future: "w przyszłości" | ||||
| @@ -17,6 +25,7 @@ common: | ||||
|     weeks_ago: "{} tyg. temu" | ||||
|     months_ago: "{} mies. temu" | ||||
|     years_ago: "{} lat temu" | ||||
|   trash: "ゴミ箱" | ||||
|   weekday-short: | ||||
|     sunday: "N" | ||||
|     monday: "Pn" | ||||
| @@ -25,6 +34,14 @@ common: | ||||
|     thursday: "C" | ||||
|     friday: "P" | ||||
|     saturday: "S" | ||||
|   weekday: | ||||
|     sunday: "日曜日" | ||||
|     monday: "月曜日" | ||||
|     tuesday: "火曜日" | ||||
|     wednesday: "水曜日" | ||||
|     thursday: "木曜日" | ||||
|     friday: "金曜日" | ||||
|     saturday: "土曜日" | ||||
|   reactions: | ||||
|     like: "Lubię" | ||||
|     love: "Kocham" | ||||
| @@ -42,11 +59,27 @@ common: | ||||
|     d: "Czy masz coś do powiedzenia?" | ||||
|     e: "Napisz coś tutaj!" | ||||
|     f: "Czekamy, aż coś napiszesz." | ||||
|   search: "Szukaj" | ||||
|   delete: "Usuń" | ||||
|   loading: "Ładowanie" | ||||
|   ok: "OK" | ||||
|   update-available-title: "Aktualizacja jest dostępna" | ||||
|   update-available: "Nowa wersja Misskey jest dostępna ({newer}, obecna to {current}). Odśwież stronę, aby zastosować aktualizację." | ||||
|   my-token-regenerated: "Twój token został wygenerowany. Zostaniesz wylogowany." | ||||
|   i-like-sushi: "Wolę sushi od puddingu" | ||||
|   show-reversi-board-labels: "Pokazuj podpisy wierszy i kolumn w Reversi" | ||||
|   verified-user: "Zweryfikowany użytkownik" | ||||
|   reversi: | ||||
|     drawn: "Remis" | ||||
|     my-turn: "Twoja kolej" | ||||
|     opponent-turn: "Kolej na przeciwnika" | ||||
|     turn-of: "Kolej na {}" | ||||
|     past-turn-of: "Kolej {}" | ||||
|     won: "{}の勝ち" | ||||
|     black: "黒" | ||||
|     white: "白" | ||||
|     total: "合計" | ||||
|     this-turn: "{}ターン目" | ||||
|   widgets: | ||||
|     analog-clock: "Zegar analogowy" | ||||
|     profile: "Profil" | ||||
| @@ -75,6 +108,7 @@ common: | ||||
|     widgets: "Widżety" | ||||
|     home: "Strona główna" | ||||
|     local: "Lokalne" | ||||
|     hybrid: "Społeczność" | ||||
|     global: "Globalne" | ||||
|     notifications: "Powiadomienia" | ||||
|     list: "Listy" | ||||
| @@ -85,8 +119,44 @@ common: | ||||
|     remove: "Usuń" | ||||
|     add-column: "Dodaj kolumnę" | ||||
|     rename: "Zmień nazwę" | ||||
|     stack-left: "左に重ねる" | ||||
|     pop-right: "右に出す" | ||||
|     stack-left: "Przypnij do lewej" | ||||
|     pop-right: "Odepnij w prawo" | ||||
| common/views/components/games/reversi/reversi.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "他のMisskeyユーザーとリバーシで対戦しよう" | ||||
|   invite: "招待" | ||||
|   rule: "遊び方" | ||||
|   rule-desc: "リバーシは、相手と交互に石をボードに置いて、相手の石を挟んで自分の色に変えてゆき、最終的に残った石が多い方が勝ちというボードゲームです。" | ||||
|   mode-invite: "招待" | ||||
|   mode-invite-desc: "指定したユーザーと対戦するモードです。" | ||||
|   invitations: "対局の招待があります!" | ||||
|   my-games: "自分の対局" | ||||
|   all-games: "みんなの対局" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
|   game-state: | ||||
|     ended: "終了" | ||||
|     playing: "進行中" | ||||
|   matching: | ||||
|     waiting-for: "{}を待っています" | ||||
|     cacnel: "キャンセル" | ||||
| common/views/components/games/reversi/reversi.room.vue: | ||||
|   settings-of-the-game: "ゲームの設定" | ||||
|   choose-map: "マップを選択" | ||||
|   random: "ランダム" | ||||
|   black-or-white: "先手/後手" | ||||
|   black-is: "{}が黒" | ||||
|   rules: "ルール" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
|   settings-of-the-bot: "Botの設定" | ||||
|   this-gane-is-started-soon: "ゲームは数秒後に開始されます" | ||||
|   waiting-for-other: "相手の準備が完了するのを待っています" | ||||
|   waiting-for-me: "あなたの準備が完了するのを待っています" | ||||
|   waiting-for-both: "準備中" | ||||
|   cancel: "キャンセル" | ||||
|   ready: "準備完了" | ||||
|   cancel-ready: "準備続行" | ||||
| common/views/components/connect-failed.vue: | ||||
|   title: "Nie udało się połączyć z serwerem" | ||||
|   description: "Wystąpił problem z Twoim połączeniem z Internetem, lub z serwerem. {Spróbuj ponownie} wkrótce." | ||||
| @@ -216,6 +286,13 @@ common/views/widgets/broadcast.vue: | ||||
|   no-broadcasts: "Brak transmisji" | ||||
|   have-a-nice-day: "Miłego dnia!" | ||||
|   next: "Dalej" | ||||
| common/views/widgets/calendar.vue: | ||||
|   year: "{}年" | ||||
|   month: "{}月" | ||||
|   day: "{}日" | ||||
|   today: "今日:" | ||||
|   this-month: "今月:" | ||||
|   this-year: "今年:" | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "Dotacje" | ||||
|   text: "Aby utrzymywać Misskey, płacimy za domenę, serwery i nie tylko… Nie zarabiamy na tym, więc byłoby nam miło, gdybyśmy uzyskali od Ciebie dotację. Jeżeli jesteś zainteresowany, skontaktuj się z {}. Dziękujemy za wsparcie!" | ||||
| @@ -228,6 +305,7 @@ common/views/widgets/posts-monitor.vue: | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "Hashtagi" | ||||
|   count: "Wspomniany przez {} użytkowników" | ||||
|   empty: "Brak popularnych hashtagów" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "Informacje o serwerze" | ||||
|   toggle: "Przełącz widok" | ||||
| @@ -235,6 +313,37 @@ common/views/widgets/memo.vue: | ||||
|   title: "Notatka" | ||||
|   memo: "Napisz tutaj!" | ||||
|   save: "Zapisz" | ||||
| common/views/widgets/slideshow.vue: | ||||
|   folder-customize-mode: "フォルダを指定するには、カスタマイズモードを終了してください" | ||||
|   folder: "クリックしてフォルダを指定してください" | ||||
|   no-image: "このフォルダには画像がありません" | ||||
| common/views/widgets/tips.vue: | ||||
|   tips-line1: "<kbd>t</kbd>でタイムラインにフォーカスできます" | ||||
|   tips-line2: "<kbd>p</kbd>または<kbd>n</kbd>で投稿フォームを開きます" | ||||
|   tips-line3: "投稿フォームにはファイルをドラッグ&ドロップできます" | ||||
|   tips-line4: "投稿フォームにクリップボードにある画像データをペーストできます" | ||||
|   tips-line5: "ドライブにファイルをドラッグ&ドロップしてアップロードできます" | ||||
|   tips-line6: "ドライブでファイルをドラッグしてフォルダ移動できます" | ||||
|   tips-line7: "ドライブでフォルダをドラッグしてフォルダ移動できます" | ||||
|   tips-line8: "ホームは設定からカスタマイズできます" | ||||
|   tips-line9: "MisskeyはAGPLv3です" | ||||
|   tips-line10: "タイムマシンウィジェットを利用すると、簡単に過去のタイムラインに遡れます" | ||||
|   tips-line11: "投稿の ... をクリックして、投稿をユーザーページにピン留めできます" | ||||
|   tips-line13: "投稿に添付したファイルは全てドライブに保存されます" | ||||
|   tips-line14: "ホームのカスタマイズ中、ウィジェットを右クリックしてデザインを変更できます" | ||||
|   tips-line17: "「**」でテキストを囲むと**強調表示**されます" | ||||
|   tips-line19: "いくつかのウィンドウはブラウザの外に切り離すことができます" | ||||
|   tips-line20: "カレンダーウィジェットのパーセンテージは、経過の割合を示しています" | ||||
|   tips-line21: "APIを利用してbotの開発なども行えます" | ||||
|   tips-line23: "まゆかわいいよまゆ" | ||||
|   tips-line24: "Misskeyは2014年にサービスを開始しました" | ||||
|   tips-line25: "対応ブラウザではMisskeyを開いていなくても通知を受け取れます" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "Zalogowany jako {}" | ||||
|   following: "Śledzisz" | ||||
|   follow: "Śledź" | ||||
|   request-pending: "Oczekiwanie na pozwolenie" | ||||
|   follow-request: "Poproś o śledzenie" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Czarny … Łącznie" | ||||
|   notes: "Niebieski … Wpisy" | ||||
| @@ -270,6 +379,8 @@ desktop/views/components/drive.file.vue: | ||||
|   banner: "Baner" | ||||
|   contextmenu: | ||||
|     rename: "Zmień nazwę" | ||||
|     mark-as-sensitive: "Oznacz jako zawartość wrażliwą" | ||||
|     unmark-as-sensitive: "Cofnij oznaczenie jako zawartość wrażliwą" | ||||
|     copy-url: "Skopiuj adres" | ||||
|     download: "Pobierz" | ||||
|     else-files: "Inne" | ||||
| @@ -313,6 +424,12 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "Utwórz katalog" | ||||
|     upload: "Wyślij plik" | ||||
|     url-upload: "Wyślij z adresu URL" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "To jest zawartość NSFW" | ||||
|   click-to-show: "Naciśnij aby wyświetlić" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "To jest zawartość NSFW" | ||||
|   click-to-show: "Naciśnij aby wyświetlić" | ||||
| desktop/views/components/follow-button.vue: | ||||
|   following: "Śledzisz" | ||||
|   follow: "Śledź" | ||||
| @@ -333,7 +450,7 @@ desktop/views/components/friends-maker.vue: | ||||
|   refresh: "Więcej" | ||||
|   close: "Zamknij" | ||||
| desktop/views/components/game-window.vue: | ||||
|   game: "Othello" | ||||
|   game: "Reversi" | ||||
| desktop/views/components/home.vue: | ||||
|   done: "Wyślij" | ||||
|   add-widget: "Dodaj widżet:" | ||||
| @@ -364,10 +481,14 @@ desktop/views/components/notes.note.vue: | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "Ładowanie nie powiodło się." | ||||
|   retry: "Spróbuj ponownie" | ||||
|   load-more: "Załaduj więcej" | ||||
| desktop/views/components/notifications.vue: | ||||
|   more: "Więcej" | ||||
|   empty: "Brak powiadomień" | ||||
| desktop/views/components/post-form.vue: | ||||
|   add-visible-user: "+ユーザーを追加" | ||||
|   attach-location-information: "位置情報を添付する" | ||||
|   hide-contents: "内容を隠す" | ||||
|   reply-placeholder: "Odpowiedz na ten wpis…" | ||||
|   quote-placeholder: "Zacytuj ten wpis…" | ||||
|   submit: "Wyślij" | ||||
| @@ -383,9 +504,15 @@ desktop/views/components/post-form.vue: | ||||
|   attach-media-from-local: "Załącz zawartość multimedialną z komputera" | ||||
|   attach-media-from-drive: "Załącz zawartość multimedialną z dysku" | ||||
|   attach-cancel: "Usuń załącznik" | ||||
|   insert-a-kao: "v(‘ω’)v" | ||||
|   insert-a-kao: "v('ω')v" | ||||
|   create-poll: "Utwórz ankietę" | ||||
|   text-remain: "pozostałe znaki: {}" | ||||
|   recent-tags: "Ostatnie" | ||||
|   click-to-tagging: "Naciśnij aby oznaczyć" | ||||
|   visibility: "公開範囲" | ||||
|   geolocation-alert: "お使いの端末は位置情報に対応していません" | ||||
|   error: "エラー" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
| desktop/views/components/post-form-window.vue: | ||||
|   note: "Nowy wpis" | ||||
|   reply: "Odpowiedz" | ||||
| @@ -426,6 +553,8 @@ desktop/views/components/settings.vue: | ||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||
|   display: "Wygląd i wyświetlanie" | ||||
|   customize: "Dostosuj stronę główną" | ||||
|   choose-wallpaper: "Wybierz tło" | ||||
|   delete-wallpaper: "Usuń tło" | ||||
|   dark-mode: "Tryb ciemny" | ||||
|   circle-icons: "Używaj okrągłych ikon" | ||||
|   gradient-window-header: "Używaj gradientów na pasku tytułu okna" | ||||
| @@ -504,6 +633,9 @@ desktop/views/components/settings.api.vue: | ||||
|   enter-password: "Wprowadź hasło" | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "Brak zautoryzowanych aplikacji" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "中" | ||||
|   in-use: "使用中" | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "Brak wyciszonych użytkowników" | ||||
| desktop/views/components/settings.password.vue: | ||||
| @@ -521,8 +653,12 @@ desktop/views/components/settings.profile.vue: | ||||
|   description: "Opis" | ||||
|   birthday: "Data urodzenia" | ||||
|   save: "Aktualizuj profil" | ||||
|   locked-account: "Zabezpiecz swoje konto" | ||||
|   is-locked: "Uczyń wpis prywatnym" | ||||
|   other: "Inne" | ||||
|   is-bot: "To konto jest prowadzone przez bota" | ||||
|   is-cat: "To konto jest prowadzone przez kota" | ||||
|   profile-updated: "プロフィールを更新しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "ten wpis jest prywatny" | ||||
|   deleted: "ten wpis został usunięty" | ||||
| @@ -533,15 +669,18 @@ desktop/views/components/taskmanager.vue: | ||||
| desktop/views/components/timeline.vue: | ||||
|   home: "Strona główna" | ||||
|   local: "Lokalne" | ||||
|   hybrid: "Społeczność" | ||||
|   global: "Globalne" | ||||
|   list: "Listy" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "Witaj ponownie," | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "Twój profil" | ||||
|   drive: "Dysk" | ||||
|   favorites: "Ulubione" | ||||
|   lists: "Listy" | ||||
|   follow-requests: "Prośby o śledzenie" | ||||
|   customize: "Dostosuj" | ||||
|   customize: "Dostosuj stronę główną" | ||||
|   settings: "Ustawienia" | ||||
|   signout: "Wyloguj się" | ||||
|   dark: "Sprowadź ciemność" | ||||
| @@ -580,6 +719,7 @@ desktop/views/components/window.vue: | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "Tylko wpisy z zawartością multimedialną" | ||||
|   is-media-view: "Widok multimediów" | ||||
|   edit: "Opcje" | ||||
| desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "Udostępniono przez {}" | ||||
|   private: "ten wpis jest prywatny" | ||||
| @@ -592,6 +732,7 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "Zaloguj się" | ||||
|   signup-button: "Zarejestruj się" | ||||
|   timeline: "Oś czasu" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Dysk Misskey" | ||||
| desktop/views/pages/favorites.vue: | ||||
| @@ -606,6 +747,14 @@ desktop/views/pages/selectdrive.vue: | ||||
|   ok: "OK" | ||||
|   cancel: "Anuluj" | ||||
|   upload: "Wyślij pliki z Twojego komputera" | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "検索機能を利用することができません。" | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "Misskeyで共有" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| desktop/views/pages/user-list.users.vue: | ||||
|   users: "Użytkownicy" | ||||
|   add-user: "Dodaj użytkownika" | ||||
| @@ -618,7 +767,7 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   title: "Najbardziej aktywni" | ||||
|   loading: "Ładowanie" | ||||
|   no-users: "Brak użytkowników" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "To konto zostało zawieszone." | ||||
|   is-remote: "To jest użytkownik zdalnej instancji, informacje mogą nie być w pełni dokładne." | ||||
|   view-remote: "Wyświetl dokładne informacje" | ||||
| @@ -636,6 +785,11 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "Wycisz" | ||||
|   muted: "Wyciszyłeś" | ||||
|   unmute: "Cofnij wyciszenie" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
|   posts: "Wpisy" | ||||
|   following: "Śledzeni" | ||||
|   followers: "Śledzący" | ||||
|   is-bot: "To konto jest botem" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "Wpisy" | ||||
|   with-replies: "Wpisy i odpowiedzi" | ||||
| @@ -692,6 +846,12 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   move: "Przenieś" | ||||
|   hash: "Hash (md5)" | ||||
|   exif: "EXIF" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "To jest zawartość NSFW" | ||||
|   click-to-show: "Naciśnij aby wyświetlić" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "To jest zawartość NSFW" | ||||
|   click-to-show: "Naciśnij aby wyświetlić" | ||||
| mobile/views/components/follow-button.vue: | ||||
|   following: "Śledzisz" | ||||
|   follow: "Śledź" | ||||
| @@ -750,6 +910,8 @@ mobile/views/components/sub-note-content.vue: | ||||
| mobile/views/components/timeline.vue: | ||||
|   empty: "Brak wpisów" | ||||
|   load-more: "Więcej" | ||||
| mobile/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
| mobile/views/components/ui.nav.vue: | ||||
|   timeline: "Oś czasu" | ||||
|   notifications: "Powiadomienia" | ||||
| @@ -780,6 +942,8 @@ mobile/views/pages/user-lists.vue: | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "Dysk" | ||||
|   more: "Załaduj więcej" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "📦 始めましょう" | ||||
| mobile/views/pages/followers.vue: | ||||
|   followers-of: "Śledzący {}" | ||||
| mobile/views/pages/following.vue: | ||||
| @@ -787,7 +951,16 @@ mobile/views/pages/following.vue: | ||||
| mobile/views/pages/home.vue: | ||||
|   home: "Strona główna" | ||||
|   local: "Lokalne" | ||||
|   hybrid: "Społeczność" | ||||
|   global: "Globalne" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| mobile/views/pages/welcome.vue: | ||||
|   signup: "新規登録" | ||||
| mobile/views/pages/widgets.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
| mobile/views/pages/widgets/activity.vue: | ||||
|   activity: "アクティビティ" | ||||
| mobile/views/pages/messaging.vue: | ||||
|   messaging: "Wiadomości" | ||||
| mobile/views/pages/messaging-room.vue: | ||||
| @@ -803,6 +976,8 @@ mobile/views/pages/note.vue: | ||||
| mobile/views/pages/notifications.vue: | ||||
|   notifications: "Powiadomienia" | ||||
|   read-all: "Czy na pewno chcesz oznaczyć wszystkie powiadomienia jako przeczytane?" | ||||
| mobile/views/pages/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "Profil" | ||||
|   name: "Nazwa" | ||||
| @@ -900,11 +1075,17 @@ docs: | ||||
|       properties: "Właściwości" | ||||
|     endpoints: | ||||
|       params: "Parametry" | ||||
|       no-params: "Brak parametrów." | ||||
|       res: "Odpowiedź" | ||||
|       require-credential: "Punkt końcowy wymaga informacji o uwierzytelnieniu." | ||||
|       require-permission: "Ten punkt końcowy wymaga uprawnienia {permission}." | ||||
|       has-limit: "Istnieje limit częstotliwości." | ||||
|       duration-limit: "直近{duration}ミリ秒の間のこのエンドポイントへのリクエスト数の合計が{max}を超える場合はリクエストできません。" | ||||
|       min-interval-limit: "Nie możesz wykonać żądania przed upłynięciem {interval} od ostatniego żądania." | ||||
|       show-src: "Możesz zobaczyć kod źródłowy tego punktu końcowego." | ||||
|       show-src-link: "Zobacz kod na GitHubie" | ||||
|       generated: "このドキュメントはAPI定義に基づき自動生成されています。" | ||||
|     props: | ||||
|       name: "Nazwa" | ||||
|       type: "Rodzaj" | ||||
|       optional: "Nieobowiązkowy" | ||||
|       description: "Opis" | ||||
|       yes: "Tak" | ||||
|       no: "Nie" | ||||
|   | ||||
							
								
								
									
										197
									
								
								locales/pt.yml
									
									
									
									
									
								
							
							
						
						| @@ -3,9 +3,17 @@ meta: | ||||
|   lang: "Português" | ||||
|   divider: "" | ||||
| common: | ||||
|   misskey: "A planet of fediverse" | ||||
|   misskey: "A ⭐ of fediverse" | ||||
|   about-title: "A ⭐ of fediverse." | ||||
|   about: "Misskeyを見つけていただき、ありがとうございます。Misskeyは、地球で生まれた<b>分散マイクロブログSNS</b>です。Fediverse(様々なSNSで構成される宇宙)の中に存在するため、他のSNSと相互に繋がっています。暫し都会の喧騒から離れて、新しいインターネットにダイブしてみませんか。" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
|     paragraph1: "ホームのカスタマイズでは、ウィジェットを追加/削除したり、ドラッグ&ドロップして並べ替えたりすることができます。" | ||||
|     paragraph2: "一部のウィジェットは、<strong><strong>右</strong>クリック</strong>することで表示を変更することができます。" | ||||
|     paragraph3: "ウィジェットを削除するには、ヘッダーの<strong>「ゴミ箱」</strong>と書かれたエリアにウィジェットをドラッグ&ドロップします。" | ||||
|     paragraph4: "カスタマイズを終了するには、右上の「完了」をクリックします。" | ||||
|     gotit: "Got it!" | ||||
|   name: "Misskey" | ||||
|   time: | ||||
|     unknown: "なぞのじかん" | ||||
|     future: "未来" | ||||
| @@ -17,6 +25,7 @@ common: | ||||
|     weeks_ago: "{}週間前" | ||||
|     months_ago: "{}ヶ月前" | ||||
|     years_ago: "{}年前" | ||||
|   trash: "ゴミ箱" | ||||
|   weekday-short: | ||||
|     sunday: "日" | ||||
|     monday: "月" | ||||
| @@ -25,6 +34,14 @@ common: | ||||
|     thursday: "木" | ||||
|     friday: "金" | ||||
|     saturday: "土" | ||||
|   weekday: | ||||
|     sunday: "日曜日" | ||||
|     monday: "月曜日" | ||||
|     tuesday: "火曜日" | ||||
|     wednesday: "水曜日" | ||||
|     thursday: "木曜日" | ||||
|     friday: "金曜日" | ||||
|     saturday: "土曜日" | ||||
|   reactions: | ||||
|     like: "いいね" | ||||
|     love: "しゅき" | ||||
| @@ -42,11 +59,27 @@ common: | ||||
|     d: "言いたいことは?" | ||||
|     e: "ここに書いてください" | ||||
|     f: "あなたが書くのを待っています..." | ||||
|   search: "検索" | ||||
|   delete: "削除" | ||||
|   loading: "読み込み中" | ||||
|   ok: "わかった" | ||||
|   update-available-title: "更新があります" | ||||
|   update-available: "Misskeyの新しいバージョンがあります({newer}。現在{current}を利用中)。ページを再度読み込みすると更新が適用されます。" | ||||
|   my-token-regenerated: "あなたのトークンが更新されたのでサインアウトします。" | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   verified-user: "認証済みのユーザー" | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
|     opponent-turn: "相手のターンです" | ||||
|     turn-of: "{}のターンです" | ||||
|     past-turn-of: "{}のターン" | ||||
|     won: "{}の勝ち" | ||||
|     black: "黒" | ||||
|     white: "白" | ||||
|     total: "合計" | ||||
|     this-turn: "{}ターン目" | ||||
|   widgets: | ||||
|     analog-clock: "アナログ時計" | ||||
|     profile: "プロフィール" | ||||
| @@ -75,6 +108,7 @@ common: | ||||
|     widgets: "ウィジェット" | ||||
|     home: "ホーム" | ||||
|     local: "ローカル" | ||||
|     hybrid: "ソーシャル" | ||||
|     global: "グローバル" | ||||
|     notifications: "通知" | ||||
|     list: "リスト" | ||||
| @@ -87,6 +121,42 @@ common: | ||||
|     rename: "名前を変更" | ||||
|     stack-left: "左に重ねる" | ||||
|     pop-right: "右に出す" | ||||
| common/views/components/games/reversi/reversi.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "他のMisskeyユーザーとリバーシで対戦しよう" | ||||
|   invite: "招待" | ||||
|   rule: "遊び方" | ||||
|   rule-desc: "リバーシは、相手と交互に石をボードに置いて、相手の石を挟んで自分の色に変えてゆき、最終的に残った石が多い方が勝ちというボードゲームです。" | ||||
|   mode-invite: "招待" | ||||
|   mode-invite-desc: "指定したユーザーと対戦するモードです。" | ||||
|   invitations: "対局の招待があります!" | ||||
|   my-games: "自分の対局" | ||||
|   all-games: "みんなの対局" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
|   game-state: | ||||
|     ended: "終了" | ||||
|     playing: "進行中" | ||||
|   matching: | ||||
|     waiting-for: "{}を待っています" | ||||
|     cacnel: "キャンセル" | ||||
| common/views/components/games/reversi/reversi.room.vue: | ||||
|   settings-of-the-game: "ゲームの設定" | ||||
|   choose-map: "マップを選択" | ||||
|   random: "ランダム" | ||||
|   black-or-white: "先手/後手" | ||||
|   black-is: "{}が黒" | ||||
|   rules: "ルール" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
|   settings-of-the-bot: "Botの設定" | ||||
|   this-gane-is-started-soon: "ゲームは数秒後に開始されます" | ||||
|   waiting-for-other: "相手の準備が完了するのを待っています" | ||||
|   waiting-for-me: "あなたの準備が完了するのを待っています" | ||||
|   waiting-for-both: "準備中" | ||||
|   cancel: "キャンセル" | ||||
|   ready: "準備完了" | ||||
|   cancel-ready: "準備続行" | ||||
| common/views/components/connect-failed.vue: | ||||
|   title: "サーバーに接続できません" | ||||
|   description: "インターネット回線に問題があるか、サーバーがダウンまたはメンテナンスしている可能性があります。しばらくしてから{再度お試し}ください。" | ||||
| @@ -216,6 +286,13 @@ common/views/widgets/broadcast.vue: | ||||
|   no-broadcasts: "お知らせはありません" | ||||
|   have-a-nice-day: "良い一日を!" | ||||
|   next: "次" | ||||
| common/views/widgets/calendar.vue: | ||||
|   year: "{}年" | ||||
|   month: "{}月" | ||||
|   day: "{}日" | ||||
|   today: "今日:" | ||||
|   this-month: "今月:" | ||||
|   this-year: "今年:" | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "寄付のお願い" | ||||
|   text: "Misskeyの運営にはドメイン、サーバー等のコストが掛かります。Misskeyは広告を掲載したりしないため、収入を皆様からの寄付に頼っています。もしご興味があれば、{}までご連絡ください。ご協力ありがとうございます。" | ||||
| @@ -228,6 +305,7 @@ common/views/widgets/posts-monitor.vue: | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "ハッシュタグ" | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "サーバー情報" | ||||
|   toggle: "表示を切り替え" | ||||
| @@ -235,6 +313,37 @@ common/views/widgets/memo.vue: | ||||
|   title: "付箋" | ||||
|   memo: "ここに書いて!" | ||||
|   save: "保存" | ||||
| common/views/widgets/slideshow.vue: | ||||
|   folder-customize-mode: "フォルダを指定するには、カスタマイズモードを終了してください" | ||||
|   folder: "クリックしてフォルダを指定してください" | ||||
|   no-image: "このフォルダには画像がありません" | ||||
| common/views/widgets/tips.vue: | ||||
|   tips-line1: "<kbd>t</kbd>でタイムラインにフォーカスできます" | ||||
|   tips-line2: "<kbd>p</kbd>または<kbd>n</kbd>で投稿フォームを開きます" | ||||
|   tips-line3: "投稿フォームにはファイルをドラッグ&ドロップできます" | ||||
|   tips-line4: "投稿フォームにクリップボードにある画像データをペーストできます" | ||||
|   tips-line5: "ドライブにファイルをドラッグ&ドロップしてアップロードできます" | ||||
|   tips-line6: "ドライブでファイルをドラッグしてフォルダ移動できます" | ||||
|   tips-line7: "ドライブでフォルダをドラッグしてフォルダ移動できます" | ||||
|   tips-line8: "ホームは設定からカスタマイズできます" | ||||
|   tips-line9: "MisskeyはAGPLv3です" | ||||
|   tips-line10: "タイムマシンウィジェットを利用すると、簡単に過去のタイムラインに遡れます" | ||||
|   tips-line11: "投稿の ... をクリックして、投稿をユーザーページにピン留めできます" | ||||
|   tips-line13: "投稿に添付したファイルは全てドライブに保存されます" | ||||
|   tips-line14: "ホームのカスタマイズ中、ウィジェットを右クリックしてデザインを変更できます" | ||||
|   tips-line17: "「**」でテキストを囲むと**強調表示**されます" | ||||
|   tips-line19: "いくつかのウィンドウはブラウザの外に切り離すことができます" | ||||
|   tips-line20: "カレンダーウィジェットのパーセンテージは、経過の割合を示しています" | ||||
|   tips-line21: "APIを利用してbotの開発なども行えます" | ||||
|   tips-line23: "まゆかわいいよまゆ" | ||||
|   tips-line24: "Misskeyは2014年にサービスを開始しました" | ||||
|   tips-line25: "対応ブラウザではMisskeyを開いていなくても通知を受け取れます" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
|   request-pending: "フォロー許可待ち" | ||||
|   follow-request: "フォロー申請" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Black ... Total" | ||||
|   notes: "Blue ... Notes" | ||||
| @@ -270,6 +379,8 @@ desktop/views/components/drive.file.vue: | ||||
|   banner: "バナー" | ||||
|   contextmenu: | ||||
|     rename: "名前を変更" | ||||
|     mark-as-sensitive: "閲覧注意に設定" | ||||
|     unmark-as-sensitive: "閲覧注意を解除" | ||||
|     copy-url: "URLをコピー" | ||||
|     download: "ダウンロード" | ||||
|     else-files: "その他..." | ||||
| @@ -313,6 +424,12 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "フォルダーを作成" | ||||
|     upload: "ファイルをアップロード" | ||||
|     url-upload: "URLからアップロード" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| desktop/views/components/follow-button.vue: | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
| @@ -333,7 +450,7 @@ desktop/views/components/friends-maker.vue: | ||||
|   refresh: "もっと見る" | ||||
|   close: "閉じる" | ||||
| desktop/views/components/game-window.vue: | ||||
|   game: "オセロ" | ||||
|   game: "リバーシ" | ||||
| desktop/views/components/home.vue: | ||||
|   done: "完了" | ||||
|   add-widget: "ウィジェットを追加:" | ||||
| @@ -364,10 +481,14 @@ desktop/views/components/notes.note.vue: | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "読み込みに失敗しました。" | ||||
|   retry: "リトライ" | ||||
|   load-more: "もっと読み込む" | ||||
| desktop/views/components/notifications.vue: | ||||
|   more: "もっと見る" | ||||
|   empty: "ありません!" | ||||
| desktop/views/components/post-form.vue: | ||||
|   add-visible-user: "+ユーザーを追加" | ||||
|   attach-location-information: "位置情報を添付する" | ||||
|   hide-contents: "内容を隠す" | ||||
|   reply-placeholder: "この投稿への返信..." | ||||
|   quote-placeholder: "この投稿を引用..." | ||||
|   submit: "投稿" | ||||
| @@ -383,9 +504,15 @@ desktop/views/components/post-form.vue: | ||||
|   attach-media-from-local: "PCからメディアを添付" | ||||
|   attach-media-from-drive: "ドライブからメディアを添付" | ||||
|   attach-cancel: "添付取り消し" | ||||
|   insert-a-kao: "v(‘ω’)v" | ||||
|   insert-a-kao: "v('ω')v" | ||||
|   create-poll: "アンケートを作成" | ||||
|   text-remain: "残り{}文字" | ||||
|   recent-tags: "最近" | ||||
|   click-to-tagging: "クリックでタグ付け" | ||||
|   visibility: "公開範囲" | ||||
|   geolocation-alert: "お使いの端末は位置情報に対応していません" | ||||
|   error: "エラー" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
| desktop/views/components/post-form-window.vue: | ||||
|   note: "新規投稿" | ||||
|   reply: "返信" | ||||
| @@ -426,6 +553,8 @@ desktop/views/components/settings.vue: | ||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||
|   display: "デザインと表示" | ||||
|   customize: "ホームをカスタマイズ" | ||||
|   choose-wallpaper: "壁紙を選択" | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
| @@ -504,6 +633,9 @@ desktop/views/components/settings.api.vue: | ||||
|   enter-password: "パスワードを入力してください" | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "連携しているアプリケーションはありません" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "中" | ||||
|   in-use: "使用中" | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "ミュートしているユーザーはいません" | ||||
| desktop/views/components/settings.password.vue: | ||||
| @@ -521,8 +653,12 @@ desktop/views/components/settings.profile.vue: | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   profile-updated: "プロフィールを更新しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| @@ -533,15 +669,18 @@ desktop/views/components/taskmanager.vue: | ||||
| desktop/views/components/timeline.vue: | ||||
|   home: "ホーム" | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   list: "リスト" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "プロフィール" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
|   customize: "カスタマイズ" | ||||
|   customize: "ホームのカスタマイズ" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   dark: "闇に飲まれる" | ||||
| @@ -580,6 +719,7 @@ desktop/views/components/window.vue: | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "メディア投稿のみ" | ||||
|   is-media-view: "メディアビュー" | ||||
|   edit: "オプション" | ||||
| desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   private: "この投稿は非公開です" | ||||
| @@ -592,6 +732,7 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "やってる" | ||||
|   signup-button: "やる" | ||||
|   timeline: "タイムライン" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Misskey Drive" | ||||
| desktop/views/pages/favorites.vue: | ||||
| @@ -606,6 +747,14 @@ desktop/views/pages/selectdrive.vue: | ||||
|   ok: "決定" | ||||
|   cancel: "キャンセル" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "検索機能を利用することができません。" | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "Misskeyで共有" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| desktop/views/pages/user-list.users.vue: | ||||
|   users: "ユーザー" | ||||
|   add-user: "ユーザーを追加" | ||||
| @@ -618,7 +767,7 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   title: "よく話すユーザー" | ||||
|   loading: "読み込み中" | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
| @@ -636,6 +785,11 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "ミュートする" | ||||
|   muted: "ミュートしています" | ||||
|   unmute: "ミュート解除" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   is-bot: "このアカウントはBotです" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "投稿" | ||||
|   with-replies: "投稿と返信" | ||||
| @@ -692,6 +846,12 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   move: "移動" | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/follow-button.vue: | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
| @@ -750,6 +910,8 @@ mobile/views/components/sub-note-content.vue: | ||||
| mobile/views/components/timeline.vue: | ||||
|   empty: "投稿がありません" | ||||
|   load-more: "もっと" | ||||
| mobile/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
| mobile/views/components/ui.nav.vue: | ||||
|   timeline: "タイムライン" | ||||
|   notifications: "通知" | ||||
| @@ -780,6 +942,8 @@ mobile/views/pages/user-lists.vue: | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   more: "もっと見る" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "📦 始めましょう" | ||||
| mobile/views/pages/followers.vue: | ||||
|   followers-of: "{}のフォロワー" | ||||
| mobile/views/pages/following.vue: | ||||
| @@ -787,7 +951,16 @@ mobile/views/pages/following.vue: | ||||
| mobile/views/pages/home.vue: | ||||
|   home: "ホーム" | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| mobile/views/pages/welcome.vue: | ||||
|   signup: "新規登録" | ||||
| mobile/views/pages/widgets.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
| mobile/views/pages/widgets/activity.vue: | ||||
|   activity: "アクティビティ" | ||||
| mobile/views/pages/messaging.vue: | ||||
|   messaging: "メッセージ" | ||||
| mobile/views/pages/messaging-room.vue: | ||||
| @@ -803,6 +976,8 @@ mobile/views/pages/note.vue: | ||||
| mobile/views/pages/notifications.vue: | ||||
|   notifications: "通知" | ||||
|   read-all: "すべての通知を既読にしますか?" | ||||
| mobile/views/pages/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
| @@ -900,11 +1075,17 @@ docs: | ||||
|       properties: "プロパティ" | ||||
|     endpoints: | ||||
|       params: "パラメータ" | ||||
|       no-params: "パラメータはありません" | ||||
|       res: "レスポンス" | ||||
|       require-credential: "このエンドポイントは認証情報が必須です。" | ||||
|       require-permission: "このエンドポイントは{permission}の権限を必要とします。" | ||||
|       has-limit: "レートリミットがあります。" | ||||
|       duration-limit: "直近{duration}ミリ秒の間のこのエンドポイントへのリクエスト数の合計が{max}を超える場合はリクエストできません。" | ||||
|       min-interval-limit: "前回のリクエストから{interval}ミリ秒経っていない場合はリクエストできません。" | ||||
|       show-src: "このエンドポイントのソースコードも閲覧できます。" | ||||
|       show-src-link: "コードをGitHubで見る" | ||||
|       generated: "このドキュメントはAPI定義に基づき自動生成されています。" | ||||
|     props: | ||||
|       name: "名前" | ||||
|       type: "型" | ||||
|       optional: "オプション" | ||||
|       description: "説明" | ||||
|       yes: "はい" | ||||
|       no: "いいえ" | ||||
|   | ||||
							
								
								
									
										197
									
								
								locales/ru.yml
									
									
									
									
									
								
							
							
						
						| @@ -3,9 +3,17 @@ meta: | ||||
|   lang: "Русский язык" | ||||
|   divider: "" | ||||
| common: | ||||
|   misskey: "A planet of fediverse" | ||||
|   misskey: "A ⭐ of fediverse" | ||||
|   about-title: "A ⭐ of fediverse." | ||||
|   about: "Misskeyを見つけていただき、ありがとうございます。Misskeyは、地球で生まれた<b>分散マイクロブログSNS</b>です。Fediverse(様々なSNSで構成される宇宙)の中に存在するため、他のSNSと相互に繋がっています。暫し都会の喧騒から離れて、新しいインターネットにダイブしてみませんか。" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
|     paragraph1: "ホームのカスタマイズでは、ウィジェットを追加/削除したり、ドラッグ&ドロップして並べ替えたりすることができます。" | ||||
|     paragraph2: "一部のウィジェットは、<strong><strong>右</strong>クリック</strong>することで表示を変更することができます。" | ||||
|     paragraph3: "ウィジェットを削除するには、ヘッダーの<strong>「ゴミ箱」</strong>と書かれたエリアにウィジェットをドラッグ&ドロップします。" | ||||
|     paragraph4: "カスタマイズを終了するには、右上の「完了」をクリックします。" | ||||
|     gotit: "Got it!" | ||||
|   name: "Misskey" | ||||
|   time: | ||||
|     unknown: "なぞのじかん" | ||||
|     future: "未来" | ||||
| @@ -17,6 +25,7 @@ common: | ||||
|     weeks_ago: "{}週間前" | ||||
|     months_ago: "{}ヶ月前" | ||||
|     years_ago: "{}年前" | ||||
|   trash: "ゴミ箱" | ||||
|   weekday-short: | ||||
|     sunday: "日" | ||||
|     monday: "月" | ||||
| @@ -25,6 +34,14 @@ common: | ||||
|     thursday: "木" | ||||
|     friday: "金" | ||||
|     saturday: "土" | ||||
|   weekday: | ||||
|     sunday: "日曜日" | ||||
|     monday: "月曜日" | ||||
|     tuesday: "火曜日" | ||||
|     wednesday: "水曜日" | ||||
|     thursday: "木曜日" | ||||
|     friday: "金曜日" | ||||
|     saturday: "土曜日" | ||||
|   reactions: | ||||
|     like: "いいね" | ||||
|     love: "しゅき" | ||||
| @@ -42,11 +59,27 @@ common: | ||||
|     d: "言いたいことは?" | ||||
|     e: "ここに書いてください" | ||||
|     f: "あなたが書くのを待っています..." | ||||
|   search: "検索" | ||||
|   delete: "削除" | ||||
|   loading: "読み込み中" | ||||
|   ok: "わかった" | ||||
|   update-available-title: "更新があります" | ||||
|   update-available: "Misskeyの新しいバージョンがあります({newer}。現在{current}を利用中)。ページを再度読み込みすると更新が適用されます。" | ||||
|   my-token-regenerated: "あなたのトークンが更新されたのでサインアウトします。" | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   verified-user: "認証済みのユーザー" | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
|     opponent-turn: "相手のターンです" | ||||
|     turn-of: "{}のターンです" | ||||
|     past-turn-of: "{}のターン" | ||||
|     won: "{}の勝ち" | ||||
|     black: "黒" | ||||
|     white: "白" | ||||
|     total: "合計" | ||||
|     this-turn: "{}ターン目" | ||||
|   widgets: | ||||
|     analog-clock: "アナログ時計" | ||||
|     profile: "プロフィール" | ||||
| @@ -75,6 +108,7 @@ common: | ||||
|     widgets: "ウィジェット" | ||||
|     home: "ホーム" | ||||
|     local: "ローカル" | ||||
|     hybrid: "ソーシャル" | ||||
|     global: "グローバル" | ||||
|     notifications: "通知" | ||||
|     list: "リスト" | ||||
| @@ -87,6 +121,42 @@ common: | ||||
|     rename: "名前を変更" | ||||
|     stack-left: "左に重ねる" | ||||
|     pop-right: "右に出す" | ||||
| common/views/components/games/reversi/reversi.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "他のMisskeyユーザーとリバーシで対戦しよう" | ||||
|   invite: "招待" | ||||
|   rule: "遊び方" | ||||
|   rule-desc: "リバーシは、相手と交互に石をボードに置いて、相手の石を挟んで自分の色に変えてゆき、最終的に残った石が多い方が勝ちというボードゲームです。" | ||||
|   mode-invite: "招待" | ||||
|   mode-invite-desc: "指定したユーザーと対戦するモードです。" | ||||
|   invitations: "対局の招待があります!" | ||||
|   my-games: "自分の対局" | ||||
|   all-games: "みんなの対局" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
|   game-state: | ||||
|     ended: "終了" | ||||
|     playing: "進行中" | ||||
|   matching: | ||||
|     waiting-for: "{}を待っています" | ||||
|     cacnel: "キャンセル" | ||||
| common/views/components/games/reversi/reversi.room.vue: | ||||
|   settings-of-the-game: "ゲームの設定" | ||||
|   choose-map: "マップを選択" | ||||
|   random: "ランダム" | ||||
|   black-or-white: "先手/後手" | ||||
|   black-is: "{}が黒" | ||||
|   rules: "ルール" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
|   settings-of-the-bot: "Botの設定" | ||||
|   this-gane-is-started-soon: "ゲームは数秒後に開始されます" | ||||
|   waiting-for-other: "相手の準備が完了するのを待っています" | ||||
|   waiting-for-me: "あなたの準備が完了するのを待っています" | ||||
|   waiting-for-both: "準備中" | ||||
|   cancel: "キャンセル" | ||||
|   ready: "準備完了" | ||||
|   cancel-ready: "準備続行" | ||||
| common/views/components/connect-failed.vue: | ||||
|   title: "サーバーに接続できません" | ||||
|   description: "インターネット回線に問題があるか、サーバーがダウンまたはメンテナンスしている可能性があります。しばらくしてから{再度お試し}ください。" | ||||
| @@ -216,6 +286,13 @@ common/views/widgets/broadcast.vue: | ||||
|   no-broadcasts: "お知らせはありません" | ||||
|   have-a-nice-day: "良い一日を!" | ||||
|   next: "次" | ||||
| common/views/widgets/calendar.vue: | ||||
|   year: "{}年" | ||||
|   month: "{}月" | ||||
|   day: "{}日" | ||||
|   today: "今日:" | ||||
|   this-month: "今月:" | ||||
|   this-year: "今年:" | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "寄付のお願い" | ||||
|   text: "Misskeyの運営にはドメイン、サーバー等のコストが掛かります。Misskeyは広告を掲載したりしないため、収入を皆様からの寄付に頼っています。もしご興味があれば、{}までご連絡ください。ご協力ありがとうございます。" | ||||
| @@ -228,6 +305,7 @@ common/views/widgets/posts-monitor.vue: | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "ハッシュタグ" | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "サーバー情報" | ||||
|   toggle: "表示を切り替え" | ||||
| @@ -235,6 +313,37 @@ common/views/widgets/memo.vue: | ||||
|   title: "付箋" | ||||
|   memo: "ここに書いて!" | ||||
|   save: "保存" | ||||
| common/views/widgets/slideshow.vue: | ||||
|   folder-customize-mode: "フォルダを指定するには、カスタマイズモードを終了してください" | ||||
|   folder: "クリックしてフォルダを指定してください" | ||||
|   no-image: "このフォルダには画像がありません" | ||||
| common/views/widgets/tips.vue: | ||||
|   tips-line1: "<kbd>t</kbd>でタイムラインにフォーカスできます" | ||||
|   tips-line2: "<kbd>p</kbd>または<kbd>n</kbd>で投稿フォームを開きます" | ||||
|   tips-line3: "投稿フォームにはファイルをドラッグ&ドロップできます" | ||||
|   tips-line4: "投稿フォームにクリップボードにある画像データをペーストできます" | ||||
|   tips-line5: "ドライブにファイルをドラッグ&ドロップしてアップロードできます" | ||||
|   tips-line6: "ドライブでファイルをドラッグしてフォルダ移動できます" | ||||
|   tips-line7: "ドライブでフォルダをドラッグしてフォルダ移動できます" | ||||
|   tips-line8: "ホームは設定からカスタマイズできます" | ||||
|   tips-line9: "MisskeyはAGPLv3です" | ||||
|   tips-line10: "タイムマシンウィジェットを利用すると、簡単に過去のタイムラインに遡れます" | ||||
|   tips-line11: "投稿の ... をクリックして、投稿をユーザーページにピン留めできます" | ||||
|   tips-line13: "投稿に添付したファイルは全てドライブに保存されます" | ||||
|   tips-line14: "ホームのカスタマイズ中、ウィジェットを右クリックしてデザインを変更できます" | ||||
|   tips-line17: "「**」でテキストを囲むと**強調表示**されます" | ||||
|   tips-line19: "いくつかのウィンドウはブラウザの外に切り離すことができます" | ||||
|   tips-line20: "カレンダーウィジェットのパーセンテージは、経過の割合を示しています" | ||||
|   tips-line21: "APIを利用してbotの開発なども行えます" | ||||
|   tips-line23: "まゆかわいいよまゆ" | ||||
|   tips-line24: "Misskeyは2014年にサービスを開始しました" | ||||
|   tips-line25: "対応ブラウザではMisskeyを開いていなくても通知を受け取れます" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
|   request-pending: "フォロー許可待ち" | ||||
|   follow-request: "フォロー申請" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Black ... Total" | ||||
|   notes: "Blue ... Notes" | ||||
| @@ -270,6 +379,8 @@ desktop/views/components/drive.file.vue: | ||||
|   banner: "バナー" | ||||
|   contextmenu: | ||||
|     rename: "名前を変更" | ||||
|     mark-as-sensitive: "閲覧注意に設定" | ||||
|     unmark-as-sensitive: "閲覧注意を解除" | ||||
|     copy-url: "URLをコピー" | ||||
|     download: "ダウンロード" | ||||
|     else-files: "その他..." | ||||
| @@ -313,6 +424,12 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "フォルダーを作成" | ||||
|     upload: "ファイルをアップロード" | ||||
|     url-upload: "URLからアップロード" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| desktop/views/components/follow-button.vue: | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
| @@ -333,7 +450,7 @@ desktop/views/components/friends-maker.vue: | ||||
|   refresh: "もっと見る" | ||||
|   close: "閉じる" | ||||
| desktop/views/components/game-window.vue: | ||||
|   game: "オセロ" | ||||
|   game: "リバーシ" | ||||
| desktop/views/components/home.vue: | ||||
|   done: "完了" | ||||
|   add-widget: "ウィジェットを追加:" | ||||
| @@ -364,10 +481,14 @@ desktop/views/components/notes.note.vue: | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "読み込みに失敗しました。" | ||||
|   retry: "リトライ" | ||||
|   load-more: "もっと読み込む" | ||||
| desktop/views/components/notifications.vue: | ||||
|   more: "もっと見る" | ||||
|   empty: "ありません!" | ||||
| desktop/views/components/post-form.vue: | ||||
|   add-visible-user: "+ユーザーを追加" | ||||
|   attach-location-information: "位置情報を添付する" | ||||
|   hide-contents: "内容を隠す" | ||||
|   reply-placeholder: "この投稿への返信..." | ||||
|   quote-placeholder: "この投稿を引用..." | ||||
|   submit: "投稿" | ||||
| @@ -383,9 +504,15 @@ desktop/views/components/post-form.vue: | ||||
|   attach-media-from-local: "PCからメディアを添付" | ||||
|   attach-media-from-drive: "ドライブからメディアを添付" | ||||
|   attach-cancel: "添付取り消し" | ||||
|   insert-a-kao: "v(‘ω’)v" | ||||
|   insert-a-kao: "v('ω')v" | ||||
|   create-poll: "アンケートを作成" | ||||
|   text-remain: "残り{}文字" | ||||
|   recent-tags: "最近" | ||||
|   click-to-tagging: "クリックでタグ付け" | ||||
|   visibility: "公開範囲" | ||||
|   geolocation-alert: "お使いの端末は位置情報に対応していません" | ||||
|   error: "エラー" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
| desktop/views/components/post-form-window.vue: | ||||
|   note: "新規投稿" | ||||
|   reply: "返信" | ||||
| @@ -426,6 +553,8 @@ desktop/views/components/settings.vue: | ||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||
|   display: "デザインと表示" | ||||
|   customize: "ホームをカスタマイズ" | ||||
|   choose-wallpaper: "壁紙を選択" | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
| @@ -504,6 +633,9 @@ desktop/views/components/settings.api.vue: | ||||
|   enter-password: "パスワードを入力してください" | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "連携しているアプリケーションはありません" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "中" | ||||
|   in-use: "使用中" | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "ミュートしているユーザーはいません" | ||||
| desktop/views/components/settings.password.vue: | ||||
| @@ -521,8 +653,12 @@ desktop/views/components/settings.profile.vue: | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   profile-updated: "プロフィールを更新しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| @@ -533,15 +669,18 @@ desktop/views/components/taskmanager.vue: | ||||
| desktop/views/components/timeline.vue: | ||||
|   home: "ホーム" | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   list: "リスト" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "プロフィール" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
|   customize: "カスタマイズ" | ||||
|   customize: "ホームのカスタマイズ" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   dark: "闇に飲まれる" | ||||
| @@ -580,6 +719,7 @@ desktop/views/components/window.vue: | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "メディア投稿のみ" | ||||
|   is-media-view: "メディアビュー" | ||||
|   edit: "オプション" | ||||
| desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   private: "この投稿は非公開です" | ||||
| @@ -592,6 +732,7 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "やってる" | ||||
|   signup-button: "やる" | ||||
|   timeline: "タイムライン" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Misskey Drive" | ||||
| desktop/views/pages/favorites.vue: | ||||
| @@ -606,6 +747,14 @@ desktop/views/pages/selectdrive.vue: | ||||
|   ok: "決定" | ||||
|   cancel: "キャンセル" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "検索機能を利用することができません。" | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "Misskeyで共有" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| desktop/views/pages/user-list.users.vue: | ||||
|   users: "ユーザー" | ||||
|   add-user: "ユーザーを追加" | ||||
| @@ -618,7 +767,7 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   title: "よく話すユーザー" | ||||
|   loading: "読み込み中" | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
| @@ -636,6 +785,11 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "ミュートする" | ||||
|   muted: "ミュートしています" | ||||
|   unmute: "ミュート解除" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   is-bot: "このアカウントはBotです" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "投稿" | ||||
|   with-replies: "投稿と返信" | ||||
| @@ -692,6 +846,12 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   move: "移動" | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/follow-button.vue: | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
| @@ -750,6 +910,8 @@ mobile/views/components/sub-note-content.vue: | ||||
| mobile/views/components/timeline.vue: | ||||
|   empty: "投稿がありません" | ||||
|   load-more: "もっと" | ||||
| mobile/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
| mobile/views/components/ui.nav.vue: | ||||
|   timeline: "タイムライン" | ||||
|   notifications: "通知" | ||||
| @@ -780,6 +942,8 @@ mobile/views/pages/user-lists.vue: | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   more: "もっと見る" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "📦 始めましょう" | ||||
| mobile/views/pages/followers.vue: | ||||
|   followers-of: "{}のフォロワー" | ||||
| mobile/views/pages/following.vue: | ||||
| @@ -787,7 +951,16 @@ mobile/views/pages/following.vue: | ||||
| mobile/views/pages/home.vue: | ||||
|   home: "ホーム" | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| mobile/views/pages/welcome.vue: | ||||
|   signup: "新規登録" | ||||
| mobile/views/pages/widgets.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
| mobile/views/pages/widgets/activity.vue: | ||||
|   activity: "アクティビティ" | ||||
| mobile/views/pages/messaging.vue: | ||||
|   messaging: "メッセージ" | ||||
| mobile/views/pages/messaging-room.vue: | ||||
| @@ -803,6 +976,8 @@ mobile/views/pages/note.vue: | ||||
| mobile/views/pages/notifications.vue: | ||||
|   notifications: "通知" | ||||
|   read-all: "すべての通知を既読にしますか?" | ||||
| mobile/views/pages/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
| @@ -900,11 +1075,17 @@ docs: | ||||
|       properties: "プロパティ" | ||||
|     endpoints: | ||||
|       params: "パラメータ" | ||||
|       no-params: "パラメータはありません" | ||||
|       res: "レスポンス" | ||||
|       require-credential: "このエンドポイントは認証情報が必須です。" | ||||
|       require-permission: "このエンドポイントは{permission}の権限を必要とします。" | ||||
|       has-limit: "レートリミットがあります。" | ||||
|       duration-limit: "直近{duration}ミリ秒の間のこのエンドポイントへのリクエスト数の合計が{max}を超える場合はリクエストできません。" | ||||
|       min-interval-limit: "前回のリクエストから{interval}ミリ秒経っていない場合はリクエストできません。" | ||||
|       show-src: "このエンドポイントのソースコードも閲覧できます。" | ||||
|       show-src-link: "コードをGitHubで見る" | ||||
|       generated: "このドキュメントはAPI定義に基づき自動生成されています。" | ||||
|     props: | ||||
|       name: "名前" | ||||
|       type: "型" | ||||
|       optional: "オプション" | ||||
|       description: "説明" | ||||
|       yes: "はい" | ||||
|       no: "いいえ" | ||||
|   | ||||
							
								
								
									
										197
									
								
								locales/zh.yml
									
									
									
									
									
								
							
							
						
						| @@ -3,9 +3,17 @@ meta: | ||||
|   lang: "中文(简体)" | ||||
|   divider: "" | ||||
| common: | ||||
|   misskey: "A planet of fediverse" | ||||
|   misskey: "A ⭐ of fediverse" | ||||
|   about-title: "A ⭐ of fediverse." | ||||
|   about: "Misskeyを見つけていただき、ありがとうございます。Misskeyは、地球で生まれた<b>分散マイクロブログSNS</b>です。Fediverse(様々なSNSで構成される宇宙)の中に存在するため、他のSNSと相互に繋がっています。暫し都会の喧騒から離れて、新しいインターネットにダイブしてみませんか。" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
|     paragraph1: "ホームのカスタマイズでは、ウィジェットを追加/削除したり、ドラッグ&ドロップして並べ替えたりすることができます。" | ||||
|     paragraph2: "一部のウィジェットは、<strong><strong>右</strong>クリック</strong>することで表示を変更することができます。" | ||||
|     paragraph3: "ウィジェットを削除するには、ヘッダーの<strong>「ゴミ箱」</strong>と書かれたエリアにウィジェットをドラッグ&ドロップします。" | ||||
|     paragraph4: "カスタマイズを終了するには、右上の「完了」をクリックします。" | ||||
|     gotit: "Got it!" | ||||
|   name: "Misskey" | ||||
|   time: | ||||
|     unknown: "なぞのじかん" | ||||
|     future: "未来" | ||||
| @@ -17,6 +25,7 @@ common: | ||||
|     weeks_ago: "{}週間前" | ||||
|     months_ago: "{}ヶ月前" | ||||
|     years_ago: "{}年前" | ||||
|   trash: "ゴミ箱" | ||||
|   weekday-short: | ||||
|     sunday: "日" | ||||
|     monday: "月" | ||||
| @@ -25,6 +34,14 @@ common: | ||||
|     thursday: "木" | ||||
|     friday: "金" | ||||
|     saturday: "土" | ||||
|   weekday: | ||||
|     sunday: "日曜日" | ||||
|     monday: "月曜日" | ||||
|     tuesday: "火曜日" | ||||
|     wednesday: "水曜日" | ||||
|     thursday: "木曜日" | ||||
|     friday: "金曜日" | ||||
|     saturday: "土曜日" | ||||
|   reactions: | ||||
|     like: "いいね" | ||||
|     love: "しゅき" | ||||
| @@ -42,11 +59,27 @@ common: | ||||
|     d: "言いたいことは?" | ||||
|     e: "ここに書いてください" | ||||
|     f: "あなたが書くのを待っています..." | ||||
|   search: "検索" | ||||
|   delete: "削除" | ||||
|   loading: "読み込み中" | ||||
|   ok: "わかった" | ||||
|   update-available-title: "更新があります" | ||||
|   update-available: "Misskeyの新しいバージョンがあります({newer}。現在{current}を利用中)。ページを再度読み込みすると更新が適用されます。" | ||||
|   my-token-regenerated: "あなたのトークンが更新されたのでサインアウトします。" | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   verified-user: "認証済みのユーザー" | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
|     opponent-turn: "相手のターンです" | ||||
|     turn-of: "{}のターンです" | ||||
|     past-turn-of: "{}のターン" | ||||
|     won: "{}の勝ち" | ||||
|     black: "黒" | ||||
|     white: "白" | ||||
|     total: "合計" | ||||
|     this-turn: "{}ターン目" | ||||
|   widgets: | ||||
|     analog-clock: "アナログ時計" | ||||
|     profile: "プロフィール" | ||||
| @@ -75,6 +108,7 @@ common: | ||||
|     widgets: "ウィジェット" | ||||
|     home: "ホーム" | ||||
|     local: "ローカル" | ||||
|     hybrid: "ソーシャル" | ||||
|     global: "グローバル" | ||||
|     notifications: "通知" | ||||
|     list: "リスト" | ||||
| @@ -87,6 +121,42 @@ common: | ||||
|     rename: "名前を変更" | ||||
|     stack-left: "左に重ねる" | ||||
|     pop-right: "右に出す" | ||||
| common/views/components/games/reversi/reversi.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "他のMisskeyユーザーとリバーシで対戦しよう" | ||||
|   invite: "招待" | ||||
|   rule: "遊び方" | ||||
|   rule-desc: "リバーシは、相手と交互に石をボードに置いて、相手の石を挟んで自分の色に変えてゆき、最終的に残った石が多い方が勝ちというボードゲームです。" | ||||
|   mode-invite: "招待" | ||||
|   mode-invite-desc: "指定したユーザーと対戦するモードです。" | ||||
|   invitations: "対局の招待があります!" | ||||
|   my-games: "自分の対局" | ||||
|   all-games: "みんなの対局" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
|   game-state: | ||||
|     ended: "終了" | ||||
|     playing: "進行中" | ||||
|   matching: | ||||
|     waiting-for: "{}を待っています" | ||||
|     cacnel: "キャンセル" | ||||
| common/views/components/games/reversi/reversi.room.vue: | ||||
|   settings-of-the-game: "ゲームの設定" | ||||
|   choose-map: "マップを選択" | ||||
|   random: "ランダム" | ||||
|   black-or-white: "先手/後手" | ||||
|   black-is: "{}が黒" | ||||
|   rules: "ルール" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
|   settings-of-the-bot: "Botの設定" | ||||
|   this-gane-is-started-soon: "ゲームは数秒後に開始されます" | ||||
|   waiting-for-other: "相手の準備が完了するのを待っています" | ||||
|   waiting-for-me: "あなたの準備が完了するのを待っています" | ||||
|   waiting-for-both: "準備中" | ||||
|   cancel: "キャンセル" | ||||
|   ready: "準備完了" | ||||
|   cancel-ready: "準備続行" | ||||
| common/views/components/connect-failed.vue: | ||||
|   title: "サーバーに接続できません" | ||||
|   description: "インターネット回線に問題があるか、サーバーがダウンまたはメンテナンスしている可能性があります。しばらくしてから{再度お試し}ください。" | ||||
| @@ -216,6 +286,13 @@ common/views/widgets/broadcast.vue: | ||||
|   no-broadcasts: "お知らせはありません" | ||||
|   have-a-nice-day: "良い一日を!" | ||||
|   next: "次" | ||||
| common/views/widgets/calendar.vue: | ||||
|   year: "{}年" | ||||
|   month: "{}月" | ||||
|   day: "{}日" | ||||
|   today: "今日:" | ||||
|   this-month: "今月:" | ||||
|   this-year: "今年:" | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "寄付のお願い" | ||||
|   text: "Misskeyの運営にはドメイン、サーバー等のコストが掛かります。Misskeyは広告を掲載したりしないため、収入を皆様からの寄付に頼っています。もしご興味があれば、{}までご連絡ください。ご協力ありがとうございます。" | ||||
| @@ -228,6 +305,7 @@ common/views/widgets/posts-monitor.vue: | ||||
| common/views/widgets/hashtags.vue: | ||||
|   title: "ハッシュタグ" | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/widgets/server.vue: | ||||
|   title: "サーバー情報" | ||||
|   toggle: "表示を切り替え" | ||||
| @@ -235,6 +313,37 @@ common/views/widgets/memo.vue: | ||||
|   title: "付箋" | ||||
|   memo: "ここに書いて!" | ||||
|   save: "保存" | ||||
| common/views/widgets/slideshow.vue: | ||||
|   folder-customize-mode: "フォルダを指定するには、カスタマイズモードを終了してください" | ||||
|   folder: "クリックしてフォルダを指定してください" | ||||
|   no-image: "このフォルダには画像がありません" | ||||
| common/views/widgets/tips.vue: | ||||
|   tips-line1: "<kbd>t</kbd>でタイムラインにフォーカスできます" | ||||
|   tips-line2: "<kbd>p</kbd>または<kbd>n</kbd>で投稿フォームを開きます" | ||||
|   tips-line3: "投稿フォームにはファイルをドラッグ&ドロップできます" | ||||
|   tips-line4: "投稿フォームにクリップボードにある画像データをペーストできます" | ||||
|   tips-line5: "ドライブにファイルをドラッグ&ドロップしてアップロードできます" | ||||
|   tips-line6: "ドライブでファイルをドラッグしてフォルダ移動できます" | ||||
|   tips-line7: "ドライブでフォルダをドラッグしてフォルダ移動できます" | ||||
|   tips-line8: "ホームは設定からカスタマイズできます" | ||||
|   tips-line9: "MisskeyはAGPLv3です" | ||||
|   tips-line10: "タイムマシンウィジェットを利用すると、簡単に過去のタイムラインに遡れます" | ||||
|   tips-line11: "投稿の ... をクリックして、投稿をユーザーページにピン留めできます" | ||||
|   tips-line13: "投稿に添付したファイルは全てドライブに保存されます" | ||||
|   tips-line14: "ホームのカスタマイズ中、ウィジェットを右クリックしてデザインを変更できます" | ||||
|   tips-line17: "「**」でテキストを囲むと**強調表示**されます" | ||||
|   tips-line19: "いくつかのウィンドウはブラウザの外に切り離すことができます" | ||||
|   tips-line20: "カレンダーウィジェットのパーセンテージは、経過の割合を示しています" | ||||
|   tips-line21: "APIを利用してbotの開発なども行えます" | ||||
|   tips-line23: "まゆかわいいよまゆ" | ||||
|   tips-line24: "Misskeyは2014年にサービスを開始しました" | ||||
|   tips-line25: "対応ブラウザではMisskeyを開いていなくても通知を受け取れます" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
|   request-pending: "フォロー許可待ち" | ||||
|   follow-request: "フォロー申請" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "Black ... Total" | ||||
|   notes: "Blue ... Notes" | ||||
| @@ -270,6 +379,8 @@ desktop/views/components/drive.file.vue: | ||||
|   banner: "バナー" | ||||
|   contextmenu: | ||||
|     rename: "名前を変更" | ||||
|     mark-as-sensitive: "閲覧注意に設定" | ||||
|     unmark-as-sensitive: "閲覧注意を解除" | ||||
|     copy-url: "URLをコピー" | ||||
|     download: "ダウンロード" | ||||
|     else-files: "その他..." | ||||
| @@ -313,6 +424,12 @@ desktop/views/components/drive.vue: | ||||
|     create-folder: "フォルダーを作成" | ||||
|     upload: "ファイルをアップロード" | ||||
|     url-upload: "URLからアップロード" | ||||
| desktop/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| desktop/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| desktop/views/components/follow-button.vue: | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
| @@ -333,7 +450,7 @@ desktop/views/components/friends-maker.vue: | ||||
|   refresh: "もっと見る" | ||||
|   close: "閉じる" | ||||
| desktop/views/components/game-window.vue: | ||||
|   game: "オセロ" | ||||
|   game: "リバーシ" | ||||
| desktop/views/components/home.vue: | ||||
|   done: "完了" | ||||
|   add-widget: "ウィジェットを追加:" | ||||
| @@ -364,10 +481,14 @@ desktop/views/components/notes.note.vue: | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "読み込みに失敗しました。" | ||||
|   retry: "リトライ" | ||||
|   load-more: "もっと読み込む" | ||||
| desktop/views/components/notifications.vue: | ||||
|   more: "もっと見る" | ||||
|   empty: "ありません!" | ||||
| desktop/views/components/post-form.vue: | ||||
|   add-visible-user: "+ユーザーを追加" | ||||
|   attach-location-information: "位置情報を添付する" | ||||
|   hide-contents: "内容を隠す" | ||||
|   reply-placeholder: "この投稿への返信..." | ||||
|   quote-placeholder: "この投稿を引用..." | ||||
|   submit: "投稿" | ||||
| @@ -383,9 +504,15 @@ desktop/views/components/post-form.vue: | ||||
|   attach-media-from-local: "PCからメディアを添付" | ||||
|   attach-media-from-drive: "ドライブからメディアを添付" | ||||
|   attach-cancel: "添付取り消し" | ||||
|   insert-a-kao: "v(‘ω’)v" | ||||
|   insert-a-kao: "v('ω')v" | ||||
|   create-poll: "アンケートを作成" | ||||
|   text-remain: "残り{}文字" | ||||
|   recent-tags: "最近" | ||||
|   click-to-tagging: "クリックでタグ付け" | ||||
|   visibility: "公開範囲" | ||||
|   geolocation-alert: "お使いの端末は位置情報に対応していません" | ||||
|   error: "エラー" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
| desktop/views/components/post-form-window.vue: | ||||
|   note: "新規投稿" | ||||
|   reply: "返信" | ||||
| @@ -426,6 +553,8 @@ desktop/views/components/settings.vue: | ||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||
|   display: "デザインと表示" | ||||
|   customize: "ホームをカスタマイズ" | ||||
|   choose-wallpaper: "壁紙を選択" | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" | ||||
| @@ -504,6 +633,9 @@ desktop/views/components/settings.api.vue: | ||||
|   enter-password: "パスワードを入力してください" | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "連携しているアプリケーションはありません" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "中" | ||||
|   in-use: "使用中" | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "ミュートしているユーザーはいません" | ||||
| desktop/views/components/settings.password.vue: | ||||
| @@ -521,8 +653,12 @@ desktop/views/components/settings.profile.vue: | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "投稿を非公開にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   profile-updated: "プロフィールを更新しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| @@ -533,15 +669,18 @@ desktop/views/components/taskmanager.vue: | ||||
| desktop/views/components/timeline.vue: | ||||
|   home: "ホーム" | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
|   list: "リスト" | ||||
| desktop/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "プロフィール" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
|   customize: "カスタマイズ" | ||||
|   customize: "ホームのカスタマイズ" | ||||
|   settings: "設定" | ||||
|   signout: "サインアウト" | ||||
|   dark: "闇に飲まれる" | ||||
| @@ -580,6 +719,7 @@ desktop/views/components/window.vue: | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   is-media-only: "メディア投稿のみ" | ||||
|   is-media-view: "メディアビュー" | ||||
|   edit: "オプション" | ||||
| desktop/views/pages/deck/deck.note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   private: "この投稿は非公開です" | ||||
| @@ -592,6 +732,7 @@ desktop/views/pages/welcome.vue: | ||||
|   signin-button: "やってる" | ||||
|   signup-button: "やる" | ||||
|   timeline: "タイムライン" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
| desktop/views/pages/drive.vue: | ||||
|   title: "Misskey Drive" | ||||
| desktop/views/pages/favorites.vue: | ||||
| @@ -606,6 +747,14 @@ desktop/views/pages/selectdrive.vue: | ||||
|   ok: "決定" | ||||
|   cancel: "キャンセル" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| desktop/views/pages/search.vue: | ||||
|   not-available: "検索機能を利用することができません。" | ||||
|   not-found: "「{}」に関する投稿は見つかりませんでした。" | ||||
| desktop/views/pages/share.vue: | ||||
|   share-with: "Misskeyで共有" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| desktop/views/pages/user-list.users.vue: | ||||
|   users: "ユーザー" | ||||
|   add-user: "ユーザーを追加" | ||||
| @@ -618,7 +767,7 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   title: "よく話すユーザー" | ||||
|   loading: "読み込み中" | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
| @@ -636,6 +785,11 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "ミュートする" | ||||
|   muted: "ミュートしています" | ||||
|   unmute: "ミュート解除" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   is-bot: "このアカウントはBotです" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "投稿" | ||||
|   with-replies: "投稿と返信" | ||||
| @@ -692,6 +846,12 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   move: "移動" | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/media-video.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| mobile/views/components/follow-button.vue: | ||||
|   following: "フォロー中" | ||||
|   follow: "フォロー" | ||||
| @@ -750,6 +910,8 @@ mobile/views/components/sub-note-content.vue: | ||||
| mobile/views/components/timeline.vue: | ||||
|   empty: "投稿がありません" | ||||
|   load-more: "もっと" | ||||
| mobile/views/components/ui.header.vue: | ||||
|   welcome-back: "おかえりなさい、" | ||||
| mobile/views/components/ui.nav.vue: | ||||
|   timeline: "タイムライン" | ||||
|   notifications: "通知" | ||||
| @@ -780,6 +942,8 @@ mobile/views/pages/user-lists.vue: | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   more: "もっと見る" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "📦 始めましょう" | ||||
| mobile/views/pages/followers.vue: | ||||
|   followers-of: "{}のフォロワー" | ||||
| mobile/views/pages/following.vue: | ||||
| @@ -787,7 +951,16 @@ mobile/views/pages/following.vue: | ||||
| mobile/views/pages/home.vue: | ||||
|   home: "ホーム" | ||||
|   local: "ローカル" | ||||
|   hybrid: "ソーシャル" | ||||
|   global: "グローバル" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{}」が付けられた投稿は見つかりませんでした。" | ||||
| mobile/views/pages/welcome.vue: | ||||
|   signup: "新規登録" | ||||
| mobile/views/pages/widgets.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
| mobile/views/pages/widgets/activity.vue: | ||||
|   activity: "アクティビティ" | ||||
| mobile/views/pages/messaging.vue: | ||||
|   messaging: "メッセージ" | ||||
| mobile/views/pages/messaging-room.vue: | ||||
| @@ -803,6 +976,8 @@ mobile/views/pages/note.vue: | ||||
| mobile/views/pages/notifications.vue: | ||||
|   notifications: "通知" | ||||
|   read-all: "すべての通知を既読にしますか?" | ||||
| mobile/views/pages/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
| @@ -900,11 +1075,17 @@ docs: | ||||
|       properties: "プロパティ" | ||||
|     endpoints: | ||||
|       params: "パラメータ" | ||||
|       no-params: "パラメータはありません" | ||||
|       res: "レスポンス" | ||||
|       require-credential: "このエンドポイントは認証情報が必須です。" | ||||
|       require-permission: "このエンドポイントは{permission}の権限を必要とします。" | ||||
|       has-limit: "レートリミットがあります。" | ||||
|       duration-limit: "直近{duration}ミリ秒の間のこのエンドポイントへのリクエスト数の合計が{max}を超える場合はリクエストできません。" | ||||
|       min-interval-limit: "前回のリクエストから{interval}ミリ秒経っていない場合はリクエストできません。" | ||||
|       show-src: "このエンドポイントのソースコードも閲覧できます。" | ||||
|       show-src-link: "コードをGitHubで見る" | ||||
|       generated: "このドキュメントはAPI定義に基づき自動生成されています。" | ||||
|     props: | ||||
|       name: "名前" | ||||
|       type: "型" | ||||
|       optional: "オプション" | ||||
|       description: "説明" | ||||
|       yes: "はい" | ||||
|       no: "いいえ" | ||||
|   | ||||
| @@ -1,11 +0,0 @@ | ||||
| Misskeyの破壊的変更に対応するいくつかのスニペットがあります。 | ||||
| MongoDBシェルで実行する必要のあるものとnodeで直接実行する必要のあるものがあります。 | ||||
| ファイル名が `shell.` から始まるものは前者、 `node.` から始まるものは後者です。 | ||||
|  | ||||
| MongoDBシェルで実行する場合、`use`でデータベースを選択しておく必要があります。 | ||||
|  | ||||
| nodeで実行するいくつかのスニペットは、並列処理させる数を引数で設定できるものがあります。 | ||||
| 処理中にエラーで落ちる場合は、メモリが足りていない可能性があるので、少ない数に設定してみてください。 | ||||
| ※デフォルトは`5`です。 | ||||
|  | ||||
| ファイルを作成する際は `../init-migration-file.sh -t _type_ -n _name_` を実行すると _type_._unixtime_._name_.js が生成されます | ||||
| @@ -1,37 +0,0 @@ | ||||
| #!/bin/bash | ||||
|  | ||||
| usage() { | ||||
| 		echo "$0 [-t type] [-n name]" | ||||
| 		echo "  type: [node | shell]" | ||||
| 		echo "  name: if no present, set untitled" | ||||
| 		exit 0 | ||||
| } | ||||
|  | ||||
| while getopts :t:n:h OPT | ||||
| do | ||||
| 	case $OPT in | ||||
| 		t)	type=$OPTARG | ||||
| 				;; | ||||
| 		n)	name=$OPTARG | ||||
| 				;; | ||||
| 		h)	usage | ||||
| 				;; | ||||
| 		\?) usage | ||||
| 				;; | ||||
| 		:)	usage | ||||
| 				;; | ||||
| 	esac | ||||
| done | ||||
|  | ||||
| if [ "$type" = "" ] | ||||
| then | ||||
| 	echo "no type present!!!" | ||||
| 	usage | ||||
| fi | ||||
|  | ||||
| if [ "$name" = "" ] | ||||
| then | ||||
| 	name="untitled" | ||||
| fi | ||||
|  | ||||
| touch "$(realpath $(dirname $BASH_SOURCE))/migration/$type.$(date +%s).$name.js" | ||||
							
								
								
									
										308
									
								
								package.json
									
									
									
									
									
								
							
							
						
						| @@ -1,21 +1,18 @@ | ||||
| { | ||||
| 	"name": "misskey", | ||||
| 	"author": "syuilo <i@syuilo.com>", | ||||
| 	"version": "2.38.3", | ||||
| 	"clientVersion": "1.0.6486", | ||||
| 	"version": "5.10.0", | ||||
| 	"clientVersion": "1.0.7828", | ||||
| 	"codename": "nighthike", | ||||
| 	"main": "./built/index.js", | ||||
| 	"private": true, | ||||
| 	"scripts": { | ||||
| 		"config": "node ./cli/init.js", | ||||
| 		"start": "node ./built", | ||||
| 		"debug": "DEBUG=misskey:* node ./built", | ||||
| 		"swagger": "node ./swagger.js", | ||||
| 		"build": "webpack && gulp build", | ||||
| 		"webpack": "webpack", | ||||
| 		"watch": "webpack --watch", | ||||
| 		"gulp": "gulp build", | ||||
| 		"rebuild": "gulp rebuild", | ||||
| 		"clean": "gulp clean", | ||||
| 		"cleanall": "gulp cleanall", | ||||
| 		"lint": "gulp lint", | ||||
| @@ -23,30 +20,120 @@ | ||||
| 		"format": "gulp format" | ||||
| 	}, | ||||
| 	"dependencies": { | ||||
| 		"@fortawesome/fontawesome": "1.0.1", | ||||
| 		"@fortawesome/fontawesome-free-brands": "5.0.2", | ||||
| 		"@fortawesome/fontawesome-free-regular": "5.0.2", | ||||
| 		"@fortawesome/fontawesome-free-solid": "5.0.2", | ||||
| 		"@koa/cors": "2.2.1", | ||||
| 		"@fortawesome/fontawesome": "1.1.8", | ||||
| 		"@fortawesome/fontawesome-free-brands": "5.0.13", | ||||
| 		"@fortawesome/fontawesome-free-regular": "5.0.13", | ||||
| 		"@fortawesome/fontawesome-free-solid": "5.0.13", | ||||
| 		"@koa/cors": "2.2.2", | ||||
| 		"@prezzemolo/rap": "0.1.2", | ||||
| 		"@prezzemolo/zip": "0.0.3", | ||||
| 		"@types/bcryptjs": "2.4.1", | ||||
| 		"@types/dateformat": "1.0.1", | ||||
| 		"@types/debug": "0.0.30", | ||||
| 		"@types/deep-equal": "1.0.1", | ||||
| 		"@types/elasticsearch": "5.0.25", | ||||
| 		"@types/file-type": "5.2.1", | ||||
| 		"@types/gulp": "3.8.36", | ||||
| 		"@types/gulp-htmlmin": "1.3.32", | ||||
| 		"@types/gulp-mocha": "0.0.32", | ||||
| 		"@types/gulp-rename": "0.0.33", | ||||
| 		"@types/gulp-replace": "0.0.31", | ||||
| 		"@types/gulp-uglify": "3.0.5", | ||||
| 		"@types/gulp-util": "3.0.34", | ||||
| 		"@types/is-root": "1.0.0", | ||||
| 		"@types/is-url": "1.2.28", | ||||
| 		"@types/js-yaml": "3.11.2", | ||||
| 		"@types/jsdom": "11.0.6", | ||||
| 		"@types/koa": "2.0.46", | ||||
| 		"@types/koa-bodyparser": "5.0.1", | ||||
| 		"@types/koa-compress": "2.0.8", | ||||
| 		"@types/koa-favicon": "2.0.19", | ||||
| 		"@types/koa-logger": "3.1.0", | ||||
| 		"@types/koa-mount": "3.0.1", | ||||
| 		"@types/koa-multer": "1.0.0", | ||||
| 		"@types/koa-router": "7.0.31", | ||||
| 		"@types/koa-send": "4.1.1", | ||||
| 		"@types/koa-views": "2.0.3", | ||||
| 		"@types/koa__cors": "2.2.3", | ||||
| 		"@types/minio": "6.0.2", | ||||
| 		"@types/mkdirp": "0.5.2", | ||||
| 		"@types/mocha": "5.2.3", | ||||
| 		"@types/mongodb": "3.1.2", | ||||
| 		"@types/ms": "0.7.30", | ||||
| 		"@types/node": "10.5.5", | ||||
| 		"@types/parse5": "5.0.0", | ||||
| 		"@types/portscanner": "2.1.0", | ||||
| 		"@types/pug": "2.0.4", | ||||
| 		"@types/qrcode": "1.2.0", | ||||
| 		"@types/ratelimiter": "2.1.28", | ||||
| 		"@types/redis": "2.8.6", | ||||
| 		"@types/request": "2.47.1", | ||||
| 		"@types/request-promise-native": "1.0.15", | ||||
| 		"@types/rimraf": "2.0.2", | ||||
| 		"@types/seedrandom": "2.4.27", | ||||
| 		"@types/sharp": "0.17.9", | ||||
| 		"@types/showdown": "1.7.5", | ||||
| 		"@types/single-line-log": "1.1.0", | ||||
| 		"@types/speakeasy": "2.0.2", | ||||
| 		"@types/systeminformation": "3.23.0", | ||||
| 		"@types/tmp": "0.0.33", | ||||
| 		"@types/uuid": "3.4.3", | ||||
| 		"@types/webpack": "4.4.8", | ||||
| 		"@types/webpack-stream": "3.2.10", | ||||
| 		"@types/websocket": "0.0.39", | ||||
| 		"@types/ws": "5.1.2", | ||||
| 		"animejs": "2.2.0", | ||||
| 		"autosize": "4.0.2", | ||||
| 		"autwh": "0.1.0", | ||||
| 		"bcryptjs": "2.4.3", | ||||
| 		"cafy": "8.0.0", | ||||
| 		"bee-queue": "1.2.2", | ||||
| 		"bootstrap-vue": "2.0.0-rc.11", | ||||
| 		"cafy": "11.3.0", | ||||
| 		"chalk": "2.4.1", | ||||
| 		"commander": "2.16.0", | ||||
| 		"crc-32": "1.2.0", | ||||
| 		"css-loader": "1.0.0", | ||||
| 		"dateformat": "3.0.3", | ||||
| 		"debug": "3.1.0", | ||||
| 		"deep-equal": "1.0.1", | ||||
| 		"deepcopy": "0.6.3", | ||||
| 		"diskusage": "0.2.4", | ||||
| 		"elasticsearch": "15.0.0", | ||||
| 		"emojilib": "2.2.12", | ||||
| 		"dompurify": "1.0.5", | ||||
| 		"elasticsearch": "15.1.1", | ||||
| 		"element-ui": "2.4.5", | ||||
| 		"emojilib": "2.3.0", | ||||
| 		"escape-regexp": "0.0.1", | ||||
| 		"file-type": "8.0.0", | ||||
| 		"gm": "1.23.1", | ||||
| 		"eslint": "5.0.1", | ||||
| 		"eslint-plugin-vue": "4.7.1", | ||||
| 		"eventemitter3": "3.1.0", | ||||
| 		"exif-js": "2.3.0", | ||||
| 		"file-loader": "1.1.11", | ||||
| 		"file-type": "8.1.0", | ||||
| 		"fuckadblock": "3.2.1", | ||||
| 		"gulp": "3.9.1", | ||||
| 		"gulp-cssnano": "2.1.3", | ||||
| 		"gulp-htmlmin": "4.0.0", | ||||
| 		"gulp-imagemin": "4.1.0", | ||||
| 		"gulp-mocha": "6.0.0", | ||||
| 		"gulp-pug": "4.0.1", | ||||
| 		"gulp-rename": "1.4.0", | ||||
| 		"gulp-replace": "1.0.0", | ||||
| 		"gulp-sourcemaps": "2.6.4", | ||||
| 		"gulp-stylus": "2.7.0", | ||||
| 		"gulp-tslint": "8.1.3", | ||||
| 		"gulp-typescript": "4.0.2", | ||||
| 		"gulp-uglify": "3.0.1", | ||||
| 		"gulp-util": "3.0.8", | ||||
| 		"hard-source-webpack-plugin": "0.12.0", | ||||
| 		"highlight.js": "9.12.0", | ||||
| 		"html-minifier": "3.5.19", | ||||
| 		"http-signature": "1.2.0", | ||||
| 		"insert-text-at-cursor": "0.1.1", | ||||
| 		"is-root": "2.0.0", | ||||
| 		"is-url": "1.2.4", | ||||
| 		"js-yaml": "3.11.0", | ||||
| 		"jsdom": "11.11.0", | ||||
| 		"jquery": "3.3.1", | ||||
| 		"js-yaml": "3.12.0", | ||||
| 		"jsdom": "11.12.0", | ||||
| 		"koa": "2.5.1", | ||||
| 		"koa-bodyparser": "4.2.1", | ||||
| 		"koa-compress": "3.0.0", | ||||
| @@ -56,168 +143,89 @@ | ||||
| 		"koa-mount": "3.0.0", | ||||
| 		"koa-multer": "1.0.2", | ||||
| 		"koa-router": "7.4.0", | ||||
| 		"koa-send": "4.1.3", | ||||
| 		"koa-send": "5.0.0", | ||||
| 		"koa-slow": "2.1.0", | ||||
| 		"koa-views": "6.1.4", | ||||
| 		"kue": "0.11.6", | ||||
| 		"mongodb": "3.0.10", | ||||
| 		"loader-utils": "1.1.0", | ||||
| 		"mecab-async": "0.1.2", | ||||
| 		"minio": "6.0.0", | ||||
| 		"mkdirp": "0.5.1", | ||||
| 		"mocha": "5.2.0", | ||||
| 		"moji": "0.5.1", | ||||
| 		"mongodb": "3.1.1", | ||||
| 		"monk": "6.0.6", | ||||
| 		"ms": "2.1.1", | ||||
| 		"nopt": "4.0.1", | ||||
| 		"nan": "2.10.0", | ||||
| 		"node-sass": "4.9.2", | ||||
| 		"node-sass-json-importer": "3.3.1", | ||||
| 		"nprogress": "0.2.0", | ||||
| 		"object-assign-deep": "0.4.0", | ||||
| 		"on-build-webpack": "0.1.0", | ||||
| 		"os-utils": "0.0.14", | ||||
| 		"parse5": "5.0.0", | ||||
| 		"prominence": "0.2.0", | ||||
| 		"portscanner": "2.2.0", | ||||
| 		"progress-bar-webpack-plugin": "1.11.0", | ||||
| 		"promise-sequential": "1.1.1", | ||||
| 		"pug": "2.0.3", | ||||
| 		"punycode": "2.1.1", | ||||
| 		"qrcode": "1.2.0", | ||||
| 		"ratelimiter": "3.0.3", | ||||
| 		"qrcode": "1.2.2", | ||||
| 		"ratelimiter": "3.2.0", | ||||
| 		"recaptcha-promise": "0.1.3", | ||||
| 		"reconnecting-websocket": "3.2.2", | ||||
| 		"redis": "2.8.0", | ||||
| 		"request": "2.87.0", | ||||
| 		"request-promise-native": "1.0.5", | ||||
| 		"rndstr": "1.0.0", | ||||
| 		"speakeasy": "2.0.0", | ||||
| 		"summaly": "2.0.6", | ||||
| 		"tcp-port-used": "0.1.2", | ||||
| 		"tmp": "0.0.33", | ||||
| 		"uuid": "3.2.1", | ||||
| 		"web-push": "3.3.1", | ||||
| 		"webfinger.js": "2.6.6", | ||||
| 		"websocket": "1.0.26", | ||||
| 		"ws": "5.2.0", | ||||
| 		"xev": "2.0.1" | ||||
| 	}, | ||||
| 	"devDependencies": { | ||||
| 		"@prezzemolo/zip": "0.0.3", | ||||
| 		"@types/bcryptjs": "2.4.1", | ||||
| 		"@types/debug": "0.0.30", | ||||
| 		"@types/deep-equal": "1.0.1", | ||||
| 		"@types/elasticsearch": "5.0.23", | ||||
| 		"@types/gm": "1.18.0", | ||||
| 		"@types/gulp": "3.8.36", | ||||
| 		"@types/gulp-htmlmin": "1.3.32", | ||||
| 		"@types/gulp-mocha": "0.0.32", | ||||
| 		"@types/gulp-rename": "0.0.33", | ||||
| 		"@types/gulp-replace": "0.0.31", | ||||
| 		"@types/gulp-uglify": "3.0.5", | ||||
| 		"@types/gulp-util": "3.0.34", | ||||
| 		"@types/inquirer": "0.0.41", | ||||
| 		"@types/is-root": "1.0.0", | ||||
| 		"@types/is-url": "1.2.28", | ||||
| 		"@types/js-yaml": "3.11.1", | ||||
| 		"@types/koa": "2.0.45", | ||||
| 		"@types/koa-bodyparser": "4.2.0", | ||||
| 		"@types/koa-compress": "2.0.8", | ||||
| 		"@types/koa-favicon": "2.0.19", | ||||
| 		"@types/koa-logger": "3.1.0", | ||||
| 		"@types/koa-mount": "3.0.1", | ||||
| 		"@types/koa-multer": "1.0.0", | ||||
| 		"@types/koa-router": "7.0.28", | ||||
| 		"@types/koa-send": "4.1.1", | ||||
| 		"@types/koa-views": "2.0.3", | ||||
| 		"@types/koa__cors": "2.2.2", | ||||
| 		"@types/kue": "0.11.8", | ||||
| 		"@types/license-checker": "15.0.0", | ||||
| 		"@types/mkdirp": "0.5.2", | ||||
| 		"@types/mocha": "5.2.0", | ||||
| 		"@types/mongodb": "3.0.18", | ||||
| 		"@types/ms": "0.7.30", | ||||
| 		"@types/node": "10.1.2", | ||||
| 		"@types/nopt": "3.0.29", | ||||
| 		"@types/parse5": "3.0.0", | ||||
| 		"@types/pug": "2.0.4", | ||||
| 		"@types/qrcode": "0.8.1", | ||||
| 		"@types/ratelimiter": "2.1.28", | ||||
| 		"@types/redis": "2.8.6", | ||||
| 		"@types/request": "2.47.0", | ||||
| 		"@types/request-promise-native": "1.0.14", | ||||
| 		"@types/rimraf": "2.0.2", | ||||
| 		"@types/seedrandom": "2.4.27", | ||||
| 		"@types/single-line-log": "1.1.0", | ||||
| 		"@types/speakeasy": "2.0.2", | ||||
| 		"@types/tmp": "0.0.33", | ||||
| 		"@types/uuid": "3.4.3", | ||||
| 		"@types/webpack": "4.4.0", | ||||
| 		"@types/webpack-stream": "3.2.10", | ||||
| 		"@types/websocket": "0.0.39", | ||||
| 		"@types/ws": "5.1.1", | ||||
| 		"animejs": "2.2.0", | ||||
| 		"autosize": "4.0.2", | ||||
| 		"bootstrap-vue": "2.0.0-rc.6", | ||||
| 		"css-loader": "0.28.11", | ||||
| 		"deep-equal": "1.0.1", | ||||
| 		"dompurify": "1.0.4", | ||||
| 		"element-ui": "2.3.9", | ||||
| 		"eslint": "4.19.1", | ||||
| 		"eslint-plugin-vue": "4.5.0", | ||||
| 		"eventemitter3": "3.1.0", | ||||
| 		"exif-js": "2.3.0", | ||||
| 		"file-loader": "1.1.11", | ||||
| 		"fuckadblock": "3.2.1", | ||||
| 		"gulp": "3.9.1", | ||||
| 		"gulp-cssnano": "2.1.3", | ||||
| 		"gulp-htmlmin": "4.0.0", | ||||
| 		"gulp-imagemin": "4.1.0", | ||||
| 		"gulp-mocha": "6.0.0", | ||||
| 		"gulp-pug": "4.0.1", | ||||
| 		"gulp-rename": "1.2.3", | ||||
| 		"gulp-replace": "1.0.0", | ||||
| 		"gulp-sourcemaps": "2.6.4", | ||||
| 		"gulp-stylus": "2.7.0", | ||||
| 		"gulp-tslint": "8.1.3", | ||||
| 		"gulp-typescript": "4.0.2", | ||||
| 		"gulp-uglify": "3.0.0", | ||||
| 		"gulp-util": "3.0.8", | ||||
| 		"hard-source-webpack-plugin": "0.6.10", | ||||
| 		"highlight.js": "9.12.0", | ||||
| 		"html-minifier": "3.5.16", | ||||
| 		"inquirer": "5.2.0", | ||||
| 		"license-checker": "20.0.0", | ||||
| 		"loader-utils": "1.1.0", | ||||
| 		"mecab-async": "0.1.2", | ||||
| 		"mkdirp": "0.5.1", | ||||
| 		"mocha": "5.2.0", | ||||
| 		"moji": "0.5.1", | ||||
| 		"nan": "2.10.0", | ||||
| 		"node-sass": "4.9.0", | ||||
| 		"node-sass-json-importer": "3.2.0", | ||||
| 		"nprogress": "0.2.0", | ||||
| 		"object-assign-deep": "0.4.0", | ||||
| 		"on-build-webpack": "0.1.0", | ||||
| 		"progress-bar-webpack-plugin": "1.11.0", | ||||
| 		"pug": "2.0.3", | ||||
| 		"rimraf": "2.6.2", | ||||
| 		"rndstr": "1.0.0", | ||||
| 		"s-age": "1.1.2", | ||||
| 		"sass-loader": "7.0.1", | ||||
| 		"sass-loader": "7.1.0", | ||||
| 		"seedrandom": "2.4.3", | ||||
| 		"sharp": "0.20.5", | ||||
| 		"showdown": "1.8.6", | ||||
| 		"showdown-highlightjs-extension": "0.1.2", | ||||
| 		"single-line-log": "1.1.2", | ||||
| 		"speakeasy": "2.0.0", | ||||
| 		"style-loader": "0.21.0", | ||||
| 		"stylus": "0.54.5", | ||||
| 		"stylus-loader": "3.0.2", | ||||
| 		"swagger-jsdoc": "1.9.7", | ||||
| 		"summaly": "2.0.6", | ||||
| 		"systeminformation": "3.42.4", | ||||
| 		"syuilo-password-strength": "0.0.1", | ||||
| 		"textarea-caret": "3.1.0", | ||||
| 		"ts-loader": "4.3.0", | ||||
| 		"ts-node": "6.0.4", | ||||
| 		"tmp": "0.0.33", | ||||
| 		"ts-loader": "4.4.1", | ||||
| 		"ts-node": "7.0.0", | ||||
| 		"tslint": "5.10.0", | ||||
| 		"typescript": "2.8.3", | ||||
| 		"typescript-eslint-parser": "15.0.0", | ||||
| 		"typescript": "2.9.2", | ||||
| 		"typescript-eslint-parser": "17.0.1", | ||||
| 		"uglify-es": "3.3.9", | ||||
| 		"url-loader": "1.0.1", | ||||
| 		"uuid": "3.3.2", | ||||
| 		"v-animate-css": "0.0.2", | ||||
| 		"vue": "2.5.16", | ||||
| 		"vue-cropperjs": "2.2.0", | ||||
| 		"vue-js-modal": "1.3.13", | ||||
| 		"vue": "2.5.17", | ||||
| 		"vue-cropperjs": "2.2.1", | ||||
| 		"vue-js-modal": "1.3.16", | ||||
| 		"vue-json-tree-view": "2.1.4", | ||||
| 		"vue-loader": "15.2.1", | ||||
| 		"vue-material": "^1.0.0-beta-10.2", | ||||
| 		"vue-loader": "15.2.6", | ||||
| 		"vue-router": "3.0.1", | ||||
| 		"vue-template-compiler": "2.5.16", | ||||
| 		"vue-style-loader": "4.1.1", | ||||
| 		"vue-template-compiler": "2.5.17", | ||||
| 		"vuedraggable": "2.16.0", | ||||
| 		"vuex": "3.0.1", | ||||
| 		"vuex-persistedstate": "^2.5.4", | ||||
| 		"webpack": "4.9.1", | ||||
| 		"webpack-cli": "2.1.4" | ||||
| 		"vuex-persistedstate": "2.5.4", | ||||
| 		"web-push": "3.3.2", | ||||
| 		"webfinger.js": "2.6.6", | ||||
| 		"webpack": "4.16.3", | ||||
| 		"webpack-cli": "3.1.0", | ||||
| 		"websocket": "1.0.26", | ||||
| 		"ws": "6.0.0", | ||||
| 		"xev": "2.0.1" | ||||
| 	}, | ||||
| 	"greenkeeper": { | ||||
| 		"ignore": [ | ||||
| 			"deepcopy", | ||||
| 			"cafy", | ||||
| 			"@types/gulp" | ||||
| 		] | ||||
| 	} | ||||
| } | ||||
|   | ||||
| @@ -1,3 +0,0 @@ | ||||
| export default user => { | ||||
| 	return user.host === null ? user.username : `${user.username}@${user.host}`; | ||||
| }; | ||||
| @@ -7,11 +7,6 @@ html | ||||
| 			cursor progress !important | ||||
|  | ||||
| body | ||||
| 	// for md | ||||
| 	font-size 16px !important | ||||
| 	line-height initial !important | ||||
| 	letter-spacing initial !important | ||||
|  | ||||
| 	overflow-wrap break-word | ||||
|  | ||||
| #error | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
| <div class="form"> | ||||
| 	<header> | ||||
| 		<h1><i>{{ app.name }}</i>があなたのアカウントにアクセスすることを<b>許可</b>しますか?</h1> | ||||
| 		<img :src="`${app.iconUrl}?thumbnail&size=64`"/> | ||||
| 		<img :src="app.iconUrl"/> | ||||
| 	</header> | ||||
| 	<div class="app"> | ||||
| 		<section> | ||||
|   | ||||
| @@ -1,16 +0,0 @@ | ||||
| export default function(note) { | ||||
| 	if (note.text == null) return true; | ||||
|  | ||||
| 	let txt = note.text; | ||||
|  | ||||
| 	if (note.media) { | ||||
| 		note.media.forEach(file => { | ||||
| 			txt = txt.replace(file.url, ''); | ||||
| 			if (file.src) txt = txt.replace(file.src, ''); | ||||
| 		}); | ||||
|  | ||||
| 		if (txt == '') return true; | ||||
| 	} | ||||
|  | ||||
| 	return false; | ||||
| } | ||||
| @@ -23,7 +23,10 @@ export default async function(mios: MiOS, force = false, silent = false) { | ||||
| 		} | ||||
|  | ||||
| 		if (!silent) { | ||||
| 			alert('%i18n:common.update-available%'.replace('{newer}', newer).replace('{current}', current)); | ||||
| 			mios.apis.dialog({ | ||||
| 				title: '%i18n:common.update-available-title%', | ||||
| 				text: '%i18n:common.update-available%'.replace('{newer}', newer).replace('{current}', current) | ||||
| 			}); | ||||
| 		} | ||||
|  | ||||
| 		return newer; | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| import getNoteSummary from '../../../../renderers/get-note-summary'; | ||||
| import getReactionEmoji from '../../../../renderers/get-reaction-emoji'; | ||||
| import getUserName from '../../../../renderers/get-user-name'; | ||||
| import getNoteSummary from '../../../../misc/get-note-summary'; | ||||
| import getReactionEmoji from '../../../../misc/get-reaction-emoji'; | ||||
| import getUserName from '../../../../misc/get-user-name'; | ||||
|  | ||||
| type Notification = { | ||||
| 	title: string; | ||||
| @@ -17,51 +17,57 @@ export default function(type, data): Notification { | ||||
| 			return { | ||||
| 				title: 'ファイルがアップロードされました', | ||||
| 				body: data.name, | ||||
| 				icon: data.url + '?thumbnail&size=64' | ||||
| 			}; | ||||
|  | ||||
| 		case 'mention': | ||||
| 			return { | ||||
| 				title: `${getUserName(data.user)}さんから:`, | ||||
| 				body: getNoteSummary(data), | ||||
| 				icon: data.user.avatarUrl + '?thumbnail&size=64' | ||||
| 			}; | ||||
|  | ||||
| 		case 'reply': | ||||
| 			return { | ||||
| 				title: `${getUserName(data.user)}さんから返信:`, | ||||
| 				body: getNoteSummary(data), | ||||
| 				icon: data.user.avatarUrl + '?thumbnail&size=64' | ||||
| 			}; | ||||
|  | ||||
| 		case 'quote': | ||||
| 			return { | ||||
| 				title: `${getUserName(data.user)}さんが引用:`, | ||||
| 				body: getNoteSummary(data), | ||||
| 				icon: data.user.avatarUrl + '?thumbnail&size=64' | ||||
| 			}; | ||||
|  | ||||
| 		case 'reaction': | ||||
| 			return { | ||||
| 				title: `${getUserName(data.user)}: ${getReactionEmoji(data.reaction)}:`, | ||||
| 				body: getNoteSummary(data.note), | ||||
| 				icon: data.user.avatarUrl + '?thumbnail&size=64' | ||||
| 				icon: data.url | ||||
| 			}; | ||||
|  | ||||
| 		case 'unread_messaging_message': | ||||
| 			return { | ||||
| 				title: `${getUserName(data.user)}さんからメッセージ:`, | ||||
| 				body: data.text, // TODO: getMessagingMessageSummary(data), | ||||
| 				icon: data.user.avatarUrl + '?thumbnail&size=64' | ||||
| 				icon: data.user.avatarUrl | ||||
| 			}; | ||||
|  | ||||
| 		case 'othello_invited': | ||||
| 		case 'reversi_invited': | ||||
| 			return { | ||||
| 				title: '対局への招待があります', | ||||
| 				body: `${getUserName(data.parent)}さんから`, | ||||
| 				icon: data.parent.avatarUrl + '?thumbnail&size=64' | ||||
| 				icon: data.parent.avatarUrl | ||||
| 			}; | ||||
|  | ||||
| 		case 'notification': | ||||
| 			switch (data.type) { | ||||
| 				case 'mention': | ||||
| 					return { | ||||
| 						title: `${getUserName(data.user)}さんから:`, | ||||
| 						body: getNoteSummary(data), | ||||
| 						icon: data.user.avatarUrl | ||||
| 					}; | ||||
|  | ||||
| 				case 'reply': | ||||
| 					return { | ||||
| 						title: `${getUserName(data.user)}さんから返信:`, | ||||
| 						body: getNoteSummary(data), | ||||
| 						icon: data.user.avatarUrl | ||||
| 					}; | ||||
|  | ||||
| 				case 'quote': | ||||
| 					return { | ||||
| 						title: `${getUserName(data.user)}さんが引用:`, | ||||
| 						body: getNoteSummary(data), | ||||
| 						icon: data.user.avatarUrl | ||||
| 					}; | ||||
|  | ||||
| 				case 'reaction': | ||||
| 					return { | ||||
| 						title: `${getUserName(data.user)}: ${getReactionEmoji(data.reaction)}:`, | ||||
| 						body: getNoteSummary(data.note), | ||||
| 						icon: data.user.avatarUrl | ||||
| 					}; | ||||
|  | ||||
| 				default: | ||||
| 					return null; | ||||
| 			} | ||||
|  | ||||
| 		default: | ||||
| 			return null; | ||||
| 	} | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| export default () => [ | ||||
| 	'(=^・・^=)', | ||||
| 	'v(‘ω’)v', | ||||
| 	'v(\'ω\')v', | ||||
| 	'🐡( \'-\' 🐡 )フグパンチ!!!!' | ||||
| ][Math.floor(Math.random() * 3)]; | ||||
|   | ||||
| @@ -0,0 +1,11 @@ | ||||
| import Stream from '../../stream'; | ||||
| import MiOS from '../../../../../mios'; | ||||
|  | ||||
| export class ReversiGameStream extends Stream { | ||||
| 	constructor(os: MiOS, me, game) { | ||||
| 		super(os, 'games/reversi-game', { | ||||
| 			i: me ? me.token : null, | ||||
| 			game: game.id | ||||
| 		}); | ||||
| 	} | ||||
| } | ||||
| @@ -0,0 +1,31 @@ | ||||
| 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,16 +1,19 @@ | ||||
| import StreamManager from './stream-manager'; | ||||
| import Stream from './stream'; | ||||
| import StreamManager from './stream-manager'; | ||||
| import MiOS from '../../../mios'; | ||||
| 
 | ||||
| export class OthelloStream extends Stream { | ||||
| /** | ||||
|  * Hybrid timeline stream connection | ||||
|  */ | ||||
| export class HybridTimelineStream extends Stream { | ||||
| 	constructor(os: MiOS, me) { | ||||
| 		super(os, 'othello', { | ||||
| 		super(os, 'hybrid-timeline', { | ||||
| 			i: me.token | ||||
| 		}); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| export class OthelloStreamManager extends StreamManager<OthelloStream> { | ||||
| export class HybridTimelineStreamManager extends StreamManager<HybridTimelineStream> { | ||||
| 	private me; | ||||
| 	private os: MiOS; | ||||
| 
 | ||||
| @@ -23,7 +26,7 @@ export class OthelloStreamManager extends StreamManager<OthelloStream> { | ||||
| 
 | ||||
| 	public getConnection() { | ||||
| 		if (this.connection == null) { | ||||
| 			this.connection = new OthelloStream(this.os, this.me); | ||||
| 			this.connection = new HybridTimelineStream(this.os, this.me); | ||||
| 		} | ||||
| 
 | ||||
| 		return this.connection; | ||||
| @@ -1,11 +0,0 @@ | ||||
| import Stream from './stream'; | ||||
| import MiOS from '../../../mios'; | ||||
|  | ||||
| export class OthelloGameStream extends Stream { | ||||
| 	constructor(os: MiOS, me, game) { | ||||
| 		super(os, 'othello-game', { | ||||
| 			i: me ? me.token : null, | ||||
| 			game: game.id | ||||
| 		}); | ||||
| 	} | ||||
| } | ||||
| @@ -39,13 +39,17 @@ export default Vue.extend({ | ||||
| 		dark: { | ||||
| 			type: Boolean, | ||||
| 			default: false | ||||
| 		}, | ||||
| 		smooth: { | ||||
| 			type: Boolean, | ||||
| 			default: false | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			now: new Date(), | ||||
| 			clock: null, | ||||
| 			enabled: true, | ||||
|  | ||||
| 			graduationsPadding: 0.5, | ||||
| 			handsPadding: 1, | ||||
| @@ -74,6 +78,9 @@ export default Vue.extend({ | ||||
| 			return themeColor; | ||||
| 		}, | ||||
|  | ||||
| 		ms(): number { | ||||
| 			return this.now.getMilliseconds() * this.smooth; | ||||
| 		} | ||||
| 		s(): number { | ||||
| 			return this.now.getSeconds(); | ||||
| 		}, | ||||
| @@ -85,13 +92,13 @@ export default Vue.extend({ | ||||
| 		}, | ||||
|  | ||||
| 		hAngle(): number { | ||||
| 			return Math.PI * (this.h % 12 + this.m / 60) / 6; | ||||
| 			return Math.PI * (this.h % 12 + (this.m + (this.s + this.ms / 1000) / 60) / 60) / 6; | ||||
| 		}, | ||||
| 		mAngle(): number { | ||||
| 			return Math.PI * (this.m + this.s / 60) / 30; | ||||
| 			return Math.PI * (this.m + (this.s + this.ms / 1000) / 60) / 30; | ||||
| 		}, | ||||
| 		sAngle(): number { | ||||
| 			return Math.PI * this.s / 30; | ||||
| 			return Math.PI * (this.s + this.ms / 1000) / 30; | ||||
| 		}, | ||||
|  | ||||
| 		graduations(): any { | ||||
| @@ -106,11 +113,17 @@ export default Vue.extend({ | ||||
| 	}, | ||||
|  | ||||
| 	mounted() { | ||||
| 		this.clock = setInterval(this.tick, 1000); | ||||
| 		const update = () => { | ||||
| 			if (this.enabled) { | ||||
| 				this.tick(); | ||||
| 				requestAnimationFrame(update); | ||||
| 			} | ||||
| 		}; | ||||
| 		update(); | ||||
| 	}, | ||||
|  | ||||
| 	beforeDestroy() { | ||||
| 		clearInterval(this.clock); | ||||
| 		this.enabled = false; | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
|   | ||||
| @@ -2,11 +2,16 @@ | ||||
| <div class="mk-autocomplete" @contextmenu.prevent="() => {}"> | ||||
| 	<ol class="users" ref="suggests" v-if="users.length > 0"> | ||||
| 		<li v-for="user in users" @click="complete(type, user)" @keydown="onKeydown" tabindex="-1"> | ||||
| 			<img class="avatar" :src="`${user.avatarUrl}?thumbnail&size=32`" alt=""/> | ||||
| 			<img class="avatar" :src="user.avatarUrl" alt=""/> | ||||
| 			<span class="name">{{ user | userName }}</span> | ||||
| 			<span class="username">@{{ user | acct }}</span> | ||||
| 		</li> | ||||
| 	</ol> | ||||
| 	<ol class="hashtags" ref="suggests" v-if="hashtags.length > 0"> | ||||
| 		<li v-for="hashtag in hashtags" @click="complete(type, hashtag)" @keydown="onKeydown" tabindex="-1"> | ||||
| 			<span class="name">{{ hashtag }}</span> | ||||
| 		</li> | ||||
| 	</ol> | ||||
| 	<ol class="emojis" ref="suggests" v-if="emojis.length > 0"> | ||||
| 		<li v-for="emoji in emojis" @click="complete(type, emoji.emoji)" @keydown="onKeydown" tabindex="-1"> | ||||
| 			<span class="emoji">{{ emoji.emoji }}</span> | ||||
| @@ -48,33 +53,33 @@ emjdb.sort((a, b) => a.name.length - b.name.length); | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: ['type', 'q', 'textarea', 'complete', 'close', 'x', 'y'], | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			fetching: true, | ||||
| 			users: [], | ||||
| 			hashtags: [], | ||||
| 			emojis: [], | ||||
| 			select: -1, | ||||
| 			emojilib | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	computed: { | ||||
| 		items(): HTMLCollection { | ||||
| 			return (this.$refs.suggests as Element).children; | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	updated() { | ||||
| 		//#region 位置調整 | ||||
| 		const margin = 32; | ||||
|  | ||||
| 		if (this.x + this.$el.offsetWidth > window.innerWidth - margin) { | ||||
| 			this.$el.style.left = (this.x - this.$el.offsetWidth) + 'px'; | ||||
| 			this.$el.style.marginLeft = '-16px'; | ||||
| 		if (this.x + this.$el.offsetWidth > window.innerWidth) { | ||||
| 			this.$el.style.left = (window.innerWidth - this.$el.offsetWidth) + 'px'; | ||||
| 		} else { | ||||
| 			this.$el.style.left = this.x + 'px'; | ||||
| 			this.$el.style.marginLeft = '0'; | ||||
| 		} | ||||
|  | ||||
| 		if (this.y + this.$el.offsetHeight > window.innerHeight - margin) { | ||||
| 		if (this.y + this.$el.offsetHeight > window.innerHeight) { | ||||
| 			this.$el.style.top = (this.y - this.$el.offsetHeight) + 'px'; | ||||
| 			this.$el.style.marginTop = '0'; | ||||
| 		} else { | ||||
| @@ -83,6 +88,7 @@ export default Vue.extend({ | ||||
| 		} | ||||
| 		//#endregion | ||||
| 	}, | ||||
|  | ||||
| 	mounted() { | ||||
| 		this.textarea.addEventListener('keydown', this.onKeydown); | ||||
|  | ||||
| @@ -100,6 +106,7 @@ export default Vue.extend({ | ||||
| 			}); | ||||
| 		}); | ||||
| 	}, | ||||
|  | ||||
| 	beforeDestroy() { | ||||
| 		this.textarea.removeEventListener('keydown', this.onKeydown); | ||||
|  | ||||
| @@ -107,6 +114,7 @@ export default Vue.extend({ | ||||
| 			el.removeEventListener('mousedown', this.onMousedown); | ||||
| 		}); | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		exec() { | ||||
| 			this.select = -1; | ||||
| @@ -117,7 +125,8 @@ export default Vue.extend({ | ||||
| 			} | ||||
|  | ||||
| 			if (this.type == 'user') { | ||||
| 				const cache = sessionStorage.getItem(this.q); | ||||
| 				const cacheKey = 'autocomplete:user:' + this.q; | ||||
| 				const cache = sessionStorage.getItem(cacheKey); | ||||
| 				if (cache) { | ||||
| 					const users = JSON.parse(cache); | ||||
| 					this.users = users; | ||||
| @@ -131,9 +140,33 @@ export default Vue.extend({ | ||||
| 						this.fetching = false; | ||||
|  | ||||
| 						// キャッシュ | ||||
| 						sessionStorage.setItem(this.q, JSON.stringify(users)); | ||||
| 						sessionStorage.setItem(cacheKey, JSON.stringify(users)); | ||||
| 					}); | ||||
| 				} | ||||
| 			} else if (this.type == 'hashtag') { | ||||
| 				if (this.q == null || this.q == '') { | ||||
| 					this.hashtags = JSON.parse(localStorage.getItem('hashtags') || '[]'); | ||||
| 					this.fetching = false; | ||||
| 				} else { | ||||
| 					const cacheKey = 'autocomplete:hashtag:' + this.q; | ||||
| 					const cache = sessionStorage.getItem(cacheKey); | ||||
| 					if (cache) { | ||||
| 						const hashtags = JSON.parse(cache); | ||||
| 						this.hashtags = hashtags; | ||||
| 						this.fetching = false; | ||||
| 					} else { | ||||
| 						(this as any).api('hashtags/search', { | ||||
| 							query: this.q, | ||||
| 							limit: 30 | ||||
| 						}).then(hashtags => { | ||||
| 							this.hashtags = hashtags; | ||||
| 							this.fetching = false; | ||||
|  | ||||
| 							// キャッシュ | ||||
| 							sessionStorage.setItem(cacheKey, JSON.stringify(hashtags)); | ||||
| 						}); | ||||
| 					} | ||||
| 				} | ||||
| 			} else if (this.type == 'emoji') { | ||||
| 				const matched = []; | ||||
| 				emjdb.some(x => { | ||||
| @@ -228,12 +261,13 @@ export default Vue.extend({ | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| .mk-autocomplete | ||||
| root(isDark) | ||||
| 	position fixed | ||||
| 	z-index 65535 | ||||
| 	max-width 100% | ||||
| 	margin-top calc(1em + 8px) | ||||
| 	overflow hidden | ||||
| 	background #fff | ||||
| 	background isDark ? #313543 : #fff | ||||
| 	border solid 1px rgba(#000, 0.1) | ||||
| 	border-radius 4px | ||||
| 	transition top 0.1s ease, left 0.1s ease | ||||
| @@ -248,7 +282,8 @@ export default Vue.extend({ | ||||
| 		list-style none | ||||
|  | ||||
| 		> li | ||||
| 			display block | ||||
| 			display flex | ||||
| 			align-items center | ||||
| 			padding 4px 12px | ||||
| 			white-space nowrap | ||||
| 			overflow hidden | ||||
| @@ -259,7 +294,13 @@ export default Vue.extend({ | ||||
| 			&, * | ||||
| 				user-select none | ||||
|  | ||||
| 			* | ||||
| 				overflow hidden | ||||
| 				text-overflow ellipsis | ||||
|  | ||||
| 			&:hover | ||||
| 				background isDark ? rgba(#fff, 0.1) : rgba(#000, 0.1) | ||||
|  | ||||
| 			&[data-selected='true'] | ||||
| 				background $theme-color | ||||
|  | ||||
| @@ -275,7 +316,6 @@ export default Vue.extend({ | ||||
| 	> .users > li | ||||
|  | ||||
| 		.avatar | ||||
| 			vertical-align middle | ||||
| 			min-width 28px | ||||
| 			min-height 28px | ||||
| 			max-width 28px | ||||
| @@ -285,10 +325,15 @@ export default Vue.extend({ | ||||
|  | ||||
| 		.name | ||||
| 			margin 0 8px 0 0 | ||||
| 			color rgba(#000, 0.8) | ||||
| 			color isDark ? rgba(#fff, 0.8) : rgba(#000, 0.8) | ||||
|  | ||||
| 		.username | ||||
| 			color rgba(#000, 0.3) | ||||
| 			color isDark ? rgba(#fff, 0.3) : rgba(#000, 0.3) | ||||
|  | ||||
| 	> .hashtags > li | ||||
|  | ||||
| 		.name | ||||
| 			color isDark ? rgba(#fff, 0.8) : rgba(#000, 0.8) | ||||
|  | ||||
| 	> .emojis > li | ||||
|  | ||||
| @@ -298,10 +343,15 @@ export default Vue.extend({ | ||||
| 			width 24px | ||||
|  | ||||
| 		.name | ||||
| 			color rgba(#000, 0.8) | ||||
| 			color isDark ? rgba(#fff, 0.8) : rgba(#000, 0.8) | ||||
|  | ||||
| 		.alias | ||||
| 			margin 0 0 0 8px | ||||
| 			color rgba(#000, 0.3) | ||||
| 			color isDark ? rgba(#fff, 0.3) : rgba(#000, 0.3) | ||||
|  | ||||
| .mk-autocomplete[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .mk-autocomplete:not([data-darkmode]) | ||||
| 	root(false) | ||||
| </style> | ||||
|   | ||||
| @@ -31,7 +31,7 @@ export default Vue.extend({ | ||||
| 					: this.user.avatarColor && this.user.avatarColor.length == 3 | ||||
| 						? `rgb(${ this.user.avatarColor.join(',') })` | ||||
| 						: null, | ||||
| 				backgroundImage: this.lightmode ? null : `url(${ this.user.avatarUrl }?thumbnail)`, | ||||
| 				backgroundImage: this.lightmode ? null : `url(${ this.user.avatarUrl })`, | ||||
| 				borderRadius: this.$store.state.settings.circleIcons ? '100%' : null | ||||
| 			}; | ||||
| 		} | ||||
|   | ||||
| @@ -13,9 +13,6 @@ | ||||
|  | ||||
| .a | ||||
| 	display block | ||||
| 	position fixed | ||||
| 	top 0 | ||||
| 	right 0 | ||||
|  | ||||
| 	> svg | ||||
| 		display block | ||||
|   | ||||
| @@ -1,30 +1,45 @@ | ||||
| <template> | ||||
| <div class="root"> | ||||
| 	<header><b>{{ blackUser.name }}</b>(黒) vs <b>{{ whiteUser.name }}</b>(白)</header> | ||||
| 	<header><b>{{ blackUser | userName }}</b>(%i18n:common.reversi.black%) vs <b>{{ whiteUser | userName }}</b>(%i18n:common.reversi.white%)</header> | ||||
| 
 | ||||
| 	<div style="overflow: hidden"> | ||||
| 		<p class="turn" v-if="!iAmPlayer && !game.isEnded">{{ turnUser.name }}のターンです<mk-ellipsis/></p> | ||||
| 		<p class="turn" v-if="logPos != logs.length">{{ turnUser.name }}のターン</p> | ||||
| 		<p class="turn1" v-if="iAmPlayer && !game.isEnded && !isMyTurn">相手のターンです<mk-ellipsis/></p> | ||||
| 		<p class="turn2" v-if="iAmPlayer && !game.isEnded && isMyTurn" v-animate-css="{ classes: 'tada', iteration: 'infinite' }">あなたのターンです</p> | ||||
| 		<p class="turn" v-if="!iAmPlayer && !game.isEnded">{{ '%i18n:common.reversi.turn-of%'.replace('{}', turnUser | userName) }}<mk-ellipsis/></p> | ||||
| 		<p class="turn" v-if="logPos != logs.length">{{ '%i18n:common.reversi.past-turn-of%'.replace('{}', turnUser | userName) }}</p> | ||||
| 		<p class="turn1" v-if="iAmPlayer && !game.isEnded && !isMyTurn">%i18n:common.reversi.opponent-turn%<mk-ellipsis/></p> | ||||
| 		<p class="turn2" v-if="iAmPlayer && !game.isEnded && isMyTurn" v-animate-css="{ classes: 'tada', iteration: 'infinite' }">%i18n:common.reversi.my-turn%</p> | ||||
| 		<p class="result" v-if="game.isEnded && logPos == logs.length"> | ||||
| 			<template v-if="game.winner"><b>{{ game.winner.name }}</b>の勝ち{{ game.settings.isLlotheo ? ' (ロセオ)' : '' }}</template> | ||||
| 			<template v-else>引き分け</template> | ||||
| 			<template v-if="game.winner">{{ '%i18n:common.reversi.won%'.replace('{}', game.winner | userName) }}{{ game.settings.isLlotheo ? ' (ロセオ)' : '' }}</template> | ||||
| 			<template v-else>%i18n:common.reversi.drawn%</template> | ||||
| 		</p> | ||||
| 	</div> | ||||
| 
 | ||||
| 	<div class="board" :style="{ 'grid-template-rows': `repeat(${ game.settings.map.length }, 1fr)`, 'grid-template-columns': `repeat(${ game.settings.map[0].length }, 1fr)` }"> | ||||
| 		<div v-for="(stone, i) in o.board" | ||||
| 			:class="{ empty: stone == null, none: o.map[i] == 'null', isEnded: game.isEnded, myTurn: !game.isEnded && isMyTurn, can: turnUser ? o.canPut(turnUser.id == blackUser.id, i) : null, prev: o.prevPos == i }" | ||||
| 			@click="set(i)" | ||||
| 			:title="'[' + (o.transformPosToXy(i)[0] + 1) + ', ' + (o.transformPosToXy(i)[1] + 1) + '] (' + i + ')'" | ||||
| 		> | ||||
| 			<img v-if="stone === true" :src="`${blackUser.avatarUrl}?thumbnail&size=128`" alt=""> | ||||
| 			<img v-if="stone === false" :src="`${whiteUser.avatarUrl}?thumbnail&size=128`" alt=""> | ||||
| 	<div class="board"> | ||||
| 		<div class="labels-x" v-if="this.$store.state.settings.reversiBoardLabels"> | ||||
| 			<span v-for="i in game.settings.map[0].length">{{ String.fromCharCode(64 + i) }}</span> | ||||
| 		</div> | ||||
| 		<div class="flex"> | ||||
| 			<div class="labels-y" v-if="this.$store.state.settings.reversiBoardLabels"> | ||||
| 				<div v-for="i in game.settings.map.length">{{ i }}</div> | ||||
| 			</div> | ||||
| 			<div class="cells" :style="cellsStyle"> | ||||
| 				<div v-for="(stone, i) in o.board" | ||||
| 						:class="{ empty: stone == null, none: o.map[i] == 'null', isEnded: game.isEnded, myTurn: !game.isEnded && isMyTurn, can: turnUser ? o.canPut(turnUser.id == blackUser.id, i) : null, prev: o.prevPos == i }" | ||||
| 						@click="set(i)" | ||||
| 						:title="`${String.fromCharCode(65 + o.transformPosToXy(i)[0])}${o.transformPosToXy(i)[1] + 1}`"> | ||||
| 					<img v-if="stone === true" :src="blackUser.avatarUrl" alt=""> | ||||
| 					<img v-if="stone === false" :src="whiteUser.avatarUrl" alt=""> | ||||
| 				</div> | ||||
| 			</div> | ||||
| 			<div class="labels-y" v-if="this.$store.state.settings.reversiBoardLabels"> | ||||
| 				<div v-for="i in game.settings.map.length">{{ i }}</div> | ||||
| 			</div> | ||||
| 		</div> | ||||
| 		<div class="labels-x" v-if="this.$store.state.settings.reversiBoardLabels"> | ||||
| 			<span v-for="i in game.settings.map[0].length">{{ String.fromCharCode(64 + i) }}</span> | ||||
| 		</div> | ||||
| 	</div> | ||||
| 
 | ||||
| 	<p class="status"><b>{{ logPos }}ターン目</b> 黒:{{ o.blackCount }} 白:{{ o.whiteCount }} 合計:{{ o.blackCount + o.whiteCount }}</p> | ||||
| 	<p class="status"><b>{{ '%i18n:common.reversi.this-turn%'.split('{}')[0] }}{{ logPos }}{{ '%i18n:common.reversi.this-turn%'.split('{}')[1] }}</b> %i18n:common.reversi.black%:{{ o.blackCount }} %i18n:common.reversi.white%:{{ o.whiteCount }} %i18n:common.reversi.total%:{{ o.blackCount + o.whiteCount }}</p> | ||||
| 
 | ||||
| 	<div class="player" v-if="game.isEnded"> | ||||
| 		<el-button-group> | ||||
| @@ -43,8 +58,8 @@ | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import * as CRC32 from 'crc-32'; | ||||
| import Othello, { Color } from '../../../../../othello/core'; | ||||
| import { url } from '../../../config'; | ||||
| import Reversi, { Color } from '../../../../../../../games/reversi/core'; | ||||
| import { url } from '../../../../../config'; | ||||
| 
 | ||||
| export default Vue.extend({ | ||||
| 	props: ['initGame', 'connection'], | ||||
| @@ -52,7 +67,7 @@ export default Vue.extend({ | ||||
| 	data() { | ||||
| 		return { | ||||
| 			game: null, | ||||
| 			o: null as Othello, | ||||
| 			o: null as Reversi, | ||||
| 			logs: [], | ||||
| 			logPos: 0, | ||||
| 			pollingClock: null | ||||
| @@ -90,15 +105,22 @@ export default Vue.extend({ | ||||
| 			} | ||||
| 		}, | ||||
| 		isMyTurn(): boolean { | ||||
| 			if (this.turnUser == null) return null; | ||||
| 			if (!this.iAmPlayer) return false; | ||||
| 			if (this.turnUser == null) return false; | ||||
| 			return this.turnUser.id == this.$store.state.i.id; | ||||
| 		}, | ||||
| 		cellsStyle(): any { | ||||
| 			return { | ||||
| 				'grid-template-rows': `repeat(${this.game.settings.map.length}, 1fr)`, | ||||
| 				'grid-template-columns': `repeat(${this.game.settings.map[0].length}, 1fr)` | ||||
| 			}; | ||||
| 		} | ||||
| 	}, | ||||
| 
 | ||||
| 	watch: { | ||||
| 		logPos(v) { | ||||
| 			if (!this.game.isEnded) return; | ||||
| 			this.o = new Othello(this.game.settings.map, { | ||||
| 			this.o = new Reversi(this.game.settings.map, { | ||||
| 				isLlotheo: this.game.settings.isLlotheo, | ||||
| 				canPutEverywhere: this.game.settings.canPutEverywhere, | ||||
| 				loopedBoard: this.game.settings.loopedBoard | ||||
| @@ -115,7 +137,7 @@ export default Vue.extend({ | ||||
| 	created() { | ||||
| 		this.game = this.initGame; | ||||
| 
 | ||||
| 		this.o = new Othello(this.game.settings.map, { | ||||
| 		this.o = new Reversi(this.game.settings.map, { | ||||
| 			isLlotheo: this.game.settings.isLlotheo, | ||||
| 			canPutEverywhere: this.game.settings.canPutEverywhere, | ||||
| 			loopedBoard: this.game.settings.loopedBoard | ||||
| @@ -163,7 +185,7 @@ export default Vue.extend({ | ||||
| 
 | ||||
| 			// サウンドを再生する | ||||
| 			if (this.$store.state.device.enableSounds) { | ||||
| 				const sound = new Audio(`${url}/assets/othello-put-me.mp3`); | ||||
| 				const sound = new Audio(`${url}/assets/reversi-put-me.mp3`); | ||||
| 				sound.volume = this.$store.state.device.soundVolume; | ||||
| 				sound.play(); | ||||
| 			} | ||||
| @@ -187,7 +209,7 @@ export default Vue.extend({ | ||||
| 
 | ||||
| 			// サウンドを再生する | ||||
| 			if (this.$store.state.device.enableSounds && x.color != this.myColor) { | ||||
| 				const sound = new Audio(`${url}/assets/othello-put-you.mp3`); | ||||
| 				const sound = new Audio(`${url}/assets/reversi-put-you.mp3`); | ||||
| 				sound.volume = this.$store.state.device.soundVolume; | ||||
| 				sound.play(); | ||||
| 			} | ||||
| @@ -213,7 +235,7 @@ export default Vue.extend({ | ||||
| 		onRescue(game) { | ||||
| 			this.game = game; | ||||
| 
 | ||||
| 			this.o = new Othello(this.game.settings.map, { | ||||
| 			this.o = new Reversi(this.game.settings.map, { | ||||
| 				isLlotheo: this.game.settings.isLlotheo, | ||||
| 				canPutEverywhere: this.game.settings.canPutEverywhere, | ||||
| 				loopedBoard: this.game.settings.loopedBoard | ||||
| @@ -244,54 +266,99 @@ export default Vue.extend({ | ||||
| 		border-bottom dashed 1px #c4cdd4 | ||||
| 
 | ||||
| 	> .board | ||||
| 		display grid | ||||
| 		grid-gap 4px | ||||
| 		width 350px | ||||
| 		height 350px | ||||
| 		width calc(100% - 16px) | ||||
| 		max-width 500px | ||||
| 		margin 0 auto | ||||
| 
 | ||||
| 		> div | ||||
| 			background transparent | ||||
| 			border-radius 6px | ||||
| 			overflow hidden | ||||
| 		$label-size = 16px | ||||
| 		$gap = 4px | ||||
| 
 | ||||
| 			* | ||||
| 				pointer-events none | ||||
| 				user-select none | ||||
| 		> .labels-x | ||||
| 			height $label-size | ||||
| 			padding 0 $label-size | ||||
| 			display flex | ||||
| 
 | ||||
| 			&.empty | ||||
| 				border solid 2px #eee | ||||
| 			> * | ||||
| 				flex 1 | ||||
| 				display flex | ||||
| 				align-items center | ||||
| 				justify-content center | ||||
| 				font-size 12px | ||||
| 
 | ||||
| 			&.empty.can | ||||
| 				background #eee | ||||
| 				&:first-child | ||||
| 					margin-left -($gap / 2) | ||||
| 
 | ||||
| 			&.empty.myTurn | ||||
| 				border-color #ddd | ||||
| 				&:last-child | ||||
| 					margin-right -($gap / 2) | ||||
| 
 | ||||
| 				&.can | ||||
| 					background #eee | ||||
| 					cursor pointer | ||||
| 		> .flex | ||||
| 			display flex | ||||
| 
 | ||||
| 					&:hover | ||||
| 						border-color darken($theme-color, 10%) | ||||
| 						background $theme-color | ||||
| 			> .labels-y | ||||
| 				width $label-size | ||||
| 				display flex | ||||
| 				flex-direction column | ||||
| 
 | ||||
| 					&:active | ||||
| 						background darken($theme-color, 10%) | ||||
| 				> * | ||||
| 					flex 1 | ||||
| 					display flex | ||||
| 					align-items center | ||||
| 					justify-content center | ||||
| 					font-size 12px | ||||
| 
 | ||||
| 			&.prev | ||||
| 				box-shadow 0 0 0 4px rgba($theme-color, 0.7) | ||||
| 					&:first-child | ||||
| 						margin-top -($gap / 2) | ||||
| 
 | ||||
| 			&.isEnded | ||||
| 				border-color #ddd | ||||
| 					&:last-child | ||||
| 						margin-bottom -($gap / 2) | ||||
| 
 | ||||
| 			&.none | ||||
| 				border-color transparent !important | ||||
| 			> .cells | ||||
| 				flex 1 | ||||
| 				display grid | ||||
| 				grid-gap $gap | ||||
| 
 | ||||
| 			> img | ||||
| 				display block | ||||
| 				width 100% | ||||
| 				height 100% | ||||
| 				> div | ||||
| 					background transparent | ||||
| 					border-radius 6px | ||||
| 					overflow hidden | ||||
| 
 | ||||
| 					* | ||||
| 						pointer-events none | ||||
| 						user-select none | ||||
| 
 | ||||
| 					&.empty | ||||
| 						border solid 2px #eee | ||||
| 
 | ||||
| 					&.empty.can | ||||
| 						background #eee | ||||
| 
 | ||||
| 					&.empty.myTurn | ||||
| 						border-color #ddd | ||||
| 
 | ||||
| 						&.can | ||||
| 							background #eee | ||||
| 							cursor pointer | ||||
| 
 | ||||
| 							&:hover | ||||
| 								border-color darken($theme-color, 10%) | ||||
| 								background $theme-color | ||||
| 
 | ||||
| 							&:active | ||||
| 								background darken($theme-color, 10%) | ||||
| 
 | ||||
| 					&.prev | ||||
| 						box-shadow 0 0 0 4px rgba($theme-color, 0.7) | ||||
| 
 | ||||
| 					&.isEnded | ||||
| 						border-color #ddd | ||||
| 
 | ||||
| 					&.none | ||||
| 						border-color transparent !important | ||||
| 
 | ||||
| 					> img | ||||
| 						display block | ||||
| 						width 100% | ||||
| 						height 100% | ||||
| 
 | ||||
| 	> .graph | ||||
| 		display grid | ||||
| @@ -7,9 +7,9 @@ | ||||
| 
 | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import XGame from './othello.game.vue'; | ||||
| import XRoom from './othello.room.vue'; | ||||
| import { OthelloGameStream } from '../../scripts/streaming/othello-game'; | ||||
| import XGame from './reversi.game.vue'; | ||||
| import XRoom from './reversi.room.vue'; | ||||
| import { ReversiGameStream } from '../../../../scripts/streaming/games/reversi/reversi-game'; | ||||
| 
 | ||||
| export default Vue.extend({ | ||||
| 	components: { | ||||
| @@ -25,7 +25,7 @@ export default Vue.extend({ | ||||
| 	}, | ||||
| 	created() { | ||||
| 		this.g = this.game; | ||||
| 		this.connection = new OthelloGameStream((this as any).os, this.$store.state.i, this.game); | ||||
| 		this.connection = new ReversiGameStream((this as any).os, this.$store.state.i, this.game); | ||||
| 		this.connection.on('started', this.onStarted); | ||||
| 	}, | ||||
| 	beforeDestroy() { | ||||
| @@ -1,14 +1,14 @@ | ||||
| <template> | ||||
| <div class="root"> | ||||
| 	<header><b>{{ game.user1.name }}</b> vs <b>{{ game.user2.name }}</b></header> | ||||
| 	<header><b>{{ game.user1 | userName }}</b> vs <b>{{ game.user2 | userName }}</b></header> | ||||
| 
 | ||||
| 	<div> | ||||
| 		<p>ゲームの設定</p> | ||||
| 		<p>%i18n:@settings-of-the-game%</p> | ||||
| 
 | ||||
| 		<el-card class="map"> | ||||
| 			<div slot="header"> | ||||
| 				<el-select :class="$style.mapSelect" v-model="mapName" placeholder="マップを選択" @change="onMapChange"> | ||||
| 					<el-option label="ランダム" :value="null"/> | ||||
| 				<el-select :class="$style.mapSelect" v-model="mapName" placeholder="%i18n:@choose-map%" @change="onMapChange"> | ||||
| 					<el-option label="%i18n:@random%" :value="null"/> | ||||
| 					<el-option-group v-for="c in mapCategories" :key="c" :label="c"> | ||||
| 						<el-option v-for="m in maps" v-if="m.category == c" :key="m.name" :label="m.name" :value="m.name"> | ||||
| 							<span style="float: left">{{ m.name }}</span> | ||||
| @@ -30,25 +30,25 @@ | ||||
| 
 | ||||
| 		<el-card class="bw"> | ||||
| 			<div slot="header"> | ||||
| 				<span>先手/後手</span> | ||||
| 				<span>%i18n:@black-or-white%</span> | ||||
| 			</div> | ||||
| 			<el-radio v-model="game.settings.bw" label="random" @change="updateSettings">ランダム</el-radio> | ||||
| 			<el-radio v-model="game.settings.bw" :label="1" @change="updateSettings">{{ game.user1.name }}が黒</el-radio> | ||||
| 			<el-radio v-model="game.settings.bw" :label="2" @change="updateSettings">{{ game.user2.name }}が黒</el-radio> | ||||
| 			<el-radio v-model="game.settings.bw" label="random" @change="updateSettings">%i18n:@random%</el-radio> | ||||
| 			<el-radio v-model="game.settings.bw" :label="1" @change="updateSettings">{{ '%i18n:@black-is%'.split('{}')[0] }}{{ game.user1.name }}{{ '%i18n:@black-is%'.split('{}')[1] }}</el-radio> | ||||
| 			<el-radio v-model="game.settings.bw" :label="2" @change="updateSettings">{{ '%i18n:@black-is%'.split('{}')[0] }}{{ game.user2.name }}{{ '%i18n:@black-is%'.split('{}')[1] }}</el-radio> | ||||
| 		</el-card> | ||||
| 
 | ||||
| 		<el-card class="rules"> | ||||
| 			<div slot="header"> | ||||
| 				<span>ルール</span> | ||||
| 				<span>%i18n:@rules%</span> | ||||
| 			</div> | ||||
| 			<mk-switch v-model="game.settings.isLlotheo" @change="updateSettings" text="石の少ない方が勝ち(ロセオ)"/> | ||||
| 			<mk-switch v-model="game.settings.loopedBoard" @change="updateSettings" text="ループマップ"/> | ||||
| 			<mk-switch v-model="game.settings.canPutEverywhere" @change="updateSettings" text="どこでも置けるモード"/> | ||||
| 			<mk-switch v-model="game.settings.isLlotheo" @change="updateSettings" text="%i18n:@is-llotheo%"/> | ||||
| 			<mk-switch v-model="game.settings.loopedBoard" @change="updateSettings" text="%i18n:@looped-map%"/> | ||||
| 			<mk-switch v-model="game.settings.canPutEverywhere" @change="updateSettings" text="%i18n:@can-put-everywhere%"/> | ||||
| 		</el-card> | ||||
| 
 | ||||
| 		<el-card class="bot-form" v-if="form"> | ||||
| 			<div slot="header"> | ||||
| 				<span>Botの設定</span> | ||||
| 				<span>%i18n:@settings-of-the-bot%</span> | ||||
| 			</div> | ||||
| 			<el-alert v-for="message in messages" | ||||
| 				:title="message.text" | ||||
| @@ -77,16 +77,16 @@ | ||||
| 
 | ||||
| 	<footer> | ||||
| 		<p class="status"> | ||||
| 			<template v-if="isAccepted && isOpAccepted">ゲームは数秒後に開始されます<mk-ellipsis/></template> | ||||
| 			<template v-if="isAccepted && !isOpAccepted">相手の準備が完了するのを待っています<mk-ellipsis/></template> | ||||
| 			<template v-if="!isAccepted && isOpAccepted">あなたの準備が完了するのを待っています</template> | ||||
| 			<template v-if="!isAccepted && !isOpAccepted">準備中<mk-ellipsis/></template> | ||||
| 			<template v-if="isAccepted && isOpAccepted">%i18n:@this-gane-is-started-soon%<mk-ellipsis/></template> | ||||
| 			<template v-if="isAccepted && !isOpAccepted">%i18n:@waiting-for-other%<mk-ellipsis/></template> | ||||
| 			<template v-if="!isAccepted && isOpAccepted">%i18n:@waiting-for-me%</template> | ||||
| 			<template v-if="!isAccepted && !isOpAccepted">%i18n:@waiting-for-both%<mk-ellipsis/></template> | ||||
| 		</p> | ||||
| 
 | ||||
| 		<div class="actions"> | ||||
| 			<el-button @click="exit">キャンセル</el-button> | ||||
| 			<el-button type="primary" @click="accept" v-if="!isAccepted">準備完了</el-button> | ||||
| 			<el-button type="primary" @click="cancel" v-if="isAccepted">準備続行</el-button> | ||||
| 			<el-button @click="exit">%i18n:@cancel%</el-button> | ||||
| 			<el-button type="primary" @click="accept" v-if="!isAccepted">%i18n:@ready%</el-button> | ||||
| 			<el-button type="primary" @click="cancel" v-if="isAccepted">%i18n:@cancel-ready%</el-button> | ||||
| 		</div> | ||||
| 	</footer> | ||||
| </div> | ||||
| @@ -94,7 +94,7 @@ | ||||
| 
 | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import * as maps from '../../../../../othello/maps'; | ||||
| import * as maps from '../../../../../../../games/reversi/maps'; | ||||
| 
 | ||||
| export default Vue.extend({ | ||||
| 	props: ['game', 'connection'], | ||||
| @@ -112,7 +112,7 @@ export default Vue.extend({ | ||||
| 
 | ||||
| 	computed: { | ||||
| 		mapCategories(): string[] { | ||||
| 			const categories = Object.entries(maps).map(x => x[1].category); | ||||
| 			const categories = Object.values(maps).map(x => x.category); | ||||
| 			return categories.filter((item, pos) => categories.indexOf(item) == pos); | ||||
| 		}, | ||||
| 		isAccepted(): boolean { | ||||
| @@ -179,8 +179,8 @@ export default Vue.extend({ | ||||
| 			if (this.game.settings.map == null) { | ||||
| 				this.mapName = null; | ||||
| 			} else { | ||||
| 				const foundMap = Object.entries(maps).find(x => x[1].data.join('') == this.game.settings.map.join('')); | ||||
| 				this.mapName = foundMap ? foundMap[1].name : '-Custom-'; | ||||
| 				const found = Object.values(maps).find(x => x.data.join('') == this.game.settings.map.join('')); | ||||
| 				this.mapName = found ? found.name : '-Custom-'; | ||||
| 			} | ||||
| 		}, | ||||
| 
 | ||||
| @@ -206,7 +206,7 @@ export default Vue.extend({ | ||||
| 			if (v == null) { | ||||
| 				this.game.settings.map = null; | ||||
| 			} else { | ||||
| 				this.game.settings.map = Object.entries(maps).find(x => x[1].name == v)[1].data; | ||||
| 				this.game.settings.map = Object.values(maps).find(x => x.name == v).data; | ||||
| 			} | ||||
| 			this.$forceUpdate(); | ||||
| 			this.updateSettings(); | ||||
| @@ -217,9 +217,9 @@ export default Vue.extend({ | ||||
| 			const y = Math.floor(pos / this.game.settings.map[0].length); | ||||
| 			const newPixel = | ||||
| 				pixel == ' ' ? '-' : | ||||
| 				pixel == '-' ? 'b' : | ||||
| 				pixel == 'b' ? 'w' : | ||||
| 				' '; | ||||
| 					pixel == '-' ? 'b' : | ||||
| 						pixel == 'b' ? 'w' : | ||||
| 							' '; | ||||
| 			const line = this.game.settings.map[y].split(''); | ||||
| 			line[x] = newPixel; | ||||
| 			this.$set(this.game.settings.map, y, line.join('')); | ||||
| @@ -1,58 +1,56 @@ | ||||
| <template> | ||||
| <div class="mk-othello"> | ||||
| <div class="mk-reversi"> | ||||
| 	<div v-if="game"> | ||||
| 		<x-gameroom :game="game"/> | ||||
| 	</div> | ||||
| 	<div class="matching" v-else-if="matching"> | ||||
| 		<h1><b>{{ matching.name }}</b>を待っています<mk-ellipsis/></h1> | ||||
| 		<h1>{{ '%i18n:@matching.waiting-for%'.split('{}')[0] }}<b>{{ matching | userName }}</b>{{ '%i18n:@matching.waiting-for%'.split('{}')[1] }}<mk-ellipsis/></h1> | ||||
| 		<div class="cancel"> | ||||
| 			<el-button round @click="cancel">キャンセル</el-button> | ||||
| 			<el-button round @click="cancel">%i18n:@matching.cancel%</el-button> | ||||
| 		</div> | ||||
| 	</div> | ||||
| 	<div class="index" v-else> | ||||
| 		<h1>Misskey %fa:circle%thell%fa:circle R%</h1> | ||||
| 		<p>他のMisskeyユーザーとオセロで対戦しよう</p> | ||||
| 		<h1>%i18n:@title%</h1> | ||||
| 		<p>%i18n:@sub-title%</p> | ||||
| 		<div class="play"> | ||||
| 			<el-button round>フリーマッチ(準備中)</el-button> | ||||
| 			<el-button type="primary" round @click="match">指名</el-button> | ||||
| 			<!--<el-button round>フリーマッチ(準備中)</el-button>--> | ||||
| 			<el-button type="primary" round @click="match">%i18n:@invite%</el-button> | ||||
| 			<details> | ||||
| 				<summary>遊び方</summary> | ||||
| 				<summary>%i18n:@rule%</summary> | ||||
| 				<div> | ||||
| 					<p>オセロは、相手と交互に石をボードに置いてゆき、相手の石を挟んでひっくり返しながら、最終的に残った石が多い方が勝ちというボードゲームです。</p> | ||||
| 					<p>%i18n:@rule-desc%</p> | ||||
| 					<dl> | ||||
| 						<dt><b>フリーマッチ</b></dt> | ||||
| 						<dd>ランダムなユーザーと対戦するモードです。</dd> | ||||
| 						<dt><b>指名</b></dt> | ||||
| 						<dd>指定したユーザーと対戦するモードです。</dd> | ||||
| 						<dt><b>%i18n:@mode-invite%</b></dt> | ||||
| 						<dd>%i18n:@mode-invite-desc%</dd> | ||||
| 					</dl> | ||||
| 				</div> | ||||
| 			</details> | ||||
| 		</div> | ||||
| 		<section v-if="invitations.length > 0"> | ||||
| 			<h2>対局の招待があります!:</h2> | ||||
| 			<h2>%i18n:@invitations%</h2> | ||||
| 			<div class="invitation" v-for="i in invitations" tabindex="-1" @click="accept(i)"> | ||||
| 				<mk-avatar class="avatar" :user="i.parent"/> | ||||
| 				<span class="name"><b>{{ i.parent.name }}</b></span> | ||||
| 				<span class="name"><b>{{ i.parent | userName }}</b></span> | ||||
| 				<span class="username">@{{ i.parent.username }}</span> | ||||
| 				<mk-time :time="i.createdAt"/> | ||||
| 			</div> | ||||
| 		</section> | ||||
| 		<section v-if="myGames.length > 0"> | ||||
| 			<h2>自分の対局</h2> | ||||
| 			<a class="game" v-for="g in myGames" tabindex="-1" @click.prevent="go(g)" :href="`/othello/${g.id}`"> | ||||
| 			<h2>%i18n:@my-games%</h2> | ||||
| 			<a class="game" v-for="g in myGames" tabindex="-1" @click.prevent="go(g)" :href="`/reversi/${g.id}`"> | ||||
| 				<mk-avatar class="avatar" :user="g.user1"/> | ||||
| 				<mk-avatar class="avatar" :user="g.user2"/> | ||||
| 				<span><b>{{ g.user1.name }}</b> vs <b>{{ g.user2.name }}</b></span> | ||||
| 				<span class="state">{{ g.isEnded ? '終了' : '進行中' }}</span> | ||||
| 				<span><b>{{ g.user1 | userName }}</b> vs <b>{{ g.user2 | userName }}</b></span> | ||||
| 				<span class="state">{{ g.isEnded ? '%i18n:@game-state.ended%' : '%i18n:@game-state.playing%' }}</span> | ||||
| 			</a> | ||||
| 		</section> | ||||
| 		<section v-if="games.length > 0"> | ||||
| 			<h2>みんなの対局</h2> | ||||
| 			<a class="game" v-for="g in games" tabindex="-1" @click.prevent="go(g)" :href="`/othello/${g.id}`"> | ||||
| 			<h2>%i18n:@all-games%</h2> | ||||
| 			<a class="game" v-for="g in games" tabindex="-1" @click.prevent="go(g)" :href="`/reversi/${g.id}`"> | ||||
| 				<mk-avatar class="avatar" :user="g.user1"/> | ||||
| 				<mk-avatar class="avatar" :user="g.user2"/> | ||||
| 				<span><b>{{ g.user1.name }}</b> vs <b>{{ g.user2.name }}</b></span> | ||||
| 				<span class="state">{{ g.isEnded ? '終了' : '進行中' }}</span> | ||||
| 				<span><b>{{ g.user1 | userName }}</b> vs <b>{{ g.user2 | userName }}</b></span> | ||||
| 				<span class="state">{{ g.isEnded ? '%i18n:@game-state.ended%' : '%i18n:@game-state.playing%' }}</span> | ||||
| 			</a> | ||||
| 		</section> | ||||
| 	</div> | ||||
| @@ -61,13 +59,15 @@ | ||||
| 
 | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import XGameroom from './othello.gameroom.vue'; | ||||
| import XGameroom from './reversi.gameroom.vue'; | ||||
| 
 | ||||
| export default Vue.extend({ | ||||
| 	components: { | ||||
| 		XGameroom | ||||
| 	}, | ||||
| 
 | ||||
| 	props: ['initGame'], | ||||
| 
 | ||||
| 	data() { | ||||
| 		return { | ||||
| 			game: null, | ||||
| @@ -82,71 +82,81 @@ export default Vue.extend({ | ||||
| 			pingClock: null | ||||
| 		}; | ||||
| 	}, | ||||
| 
 | ||||
| 	watch: { | ||||
| 		game(g) { | ||||
| 			this.$emit('gamed', g); | ||||
| 		} | ||||
| 	}, | ||||
| 
 | ||||
| 	created() { | ||||
| 		if (this.initGame) { | ||||
| 			this.game = this.initGame; | ||||
| 		} | ||||
| 	}, | ||||
| 
 | ||||
| 	mounted() { | ||||
| 		this.connection = (this as any).os.streams.othelloStream.getConnection(); | ||||
| 		this.connectionId = (this as any).os.streams.othelloStream.use(); | ||||
| 		if (this.$store.getters.isSignedIn) { | ||||
| 			this.connection = (this as any).os.streams.reversiStream.getConnection(); | ||||
| 			this.connectionId = (this as any).os.streams.reversiStream.use(); | ||||
| 
 | ||||
| 		this.connection.on('matched', this.onMatched); | ||||
| 		this.connection.on('invited', this.onInvited); | ||||
| 			this.connection.on('matched', this.onMatched); | ||||
| 			this.connection.on('invited', this.onInvited); | ||||
| 
 | ||||
| 		(this as any).api('othello/games', { | ||||
| 			my: true | ||||
| 		}).then(games => { | ||||
| 			this.myGames = games; | ||||
| 		}); | ||||
| 			(this as any).api('games/reversi/games', { | ||||
| 				my: true | ||||
| 			}).then(games => { | ||||
| 				this.myGames = games; | ||||
| 			}); | ||||
| 
 | ||||
| 		(this as any).api('othello/games').then(games => { | ||||
| 			(this as any).api('games/reversi/invitations').then(invitations => { | ||||
| 				this.invitations = this.invitations.concat(invitations); | ||||
| 			}); | ||||
| 
 | ||||
| 			this.pingClock = setInterval(() => { | ||||
| 				if (this.matching) { | ||||
| 					this.connection.send({ | ||||
| 						type: 'ping', | ||||
| 						id: this.matching.id | ||||
| 					}); | ||||
| 				} | ||||
| 			}, 3000); | ||||
| 		} | ||||
| 
 | ||||
| 		(this as any).api('games/reversi/games').then(games => { | ||||
| 			this.games = games; | ||||
| 			this.gamesFetching = false; | ||||
| 		}); | ||||
| 
 | ||||
| 		(this as any).api('othello/invitations').then(invitations => { | ||||
| 			this.invitations = this.invitations.concat(invitations); | ||||
| 		}); | ||||
| 
 | ||||
| 		this.pingClock = setInterval(() => { | ||||
| 			if (this.matching) { | ||||
| 				this.connection.send({ | ||||
| 					type: 'ping', | ||||
| 					id: this.matching.id | ||||
| 				}); | ||||
| 			} | ||||
| 		}, 3000); | ||||
| 	}, | ||||
| 
 | ||||
| 	beforeDestroy() { | ||||
| 		this.connection.off('matched', this.onMatched); | ||||
| 		this.connection.off('invited', this.onInvited); | ||||
| 		(this as any).os.streams.othelloStream.dispose(this.connectionId); | ||||
| 		if (this.connection) { | ||||
| 			this.connection.off('matched', this.onMatched); | ||||
| 			this.connection.off('invited', this.onInvited); | ||||
| 			(this as any).os.streams.reversiStream.dispose(this.connectionId); | ||||
| 
 | ||||
| 		clearInterval(this.pingClock); | ||||
| 			clearInterval(this.pingClock); | ||||
| 		} | ||||
| 	}, | ||||
| 
 | ||||
| 	methods: { | ||||
| 		go(game) { | ||||
| 			(this as any).api('othello/games/show', { | ||||
| 			(this as any).api('games/reversi/games/show', { | ||||
| 				gameId: game.id | ||||
| 			}).then(game => { | ||||
| 				this.matching = null; | ||||
| 				this.game = game; | ||||
| 			}); | ||||
| 		}, | ||||
| 
 | ||||
| 		match() { | ||||
| 			(this as any).apis.input({ | ||||
| 				title: 'ユーザー名を入力してください' | ||||
| 				title: '%i18n:@enter-username%' | ||||
| 			}).then(username => { | ||||
| 				(this as any).api('users/show', { | ||||
| 					username | ||||
| 				}).then(user => { | ||||
| 					(this as any).api('othello/match', { | ||||
| 					(this as any).api('games/reversi/match', { | ||||
| 						userId: user.id | ||||
| 					}).then(res => { | ||||
| 						if (res == null) { | ||||
| @@ -158,12 +168,14 @@ export default Vue.extend({ | ||||
| 				}); | ||||
| 			}); | ||||
| 		}, | ||||
| 
 | ||||
| 		cancel() { | ||||
| 			this.matching = null; | ||||
| 			(this as any).api('othello/match/cancel'); | ||||
| 			(this as any).api('games/reversi/match/cancel'); | ||||
| 		}, | ||||
| 
 | ||||
| 		accept(invitation) { | ||||
| 			(this as any).api('othello/match', { | ||||
| 			(this as any).api('games/reversi/match', { | ||||
| 				userId: invitation.parent.id | ||||
| 			}).then(game => { | ||||
| 				if (game) { | ||||
| @@ -172,10 +184,12 @@ export default Vue.extend({ | ||||
| 				} | ||||
| 			}); | ||||
| 		}, | ||||
| 
 | ||||
| 		onMatched(game) { | ||||
| 			this.matching = null; | ||||
| 			this.game = game; | ||||
| 		}, | ||||
| 
 | ||||
| 		onInvited(invite) { | ||||
| 			this.invitations.unshift(invite); | ||||
| 		} | ||||
| @@ -186,7 +200,7 @@ export default Vue.extend({ | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
| 
 | ||||
| .mk-othello | ||||
| .mk-reversi | ||||
| 	color #677f84 | ||||
| 	background #fff | ||||
| 
 | ||||
| @@ -1,7 +1,7 @@ | ||||
| <template> | ||||
| <div class="mk-google"> | ||||
| 	<input type="search" v-model="query" :placeholder="q"> | ||||
| 	<button @click="search">検索</button> | ||||
| 	<button @click="search">%fa:search% %i18n:common.search%</button> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -9,7 +9,7 @@ import forkit from './forkit.vue'; | ||||
| import acct from './acct.vue'; | ||||
| import avatar from './avatar.vue'; | ||||
| import nav from './nav.vue'; | ||||
| import noteHtml from './note-html'; | ||||
| import misskeyFlavoredMarkdown from './misskey-flavored-markdown'; | ||||
| import poll from './poll.vue'; | ||||
| import pollEditor from './poll-editor.vue'; | ||||
| import reactionIcon from './reaction-icon.vue'; | ||||
| @@ -27,8 +27,16 @@ import urlPreview from './url-preview.vue'; | ||||
| import twitterSetting from './twitter-setting.vue'; | ||||
| import fileTypeIcon from './file-type-icon.vue'; | ||||
| import Switch from './switch.vue'; | ||||
| import Othello from './othello.vue'; | ||||
| import Reversi from './games/reversi/reversi.vue'; | ||||
| import welcomeTimeline from './welcome-timeline.vue'; | ||||
| import uiInput from './ui/input.vue'; | ||||
| import uiButton from './ui/button.vue'; | ||||
| import uiCard from './ui/card.vue'; | ||||
| import uiForm from './ui/form.vue'; | ||||
| import uiTextarea from './ui/textarea.vue'; | ||||
| import uiSwitch from './ui/switch.vue'; | ||||
| import uiRadio from './ui/radio.vue'; | ||||
| import uiSelect from './ui/select.vue'; | ||||
|  | ||||
| Vue.component('mk-analog-clock', analogClock); | ||||
| Vue.component('mk-menu', menu); | ||||
| @@ -39,7 +47,7 @@ Vue.component('mk-forkit', forkit); | ||||
| Vue.component('mk-acct', acct); | ||||
| Vue.component('mk-avatar', avatar); | ||||
| Vue.component('mk-nav', nav); | ||||
| Vue.component('mk-note-html', noteHtml); | ||||
| Vue.component('misskey-flavored-markdown', misskeyFlavoredMarkdown); | ||||
| Vue.component('mk-poll', poll); | ||||
| Vue.component('mk-poll-editor', pollEditor); | ||||
| Vue.component('mk-reaction-icon', reactionIcon); | ||||
| @@ -57,5 +65,13 @@ Vue.component('mk-url-preview', urlPreview); | ||||
| Vue.component('mk-twitter-setting', twitterSetting); | ||||
| Vue.component('mk-file-type-icon', fileTypeIcon); | ||||
| Vue.component('mk-switch', Switch); | ||||
| Vue.component('mk-othello', Othello); | ||||
| Vue.component('mk-reversi', Reversi); | ||||
| Vue.component('mk-welcome-timeline', welcomeTimeline); | ||||
| Vue.component('ui-input', uiInput); | ||||
| Vue.component('ui-button', uiButton); | ||||
| Vue.component('ui-card', uiCard); | ||||
| Vue.component('ui-form', uiForm); | ||||
| Vue.component('ui-textarea', uiTextarea); | ||||
| Vue.component('ui-switch', uiSwitch); | ||||
| Vue.component('ui-radio', uiRadio); | ||||
| Vue.component('ui-select', uiSelect); | ||||
|   | ||||
| @@ -46,33 +46,45 @@ export default Vue.extend({ | ||||
| 		display grid | ||||
| 		grid-gap 4px | ||||
|  | ||||
| 		> * | ||||
| 			overflow hidden | ||||
| 			border-radius 4px | ||||
|  | ||||
| 		&[data-count="1"] | ||||
| 			grid-template-rows 1fr | ||||
|  | ||||
| 		&[data-count="2"] | ||||
| 			grid-template-columns 1fr 1fr | ||||
| 			grid-template-rows 1fr | ||||
|  | ||||
| 		&[data-count="3"] | ||||
| 			grid-template-columns 1fr 0.5fr | ||||
| 			grid-template-rows 1fr 1fr | ||||
| 			:nth-child(1) | ||||
|  | ||||
| 			> *:nth-child(1) | ||||
| 				grid-row 1 / 3 | ||||
| 			:nth-child(3) | ||||
|  | ||||
| 			> *:nth-child(3) | ||||
| 				grid-column 2 / 3 | ||||
| 				grid-row 2 / 3 | ||||
|  | ||||
| 		&[data-count="4"] | ||||
| 			grid-template-columns 1fr 1fr | ||||
| 			grid-template-rows 1fr 1fr | ||||
|  | ||||
| 		:nth-child(1) | ||||
| 		> *:nth-child(1) | ||||
| 			grid-column 1 / 2 | ||||
| 			grid-row 1 / 2 | ||||
| 		:nth-child(2) | ||||
|  | ||||
| 		> *:nth-child(2) | ||||
| 			grid-column 2 / 3 | ||||
| 			grid-row 1 / 2 | ||||
| 		:nth-child(3) | ||||
|  | ||||
| 		> *:nth-child(3) | ||||
| 			grid-column 1 / 2 | ||||
| 			grid-row 2 / 3 | ||||
| 		:nth-child(4) | ||||
|  | ||||
| 		> *:nth-child(4) | ||||
| 			grid-column 2 / 3 | ||||
| 			grid-row 2 / 3 | ||||
|  | ||||
|   | ||||
| @@ -119,7 +119,7 @@ export default Vue.extend({ | ||||
| 		}, | ||||
|  | ||||
| 		onKeypress(e) { | ||||
| 			if ((e.which == 10 || e.which == 13) && e.ctrlKey) { | ||||
| 			if ((e.which == 10 || e.which == 13) && e.ctrlKey && this.canSend) { | ||||
| 				this.send(); | ||||
| 			} | ||||
| 		}, | ||||
|   | ||||
| @@ -3,12 +3,11 @@ | ||||
| 	<mk-avatar class="avatar" :user="message.user" target="_blank"/> | ||||
| 	<div class="content"> | ||||
| 		<div class="balloon" :data-no-text="message.text == null"> | ||||
| 			<p class="read" v-if="isMe && message.isRead">%i18n:@is-read%</p> | ||||
| 			<button class="delete-button" v-if="isMe" title="%i18n:common.delete%"> | ||||
| 			<!-- <button class="delete-button" v-if="isMe" title="%i18n:common.delete%"> | ||||
| 				<img src="/assets/desktop/messaging/delete.png" alt="Delete"/> | ||||
| 			</button> | ||||
| 			</button> --> | ||||
| 			<div class="content" v-if="!message.isDeleted"> | ||||
| 				<mk-note-html class="text" v-if="message.text" ref="text" :text="message.text" :i="$store.state.i"/> | ||||
| 				<misskey-flavored-markdown class="text" v-if="message.text" ref="text" :text="message.text" :i="$store.state.i"/> | ||||
| 				<div class="file" v-if="message.file"> | ||||
| 					<a :href="message.file.url" target="_blank" :title="message.file.name"> | ||||
| 						<img v-if="message.file.type.split('/')[0] == 'image'" :src="message.file.url" :alt="message.file.name"/> | ||||
| @@ -23,6 +22,7 @@ | ||||
| 		<div></div> | ||||
| 		<mk-url-preview v-for="url in urls" :url="url" :key="url"/> | ||||
| 		<footer> | ||||
| 			<span class="read" v-if="isMe && message.isRead">%i18n:@is-read%</span> | ||||
| 			<mk-time :time="message.createdAt"/> | ||||
| 			<template v-if="message.is_edited">%fa:pencil-alt%</template> | ||||
| 		</footer> | ||||
| @@ -32,7 +32,7 @@ | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import parse from '../../../../../text/parse'; | ||||
| import parse from '../../../../../mfm/parse'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: { | ||||
| @@ -79,7 +79,8 @@ root(isDark) | ||||
| 	> .content | ||||
|  | ||||
| 		> .balloon | ||||
| 			display block | ||||
| 			display flex | ||||
| 			align-items center | ||||
| 			padding 0 | ||||
| 			max-width calc(100% - 16px) | ||||
| 			min-height 38px | ||||
| @@ -120,17 +121,6 @@ root(isDark) | ||||
| 					height 16px | ||||
| 					cursor pointer | ||||
|  | ||||
| 			> .read | ||||
| 				user-select none | ||||
| 				display block | ||||
| 				position absolute | ||||
| 				z-index 1 | ||||
| 				bottom -4px | ||||
| 				left -12px | ||||
| 				margin 0 | ||||
| 				color isDark ? rgba(#fff, 0.5) : rgba(#000, 0.5) | ||||
| 				font-size 11px | ||||
|  | ||||
| 			> .content | ||||
|  | ||||
| 				> .is-deleted | ||||
| @@ -258,8 +248,14 @@ root(isDark) | ||||
| 			> footer | ||||
| 				text-align right | ||||
|  | ||||
| 				> .read | ||||
| 					user-select none | ||||
| 					margin 0 4px 0 0 | ||||
| 					color isDark ? rgba(#fff, 0.5) : rgba(#000, 0.5) | ||||
| 					font-size 11px | ||||
|  | ||||
| 	&[data-is-deleted] | ||||
| 		> .baloon | ||||
| 		> .balloon | ||||
| 			opacity 0.5 | ||||
|  | ||||
| .message[data-darkmode] | ||||
|   | ||||
| @@ -51,7 +51,7 @@ | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import getAcct from '../../../../../acct/render'; | ||||
| import getAcct from '../../../../../misc/acct/render'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: { | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| import Vue from 'vue'; | ||||
| import * as emojilib from 'emojilib'; | ||||
| import parse from '../../../../../text/parse'; | ||||
| import getAcct from '../../../../../acct/render'; | ||||
| import parse from '../../../../../mfm/parse'; | ||||
| import getAcct from '../../../../../misc/acct/render'; | ||||
| import { url } from '../../../config'; | ||||
| import MkUrl from './url.vue'; | ||||
| import MkGoogle from './google.vue'; | ||||
| @@ -10,7 +10,7 @@ const flatten = list => list.reduce( | ||||
| 	(a, b) => a.concat(Array.isArray(b) ? flatten(b) : b), [] | ||||
| ); | ||||
| 
 | ||||
| export default Vue.component('mk-note-html', { | ||||
| export default Vue.component('misskey-flavored-markdown', { | ||||
| 	props: { | ||||
| 		text: { | ||||
| 			type: String, | ||||
| @@ -40,17 +40,6 @@ export default Vue.component('mk-note-html', { | ||||
| 			ast = this.ast; | ||||
| 		} | ||||
| 
 | ||||
| 		if (ast.filter(x => x.type != 'hashtag').length == 0) { | ||||
| 			return; | ||||
| 		} | ||||
| 
 | ||||
| 		while (ast[ast.length - 1] && ( | ||||
| 			ast[ast.length - 1].type == 'hashtag' || | ||||
| 			(ast[ast.length - 1].type == 'text' && ast[ast.length - 1].content == ' ') || | ||||
| 			(ast[ast.length - 1].type == 'text' && ast[ast.length - 1].content == '\n'))) { | ||||
| 			ast.pop(); | ||||
| 		} | ||||
| 
 | ||||
| 		// Parse ast to DOM
 | ||||
| 		const els = flatten(ast.map(token => { | ||||
| 			switch (token.type) { | ||||
| @@ -103,7 +92,7 @@ export default Vue.component('mk-note-html', { | ||||
| 				case 'hashtag': | ||||
| 					return createElement('a', { | ||||
| 						attrs: { | ||||
| 							href: `${url}/tags/${token.hashtag}`, | ||||
| 							href: `${url}/tags/${encodeURIComponent(token.hashtag)}`, | ||||
| 							target: '_blank' | ||||
| 						} | ||||
| 					}, token.content); | ||||
| @@ -2,9 +2,9 @@ | ||||
| <span class="mk-nav"> | ||||
| 	<a :href="aboutUrl">%i18n:@about%</a> | ||||
| 	<i>・</i> | ||||
| 	<a href="https://github.com/syuilo/misskey">%i18n:@repository%</a> | ||||
| 	<a :href="repositoryUrl">%i18n:@repository%</a> | ||||
| 	<i>・</i> | ||||
| 	<a href="https://github.com/syuilo/misskey/issues/new" target="_blank">%i18n:@feedback%</a> | ||||
| 	<a :href="feedbackUrl" target="_blank">%i18n:@feedback%</a> | ||||
| 	<i>・</i> | ||||
| 	<a :href="devUrl">%i18n:@develop%</a> | ||||
| 	<i>・</i> | ||||
| @@ -14,7 +14,7 @@ | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { docsUrl, statsUrl, statusUrl, devUrl, lang } from '../../../config'; | ||||
| import { docsUrl, statsUrl, statusUrl, devUrl, repositoryUrl, feedbackUrl, lang } from '../../../config'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	data() { | ||||
| @@ -22,7 +22,9 @@ export default Vue.extend({ | ||||
| 			aboutUrl: `${docsUrl}/${lang}/about`, | ||||
| 			statsUrl, | ||||
| 			statusUrl, | ||||
| 			devUrl | ||||
| 			devUrl, | ||||
| 			repositoryUrl: repositoryUrl || `https://github.com/syuilo/misskey`, | ||||
| 			feedbackUrl: feedbackUrl || `https://github.com/syuilo/misskey/issues/new` | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
|   | ||||
| @@ -2,6 +2,7 @@ | ||||
| <header class="bvonvjxbwzaiskogyhbwgyxvcgserpmu"> | ||||
| 	<mk-avatar class="avatar" :user="note.user" v-if="$store.state.device.postStyle == 'smart'"/> | ||||
| 	<router-link class="name" :to="note.user | userPage" v-user-preview="note.user.id">{{ note.user | userName }}</router-link> | ||||
| 	<span class="is-verified" v-if="note.user.isVerified" title="%i18n:common.verified-user%">%fa:bookmark%</span> | ||||
| 	<span class="is-admin" v-if="note.user.isAdmin">admin</span> | ||||
| 	<span class="is-bot" v-if="note.user.isBot">bot</span> | ||||
| 	<span class="is-cat" v-if="note.user.isCat">cat</span> | ||||
| @@ -69,9 +70,14 @@ root(isDark) | ||||
| 		&:hover | ||||
| 			text-decoration underline | ||||
|  | ||||
| 	> .is-verified | ||||
| 		margin-right 8px | ||||
| 		color #4dabf7 | ||||
|  | ||||
| 	> .is-admin | ||||
| 	> .is-bot | ||||
| 	> .is-cat | ||||
| 		flex-shrink 0 | ||||
| 		align-self center | ||||
| 		margin 0 .5em 0 0 | ||||
| 		padding 1px 6px | ||||
| @@ -89,6 +95,7 @@ root(isDark) | ||||
| 		overflow hidden | ||||
| 		text-overflow ellipsis | ||||
| 		color isDark ? #606984 : #ccc | ||||
| 		flex-shrink 2147483647 | ||||
|  | ||||
| 	> .info | ||||
| 		margin-left auto | ||||
|   | ||||
| @@ -8,7 +8,10 @@ | ||||
| 	<img v-if="reaction == 'congrats'" src="/assets/reactions/congrats.png" alt="%i18n:common.reactions.congrats%"> | ||||
| 	<img v-if="reaction == 'angry'" src="/assets/reactions/angry.png" alt="%i18n:common.reactions.angry%"> | ||||
| 	<img v-if="reaction == 'confused'" src="/assets/reactions/confused.png" alt="%i18n:common.reactions.confused%"> | ||||
| 	<img v-if="reaction == 'pudding'" src="/assets/reactions/pudding.png" alt="%i18n:common.reactions.pudding%"> | ||||
| 	<template v-if="reaction == 'pudding'"> | ||||
| 		<img v-if="$store.getters.isSignedIn && $store.state.settings.iLikeSushi" src="/assets/reactions/sushi.png" alt="%i18n:common.reactions.pudding%"> | ||||
| 		<img v-else src="/assets/reactions/pudding.png" alt="%i18n:common.reactions.pudding%"> | ||||
| 	</template> | ||||
| </span> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <template> | ||||
| <div class="mk-reaction-picker"> | ||||
| 	<div class="backdrop" ref="backdrop" @click="close"></div> | ||||
| 	<div class="popover" :class="{ compact }" ref="popover"> | ||||
| 	<div class="popover" :class="{ compact, big }" ref="popover"> | ||||
| 		<p v-if="!compact">{{ title }}</p> | ||||
| 		<div> | ||||
| 			<button @click="react('like')" @mouseover="onMouseover" @mouseout="onMouseout" tabindex="1" title="%i18n:common.reactions.like%"><mk-reaction-icon reaction='like'/></button> | ||||
| @@ -25,7 +25,28 @@ import * as anime from 'animejs'; | ||||
| const placeholder = '%i18n:@choose-reaction%'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: ['note', 'source', 'compact', 'cb'], | ||||
| 	props: { | ||||
| 		note: { | ||||
| 			type: Object, | ||||
| 			required: true | ||||
| 		}, | ||||
| 		source: { | ||||
| 			required: true | ||||
| 		}, | ||||
| 		compact: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		}, | ||||
| 		cb: { | ||||
| 			required: false | ||||
| 		}, | ||||
| 		big: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		} | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| 			title: placeholder | ||||
| @@ -162,6 +183,16 @@ root(isDark) | ||||
| 				border-right solid $balloon-size transparent | ||||
| 				border-bottom solid $balloon-size $bgcolor | ||||
|  | ||||
| 		&.big | ||||
| 			> div | ||||
| 				width 280px | ||||
|  | ||||
| 				> button | ||||
| 					width 50px | ||||
| 					height 50px | ||||
| 					font-size 28px | ||||
| 					border-radius 4px | ||||
|  | ||||
| 		> p | ||||
| 			display block | ||||
| 			margin 0 | ||||
|   | ||||
| @@ -1,24 +1,33 @@ | ||||
| <template> | ||||
| <form class="mk-signin" :class="{ signing }" @submit.prevent="onSubmit"> | ||||
| 	<label class="user-name"> | ||||
| 		<input v-model="username" type="text" pattern="^[a-zA-Z0-9_]+$" placeholder="%i18n:@username%" autofocus required @change="onUsernameChange"/>%fa:at% | ||||
| 	</label> | ||||
| 	<label class="password"> | ||||
| 		<input v-model="password" type="password" placeholder="%i18n:@password%" required/>%fa:lock% | ||||
| 	</label> | ||||
| 	<label class="token" v-if="user && user.twoFactorEnabled"> | ||||
| 		<input v-model="token" type="number" placeholder="%i18n:@token%" required/>%fa:lock% | ||||
| 	</label> | ||||
| 	<button type="submit" :disabled="signing">{{ signing ? '%i18n:@signing-in%' : '%i18n:@signin%' }}</button> | ||||
| 	もしくは <a :href="`${apiUrl}/signin/twitter`">Twitterでログイン</a> | ||||
| 	<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"> | ||||
| 		<span>%i18n:@username%</span> | ||||
| 		<span slot="prefix">@</span> | ||||
| 		<span slot="suffix">@{{ host }}</span> | ||||
| 	</ui-input> | ||||
| 	<ui-input v-model="password" type="password" required> | ||||
| 		<span>%i18n:@password%</span> | ||||
| 		<span slot="prefix">%fa:lock%</span> | ||||
| 	</ui-input> | ||||
| 	<ui-input v-if="user && user.twoFactorEnabled" v-model="token" type="number" required/> | ||||
| 	<ui-button type="submit" :disabled="signing">{{ signing ? '%i18n:@signing-in%' : '%i18n:@signin%' }}</ui-button> | ||||
| 	<p style="margin: 8px 0;">または<a :href="`${apiUrl}/signin/twitter`">Twitterでログイン</a></p> | ||||
| </form> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { apiUrl } from '../../../config'; | ||||
| import { apiUrl, host } from '../../../config'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: { | ||||
| 		withAvatar: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: true | ||||
| 		} | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| 			signing: false, | ||||
| @@ -27,6 +36,7 @@ export default Vue.extend({ | ||||
| 			password: '', | ||||
| 			token: '', | ||||
| 			apiUrl, | ||||
| 			host | ||||
| 		}; | ||||
| 	}, | ||||
| 	methods: { | ||||
| @@ -35,6 +45,8 @@ export default Vue.extend({ | ||||
| 				username: this.username | ||||
| 			}).then(user => { | ||||
| 				this.user = user; | ||||
| 			}, () => { | ||||
| 				this.user = null; | ||||
| 			}); | ||||
| 		}, | ||||
| 		onSubmit() { | ||||
| @@ -59,84 +71,19 @@ export default Vue.extend({ | ||||
| @import '~const.styl' | ||||
|  | ||||
| .mk-signin | ||||
| 	color #555 | ||||
|  | ||||
| 	&.signing | ||||
| 		&, * | ||||
| 			cursor wait !important | ||||
|  | ||||
| 	label | ||||
| 		display block | ||||
| 		margin 12px 0 | ||||
|  | ||||
| 		[data-fa] | ||||
| 			display block | ||||
| 			pointer-events none | ||||
| 			position absolute | ||||
| 			bottom 0 | ||||
| 			top 0 | ||||
| 			left 0 | ||||
| 			z-index 1 | ||||
| 			margin auto | ||||
| 			padding 0 16px | ||||
| 			height 1em | ||||
| 			color #898786 | ||||
|  | ||||
| 		input[type=text] | ||||
| 		input[type=password] | ||||
| 		input[type=number] | ||||
| 			user-select text | ||||
| 			display inline-block | ||||
| 			cursor auto | ||||
| 			padding 0 0 0 38px | ||||
| 			margin 0 | ||||
| 			width 100% | ||||
| 			line-height 44px | ||||
| 			font-size 1em | ||||
| 			color rgba(#000, 0.7) | ||||
| 			background #fff | ||||
| 			outline none | ||||
| 			border solid 1px #eee | ||||
| 			border-radius 4px | ||||
|  | ||||
| 			&:hover | ||||
| 				background rgba(255, 255, 255, 0.7) | ||||
| 				border-color #ddd | ||||
|  | ||||
| 				& + i | ||||
| 					color #797776 | ||||
|  | ||||
| 			&:focus | ||||
| 				background #fff | ||||
| 				border-color #ccc | ||||
|  | ||||
| 				& + i | ||||
| 					color #797776 | ||||
|  | ||||
| 	[type=submit] | ||||
| 		cursor pointer | ||||
| 		padding 16px | ||||
| 		margin -6px 0 0 0 | ||||
| 		width 100% | ||||
| 		font-size 1.2em | ||||
| 		color rgba(#000, 0.5) | ||||
| 		outline none | ||||
| 		border none | ||||
| 		border-radius 0 | ||||
| 		background transparent | ||||
| 		transition all .5s ease | ||||
|  | ||||
| 		&:hover | ||||
| 			color $theme-color | ||||
| 			transition all .2s ease | ||||
|  | ||||
| 		&:focus | ||||
| 			color $theme-color | ||||
| 			transition all .2s ease | ||||
|  | ||||
| 		&:active | ||||
| 			color darken($theme-color, 30%) | ||||
| 			transition all .2s ease | ||||
|  | ||||
| 		&:disabled | ||||
| 			opacity 0.7 | ||||
| 	> .avatar | ||||
| 		margin 16px auto 0 auto | ||||
| 		width 64px | ||||
| 		height 64px | ||||
| 		background #ddd | ||||
| 		background-position center | ||||
| 		background-size cover | ||||
| 		border-radius 100% | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -1,60 +1,53 @@ | ||||
| <template> | ||||
| <form class="mk-signup" @submit.prevent="onSubmit" autocomplete="off"> | ||||
| 	<label class="username"> | ||||
| 		<p class="caption">%fa:at%%i18n:@username%</p> | ||||
| 		<input v-model="username" type="text" pattern="^[a-zA-Z0-9_]{1,20}$" placeholder="a~z、A~Z、0~9、-" autocomplete="off" required @input="onChangeUsername"/> | ||||
| 		<p class="profile-page-url-preview" v-if="shouldShowProfileUrl">{{ `${url}/@${username}` }}</p> | ||||
| 		<p class="info" v-if="usernameState == 'wait'" style="color:#999">%fa:spinner .pulse .fw%%i18n:@checking%</p> | ||||
| 		<p class="info" v-if="usernameState == 'ok'" style="color:#3CB7B5">%fa:check .fw%%i18n:@available%</p> | ||||
| 		<p class="info" v-if="usernameState == 'unavailable'" style="color:#FF1161">%fa:exclamation-triangle .fw%%i18n:@unavailable%</p> | ||||
| 		<p class="info" v-if="usernameState == 'error'" style="color:#FF1161">%fa:exclamation-triangle .fw%%i18n:@error%</p> | ||||
| 		<p class="info" v-if="usernameState == 'invalid-format'" style="color:#FF1161">%fa:exclamation-triangle .fw%%i18n:@invalid-format%</p> | ||||
| 		<p class="info" v-if="usernameState == 'min-range'" style="color:#FF1161">%fa:exclamation-triangle .fw%%i18n:@too-short%</p> | ||||
| 		<p class="info" v-if="usernameState == 'max-range'" style="color:#FF1161">%fa:exclamation-triangle .fw%%i18n:@too-long%</p> | ||||
| 	</label> | ||||
| 	<label class="password"> | ||||
| 		<p class="caption">%fa:lock%%i18n:@password%</p> | ||||
| 		<input v-model="password" type="password" placeholder="%i18n:@password-placeholder%" autocomplete="off" required @input="onChangePassword"/> | ||||
| 		<div class="meter" v-show="passwordStrength != ''" :data-strength="passwordStrength"> | ||||
| 			<div class="value" ref="passwordMetar"></div> | ||||
| <form class="mk-signup" @submit.prevent="onSubmit" :autocomplete="Math.random()"> | ||||
| 	<ui-input v-model="username" type="text" pattern="^[a-zA-Z0-9_]{1,20}$" :autocomplete="Math.random()" spellcheck="false" required @input="onChangeUsername"> | ||||
| 		<span>%i18n:@username%</span> | ||||
| 		<span slot="prefix">@</span> | ||||
| 		<span slot="suffix">@{{ host }}</span> | ||||
| 		<p slot="text" v-if="usernameState == 'wait'" style="color:#999">%fa:spinner .pulse .fw% %i18n:@checking%</p> | ||||
| 		<p slot="text" v-if="usernameState == 'ok'" style="color:#3CB7B5">%fa:check .fw% %i18n:@available%</p> | ||||
| 		<p slot="text" v-if="usernameState == 'unavailable'" style="color:#FF1161">%fa:exclamation-triangle .fw% %i18n:@unavailable%</p> | ||||
| 		<p slot="text" v-if="usernameState == 'error'" style="color:#FF1161">%fa:exclamation-triangle .fw% %i18n:@error%</p> | ||||
| 		<p slot="text" v-if="usernameState == 'invalid-format'" style="color:#FF1161">%fa:exclamation-triangle .fw% %i18n:@invalid-format%</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> | ||||
| 	</ui-input> | ||||
| 	<ui-input v-model="password" type="password" :autocomplete="Math.random()" required @input="onChangePassword" :with-password-meter="true"> | ||||
| 		<span>%i18n:@password%</span> | ||||
| 		<span slot="prefix">%fa:lock%</span> | ||||
| 		<div slot="text"> | ||||
| 			<p slot="text" v-if="passwordStrength == 'low'" style="color:#FF1161">%fa:exclamation-triangle .fw% %i18n:@weak-password%</p> | ||||
| 			<p slot="text" v-if="passwordStrength == 'medium'" style="color:#3CB7B5">%fa:check .fw% %i18n:@normal-password%</p> | ||||
| 			<p slot="text" v-if="passwordStrength == 'high'" style="color:#3CB7B5">%fa:check .fw% %i18n:@strong-password%</p> | ||||
| 		</div> | ||||
| 		<p class="info" v-if="passwordStrength == 'low'" style="color:#FF1161">%fa:exclamation-triangle .fw%%i18n:@weak-password%</p> | ||||
| 		<p class="info" v-if="passwordStrength == 'medium'" style="color:#3CB7B5">%fa:check .fw%%i18n:@normal-password%</p> | ||||
| 		<p class="info" v-if="passwordStrength == 'high'" style="color:#3CB7B5">%fa:check .fw%%i18n:@strong-password%</p> | ||||
| 	</label> | ||||
| 	<label class="retype-password"> | ||||
| 		<p class="caption">%fa:lock%%i18n:@password%(%i18n:@retype%)</p> | ||||
| 		<input v-model="retypedPassword" type="password" placeholder="%i18n:@retype-placeholder%" autocomplete="off" required @input="onChangePasswordRetype"/> | ||||
| 		<p class="info" v-if="passwordRetypeState == 'match'" style="color:#3CB7B5">%fa:check .fw%%i18n:@password-matched%</p> | ||||
| 		<p class="info" v-if="passwordRetypeState == 'not-match'" style="color:#FF1161">%fa:exclamation-triangle .fw%%i18n:@password-not-matched%</p> | ||||
| 	</label> | ||||
| 	<label class="recaptcha"> | ||||
| 		<p class="caption"><template v-if="recaptchaed">%fa:toggle-on%</template><template v-if="!recaptchaed">%fa:toggle-off%</template>%i18n:@recaptcha%</p> | ||||
| 		<div class="g-recaptcha" data-callback="onRecaptchaed" data-expired-callback="onRecaptchaExpired" :data-sitekey="recaptchaSitekey"></div> | ||||
| 	</label> | ||||
| 	<label class="agree-tou"> | ||||
| 		<input name="agree-tou" type="checkbox" autocomplete="off" required/> | ||||
| 		<p><a :href="touUrl" target="_blank">利用規約</a>に同意する</p> | ||||
| 	</label> | ||||
| 	<button type="submit">%i18n:@create%</button> | ||||
| 	</ui-input> | ||||
| 	<ui-input v-model="retypedPassword" type="password" :autocomplete="Math.random()" required @input="onChangePasswordRetype"> | ||||
| 		<span>%i18n:@password% (%i18n:@retype%)</span> | ||||
| 		<span slot="prefix">%fa:lock%</span> | ||||
| 		<div slot="text"> | ||||
| 			<p slot="text" v-if="passwordRetypeState == 'match'" style="color:#3CB7B5">%fa:check .fw% %i18n:@password-matched%</p> | ||||
| 			<p slot="text" v-if="passwordRetypeState == 'not-match'" style="color:#FF1161">%fa:exclamation-triangle .fw% %i18n:@password-not-matched%</p> | ||||
| 		</div> | ||||
| 	</ui-input> | ||||
| 	<div v-if="recaptchaSitekey != null" class="g-recaptcha" :data-sitekey="recaptchaSitekey" style="margin: 16px 0;"></div> | ||||
| 	<ui-button type="submit">%i18n:@create%</ui-button> | ||||
| </form> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| const getPasswordStrength = require('syuilo-password-strength'); | ||||
| import { url, docsUrl, lang, recaptchaSitekey } from '../../../config'; | ||||
| import { host, url, recaptchaSitekey } from '../../../config'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	data() { | ||||
| 		return { | ||||
| 			host, | ||||
| 			username: '', | ||||
| 			password: '', | ||||
| 			retypedPassword: '', | ||||
| 			url, | ||||
| 			touUrl: `${docsUrl}/${lang}/tou`, | ||||
| 			recaptchaSitekey, | ||||
| 			recaptchaed: false, | ||||
| 			usernameState: null, | ||||
| 			passwordStrength: '', | ||||
| 			passwordRetypeState: null | ||||
| @@ -104,7 +97,6 @@ export default Vue.extend({ | ||||
|  | ||||
| 			const strength = getPasswordStrength(this.password); | ||||
| 			this.passwordStrength = strength > 0.7 ? 'high' : strength > 0.3 ? 'medium' : 'low'; | ||||
| 			(this.$refs.passwordMetar as any).style.width = `${strength * 100}%`; | ||||
| 		}, | ||||
| 		onChangePasswordRetype() { | ||||
| 			if (this.retypedPassword == '') { | ||||
| @@ -118,7 +110,7 @@ export default Vue.extend({ | ||||
| 			(this as any).api('signup', { | ||||
| 				username: this.username, | ||||
| 				password: this.password, | ||||
| 				'g-recaptcha-response': (window as any).grecaptcha.getResponse() | ||||
| 				'g-recaptcha-response': recaptchaSitekey != null ? (window as any).grecaptcha.getResponse() : null | ||||
| 			}).then(() => { | ||||
| 				(this as any).api('signin', { | ||||
| 					username: this.username, | ||||
| @@ -129,25 +121,19 @@ export default Vue.extend({ | ||||
| 			}).catch(() => { | ||||
| 				alert('%i18n:@some-error%'); | ||||
|  | ||||
| 				(window as any).grecaptcha.reset(); | ||||
| 				this.recaptchaed = false; | ||||
| 				if (recaptchaSitekey != null) { | ||||
| 					(window as any).grecaptcha.reset(); | ||||
| 				} | ||||
| 			}); | ||||
| 		} | ||||
| 	}, | ||||
| 	created() { | ||||
| 		(window as any).onRecaptchaed = () => { | ||||
| 			this.recaptchaed = true; | ||||
| 		}; | ||||
|  | ||||
| 		(window as any).onRecaptchaExpired = () => { | ||||
| 			this.recaptchaed = false; | ||||
| 		}; | ||||
| 	}, | ||||
| 	mounted() { | ||||
| 		const head = document.getElementsByTagName('head')[0]; | ||||
| 		const script = document.createElement('script'); | ||||
| 		script.setAttribute('src', 'https://www.google.com/recaptcha/api.js'); | ||||
| 		head.appendChild(script); | ||||
| 		if (recaptchaSitekey != null) { | ||||
| 			const head = document.getElementsByTagName('head')[0]; | ||||
| 			const script = document.createElement('script'); | ||||
| 			script.setAttribute('src', 'https://www.google.com/recaptcha/api.js'); | ||||
| 			head.appendChild(script); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
| @@ -157,131 +143,4 @@ export default Vue.extend({ | ||||
|  | ||||
| .mk-signup | ||||
| 	min-width 302px | ||||
|  | ||||
| 	label | ||||
| 		display block | ||||
| 		margin 0 0 16px 0 | ||||
|  | ||||
| 		> .caption | ||||
| 			margin 0 0 4px 0 | ||||
| 			color #828888 | ||||
| 			font-size 0.95em | ||||
|  | ||||
| 			> [data-fa] | ||||
| 				margin-right 0.25em | ||||
| 				color #96adac | ||||
|  | ||||
| 		> .info | ||||
| 			display block | ||||
| 			margin 4px 0 | ||||
| 			font-size 0.8em | ||||
|  | ||||
| 			> [data-fa] | ||||
| 				margin-right 0.3em | ||||
|  | ||||
| 		&.username | ||||
| 			.profile-page-url-preview | ||||
| 				display block | ||||
| 				margin 4px 8px 0 4px | ||||
| 				font-size 0.8em | ||||
| 				color #888 | ||||
|  | ||||
| 				&:empty | ||||
| 					display none | ||||
|  | ||||
| 				&:not(:empty) + .info | ||||
| 					margin-top 0 | ||||
|  | ||||
| 		&.password | ||||
| 			.meter | ||||
| 				display block | ||||
| 				margin-top 8px | ||||
| 				width 100% | ||||
| 				height 8px | ||||
|  | ||||
| 				&[data-strength=''] | ||||
| 					display none | ||||
|  | ||||
| 				&[data-strength='low'] | ||||
| 					> .value | ||||
| 						background #d73612 | ||||
|  | ||||
| 				&[data-strength='medium'] | ||||
| 					> .value | ||||
| 						background #d7ca12 | ||||
|  | ||||
| 				&[data-strength='high'] | ||||
| 					> .value | ||||
| 						background #61bb22 | ||||
|  | ||||
| 				> .value | ||||
| 					display block | ||||
| 					width 0% | ||||
| 					height 100% | ||||
| 					background transparent | ||||
| 					border-radius 4px | ||||
| 					transition all 0.1s ease | ||||
|  | ||||
| 	[type=text], [type=password] | ||||
| 		user-select text | ||||
| 		display inline-block | ||||
| 		cursor auto | ||||
| 		padding 0 12px | ||||
| 		margin 0 | ||||
| 		width 100% | ||||
| 		line-height 44px | ||||
| 		font-size 1em | ||||
| 		color #333 !important | ||||
| 		background #fff !important | ||||
| 		outline none | ||||
| 		border solid 1px rgba(#000, 0.1) | ||||
| 		border-radius 4px | ||||
| 		box-shadow 0 0 0 114514px #fff inset | ||||
| 		transition all .3s ease | ||||
|  | ||||
| 		&:hover | ||||
| 			border-color rgba(#000, 0.2) | ||||
| 			transition all .1s ease | ||||
|  | ||||
| 		&:focus | ||||
| 			color $theme-color !important | ||||
| 			border-color $theme-color | ||||
| 			box-shadow 0 0 0 1024px #fff inset, 0 0 0 4px rgba($theme-color, 10%) | ||||
| 			transition all 0s ease | ||||
|  | ||||
| 		&:disabled | ||||
| 			opacity 0.5 | ||||
|  | ||||
| 	.agree-tou | ||||
| 		padding 4px | ||||
| 		border-radius 4px | ||||
|  | ||||
| 		&:hover | ||||
| 			background #f4f4f4 | ||||
|  | ||||
| 		&:active | ||||
| 			background #eee | ||||
|  | ||||
| 		&, * | ||||
| 			cursor pointer | ||||
|  | ||||
| 		p | ||||
| 			display inline | ||||
| 			color #555 | ||||
|  | ||||
| 	button | ||||
| 		margin 0 | ||||
| 		padding 16px | ||||
| 		width 100% | ||||
| 		font-size 1em | ||||
| 		color #fff | ||||
| 		background $theme-color | ||||
| 		border-radius 3px | ||||
|  | ||||
| 		&:hover | ||||
| 			background lighten($theme-color, 5%) | ||||
|  | ||||
| 		&:active | ||||
| 			background darken($theme-color, 5%) | ||||
|  | ||||
| </style> | ||||
|   | ||||
							
								
								
									
										82
									
								
								src/client/app/common/views/components/ui/button.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,82 @@ | ||||
| <template> | ||||
| <div class="ui-button" :class="[styl]"> | ||||
| 	<button :type="type" @click="$emit('click')"> | ||||
| 		<slot></slot> | ||||
| 	</button> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| export default Vue.extend({ | ||||
| 	props: { | ||||
| 		type: { | ||||
| 			type: String, | ||||
| 			required: false | ||||
| 		} | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| 			styl: 'fill' | ||||
| 		}; | ||||
| 	}, | ||||
| 	inject: { | ||||
| 		isCardChild: { default: false } | ||||
| 	}, | ||||
| 	created() { | ||||
| 		if (this.isCardChild) { | ||||
| 			this.styl = 'line'; | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark, fill) | ||||
| 	> button | ||||
| 		display block | ||||
| 		width 100% | ||||
| 		margin 0 | ||||
| 		padding 0 | ||||
| 		font-weight bold | ||||
| 		font-size 16px | ||||
| 		line-height 44px | ||||
| 		border none | ||||
| 		border-radius 6px | ||||
| 		outline none | ||||
| 		box-shadow none | ||||
|  | ||||
| 		if fill | ||||
| 			color $theme-color-foreground | ||||
| 			background $theme-color | ||||
|  | ||||
| 			&:hover | ||||
| 				background lighten($theme-color, 5%) | ||||
|  | ||||
| 			&:active | ||||
| 				background darken($theme-color, 5%) | ||||
| 		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) | ||||
| 		root(true, false) | ||||
|  | ||||
| .ui-button:not([data-darkmode]) | ||||
| 	&.fill | ||||
| 		root(false, true) | ||||
| 	&:not(.fill) | ||||
| 		root(false, false) | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										46
									
								
								src/client/app/common/views/components/ui/card.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,46 @@ | ||||
| <template> | ||||
| <div class="ui-card"> | ||||
| 	<header> | ||||
| 		<slot name="title"></slot> | ||||
| 	</header> | ||||
|  | ||||
| 	<slot></slot> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| export default Vue.extend({ | ||||
| 	provide() { | ||||
| 		return { | ||||
| 			isCardChild: true | ||||
| 		}; | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
| 	margin 16px | ||||
| 	padding 16px | ||||
| 	color isDark ? #fff : #000 | ||||
| 	background isDark ? #282C37 : #fff | ||||
| 	box-shadow 0 3px 1px -2px rgba(#000, 0.2), 0 2px 2px 0 rgba(#000, 0.14), 0 1px 5px 0 rgba(#000, 0.12) | ||||
|  | ||||
| 	@media (min-width 500px) | ||||
| 		padding 32px | ||||
|  | ||||
| 	> header | ||||
| 		font-weight normal | ||||
| 		font-size 24px | ||||
| 		color isDark ? #fff : #444 | ||||
|  | ||||
| .ui-card[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .ui-card:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										30
									
								
								src/client/app/common/views/components/ui/form.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,30 @@ | ||||
| <template> | ||||
| <div class="ui-form"> | ||||
| 	<fieldset :disabled="disabled"> | ||||
| 		<slot></slot> | ||||
| 	</fieldset> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| export default Vue.extend({ | ||||
| 	props: { | ||||
| 		disabled: { | ||||
| 			type: Boolean, | ||||
| 			required: false | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| .ui-form | ||||
| 	> fieldset | ||||
| 		margin 0 | ||||
| 		padding 0 | ||||
| 		border none | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										350
									
								
								src/client/app/common/views/components/ui/input.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,350 @@ | ||||
| <template> | ||||
| <div class="ui-input" :class="[{ focused, filled }, styl]"> | ||||
| 	<div class="icon" ref="icon"><slot name="icon"></slot></div> | ||||
| 	<div class="input"> | ||||
| 		<div class="password-meter" v-if="withPasswordMeter" v-show="passwordStrength != ''" :data-strength="passwordStrength"> | ||||
| 			<div class="value" ref="passwordMetar"></div> | ||||
| 		</div> | ||||
| 		<span class="label" ref="label"><slot></slot></span> | ||||
| 		<div class="prefix" ref="prefix"><slot name="prefix"></slot></div> | ||||
| 		<template v-if="type != 'file'"> | ||||
| 			<input ref="input" | ||||
| 					:type="type" | ||||
| 					v-model="v" | ||||
| 					:required="required" | ||||
| 					:readonly="readonly" | ||||
| 					:pattern="pattern" | ||||
| 					:autocomplete="autocomplete" | ||||
| 					:spellcheck="spellcheck" | ||||
| 					@focus="focused = true" | ||||
| 					@blur="focused = false"> | ||||
| 		</template> | ||||
| 		<template v-else> | ||||
| 			<input ref="input" | ||||
| 					type="text" | ||||
| 					:value="placeholder" | ||||
| 					readonly | ||||
| 					@click="chooseFile"> | ||||
| 			<input ref="file" | ||||
| 					type="file" | ||||
| 					:value="value" | ||||
| 					@change="onChangeFile"> | ||||
| 		</template> | ||||
| 		<div class="suffix" ref="suffix"><slot name="suffix"></slot></div> | ||||
| 	</div> | ||||
| 	<div class="text"><slot name="text"></slot></div> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| const getPasswordStrength = require('syuilo-password-strength'); | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: { | ||||
| 		value: { | ||||
| 			required: false | ||||
| 		}, | ||||
| 		type: { | ||||
| 			type: String, | ||||
| 			required: false | ||||
| 		}, | ||||
| 		required: { | ||||
| 			type: Boolean, | ||||
| 			required: false | ||||
| 		}, | ||||
| 		readonly: { | ||||
| 			type: Boolean, | ||||
| 			required: false | ||||
| 		}, | ||||
| 		pattern: { | ||||
| 			type: String, | ||||
| 			required: false | ||||
| 		}, | ||||
| 		autocomplete: { | ||||
| 			required: false | ||||
| 		}, | ||||
| 		spellcheck: { | ||||
| 			required: false | ||||
| 		}, | ||||
| 		withPasswordMeter: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		} | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| 			v: this.value, | ||||
| 			focused: false, | ||||
| 			passwordStrength: '', | ||||
| 			styl: 'fill' | ||||
| 		}; | ||||
| 	}, | ||||
| 	computed: { | ||||
| 		filled(): boolean { | ||||
| 			return this.v != '' && this.v != null; | ||||
| 		}, | ||||
| 		placeholder(): string { | ||||
| 			if (this.type != 'file') return null; | ||||
| 			if (this.v == null) return null; | ||||
|  | ||||
| 			if (typeof this.v == 'string') return this.v; | ||||
|  | ||||
| 			if (Array.isArray(this.v)) { | ||||
| 				return this.v.map(file => file.name).join(', '); | ||||
| 			} else { | ||||
| 				return this.v.name; | ||||
| 			} | ||||
| 		} | ||||
| 	}, | ||||
| 	watch: { | ||||
| 		value(v) { | ||||
| 			this.v = v; | ||||
| 		}, | ||||
| 		v(v) { | ||||
| 			this.$emit('input', v); | ||||
|  | ||||
| 			if (this.withPasswordMeter) { | ||||
| 				if (v == '') { | ||||
| 					this.passwordStrength = ''; | ||||
| 					return; | ||||
| 				} | ||||
|  | ||||
| 				const strength = getPasswordStrength(v); | ||||
| 				this.passwordStrength = strength > 0.7 ? 'high' : strength > 0.3 ? 'medium' : 'low'; | ||||
| 				(this.$refs.passwordMetar as any).style.width = `${strength * 100}%`; | ||||
| 			} | ||||
| 		} | ||||
| 	}, | ||||
| 	inject: { | ||||
| 		isCardChild: { default: false } | ||||
| 	}, | ||||
| 	created() { | ||||
| 		if (this.isCardChild) { | ||||
| 			this.styl = 'line'; | ||||
| 		} | ||||
| 	}, | ||||
| 	mounted() { | ||||
| 		if (this.$refs.prefix) { | ||||
| 			this.$refs.label.style.left = (this.$refs.prefix.offsetLeft + this.$refs.prefix.offsetWidth) + 'px'; | ||||
| 			if (this.$refs.prefix.offsetWidth) { | ||||
| 				this.$refs.input.style.paddingLeft = this.$refs.prefix.offsetWidth + 'px'; | ||||
| 			} | ||||
| 		} | ||||
| 		if (this.$refs.suffix) { | ||||
| 			if (this.$refs.suffix.offsetWidth) { | ||||
| 				this.$refs.input.style.paddingRight = this.$refs.suffix.offsetWidth + 'px'; | ||||
| 			} | ||||
| 		} | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		focus() { | ||||
| 			this.$refs.input.focus(); | ||||
| 		}, | ||||
| 		chooseFile() { | ||||
| 			this.$refs.file.click(); | ||||
| 		}, | ||||
| 		onChangeFile() { | ||||
| 			this.v = Array.from((this.$refs.file as any).files); | ||||
| 			this.$emit('input', this.v); | ||||
| 			this.$emit('change', this.v); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark, fill) | ||||
| 	margin 32px 0 | ||||
|  | ||||
| 	> .icon | ||||
| 		position absolute | ||||
| 		top 0 | ||||
| 		left 0 | ||||
| 		width 24px | ||||
| 		text-align center | ||||
| 		line-height 32px | ||||
| 		color isDark ? rgba(#fff, 0.7) : rgba(#000, 0.54) | ||||
|  | ||||
| 		&:not(:empty) + .input | ||||
| 			margin-left 28px | ||||
|  | ||||
| 	> .input | ||||
|  | ||||
| 		if !fill | ||||
| 			&:before | ||||
| 				content '' | ||||
| 				display block | ||||
| 				position absolute | ||||
| 				bottom 0 | ||||
| 				left 0 | ||||
| 				right 0 | ||||
| 				height 1px | ||||
| 				background isDark ? rgba(#fff, 0.7) : rgba(#000, 0.42) | ||||
|  | ||||
| 			&:after | ||||
| 				content '' | ||||
| 				display block | ||||
| 				position absolute | ||||
| 				bottom 0 | ||||
| 				left 0 | ||||
| 				right 0 | ||||
| 				height 2px | ||||
| 				background $theme-color | ||||
| 				opacity 0 | ||||
| 				transform scaleX(0.12) | ||||
| 				transition border 0.3s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1), transform 0.3s cubic-bezier(0.4, 0, 0.2, 1) | ||||
| 				will-change border opacity transform | ||||
|  | ||||
| 		> .password-meter | ||||
| 			position absolute | ||||
| 			top 0 | ||||
| 			left 0 | ||||
| 			width 100% | ||||
| 			height 100% | ||||
| 			border-radius 6px | ||||
| 			overflow hidden | ||||
| 			opacity 0.3 | ||||
|  | ||||
| 			&[data-strength=''] | ||||
| 				display none | ||||
|  | ||||
| 			&[data-strength='low'] | ||||
| 				> .value | ||||
| 					background #d73612 | ||||
|  | ||||
| 			&[data-strength='medium'] | ||||
| 				> .value | ||||
| 					background #d7ca12 | ||||
|  | ||||
| 			&[data-strength='high'] | ||||
| 				> .value | ||||
| 					background #61bb22 | ||||
|  | ||||
| 			> .value | ||||
| 				display block | ||||
| 				width 0% | ||||
| 				height 100% | ||||
| 				background transparent | ||||
| 				border-radius 6px | ||||
| 				transition all 0.1s ease | ||||
|  | ||||
| 		> .label | ||||
| 			position absolute | ||||
| 			z-index 1 | ||||
| 			top fill ? 6px : 0 | ||||
| 			left 0 | ||||
| 			pointer-events none | ||||
| 			transition 0.4s cubic-bezier(0.25, 0.8, 0.25, 1) | ||||
| 			transition-duration 0.3s | ||||
| 			font-size 16px | ||||
| 			line-height 32px | ||||
| 			color isDark ? rgba(#fff, 0.7) : rgba(#000, 0.54) | ||||
| 			pointer-events none | ||||
| 			//will-change transform | ||||
| 			transform-origin top left | ||||
| 			transform scale(1) | ||||
|  | ||||
| 		> input | ||||
| 			display block | ||||
| 			width 100% | ||||
| 			margin 0 | ||||
| 			padding 0 | ||||
| 			font inherit | ||||
| 			font-weight fill ? bold : normal | ||||
| 			font-size 16px | ||||
| 			line-height 32px | ||||
| 			color isDark ? #fff : #000 | ||||
| 			background transparent | ||||
| 			border none | ||||
| 			border-radius 0 | ||||
| 			outline none | ||||
| 			box-shadow none | ||||
|  | ||||
| 			if fill | ||||
| 				padding 6px 12px | ||||
| 				background rgba(#000, 0.035) | ||||
| 				border-radius 6px | ||||
|  | ||||
| 			&[type='file'] | ||||
| 				display none | ||||
|  | ||||
| 		> .prefix | ||||
| 		> .suffix | ||||
| 			display block | ||||
| 			position absolute | ||||
| 			z-index 1 | ||||
| 			top 0 | ||||
| 			font-size 16px | ||||
| 			line-height fill ? 44px : 32px | ||||
| 			color isDark ? rgba(#fff, 0.7) : rgba(#000, 0.54) | ||||
| 			pointer-events none | ||||
|  | ||||
| 			&:empty | ||||
| 				display none | ||||
|  | ||||
| 			> * | ||||
| 				display block | ||||
| 				min-width 16px | ||||
| 				max-width 150px | ||||
| 				overflow hidden | ||||
| 				white-space nowrap | ||||
| 				text-overflow ellipsis | ||||
|  | ||||
| 		> .prefix | ||||
| 			left 0 | ||||
| 			padding-right 4px | ||||
|  | ||||
| 			if fill | ||||
| 				padding-left 12px | ||||
|  | ||||
| 		> .suffix | ||||
| 			right 0 | ||||
| 			padding-left 4px | ||||
|  | ||||
| 			if fill | ||||
| 				padding-right 12px | ||||
|  | ||||
| 	> .text | ||||
| 		margin 6px 0 | ||||
| 		font-size 13px | ||||
|  | ||||
| 		* | ||||
| 			margin 0 | ||||
|  | ||||
| 	&.focused | ||||
| 		> .input | ||||
| 			if fill | ||||
| 				background rgba(#000, 0.05) | ||||
| 			else | ||||
| 				&:after | ||||
| 					opacity 1 | ||||
| 					transform scaleX(1) | ||||
|  | ||||
| 			> .label | ||||
| 				color $theme-color | ||||
|  | ||||
| 	&.focused | ||||
| 	&.filled | ||||
| 		> .input | ||||
| 			> .label | ||||
| 				top fill ? -24px : -17px | ||||
| 				left 0 !important | ||||
| 				transform scale(0.75) | ||||
|  | ||||
| .ui-input[data-darkmode] | ||||
| 	&.fill | ||||
| 		root(true, true) | ||||
| 	&:not(.fill) | ||||
| 		root(true, false) | ||||
|  | ||||
| .ui-input:not([data-darkmode]) | ||||
| 	&.fill | ||||
| 		root(false, true) | ||||
| 	&:not(.fill) | ||||
| 		root(false, false) | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										120
									
								
								src/client/app/common/views/components/ui/radio.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,120 @@ | ||||
| <template> | ||||
| <div | ||||
| 	class="ui-radio" | ||||
| 	:class="{ disabled, checked }" | ||||
| 	:aria-checked="checked" | ||||
| 	:aria-disabled="disabled" | ||||
| 	@click="toggle" | ||||
| > | ||||
| 	<input type="radio" | ||||
| 		:disabled="disabled" | ||||
| 	> | ||||
| 	<span class="button"> | ||||
| 		<span></span> | ||||
| 	</span> | ||||
| 	<span class="label"><slot></slot></span> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| export default Vue.extend({ | ||||
| 	model: { | ||||
| 		prop: 'model', | ||||
| 		event: 'change' | ||||
| 	}, | ||||
| 	props: { | ||||
| 		model: { | ||||
| 			type: String, | ||||
| 			required: false | ||||
| 		}, | ||||
| 		value: { | ||||
| 			type: String, | ||||
| 			required: false | ||||
| 		}, | ||||
| 		disabled: { | ||||
| 			type: Boolean, | ||||
| 			default: false | ||||
| 		} | ||||
| 	}, | ||||
| 	computed: { | ||||
| 		checked(): boolean { | ||||
| 			return this.model === this.value; | ||||
| 		} | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		toggle() { | ||||
| 			this.$emit('change', this.value); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
| 	display inline-block | ||||
| 	margin 32px 32px 32px 0 | ||||
| 	cursor pointer | ||||
| 	transition all 0.3s | ||||
|  | ||||
| 	> * | ||||
| 		user-select none | ||||
|  | ||||
| 	&.disabled | ||||
| 		opacity 0.6 | ||||
| 		cursor not-allowed | ||||
|  | ||||
| 	&.checked | ||||
| 		> .button | ||||
| 			border-color $theme-color | ||||
|  | ||||
| 			&:after | ||||
| 				background-color $theme-color | ||||
| 				transform scale(1) | ||||
| 				opacity 1 | ||||
|  | ||||
| 	> input | ||||
| 		position absolute | ||||
| 		width 0 | ||||
| 		height 0 | ||||
| 		opacity 0 | ||||
| 		margin 0 | ||||
|  | ||||
| 	> .button | ||||
| 		position absolute | ||||
| 		width 20px | ||||
| 		height 20px | ||||
| 		background none | ||||
| 		border solid 2px isDark ? rgba(#fff, 0.7) : rgba(#000, 0.54) | ||||
| 		border-radius 100% | ||||
| 		transition inherit | ||||
|  | ||||
| 		&:after | ||||
| 			content '' | ||||
| 			display block | ||||
| 			position absolute | ||||
| 			top 3px | ||||
| 			right 3px | ||||
| 			bottom 3px | ||||
| 			left 3px | ||||
| 			border-radius 100% | ||||
| 			opacity 0 | ||||
| 			transform scale(0) | ||||
| 			transition 0.4s cubic-bezier(0.25, 0.8, 0.25, 1) | ||||
|  | ||||
| 	> .label | ||||
| 		margin-left 28px | ||||
| 		display block | ||||
| 		font-size 16px | ||||
| 		line-height 20px | ||||
| 		cursor pointer | ||||
|  | ||||
| .ui-radio[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .ui-radio:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										215
									
								
								src/client/app/common/views/components/ui/select.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,215 @@ | ||||
| <template> | ||||
| <div class="ui-select" :class="[{ focused, filled }, styl]"> | ||||
| 	<div class="icon" ref="icon"><slot name="icon"></slot></div> | ||||
| 	<div class="input" @click="focus"> | ||||
| 		<span class="label" ref="label"><slot name="label"></slot></span> | ||||
| 		<div class="prefix" ref="prefix"><slot name="prefix"></slot></div> | ||||
| 		<select ref="input" | ||||
| 				:value="v" | ||||
| 				:required="required" | ||||
| 				@input="$emit('input', $event.target.value)" | ||||
| 				@focus="focused = true" | ||||
| 				@blur="focused = false"> | ||||
| 			<slot></slot> | ||||
| 		</select> | ||||
| 		<div class="suffix"><slot name="suffix"></slot></div> | ||||
| 	</div> | ||||
| 	<div class="text"><slot name="text"></slot></div> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: { | ||||
| 		value: { | ||||
| 			required: false | ||||
| 		}, | ||||
| 		required: { | ||||
| 			type: Boolean, | ||||
| 			required: false | ||||
| 		} | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| 			v: this.value, | ||||
| 			focused: false, | ||||
| 			styl: 'fill' | ||||
| 		}; | ||||
| 	}, | ||||
| 	computed: { | ||||
| 		filled(): boolean { | ||||
| 			return this.v != '' && this.v != null; | ||||
| 		} | ||||
| 	}, | ||||
| 	watch: { | ||||
| 		value(v) { | ||||
| 			this.v = v; | ||||
| 		} | ||||
| 	}, | ||||
| 	inject: { | ||||
| 		isCardChild: { default: false } | ||||
| 	}, | ||||
| 	created() { | ||||
| 		if (this.isCardChild) { | ||||
| 			this.styl = 'line'; | ||||
| 		} | ||||
| 	}, | ||||
| 	mounted() { | ||||
| 		if (this.$refs.prefix) { | ||||
| 			this.$refs.label.style.left = (this.$refs.prefix.offsetLeft + this.$refs.prefix.offsetWidth) + 'px'; | ||||
| 		} | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		focus() { | ||||
| 			this.$refs.input.focus(); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark, fill) | ||||
| 	margin 32px 0 | ||||
|  | ||||
| 	> .icon | ||||
| 		position absolute | ||||
| 		top 0 | ||||
| 		left 0 | ||||
| 		width 24px | ||||
| 		text-align center | ||||
| 		line-height 32px | ||||
| 		color rgba(#000, 0.54) | ||||
|  | ||||
| 		&:not(:empty) + .input | ||||
| 			margin-left 28px | ||||
|  | ||||
| 	> .input | ||||
| 		display flex | ||||
|  | ||||
| 		if fill | ||||
| 			padding 6px 12px | ||||
| 			background rgba(#000, 0.035) | ||||
| 			border-radius 6px | ||||
| 		else | ||||
| 			&:before | ||||
| 				content '' | ||||
| 				display block | ||||
| 				position absolute | ||||
| 				bottom 0 | ||||
| 				left 0 | ||||
| 				right 0 | ||||
| 				height 1px | ||||
| 				background isDark ? rgba(#fff, 0.7) : rgba(#000, 0.42) | ||||
|  | ||||
| 			&:after | ||||
| 				content '' | ||||
| 				display block | ||||
| 				position absolute | ||||
| 				bottom 0 | ||||
| 				left 0 | ||||
| 				right 0 | ||||
| 				height 2px | ||||
| 				background $theme-color | ||||
| 				opacity 0 | ||||
| 				transform scaleX(0.12) | ||||
| 				transition border 0.3s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1), transform 0.3s cubic-bezier(0.4, 0, 0.2, 1) | ||||
| 				will-change border opacity transform | ||||
|  | ||||
| 		> .label | ||||
| 			position absolute | ||||
| 			top fill ? 6px : 0 | ||||
| 			left 0 | ||||
| 			pointer-events none | ||||
| 			transition 0.4s cubic-bezier(0.25, 0.8, 0.25, 1) | ||||
| 			transition-duration 0.3s | ||||
| 			font-size 16px | ||||
| 			line-height 32px | ||||
| 			color rgba(#000, 0.54) | ||||
| 			pointer-events none | ||||
| 			//will-change transform | ||||
| 			transform-origin top left | ||||
| 			transform scale(1) | ||||
|  | ||||
| 		> select | ||||
| 			display block | ||||
| 			flex 1 | ||||
| 			width 100% | ||||
| 			padding 0 | ||||
| 			font inherit | ||||
| 			font-weight fill ? bold : normal | ||||
| 			font-size 16px | ||||
| 			height 32px | ||||
| 			color isDark ? #fff : #000 | ||||
| 			background transparent | ||||
| 			border none | ||||
| 			border-radius 0 | ||||
| 			outline none | ||||
| 			box-shadow none | ||||
|  | ||||
| 			* | ||||
| 				color #000 | ||||
|  | ||||
| 		> .prefix | ||||
| 		> .suffix | ||||
| 			display block | ||||
| 			align-self center | ||||
| 			justify-self center | ||||
| 			font-size 16px | ||||
| 			line-height 32px | ||||
| 			color rgba(#000, 0.54) | ||||
| 			pointer-events none | ||||
|  | ||||
| 			> * | ||||
| 				display block | ||||
| 				min-width 16px | ||||
|  | ||||
| 		> .prefix | ||||
| 			padding-right 4px | ||||
|  | ||||
| 		> .suffix | ||||
| 			padding-left 4px | ||||
|  | ||||
| 	> .text | ||||
| 		margin 6px 0 | ||||
| 		font-size 13px | ||||
|  | ||||
| 		* | ||||
| 			margin 0 | ||||
|  | ||||
| 	&.focused | ||||
| 		> .input | ||||
| 			if fill | ||||
| 				background rgba(#000, 0.05) | ||||
| 			else | ||||
| 				&:after | ||||
| 					opacity 1 | ||||
| 					transform scaleX(1) | ||||
|  | ||||
| 			> .label | ||||
| 				color $theme-color | ||||
|  | ||||
| 	&.focused | ||||
| 	&.filled | ||||
| 		> .input | ||||
| 			> .label | ||||
| 				top fill ? -24px : -17px | ||||
| 				left 0 !important | ||||
| 				transform scale(0.75) | ||||
|  | ||||
| .ui-select[data-darkmode] | ||||
| 	&.fill | ||||
| 		root(true, true) | ||||
| 	&:not(.fill) | ||||
| 		root(true, false) | ||||
|  | ||||
| .ui-select:not([data-darkmode]) | ||||
| 	&.fill | ||||
| 		root(false, true) | ||||
| 	&:not(.fill) | ||||
| 		root(false, false) | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										135
									
								
								src/client/app/common/views/components/ui/switch.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,135 @@ | ||||
| <template> | ||||
| <div | ||||
| 	class="ui-switch" | ||||
| 	:class="{ disabled, checked }" | ||||
| 	role="switch" | ||||
| 	:aria-checked="checked" | ||||
| 	:aria-disabled="disabled" | ||||
| 	@click="toggle" | ||||
| > | ||||
| 	<input | ||||
| 		type="checkbox" | ||||
| 		ref="input" | ||||
| 		:disabled="disabled" | ||||
| 		@keydown.enter="toggle" | ||||
| 	> | ||||
| 	<span class="button"> | ||||
| 		<span></span> | ||||
| 	</span> | ||||
| 	<span class="label"> | ||||
| 		<span :aria-hidden="!checked"><slot></slot></span> | ||||
| 		<p :aria-hidden="!checked"> | ||||
| 			<slot name="text"></slot> | ||||
| 		</p> | ||||
| 	</span> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| export default Vue.extend({ | ||||
| 	model: { | ||||
| 		prop: 'value', | ||||
| 		event: 'change' | ||||
| 	}, | ||||
| 	props: { | ||||
| 		value: { | ||||
| 			type: Boolean, | ||||
| 			default: false | ||||
| 		}, | ||||
| 		disabled: { | ||||
| 			type: Boolean, | ||||
| 			default: false | ||||
| 		} | ||||
| 	}, | ||||
| 	computed: { | ||||
| 		checked(): boolean { | ||||
| 			return this.value; | ||||
| 		} | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		toggle() { | ||||
| 			this.$emit('change', !this.checked); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark) | ||||
| 	display flex | ||||
| 	margin 32px 0 | ||||
| 	cursor pointer | ||||
| 	transition all 0.3s | ||||
|  | ||||
| 	> * | ||||
| 		user-select none | ||||
|  | ||||
| 	&.disabled | ||||
| 		opacity 0.6 | ||||
| 		cursor not-allowed | ||||
|  | ||||
| 	&.checked | ||||
| 		> .button | ||||
| 			background-color rgba($theme-color, 0.4) | ||||
| 			border-color rgba($theme-color, 0.4) | ||||
|  | ||||
| 			> * | ||||
| 				background-color $theme-color | ||||
| 				transform translateX(14px) | ||||
|  | ||||
| 	> input | ||||
| 		position absolute | ||||
| 		width 0 | ||||
| 		height 0 | ||||
| 		opacity 0 | ||||
| 		margin 0 | ||||
|  | ||||
| 	> .button | ||||
| 		display inline-block | ||||
| 		margin 3px 0 0 0 | ||||
| 		width 34px | ||||
| 		height 14px | ||||
| 		background isDark ? rgba(#fff, 0.15) : rgba(#000, 0.25) | ||||
| 		outline none | ||||
| 		border-radius 14px | ||||
| 		transition inherit | ||||
|  | ||||
| 		> * | ||||
| 			position absolute | ||||
| 			top -3px | ||||
| 			left 0 | ||||
| 			border-radius 100% | ||||
| 			transition background-color 0.3s, transform 0.3s | ||||
| 			width 20px | ||||
| 			height 20px | ||||
| 			background-color #fff | ||||
| 			box-shadow 0 2px 1px -1px rgba(#000, 0.2), 0 1px 1px 0 rgba(#000, 0.14), 0 1px 3px 0 rgba(#000, 0.12) | ||||
|  | ||||
| 	> .label | ||||
| 		margin-left 8px | ||||
| 		display block | ||||
| 		font-size 16px | ||||
| 		cursor pointer | ||||
| 		transition inherit | ||||
|  | ||||
| 		> span | ||||
| 			display block | ||||
| 			line-height 20px | ||||
| 			color isDark ? #c4ccd2 : rgba(#000, 0.75) | ||||
| 			transition inherit | ||||
|  | ||||
| 		> p | ||||
| 			margin 0 | ||||
| 			//font-size 90% | ||||
| 			color isDark ? #78858e : #9daab3 | ||||
|  | ||||
| .ui-switch[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
| .ui-switch:not([data-darkmode]) | ||||
| 	root(false) | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										174
									
								
								src/client/app/common/views/components/ui/textarea.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,174 @@ | ||||
| <template> | ||||
| <div class="ui-textarea" :class="{ focused, filled }"> | ||||
| 	<div class="input"> | ||||
| 		<span class="label" ref="label"><slot></slot></span> | ||||
| 		<textarea ref="input" | ||||
| 				:value="value" | ||||
| 				:required="required" | ||||
| 				:readonly="readonly" | ||||
| 				:pattern="pattern" | ||||
| 				:autocomplete="autocomplete" | ||||
| 				@input="$emit('input', $event.target.value)" | ||||
| 				@focus="focused = true" | ||||
| 				@blur="focused = false"> | ||||
| 		</textarea> | ||||
| 	</div> | ||||
| 	<div class="text"><slot name="text"></slot></div> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| const getPasswordStrength = require('syuilo-password-strength'); | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: { | ||||
| 		value: { | ||||
| 			required: false | ||||
| 		}, | ||||
| 		required: { | ||||
| 			type: Boolean, | ||||
| 			required: false | ||||
| 		}, | ||||
| 		readonly: { | ||||
| 			type: Boolean, | ||||
| 			required: false | ||||
| 		}, | ||||
| 		pattern: { | ||||
| 			type: String, | ||||
| 			required: false | ||||
| 		}, | ||||
| 		autocomplete: { | ||||
| 			type: String, | ||||
| 			required: false | ||||
| 		} | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| 			focused: false, | ||||
| 			passwordStrength: '' | ||||
| 		} | ||||
| 	}, | ||||
| 	computed: { | ||||
| 		filled(): boolean { | ||||
| 			return this.value != '' && this.value != null; | ||||
| 		} | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		focus() { | ||||
| 			this.$refs.input.focus(); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| @import '~const.styl' | ||||
|  | ||||
| root(isDark, fill) | ||||
| 	margin 42px 0 32px 0 | ||||
|  | ||||
| 	> .input | ||||
| 		padding 12px | ||||
|  | ||||
| 		if fill | ||||
| 			background rgba(#000, 0.035) | ||||
| 			border-radius 6px | ||||
| 		else | ||||
| 			&:before | ||||
| 				content '' | ||||
| 				display block | ||||
| 				position absolute | ||||
| 				top 0 | ||||
| 				bottom 0 | ||||
| 				left 0 | ||||
| 				right 0 | ||||
| 				background none | ||||
| 				border solid 1px isDark ? rgba(#fff, 0.7) : rgba(#000, 0.42) | ||||
| 				border-radius 3px | ||||
| 				pointer-events none | ||||
|  | ||||
| 			&:after | ||||
| 				content '' | ||||
| 				display block | ||||
| 				position absolute | ||||
| 				top 0 | ||||
| 				bottom 0 | ||||
| 				left 0 | ||||
| 				right 0 | ||||
| 				background none | ||||
| 				border solid 2px $theme-color | ||||
| 				border-radius 3px | ||||
| 				opacity 0 | ||||
| 				transition opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1) | ||||
| 				pointer-events none | ||||
|  | ||||
| 		> .label | ||||
| 			position absolute | ||||
| 			top 6px | ||||
| 			left 12px | ||||
| 			pointer-events none | ||||
| 			transition 0.4s cubic-bezier(0.25, 0.8, 0.25, 1) | ||||
| 			transition-duration 0.3s | ||||
| 			font-size 16px | ||||
| 			line-height 32px | ||||
| 			color isDark ? rgba(#fff, 0.7) : rgba(#000, 0.54) | ||||
| 			pointer-events none | ||||
| 			//will-change transform | ||||
| 			transform-origin top left | ||||
| 			transform scale(1) | ||||
|  | ||||
| 		> textarea | ||||
| 			display block | ||||
| 			width 100% | ||||
| 			min-height 100px | ||||
| 			padding 0 | ||||
| 			font inherit | ||||
| 			font-weight fill ? bold : normal | ||||
| 			font-size 16px | ||||
| 			color isDark ? #fff : #000 | ||||
| 			background transparent | ||||
| 			border none | ||||
| 			border-radius 0 | ||||
| 			outline none | ||||
| 			box-shadow none | ||||
|  | ||||
| 	> .text | ||||
| 		margin 6px 0 | ||||
| 		font-size 13px | ||||
|  | ||||
| 		* | ||||
| 			margin 0 | ||||
|  | ||||
| 	&.focused | ||||
| 		> .input | ||||
| 			if fill | ||||
| 				background rgba(#000, 0.05) | ||||
| 			else | ||||
| 				&:after | ||||
| 					opacity 1 | ||||
|  | ||||
| 			> .label | ||||
| 				color $theme-color | ||||
|  | ||||
| 	&.focused | ||||
| 	&.filled | ||||
| 		> .input | ||||
| 			> .label | ||||
| 				top -24px | ||||
| 				left 0 !important | ||||
| 				transform scale(0.75) | ||||
|  | ||||
| .ui-textarea[data-darkmode] | ||||
| 	&.fill | ||||
| 		root(true, true) | ||||
| 	&:not(.fill) | ||||
| 		root(true, false) | ||||
|  | ||||
| .ui-textarea:not([data-darkmode]) | ||||
| 	&.fill | ||||
| 		root(false, true) | ||||
| 	&:not(.fill) | ||||
| 		root(false, false) | ||||
|  | ||||
| </style> | ||||
| @@ -2,6 +2,11 @@ | ||||
| <iframe v-if="youtubeId" type="text/html" height="250" | ||||
| 	:src="`https://www.youtube.com/embed/${youtubeId}?origin=${misskeyUrl}`" | ||||
| 	frameborder="0"/> | ||||
| <div v-else-if="tweetUrl && detail" class="twitter"> | ||||
| 	<blockquote ref="tweet" class="twitter-tweet" :data-theme="$store.state.device.darkmode ? 'dark' : null"> | ||||
| 		<a :href="url"></a> | ||||
| 	</blockquote> | ||||
| </div> | ||||
| <div v-else class="mk-url-preview"> | ||||
| 	<a :href="url" target="_blank" :title="url" v-if="!fetching"> | ||||
| 		<div class="thumbnail" v-if="thumbnail" :style="`background-image: url(${thumbnail})`"></div> | ||||
| @@ -24,7 +29,17 @@ import Vue from 'vue'; | ||||
| import { url as misskeyUrl } from '../../../config'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: ['url'], | ||||
| 	props: { | ||||
| 		url: { | ||||
| 			type: String, | ||||
| 			require: true | ||||
| 		}, | ||||
| 		detail: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		} | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| 			fetching: true, | ||||
| @@ -34,6 +49,7 @@ export default Vue.extend({ | ||||
| 			icon: null, | ||||
| 			sitename: null, | ||||
| 			youtubeId: null, | ||||
| 			tweetUrl: null, | ||||
| 			misskeyUrl | ||||
| 		}; | ||||
| 	}, | ||||
| @@ -44,6 +60,25 @@ export default Vue.extend({ | ||||
| 			this.youtubeId = url.searchParams.get('v'); | ||||
| 		} else if (url.hostname == 'youtu.be') { | ||||
| 			this.youtubeId = url.pathname; | ||||
| 		} else if (this.detail && url.hostname == 'twitter.com' && /^\/.+\/status(es)?\/\d+/.test(url.pathname)) { | ||||
| 			this.tweetUrl = url; | ||||
| 			const twttr = (window as any).twttr || {}; | ||||
| 			const loadTweet = () => twttr.widgets.load(this.$refs.tweet); | ||||
|  | ||||
| 			if (twttr.widgets) { | ||||
| 				Vue.nextTick(loadTweet); | ||||
| 			} else { | ||||
| 				const wjsId = 'twitter-wjs'; | ||||
| 				if (!document.getElementById(wjsId)) { | ||||
| 					const head = document.getElementsByTagName('head')[0]; | ||||
| 					const script = document.createElement('script'); | ||||
| 					script.setAttribute('id', wjsId); | ||||
| 					script.setAttribute('src', 'https://platform.twitter.com/widgets.js'); | ||||
| 					head.appendChild(script); | ||||
| 				} | ||||
| 				twttr.ready = loadTweet; | ||||
| 				(window as any).twttr = twttr; | ||||
| 			} | ||||
| 		} else { | ||||
| 			fetch('/url?url=' + encodeURIComponent(this.url)).then(res => { | ||||
| 				res.json().then(info => { | ||||
|   | ||||
| @@ -13,7 +13,7 @@ | ||||
| 				</div> | ||||
| 			</header> | ||||
| 			<div class="text"> | ||||
| 				<mk-note-html v-if="note.text" :text="note.text"/> | ||||
| 				<misskey-flavored-markdown v-if="note.text" :text="note.text"/> | ||||
| 			</div> | ||||
| 		</div> | ||||
| 	</div> | ||||
| @@ -24,6 +24,13 @@ | ||||
| import Vue from 'vue'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: { | ||||
| 		max: { | ||||
| 			type: Number, | ||||
| 			required: false, | ||||
| 			default: undefined | ||||
| 		} | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| 			fetching: true, | ||||
| @@ -37,6 +44,7 @@ export default Vue.extend({ | ||||
| 		fetch(cb?) { | ||||
| 			this.fetching = true; | ||||
| 			(this as any).api('notes', { | ||||
| 				limit: this.max, | ||||
| 				local: true, | ||||
| 				reply: false, | ||||
| 				renote: false, | ||||
| @@ -109,6 +117,9 @@ root(isDark) | ||||
| 					> .created-at | ||||
| 						color isDark ? #606984 : #c0c0c0 | ||||
|  | ||||
| 			> .text | ||||
| 				text-align left | ||||
|  | ||||
| .mk-welcome-timeline[data-darkmode] | ||||
| 	root(true) | ||||
|  | ||||
|   | ||||