Compare commits
	
		
			1040 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | c40b630530 | ||
|   | 7fc0698ecf | ||
|   | 4f3c8b940e | ||
|   | 1855ab60f1 | ||
|   | af4f1a7bd6 | ||
|   | 8646a9c49c | ||
|   | 8d7c033cf5 | ||
|   | b8900e32de | ||
|   | d48c25d2c9 | ||
|   | a87c5899c5 | ||
|   | 147ad69864 | ||
|   | c146006476 | ||
|   | a0f10d7ca1 | ||
|   | 299b91edc4 | ||
|   | 95c89ca6db | ||
|   | 7fe0d71e7f | ||
|   | fbbb506e86 | ||
|   | ec80b06a45 | ||
|   | 41e1619f1f | ||
|   | ba6a9c6a93 | ||
|   | 18571c52fb | ||
|   | 5d5dfeaa83 | ||
|   | 3669d8c0f3 | ||
|   | 69d72819c6 | ||
|   | 54dcc10250 | ||
|   | 1edfce8f73 | ||
|   | 675e573a8c | ||
|   | 1080fa63a9 | ||
|   | 8047086988 | ||
|   | 449b9f7fa0 | ||
|   | b7a15bf6ca | ||
|   | 7c3873887d | ||
|   | 247ea4cf12 | ||
|   | 0b7af5c669 | ||
|   | 2b62a4e2e5 | ||
|   | 65bfa3c0d6 | ||
|   | 84db15694d | ||
|   | 746189ba37 | ||
|   | 74e845b3ac | ||
|   | 90fe70540e | ||
|   | f28af75191 | ||
|   | 924bb2bc70 | ||
|   | 19d60f3d51 | ||
|   | 6903476868 | ||
|   | cf0dccc209 | ||
|   | cfd959129d | ||
|   | 819287951c | ||
|   | e136193925 | ||
|   | 8c631864d9 | ||
|   | d7d0f6ae2e | ||
|   | b83b3fb9d1 | ||
|   | dfce5bc0af | ||
|   | 3487ddabea | ||
|   | 2dbff75e7a | ||
|   | 02465ded9f | ||
|   | ffcd387945 | ||
|   | 4806346707 | ||
|   | 31c3f6abf7 | ||
|   | 83e47fdd60 | ||
|   | 340ce7fa4c | ||
|   | ac86fee9b4 | ||
|   | 6dfa283d7a | ||
|   | 0cce8a4d21 | ||
|   | 1c6d9ab2ef | ||
|   | 6ca265e579 | ||
|   | c612c4bf18 | ||
|   | 481a791a60 | ||
|   | cb516c2943 | ||
|   | c0abd6f0c0 | ||
|   | 47695ed685 | ||
|   | 4ca8020ef5 | ||
|   | bfac83d5b8 | ||
|   | 4cd2e55fd3 | ||
|   | 61c7e7bc48 | ||
|   | bef41718e2 | ||
|   | 5b4b52bb97 | ||
|   | 8901b6d774 | ||
|   | e3a24e9215 | ||
|   | a515c1f53e | ||
|   | 2e22874dec | ||
|   | 30f0b1c30d | ||
|   | 600aea4dbb | ||
|   | f5d53d784d | ||
|   | 1061e1f7ae | ||
|   | 1d5fc04aa6 | ||
|   | d1cf0c7998 | ||
|   | 84218abf2b | ||
|   | 5bebdb2511 | ||
|   | 9c8e9b4165 | ||
|   | 7b786bfde3 | ||
|   | 42a08642a4 | ||
|   | e88f7ca7b2 | ||
|   | c26ed1421b | ||
|   | ed2f94a3c1 | ||
|   | daba7fe87c | ||
|   | afc9caf7bf | ||
|   | 67697a7aa6 | ||
|   | 1623d9e70c | ||
|   | c304351335 | ||
|   | c1520763c6 | ||
|   | 4853bc9414 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | e7c865f8e3 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 46cb377bc2 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 373a5ba3e1 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 3bedef67c8 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 17ea19ada8 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 1f5b2285fd | ||
|   | 17f0001966 | ||
|   | 04ba09a6af | ||
|   | 70d2744319 | ||
|   | 6b2f0929ec | ||
|   | f2629bd3f2 | ||
|   | 9e6c29c3c0 | ||
|   | abda973094 | ||
|   | 86b08dd5bd | ||
|   | 617e331f0f | ||
|   | cc438a9372 | ||
|   | b0fb218bfd | ||
|   | fc85a607e6 | ||
|   | fb244c45e3 | ||
|   | c123784c54 | ||
|   | 342a5276fc | ||
|   | 51a32846ee | ||
|   | 35865429a8 | ||
|   | aadd5b95b8 | ||
|   | f9f2ca51ac | ||
|   | 1cb93a8c10 | ||
|   | 7e5dbb2ba5 | ||
|   | 2772e3d80e | ||
|   | 223c578734 | ||
|   | d01315dee2 | ||
|   | 7dafb4ce4c | ||
|   | 9671db9b14 | ||
|   | bec559f67c | ||
|   | 14053c1394 | ||
|   | 55e4b1c828 | ||
|   | dda3421159 | ||
|   | 45e7488e60 | ||
|   | 30c7bd66b7 | ||
|   | af4f5bdac0 | ||
|   | 3d1a8cc341 | ||
|   | 0e52fb2544 | ||
|   | e6d6c0a17c | ||
|   | cfd2d47e00 | ||
|   | 83301a879d | ||
|   | d7881ba129 | ||
|   | b9fef1edf7 | ||
|   | 2c606f7b23 | ||
|   | 03797607ed | ||
|   | 254b7f500d | ||
|   | 51edd51bf2 | ||
|   | 0d403f4a3f | ||
|   | 0fa134addd | ||
|   | 7002270084 | ||
|   | 1c5452d047 | ||
|   | f0d62c07bf | ||
|   | 496ca55bba | ||
|   | 79cfba226b | ||
|   | f69b60dffe | ||
|   | 513385133f | ||
|   | 6f1e2f6636 | ||
|   | 8ae94c034d | ||
|   | cd9696f25e | ||
|   | d62a6bab41 | ||
|   | 20df002746 | ||
|   | fa6b01546e | ||
|   | 91b37a6e52 | ||
|   | d8171d7c8b | ||
|   | fa96e2daf1 | ||
|   | 87708c3b84 | ||
|   | 6319023cc9 | ||
|   | efad9d1b60 | ||
|   | a1dea657fa | ||
|   | 6b1b75717b | ||
|   | efe08e0bd3 | ||
|   | 62892c4894 | ||
|   | 0c2a62da11 | ||
|   | 5bc9e9aadd | ||
|   | 112c33d35b | ||
|   | 864da3030f | ||
|   | f2e719b361 | ||
|   | 6aab515389 | ||
|   | 819b535ab0 | ||
|   | 60e95ac2ac | ||
|   | 9b94ddff0a | ||
|   | 174f8022eb | ||
|   | ddc3c5ba68 | ||
|   | a7e6b766be | ||
|   | befc35a3ac | ||
|   | 2e9bbf389e | ||
|   | 80b5fda292 | ||
|   | c48cbd95f6 | ||
|   | 931bdc6aac | ||
|   | 7f81506c8b | ||
|   | b4b9e76c8d | ||
|   | e5a3dcf868 | ||
|   | 825648535c | ||
|   | 5cbc908ba3 | ||
|   | 895cf53ee1 | ||
|   | e41f74e77c | ||
|   | c21caad1c5 | ||
|   | 86fcd3a378 | ||
|   | 2b3687b3cb | ||
|   | 5d61c7c691 | ||
|   | 1bb266e7c7 | ||
|   | 1fca8d322c | ||
|   | 325cd03a59 | ||
|   | 2f7e6baa05 | ||
|   | d252e066fe | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | fe7bd9ab3c | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 84e3f41305 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 3e8cccad0d | ||
|   | a2b94d67f7 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 6ab61e73b0 | ||
|   | 051c6973af | ||
|   | 806a49ec3d | ||
|   | 3829fe128a | ||
|   | 649177985d | ||
|   | c15148b23c | ||
|   | 261a3f5d91 | ||
|   | 256ba78ba5 | ||
|   | 04aff8866e | ||
|   | 1a51b98700 | ||
|   | f64100226d | ||
|   | b7805e48a6 | ||
|   | 0d9556620d | ||
|   | a51828a7a2 | ||
|   | 7e2009f408 | ||
|   | 008d950a39 | ||
|   | 22d5862afb | ||
|   | de569147a5 | ||
|   | a82c3db750 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 80706d10af | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 93f01ed4df | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | a3a28e5557 | ||
|   | 8948a0d3a4 | ||
|   | d849ea9b41 | ||
|   | 0144575f3f | ||
|   | bdbe646ca7 | ||
|   | 1a1483a242 | ||
|   | 962346785b | ||
|   | a73da3cd70 | ||
|   | 9c27d0ae3f | ||
|   | 525d5218c1 | ||
|   | e23b13ec7f | ||
|   | 29b000e03c | ||
|   | 6a7b0df810 | ||
|   | 4142de9195 | ||
|   | 9195e1be00 | ||
|   | 75382d13fd | ||
|   | d444280a28 | ||
|   | 52fc0fe04a | ||
|   | 216bebadf1 | ||
|   | a5592931cb | ||
|   | a2228417ff | ||
|   | 3e1e292c3e | ||
|   | f2f039ae9e | ||
|   | 29dde1eda0 | ||
|   | 45d3792ce0 | ||
|   | 875d0aaebb | ||
|   | 26c9d8ff6f | ||
|   | 5e3372e932 | ||
|   | f7069dcd18 | ||
|   | 560bb65384 | ||
|   | 50cd6a036e | ||
|   | 441ab2b5f8 | ||
|   | ba5ed188a1 | ||
|   | 72e672f08d | ||
|   | 120474ec6a | ||
|   | eee57c47f5 | ||
|   | 4c160869b8 | ||
|   | 3720a7fbe0 | ||
|   | 7afa541a53 | ||
|   | 6f979c8275 | ||
|   | d399241e65 | ||
|   | e85dec030a | ||
|   | d0220764cc | ||
|   | 75c1df9531 | ||
|   | bca7156d6b | ||
|   | 64277b7157 | ||
|   | 4a72543f65 | ||
|   | 5b84d29807 | ||
|   | a11061ec2b | ||
|   | 24cfb93b2e | ||
|   | 502b42d63a | ||
|   | 612672b79c | ||
|   | abc670e1b1 | ||
|   | d589ccdd01 | ||
|   | acb07d9f7d | ||
|   | f4d2186719 | ||
|   | d0ede5c665 | ||
|   | 554cbb5e9b | ||
|   | dbd32a56bf | ||
|   | 7f500235c6 | ||
|   | 39a58084c8 | ||
|   | cde0fde836 | ||
|   | e70cca0fda | ||
|   | 919bd7eb82 | ||
|   | 312cff3d6f | ||
|   | 0d86eef3d7 | ||
|   | 13acf570e7 | ||
|   | fa17623fa8 | ||
|   | 06fd525950 | ||
|   | 4805b5115a | ||
|   | 108dcb3e61 | ||
|   | 780d272535 | ||
|   | 02ea4b81a5 | ||
|   | 7c1bdc6d36 | ||
|   | 78c7b8b836 | ||
|   | 227da30acb | ||
|   | 610805026f | ||
|   | c02399c3d2 | ||
|   | e0799d4153 | ||
|   | 6df83f1aa9 | ||
|   | efb5ad1d9b | ||
|   | 716976f016 | ||
|   | 7892f41b84 | ||
|   | d549e03b3f | ||
|   | c511ef21ff | ||
|   | d64dc45899 | ||
|   | bcb0588409 | ||
|   | 0975959eb9 | ||
|   | e985a6d9d3 | ||
|   | b893305974 | ||
|   | 724fdd44e4 | ||
|   | b480ef669c | ||
|   | 4b145da046 | ||
|   | 83d168ece3 | ||
|   | ae44fe7818 | ||
|   | f8981b3acb | ||
|   | 050b324885 | ||
|   | e74c0df6c6 | ||
|   | 22d0d11895 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 80d0c0cf74 | ||
|   | 518646b925 | ||
|   | 479d7e0087 | ||
|   | 8ea1a555f4 | ||
|   | 04024dc37c | ||
|   | 060ff9288f | ||
|   | 197116ee78 | ||
|   | a1e0015257 | ||
|   | 7e701ef9e0 | ||
|   | 3d6fb661bb | ||
|   | fc372496da | ||
|   | ad7258fe9c | ||
|   | bd707cb2a8 | ||
|   | 1839b5f205 | ||
|   | 02b47f963c | ||
|   | f8a7f9378a | ||
|   | 65cb253be4 | ||
|   | a12356b24b | ||
|   | 6a67ad7f93 | ||
|   | 140a7f0b1c | ||
|   | 00159bc6b5 | ||
|   | 9542260103 | ||
|   | 72074578df | ||
|   | 3b4750a988 | ||
|   | aeec5f0163 | ||
|   | 9c94d8c8d6 | ||
|   | 581712a2c8 | ||
|   | b25b51aaca | ||
|   | fb97e13a61 | ||
|   | 36e154fdb2 | ||
|   | ca273a24b4 | ||
|   | d828bf2889 | ||
|   | 87efccef18 | ||
|   | e0bf522e7f | ||
|   | 5b1cd3bd3c | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | f00489196d | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | dd53bf7e51 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 35a6da26d2 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | c8c8748a0b | ||
|   | 46d0065a90 | ||
|   | 990b0180a8 | ||
|   | f3bfb72251 | ||
|   | 0358a7edc6 | ||
|   | 37f99fca04 | ||
|   | 50dfc8ab82 | ||
|   | c70c739b0c | ||
|   | 5918285326 | ||
|   | b1dead1186 | ||
|   | 3e36e132c3 | ||
|   | fa8d1809e7 | ||
|   | e12b668d04 | ||
|   | e5506f7d8c | ||
|   | b1ac7e5cb3 | ||
|   | ffd164a5f3 | ||
|   | cb27414026 | ||
|   | e320912f33 | ||
|   | d23aaae698 | ||
|   | 120c0fe848 | ||
|   | 34857b9520 | ||
|   | a87dcece4c | ||
|   | 01e2479004 | ||
|   | 0fd63fe091 | ||
|   | cc98801c67 | ||
|   | 2724d74108 | ||
|   | 6d0c0d3a5f | ||
|   | 15f8f63317 | ||
|   | d970d65968 | ||
|   | 04d359691b | ||
|   | bfc519944a | ||
|   | 9f69fd14a2 | ||
|   | 85058787b2 | ||
|   | ec851623e0 | ||
|   | e05429a3ec | ||
|   | f651c41816 | ||
|   | 6b88d99ae2 | ||
|   | 814469cdca | ||
|   | 536bf8f141 | ||
|   | 6a27290815 | ||
|   | 7dde3465e2 | ||
|   | 0206a4ac83 | ||
|   | 380f5a972c | ||
|   | 407467a236 | ||
|   | bcfa9e18bf | ||
|   | 69b730e91a | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 6c6c003d68 | ||
|   | fd652b70d6 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 804a5ab6a8 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | d984a1aa19 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | e05b5a6ab8 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 3ff84db421 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 74ca73ecb4 | ||
|   | 37032f68ae | ||
|   | 21d3605737 | ||
|   | 0a7c1caf43 | ||
|   | 24b57335fa | ||
|   | 9f981d875a | ||
|   | 6dcc3800e0 | ||
|   | 44e9be5a1c | ||
|   | 6a8c560d21 | ||
|   | 0afe8c6b34 | ||
|   | 0f5d7f52a0 | ||
|   | aaaefa0ee2 | ||
|   | 276929bc7e | ||
|   | 32882f1397 | ||
|   | 7dc380c485 | ||
|   | 49aaa9a5d3 | ||
|   | 84462eb3f2 | ||
|   | 91709ca979 | ||
|   | 9ece71e652 | ||
|   | 4e93f6c6ff | ||
|   | ad9f1fb7c7 | ||
|   | abaeea6d8b | ||
|   | 8efbcc4c6b | ||
|   | 8ef31cab8c | ||
|   | 37ae53e55c | ||
|   | d01f06bdf4 | ||
|   | 0d4a8d118a | ||
|   | 7e6ec83b1f | ||
|   | 9eb515cfae | ||
|   | d0da019a21 | ||
|   | 57a13c9ad3 | ||
|   | 7f39100634 | ||
|   | 9ab96ef39a | ||
|   | ed21d797a6 | ||
|   | 15960746bb | ||
|   | e0f1e3ca71 | ||
|   | 51d0524182 | ||
|   | 16801aa5c4 | ||
|   | cd23f66834 | ||
|   | cc5d2b2875 | ||
|   | 94ef03db9e | ||
|   | 038bd100b2 | ||
|   | 3b5c3f086a | ||
|   | a136715111 | ||
|   | daa22d68fa | ||
|   | f24d202024 | ||
|   | d3e0b8574b | ||
|   | f4482cc34a | ||
|   | 3ff226cd6b | ||
|   | 5c0d37d021 | ||
|   | b958959cca | ||
|   | 762418d0fa | ||
|   | 6831f0c192 | ||
|   | 64635fff2d | ||
|   | e7e861fb5c | ||
|   | 08523ce271 | ||
|   | 833f63c1a9 | ||
|   | 1c05825bc8 | ||
|   | 26bb088a3d | ||
|   | 5c361cef23 | ||
|   | 04bef96aee | ||
|   | a791981da9 | ||
|   | 264c47e07a | ||
|   | 863c44d15c | ||
|   | cdec6f202e | ||
|   | bdf6c739a9 | ||
|   | 843dd5fb58 | ||
|   | c05853289a | ||
|   | 11c5d257f2 | ||
|   | cee1a27348 | ||
|   | 690dc75e45 | ||
|   | 8dc82b7a6e | ||
|   | a396b519bb | ||
|   | d5f9ce0893 | ||
|   | c1d7ae99ab | ||
|   | d8aee7c310 | ||
|   | 3e43d847ca | ||
|   | 70273931b2 | ||
|   | cc94d2acc5 | ||
|   | 327d9702ca | ||
|   | 1cdb285fe6 | ||
|   | e9e61e3034 | ||
|   | b613a51035 | ||
|   | 63e62ecb02 | ||
|   | d11122af3f | ||
|   | e8ddb7f6ee | ||
|   | 5ad0a158bc | ||
|   | e3ea29a8b6 | ||
|   | ead201ac3d | ||
|   | 19af2d7a7b | ||
|   | 8ba87443ca | ||
|   | 162ace2fd6 | ||
|   | f51fdc0dbf | ||
|   | d3d612a89b | ||
|   | 7c7f32d9a6 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | c8b6b6e44f | ||
|   | 12daa80071 | ||
|   | 2f8cc36d4b | ||
|   | 1af4f94338 | ||
|   | 172a0a85aa | ||
|   | d37c06884d | ||
|   | 80e52c57e1 | ||
|   | 213a7f137e | ||
|   | 4848b71ca0 | ||
|   | 13bad106cc | ||
|   | 3bebf82501 | ||
|   | e9a8090d7e | ||
|   | e2a79abbe0 | ||
|   | d7f57a4415 | ||
|   | 9dd5ed7f1a | ||
|   | 432e18a0c0 | ||
|   | 9a2d435cb1 | ||
|   | b02274c178 | ||
|   | 91408bceb1 | ||
|   | e1fd7e3f0c | ||
|   | d18498cb6b | ||
|   | b3986b8963 | ||
|   | 75e3d6f7fb | ||
|   | ded78aa294 | ||
|   | 58e8938364 | ||
|   | 6e8e6c7352 | ||
|   | 270de03646 | ||
|   | b6c7ff109b | ||
|   | 9b72a5a46d | ||
|   | 626e06c5fd | ||
|   | b09d10ac52 | ||
|   | d1568cda19 | ||
|   | 3400b4fa0d | ||
|   | 4455f110b1 | ||
|   | 25fc37449b | ||
|   | e5ffc7c492 | ||
|   | 5c118e6d8a | ||
|   | b49c70e67e | ||
|   | 3760fdeed0 | ||
|   | 3aece449e4 | ||
|   | dcd2d8be77 | ||
|   | b90e6f9abb | ||
|   | d984652aa1 | ||
|   | f176de6d2e | ||
|   | ef31efabb2 | ||
|   | 53763acb76 | ||
|   | 6f39010133 | ||
|   | 04b5fe6af4 | ||
|   | 626f43f424 | ||
|   | bebcc72deb | ||
|   | 9f285779ec | ||
|   | 57d3e9fc32 | ||
|   | 84cf09c1d0 | ||
|   | 0848bad960 | ||
|   | c1b13c3b5b | ||
|   | 8abc4ed65a | ||
|   | 0eebe620cb | ||
|   | 62a0d87795 | ||
|   | 8318633749 | ||
|   | a453f8aa2e | ||
|   | 54d2b90c25 | ||
|   | 7e1865984d | ||
|   | a2c56cc112 | ||
|   | 5c0ee8ca48 | ||
|   | 7397b2b82b | ||
|   | ddcbe21ce6 | ||
|   | 8fc7d1377d | ||
|   | 092403f362 | ||
|   | bb179922b9 | ||
|   | c29f912461 | ||
|   | 83d3e1cfe6 | ||
|   | 2914f0f65d | ||
|   | 99aa588ae7 | ||
|   | 0085e1f3ab | ||
|   | 53a9eb13f8 | ||
|   | b8c56c4dda | ||
|   | 59266b3190 | ||
|   | 0dc94547f5 | ||
|   | 29fc6de330 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | e24d0c40cd | ||
|   | e95845777a | ||
|   | 167648f61c | ||
|   | 9e6d6ff0dd | ||
|   | e659cc3d58 | ||
|   | ff6d45571a | ||
|   | 6cc9a2c945 | ||
|   | a873401bd7 | ||
|   | 6b19745241 | ||
|   | 982fae80aa | ||
|   | 77b15a3535 | ||
|   | 72754ede4e | ||
|   | b8ed8336e0 | ||
|   | 13f82856f9 | ||
|   | a62013f54d | ||
|   | 4c180869c6 | ||
|   | 7bbf022978 | ||
|   | 6b0d48423d | ||
|   | a617b8dbed | ||
|   | c57f472caf | ||
|   | e1ba19fd7e | ||
|   | 1bf8cbeb29 | ||
|   | f13faf2243 | ||
|   | 6cccd9d288 | ||
|   | be2cde106b | ||
|   | 17263fb459 | ||
|   | fed04ef5ae | ||
|   | 969b6dbcad | ||
|   | aa50d0ee11 | ||
|   | f09999ad5a | ||
|   | 35814faf8a | ||
|   | 8447a7fafa | ||
|   | c6e6c5e3ce | ||
|   | 85cbd8dd47 | ||
|   | bebc9003a3 | ||
|   | 3c081fbd65 | ||
|   | fdcf874306 | ||
|   | 6cbb741fa1 | ||
|   | 24129c1cb9 | ||
|   | f0938c36f5 | ||
|   | 484a6eda2e | ||
|   | 3f2ebffbe7 | ||
|   | ff278a7d8f | ||
|   | 844a3c3aff | ||
|   | 0db48993e9 | ||
|   | 81e21c4314 | ||
|   | ba0e57396d | ||
|   | 6a728d160a | ||
|   | 180e507bc8 | ||
|   | f3b7611ded | ||
|   | c344de5546 | ||
|   | 0bd0aa2bf7 | ||
|   | c786cbb3a1 | ||
|   | cd856f653d | ||
|   | d528c09da6 | ||
|   | 76b7ad006d | ||
|   | ff33e405a3 | ||
|   | f74de26d63 | ||
|   | 2c823798d8 | ||
|   | 381e261bbb | ||
|   | ba9bb5db6c | ||
|   | cd12bb33a5 | ||
|   | e333aee232 | ||
|   | 54571f60c3 | ||
|   | dd743aaeac | ||
|   | 22c76dc9f8 | ||
|   | 7c7e09cf64 | ||
|   | e5e3d69371 | ||
|   | 82a700b24e | ||
|   | 0579425a4f | ||
|   | 218e74569d | ||
|   | 448f54cf84 | ||
|   | c139e13049 | ||
|   | 65116fef32 | ||
|   | a0a35b7dca | ||
|   | 11fb8a24b7 | ||
|   | 512336685c | ||
|   | 484f281c19 | ||
|   | 2169bc5d3e | ||
|   | c653c84ad2 | ||
|   | 050f75aa60 | ||
|   | dae3f3552a | ||
|   | 8b09b170d6 | ||
|   | ec88f2ed8a | ||
|   | 607d8502ff | ||
|   | 2f084d7c15 | ||
|   | 5bf6e7d8f9 | ||
|   | 31cb9fbfaf | ||
|   | c7c48f3bea | ||
|   | 6732d22e6c | ||
|   | 04c6b7fe31 | ||
|   | 2687879dbd | ||
|   | 20a660fa89 | ||
|   | ba9781e1a8 | ||
|   | f65ac74914 | ||
|   | 6c33d9aeed | ||
|   | 68e86ad40d | ||
|   | 0aa4aa49a7 | ||
|   | 0ff3846e49 | ||
|   | bfb81299c3 | ||
|   | 0362a8e73c | ||
|   | f00f5cbed1 | ||
|   | c4e8cabae9 | ||
|   | 1729d05e8c | ||
|   | 770fb46ca7 | ||
|   | a3c4e54bc0 | ||
|   | b8a77fbada | ||
|   | 9182ebfc19 | ||
|   | 25c0cf5848 | ||
|   | a160dc0a4d | ||
|   | 28f1ca9c17 | ||
|   | 6399a0f046 | ||
|   | 639413608b | ||
|   | c14e4c7d22 | ||
|   | c74ac64237 | ||
|   | 4b3289ed99 | ||
|   | 0c432b39dc | ||
|   | c4b9276713 | ||
|   | df300c0663 | ||
|   | 518114cbbd | ||
|   | 999f0e4d58 | ||
|   | c2663529c1 | ||
|   | 9df74a02b6 | ||
|   | 71c9964e19 | ||
|   | ae2e47f6a9 | ||
|   | 1524d35f66 | ||
|   | 845be966a0 | ||
|   | 80818d79eb | ||
|   | cb9b3c00dd | ||
|   | b3997fb5df | ||
|   | 09dde6b78a | ||
|   | 3345d3ab35 | ||
|   | 366be7bbdd | ||
|   | 7008ea66f8 | ||
|   | 70f881e989 | ||
|   | 94d2355089 | ||
|   | dfbe48b25b | ||
|   | 931cb38b54 | ||
|   | e5fd34f94e | ||
|   | c638d7eb48 | ||
|   | 7e96384618 | ||
|   | 829cb99f5b | ||
|   | 1f93c99304 | ||
|   | dbb7c756cd | ||
|   | 13f381710c | ||
|   | 70897c0e9a | ||
|   | f51d1c5264 | ||
|   | 70d0937aab | ||
|   | 7d1ab6102f | ||
|   | 77ddd778be | ||
|   | 890ecb693f | ||
|   | 209fe7dcaf | ||
|   | e0d6f7c7c4 | ||
|   | 5d3fe9599b | ||
|   | 0fe0b6d254 | ||
|   | b794216eaf | ||
|   | 1fccde38f6 | ||
|   | 41bd436d3e | ||
|   | c66155ed48 | ||
|   | 627bd410fa | ||
|   | 41a3932c6b | ||
|   | 785b8d7846 | ||
|   | 622c8f9598 | ||
|   | ef978a6364 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | d95fbe1c6b | ||
|   | d4ffddc2ab | ||
|   | 3d497cedfc | ||
|   | e8de29ae79 | ||
|   | b622946844 | ||
|   | d013f78cc7 | ||
|   | 2afbafdb3b | ||
|   | 67148114a8 | ||
|   | 7903140ec2 | ||
|   | cefd296200 | ||
|   | 99d1c15851 | ||
|   | a3107ab26f | ||
|   | 854cfae75b | ||
|   | 36ab82957d | ||
|   | de9f54386c | ||
|   | 7f43820765 | ||
|   | 955e907e7f | ||
|   | 4c18022e7d | ||
|   | 509f59e46d | ||
|   | f14c372f5e | ||
|   | f028800a96 | ||
|   | 8a1ce7a4f3 | ||
|   | ea7a139ae0 | ||
|   | 63959eb3da | ||
|   | a6adbc4e56 | ||
|   | b418cb67ba | ||
|   | 0ccc360c0a | ||
|   | 1e0dda3c40 | ||
|   | 9197793bc8 | ||
|   | 29f62241bc | ||
|   | 8de1e91dec | ||
|   | de822a22d4 | ||
|   | f2cef456bd | ||
|   | 5d681d0fd6 | ||
|   | 2ed24ebd75 | ||
|   | 6e6824ecb0 | ||
|   | 0504a4f659 | ||
|   | 9a261755d2 | ||
|   | 8533663b26 | ||
|   | 0a4015b8a2 | ||
|   | dcfe56322e | ||
|   | d00a693026 | ||
|   | fb36ecad70 | ||
|   | 26c39768ca | ||
|   | df8abcfce8 | ||
|   | e3aab0e9e3 | ||
|   | e3dfc49ed0 | ||
|   | 8485284f63 | ||
|   | e549e19c03 | ||
|   | 2ace47cbb9 | ||
|   | dc184e7bc9 | ||
|   | aef1bd094b | ||
|   | 4f8b22f53b | ||
|   | 0f3cbafe91 | ||
|   | 16ad232c40 | ||
|   | 4d235a2be5 | ||
|   | aadf6fa9b1 | ||
|   | a72e9bc8b2 | ||
|   | f11ef93a81 | ||
|   | 9136556218 | ||
|   | 3ead008295 | ||
|   | 9ff5693442 | ||
|   | ac84b42394 | ||
|   | a79361c71f | ||
|   | 85e17d5dc7 | ||
|   | 45493fd093 | ||
|   | 6f987a2391 | ||
|   | ddf785a393 | ||
|   | b8e20fe717 | ||
|   | 82555bf9b6 | ||
|   | ffe6f6c168 | ||
|   | 6b11f5bb7d | ||
|   | 1a65d14864 | ||
|   | 6c1f1ffdb1 | ||
|   | 61cdbd5dd2 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | e7e321e2b3 | ||
|   | fb5f6fdc10 | ||
|   | 00290fbf75 | ||
|   | ff02dc723b | ||
|   | 67521c0d2a | ||
|   | da8765150b | ||
|   | ea7f51bc12 | ||
|   | 1b34b3b7e2 | ||
|   | bca4ceb7ae | ||
|   | 5648cd53d0 | ||
|   | 8dab37539f | ||
|   | 2dd42c0061 | ||
|   | dfafed504a | ||
|   | 9fcd2bcb0a | ||
|   | 4c701b91a6 | ||
|   | 84f7aa6d09 | ||
|   | 82f0c64dee | ||
|   | 4b7c6b124b | ||
|   | e043b678d4 | ||
|   | fef4f7fce8 | ||
|   | 9732b3521a | ||
|   | a59fcc4aec | ||
|   | 979e1e78fb | ||
|   | c1a929022f | ||
|   | 611bb81032 | ||
|   | 5047020e6d | ||
|   | fb74a6a689 | ||
|   | a14a216c8d | ||
|   | 549e212a59 | ||
|   | 1bdc91ad47 | ||
|   | 67f288479c | ||
|   | 496e45c2bb | ||
|   | e458bd3cc7 | ||
|   | 031911c463 | ||
|   | 4aa7f638f9 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | f6f4ea69ae | ||
|   | ef945597f2 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 3ab4e1d368 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | c6216f5b5f | ||
|   | 4f24d58a79 | ||
|   | 73d6e7ba66 | ||
|   | 949707e18e | ||
|   | f51b299c17 | ||
|   | d2e0faa533 | ||
|   | 22015044a5 | ||
|   | 61f86dcb2b | ||
|   | 8f3bce6b11 | ||
|   | ee736e73a9 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 99f867897e | ||
|   | c66c5b6e75 | ||
|   | f25ecc19b9 | ||
|   | 48e09970f3 | ||
|   | f05cb79604 | ||
|   | 46d3293edd | ||
|   | 9703d613cf | ||
|   | 704e217dbb | ||
|   | a103032d94 | ||
|   | c7207a4bd7 | ||
|   | 35c65fe589 | ||
|   | 6d5bd0c484 | ||
|   | cfbb6e8092 | ||
|   | feef4a933e | ||
|   | 468bc67569 | ||
|   | 0d517fa52f | ||
|   | d9054367c1 | ||
|   | 1213373027 | ||
|   | 100a525507 | ||
|   | 1bec4e2d12 | ||
|   | 03cd1d27bf | ||
|   | 9427a756c9 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | d32b2a8ce5 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 15473b4368 | ||
|   | 54de0dc4a7 | ||
|   | 0162eaf826 | ||
|   | 572cfafbe1 | ||
|   | 4d6335ce9a | ||
|   | 1c9c4af9f1 | ||
|   | a6844ebc9d | ||
|   | 072492c29b | ||
|   | 99da4f9839 | ||
|   | 88664486af | ||
|   | 80daf7c749 | ||
|   | 92ba64c35c | ||
|   | a8ee51ffd6 | ||
|   | 5538afc61d | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | beb2f7e558 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 6243184c95 | ||
|   | 1b3baef966 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 98f38ee29b | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 09b82bfea4 | ||
|   | 937f686264 | ||
|   | 9bc9cbac21 | ||
|   | 6024550158 | ||
|   | 4ae5f82171 | ||
|   | 6d2c9dcee9 | ||
|   | 0f1b0e1870 | ||
|   | 81c682cdc8 | ||
|   | ab9fa67d9f | ||
|   | 9537fce335 | ||
|   | 9d97e7e348 | ||
|   | ebe7939412 | ||
|   | 807e3e8ca7 | ||
|   | a59faf9117 | ||
|   | d786036155 | ||
|   | 61d6ed5489 | ||
|   | b38200d48a | ||
|   | a0c396a842 | ||
|   | 88fbc53e37 | ||
|   | a2206b2d52 | ||
|   | a95ff447d7 | ||
|   | 49dbd7f9d2 | ||
|   | 2ad2779096 | ||
|   | 23045369aa | ||
|   | 116faf26e6 | ||
|   | 2582b8d132 | ||
|   | 63f7941073 | ||
|   | 676f026085 | ||
|   | a13319fd86 | ||
|   | be8765278c | ||
|   | c8bb3dc209 | ||
|   | ea16befb73 | ||
|   | 20b1bb7681 | ||
|   | bd10eb50eb | ||
|   | d47c0eb31a | ||
|   | 177e8bb19f | ||
|   | d156111637 | ||
|   | 8c13d3e50b | ||
|   | 6ff01016f0 | ||
|   | 5d659da012 | ||
|   | 28e7552a1a | ||
|   | 53d264814b | ||
|   | 2d6b20d34b | ||
|   | 99073b56df | ||
|   | 5dce81c0db | ||
|   | be82d845a4 | ||
|   | f49ccd0cd3 | ||
|   | 69d83f535d | ||
|   | c7988fb6f5 | ||
|   | 3961fd08c9 | ||
|   | e3faf64061 | ||
|   | ed83993e15 | ||
|   | 0f8847bb74 | ||
|   | a72cfa7535 | ||
|   | 514b74a19d | ||
|   | a2c124306f | ||
|   | 273f67e268 | ||
|   | 2870a7e463 | ||
|   | 935b074a7a | ||
|   | 9d9c609bfb | ||
|   | f6a664f181 | ||
|   | fce68d1f75 | ||
|   | 88739c2444 | ||
|   | 7e2f10fce3 | ||
|   | a494c3a5cc | ||
|   | d6bb702883 | ||
|   | d15a972c68 | ||
|   | 2ae7d31725 | ||
|   | 2e329b1888 | ||
|   | 522d40328b | ||
|   | 2ecbff45bf | ||
|   | b6f7282c13 | ||
|   | 65e5cfa68e | ||
|   | 10e59957d1 | ||
|   | 4f74373df3 | ||
|   | 2d414bbf86 | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | a199969b81 | ||
|   | 3aef5e6748 | ||
|   | 2b536a7443 | ||
|   | 20fe68de05 | ||
|   | c7684b59de | ||
|   | a7237d157a | ||
|   | 35f91fa280 | ||
|   | 299ac32225 | ||
|   | a038738d72 | ||
|   | 2b0a919fb5 | ||
|   | 946c706913 | ||
|   | 89b5d976ee | ||
|   | 6f679bb6b4 | ||
|   | db4e7b0e16 | ||
|   | 9ca942490d | ||
|   | ebcf249c8b | ||
|   | 939c487503 | ||
|   | 981a8b267e | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 9531da80a0 | ||
|   | e1109b168c | ||
|   | b7c70039aa | ||
| ![greenkeeper[bot]](/assets/img/avatar_default.png)  | 17b6f6cf2a | ||
|   | dd88483ba4 | ||
|   | 0ff27f65b3 | ||
|   | b1655740df | ||
|   | 6d562aece1 | ||
|   | 2182c3372b | ||
|   | d3331bfe82 | ||
|   | cfc4a2e8b4 | ||
|   | 36c41c8eb3 | ||
|   | d255157e6e | ||
|   | c12e07277d | ||
|   | 06b4fb5095 | ||
|   | 8fafdcb428 | ||
|   | 537a606bb6 | ||
|   | 3dc7a4463c | ||
|   | fd6ff05b60 | ||
|   | 1a159e41b8 | ||
|   | 23533cdd16 | 
| @@ -30,7 +30,7 @@ while : | ||||
|   touch patreon.cache && \ | ||||
|   rm patreon.cache && \ | ||||
|   cat patreon.raw.cache | \ | ||||
|   jq -r '(.data|map(select(.relationships.currently_entitled_tiers.data[]))|map(.relationships.user.data.id))as$data|.included|map(select(.attributes.hide_pledges==false))|map(select(.id as$id|$data|contains([$id])))|map(.attributes|[.full_name,.thumb_url,.url]|@tsv)|.[]|@text' >> patreon.cache && \ | ||||
|   jq -r '(.data|map(select(.relationships.currently_entitled_tiers.data[]))|map(.relationships.user.data.id))as$data|.included|map(select(.id as$id|$data|contains([$id])))|map(.attributes|[.full_name,.thumb_url,.url]|@tsv)|.[]|@text' >> patreon.cache && \ | ||||
|   echo '<table><tr>' >> patreon.md.cache && \ | ||||
|   cat patreon.cache | \ | ||||
|   awk -F'\t' '{print $2,$1}' | \ | ||||
|   | ||||
							
								
								
									
										15
									
								
								.ci/default.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								.ci/default.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | ||||
| maintainer: | ||||
|   name: syuilo | ||||
|   url: 'https://syuilo.com' | ||||
| url: 'http://misskey.local' | ||||
| port: 80 | ||||
| mongodb: | ||||
|   host: localhost | ||||
|   port: 27017 | ||||
|   db: misskey | ||||
|   user: syuilo | ||||
|   pass: '' | ||||
| redis: | ||||
|   host: localhost | ||||
|   port: 6379 | ||||
|   pass: '' | ||||
							
								
								
									
										16
									
								
								.ci/test.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								.ci/test.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | ||||
| maintainer: | ||||
|   name: syuilo | ||||
|   url: 'https://syuilo.com' | ||||
| url: 'http://misskey.local' | ||||
| port: 80 | ||||
| mongodb: | ||||
|   host: localhost | ||||
|   port: 27017 | ||||
|   db: test-misskey | ||||
|   user: admin | ||||
|   pass: '' | ||||
| # __REDIS__ | ||||
| redis: | ||||
|   host: localhost | ||||
|   port: 6379 | ||||
|   pass: '' | ||||
							
								
								
									
										137
									
								
								.circleci/config.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										137
									
								
								.circleci/config.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,137 @@ | ||||
| version: 2.1 | ||||
|  | ||||
| general: | ||||
|   branches: | ||||
|     ignore: | ||||
|       - l10n_develop | ||||
|       - imgbot | ||||
|  | ||||
| executors: | ||||
|   default: | ||||
|     working_directory: /tmp/workspace | ||||
|     docker: | ||||
|       - image: misskey/ci:latest | ||||
|       - image: circleci/mongo:latest | ||||
|       - image: circleci/redis:latest | ||||
|   docker: | ||||
|     working_directory: /tmp/workspace | ||||
|     docker: | ||||
|       - image: docker:latest | ||||
|  | ||||
| jobs: | ||||
|   build: | ||||
|     executor: default | ||||
|     steps: | ||||
|       - checkout | ||||
|       - restore_cache: | ||||
|           name: Restore npm package caches | ||||
|           keys: | ||||
|             - npm-v1-arch-{{ arch }}-env-{{ .Environment.variableName }}-package-{{ checksum "package.json" }}-lock-{{ checksum "package-lock.json" }}- | ||||
|             - npm-v1-arch-{{ arch }}-env-{{ .Environment.variableName }}-package-{{ checksum "package.json" }}- | ||||
|             - npm-v1-arch-{{ arch }}-env-{{ .Environment.variableName }}- | ||||
|             - npm-v1-arch-{{ arch }}- | ||||
|             - npm-v1- | ||||
|       - run: | ||||
|           name: Install Dependencies | ||||
|           command: | | ||||
|             npm install | ||||
|       - run: | ||||
|           name: Configure | ||||
|           command: | | ||||
|             cp .ci/default.yml .config | ||||
|             cp .ci/test.yml .config | ||||
|       - run: | ||||
|           name: Build | ||||
|           command: | | ||||
|             npm run build || (echo -e '\033[0;34mRebuild modules\033[0;39m' && ls -1A node_modules | grep '^[^@]' | xargs npm rebuild && ls -1A node_modules | grep '^@' | xargs -I%1 sh -c 'ls -1A node_modules/'%1' | xargs -P0 -I%2 npm rebuild node_modules/'%1'/%2' && npm run build) | ||||
|             ls -1ARl node_modules > ls | ||||
|       - save_cache: | ||||
|           name: Cache npm packages | ||||
|           key: npm-v1-arch-{{ arch }}-env-{{ .Environment.variableName }}-package-{{ checksum "package.json" }}-lock-{{ checksum "package-lock.json" }}-ls-{{ checksum "ls" }} | ||||
|           paths: | ||||
|             - node_modules | ||||
|       - store_artifacts: | ||||
|           path: built | ||||
|       - persist_to_workspace: | ||||
|           root: . | ||||
|           paths: | ||||
|             - . | ||||
|   test: | ||||
|     parameters: | ||||
|       without_redis: | ||||
|         type: string | ||||
|         default: "" | ||||
|     executor: default | ||||
|     steps: | ||||
|       - attach_workspace: | ||||
|           at: /tmp/workspace | ||||
|       - when: | ||||
|           condition: <<parameters.without_redis>> | ||||
|           steps: | ||||
|             - run: | ||||
|                 name: Configure | ||||
|                 command: | | ||||
|                   mv .config/test.yml .config/test_redis.yml | ||||
|                   touch .config/test.yml | ||||
|                   cat .config/test_redis.yml | while IFS= read line; do if [[ "$line" = '# __REDIS__' ]]; then break; else echo "$line" >> .config/test.yml; fi; done | ||||
|       - run: | ||||
|           name: Test | ||||
|           command: | | ||||
|             npm run test || (npm rebuild && npm run test) || ((node-gyp configure && node-gyp build && npm run build || (echo -e '\033[0;34mRebuild modules\033[0;39m' && ls -1A node_modules | grep '^[^@]' | xargs npm rebuild && ls -1A node_modules | grep '^@' | xargs -I%1 sh -c 'ls -1A node_modules/'%1' | xargs -P0 -I%2 npm rebuild node_modules/'%1'/%2' && npm run build)) && npm run test) | ||||
|             ls -1ARl node_modules > ls | ||||
|       - save_cache: | ||||
|           name: Cache npm packages | ||||
|           key: npm-v1-arch-{{ arch }}-env-{{ .Environment.variableName }}-package-{{ checksum "package.json" }}-lock-{{ checksum "package-lock.json" }}-ls-{{ checksum "ls" }} | ||||
|           paths: | ||||
|             - node_modules | ||||
|  | ||||
|   docker: | ||||
|     parameters: | ||||
|       with_deploy: | ||||
|         type: string | ||||
|         default: "" | ||||
|     executor: docker | ||||
|     steps: | ||||
|       - checkout | ||||
|       - setup_remote_docker | ||||
|       - run: | ||||
|           name: Build | ||||
|           command: | | ||||
|             docker build . | tee docker.log | ||||
|             tail -n 1 docker.log | read __Successfully __built tag | ||||
|       - when: | ||||
|           condition: <<parameters.with_deploy>> | ||||
|           steps: | ||||
|             - run: | ||||
|                 name: Deploy | ||||
|                 command: | | ||||
|                   if [ "$DOCKERHUB_USERNAME$DOCKERHUB_PASSWORD" ] | ||||
|                    then | ||||
|                     docker tag $tag misskey/misskey | ||||
|                     docker login -u $DOCKERHUB_USERNAME -p $DOCKERHUB_PASSWORD | ||||
|                     docker push misskey/misskey | ||||
|                    else | ||||
|                     echo -e '\033[0;33mAborted deploying to Docker Hub\033[0;39m' | ||||
|                   fi | ||||
|  | ||||
| workflows: | ||||
|   version: 2 | ||||
|   build-and-test: | ||||
|     jobs: | ||||
|       - build | ||||
|       - test: | ||||
|           requires: | ||||
|             - build | ||||
|       - test: | ||||
|           without_redis: "true" | ||||
|           requires: | ||||
|             - build | ||||
|       - docker: | ||||
|           filters: | ||||
|             branches: | ||||
|               ignore: master | ||||
|       - docker: | ||||
|           with_deploy: "true" | ||||
|           filters: | ||||
|             branches: | ||||
|               only: master | ||||
| @@ -1,6 +1,3 @@ | ||||
| name: example-instance-name # Name of your instance | ||||
| description: example-description # Description of your instance | ||||
|  | ||||
| maintainer: | ||||
|   name: example-maitainer-name # Your name | ||||
|   url: http://example.com/ # Your contact (http or mailto) | ||||
| @@ -25,7 +22,7 @@ url: https://example.tld/ | ||||
| #   +------+      |+-------------+      +----------------+| | ||||
| #                 +---------------------------------------+ | ||||
| # | ||||
| #   You need to setup reverse proxy. (eg. Nginx) | ||||
| #   You need to setup reverse proxy. (eg. nginx) | ||||
| #   You do not define 'https' section. | ||||
|  | ||||
| # Option 2: Standalone | ||||
| @@ -148,6 +145,12 @@ drive: | ||||
| #  consumer_key: example-twitter-consumer-key | ||||
| #  consumer_secret: example-twitter-consumer-secret-key | ||||
|  | ||||
| # GitHub integration | ||||
| # You need to set the oauth callback url as : https://<your-misskey-instance>/api/gh/cb | ||||
| #github: | ||||
| #  client_id: example-github-client-id | ||||
| #  client_secret: example-github-client-secret | ||||
|  | ||||
| # Ghost | ||||
| # Ghost account is an account used for the purpose of delegating | ||||
| # followers when putting users in the list. | ||||
| @@ -164,3 +167,6 @@ drive: | ||||
| #  external: true | ||||
| #  engine: http://vinayaka.distsn.org/cgi-bin/vinayaka-user-match-misskey-api.cgi?{{host}}+{{user}}+{{limit}}+{{offset}} | ||||
| #  timeout: 300000 | ||||
|  | ||||
| # Max allowed note text length in charactors | ||||
| maxNoteTextLength: 1000 | ||||
|   | ||||
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -16,3 +16,4 @@ api-docs.json | ||||
| /redis | ||||
| /mongo | ||||
| /elasticsearch | ||||
| *.code-workspace | ||||
|   | ||||
| @@ -11,7 +11,7 @@ branches: | ||||
| language: node_js | ||||
|  | ||||
| node_js: | ||||
|   - 10.1.0 | ||||
|   - 11.0.0 | ||||
|  | ||||
| env: | ||||
|   - CXX=g++-4.8 NODE_ENV=production | ||||
| @@ -35,7 +35,7 @@ before_script: | ||||
|   - npm install | ||||
|  | ||||
|   # 設定ファイルを配置 | ||||
|   - cp ./.travis/default.yml ./.config | ||||
|   - cp ./.travis/test.yml ./.config | ||||
|   - cp ./.ci/default.yml ./.config | ||||
|   - cp ./.ci/test.yml ./.config | ||||
|  | ||||
|   - travis_wait npm run build | ||||
|   | ||||
| @@ -1,26 +0,0 @@ | ||||
| maintainer: '@syuilo' | ||||
| url: 'https://misskey.xyz' | ||||
| secondary_url: 'https://himasaku.net' | ||||
| port: 80 | ||||
| https: | ||||
|   enable: false | ||||
|   key: null | ||||
|   cert: null | ||||
|   ca: null | ||||
| mongodb: | ||||
|   host: localhost | ||||
|   port: 27017 | ||||
|   db: misskey | ||||
|   user: syuilo | ||||
|   pass: '' | ||||
| redis: | ||||
|   host: localhost | ||||
|   port: 6379 | ||||
|   pass: '' | ||||
| elasticsearch: | ||||
|   host: localhost | ||||
|   port: 9200 | ||||
|   pass: '' | ||||
| recaptcha: | ||||
|   site_key: hima | ||||
|   secret_key: saku | ||||
| @@ -1,26 +0,0 @@ | ||||
| maintainer: '@syuilo' | ||||
| url: 'https://misskey.xyz' | ||||
| secondary_url: 'https://himasaku.net' | ||||
| port: 80 | ||||
| https: | ||||
|   enable: false | ||||
|   key: null | ||||
|   cert: null | ||||
|   ca: null | ||||
| mongodb: | ||||
|   host: localhost | ||||
|   port: 27017 | ||||
|   db: test-misskey | ||||
|   user: admin | ||||
|   pass: '' | ||||
| redis: | ||||
|   host: localhost | ||||
|   port: 6379 | ||||
|   pass: '' | ||||
| elasticsearch: | ||||
|   host: localhost | ||||
|   port: 9200 | ||||
|   pass: '' | ||||
| recaptcha: | ||||
|   site_key: hima | ||||
|   secret_key: saku | ||||
							
								
								
									
										44
									
								
								Dockerfile
									
									
									
									
									
								
							
							
						
						
									
										44
									
								
								Dockerfile
									
									
									
									
									
								
							| @@ -1,28 +1,44 @@ | ||||
| FROM alpine:latest AS base | ||||
| FROM alpine:3.8 AS base | ||||
|  | ||||
| ENV NODE_ENV=production | ||||
|  | ||||
| RUN apk add --no-cache nodejs nodejs-npm | ||||
| RUN apk add vips fftw --update-cache --repository https://dl-3.alpinelinux.org/alpine/edge/testing/ | ||||
| RUN apk add --no-cache nodejs nodejs-npm zlib | ||||
| RUN npm i -g npm@latest | ||||
|  | ||||
| WORKDIR /misskey | ||||
| COPY . ./ | ||||
|  | ||||
| FROM base AS builder | ||||
|  | ||||
| RUN apk add --no-cache	gcc g++ python autoconf automake file make nasm | ||||
| RUN apk add vips-dev fftw-dev --update-cache --repository https://dl-3.alpinelinux.org/alpine/edge/testing/ | ||||
| RUN npm install \ | ||||
|     && npm install -g node-gyp \ | ||||
|     && node-gyp configure \ | ||||
|     && node-gyp build \ | ||||
|     && npm run build | ||||
| RUN apk add --no-cache \ | ||||
|     gcc \ | ||||
|     g++ \ | ||||
|     libc-dev \ | ||||
|     python \ | ||||
|     autoconf \ | ||||
|     automake \ | ||||
|     file \ | ||||
|     make \ | ||||
|     nasm \ | ||||
|     pkgconfig \ | ||||
|     libtool \ | ||||
|     zlib-dev | ||||
| RUN npm i -g node-gyp | ||||
|  | ||||
| COPY ./package.json ./ | ||||
| RUN npm i | ||||
|  | ||||
| COPY . ./ | ||||
| RUN node-gyp configure \ | ||||
|  && node-gyp build \ | ||||
|  && npm run build | ||||
|  | ||||
| FROM base AS runner | ||||
|  | ||||
| COPY --from=builder /misskey/built ./built | ||||
| COPY --from=builder /misskey/node_modules ./node_modules | ||||
|  | ||||
| RUN apk add --no-cache tini | ||||
| ENTRYPOINT ["/sbin/tini", "--"] | ||||
|  | ||||
| COPY --from=builder /misskey/node_modules ./node_modules | ||||
| COPY --from=builder /misskey/built ./built | ||||
| COPY . ./ | ||||
|  | ||||
| CMD ["npm", "start"] | ||||
|   | ||||
							
								
								
									
										32
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										32
									
								
								README.md
									
									
									
									
									
								
							| @@ -3,9 +3,10 @@ | ||||
| [](https://misskey.xyz/) | ||||
| ================================================================ | ||||
|  | ||||
| [](https://circleci.com/gh/syuilo/misskey) | ||||
| [![][travis-badge]][travis-link] | ||||
| [![][dependencies-badge]][dependencies-link] | ||||
| [](http://makeapullrequest.com) [](https://greenkeeper.io/) | ||||
| [](http://makeapullrequest.com) | ||||
|  | ||||
| **Sophisticated microblogging platform, evolving forever.** | ||||
|  | ||||
| @@ -71,39 +72,46 @@ Please see [Contribution guide](./CONTRIBUTING.md). | ||||
| ---------------------------------------------------------------- | ||||
| <!-- PATREON_START --> | ||||
| <table><tr> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/619786/32cf01444db24e578cd1982c197f6fc6/1?token-time=2145916800&token-hash=CXe9AqlZy9AsYfiWd3OBYVOzvODoN47Litz0Tu4BFpU%3D" alt="Gargron"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12731202/0995c46cdcb54153ab5f073f5869b70a/1?token-time=2145916800&token-hash=Yd60FK_SWfQO56SeiJpy1tDHOnCV4xdEywQe8gn5_Wo%3D" alt="negao"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/13099460/43cecdbaa63a40d79bf50a96b9910b9d/1?token-time=2145916800&token-hash=d6P5MWHHsCMxUuBAEPAoVc5wLUR19mIhqAq7Ma9h9rI%3D" alt="ne_moni"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12913507/f7181eacafe8469a93033d85f5969c29/2?token-time=2145916800&token-hash=mgPdX9TqZxEg4TTPuc477dxhIgYk9246qafjWZEqZ7g%3D" alt="Melilot"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12999811/5f349fafcce44dd1824a8b1ebbec4564/2?token-time=2145916800&token-hash=rwZ8qvbm_kpA4ib3kc07tVKupXeySpY5ATQFGxfL9v0%3D" alt="Xeltica"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/3384329/8b713330cb27404ea6e9fac50ff96efe/1?token-time=2145916800&token-hash=0eu4-m1gTWA9PhptVZt6rdKcusqcD7RB87rJT23VVFI%3D" alt="べすれい"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12021162/963128bb8d14476dbd8407943db8f31a/1?token-time=2145916800&token-hash=GgJ_NmUB6_nnRNLVGUWjV-WX91On7BOu59LKncYV9fE%3D" alt="gutfuckllc"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/11357794/923ce94cd8c44ba788ee931907881839/1?token-time=2145916800&token-hash=I8lJVM8LeW6TSo5W6uIIRZ42cw83zp1wK_FsbzY0mcQ%3D" alt="mydarkstar"></td> | ||||
| <td><img src="https://c8.patreon.com/2/100/12718187" alt="Peter G."></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/13039004/509d0c412eb14ae08d6a812a3054f7d6/1?token-time=2145916800&token-hash=zwSu01tOtn5xTUucDZHuPsCxF2HBEMVs9ROJKTlEV_o%3D" alt="nemu"></td> | ||||
| </tr><tr> | ||||
| <td><a href="https://www.patreon.com/mastodon">Gargron</a></td> | ||||
| <td><a href="https://www.patreon.com/negao">negao</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=13099460">ne_moni</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=12913507">Melilot</a></td> | ||||
| <td><a href="https://www.patreon.com/AxellaMC">Xeltica</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=3384329">べすれい</a></td> | ||||
| <td><a href="https://www.patreon.com/gutfuckllc">gutfuckllc</a></td> | ||||
| <td><a href="https://www.patreon.com/mydarkstar">mydarkstar</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=12718187">Peter G.</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=13039004">nemu</a></td> | ||||
| </tr></table> | ||||
| <table><tr> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/5881381/6235ca5d3fb04c8e95ef5b4ff2abcc18/2?token-time=2145916800&token-hash=zElv7ZcPL3viGsXbNG_KWiKrbV0vvw1gk0panx8DJoo%3D" alt="Naoki Kosaka"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/13039004/509d0c412eb14ae08d6a812a3054f7d6/1?token-time=2145916800&token-hash=zwSu01tOtn5xTUucDZHuPsCxF2HBEMVs9ROJKTlEV_o%3D" alt="nemu"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/5881381/6235ca5d3fb04c8e95ef5b4ff2abcc18/3?token-time=2145916800&token-hash=qsdn0-e6yLaLI6hUX9JAkyTR6a5UdnSp7T1foniBvGQ%3D" alt="YUKIMOCHI"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/8241184/39e18850e87a449e9c9a71acb3310ebd/2?token-time=2145916800&token-hash=iUXOQzRyJDv3PJxwS7Mjwg1459dzh2trOq6NFtXu_OM%3D" alt="Acid Chicken"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/13034746/c711c7f58e204ecfbc2fd646bc8a4eee/1?token-time=2145916800&token-hash=UERBN4OyP7Nh5XwwdDg0N0IE5cD6_qUQMO81Z5Wizso%3D" alt="Hiratake"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/10789744/97175095d8f04c0f86225ff47cb98d40/1?token-time=2145916800&token-hash=P4BIzCX2I1CkEP66ottfhsC8Wr6BUSamjA-vq3pLqFI%3D" alt="Naoki Hirayama"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/4503830/ccf2cc867ea64de0b524bb2e24b9a1cb/1?token-time=2145916800&token-hash=S1zP0QyLU52Dqq6dtc9qNYyWfW86XrYHiR4NMbeOrnA%3D" alt="dansup"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/619786/32cf01444db24e578cd1982c197f6fc6/1?token-time=2145916800&token-hash=tB1e_r8RlZ5sFL0KV_e8dugapxatNBRK1Z3h67TO1g8%3D" alt="Gargron"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/5731881/4b6038e6cda34c04b83a5fcce3806a93/1?token-time=2145916800&token-hash=VZUtwrjQa8Jml4twCjHYQQZ64wHEY4oIlGl7Kc-VYUQ%3D" alt="Nokotaro Takeda"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12531784/93a45137841849329ba692da92ac7c60/1?token-time=2145916800&token-hash=tMosUojzUYJCH_3t--tvYA-SMCyrS__hzSndyaRSnbo%3D" alt="Takashi Shibuya"></td> | ||||
| </tr><tr> | ||||
| <td><a href="https://www.patreon.com/user?u=5881381">Naoki Kosaka</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=13039004">nemu</a></td> | ||||
| <td><a href="https://www.patreon.com/yukimochi">YUKIMOCHI</a></td> | ||||
| <td><a href="https://www.patreon.com/acid_chicken">Acid Chicken</a></td> | ||||
| <td><a href="https://www.patreon.com/hiratake">Hiratake</a></td> | ||||
| <td><a href="https://www.patreon.com/spinlock">Naoki Hirayama</a></td> | ||||
| <td><a href="https://www.patreon.com/dansup">dansup</a></td> | ||||
| <td><a href="https://www.patreon.com/mastodon">Gargron</a></td> | ||||
| <td><a href="https://www.patreon.com/takenoko">Nokotaro Takeda</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=12531784">Takashi Shibuya</a></td> | ||||
| </tr></table> | ||||
| <table><tr> | ||||
| </tr><tr> | ||||
| </tr></table> | ||||
|  | ||||
| **Last updated:** Tue, 02 Oct 2018 09:25:07 UTC | ||||
| **Last updated:** Wed, 31 Oct 2018 23:21:06 UTC | ||||
| <!-- PATREON_END --> | ||||
|  | ||||
| :four_leaf_clover: Copyright | ||||
|   | ||||
| @@ -1,13 +0,0 @@ | ||||
| const deleteUser = require('../built/models/user').deleteUser; | ||||
|  | ||||
| const args = process.argv.slice(2); | ||||
|  | ||||
| const userId = args[0]; | ||||
|  | ||||
| console.log(`deleting ${userId}...`); | ||||
|  | ||||
| deleteUser(userId).then(() => { | ||||
| 	console.log('done'); | ||||
| }, e => { | ||||
| 	console.error(e); | ||||
| }); | ||||
| @@ -1,23 +0,0 @@ | ||||
| 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); | ||||
| }); | ||||
| @@ -1,42 +0,0 @@ | ||||
| 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); | ||||
| @@ -6,7 +6,7 @@ services: | ||||
|     restart: always | ||||
|     links: | ||||
|       - mongo | ||||
|       - redis | ||||
| #      - redis | ||||
| #      - es | ||||
|     ports: | ||||
|       - "127.0.0.1:3000:3000" | ||||
| @@ -14,18 +14,18 @@ services: | ||||
|       - internal_network | ||||
|       - external_network | ||||
|  | ||||
|   redis: | ||||
|     restart: always | ||||
|     image: redis:4.0-alpine | ||||
|     networks: | ||||
|       - internal_network | ||||
| #  redis: | ||||
| #    restart: always | ||||
| #    image: redis:4.0-alpine | ||||
| #    networks: | ||||
| #      - internal_network | ||||
| ### Uncomment to enable Redis persistance | ||||
| #    volumes: | ||||
| #      - ./redis:/data | ||||
| ##    volumes: | ||||
| ##      - ./redis:/data | ||||
|  | ||||
|   mongo: | ||||
|     restart: always | ||||
|     image: mongo:4.1-bionic | ||||
|     image: mongo:4.1 | ||||
|     networks: | ||||
|       - internal_network | ||||
|     environment: | ||||
|   | ||||
| @@ -7,23 +7,29 @@ This guide describes how to install and setup Misskey with Docker. | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| *1.* Make configuration files | ||||
| *1.* Download Misskey | ||||
| ---------------------------------------------------------------- | ||||
| 1. `git clone -b master git://github.com/syuilo/misskey.git` Clone Misskey repository's master branch. | ||||
| 2. `cd misskey` Move to misskey directory. | ||||
| 3. `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) tag. | ||||
|  | ||||
| *2.* Make configuration files | ||||
| ---------------------------------------------------------------- | ||||
| 1. `cp .config/example.yml .config/default.yml` Copy the `.config/example.yml` and rename it to `default.yml`. | ||||
| 2. `cp .config/mongo_initdb_example.js .config/mongo_initdb.js` Copy the `.config/mongo_initdb_example.js` and rename it to `mongo_initdb.js`. | ||||
| 2. Edit `default.yml` and `mongo_initdb.js`. | ||||
|  | ||||
| *2.* Configure Docker | ||||
| *3.* Configure Docker | ||||
| ---------------------------------------------------------------- | ||||
| Edit `docker-compose.yml`. | ||||
|  | ||||
| *3.* Build Misskey | ||||
| *4.* Build Misskey | ||||
| ---------------------------------------------------------------- | ||||
| Build misskey with the following: | ||||
|  | ||||
| `docker-compose build` | ||||
|  | ||||
| *4.* That is it. | ||||
| *5.* That is it. | ||||
| ---------------------------------------------------------------- | ||||
| Well done! Now, you have an environment that run to Misskey. | ||||
|  | ||||
|   | ||||
| @@ -7,23 +7,29 @@ Dockerを使ったMisskey構築方法 | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| *1.* 設定ファイルを作成する | ||||
| *1.* Misskeyのダウンロード | ||||
| ---------------------------------------------------------------- | ||||
| 1. `git clone -b master git://github.com/syuilo/misskey.git` masterブランチからMisskeyレポジトリをクローン | ||||
| 2. `cd misskey` misskeyディレクトリに移動 | ||||
| 3. `git checkout $(git tag -l | grep -v 'rc[0-9]*$' | sort -V | tail -n 1)` [最新のリリース](https://github.com/syuilo/misskey/releases/latest)を確認 | ||||
|  | ||||
| *2.* 設定ファイルを作成する | ||||
| ---------------------------------------------------------------- | ||||
| 1. `cp .config/example.yml .config/default.yml` `.config/example.yml`をコピーし名前を`default.yml`にする | ||||
| 2. `cp .config/mongo_initdb_example.js .config/mongo_initdb.js` `.config/mongo_initdb_example.js`をコピーし名前を`mongo_initdb.js`にする | ||||
| 3. `default.yml`と`mongo_initdb.js`を編集する | ||||
|  | ||||
| *2.* Dockerの設定 | ||||
| *3.* Dockerの設定 | ||||
| ---------------------------------------------------------------- | ||||
| `docker-compose.yml`を編集してください。 | ||||
|  | ||||
| *3.* Misskeyのビルド | ||||
| *4.* Misskeyのビルド | ||||
| ---------------------------------------------------------------- | ||||
| 次のコマンドでMisskeyをビルドしてください: | ||||
|  | ||||
| `docker-compose build` | ||||
|  | ||||
| *4.* 以上です! | ||||
| *5.* 以上です! | ||||
| ---------------------------------------------------------------- | ||||
| お疲れ様でした。これでMisskeyを動かす準備は整いました。 | ||||
|  | ||||
|   | ||||
| @@ -28,7 +28,7 @@ Please install and setup these softwares: | ||||
| ##### Optional | ||||
| * [Redis](https://redis.io/) | ||||
|   * Redis is optional, but we strongly recommended to install it | ||||
| * [Elasticsearch](https://www.elastic.co/) - used to provide searching feature instead of MongoDB | ||||
| * [Elasticsearch](https://www.elastic.co/) - required to enable the search feature | ||||
|  | ||||
| *3.* Setup MongoDB | ||||
| ---------------------------------------------------------------- | ||||
|   | ||||
| @@ -18,6 +18,10 @@ If you find an untranslated part on Misskey: | ||||
| 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-JP.yml`. | ||||
|  | ||||
| 5. And done! | ||||
| 5. When you add text to the ja-JP file (of syuilo/misskey), it will automatically be applied to all other local language files within 24-48 hours. Translations added in ja-JP file should contain the original Japanese strings (example see step 4).  | ||||
|  | ||||
| 6. The new strings will automatically appear in the localized language files in the original Japanese text. After that, please go to [CrowdIn](https://crowdin.com/project/misskey) to do the localized translations in your language. | ||||
|  | ||||
| 7. And done! | ||||
|  | ||||
| For more details, please refer to this [commit](https://github.com/syuilo/misskey/commit/10f6d5980fa7692ccb45fbc5f843458b69b7607c). | ||||
|   | ||||
| @@ -1,3 +1,6 @@ | ||||
| # **DO NOT edit locale files** except `ja-JP.yml`. | ||||
|  | ||||
| When you add text to the ja-JP file (of syuilo/misskey), it will automatically be applied to other language files. | ||||
| Translations added in ja-JP file should contain the original Japanese strings. | ||||
|  | ||||
| Please see [Contribution guide](../CONTRIBUTING.md) for more information. | ||||
|   | ||||
| @@ -25,6 +25,14 @@ common: | ||||
|   application-authorization: "アプリの連携" | ||||
|   close: "閉じる" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   BSoD: | ||||
|     fatal-error: ":( 致命的な問題が発生しました。" | ||||
|     update-browser-os: "お使いのブラウザ(またはOS)のバージョンを更新すると解決する可能性があります。" | ||||
|     error-code: "エラーコード" | ||||
|     browser-version: "ブラウザ バージョン" | ||||
|     client-version: "クライアント バージョン" | ||||
|     email-support: "問題が解決しない場合は、上記の情報をお書き添えの上 syuilotan@yahoo.co.jp までご連絡ください。" | ||||
|     thanks: "Thank you for using Misskey." | ||||
|   got-it: "わかった" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
| @@ -54,6 +62,7 @@ common: | ||||
|     years_ago: "{}年前" | ||||
|   month-and-day: "{month}月 {day}日" | ||||
|   trash: "ゴミ箱" | ||||
|   drive: "ドライブ" | ||||
|   weekday-short: | ||||
|     sunday: "日" | ||||
|     monday: "月" | ||||
| @@ -115,6 +124,12 @@ common: | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|   error: | ||||
|     title: '問題が発生しました' | ||||
|     retry: 'やり直す' | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
| @@ -170,6 +185,8 @@ common: | ||||
|     rename: "名前を変更" | ||||
|     stack-left: "左に重ねる" | ||||
|     pop-right: "右に出す" | ||||
|   dev: "アプリの作成に失敗しました。再度お試しください。" | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{{ app.name }}</i>があなたのアカウントにアクセスすることを<b>許可</b>しますか?" | ||||
|   permission-ask: "このアプリは次の権限を要求しています:" | ||||
| @@ -335,6 +352,7 @@ common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   unfavorite: "お気に入り解除" | ||||
|   pin: "ピン留め" | ||||
|   unpin: "ピン留め解除" | ||||
|   delete: "削除" | ||||
| @@ -415,6 +433,25 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   careful-bot: "Botからのフォローだけ承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "確認中" | ||||
|   no-broadcasts: "お知らせはありません" | ||||
| @@ -506,11 +543,14 @@ desktop/views/components/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
| @@ -540,7 +580,6 @@ desktop/views/components/crop-window.vue: | ||||
|   ok: "決定" | ||||
| desktop/views/components/drive-window.vue: | ||||
|   used: "使用中" | ||||
|   drive: "ドライブ" | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
| @@ -570,8 +609,6 @@ desktop/views/components/drive.folder.vue: | ||||
|     rename: "名前を変更" | ||||
|     rename-folder: "フォルダ名の変更" | ||||
|     input-new-folder-name: "新しいフォルダ名を入力してください" | ||||
| desktop/views/components/drive.nav-folder.vue: | ||||
|   drive: "ドライブ" | ||||
| desktop/views/components/drive.vue: | ||||
|   search: "検索" | ||||
|   load-more: "もっと読み込む" | ||||
| @@ -639,7 +676,7 @@ desktop/views/components/note-detail.vue: | ||||
|   location: "位置情報" | ||||
|   renote: "Renote" | ||||
|   add-reaction: "リアクション" | ||||
| desktop/views/components/notes.note.vue: | ||||
| desktop/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   reply: "返信" | ||||
|   renote: "Renote" | ||||
| @@ -705,8 +742,8 @@ desktop/views/components/settings.vue: | ||||
|   profile: "プロフィール" | ||||
|   notification: "通知" | ||||
|   apps: "アプリ" | ||||
|   mute: "ミュート" | ||||
|   drive: "ドライブ" | ||||
|   mute-and-block: "ミュート/ブロック" | ||||
|   blocking: "ブロック" | ||||
|   security: "セキュリティ" | ||||
|   signin: "サインイン履歴" | ||||
|   password: "パスワード" | ||||
| @@ -725,8 +762,12 @@ desktop/views/components/settings.vue: | ||||
|   advanced: "詳細設定" | ||||
|   api-via-stream: "ストリームを経由したAPIリクエスト" | ||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "デザインと表示" | ||||
|   customize: "ホームをカスタマイズ" | ||||
|   wallpaper: "壁紙" | ||||
|   choose-wallpaper: "壁紙を選択" | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
| @@ -738,17 +779,19 @@ desktop/views/components/settings.vue: | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   timeline: "タイムライン" | ||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||
|   volume: "ボリューム" | ||||
|   test: "テスト" | ||||
|   mobile: "モバイル" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   language: "言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
| @@ -784,6 +827,10 @@ desktop/views/components/settings.vue: | ||||
|   tools: "ツール" | ||||
|   task-manager: "タスクマネージャ" | ||||
|   third-parties: "サードパーティ" | ||||
|   navbar-position: "ナビゲーションバーの位置" | ||||
|   navbar-position-top: "上" | ||||
|   navbar-position-left: "左" | ||||
|   navbar-position-right: "右" | ||||
| desktop/views/components/settings.2fa.vue: | ||||
|   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" | ||||
|   detail: "詳細..." | ||||
| @@ -802,41 +849,39 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "設定が完了しました!" | ||||
|   failed: "設定に失敗しました。トークンに誤りがないかご確認ください。" | ||||
|   info: "次回サインインからは、同様にパスワードに加えてデバイスに表示されているトークンを入力します。" | ||||
| desktop/views/components/settings.api.vue: | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
|   regeneration-of-token: "万が一このトークンが漏れたりその可能性がある場合はトークンを再生成できます。" | ||||
|   regenerate-token: "トークンを再生成" | ||||
|   token: "Token:" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   console: | ||||
|     title: 'APIコンソール' | ||||
|     endpoint: 'エンドポイント' | ||||
|     parameter: 'パラメータ' | ||||
|     send: '送信' | ||||
|     sending: '応答待ち' | ||||
|     response: '結果' | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "連携しているアプリケーションはありません" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "中" | ||||
| common/views/components/drive-settings.vue: | ||||
|   max: "容量" | ||||
|   in-use: "使用中" | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "ミュートしているユーザーはいません" | ||||
| desktop/views/components/settings.password.vue: | ||||
|   stats: "統計" | ||||
| common/views/components/mute-and-block.vue: | ||||
|   mute-and-block: "ミュートとブロック" | ||||
|   mute: "ミュート" | ||||
|   block: "ブロック" | ||||
|   no-muted-users: "ミュートしているユーザーはいません" | ||||
|   no-blocked-users: "ブロックしているユーザーはいません" | ||||
| common/views/components/password-settings.vue: | ||||
|   reset: "パスワードを変更する" | ||||
|   enter-current-password: "現在のパスワードを入力してください" | ||||
|   enter-new-password: "新しいパスワードを入力してください" | ||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||
|   not-match: "新しいパスワードが一致しません" | ||||
|   changed: "パスワードを変更しました" | ||||
| desktop/views/components/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   choice-avatar: "画像を選択" | ||||
|   name: "名前" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   profile-updated: "プロフィールを更新しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| @@ -861,7 +906,6 @@ desktop/views/components/ui.header.vue: | ||||
|   adjective: "さん" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "プロフィール" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
| @@ -903,42 +947,100 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
| admin/views/index.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "ドライブ" | ||||
|   instance: "インスタンス" | ||||
|   emoji: "カスタム絵文字" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   announcements: "お知らせ" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   accounts: "アカウント" | ||||
|   notes: "投稿" | ||||
|   drive: "ドライブ" | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "このインスタンス" | ||||
|   federated: "連合" | ||||
|   invite: "招待" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   banner-url: "Banner URL" | ||||
|   disableRegistration: "Disable new user registration" | ||||
|   disableLocalTimeline: "Disable the local timeline" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の積算" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の積算" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| admin/views/emoji.vue: | ||||
|   add-emoji: | ||||
|     title: "絵文字の登録" | ||||
|     name: "絵文字名" | ||||
|     name-desc: "a~z 0~9 _ の文字が使えます。" | ||||
|     aliases: "エイリアス" | ||||
|     aliases-desc: "スペースで区切って複数設定できます。" | ||||
|     url: "絵文字画像URL" | ||||
|     add: "追加" | ||||
|   emojis: | ||||
|     title: "絵文字一覧" | ||||
|     update: "更新" | ||||
|     remove: "削除" | ||||
| admin/views/announcements.vue: | ||||
|   announcements: "お知らせ" | ||||
|   save: "保存" | ||||
|   remove: "削除" | ||||
|   add: "追加" | ||||
|   title: "タイトル" | ||||
|   text: "内容" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| 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: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/pages/deck/deck.user-column.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   images: "画像" | ||||
|   activity: "アクティビティ" | ||||
|   timeline: "タイムライン" | ||||
|   pinned-notes: "ピン留めされた投稿" | ||||
|   push-to-a-list: "リストに追加" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
| @@ -991,9 +1093,6 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
| desktop/views/pages/user/user.home.vue: | ||||
|   last-used-at: "最終アクセス" | ||||
| desktop/views/pages/user/user.photos.vue: | ||||
|   title: "フォト" | ||||
| @@ -1007,6 +1106,9 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "ミュートする" | ||||
|   muted: "ミュートしています" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロックする" | ||||
|   unblock: "ブロック解除" | ||||
|   block-confirm: "このユーザーをブロックしますか?" | ||||
|   push-to-a-list: "リストに追加" | ||||
|   list-pushed: "{user}を{list}に追加しました。" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| @@ -1014,6 +1116,10 @@ desktop/views/pages/user/user.header.vue: | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   years-old: "歳" | ||||
|   year: "年" | ||||
|   month: "月" | ||||
|   day: "日" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "投稿" | ||||
|   with-replies: "投稿と返信" | ||||
| @@ -1043,7 +1149,6 @@ desktop/views/widgets/users.vue: | ||||
|   refresh: "他を見る" | ||||
|   no-one: "いません!" | ||||
| mobile/views/components/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   used: "使用中" | ||||
|   folder-count: "フォルダ" | ||||
|   count-separator: "、" | ||||
| @@ -1073,6 +1178,8 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -1145,7 +1252,6 @@ mobile/views/components/ui.nav.vue: | ||||
|   messaging: "メッセージ" | ||||
|   follow-requests: "フォロー申請" | ||||
|   search: "検索" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   user-lists: "リスト" | ||||
|   widgets: "ウィジェット" | ||||
| @@ -1168,7 +1274,6 @@ mobile/views/pages/user-lists.vue: | ||||
|   title: "リスト" | ||||
|   enter-list-name: "リスト名を入力してください" | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   more: "もっと見る" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "📦 始めましょう" | ||||
| @@ -1213,23 +1318,6 @@ mobile/views/pages/notifications.vue: | ||||
|   read-all: "すべての通知を既読にしますか?" | ||||
| mobile/views/pages/games/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
| mobile/views/pages/search.vue: | ||||
|   search: "検索" | ||||
|   empty: "「{}」に関する投稿は見つかりませんでした。" | ||||
| @@ -1285,6 +1373,8 @@ mobile/views/pages/settings.vue: | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   mark-as-read-all-unread-notes: "すべての投稿を既読にする" | ||||
|   password: "パスワード" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   following: "フォロー" | ||||
| @@ -1294,8 +1384,10 @@ mobile/views/pages/user.vue: | ||||
|   timeline: "タイムライン" | ||||
|   media: "メディア" | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
|   mute: "ミュート" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "最近の投稿" | ||||
|   images: "画像" | ||||
| @@ -1341,3 +1433,29 @@ docs: | ||||
|       description: "説明" | ||||
| dev/views/index.vue: | ||||
|   manage-apps: "アプリの管理" | ||||
| dev/views/apps.vue: | ||||
|   manage-apps: "アプリを管理" | ||||
|   create-app: "アプリ作成" | ||||
|   app-missing: "アプリなし" | ||||
| dev/views/new-app.vue: | ||||
|   create-app: "アプリケーションの作成" | ||||
|   app-name: "アプリケーション名" | ||||
|   app-name-desc: "あなたのアプリの名称。" | ||||
|   app-name-ex: "ex) Misskey for iOS" | ||||
|   app-overview: "アプリの概要" | ||||
|   app-desc: "あなたのアプリの簡単な説明や紹介。" | ||||
|   app-desc-ex: "ex) Misskey iOSクライアント。" | ||||
|   callback-url: "コールバックURL (オプション)" | ||||
|   callback-url-desc: "ユーザーが認証フォームで認証した際にリダイレクトするURLを設定できます。" | ||||
|   authority: "権限" | ||||
|   authority-desc: "ここで要求した機能だけがAPIからアクセスできます。" | ||||
|   authority-warning: "アプリ作成後も変更できますが、新たな権限を付与する場合、その時点で関連付けられているユーザーキーはすべて無効になります。" | ||||
|   account-read: "アカウントの情報を見る。" | ||||
|   account-write: "アカウントの情報を操作する。" | ||||
|   note-write: "投稿する。" | ||||
|   reaction-write: "リアクションしたりリアクションをキャンセルする。" | ||||
|   following-write: "フォローしたりフォロー解除する。" | ||||
|   drive-read: "ドライブを見る。" | ||||
|   drive-write: "ドライブを操作する。" | ||||
|   notification-read: "通知を見る。" | ||||
|   notification-write: "通知を操作する。" | ||||
|   | ||||
| @@ -3,44 +3,52 @@ meta: | ||||
|   lang: "Deutsch" | ||||
|   divider: "" | ||||
| common: | ||||
|   misskey: "A ⭐ of fediverse" | ||||
|   about-title: "A ⭐ of fediverse." | ||||
|   misskey: "Ein ⭐ des Fediversums" | ||||
|   about-title: "Ein ⭐ des Fediversums." | ||||
|   about: "Misskeyを見つけていただき、ありがとうございます。Misskeyは、地球で生まれた<b>分散マイクロブログSNS</b>です。Fediverse(様々なSNSで構成される宇宙)の中に存在するため、他のSNSと相互に繋がっています。暫し都会の喧騒から離れて、新しいインターネットにダイブしてみませんか。" | ||||
|   intro: | ||||
|     title: "Misskeyって?" | ||||
|     title: "Was ist Misskey?" | ||||
|     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" | ||||
|     features: "特徴" | ||||
|     rich-contents: "投稿" | ||||
|     features: "Funktionen" | ||||
|     rich-contents: "Notizen" | ||||
|     rich-contents-desc: "自分の考え、話題の出来事、皆と共有したいことについて発信してください。必要であれば、様々な構文を使って投稿を装飾したり、好きな画像、動画などのファイルやアンケートを添付することもできます。" | ||||
|     reaction: "リアクション" | ||||
|     reaction: "Reaktionen" | ||||
|     reaction-desc: "あなたの気持ちを伝える最も簡単な方法です。Misskeyは、他のユーザーの投稿に様々なリアクションを付けることができます。いちどMisskeyのリアクション機能を体験してしまうと、もう「いいね」の概念しか存在しないSNSには戻れなくなるかもしれません。" | ||||
|     ui: "インターフェース" | ||||
|     ui: "Benutzeroberfläche" | ||||
|     ui-desc: "どのようなUIが使いやすいかは人それぞれです。だから、Misskeyは自由度の高いUIを持っています。レイアウトやデザインを調整したり、カスタマイズ可能な様々なウィジェットを配置したりして、自分だけのホームを作ってください。" | ||||
|     drive: "ドライブ" | ||||
|     drive: "Drive" | ||||
|     drive-desc: "以前投稿したことのある画像をまた投稿したくなったことはありませんか?もしくは、アップロードしたファイルをフォルダ分けして整理したくなったことはありませんか?Misskeyの根幹に組み込まれたドライブ機能によってそれらが解決します。ファイルの共有も簡単です。" | ||||
|     outro: "他にもMisskeyにしかない機能はまだまだあるので、ぜひあなた自身の目で確かめてください。Misskeyは分散型SNSなので、このインスタンスが気に入らなければ他のインスタンスを試すこともできます。それでは、GLHF!" | ||||
|   adblock: | ||||
|     detected: "広告ブロッカーを無効にしてください" | ||||
|     detected: "Bitte deaktiviere den Werbeblocker." | ||||
|     warning: "<strong>Misskeyは広告を掲載していません</strong>が、広告をブロックする機能が有効だと一部の機能が利用できなかったり、不具合が発生する場合があります。" | ||||
|   application-authorization: "アプリの連携" | ||||
|   close: "閉じる" | ||||
|   application-authorization: "Autorisierte Anwendungen" | ||||
|   close: "Schließen" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   got-it: "わかった" | ||||
|   BSoD: | ||||
|     fatal-error: "Ein schwerwiegender Fehler ist aufgetreten :(" | ||||
|     update-browser-os: "お使いのブラウザ(またはOS)のバージョンを更新すると解決する可能性があります。" | ||||
|     error-code: "Fehlercode" | ||||
|     browser-version: "Browserversion" | ||||
|     client-version: "Clientversion" | ||||
|     email-support: "問題が解決しない場合は、上記の情報をお書き添えの上 syuilotan@yahoo.co.jp までご連絡ください。" | ||||
|     thanks: "Vielen Dank dass du Misskey verwendest." | ||||
|   got-it: "Verstanden!" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
|     title: "Anpassung-Tipps" | ||||
|     paragraph1: "ホームのカスタマイズでは、ウィジェットを追加/削除したり、ドラッグ&ドロップして並べ替えたりすることができます。" | ||||
|     paragraph2: "一部のウィジェットは、<strong><strong>右</strong>クリック</strong>することで表示を変更することができます。" | ||||
|     paragraph3: "ウィジェットを削除するには、ヘッダーの<strong>「ゴミ箱」</strong>と書かれたエリアにウィジェットをドラッグ&ドロップします。" | ||||
|     paragraph4: "カスタマイズを終了するには、右上の「完了」をクリックします。" | ||||
|     gotit: "Got it!" | ||||
|     gotit: "Verstanden!" | ||||
|   notification: | ||||
|     file-uploaded: "ファイルがアップロードされました" | ||||
|     message-from: "{}さんからメッセージ:" | ||||
|     file-uploaded: "Datei hochgeladen!" | ||||
|     message-from: "Nachricht von {}:" | ||||
|     reversi-invited: "対局への招待があります" | ||||
|     reversi-invited-by: "{}さんから" | ||||
|     notified-by: "{}さんから" | ||||
|     reply-from: "{}さんから返信:" | ||||
|     quoted-by: "{}さんが引用:" | ||||
|     reversi-invited-by: "Eingeladen von {}:" | ||||
|     notified-by: "Benachrichtigt von {}:" | ||||
|     reply-from: "Antwort von {}:" | ||||
|     quoted-by: "Zitiert von {}:" | ||||
|   time: | ||||
|     unknown: "Unbekannt" | ||||
|     future: "Zukunft" | ||||
| @@ -52,8 +60,9 @@ common: | ||||
|     weeks_ago: "vor {0} Woche{0:n}" | ||||
|     months_ago: "vor {0} Monat{0:en}" | ||||
|     years_ago: "vor {} Jahr{0:en}" | ||||
|   month-and-day: "{month}月 {day}日" | ||||
|   trash: "ゴミ箱" | ||||
|   month-and-day: "{day}/{month}" | ||||
|   trash: "Papierkorb" | ||||
|   drive: "ドライブ" | ||||
|   weekday-short: | ||||
|     sunday: "So" | ||||
|     monday: "Mo" | ||||
| @@ -63,15 +72,15 @@ common: | ||||
|     friday: "Fr" | ||||
|     saturday: "Sa" | ||||
|   weekday: | ||||
|     sunday: "日曜日" | ||||
|     monday: "月曜日" | ||||
|     tuesday: "火曜日" | ||||
|     wednesday: "水曜日" | ||||
|     thursday: "木曜日" | ||||
|     friday: "金曜日" | ||||
|     saturday: "土曜日" | ||||
|     sunday: "Sonntag" | ||||
|     monday: "Montag" | ||||
|     tuesday: "Dienstag" | ||||
|     wednesday: "Mittwoch" | ||||
|     thursday: "Donnerstag" | ||||
|     friday: "Freitag" | ||||
|     saturday: "Samstag" | ||||
|   reactions: | ||||
|     like: "いいね" | ||||
|     like: "Gefällt mir" | ||||
|     love: "Lieben" | ||||
|     laugh: "Lachen" | ||||
|     hmm: "Hmm...?" | ||||
| @@ -82,14 +91,14 @@ common: | ||||
|     rip: "RIP" | ||||
|     pudding: "Pudding" | ||||
|   note-visibility: | ||||
|     public: "公開" | ||||
|     home: "ホーム" | ||||
|     home-desc: "ホームタイムラインにのみ公開" | ||||
|     followers: "フォロワー" | ||||
|     followers-desc: "自分のフォロワーにのみ公開" | ||||
|     specified: "ダイレクト" | ||||
|     specified-desc: "指定したユーザーにのみ公開" | ||||
|     private: "非公開" | ||||
|     public: "Öffentlich" | ||||
|     home: "Startseite" | ||||
|     home-desc: "Nur auf die Startseite posten" | ||||
|     followers: "Abonnenten" | ||||
|     followers-desc: "Nur für diejenigen sichtbar, die dir folgen" | ||||
|     specified: "Direkt" | ||||
|     specified-desc: "Nur für bestimmte Benutzer posten" | ||||
|     private: "Privat" | ||||
|   note-placeholders: | ||||
|     a: "Was machst du gerade?" | ||||
|     b: "Was ist so passiert?" | ||||
| @@ -97,34 +106,40 @@ common: | ||||
|     d: "Willst du etwas sagen?" | ||||
|     e: "Schreib hier etwas!" | ||||
|     f: "Warte darauf, das du schreibst." | ||||
|   search: "検索" | ||||
|   search: "Suche" | ||||
|   delete: "Löschen" | ||||
|   loading: "Laden" | ||||
|   ok: "OK" | ||||
|   update-available-title: "更新があります" | ||||
|   update-available-title: "Aktualisierung verfügbar" | ||||
|   update-available: "Eine neue Version von Misskey ist verfügbar ({newer}, aktuell ist {current}). Lade die Seite neu um die aktuelle Version zu laden" | ||||
|   my-token-regenerated: "Dein Token wurde generiert. Du wirst jetzt abgemeldet." | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   i-like-sushi: "Ich bevorzuge Sushi anstelle von Pudding" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   verified-user: "公式アカウント" | ||||
|   verified-user: "Verifizierter Benutzer" | ||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   show-full-acct: "ユーザー名のホストを省略しない" | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||
|   reduce-motion: "Animationen der Benutzeroberfläche reduzieren" | ||||
|   this-setting-is-this-device-only: "Nur auf diesem Gerät" | ||||
|   do-not-use-in-production: 'Dies ist eine Entwicklungsversion. Nicht in einer Produktionsumgebung verwenden.' | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|   error: | ||||
|     title: '問題が発生しました' | ||||
|     retry: 'Erneut versuchen' | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
|     opponent-turn: "相手のターンです" | ||||
|     turn-of: "{}のターンです" | ||||
|     past-turn-of: "{}のターン" | ||||
|     won: "{}の勝ち" | ||||
|     black: "黒" | ||||
|     white: "白" | ||||
|     total: "合計" | ||||
|     drawn: "Unentschieden" | ||||
|     my-turn: "Du bist am Zug" | ||||
|     opponent-turn: "Dein Gegner ist an der Reihe" | ||||
|     turn-of: "{} ist am Zug" | ||||
|     past-turn-of: "Zug von {}" | ||||
|     won: "{} hat gewonnen!" | ||||
|     black: "Schwarz" | ||||
|     white: "Weiß" | ||||
|     total: "Gesamt" | ||||
|     this-turn: "{}ターン目" | ||||
|   widgets: | ||||
|     analog-clock: "Analoge Uhr" | ||||
| @@ -142,23 +157,23 @@ common: | ||||
|     broadcast: "ブロードキャスト" | ||||
|     notifications: "Benachrichtigungen" | ||||
|     users: "Empfohlene Benutzer" | ||||
|     polls: "アンケート" | ||||
|     polls: "Umfrage" | ||||
|     post-form: "Beitragsform" | ||||
|     messaging: "Nachrichten" | ||||
|     server: "Server-Info" | ||||
|     donation: "Spenden" | ||||
|     nav: "Navigation" | ||||
|     tips: "Tipps" | ||||
|     hashtags: "ハッシュタグ" | ||||
|     hashtags: "Hashtags" | ||||
|   deck: | ||||
|     widgets: "Widget hinzufügen:" | ||||
|     home: "Startseite" | ||||
|     local: "Lokal" | ||||
|     hybrid: "ソーシャル" | ||||
|     hashtag: "ハッシュタグ" | ||||
|     hybrid: "Sozial" | ||||
|     hashtag: "Hashtag" | ||||
|     global: "Global" | ||||
|     mentions: "あなた宛て" | ||||
|     direct: "ダイレクト投稿" | ||||
|     mentions: "Erwähnungen" | ||||
|     direct: "Direktnachrichten" | ||||
|     notifications: "Mitteilungen" | ||||
|     list: "Listen" | ||||
|     swap-left: "Nach links" | ||||
| @@ -169,73 +184,75 @@ common: | ||||
|     add-column: "Eine Spalte hinzufügen" | ||||
|     rename: "Umbenennen" | ||||
|     stack-left: "Nach links schichten" | ||||
|     pop-right: "右に出す" | ||||
|     pop-right: "Rechts andocken" | ||||
|   dev: "Fehler beim Erstellen der Applikation. Bitte versuche es erneut." | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{{ app.name }}</i>があなたのアカウントにアクセスすることを<b>許可</b>しますか?" | ||||
|   permission-ask: "このアプリは次の権限を要求しています:" | ||||
|   account-read: "アカウントの情報を見る。" | ||||
|   account-write: "アカウントの情報を操作する。" | ||||
|   note-write: "投稿する。" | ||||
|   note-write: "Senden." | ||||
|   like-write: "いいねしたりいいね解除する。" | ||||
|   following-write: "フォローしたりフォロー解除する。" | ||||
|   drive-read: "ドライブを見る。" | ||||
|   drive-write: "ドライブを操作する。" | ||||
|   notification-read: "通知を見る。" | ||||
|   notification-write: "通知を操作する。" | ||||
|   cancel: "キャンセル" | ||||
|   accept: "アクセスを許可" | ||||
|   notification-write: "Benachrichtigungen verwalten." | ||||
|   cancel: "Abbrechen" | ||||
|   accept: "Zugriff erlauben." | ||||
| auth/views/index.vue: | ||||
|   loading: "読み込み中" | ||||
|   denied: "アプリケーションの連携をキャンセルしました。" | ||||
|   loading: "Lädt" | ||||
|   denied: "Autorisierung der Anwendung wurde verweigert." | ||||
|   denied-paragraph: "このアプリがあなたのアカウントにアクセスすることはありません。" | ||||
|   already-authorized: "このアプリは既に連携済みです" | ||||
|   allowed: "アプリケーションの連携を許可しました" | ||||
|   already-authorized: "Diese Anwendung ist bereits autorisiert." | ||||
|   allowed: "Autorisierung der Anwendung wurde erlaubt." | ||||
|   callback-url: "アプリケーションに戻っています" | ||||
|   please-go-back: "アプリケーションに戻って、やっていってください。" | ||||
|   error: "セッションが存在しません。" | ||||
|   sign-in: "サインインしてください" | ||||
|   please-go-back: "Bitte gehe zurück zur Anwendung." | ||||
|   error: "Sitzung ist nicht vorhanden." | ||||
|   sign-in: "Bitte melde dich an." | ||||
| common/views/components/games/reversi/reversi.vue: | ||||
|   matching: | ||||
|     waiting-for: "{}を待っています" | ||||
|     cancel: "キャンセル" | ||||
|     waiting-for: "Warten auf {}" | ||||
|     cancel: "Abbrechen" | ||||
| common/views/components/games/reversi/reversi.game.vue: | ||||
|   surrender: "投了" | ||||
|   surrender: "Aufgeben" | ||||
|   surrendered: "投了により" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
| common/views/components/games/reversi/reversi.index.vue: | ||||
|   title: "Misskey Reversi" | ||||
|   sub-title: "他のMisskeyユーザーとリバーシで対戦しよう" | ||||
|   invite: "招待" | ||||
|   rule: "遊び方" | ||||
|   sub-title: "Spiele Reversi mit deinen Freunden!" | ||||
|   invite: "Einladen" | ||||
|   rule: "Spielanleitung" | ||||
|   rule-desc: "リバーシは、相手と交互に石をボードに置いて、相手の石を挟んで自分の色に変えてゆき、最終的に残った石が多い方が勝ちというボードゲームです。" | ||||
|   mode-invite: "招待" | ||||
|   mode-invite: "Einladen" | ||||
|   mode-invite-desc: "指定したユーザーと対戦するモードです。" | ||||
|   invitations: "対局の招待があります!" | ||||
|   my-games: "自分の対局" | ||||
|   all-games: "みんなの対局" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
|   all-games: "Alle Spiele" | ||||
|   enter-username: "Bitte gib einen Benutzernamen ein" | ||||
|   game-state: | ||||
|     ended: "終了" | ||||
|     ended: "Fertig" | ||||
|     playing: "進行中" | ||||
| common/views/components/games/reversi/reversi.room.vue: | ||||
|   settings-of-the-game: "ゲームの設定" | ||||
|   choose-map: "マップを選択" | ||||
|   random: "ランダム" | ||||
|   black-or-white: "先手/後手" | ||||
|   black-is: "{}が黒" | ||||
|   rules: "ルール" | ||||
|   settings-of-the-game: "Spieleinstellungen" | ||||
|   choose-map: "Wähle eine Karte" | ||||
|   random: "Zufällige Auswahl" | ||||
|   black-or-white: "Schwarz/Weiß" | ||||
|   black-is: "Schwarz ist {}" | ||||
|   rules: "Regeln" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
|   settings-of-the-bot: "Botの設定" | ||||
|   this-game-is-started-soon: "ゲームは数秒後に開始されます" | ||||
|   waiting-for-other: "相手の準備が完了するのを待っています" | ||||
|   waiting-for-other: "Warte auf den Gegner" | ||||
|   waiting-for-me: "あなたの準備が完了するのを待っています" | ||||
|   waiting-for-both: "準備中" | ||||
|   cancel: "キャンセル" | ||||
|   ready: "準備完了" | ||||
|   cancel: "Abbrechen" | ||||
|   ready: "Bereit" | ||||
|   cancel-ready: "準備続行" | ||||
| common/views/components/connect-failed.vue: | ||||
|   title: "Verbindung zum Server ist fehlgeschlagen" | ||||
| @@ -262,29 +279,29 @@ common/views/components/connect-failed.troubleshooter.vue: | ||||
|   flush: "Cache leeren" | ||||
|   set-version: "Version angeben" | ||||
| common/views/components/media-banner.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
|   sensitive: "Dieser Inhalt ist NSFW" | ||||
|   click-to-show: "Klicke zum den Inhalt anzusehen" | ||||
| common/views/components/theme.vue: | ||||
|   light-theme: "非ダークモード時に使用するテーマ" | ||||
|   dark-theme: "ダークモード時に使用するテーマ" | ||||
|   light-themes: "明るいテーマ" | ||||
|   dark-themes: "暗いテーマ" | ||||
|   light-theme: "Thema" | ||||
|   dark-theme: "Thema während des Nachtmodus" | ||||
|   light-themes: "Helles Thema" | ||||
|   dark-themes: "Dunkles Thema" | ||||
|   install-a-theme: "テーマのインストール" | ||||
|   theme-code: "テーマコード" | ||||
|   install: "インストール" | ||||
|   installed: "「{}」をインストールしました" | ||||
|   create-a-theme: "テーマの作成" | ||||
|   save-created-theme: "テーマを保存" | ||||
|   primary-color: "プライマリ カラー" | ||||
|   secondary-color: "セカンダリ カラー" | ||||
|   text-color: "文字色" | ||||
|   base-theme: "ベーステーマ" | ||||
|   base-theme-light: "Light" | ||||
|   base-theme-dark: "Dark" | ||||
|   theme-name: "テーマ名" | ||||
|   preview-created-theme: "プレビュー" | ||||
|   invalid-theme: "テーマが正しくありません。" | ||||
|   already-installed: "既にそのテーマはインストールされています。" | ||||
|   install: "Anwenden" | ||||
|   installed: "\"{}\" wurde installiert" | ||||
|   create-a-theme: "Thema erstellen" | ||||
|   save-created-theme: "Thema speichern" | ||||
|   primary-color: "Primäre Farbe" | ||||
|   secondary-color: "Sekundäre Farbe" | ||||
|   text-color: "Textfarbe" | ||||
|   base-theme: "Basisthema" | ||||
|   base-theme-light: "Hell" | ||||
|   base-theme-dark: "Dunkel" | ||||
|   theme-name: "Name des Themas" | ||||
|   preview-created-theme: "Vorschau" | ||||
|   invalid-theme: "Thema ist ungültig" | ||||
|   already-installed: "Thema ist bereits installiert" | ||||
|   saved: "保存しました" | ||||
|   manage-themes: "テーマの管理" | ||||
|   builtin-themes: "標準テーマ" | ||||
| @@ -293,10 +310,10 @@ common/views/components/theme.vue: | ||||
|   select-theme: "テーマを選択してください" | ||||
|   uninstall: "アンインストール" | ||||
|   uninstalled: "「{}」をアンインストールしました" | ||||
|   author: "作者" | ||||
|   author: "Autor" | ||||
|   desc: "説明" | ||||
|   export: "エクスポート" | ||||
|   import: "インポート" | ||||
|   export: "Exportieren" | ||||
|   import: "Importieren" | ||||
|   import-by-code: "またはコードをペースト" | ||||
|   theme-name-required: "テーマ名は必須です。" | ||||
| common/views/components/cw-button.vue: | ||||
| @@ -334,7 +351,8 @@ common/views/components/nav.vue: | ||||
| common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "Diese Anmerkung favorisieren" | ||||
|   favorite: "Diese Notiz favorisieren" | ||||
|   unfavorite: "Aus Favoriten entfernen" | ||||
|   pin: "An die Profilseite pinnen" | ||||
|   unpin: "ピン留め解除" | ||||
|   delete: "Löschen" | ||||
| @@ -361,7 +379,7 @@ common/views/components/signin.vue: | ||||
|   token: "Token" | ||||
|   signing-in: "Melde an..." | ||||
|   signin: "Anmelden" | ||||
|   or: "または" | ||||
|   or: "Oder" | ||||
|   signin-with-twitter: "Twitterでログイン" | ||||
|   login-failed: "ログインできませんでした。ユーザー名とパスワードを確認してください。" | ||||
| common/views/components/signup.vue: | ||||
| @@ -415,6 +433,25 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   careful-bot: "Botからのフォローだけ承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "Laden" | ||||
|   no-broadcasts: "Keine Broadcasts" | ||||
| @@ -506,11 +543,14 @@ desktop/views/components/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   network: "Netzwerk" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
| @@ -521,9 +561,9 @@ desktop/views/components/charts.vue: | ||||
|     drive-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の積算" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
|     network-requests: "Anfragen" | ||||
|     network-time: "Antwortzeit" | ||||
|     network-usage: "Datenverkehr" | ||||
| desktop/views/components/choose-file-from-drive-window.vue: | ||||
|   choose-file: "Datei auswählen" | ||||
|   upload: "Dateien von deinem PC hochladen" | ||||
| @@ -540,7 +580,6 @@ desktop/views/components/crop-window.vue: | ||||
|   ok: "OK" | ||||
| desktop/views/components/drive-window.vue: | ||||
|   used: "benutzt" | ||||
|   drive: "Speicher" | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "Avatar" | ||||
|   banner: "Banner" | ||||
| @@ -557,7 +596,7 @@ desktop/views/components/drive.file.vue: | ||||
|     open-in-app: "In der App öffnen" | ||||
|     add-app: "App hinzufügen" | ||||
|     rename-file: "Datei umbennen" | ||||
|     input-new-file-name: "Geben Sie den neuen Dateinamen an" | ||||
|     input-new-file-name: "Gib den neuen Dateinamen an" | ||||
|     copied: "Kopieren erfolgreich" | ||||
|     copied-url-to-clipboard: "URL wurde in die Zwischenablage kopiert" | ||||
| desktop/views/components/drive.folder.vue: | ||||
| @@ -570,8 +609,6 @@ desktop/views/components/drive.folder.vue: | ||||
|     rename: "Umbenennen" | ||||
|     rename-folder: "Ordner umbenennen" | ||||
|     input-new-folder-name: "Namen für neuen Ordner eingeben" | ||||
| desktop/views/components/drive.nav-folder.vue: | ||||
|   drive: "Laufwerk" | ||||
| desktop/views/components/drive.vue: | ||||
|   search: "Suchen" | ||||
|   load-more: "Mehr laden" | ||||
| @@ -639,25 +676,25 @@ desktop/views/components/note-detail.vue: | ||||
|   location: "Ort" | ||||
|   renote: "Anmerkung" | ||||
|   add-reaction: "Reaktion hinzufügen" | ||||
| desktop/views/components/notes.note.vue: | ||||
|   reposted-by: "Auch geteilt von" | ||||
|   reply: "Antworten" | ||||
|   renote: "Anmerken" | ||||
|   add-reaction: "Eine Reaktion hinzufügen" | ||||
|   detail: "Zeige Details" | ||||
|   private: "Dieser Beitrag ist eine privat" | ||||
|   deleted: "Dieser Beitrag wurde entfernt" | ||||
| desktop/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   reply: "返信" | ||||
|   renote: "Renote" | ||||
|   add-reaction: "リアクション" | ||||
|   detail: "詳細" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "Laden fehlgeschlagen." | ||||
|   retry: "Erneut versuchen" | ||||
|   load-more: "もっと読み込む" | ||||
|   load-more: "Mehr laden" | ||||
| desktop/views/components/notifications.vue: | ||||
|   more: "Mehr" | ||||
|   empty: "Keine Benachrichtigungen" | ||||
| desktop/views/components/post-form.vue: | ||||
|   add-visible-user: "+ユーザーを追加" | ||||
|   add-visible-user: "+Nutzer hinzufügen" | ||||
|   attach-location-information: "位置情報を添付する" | ||||
|   hide-contents: "内容を隠す" | ||||
|   hide-contents: "Inhalt verstecken" | ||||
|   reply-placeholder: "Antworte auf diese Anmerkung..." | ||||
|   quote-placeholder: "Zitiere diese Anmerkung..." | ||||
|   submit: "Beitragsform" | ||||
| @@ -678,10 +715,10 @@ desktop/views/components/post-form.vue: | ||||
|   text-remain: "{} Zeichen verbleibend" | ||||
|   recent-tags: "最近" | ||||
|   click-to-tagging: "クリックでタグ付け" | ||||
|   visibility: "公開範囲" | ||||
|   visibility: "Sichtbarkeit" | ||||
|   geolocation-alert: "お使いの端末は位置情報に対応していません" | ||||
|   error: "エラー" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
|   error: "Fehler" | ||||
|   enter-username: "Bitte gib einen Benutzernamen ein..." | ||||
|   annotations: "内容への注釈 (オプション)" | ||||
| desktop/views/components/post-form-window.vue: | ||||
|   note: "Neue Notiz" | ||||
| @@ -705,8 +742,8 @@ desktop/views/components/settings.vue: | ||||
|   profile: "Profil" | ||||
|   notification: "Mitteilungen" | ||||
|   apps: "In App öffnen" | ||||
|   mute: "Stummschalten" | ||||
|   drive: "Dateien vom Drive anfügen" | ||||
|   mute-and-block: "ミュート/ブロック" | ||||
|   blocking: "ブロック" | ||||
|   security: "Sicherheit" | ||||
|   signin: "サインイン履歴" | ||||
|   password: "Passwort" | ||||
| @@ -725,30 +762,36 @@ desktop/views/components/settings.vue: | ||||
|   advanced: "Erweiterte Einstellungen" | ||||
|   api-via-stream: "API-Anfrage via stream" | ||||
|   api-via-stream-desc: "API-Anfrage über WebSocket statt native Aktualisierungs-API (für bessere Leistung). Diese Einstellung wird im Browser gespeichert." | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "Erscheinungsbild und Anzeige" | ||||
|   customize: "Startseite anpassen" | ||||
|   wallpaper: "壁紙" | ||||
|   choose-wallpaper: "壁紙を選択" | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "Nacht Modus" | ||||
|   use-shadow: "UIに影を使用" | ||||
|   rounded-corners: "UIの角を丸める" | ||||
|   rounded-corners: "Abgerundete Ecken" | ||||
|   circle-icons: "Kreisförmige Icons" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "Zeige Antworten" | ||||
|   timeline: "タイムライン" | ||||
|   show-my-renotes: "Zeige meine Reposts auf der Zeitleiste" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "Karte anzeigen" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   sound: "Ton" | ||||
|   enable-sounds: "Ton aktivieren" | ||||
|   enable-sounds-desc: "Spiel einen Ton ab beim Erhalten eines Beitrags bzw. einer Nachricht. Diese Einstellung wird im Browser gespeichert." | ||||
|   volume: "Lautstärke" | ||||
|   test: "Test" | ||||
|   mobile: "Mobil" | ||||
|   disable-via-mobile: "Diesen Beitrag nicht mit 'vom Handy' absenden" | ||||
|   language: "Sprache" | ||||
|   pick-language: "Sprache auswählen" | ||||
|   recommended: "Empfohlen" | ||||
| @@ -784,6 +827,10 @@ desktop/views/components/settings.vue: | ||||
|   tools: "Werkzeuge" | ||||
|   task-manager: "Taskmanager" | ||||
|   third-parties: "サードパーティ" | ||||
|   navbar-position: "ナビゲーションバーの位置" | ||||
|   navbar-position-top: "上" | ||||
|   navbar-position-left: "左" | ||||
|   navbar-position-right: "右" | ||||
| desktop/views/components/settings.2fa.vue: | ||||
|   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" | ||||
|   detail: "詳細..." | ||||
| @@ -802,41 +849,39 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "設定が完了しました!" | ||||
|   failed: "設定に失敗しました。トークンに誤りがないかご確認ください。" | ||||
|   info: "次回サインインからは、同様にパスワードに加えてデバイスに表示されているトークンを入力します。" | ||||
| desktop/views/components/settings.api.vue: | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
|   regeneration-of-token: "万が一このトークンが漏れたりその可能性がある場合はトークンを再生成できます。" | ||||
|   regenerate-token: "トークンを再生成" | ||||
|   token: "Token:" | ||||
|   enter-password: "Bitte Passwort eingeben" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   console: | ||||
|     title: 'APIコンソール' | ||||
|     endpoint: 'エンドポイント' | ||||
|     parameter: 'パラメータ' | ||||
|     send: '送信' | ||||
|     sending: '応答待ち' | ||||
|     response: '結果' | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "連携しているアプリケーションはありません" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "中" | ||||
| common/views/components/drive-settings.vue: | ||||
|   max: "容量" | ||||
|   in-use: "使用中" | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "ミュートしているユーザーはいません" | ||||
| desktop/views/components/settings.password.vue: | ||||
|   stats: "統計" | ||||
| common/views/components/mute-and-block.vue: | ||||
|   mute-and-block: "ミュートとブロック" | ||||
|   mute: "ミュート" | ||||
|   block: "ブロック" | ||||
|   no-muted-users: "ミュートしているユーザーはいません" | ||||
|   no-blocked-users: "ブロックしているユーザーはいません" | ||||
| common/views/components/password-settings.vue: | ||||
|   reset: "パスワードを変更する" | ||||
|   enter-current-password: "Derzeitiges Passwort eingeben" | ||||
|   enter-new-password: "Neues Passwort eingeben" | ||||
|   enter-new-password-again: "Neues Passwort erneut eingeben" | ||||
|   enter-current-password: "現在のパスワードを入力してください" | ||||
|   enter-new-password: "新しいパスワードを入力してください" | ||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||
|   not-match: "新しいパスワードが一致しません" | ||||
|   changed: "パスワードを変更しました" | ||||
| desktop/views/components/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   choice-avatar: "画像を選択" | ||||
|   name: "名前" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   save: "Profil aktualisieren" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   profile-updated: "プロフィールを更新しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| @@ -861,7 +906,6 @@ desktop/views/components/ui.header.vue: | ||||
|   adjective: "さん" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "Dein Profil" | ||||
|   drive: "Speicher" | ||||
|   favorites: "Favoriten" | ||||
|   lists: "Listen" | ||||
|   follow-requests: "フォロー申請" | ||||
| @@ -896,49 +940,107 @@ desktop/views/components/user-preview.vue: | ||||
| desktop/views/components/users-list.vue: | ||||
|   all: "すべて" | ||||
|   iknow: "知り合い" | ||||
|   load-more: "もっと" | ||||
|   load-more: "Mehr" | ||||
|   fetching: "Lade…" | ||||
| desktop/views/components/users-list-item.vue: | ||||
|   followed: "フォローされています" | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
| admin/views/index.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "ドライブ" | ||||
|   instance: "インスタンス" | ||||
|   emoji: "カスタム絵文字" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   announcements: "お知らせ" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   accounts: "アカウント" | ||||
|   notes: "投稿" | ||||
|   drive: "ドライブ" | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "このインスタンス" | ||||
|   federated: "連合" | ||||
|   invite: "招待" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   banner-url: "Banner URL" | ||||
|   disableRegistration: "Disable new user registration" | ||||
|   disableLocalTimeline: "Disable the local timeline" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の積算" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の積算" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| admin/views/emoji.vue: | ||||
|   add-emoji: | ||||
|     title: "絵文字の登録" | ||||
|     name: "絵文字名" | ||||
|     name-desc: "a~z 0~9 _ の文字が使えます。" | ||||
|     aliases: "エイリアス" | ||||
|     aliases-desc: "スペースで区切って複数設定できます。" | ||||
|     url: "絵文字画像URL" | ||||
|     add: "追加" | ||||
|   emojis: | ||||
|     title: "絵文字一覧" | ||||
|     update: "更新" | ||||
|     remove: "削除" | ||||
| admin/views/announcements.vue: | ||||
|   announcements: "お知らせ" | ||||
|   save: "保存" | ||||
|   remove: "削除" | ||||
|   add: "追加" | ||||
|   title: "タイトル" | ||||
|   text: "内容" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| 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: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/pages/deck/deck.user-column.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   images: "画像" | ||||
|   activity: "アクティビティ" | ||||
|   timeline: "タイムライン" | ||||
|   pinned-notes: "ピン留めされた投稿" | ||||
|   push-to-a-list: "リストに追加" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
| @@ -991,9 +1093,6 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
| desktop/views/pages/user/user.home.vue: | ||||
|   last-used-at: "最終アクセス" | ||||
| desktop/views/pages/user/user.photos.vue: | ||||
|   title: "フォト" | ||||
| @@ -1007,6 +1106,9 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "ミュートする" | ||||
|   muted: "ミュートしています" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロックする" | ||||
|   unblock: "ブロック解除" | ||||
|   block-confirm: "このユーザーをブロックしますか?" | ||||
|   push-to-a-list: "リストに追加" | ||||
|   list-pushed: "{user}を{list}に追加しました。" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| @@ -1014,6 +1116,10 @@ desktop/views/pages/user/user.header.vue: | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   years-old: "歳" | ||||
|   year: "年" | ||||
|   month: "月" | ||||
|   day: "日" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "投稿" | ||||
|   with-replies: "投稿と返信" | ||||
| @@ -1043,7 +1149,6 @@ desktop/views/widgets/users.vue: | ||||
|   refresh: "他を見る" | ||||
|   no-one: "いません!" | ||||
| mobile/views/components/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   used: "使用中" | ||||
|   folder-count: "フォルダ" | ||||
|   count-separator: "、" | ||||
| @@ -1073,6 +1178,8 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -1145,7 +1252,6 @@ mobile/views/components/ui.nav.vue: | ||||
|   messaging: "メッセージ" | ||||
|   follow-requests: "フォロー申請" | ||||
|   search: "検索" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   user-lists: "リスト" | ||||
|   widgets: "ウィジェット" | ||||
| @@ -1157,19 +1263,18 @@ mobile/views/components/ui.nav.vue: | ||||
| mobile/views/components/user-timeline.vue: | ||||
|   no-notes: "このユーザーは投稿していないようです。" | ||||
|   no-notes-with-media: "メディア付き投稿はありません。" | ||||
|   load-more: "もっと" | ||||
|   load-more: "Mehr" | ||||
| mobile/views/components/users-list.vue: | ||||
|   all: "すべて" | ||||
|   known: "知り合い" | ||||
|   load-more: "もっと" | ||||
|   load-more: "Mehr" | ||||
| mobile/views/pages/favorites.vue: | ||||
|   title: "お気に入り" | ||||
|   title: "Favoriten" | ||||
| mobile/views/pages/user-lists.vue: | ||||
|   title: "リスト" | ||||
|   enter-list-name: "リスト名を入力してください" | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   more: "もっと見る" | ||||
|   more: "Mehr laden" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "📦 始めましょう" | ||||
| mobile/views/pages/followers.vue: | ||||
| @@ -1213,23 +1318,6 @@ mobile/views/pages/notifications.vue: | ||||
|   read-all: "すべての通知を既読にしますか?" | ||||
| mobile/views/pages/games/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "Profil" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "Profil wurde aktualisiert" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
| mobile/views/pages/search.vue: | ||||
|   search: "検索" | ||||
|   empty: "「{}」に関する投稿は見つかりませんでした。" | ||||
| @@ -1285,6 +1373,8 @@ mobile/views/pages/settings.vue: | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   mark-as-read-all-unread-notes: "すべての投稿を既読にする" | ||||
|   password: "パスワード" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   following: "フォロー" | ||||
| @@ -1294,13 +1384,15 @@ mobile/views/pages/user.vue: | ||||
|   timeline: "タイムライン" | ||||
|   media: "メディア" | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
|   mute: "ミュート" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "最近の投稿" | ||||
|   images: "画像" | ||||
|   activity: "アクティビティ" | ||||
|   keywords: "キーワード" | ||||
|   keywords: "Schlagwörter" | ||||
|   domains: "頻出ドメイン" | ||||
|   frequently-replied-users: "よく会話するユーザー" | ||||
|   followers-you-know: "知り合いのフォロワー" | ||||
| @@ -1341,3 +1433,29 @@ docs: | ||||
|       description: "説明" | ||||
| dev/views/index.vue: | ||||
|   manage-apps: "アプリの管理" | ||||
| dev/views/apps.vue: | ||||
|   manage-apps: "アプリを管理" | ||||
|   create-app: "アプリ作成" | ||||
|   app-missing: "アプリなし" | ||||
| dev/views/new-app.vue: | ||||
|   create-app: "アプリケーションの作成" | ||||
|   app-name: "アプリケーション名" | ||||
|   app-name-desc: "あなたのアプリの名称。" | ||||
|   app-name-ex: "ex) Misskey for iOS" | ||||
|   app-overview: "アプリの概要" | ||||
|   app-desc: "あなたのアプリの簡単な説明や紹介。" | ||||
|   app-desc-ex: "ex) Misskey iOSクライアント。" | ||||
|   callback-url: "コールバックURL (オプション)" | ||||
|   callback-url-desc: "ユーザーが認証フォームで認証した際にリダイレクトするURLを設定できます。" | ||||
|   authority: "権限" | ||||
|   authority-desc: "ここで要求した機能だけがAPIからアクセスできます。" | ||||
|   authority-warning: "アプリ作成後も変更できますが、新たな権限を付与する場合、その時点で関連付けられているユーザーキーはすべて無効になります。" | ||||
|   account-read: "アカウントの情報を見る。" | ||||
|   account-write: "アカウントの情報を操作する。" | ||||
|   note-write: "投稿する。" | ||||
|   reaction-write: "リアクションしたりリアクションをキャンセルする。" | ||||
|   following-write: "フォローしたりフォロー解除する。" | ||||
|   drive-read: "ドライブを見る。" | ||||
|   drive-write: "ドライブを操作する。" | ||||
|   notification-read: "通知を見る。" | ||||
|   notification-write: "通知を操作する。" | ||||
|   | ||||
| @@ -25,6 +25,14 @@ common: | ||||
|   application-authorization: "Application authorizations" | ||||
|   close: "Close" | ||||
|   do-not-copy-paste: "Please do not enter or paste the code here. Account may be compromised." | ||||
|   BSoD: | ||||
|     fatal-error: "A fatal error has occurred :(" | ||||
|     update-browser-os: "You might resolve to update the version of your browser (or OS)." | ||||
|     error-code: "Error code" | ||||
|     browser-version: "Browser version" | ||||
|     client-version: "Client version" | ||||
|     email-support: "If the problem persists, contact syuilotan@yahoo.co.jp please on the above information." | ||||
|     thanks: "Thank you for using Misskey." | ||||
|   got-it: "Got it!" | ||||
|   customization-tips: | ||||
|     title: "Customization tips" | ||||
| @@ -54,6 +62,7 @@ common: | ||||
|     years_ago: "{}year(s) ago" | ||||
|   month-and-day: "{month}/{day}" | ||||
|   trash: "Trash" | ||||
|   drive: "Drive" | ||||
|   weekday-short: | ||||
|     sunday: "S" | ||||
|     monday: "M" | ||||
| @@ -110,11 +119,17 @@ common: | ||||
|   verified-user: "Verified account" | ||||
|   disable-animated-mfm: "Disable animated texts in a post" | ||||
|   always-show-nsfw: "Always show NSFW contents" | ||||
|   always-mark-nsfw: "Always post with a warning about media attachment" | ||||
|   always-mark-nsfw: "Always mark posts with media attachments as NSFW" | ||||
|   show-full-acct: "Do not omit the hostname from the username" | ||||
|   reduce-motion: "Reduce motion in UI" | ||||
|   this-setting-is-this-device-only: "Only for this device" | ||||
|   do-not-use-in-production: 'As this is for development, do not use this in production.' | ||||
|   is-remote-user: "This user information is copied." | ||||
|   is-remote-post: "This post information is a copy." | ||||
|   view-on-remote: "View it on remote" | ||||
|   error: | ||||
|     title: 'Something happened :(' | ||||
|     retry: 'Retry' | ||||
|   reversi: | ||||
|     drawn: "Draw" | ||||
|     my-turn: "Your turn" | ||||
| @@ -170,6 +185,8 @@ common: | ||||
|     rename: "Rename" | ||||
|     stack-left: "Stack to the left" | ||||
|     pop-right: "Dock on the right" | ||||
|   dev: "Failed to create the application. Please try again." | ||||
|   ai-chan-kawaii: "Ai-chan kawaii!" | ||||
| auth/views/form.vue: | ||||
|   share-access: "Would you <b>allow</b> <i>{{ app.name }}</i> to access your account?" | ||||
|   permission-ask: "This application requires the following permissions:" | ||||
| @@ -233,7 +250,7 @@ common/views/components/games/reversi/reversi.room.vue: | ||||
|   this-game-is-started-soon: "The game will begin in seconds" | ||||
|   waiting-for-other: "Waiting for the opponent" | ||||
|   waiting-for-me: "Waiting for the your preparation" | ||||
|   waiting-for-both: "Prepareing" | ||||
|   waiting-for-both: "Preparing" | ||||
|   cancel: "Cancel" | ||||
|   ready: "Ready" | ||||
|   cancel-ready: "Cancel \"Ready\"" | ||||
| @@ -265,40 +282,40 @@ common/views/components/media-banner.vue: | ||||
|   sensitive: "NSFW" | ||||
|   click-to-show: "Click to show" | ||||
| common/views/components/theme.vue: | ||||
|   light-theme: "非ダークモード時に使用するテーマ" | ||||
|   dark-theme: "ダークモード時に使用するテーマ" | ||||
|   light-themes: "明るいテーマ" | ||||
|   dark-themes: "暗いテーマ" | ||||
|   install-a-theme: "テーマのインストール" | ||||
|   theme-code: "テーマコード" | ||||
|   install: "インストール" | ||||
|   installed: "「{}」をインストールしました" | ||||
|   create-a-theme: "テーマの作成" | ||||
|   save-created-theme: "テーマを保存" | ||||
|   primary-color: "プライマリ カラー" | ||||
|   secondary-color: "セカンダリ カラー" | ||||
|   text-color: "文字色" | ||||
|   base-theme: "ベーステーマ" | ||||
|   light-theme: "Theme" | ||||
|   dark-theme: "Theme during dark mode" | ||||
|   light-themes: "Light theme" | ||||
|   dark-themes: "Dark theme" | ||||
|   install-a-theme: "Install a theme" | ||||
|   theme-code: "Theme code" | ||||
|   install: "Install" | ||||
|   installed: "\"{}\" has been installed" | ||||
|   create-a-theme: "Create a theme" | ||||
|   save-created-theme: "Save a theme" | ||||
|   primary-color: "Primary color" | ||||
|   secondary-color: "Secondary color" | ||||
|   text-color: "Text color" | ||||
|   base-theme: "Base theme" | ||||
|   base-theme-light: "Light" | ||||
|   base-theme-dark: "Dark" | ||||
|   theme-name: "テーマ名" | ||||
|   preview-created-theme: "プレビュー" | ||||
|   invalid-theme: "テーマが正しくありません。" | ||||
|   already-installed: "既にそのテーマはインストールされています。" | ||||
|   saved: "保存しました" | ||||
|   manage-themes: "テーマの管理" | ||||
|   builtin-themes: "標準テーマ" | ||||
|   my-themes: "マイテーマ" | ||||
|   installed-themes: "インストールされたテーマ" | ||||
|   select-theme: "テーマを選択してください" | ||||
|   uninstall: "アンインストール" | ||||
|   uninstalled: "「{}」をアンインストールしました" | ||||
|   author: "作者" | ||||
|   desc: "説明" | ||||
|   export: "エクスポート" | ||||
|   import: "インポート" | ||||
|   import-by-code: "またはコードをペースト" | ||||
|   theme-name-required: "テーマ名は必須です。" | ||||
|   theme-name: "Theme name" | ||||
|   preview-created-theme: "Preview" | ||||
|   invalid-theme: "Not valid theme" | ||||
|   already-installed: "This theme is already installed." | ||||
|   saved: "Saved" | ||||
|   manage-themes: "Themes manager" | ||||
|   builtin-themes: "Standard themes" | ||||
|   my-themes: "My themes" | ||||
|   installed-themes: "Installed themes" | ||||
|   select-theme: "Select your theme" | ||||
|   uninstall: "Uninstall" | ||||
|   uninstalled: "\"{}\" has been uninstalled" | ||||
|   author: "Author" | ||||
|   desc: "Description" | ||||
|   export: "Export" | ||||
|   import: "Import" | ||||
|   import-by-code: "or paste code" | ||||
|   theme-name-required: "Theme name is required" | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "Hide" | ||||
|   show: "See more" | ||||
| @@ -335,8 +352,9 @@ common/views/components/note-menu.vue: | ||||
|   detail: "Details" | ||||
|   copy-link: "Copy link" | ||||
|   favorite: "Favorite this note" | ||||
|   unfavorite: "Unfavorite" | ||||
|   pin: "Pin to your profile" | ||||
|   unpin: "ピン留め解除" | ||||
|   unpin: "Unpin" | ||||
|   delete: "Delete" | ||||
|   delete-confirm: "Delete this post?" | ||||
|   remote: "Show original note" | ||||
| @@ -415,6 +433,25 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{} users mentioned" | ||||
|   empty: "No popular hashtag trends" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "Profile" | ||||
|   name: "Name" | ||||
|   account: "Account" | ||||
|   location: "Location" | ||||
|   description: "About me" | ||||
|   birthday: "Birthday" | ||||
|   avatar: "Avatar" | ||||
|   banner: "Banner" | ||||
|   is-cat: "This account is a Cat" | ||||
|   is-bot: "This account is a Bot" | ||||
|   is-locked: "Follower requests require approval" | ||||
|   careful-bot: "Follower requests from bots require approval" | ||||
|   advanced: "Advanced" | ||||
|   privacy: "Privacy" | ||||
|   save: "Update profile" | ||||
|   saved: "Profile updated successfully" | ||||
|   uploading: "Uploading" | ||||
|   upload-failed: "Failed to upload" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "Fetching" | ||||
|   no-broadcasts: "No announcements" | ||||
| @@ -462,7 +499,7 @@ common/views/widgets/tips.vue: | ||||
|   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-line14: "While customizing your home layout, you can right click on a widget to change its design." | ||||
|   tips-line17: "Surrounding the text with ** ** will highlight it." | ||||
|   tips-line19: "Several windows can be detached outside the browser." | ||||
|   tips-line20: "The percentage of the calendar widget shows the percentage of time elapsed." | ||||
| @@ -506,21 +543,24 @@ desktop/views/components/charts.vue: | ||||
|   title: "Charts" | ||||
|   per-day: "per Day" | ||||
|   per-hour: "per Hour" | ||||
|   federation: "Federation" | ||||
|   notes: "Posts" | ||||
|   users: "Users" | ||||
|   drive: "Drive" | ||||
|   network: "Network" | ||||
|   charts: | ||||
|     federation-instances: "The number of instances: increase/decrease" | ||||
|     federation-instances-total: "Total number of instances" | ||||
|     notes: "The number of posts: increase/decrease (Combined)" | ||||
|     local-notes: "The number of posts: increase/decrease (Local)" | ||||
|     remote-notes: "The number of posts: increase/decrease (Remote)" | ||||
|     notes-total: "投稿の積算" | ||||
|     notes-total: "Total posts" | ||||
|     users: "The number of users: increase/decrease" | ||||
|     users-total: "ユーザーの積算" | ||||
|     users-total: "Total users" | ||||
|     drive: "Capacity used as the storage: increase/decrease" | ||||
|     drive-total: "ドライブ使用量の積算" | ||||
|     drive-total: "Total usage of Drive" | ||||
|     drive-files: "The number of files on the storage: increase/decrease" | ||||
|     drive-files-total: "ドライブのファイル数の積算" | ||||
|     drive-files-total: "Total number of files on Drive" | ||||
|     network-requests: "Requests" | ||||
|     network-time: "Response time" | ||||
|     network-usage: "Traffic" | ||||
| @@ -540,7 +580,6 @@ desktop/views/components/crop-window.vue: | ||||
|   ok: "OK" | ||||
| desktop/views/components/drive-window.vue: | ||||
|   used: "used" | ||||
|   drive: "Media storage" | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "Avatar" | ||||
|   banner: "Banner" | ||||
| @@ -570,8 +609,6 @@ desktop/views/components/drive.folder.vue: | ||||
|     rename: "Rename" | ||||
|     rename-folder: "Rename folder" | ||||
|     input-new-folder-name: "Enter new name" | ||||
| desktop/views/components/drive.nav-folder.vue: | ||||
|   drive: "Media storage" | ||||
| desktop/views/components/drive.vue: | ||||
|   search: "Search" | ||||
|   load-more: "Load more" | ||||
| @@ -639,14 +676,14 @@ desktop/views/components/note-detail.vue: | ||||
|   location: "Location" | ||||
|   renote: "Repost" | ||||
|   add-reaction: "Add a reaction" | ||||
| desktop/views/components/notes.note.vue: | ||||
| desktop/views/components/note.vue: | ||||
|   reposted-by: "Reposted by {}" | ||||
|   reply: "Reply" | ||||
|   renote: "Repost" | ||||
|   renote: "Renote" | ||||
|   add-reaction: "Add a reaction" | ||||
|   detail: "Show details" | ||||
|   private: "Post is private" | ||||
|   deleted: "Post has been deleted" | ||||
|   detail: "Details" | ||||
|   private: "This post is private" | ||||
|   deleted: "This post has been deleted" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "Loading failed." | ||||
|   retry: "Retry" | ||||
| @@ -705,8 +742,8 @@ desktop/views/components/settings.vue: | ||||
|   profile: "Profile" | ||||
|   notification: "Notification" | ||||
|   apps: "Apps" | ||||
|   mute: "Mute" | ||||
|   drive: "Drive" | ||||
|   mute-and-block: "Mute / Block" | ||||
|   blocking: "Blocking" | ||||
|   security: "Security" | ||||
|   signin: "Sign in history" | ||||
|   password: "Password" | ||||
| @@ -725,30 +762,36 @@ desktop/views/components/settings.vue: | ||||
|   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." | ||||
|   deck-nav: "Transitionless deck navigation" | ||||
|   deck-nav-desc: "You get a temporary column without page transitions during navigation when using the deck." | ||||
|   deck-default: "Use Deck as default UI" | ||||
|   display: "Design and display" | ||||
|   customize: "Customize home layout" | ||||
|   wallpaper: "Wallpaper" | ||||
|   choose-wallpaper: "Choose a background" | ||||
|   delete-wallpaper: "Remove background" | ||||
|   dark-mode: "Dark Mode" | ||||
|   use-shadow: "UIに影を使用" | ||||
|   rounded-corners: "UIの角を丸める" | ||||
|   use-shadow: "Use shadows in the UI" | ||||
|   rounded-corners: "Round corners of UI" | ||||
|   circle-icons: "Use circle icons" | ||||
|   contrasted-acct: "Add contrast to username" | ||||
|   post-form-on-timeline: "Display post form at the top of the timeline" | ||||
|   suggest-recent-hashtags: "Show recent popular hashtags on the post form" | ||||
|   show-clock-on-header: "Show clock on upper-right" | ||||
|   show-reply-target: "Display reply target" | ||||
|   timeline: "Timeline" | ||||
|   show-my-renotes: "Show my renotes in the timeline" | ||||
|   show-renoted-my-notes: "Show renoted my posts in timelines" | ||||
|   show-renoted-my-notes: "Show renoted posts of mine in timelines" | ||||
|   show-local-renotes: "Show renoted local posts in timelines" | ||||
|   show-maps: "Display a map to show the location" | ||||
|   deck-column-align: "Deck column alignment" | ||||
|   deck-column-align-center: "Center" | ||||
|   deck-column-align-left: "Left" | ||||
|   sound: "Sound" | ||||
|   enable-sounds: "Enable sound" | ||||
|   enable-sounds-desc: "Play a sound when you receive a post/message. This setting is stored in the browser." | ||||
|   volume: "Volume" | ||||
|   test: "Test" | ||||
|   mobile: "Mobile" | ||||
|   disable-via-mobile: "Don't mark the post as 'from mobile'" | ||||
|   language: "Language" | ||||
|   pick-language: "Select a language" | ||||
|   recommended: "Recommended" | ||||
| @@ -784,6 +827,10 @@ desktop/views/components/settings.vue: | ||||
|   tools: "Tools" | ||||
|   task-manager: "Task Manager" | ||||
|   third-parties: "Third-parties" | ||||
|   navbar-position: "Navigation bar position" | ||||
|   navbar-position-top: "Top" | ||||
|   navbar-position-left: "Left" | ||||
|   navbar-position-right: "Right" | ||||
| desktop/views/components/settings.2fa.vue: | ||||
|   intro: "If you set up 2-step verification, you will not only need a password at sign-in, but also a pre-registered physical device (such as your smartphone), which will improve security." | ||||
|   detail: "Details…" | ||||
| @@ -802,41 +849,39 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "Settings saved!" | ||||
|   failed: "Failed to setup. Please ensure that the token is correct." | ||||
|   info: "From the next time you sign in to Misskey, the token displayed on your device will be necessary too, as well as the password." | ||||
| desktop/views/components/settings.api.vue: | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "To access the API, set this token as the key 'i' of request parameters." | ||||
|   caution: "Do not enter this token to any apps nor tell this token to others otherwise your account may get compromised." | ||||
|   regeneration-of-token: "If your token gets leaked, you can regenerate it." | ||||
|   regenerate-token: "Regenerate the token" | ||||
|   token: "Token:" | ||||
|   enter-password: "Please enter the password" | ||||
|   enter-password: "Enter the password" | ||||
|   console: | ||||
|     title: 'API console' | ||||
|     endpoint: 'Endpoint' | ||||
|     parameter: 'Parameters' | ||||
|     send: 'Send' | ||||
|     sending: 'Sending' | ||||
|     response: 'Result' | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "No linked applications" | ||||
| desktop/views/components/settings.drive.vue: | ||||
| common/views/components/drive-settings.vue: | ||||
|   max: "Max" | ||||
|   in-use: "In use" | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "No muted users" | ||||
| desktop/views/components/settings.password.vue: | ||||
|   stats: "Statistics" | ||||
| common/views/components/mute-and-block.vue: | ||||
|   mute-and-block: "Mute / Block" | ||||
|   mute: "Mute" | ||||
|   block: "Blocking" | ||||
|   no-muted-users: "No muted users" | ||||
|   no-blocked-users: "No blocked users" | ||||
| common/views/components/password-settings.vue: | ||||
|   reset: "Change password" | ||||
|   enter-current-password: "Enter the current password" | ||||
|   enter-new-password: "Enter the new password" | ||||
|   enter-new-password-again: "Enter new password again" | ||||
|   enter-new-password-again: "Enter the new password again" | ||||
|   not-match: "The new passwords do not match" | ||||
|   changed: "Password updated" | ||||
| desktop/views/components/settings.profile.vue: | ||||
|   avatar: "Avatar" | ||||
|   choice-avatar: "Select an image" | ||||
|   name: "Name" | ||||
|   location: "Location" | ||||
|   description: "Description" | ||||
|   birthday: "Birthday" | ||||
|   save: "Update profile" | ||||
|   locked-account: "Protect your account" | ||||
|   is-locked: "Follow request needs approval" | ||||
|   other: "Other" | ||||
|   is-bot: "This account is a Bot" | ||||
|   is-cat: "This account is a Cat" | ||||
|   profile-updated: "Your profile has been updated" | ||||
|   changed: "Password changed" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "This post is private" | ||||
|   deleted: "This post has been deleted" | ||||
| @@ -861,7 +906,6 @@ desktop/views/components/ui.header.vue: | ||||
|   adjective: "-san" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "Your profile" | ||||
|   drive: "Media storage" | ||||
|   favorites: "Favorites" | ||||
|   lists: "Lists" | ||||
|   follow-requests: "Follow requests" | ||||
| @@ -869,7 +913,7 @@ desktop/views/components/ui.header.account.vue: | ||||
|   admin: "Admin" | ||||
|   settings: "Settings" | ||||
|   signout: "Sign out" | ||||
|   dark: "Submerge in dark" | ||||
|   dark: "Toggle dark mode" | ||||
| desktop/views/components/ui.header.nav.vue: | ||||
|   home: "Home" | ||||
|   deck: "Deck" | ||||
| @@ -903,42 +947,100 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "Pop-out" | ||||
|   close: "Close" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
| admin/views/index.vue: | ||||
|   dashboard: "Dashboard" | ||||
|   drive: "Drive" | ||||
|   instance: "Instance" | ||||
|   emoji: "Emoji" | ||||
|   users: "Users" | ||||
|   update: "Updates" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   update: "Update" | ||||
|   announcements: "Announcements" | ||||
|   hashtags: "Hashtags" | ||||
|   back-to-misskey: "Back to Misskey" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "Dashboard" | ||||
|   all-users: "All Users" | ||||
|   original-users: "Users on this instance" | ||||
|   all-notes: "All the posts" | ||||
|   original-notes: "Posts on this instance" | ||||
|   accounts: "Accounts" | ||||
|   notes: "Notes" | ||||
|   drive: "Drive" | ||||
|   instances: "Instances" | ||||
|   this-instance: "This instance" | ||||
|   federated: "Federated" | ||||
|   invite: "Invite" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   banner-url: "Banner URL" | ||||
|   disableRegistration: "Disable new user registration" | ||||
|   disableLocalTimeline: "Disable the local timeline" | ||||
| admin/views/charts.vue: | ||||
|   title: "Chart" | ||||
|   per-day: "per Day" | ||||
|   per-hour: "per Hour" | ||||
|   federation: "Federation" | ||||
|   notes: "Posts" | ||||
|   users: "Users" | ||||
|   drive: "Drive" | ||||
|   network: "Network" | ||||
|   charts: | ||||
|     federation-instances: "The number of instances: increase/decrease" | ||||
|     federation-instances-total: "Total number of instances" | ||||
|     notes: "The number of posts: increase/decrease (Combined)" | ||||
|     local-notes: "The number of posts: increase/decrease (Local)" | ||||
|     remote-notes: "The number of posts: increase/decrease (Remote)" | ||||
|     notes-total: "Total posts" | ||||
|     users: "The number of users: increase/decrease" | ||||
|     users-total: "Total users" | ||||
|     drive: "Capacity used as the storage: increase/decrease" | ||||
|     drive-total: "Total usage of Drive" | ||||
|     drive-files: "The number of files on the storage: increase/decrease" | ||||
|     drive-files-total: "Total number of files on Drive" | ||||
|     network-requests: "Requests" | ||||
|     network-time: "Response time" | ||||
|     network-usage: "Traffic" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "Suspend a user" | ||||
|   suspend: "Suspend" | ||||
|   suspended: "Successfully suspended." | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "Unsuspend users" | ||||
|   unsuspend: "Unsuspend" | ||||
|   unsuspended: "The user has successfully unsuspended." | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "User account verification settings" | ||||
|   verify: "Verify account" | ||||
|   verified: "The account is now being verified" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "User account unverification settings" | ||||
|   unverify: "Unverify account" | ||||
|   unverified: "The account is now being unverified" | ||||
| admin/views/emoji.vue: | ||||
|   add-emoji: | ||||
|     title: "Add emoji" | ||||
|     name: "Emoji name" | ||||
|     name-desc: "You can use the characters a~z 0~9 _" | ||||
|     aliases: "Aliases" | ||||
|     aliases-desc: "You can add more than one, separated by spaces." | ||||
|     url: "Image URL" | ||||
|     add: "Add" | ||||
|   emojis: | ||||
|     title: "Emojis" | ||||
|     update: "Update" | ||||
|     remove: "Remove" | ||||
| admin/views/announcements.vue: | ||||
|   announcements: "Announcements" | ||||
|   save: "Save" | ||||
|   remove: "Remove" | ||||
|   add: "Add" | ||||
|   title: "Title" | ||||
|   text: "Content" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| 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" | ||||
| desktop/views/pages/deck/deck.user-column.vue: | ||||
|   posts: "Posts" | ||||
|   following: "Following" | ||||
|   followers: "Followers" | ||||
|   images: "Images" | ||||
|   activity: "Activity" | ||||
|   timeline: "Timeline" | ||||
|   pinned-notes: "Pinned posts" | ||||
|   push-to-a-list: "Add to list" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "All Users" | ||||
|   original-users: "Users on this instance" | ||||
| @@ -953,7 +1055,7 @@ desktop/views/pages/welcome.vue: | ||||
|   signup-button: "Sign up" | ||||
|   timeline: "Timeline" | ||||
|   announcements: "Announcements" | ||||
|   photos: "Recent uploaded" | ||||
|   photos: "Recent Images" | ||||
|   powered-by-misskey: "Powered by <b>Misskey</b>." | ||||
|   info: "Information" | ||||
| desktop/views/pages/drive.vue: | ||||
| @@ -991,10 +1093,7 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   no-users: "No frequent mentions" | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "This account has been suspended." | ||||
|   is-remote: "This profile belongs to a remote user. The profile that you see here may not be complete. " | ||||
|   view-remote: "See their complete profile" | ||||
| desktop/views/pages/user/user.home.vue: | ||||
|   last-used-at: "Last active:" | ||||
|   last-used-at: "Last active" | ||||
| desktop/views/pages/user/user.photos.vue: | ||||
|   title: "Photos" | ||||
|   loading: "Loading" | ||||
| @@ -1007,6 +1106,9 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "Mute" | ||||
|   muted: "Muting" | ||||
|   unmute: "Unmute" | ||||
|   block: "Block" | ||||
|   unblock: "Unblock" | ||||
|   block-confirm: "Are you sure block this user?" | ||||
|   push-to-a-list: "Add to list" | ||||
|   list-pushed: "Successfully added {user} to {list}." | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| @@ -1014,6 +1116,10 @@ desktop/views/pages/user/user.header.vue: | ||||
|   following: "Following" | ||||
|   followers: "Followers" | ||||
|   is-bot: "This account is a Bot" | ||||
|   years-old: " years old" | ||||
|   year: "/" | ||||
|   month: "/" | ||||
|   day: "-" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "Posts" | ||||
|   with-replies: "Posts and replies" | ||||
| @@ -1043,7 +1149,6 @@ desktop/views/widgets/users.vue: | ||||
|   refresh: "refresh" | ||||
|   no-one: "Anyone!" | ||||
| mobile/views/components/drive.vue: | ||||
|   drive: "Media storage" | ||||
|   used: "used" | ||||
|   folder-count: "Folder(s)" | ||||
|   count-separator: ", " | ||||
| @@ -1073,6 +1178,8 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   hash: "Hash (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "NSFW" | ||||
|   mark-as-sensitive: "Mark as 'sensitive'" | ||||
|   unmark-as-sensitive: "Unmark as 'sensitive'" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "NSFW" | ||||
|   click-to-show: "Click to show" | ||||
| @@ -1145,7 +1252,6 @@ mobile/views/components/ui.nav.vue: | ||||
|   messaging: "Messages" | ||||
|   follow-requests: "Follow requests" | ||||
|   search: "Search" | ||||
|   drive: "Drive" | ||||
|   favorites: "Favorites" | ||||
|   user-lists: "Lists" | ||||
|   widgets: "Widgets" | ||||
| @@ -1156,11 +1262,11 @@ mobile/views/components/ui.nav.vue: | ||||
|   about: "About Misskey" | ||||
| mobile/views/components/user-timeline.vue: | ||||
|   no-notes: "It seems this user hasn't posted anything yet." | ||||
|   no-notes-with-media: "There are no posts attaching media" | ||||
|   no-notes-with-media: "There are no notes with media attachments" | ||||
|   load-more: "More" | ||||
| mobile/views/components/users-list.vue: | ||||
|   all: "All" | ||||
|   known: "You know" | ||||
|   known: "In common" | ||||
|   load-more: "More" | ||||
| mobile/views/pages/favorites.vue: | ||||
|   title: "Favorites" | ||||
| @@ -1168,7 +1274,6 @@ mobile/views/pages/user-lists.vue: | ||||
|   title: "Lists" | ||||
|   enter-list-name: "Enter a name of the list to make" | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "Drive" | ||||
|   more: "Load more" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "Your account is now ready! 📦" | ||||
| @@ -1213,23 +1318,6 @@ mobile/views/pages/notifications.vue: | ||||
|   read-all: "Do you wish to mark all notifications as read?" | ||||
| mobile/views/pages/games/reversi.vue: | ||||
|   reversi: "Reversi" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "Profile" | ||||
|   name: "Name" | ||||
|   account: "Account" | ||||
|   location: "Location" | ||||
|   description: "Biography" | ||||
|   birthday: "Birthday" | ||||
|   avatar: "Avatar" | ||||
|   banner: "Banner" | ||||
|   is-cat: "This account is a Cat" | ||||
|   is-locked: "Follow request needs approval" | ||||
|   advanced: "Advanced" | ||||
|   privacy: "Privacy" | ||||
|   save: "Update profile" | ||||
|   saved: "Profile updated" | ||||
|   uploading: "Uploading" | ||||
|   upload-failed: "Failed to upload" | ||||
| mobile/views/pages/search.vue: | ||||
|   search: "Search" | ||||
|   empty: "No posts were found for '{}'" | ||||
| @@ -1251,7 +1339,7 @@ mobile/views/pages/settings.vue: | ||||
|   timeline: "Timeline" | ||||
|   show-reply-target: "Show reply target" | ||||
|   show-my-renotes: "Show my reposts" | ||||
|   show-renoted-my-notes: "Show renoted my posts" | ||||
|   show-renoted-my-notes: "Show renoted posts of mine" | ||||
|   show-local-renotes: "Show renoted local posts" | ||||
|   post-style: "Post design" | ||||
|   post-style-standard: "Standard" | ||||
| @@ -1285,6 +1373,8 @@ mobile/views/pages/settings.vue: | ||||
|   signout: "Sign out" | ||||
|   sound: "Sounds" | ||||
|   enable-sounds: "Enable sounds" | ||||
|   mark-as-read-all-unread-notes: "Mark all posts as read" | ||||
|   password: "Password" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "Follows you" | ||||
|   following: "Following" | ||||
| @@ -1294,8 +1384,10 @@ mobile/views/pages/user.vue: | ||||
|   timeline: "Timeline" | ||||
|   media: "Media" | ||||
|   is-suspended: "This account has been suspended." | ||||
|   is-remote: "The user is a remote user. The profile that you see here may not complete." | ||||
|   view-remote: "See his/her complete profile" | ||||
|   mute: "Mute" | ||||
|   unmute: "Unmute" | ||||
|   block: "Block" | ||||
|   unblock: "Unblock" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "Recent notes" | ||||
|   images: "Images" | ||||
| @@ -1341,3 +1433,29 @@ docs: | ||||
|       description: "Description" | ||||
| dev/views/index.vue: | ||||
|   manage-apps: "Manage apps" | ||||
| dev/views/apps.vue: | ||||
|   manage-apps: "Manage apps" | ||||
|   create-app: "Create app" | ||||
|   app-missing: "No apps" | ||||
| dev/views/new-app.vue: | ||||
|   create-app: "Creating application" | ||||
|   app-name: "Application name" | ||||
|   app-name-desc: "The name of your app" | ||||
|   app-name-ex: "ex) Misskey for iOS" | ||||
|   app-overview: "Application summary" | ||||
|   app-desc: "A brief description or introduction of your app." | ||||
|   app-desc-ex: "ex) Misskey iOS client." | ||||
|   callback-url: "The callback URL (optional)" | ||||
|   callback-url-desc: "The URL to redirect to after the user is authenticated via the authentication form." | ||||
|   authority: "Permissions" | ||||
|   authority-desc: "Only the functions requested here can be accessed via the API." | ||||
|   authority-warning: "You can change it even after creating the application, but if you give different permissions, all user keys associated at that time will be invalidated." | ||||
|   account-read: "View account information." | ||||
|   account-write: "Modify account information." | ||||
|   note-write: "Post." | ||||
|   reaction-write: "Add or remove reactions." | ||||
|   following-write: "Follow and unfollow." | ||||
|   drive-read: "Read the drive." | ||||
|   drive-write: "Upload/delete files in the drive." | ||||
|   notification-read: "Read your notifications." | ||||
|   notification-write: "Manage your notifications." | ||||
|   | ||||
| @@ -25,6 +25,14 @@ common: | ||||
|   application-authorization: "Autorizaciones de la aplicación." | ||||
|   close: "Cerrar" | ||||
|   do-not-copy-paste: "Por favor no copies código aquí. Tu cuenta puede resultar comprometida." | ||||
|   BSoD: | ||||
|     fatal-error: ":( 致命的な問題が発生しました。" | ||||
|     update-browser-os: "お使いのブラウザ(またはOS)のバージョンを更新すると解決する可能性があります。" | ||||
|     error-code: "エラーコード" | ||||
|     browser-version: "ブラウザ バージョン" | ||||
|     client-version: "クライアント バージョン" | ||||
|     email-support: "問題が解決しない場合は、上記の情報をお書き添えの上 syuilotan@yahoo.co.jp までご連絡ください。" | ||||
|     thanks: "Thank you for using Misskey." | ||||
|   got-it: "¡Listo!" | ||||
|   customization-tips: | ||||
|     title: "Consejos de personalización" | ||||
| @@ -54,6 +62,7 @@ common: | ||||
|     years_ago: "Hace {} año(s)" | ||||
|   month-and-day: "{day} de {month}" | ||||
|   trash: "Papelera" | ||||
|   drive: "ドライブ" | ||||
|   weekday-short: | ||||
|     sunday: "domingo" | ||||
|     monday: "lunes" | ||||
| @@ -115,6 +124,12 @@ common: | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   do-not-use-in-production: 'Esto está en desarrollo, no usarlo para producción.' | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|   error: | ||||
|     title: '問題が発生しました' | ||||
|     retry: 'やり直す' | ||||
|   reversi: | ||||
|     drawn: "Empatado" | ||||
|     my-turn: "Mi turno" | ||||
| @@ -170,6 +185,8 @@ common: | ||||
|     rename: "Renombrar" | ||||
|     stack-left: "A la izqda." | ||||
|     pop-right: "A la dcha." | ||||
|   dev: "アプリの作成に失敗しました。再度お試しください。" | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
| auth/views/form.vue: | ||||
|   share-access: "¿Deseas <b>permitir</b> a <i>{{ app.name }}</i> acceder a tu cuenta?" | ||||
|   permission-ask: "La aplicación requiere los siguientes permisos:" | ||||
| @@ -335,6 +352,7 @@ common/views/components/note-menu.vue: | ||||
|   detail: "Detalles" | ||||
|   copy-link: "Copiar enlace" | ||||
|   favorite: "Me gusta esta nota" | ||||
|   unfavorite: "お気に入り解除" | ||||
|   pin: "Fijar en el perfil" | ||||
|   unpin: "ピン留め解除" | ||||
|   delete: "Borrar" | ||||
| @@ -415,6 +433,25 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   careful-bot: "Botからのフォローだけ承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "Recuperando" | ||||
|   no-broadcasts: "Sin emisión" | ||||
| @@ -506,11 +543,14 @@ desktop/views/components/charts.vue: | ||||
|   title: "Gráficos" | ||||
|   per-day: "por día" | ||||
|   per-hour: "por hora" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "Publicaciones" | ||||
|   users: "Usuarios" | ||||
|   drive: "Unidad" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "Número de publicaciones: aumentar/disminuir (Combinado)" | ||||
|     local-notes: "Número de publicaciones: aumentar/disminuir (Local)" | ||||
|     remote-notes: "Número de publicaciones: aumentar/disminuir (Remoto)" | ||||
| @@ -540,7 +580,6 @@ desktop/views/components/crop-window.vue: | ||||
|   ok: "OK" | ||||
| desktop/views/components/drive-window.vue: | ||||
|   used: "usado" | ||||
|   drive: "Disco" | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "Avatar" | ||||
|   banner: "Banner" | ||||
| @@ -570,8 +609,6 @@ desktop/views/components/drive.folder.vue: | ||||
|     rename: "Renombrar" | ||||
|     rename-folder: "Renombrar carpeta" | ||||
|     input-new-folder-name: "Escribe el nombre nuevo" | ||||
| desktop/views/components/drive.nav-folder.vue: | ||||
|   drive: "Disco" | ||||
| desktop/views/components/drive.vue: | ||||
|   search: "Buscar" | ||||
|   load-more: "Cargar más" | ||||
| @@ -639,14 +676,14 @@ desktop/views/components/note-detail.vue: | ||||
|   location: "Localización" | ||||
|   renote: "Republicar" | ||||
|   add-reaction: "Agregar una reacción" | ||||
| desktop/views/components/notes.note.vue: | ||||
|   reposted-by: "Republicado por {}" | ||||
|   reply: "Responder" | ||||
|   renote: "Republicar" | ||||
|   add-reaction: "Agregar una reacción" | ||||
|   detail: "Mostrar detalles" | ||||
|   private: "Esta publicación es privada" | ||||
|   deleted: "Esta publicación ha sido borrada" | ||||
| desktop/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   reply: "返信" | ||||
|   renote: "Renote" | ||||
|   add-reaction: "リアクション" | ||||
|   detail: "詳細" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "Error al cargar." | ||||
|   retry: "Reintentar" | ||||
| @@ -705,8 +742,8 @@ desktop/views/components/settings.vue: | ||||
|   profile: "Perfil" | ||||
|   notification: "Notificación" | ||||
|   apps: "Aplicaciones" | ||||
|   mute: "Silenciar" | ||||
|   drive: "Disco" | ||||
|   mute-and-block: "ミュート/ブロック" | ||||
|   blocking: "ブロック" | ||||
|   security: "Seguridad" | ||||
|   signin: "Historial de inicios de sesión" | ||||
|   password: "Contraseña" | ||||
| @@ -725,8 +762,12 @@ desktop/views/components/settings.vue: | ||||
|   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." | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "Diseño y pantalla" | ||||
|   customize: "Personaliza la página principal" | ||||
|   wallpaper: "壁紙" | ||||
|   choose-wallpaper: "Elije un fondo" | ||||
|   delete-wallpaper: "Suprimir fondo" | ||||
|   dark-mode: "Modo Nocturno" | ||||
| @@ -738,17 +779,19 @@ desktop/views/components/settings.vue: | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   timeline: "タイムライン" | ||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||
|   volume: "ボリューム" | ||||
|   test: "テスト" | ||||
|   mobile: "モバイル" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   language: "言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
| @@ -784,6 +827,10 @@ desktop/views/components/settings.vue: | ||||
|   tools: "Herramientas" | ||||
|   task-manager: "Navegador de tareas" | ||||
|   third-parties: "Servicios externos" | ||||
|   navbar-position: "ナビゲーションバーの位置" | ||||
|   navbar-position-top: "上" | ||||
|   navbar-position-left: "左" | ||||
|   navbar-position-right: "右" | ||||
| desktop/views/components/settings.2fa.vue: | ||||
|   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" | ||||
|   detail: "Ver detalles..." | ||||
| @@ -802,41 +849,39 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "¡Configuraciones guardadas!" | ||||
|   failed: "Error al configurar. Por favor asegúrate de que el token es correcto." | ||||
|   info: "Desde ahora, ingresa el token que se muestra en tu dispositivo adicionalmente a tu contraseña cuando inicies sesión en Misskey" | ||||
| desktop/views/components/settings.api.vue: | ||||
|   intro: "Para acceder al API, configura este token como la letra \"i\" de los parámetros requeridos." | ||||
|   caution: "Por favor no muestres este token a otros (no lo ingreses en otro lugar que no sea aquí). De otra forma, tu cuenta puede llegar a ser comprometida." | ||||
|   regeneration-of-token: "En el caso no deseado de que este token lo tenga otra persona, puedes regenerarlo." | ||||
|   regenerate-token: "Regenerar el token" | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
|   regeneration-of-token: "万が一このトークンが漏れたりその可能性がある場合はトークンを再生成できます。" | ||||
|   regenerate-token: "トークンを再生成" | ||||
|   token: "Token:" | ||||
|   enter-password: "Por favor ingresa tu contraseña" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   console: | ||||
|     title: 'APIコンソール' | ||||
|     endpoint: 'エンドポイント' | ||||
|     parameter: 'パラメータ' | ||||
|     send: '送信' | ||||
|     sending: '応答待ち' | ||||
|     response: '結果' | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "No hay aplicaciones asociadas" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "Max" | ||||
|   in-use: "en uso." | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "No hay usuarios silenciados" | ||||
| desktop/views/components/settings.password.vue: | ||||
|   reset: "Cambiar contraseña" | ||||
|   enter-current-password: "Ingresar contraseña actual" | ||||
|   enter-new-password: "Ingresar nueva contraseña" | ||||
|   enter-new-password-again: "Ingresar nueva contraseña de nuevo" | ||||
|   not-match: "Las nuevas contraseñas no se corresponden consigo mismas" | ||||
|   changed: "Contraseña actualizada" | ||||
| desktop/views/components/settings.profile.vue: | ||||
|   avatar: "Avatar" | ||||
|   choice-avatar: "Escoger una imagen" | ||||
|   name: "Nombre" | ||||
|   location: "Localización" | ||||
|   description: "Descripción" | ||||
|   birthday: "Fecha de nacimiento" | ||||
|   save: "Perfil actualizado" | ||||
|   locked-account: "Protege tu cuenta" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   profile-updated: "プロフィールを更新しました" | ||||
| common/views/components/drive-settings.vue: | ||||
|   max: "容量" | ||||
|   in-use: "使用中" | ||||
|   stats: "統計" | ||||
| common/views/components/mute-and-block.vue: | ||||
|   mute-and-block: "ミュートとブロック" | ||||
|   mute: "ミュート" | ||||
|   block: "ブロック" | ||||
|   no-muted-users: "ミュートしているユーザーはいません" | ||||
|   no-blocked-users: "ブロックしているユーザーはいません" | ||||
| common/views/components/password-settings.vue: | ||||
|   reset: "パスワードを変更する" | ||||
|   enter-current-password: "現在のパスワードを入力してください" | ||||
|   enter-new-password: "新しいパスワードを入力してください" | ||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||
|   not-match: "新しいパスワードが一致しません" | ||||
|   changed: "パスワードを変更しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| @@ -861,7 +906,6 @@ desktop/views/components/ui.header.vue: | ||||
|   adjective: "-san" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "Tu perfil" | ||||
|   drive: "Unidad" | ||||
|   favorites: "Favoritos" | ||||
|   lists: "Listas" | ||||
|   follow-requests: "Solicitudes de seguimiento" | ||||
| @@ -903,42 +947,100 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
| admin/views/index.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "ドライブ" | ||||
|   instance: "インスタンス" | ||||
|   emoji: "カスタム絵文字" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   announcements: "お知らせ" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   accounts: "アカウント" | ||||
|   notes: "投稿" | ||||
|   drive: "ドライブ" | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "このインスタンス" | ||||
|   federated: "連合" | ||||
|   invite: "招待" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   banner-url: "Banner URL" | ||||
|   disableRegistration: "Disable new user registration" | ||||
|   disableLocalTimeline: "Disable the local timeline" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の積算" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の積算" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| admin/views/emoji.vue: | ||||
|   add-emoji: | ||||
|     title: "絵文字の登録" | ||||
|     name: "絵文字名" | ||||
|     name-desc: "a~z 0~9 _ の文字が使えます。" | ||||
|     aliases: "エイリアス" | ||||
|     aliases-desc: "スペースで区切って複数設定できます。" | ||||
|     url: "絵文字画像URL" | ||||
|     add: "追加" | ||||
|   emojis: | ||||
|     title: "絵文字一覧" | ||||
|     update: "更新" | ||||
|     remove: "削除" | ||||
| admin/views/announcements.vue: | ||||
|   announcements: "お知らせ" | ||||
|   save: "保存" | ||||
|   remove: "削除" | ||||
|   add: "追加" | ||||
|   title: "タイトル" | ||||
|   text: "内容" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| 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: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/pages/deck/deck.user-column.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   images: "画像" | ||||
|   activity: "アクティビティ" | ||||
|   timeline: "タイムライン" | ||||
|   pinned-notes: "ピン留めされた投稿" | ||||
|   push-to-a-list: "リストに追加" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
| @@ -991,9 +1093,6 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
| desktop/views/pages/user/user.home.vue: | ||||
|   last-used-at: "最終アクセス" | ||||
| desktop/views/pages/user/user.photos.vue: | ||||
|   title: "フォト" | ||||
| @@ -1007,6 +1106,9 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "ミュートする" | ||||
|   muted: "ミュートしています" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロックする" | ||||
|   unblock: "ブロック解除" | ||||
|   block-confirm: "このユーザーをブロックしますか?" | ||||
|   push-to-a-list: "リストに追加" | ||||
|   list-pushed: "{user}を{list}に追加しました。" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| @@ -1014,6 +1116,10 @@ desktop/views/pages/user/user.header.vue: | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   years-old: "歳" | ||||
|   year: "年" | ||||
|   month: "月" | ||||
|   day: "日" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "投稿" | ||||
|   with-replies: "投稿と返信" | ||||
| @@ -1043,7 +1149,6 @@ desktop/views/widgets/users.vue: | ||||
|   refresh: "他を見る" | ||||
|   no-one: "いません!" | ||||
| mobile/views/components/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   used: "使用中" | ||||
|   folder-count: "フォルダ" | ||||
|   count-separator: "、" | ||||
| @@ -1073,6 +1178,8 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -1145,7 +1252,6 @@ mobile/views/components/ui.nav.vue: | ||||
|   messaging: "メッセージ" | ||||
|   follow-requests: "フォロー申請" | ||||
|   search: "検索" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   user-lists: "リスト" | ||||
|   widgets: "ウィジェット" | ||||
| @@ -1168,7 +1274,6 @@ mobile/views/pages/user-lists.vue: | ||||
|   title: "リスト" | ||||
|   enter-list-name: "リスト名を入力してください" | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   more: "もっと見る" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "📦 始めましょう" | ||||
| @@ -1213,23 +1318,6 @@ mobile/views/pages/notifications.vue: | ||||
|   read-all: "すべての通知を既読にしますか?" | ||||
| mobile/views/pages/games/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
| mobile/views/pages/search.vue: | ||||
|   search: "検索" | ||||
|   empty: "「{}」に関する投稿は見つかりませんでした。" | ||||
| @@ -1285,6 +1373,8 @@ mobile/views/pages/settings.vue: | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   mark-as-read-all-unread-notes: "すべての投稿を既読にする" | ||||
|   password: "パスワード" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   following: "フォロー" | ||||
| @@ -1294,8 +1384,10 @@ mobile/views/pages/user.vue: | ||||
|   timeline: "タイムライン" | ||||
|   media: "メディア" | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
|   mute: "ミュート" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "最近の投稿" | ||||
|   images: "画像" | ||||
| @@ -1341,3 +1433,29 @@ docs: | ||||
|       description: "説明" | ||||
| dev/views/index.vue: | ||||
|   manage-apps: "アプリの管理" | ||||
| dev/views/apps.vue: | ||||
|   manage-apps: "アプリを管理" | ||||
|   create-app: "アプリ作成" | ||||
|   app-missing: "アプリなし" | ||||
| dev/views/new-app.vue: | ||||
|   create-app: "アプリケーションの作成" | ||||
|   app-name: "アプリケーション名" | ||||
|   app-name-desc: "あなたのアプリの名称。" | ||||
|   app-name-ex: "ex) Misskey for iOS" | ||||
|   app-overview: "アプリの概要" | ||||
|   app-desc: "あなたのアプリの簡単な説明や紹介。" | ||||
|   app-desc-ex: "ex) Misskey iOSクライアント。" | ||||
|   callback-url: "コールバックURL (オプション)" | ||||
|   callback-url-desc: "ユーザーが認証フォームで認証した際にリダイレクトするURLを設定できます。" | ||||
|   authority: "権限" | ||||
|   authority-desc: "ここで要求した機能だけがAPIからアクセスできます。" | ||||
|   authority-warning: "アプリ作成後も変更できますが、新たな権限を付与する場合、その時点で関連付けられているユーザーキーはすべて無効になります。" | ||||
|   account-read: "アカウントの情報を見る。" | ||||
|   account-write: "アカウントの情報を操作する。" | ||||
|   note-write: "投稿する。" | ||||
|   reaction-write: "リアクションしたりリアクションをキャンセルする。" | ||||
|   following-write: "フォローしたりフォロー解除する。" | ||||
|   drive-read: "ドライブを見る。" | ||||
|   drive-write: "ドライブを操作する。" | ||||
|   notification-read: "通知を見る。" | ||||
|   notification-write: "通知を操作する。" | ||||
|   | ||||
| @@ -5,7 +5,7 @@ meta: | ||||
| common: | ||||
|   misskey: "Une ⭐ du fédiverse" | ||||
|   about-title: "Une ⭐ du fédivers." | ||||
|   about: "Merci d'avoir découvert Misskey. Misskey est une <b>plateforme de microblogage distribuée</b> née sur Terre. Parce qu'il fait partie du Fédivers (un univers composé de diverses plateformes de réseaux sociaux organisées), il est mutuellement connecté avec d'autres plateformes de réseaux sociaux. Désirez-vous prendre une pause, pendant un instant, loin de l'agitation de la ville et plonger dans un nouvel Internet ?" | ||||
|   about: "Merci d’avoir choisis Misskey. Misskey est une <b>plateforme de micro-blogging distribuée</b> née sur Terre et fait partie du Fédiverse (un univers composé de diverses plateformes de réseaux sociaux organisées), elle est connectée mutuellement avec d’autres plateformes de réseaux sociaux. Désirez-vous prendre une pause, un court instant, loin de l’agitation de la ville et plonger dans un Internet d’un nouveau genre ?" | ||||
|   intro: | ||||
|     title: "C’est quoi Misskey ?" | ||||
|     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" | ||||
| @@ -25,6 +25,14 @@ common: | ||||
|   application-authorization: "Permissions de l'application" | ||||
|   close: "Fermer" | ||||
|   do-not-copy-paste: "Veuillez ne pas entrer ou coller le code ici. Le compte peut être compromis." | ||||
|   BSoD: | ||||
|     fatal-error: ":( 致命的な問題が発生しました。" | ||||
|     update-browser-os: "お使いのブラウザ(またはOS)のバージョンを更新すると解決する可能性があります。" | ||||
|     error-code: "Code d’erreur" | ||||
|     browser-version: "Version du navigateur" | ||||
|     client-version: "La version du client" | ||||
|     email-support: "問題が解決しない場合は、上記の情報をお書き添えの上 syuilotan@yahoo.co.jp までご連絡ください。" | ||||
|     thanks: "Merci d’avoir choisi d’utiliser Misskey." | ||||
|   got-it: "J'ai compris !" | ||||
|   customization-tips: | ||||
|     title: "Conseils de personnalisation" | ||||
| @@ -43,7 +51,7 @@ common: | ||||
|     quoted-by: "Cité·e par {} :" | ||||
|   time: | ||||
|     unknown: "inconnu" | ||||
|     future: "à l'instant" | ||||
|     future: "à l’instant" | ||||
|     just_now: "à l'instant" | ||||
|     seconds_ago: "Il y a {} seconde·s" | ||||
|     minutes_ago: "Il y a {} minute·s" | ||||
| @@ -54,6 +62,7 @@ common: | ||||
|     years_ago: "Il y a {} an·s" | ||||
|   month-and-day: "{month} mois/{day} jour" | ||||
|   trash: "Corbeille" | ||||
|   drive: "Drive" | ||||
|   weekday-short: | ||||
|     sunday: "D" | ||||
|     monday: "L" | ||||
| @@ -106,15 +115,21 @@ common: | ||||
|   my-token-regenerated: "Votre jeton vient d’être généré, vous allez maintenant être déconnecté." | ||||
|   i-like-sushi: "Je préfère les sushis plutôt que le pudding" | ||||
|   show-reversi-board-labels: "Afficher les étiquettes des lignes et colonnes dans Reversi" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   use-contrast-reversi-stones: "Icône avec contraste sur Reversi" | ||||
|   verified-user: "Compte vérifié" | ||||
|   disable-animated-mfm: "Désactiver les textes animés dans les publications" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   always-show-nsfw: "Toujours afficher les contenus sensibles" | ||||
|   always-mark-nsfw: "Toujours marquer les notes ayant des attachements comme sensibles" | ||||
|   show-full-acct: "Afficher l’adresse complète de l’utilisateur" | ||||
|   reduce-motion: "Réduire les animations dans l’interface utilisateur" | ||||
|   this-setting-is-this-device-only: "Uniquement sur cet appareil" | ||||
|   do-not-use-in-production: 'Il s’agit d’une version de développement. Ne pas utiliser dans un environnement de production.' | ||||
|   is-remote-user: "Ces informations utilisateur ont été copiées." | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "Consulter le profil complet" | ||||
|   error: | ||||
|     title: 'Une erreur est survenue' | ||||
|     retry: 'Réessayer' | ||||
|   reversi: | ||||
|     drawn: "Partie nulle" | ||||
|     my-turn: "C’est votre tour" | ||||
| @@ -170,6 +185,8 @@ common: | ||||
|     rename: "Renommer" | ||||
|     stack-left: "Vers la gauche" | ||||
|     pop-right: "Vers la droite" | ||||
|   dev: "Échec lors de la création de l’application. Veuillez réessayer." | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
| auth/views/form.vue: | ||||
|   share-access: "Désirez-vous <b>autoriser</b> <i>{{ app.name }}</i> à avoir accès à votre compte ?" | ||||
|   permission-ask: "Cette application nécessite les autorisations suivantes :" | ||||
| @@ -254,7 +271,7 @@ common/views/components/connect-failed.troubleshooter.vue: | ||||
|   no-network: "Aucune connexion au réseau" | ||||
|   no-network-desc: "Veuillez vérifier que vous êtes bien connecté au réseau." | ||||
|   no-internet: "Aucune connexion internet." | ||||
|   no-internet-desc: "Veuillez vérifier que vous êtes bien connecté à internet." | ||||
|   no-internet-desc: "Assurez-vous que vous êtes bien connectés à internet." | ||||
|   no-server: "Impossible de se connecter au serveur" | ||||
|   no-server-desc: "Votre connexion semble correcte, mais il a été impossible de vous connecter au serveur de Misskey. Il se peut que le serveur soit hors-ligne ou en maintenance, veuillez ressayer plus tard." | ||||
|   success: "Connexion au serveur de Misskey réussie !" | ||||
| @@ -265,8 +282,8 @@ common/views/components/media-banner.vue: | ||||
|   sensitive: "Contenu sensible" | ||||
|   click-to-show: "Cliquer pour afficher" | ||||
| common/views/components/theme.vue: | ||||
|   light-theme: "非ダークモード時に使用するテーマ" | ||||
|   dark-theme: "ダークモード時に使用するテーマ" | ||||
|   light-theme: "Thème durant le mode clair" | ||||
|   dark-theme: "Thème durant le mode sombre" | ||||
|   light-themes: "Thème clair" | ||||
|   dark-themes: "Thème sombre" | ||||
|   install-a-theme: "Installer un thème" | ||||
| @@ -335,6 +352,7 @@ common/views/components/note-menu.vue: | ||||
|   detail: "Détails" | ||||
|   copy-link: "Copier le lien" | ||||
|   favorite: "Mettre cette note en favoris" | ||||
|   unfavorite: "Retirer des favoris" | ||||
|   pin: "Épingler sur votre profil" | ||||
|   unpin: "Désépingler" | ||||
|   delete: "Supprimer" | ||||
| @@ -415,6 +433,25 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{} utilisateurs·rices mentionnés·es" | ||||
|   empty: "Aucune tendance" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "Profil" | ||||
|   name: "Nom" | ||||
|   account: "Compte" | ||||
|   location: "Lieu" | ||||
|   description: "À propos de moi" | ||||
|   birthday: "Date de naissance" | ||||
|   avatar: "Avatar" | ||||
|   banner: "Bannière" | ||||
|   is-cat: "Ce compte est un Chat" | ||||
|   is-bot: "Ce compte est un Bot" | ||||
|   is-locked: "Demandes d’abonnements requièrent l’approbation" | ||||
|   careful-bot: "Les demandes d’abonnements venant de Bots requièrent l’approbation" | ||||
|   advanced: "Avancé" | ||||
|   privacy: "Vie privée" | ||||
|   save: "Mettre à jour le profil" | ||||
|   saved: "Profil mis à jour avec succès" | ||||
|   uploading: "En cours d'envoi …" | ||||
|   upload-failed: "Échec de l'envoi" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "Récupération" | ||||
|   no-broadcasts: "Aucune annonce" | ||||
| @@ -465,7 +502,7 @@ common/views/widgets/tips.vue: | ||||
|   tips-line14: "ホームのカスタマイズ中、ウィジェットを右クリックしてデザインを変更できます" | ||||
|   tips-line17: "Vous pouvez mettre un texte en surbrillance en le mettant entre ** **" | ||||
|   tips-line19: "Plusieurs fenêtres peuvent être détachées en dehors du navigateur." | ||||
|   tips-line20: "カレンダーウィジェットのパーセンテージは、経過の割合を示しています" | ||||
|   tips-line20: "Pourcentage sur le widget calendrier qui indique le pourcentage de temps passé" | ||||
|   tips-line21: "Vous pouvez aussi utiliser l'API pour développer des Bots." | ||||
|   tips-line23: "Mayu est mignone avec ses sourcils." | ||||
|   tips-line24: "Misskey a vu le jour en 2014" | ||||
| @@ -506,21 +543,24 @@ desktop/views/components/charts.vue: | ||||
|   title: "Graphiques" | ||||
|   per-day: "par jour" | ||||
|   per-hour: "par heure" | ||||
|   federation: "Fédération" | ||||
|   notes: "Publications" | ||||
|   users: "Utilisateurs" | ||||
|   drive: "Drive" | ||||
|   network: "Réseau" | ||||
|   charts: | ||||
|     federation-instances: "Nombre d’instances : augmentation/diminution" | ||||
|     federation-instances-total: "Nombre total d’instances" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "Total des notes" | ||||
|     users: "Nombre d’utilisateurs·trices : augmentation/diminution" | ||||
|     users-total: "ユーザーの積算" | ||||
|     users-total: "Nombre total des utilisateurs·rices" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の積算" | ||||
|     drive-total: "Utilisation totale du lecteur" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の積算" | ||||
|     drive-files-total: "Nombre total de fichiers sur le lecteur" | ||||
|     network-requests: "Requêtes" | ||||
|     network-time: "Temps de réponse" | ||||
|     network-usage: "Traffic" | ||||
| @@ -540,7 +580,6 @@ desktop/views/components/crop-window.vue: | ||||
|   ok: "OK" | ||||
| desktop/views/components/drive-window.vue: | ||||
|   used: "utilisé" | ||||
|   drive: "Drive" | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "Avatar" | ||||
|   banner: "Bannière" | ||||
| @@ -570,8 +609,6 @@ desktop/views/components/drive.folder.vue: | ||||
|     rename: "Renommer" | ||||
|     rename-folder: "Renommer le dossier" | ||||
|     input-new-folder-name: "Entrer un nouveau nom" | ||||
| desktop/views/components/drive.nav-folder.vue: | ||||
|   drive: "Drive" | ||||
| desktop/views/components/drive.vue: | ||||
|   search: "Rechercher" | ||||
|   load-more: "Afficher plus" | ||||
| @@ -639,14 +676,14 @@ desktop/views/components/note-detail.vue: | ||||
|   location: "Géolocalisation" | ||||
|   renote: "Republier" | ||||
|   add-reaction: "Ajouter votre reaction" | ||||
| desktop/views/components/notes.note.vue: | ||||
|   reposted-by: "Reposté par {}" | ||||
| desktop/views/components/note.vue: | ||||
|   reposted-by: "Partagé par {}" | ||||
|   reply: "Répondre" | ||||
|   renote: "Republier" | ||||
|   add-reaction: "Ajouter votre reaction" | ||||
|   detail: "Afficher les détails" | ||||
|   private: "cette publication est privée" | ||||
|   deleted: "cette publication a été supprimée" | ||||
|   renote: "Partager" | ||||
|   add-reaction: "Ajouter votre réaction" | ||||
|   detail: "Détails" | ||||
|   private: "Cette publication est privée" | ||||
|   deleted: "Cette publication a été supprimée" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "Échec du chargement." | ||||
|   retry: "Réessayer" | ||||
| @@ -705,8 +742,8 @@ desktop/views/components/settings.vue: | ||||
|   profile: "Profil" | ||||
|   notification: "Notification" | ||||
|   apps: "Applications" | ||||
|   mute: "Mettre en sourdine" | ||||
|   drive: "Drive" | ||||
|   mute-and-block: "ミュート/ブロック" | ||||
|   blocking: "ブロック" | ||||
|   security: "Sécurité" | ||||
|   signin: "Historique de connexion" | ||||
|   password: "Mot de Passe" | ||||
| @@ -725,8 +762,12 @@ desktop/views/components/settings.vue: | ||||
|   advanced: "Paramètres avancés" | ||||
|   api-via-stream: "Requête API via le flux" | ||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "Affichage et design" | ||||
|   customize: "Personnaliser l'Accueil" | ||||
|   wallpaper: "Arrière plan" | ||||
|   choose-wallpaper: "Sélectionner un fond d'écran" | ||||
|   delete-wallpaper: "Supprimer le fond d'écran" | ||||
|   dark-mode: "Mode nuit" | ||||
| @@ -738,17 +779,19 @@ desktop/views/components/settings.vue: | ||||
|   suggest-recent-hashtags: "Afficher les hashtags populaires dans le champs de saisie" | ||||
|   show-clock-on-header: "Afficher l'horloge à droite sur le coté supérieur" | ||||
|   show-reply-target: "Afficher les réponses" | ||||
|   timeline: "Chronologie" | ||||
|   show-my-renotes: "Afficher mes republications dans le fil" | ||||
|   show-renoted-my-notes: "Afficher mes republications dans les fils" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "Afficher les partages locaux sur les fils" | ||||
|   show-maps: "Afficher la carte" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align-center: "Centrer" | ||||
|   deck-column-align-left: "À gauche" | ||||
|   sound: "Son" | ||||
|   enable-sounds: "Activer le son" | ||||
|   enable-sounds-desc: "Jouer un son lorsque vous recevez un message. Ce paramètre est sauvegardé dans le navigateur." | ||||
|   volume: "Volume" | ||||
|   test: "Test" | ||||
|   mobile: "Mobile" | ||||
|   disable-via-mobile: "Enlever la mention publié via 'un périphérique mobile'" | ||||
|   language: "Langue" | ||||
|   pick-language: "Sélectionner une langue" | ||||
|   recommended: "Recommandé" | ||||
| @@ -784,6 +827,10 @@ desktop/views/components/settings.vue: | ||||
|   tools: "Outils" | ||||
|   task-manager: "Gestionnaire de tâches" | ||||
|   third-parties: "Services tiers" | ||||
|   navbar-position: "Position de la barre de navigation" | ||||
|   navbar-position-top: "En haut" | ||||
|   navbar-position-left: "à gauche" | ||||
|   navbar-position-right: "à droite" | ||||
| desktop/views/components/settings.2fa.vue: | ||||
|   intro: "Si vous configurez la vérication en deux étapes vous aurez non seulement besoin de votre mot de passe mais aussi un appareil déjà pré-enregistré(tel que votre smartphone) ce qui ameliora grandement la sécurité de votre compte." | ||||
|   detail: "Voir les détails..." | ||||
| @@ -802,41 +849,39 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "L'operation a été complétée avec succès!" | ||||
|   failed: "L'operation a échoué. Veuillez vous assurer que le token a été entrer correctement." | ||||
|   info: "À partir de maintenant, à chaque fois que vous vous connecter entrez votre mot de passe ainsi que le token généré sur votre appareil." | ||||
| desktop/views/components/settings.api.vue: | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
|   regeneration-of-token: "Si votre jeton est compromis, vous pouvez le régénérer." | ||||
|   regenerate-token: "Regenerer le token" | ||||
|   regenerate-token: "Régénérer le jeton" | ||||
|   token: "Jeton :" | ||||
|   enter-password: "Veuillez entrer le mot de passe" | ||||
|   enter-password: "Entrez le mot de passe" | ||||
|   console: | ||||
|     title: 'Console API' | ||||
|     endpoint: 'Point de terminaison' | ||||
|     parameter: 'Paramètres' | ||||
|     send: 'Envoyer' | ||||
|     sending: 'Envoi en cours' | ||||
|     response: 'Résultat' | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "Aucune application autorisée" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "Maximum" | ||||
|   in-use: "en cours d’utilisation" | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "Aucun utilisateurs mis en sourdine" | ||||
| desktop/views/components/settings.password.vue: | ||||
|   reset: "Changer votre mot de passe" | ||||
| common/views/components/drive-settings.vue: | ||||
|   max: "Maximale" | ||||
|   in-use: "utilisé" | ||||
|   stats: "Statistiques" | ||||
| common/views/components/mute-and-block.vue: | ||||
|   mute-and-block: "Silencer / Bloquer" | ||||
|   mute: "Mettre en sourdine" | ||||
|   block: "En cours blocage" | ||||
|   no-muted-users: "Aucun utilisateur·rice n’est mis·e en sourdine" | ||||
|   no-blocked-users: "Aucun utilisateur·rice n’est bloqué·e" | ||||
| common/views/components/password-settings.vue: | ||||
|   reset: "Modifier le mot de passe" | ||||
|   enter-current-password: "Entrez votre mot de passe actuel" | ||||
|   enter-new-password: "Entrez votre nouveau mot de passe" | ||||
|   enter-new-password: "Saisissez le nouveau mot de passe" | ||||
|   enter-new-password-again: "Entrez à nouveau le nouveau mot de passe" | ||||
|   not-match: "Le nouveau mot de passe ne correspond pas." | ||||
|   not-match: "Les nouveaux mots de passe ne sont pas identiques" | ||||
|   changed: "Mot de passe modifié avec succès" | ||||
| desktop/views/components/settings.profile.vue: | ||||
|   avatar: "Avatar" | ||||
|   choice-avatar: "Choose an image" | ||||
|   name: "Nom" | ||||
|   location: "Localisation" | ||||
|   description: "Description" | ||||
|   birthday: "Date de naissance" | ||||
|   save: "Mettre à jour le profil" | ||||
|   locked-account: "Protéger votre compte" | ||||
|   is-locked: "Demande d’abonnement en attente d’approbation" | ||||
|   other: "Autre" | ||||
|   is-bot: "Ce compte est un Bot" | ||||
|   is-cat: "Ce compte est un Chat" | ||||
|   profile-updated: "Profil mis à jour" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "cette publication est privée" | ||||
|   deleted: "cette publication a été supprimée" | ||||
| @@ -861,7 +906,6 @@ desktop/views/components/ui.header.vue: | ||||
|   adjective: "M." | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "Votre profil" | ||||
|   drive: "Drive" | ||||
|   favorites: "Favorites" | ||||
|   lists: "Listes" | ||||
|   follow-requests: "Demandes de suivi" | ||||
| @@ -903,42 +947,100 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "Fermer" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
| admin/views/index.vue: | ||||
|   dashboard: "Tableau de bord" | ||||
|   drive: "Drive" | ||||
|   instance: "Instance" | ||||
|   emoji: "Emoji" | ||||
|   users: "Utilisateur·rice·s" | ||||
|   update: "Mises à jour" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   update: "Mise à jour" | ||||
|   announcements: "Annonces" | ||||
|   hashtags: "Hashtags" | ||||
|   back-to-misskey: "Retour vers Misskey" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "Tableau de bord" | ||||
|   all-users: "Toutes les utilisateurrices" | ||||
|   original-users: "Utilisateur·rice·s sur cette instance" | ||||
|   all-notes: "Toutes les publications" | ||||
|   original-notes: "Publications sur cette instance" | ||||
|   invite: "Invitation" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   accounts: "Comptes" | ||||
|   notes: "Notes" | ||||
|   drive: "Lecteur" | ||||
|   instances: "Instances" | ||||
|   this-instance: "Cette instance" | ||||
|   federated: "Fédérées" | ||||
|   invite: "Inviter" | ||||
|   banner-url: "URL de la bannière" | ||||
|   disableRegistration: "Désactiver l’enregistrement de nouveaux utilisateur·rice·s" | ||||
|   disableLocalTimeline: "Désactiver le fil local" | ||||
| admin/views/charts.vue: | ||||
|   title: "Graph" | ||||
|   per-day: "par jour" | ||||
|   per-hour: "par heure" | ||||
|   federation: "Fédération" | ||||
|   notes: "Publications" | ||||
|   users: "Utilisateur·rice·s" | ||||
|   drive: "Lecteur" | ||||
|   network: "Réseau" | ||||
|   charts: | ||||
|     federation-instances: "Nombre d’instances : augmentation/diminution" | ||||
|     federation-instances-total: "Nombre total d’instances" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "Total des publications" | ||||
|     users: "Nombre d’utilisateur·rice·s : augmentation/diminution" | ||||
|     users-total: "Nombre total des utilisateur·rice·s" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "Utilisation totale du lecteur" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "Nombre total de fichiers sur le lecteur" | ||||
|     network-requests: "Requêtes" | ||||
|     network-time: "Temps de réponse" | ||||
|     network-usage: "Traffic" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "Suspendre un·e utilisateur·rice" | ||||
|   suspend: "Suspendre" | ||||
|   suspended: "Suspendu avec succès" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   suspended: "Suspendu·e avec succès." | ||||
|   unsuspend-user: "Lever la suspension d’utilisateur·rice·s" | ||||
|   unsuspend: "Suspension levée" | ||||
|   unsuspended: "La suspension de l’utilisateur·rice a été levée avec succès" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "Paramètres de vérification du compte utilisateur" | ||||
|   verify: "Vérification du compte" | ||||
|   verified: "Le compte a été vérifié" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "Ôter la vérification du compte" | ||||
|   unverified: "Ce compte n'est pas vérifié" | ||||
|   unverified: "Ce compte n'est plus vérifié" | ||||
| admin/views/emoji.vue: | ||||
|   add-emoji: | ||||
|     title: "Ajouter un émoji" | ||||
|     name: "Nom de l’émoji" | ||||
|     name-desc: "a~z 0~9 _ の文字が使えます。" | ||||
|     aliases: "Aliases" | ||||
|     aliases-desc: "Vous pouvez définir plus d’un, séparés par des espaces." | ||||
|     url: "URL de l’image" | ||||
|     add: "Ajouter" | ||||
|   emojis: | ||||
|     title: "絵文字一覧" | ||||
|     update: "更新" | ||||
|     remove: "削除" | ||||
| admin/views/announcements.vue: | ||||
|   announcements: "Annonces" | ||||
|   save: "Enregistrer" | ||||
|   remove: "Supprimer" | ||||
|   add: "Ajouter" | ||||
|   title: "Titre" | ||||
|   text: "Contenu" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Tags cachés" | ||||
| desktop/views/pages/deck/deck.tl-column.vue: | ||||
|   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" | ||||
|   deleted: "cette publication a été supprimée" | ||||
| desktop/views/pages/deck/deck.user-column.vue: | ||||
|   posts: "Publications" | ||||
|   following: "Suit" | ||||
|   followers: "Abonné·e·s" | ||||
|   images: "Images" | ||||
|   activity: "Activité" | ||||
|   timeline: "Chronologie" | ||||
|   pinned-notes: "Publications épinglées" | ||||
|   push-to-a-list: "Ajouter à la liste" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "Toutes les utilisateurrices" | ||||
|   original-users: "Utilisateur·rice·s sur cette instance" | ||||
| @@ -991,10 +1093,7 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   no-users: "Pas d'utilisateurs" | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "Ce compte a été suspendu." | ||||
|   is-remote: "Cet utilisateur n'est pas un utilisateur Misskey. Certaines informations peuvent ne pas refléter ce profil dans sa totalité." | ||||
|   view-remote: "Consulter le profil complet" | ||||
| desktop/views/pages/user/user.home.vue: | ||||
|   last-used-at: "Last used at" | ||||
|   last-used-at: "Actif·ive pour la dernière fois" | ||||
| desktop/views/pages/user/user.photos.vue: | ||||
|   title: "Photos" | ||||
|   loading: "Chargement en cours" | ||||
| @@ -1007,6 +1106,9 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "Mettre en sourdine" | ||||
|   muted: "Muting" | ||||
|   unmute: "Enlever la sourdine" | ||||
|   block: "Bloquer" | ||||
|   unblock: "Débloquer" | ||||
|   block-confirm: "Bloquer cet utilisateur ?" | ||||
|   push-to-a-list: "Ajouter à la liste" | ||||
|   list-pushed: "Vous avez ajouté {user} à la liste {list}." | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| @@ -1014,6 +1116,10 @@ desktop/views/pages/user/user.header.vue: | ||||
|   following: "Suit" | ||||
|   followers: "Abonné·e·s" | ||||
|   is-bot: "Ce compte est un Bot" | ||||
|   years-old: "ans d’âge" | ||||
|   year: "Année" | ||||
|   month: "Mois" | ||||
|   day: "Jour" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "Publications" | ||||
|   with-replies: "Publications et réponses" | ||||
| @@ -1043,7 +1149,6 @@ desktop/views/widgets/users.vue: | ||||
|   refresh: "Afficher d'autres" | ||||
|   no-one: "Personne" | ||||
| mobile/views/components/drive.vue: | ||||
|   drive: "Drive" | ||||
|   used: "utilisé" | ||||
|   folder-count: "Dossier(s)" | ||||
|   count-separator: ", " | ||||
| @@ -1073,6 +1178,8 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   hash: "Hash (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "CW" | ||||
|   mark-as-sensitive: "Marquer comme sensible" | ||||
|   unmark-as-sensitive: "Ne pas marquer comme sensible" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "Le contenu est NSFW" | ||||
|   click-to-show: "Cliquer pour afficher" | ||||
| @@ -1145,7 +1252,6 @@ mobile/views/components/ui.nav.vue: | ||||
|   messaging: "Messages" | ||||
|   follow-requests: "Demandes d'abonnement" | ||||
|   search: "Rechercher" | ||||
|   drive: "Drive" | ||||
|   favorites: "Favoris" | ||||
|   user-lists: "Listes" | ||||
|   widgets: "Modules" | ||||
| @@ -1168,7 +1274,6 @@ mobile/views/pages/user-lists.vue: | ||||
|   title: "Listes" | ||||
|   enter-list-name: "Nom de la liste" | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "Drive" | ||||
|   more: "Afficher plus ..." | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "Votre compte est prêt ! 📦" | ||||
| @@ -1213,23 +1318,6 @@ mobile/views/pages/notifications.vue: | ||||
|   read-all: "Êtes vous sûr de vouloir marqués toutes les notifications non-lus en tant que lus?" | ||||
| mobile/views/pages/games/reversi.vue: | ||||
|   reversi: "Reversi" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "Profil" | ||||
|   name: "Nom" | ||||
|   account: "Compte" | ||||
|   location: "Lieu" | ||||
|   description: "Description" | ||||
|   birthday: "Date de naissance" | ||||
|   avatar: "Avatar" | ||||
|   banner: "Bannière" | ||||
|   is-cat: "Ce compte est un Bot" | ||||
|   is-locked: "Demande d’abonnement en attente d’approbation" | ||||
|   advanced: "Avancé" | ||||
|   privacy: "Vie privée" | ||||
|   save: "Mettre à jour le profil" | ||||
|   saved: "Profil mis à jour avec succès" | ||||
|   uploading: "En cours d'envoi" | ||||
|   upload-failed: "Échec de l'envoi" | ||||
| mobile/views/pages/search.vue: | ||||
|   search: "Chercher" | ||||
|   empty: "Aucun message trouvé pour '{}' " | ||||
| @@ -1251,8 +1339,8 @@ mobile/views/pages/settings.vue: | ||||
|   timeline: "Fil d'actualité" | ||||
|   show-reply-target: "Afficher les réponses" | ||||
|   show-my-renotes: "Afficher mes republications" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteを表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteを表示する" | ||||
|   show-renoted-my-notes: "Afficher mes publications partagées" | ||||
|   show-local-renotes: "Afficher les publications partagées localement" | ||||
|   post-style: "Style de la publication" | ||||
|   post-style-standard: "Standard" | ||||
|   post-style-smart: "Intelligent" | ||||
| @@ -1285,6 +1373,8 @@ mobile/views/pages/settings.vue: | ||||
|   signout: "Déconnexion" | ||||
|   sound: "Sons" | ||||
|   enable-sounds: "Activer les sons" | ||||
|   mark-as-read-all-unread-notes: "Marquer toutes les publications comme lues" | ||||
|   password: "Mot de Passe" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "Vous suit" | ||||
|   following: "Abonnements" | ||||
| @@ -1294,8 +1384,10 @@ mobile/views/pages/user.vue: | ||||
|   timeline: "Fil d'actualité" | ||||
|   media: "Media" | ||||
|   is-suspended: "This account has been suspended." | ||||
|   is-remote: "Ceci est le profil d’un utilisateur·rice distant·e. Certaines informations peuvent ne pas refléter ce profil dans sa totalité." | ||||
|   view-remote: "Consulter son profil complet" | ||||
|   mute: "Mettre en sourdine" | ||||
|   unmute: "Enlever la sourdine" | ||||
|   block: "Bloquer" | ||||
|   unblock: "Débloquer" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "Notes récentes" | ||||
|   images: "Images" | ||||
| @@ -1341,3 +1433,29 @@ docs: | ||||
|       description: "Description" | ||||
| dev/views/index.vue: | ||||
|   manage-apps: "Gestion des applications" | ||||
| dev/views/apps.vue: | ||||
|   manage-apps: "Gestion des applications" | ||||
|   create-app: "Créer une app" | ||||
|   app-missing: "Aucune application" | ||||
| dev/views/new-app.vue: | ||||
|   create-app: "Création d’une application" | ||||
|   app-name: "Nom de l’application" | ||||
|   app-name-desc: "Le nom de votre application" | ||||
|   app-name-ex: "p. ex. Misskey pour iOS" | ||||
|   app-overview: "Description courte de l’application" | ||||
|   app-desc: "Brève description introductive à votre application." | ||||
|   app-desc-ex: "p. ex) Misskey pour iOS" | ||||
|   callback-url: "コールバックURL (オプション)" | ||||
|   callback-url-desc: "ユーザーが認証フォームで認証した際にリダイレクトするURLを設定できます。" | ||||
|   authority: "Autorisations " | ||||
|   authority-desc: "ここで要求した機能だけがAPIからアクセスできます。" | ||||
|   authority-warning: "アプリ作成後も変更できますが、新たな権限を付与する場合、その時点で関連付けられているユーザーキーはすべて無効になります。" | ||||
|   account-read: "Afficher les informations du compte" | ||||
|   account-write: "Modifications des informations du compte" | ||||
|   note-write: "Publications." | ||||
|   reaction-write: "Ajout et suppression de réactions." | ||||
|   following-write: "S’abonner et se désabonner." | ||||
|   drive-read: "Lecture du Drive." | ||||
|   drive-write: "Téléversement/suppression des fichiers de votre Lecteur." | ||||
|   notification-read: "Lire vos notifications." | ||||
|   notification-write: "Gestion de vos notifications." | ||||
|   | ||||
| @@ -25,6 +25,14 @@ common: | ||||
|   application-authorization: "アプリの連携" | ||||
|   close: "閉じる" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   BSoD: | ||||
|     fatal-error: ":( 致命的な問題が発生しました。" | ||||
|     update-browser-os: "お使いのブラウザ(またはOS)のバージョンを更新すると解決する可能性があります。" | ||||
|     error-code: "エラーコード" | ||||
|     browser-version: "ブラウザ バージョン" | ||||
|     client-version: "クライアント バージョン" | ||||
|     email-support: "問題が解決しない場合は、上記の情報をお書き添えの上 syuilotan@yahoo.co.jp までご連絡ください。" | ||||
|     thanks: "Thank you for using Misskey." | ||||
|   got-it: "わかった" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
| @@ -54,6 +62,7 @@ common: | ||||
|     years_ago: "{}年前" | ||||
|   month-and-day: "{month}月 {day}日" | ||||
|   trash: "ゴミ箱" | ||||
|   drive: "ドライブ" | ||||
|   weekday-short: | ||||
|     sunday: "日" | ||||
|     monday: "月" | ||||
| @@ -115,6 +124,12 @@ common: | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|   error: | ||||
|     title: '問題が発生しました' | ||||
|     retry: 'やり直す' | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
| @@ -170,6 +185,8 @@ common: | ||||
|     rename: "名前を変更" | ||||
|     stack-left: "左に重ねる" | ||||
|     pop-right: "右に出す" | ||||
|   dev: "アプリの作成に失敗しました。再度お試しください。" | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{{ app.name }}</i>があなたのアカウントにアクセスすることを<b>許可</b>しますか?" | ||||
|   permission-ask: "このアプリは次の権限を要求しています:" | ||||
| @@ -335,6 +352,7 @@ common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   unfavorite: "お気に入り解除" | ||||
|   pin: "ピン留め" | ||||
|   unpin: "ピン留め解除" | ||||
|   delete: "削除" | ||||
| @@ -415,6 +433,25 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   careful-bot: "Botからのフォローだけ承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "確認中" | ||||
|   no-broadcasts: "お知らせはありません" | ||||
| @@ -506,11 +543,14 @@ desktop/views/components/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
| @@ -540,7 +580,6 @@ desktop/views/components/crop-window.vue: | ||||
|   ok: "決定" | ||||
| desktop/views/components/drive-window.vue: | ||||
|   used: "使用中" | ||||
|   drive: "ドライブ" | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
| @@ -570,8 +609,6 @@ desktop/views/components/drive.folder.vue: | ||||
|     rename: "名前を変更" | ||||
|     rename-folder: "フォルダ名の変更" | ||||
|     input-new-folder-name: "新しいフォルダ名を入力してください" | ||||
| desktop/views/components/drive.nav-folder.vue: | ||||
|   drive: "ドライブ" | ||||
| desktop/views/components/drive.vue: | ||||
|   search: "検索" | ||||
|   load-more: "もっと読み込む" | ||||
| @@ -639,7 +676,7 @@ desktop/views/components/note-detail.vue: | ||||
|   location: "位置情報" | ||||
|   renote: "Renote" | ||||
|   add-reaction: "リアクション" | ||||
| desktop/views/components/notes.note.vue: | ||||
| desktop/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   reply: "返信" | ||||
|   renote: "Renote" | ||||
| @@ -705,8 +742,8 @@ desktop/views/components/settings.vue: | ||||
|   profile: "プロフィール" | ||||
|   notification: "通知" | ||||
|   apps: "アプリ" | ||||
|   mute: "ミュート" | ||||
|   drive: "ドライブ" | ||||
|   mute-and-block: "ミュート/ブロック" | ||||
|   blocking: "ブロック" | ||||
|   security: "セキュリティ" | ||||
|   signin: "サインイン履歴" | ||||
|   password: "パスワード" | ||||
| @@ -725,8 +762,12 @@ desktop/views/components/settings.vue: | ||||
|   advanced: "詳細設定" | ||||
|   api-via-stream: "ストリームを経由したAPIリクエスト" | ||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "デザインと表示" | ||||
|   customize: "ホームをカスタマイズ" | ||||
|   wallpaper: "壁紙" | ||||
|   choose-wallpaper: "壁紙を選択" | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
| @@ -738,17 +779,19 @@ desktop/views/components/settings.vue: | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   timeline: "タイムライン" | ||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||
|   volume: "ボリューム" | ||||
|   test: "テスト" | ||||
|   mobile: "モバイル" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   language: "言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
| @@ -784,6 +827,10 @@ desktop/views/components/settings.vue: | ||||
|   tools: "ツール" | ||||
|   task-manager: "タスクマネージャ" | ||||
|   third-parties: "サードパーティ" | ||||
|   navbar-position: "ナビゲーションバーの位置" | ||||
|   navbar-position-top: "上" | ||||
|   navbar-position-left: "左" | ||||
|   navbar-position-right: "右" | ||||
| desktop/views/components/settings.2fa.vue: | ||||
|   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" | ||||
|   detail: "詳細..." | ||||
| @@ -802,41 +849,39 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "設定が完了しました!" | ||||
|   failed: "設定に失敗しました。トークンに誤りがないかご確認ください。" | ||||
|   info: "次回サインインからは、同様にパスワードに加えてデバイスに表示されているトークンを入力します。" | ||||
| desktop/views/components/settings.api.vue: | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
|   regeneration-of-token: "万が一このトークンが漏れたりその可能性がある場合はトークンを再生成できます。" | ||||
|   regenerate-token: "トークンを再生成" | ||||
|   token: "Token:" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   console: | ||||
|     title: 'APIコンソール' | ||||
|     endpoint: 'エンドポイント' | ||||
|     parameter: 'パラメータ' | ||||
|     send: '送信' | ||||
|     sending: '応答待ち' | ||||
|     response: '結果' | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "連携しているアプリケーションはありません" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "中" | ||||
| common/views/components/drive-settings.vue: | ||||
|   max: "容量" | ||||
|   in-use: "使用中" | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "ミュートしているユーザーはいません" | ||||
| desktop/views/components/settings.password.vue: | ||||
|   stats: "統計" | ||||
| common/views/components/mute-and-block.vue: | ||||
|   mute-and-block: "ミュートとブロック" | ||||
|   mute: "ミュート" | ||||
|   block: "ブロック" | ||||
|   no-muted-users: "ミュートしているユーザーはいません" | ||||
|   no-blocked-users: "ブロックしているユーザーはいません" | ||||
| common/views/components/password-settings.vue: | ||||
|   reset: "パスワードを変更する" | ||||
|   enter-current-password: "現在のパスワードを入力してください" | ||||
|   enter-new-password: "新しいパスワードを入力してください" | ||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||
|   not-match: "新しいパスワードが一致しません" | ||||
|   changed: "パスワードを変更しました" | ||||
| desktop/views/components/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   choice-avatar: "画像を選択" | ||||
|   name: "名前" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   profile-updated: "プロフィールを更新しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| @@ -861,7 +906,6 @@ desktop/views/components/ui.header.vue: | ||||
|   adjective: "さん" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "プロフィール" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
| @@ -903,42 +947,100 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
| admin/views/index.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "ドライブ" | ||||
|   instance: "インスタンス" | ||||
|   emoji: "カスタム絵文字" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   announcements: "お知らせ" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   accounts: "アカウント" | ||||
|   notes: "投稿" | ||||
|   drive: "ドライブ" | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "このインスタンス" | ||||
|   federated: "連合" | ||||
|   invite: "招待" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   banner-url: "Banner URL" | ||||
|   disableRegistration: "Disable new user registration" | ||||
|   disableLocalTimeline: "Disable the local timeline" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の積算" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の積算" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| admin/views/emoji.vue: | ||||
|   add-emoji: | ||||
|     title: "絵文字の登録" | ||||
|     name: "絵文字名" | ||||
|     name-desc: "a~z 0~9 _ の文字が使えます。" | ||||
|     aliases: "エイリアス" | ||||
|     aliases-desc: "スペースで区切って複数設定できます。" | ||||
|     url: "絵文字画像URL" | ||||
|     add: "追加" | ||||
|   emojis: | ||||
|     title: "絵文字一覧" | ||||
|     update: "更新" | ||||
|     remove: "削除" | ||||
| admin/views/announcements.vue: | ||||
|   announcements: "お知らせ" | ||||
|   save: "保存" | ||||
|   remove: "削除" | ||||
|   add: "追加" | ||||
|   title: "タイトル" | ||||
|   text: "内容" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| 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: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/pages/deck/deck.user-column.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   images: "画像" | ||||
|   activity: "アクティビティ" | ||||
|   timeline: "タイムライン" | ||||
|   pinned-notes: "ピン留めされた投稿" | ||||
|   push-to-a-list: "リストに追加" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
| @@ -991,9 +1093,6 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
| desktop/views/pages/user/user.home.vue: | ||||
|   last-used-at: "最終アクセス" | ||||
| desktop/views/pages/user/user.photos.vue: | ||||
|   title: "フォト" | ||||
| @@ -1007,6 +1106,9 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "ミュートする" | ||||
|   muted: "ミュートしています" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロックする" | ||||
|   unblock: "ブロック解除" | ||||
|   block-confirm: "このユーザーをブロックしますか?" | ||||
|   push-to-a-list: "リストに追加" | ||||
|   list-pushed: "{user}を{list}に追加しました。" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| @@ -1014,6 +1116,10 @@ desktop/views/pages/user/user.header.vue: | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   years-old: "歳" | ||||
|   year: "年" | ||||
|   month: "月" | ||||
|   day: "日" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "投稿" | ||||
|   with-replies: "投稿と返信" | ||||
| @@ -1043,7 +1149,6 @@ desktop/views/widgets/users.vue: | ||||
|   refresh: "他を見る" | ||||
|   no-one: "いません!" | ||||
| mobile/views/components/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   used: "使用中" | ||||
|   folder-count: "フォルダ" | ||||
|   count-separator: "、" | ||||
| @@ -1073,6 +1178,8 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -1145,7 +1252,6 @@ mobile/views/components/ui.nav.vue: | ||||
|   messaging: "メッセージ" | ||||
|   follow-requests: "フォロー申請" | ||||
|   search: "検索" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   user-lists: "リスト" | ||||
|   widgets: "ウィジェット" | ||||
| @@ -1168,7 +1274,6 @@ mobile/views/pages/user-lists.vue: | ||||
|   title: "リスト" | ||||
|   enter-list-name: "リスト名を入力してください" | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   more: "もっと見る" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "📦 始めましょう" | ||||
| @@ -1213,23 +1318,6 @@ mobile/views/pages/notifications.vue: | ||||
|   read-all: "すべての通知を既読にしますか?" | ||||
| mobile/views/pages/games/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
| mobile/views/pages/search.vue: | ||||
|   search: "検索" | ||||
|   empty: "「{}」に関する投稿は見つかりませんでした。" | ||||
| @@ -1285,6 +1373,8 @@ mobile/views/pages/settings.vue: | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   mark-as-read-all-unread-notes: "すべての投稿を既読にする" | ||||
|   password: "パスワード" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   following: "フォロー" | ||||
| @@ -1294,8 +1384,10 @@ mobile/views/pages/user.vue: | ||||
|   timeline: "タイムライン" | ||||
|   media: "メディア" | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
|   mute: "ミュート" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "最近の投稿" | ||||
|   images: "画像" | ||||
| @@ -1341,3 +1433,29 @@ docs: | ||||
|       description: "説明" | ||||
| dev/views/index.vue: | ||||
|   manage-apps: "アプリの管理" | ||||
| dev/views/apps.vue: | ||||
|   manage-apps: "アプリを管理" | ||||
|   create-app: "アプリ作成" | ||||
|   app-missing: "アプリなし" | ||||
| dev/views/new-app.vue: | ||||
|   create-app: "アプリケーションの作成" | ||||
|   app-name: "アプリケーション名" | ||||
|   app-name-desc: "あなたのアプリの名称。" | ||||
|   app-name-ex: "ex) Misskey for iOS" | ||||
|   app-overview: "アプリの概要" | ||||
|   app-desc: "あなたのアプリの簡単な説明や紹介。" | ||||
|   app-desc-ex: "ex) Misskey iOSクライアント。" | ||||
|   callback-url: "コールバックURL (オプション)" | ||||
|   callback-url-desc: "ユーザーが認証フォームで認証した際にリダイレクトするURLを設定できます。" | ||||
|   authority: "権限" | ||||
|   authority-desc: "ここで要求した機能だけがAPIからアクセスできます。" | ||||
|   authority-warning: "アプリ作成後も変更できますが、新たな権限を付与する場合、その時点で関連付けられているユーザーキーはすべて無効になります。" | ||||
|   account-read: "アカウントの情報を見る。" | ||||
|   account-write: "アカウントの情報を操作する。" | ||||
|   note-write: "投稿する。" | ||||
|   reaction-write: "リアクションしたりリアクションをキャンセルする。" | ||||
|   following-write: "フォローしたりフォロー解除する。" | ||||
|   drive-read: "ドライブを見る。" | ||||
|   drive-write: "ドライブを操作する。" | ||||
|   notification-read: "通知を見る。" | ||||
|   notification-write: "通知を操作する。" | ||||
|   | ||||
| @@ -25,6 +25,15 @@ common: | ||||
|   application-authorization: "アプリの連携" | ||||
|   close: "閉じる" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   BSoD: | ||||
|     fatal-error: ":( 致命的な問題が発生しました。" | ||||
|     update-browser-os: "お使いのブラウザ(またはOS)のバージョンを更新すると解決する可能性があります。" | ||||
|     error-code: "エラーコード" | ||||
|     browser-version: "ブラウザ バージョン" | ||||
|     client-version: "クライアント バージョン" | ||||
|     email-support: "問題が解決しない場合は、上記の情報をお書き添えの上 syuilotan@yahoo.co.jp までご連絡ください。" | ||||
|     thanks: "Thank you for using Misskey." | ||||
|  | ||||
|   got-it: "わかった" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
| @@ -55,6 +64,7 @@ common: | ||||
|   month-and-day: "{month}月 {day}日" | ||||
|  | ||||
|   trash: "ゴミ箱" | ||||
|   drive: "ドライブ" | ||||
|  | ||||
|   weekday-short: | ||||
|     sunday: "日" | ||||
| @@ -124,6 +134,14 @@ common: | ||||
|  | ||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||
|  | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|  | ||||
|   error: | ||||
|     title: '問題が発生しました' | ||||
|     retry: 'やり直す' | ||||
|  | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
| @@ -182,6 +200,9 @@ common: | ||||
|     stack-left: "左に重ねる" | ||||
|     pop-right: "右に出す" | ||||
|  | ||||
|   dev: "アプリの作成に失敗しました。再度お試しください。" | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
|  | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{{ app.name }}</i>があなたのアカウントにアクセスすることを<b>許可</b>しますか?" | ||||
|   permission-ask: "このアプリは次の権限を要求しています:" | ||||
| @@ -396,6 +417,7 @@ common/views/components/signin.vue: | ||||
|   signin: "サインイン" | ||||
|   or: "または" | ||||
|   signin-with-twitter: "Twitterでログイン" | ||||
|   signin-with-github: "GitHubでログイン" | ||||
|   login-failed: "ログインできませんでした。ユーザー名とパスワードを確認してください。" | ||||
|  | ||||
| common/views/components/signup.vue: | ||||
| @@ -439,6 +461,14 @@ common/views/components/twitter-setting.vue: | ||||
|   connect: "Twitterと接続する" | ||||
|   disconnect: "切断する" | ||||
|  | ||||
| common/views/components/github-setting.vue: | ||||
|   description: "お使いのGitHubアカウントをお使いのMisskeyアカウントに接続しておくと、プロフィールでGitHubアカウント情報が表示されるようになったり、GitHubを用いた便利なサインインを利用できるようになります。" | ||||
|   connected-to: "次のGitHubアカウントに接続されています" | ||||
|   detail: "詳細..." | ||||
|   reconnect: "再接続する" | ||||
|   connect: "GitHubと接続する" | ||||
|   disconnect: "切断する" | ||||
|  | ||||
| common/views/components/uploader.vue: | ||||
|   waiting: "待機中" | ||||
|  | ||||
| @@ -456,6 +486,26 @@ common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
|  | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   careful-bot: "Botからのフォローだけ承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
|  | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "確認中" | ||||
|   no-broadcasts: "お知らせはありません" | ||||
| @@ -558,29 +608,6 @@ desktop/views/components/calendar.vue: | ||||
|   next: "次の月" | ||||
|   go: "クリックして時間遡行" | ||||
|  | ||||
| desktop/views/components/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の積算" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の積算" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
|  | ||||
| desktop/views/components/choose-file-from-drive-window.vue: | ||||
|   choose-file: "ファイル選択中" | ||||
|   upload: "PCからドライブにファイルをアップロード" | ||||
| @@ -600,7 +627,6 @@ desktop/views/components/crop-window.vue: | ||||
|  | ||||
| desktop/views/components/drive-window.vue: | ||||
|   used: "使用中" | ||||
|   drive: "ドライブ" | ||||
|  | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "アイコン" | ||||
| @@ -633,9 +659,6 @@ desktop/views/components/drive.folder.vue: | ||||
|     rename-folder: "フォルダ名の変更" | ||||
|     input-new-folder-name: "新しいフォルダ名を入力してください" | ||||
|  | ||||
| desktop/views/components/drive.nav-folder.vue: | ||||
|   drive: "ドライブ" | ||||
|  | ||||
| desktop/views/components/drive.vue: | ||||
|   search: "検索" | ||||
|   load-more: "もっと読み込む" | ||||
| @@ -718,7 +741,7 @@ desktop/views/components/note-detail.vue: | ||||
|   renote: "Renote" | ||||
|   add-reaction: "リアクション" | ||||
|  | ||||
| desktop/views/components/notes.note.vue: | ||||
| desktop/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   reply: "返信" | ||||
|   renote: "Renote" | ||||
| @@ -793,8 +816,8 @@ desktop/views/components/settings.vue: | ||||
|   profile: "プロフィール" | ||||
|   notification: "通知" | ||||
|   apps: "アプリ" | ||||
|   mute: "ミュート" | ||||
|   drive: "ドライブ" | ||||
|   mute-and-block: "ミュート/ブロック" | ||||
|   blocking: "ブロック" | ||||
|   security: "セキュリティ" | ||||
|   signin: "サインイン履歴" | ||||
|   password: "パスワード" | ||||
| @@ -814,9 +837,13 @@ desktop/views/components/settings.vue: | ||||
|   advanced: "詳細設定" | ||||
|   api-via-stream: "ストリームを経由したAPIリクエスト" | ||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|  | ||||
|   display: "デザインと表示" | ||||
|   customize: "ホームをカスタマイズ" | ||||
|   wallpaper: "壁紙" | ||||
|   choose-wallpaper: "壁紙を選択" | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
| @@ -828,10 +855,14 @@ desktop/views/components/settings.vue: | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   timeline: "タイムライン" | ||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|  | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
| @@ -839,9 +870,6 @@ desktop/views/components/settings.vue: | ||||
|   volume: "ボリューム" | ||||
|   test: "テスト" | ||||
|  | ||||
|   mobile: "モバイル" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|  | ||||
|   language: "言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
| @@ -883,6 +911,11 @@ desktop/views/components/settings.vue: | ||||
|   task-manager: "タスクマネージャ" | ||||
|   third-parties: "サードパーティ" | ||||
|  | ||||
|   navbar-position: "ナビゲーションバーの位置" | ||||
|   navbar-position-top: "上" | ||||
|   navbar-position-left: "左" | ||||
|   navbar-position-right: "右" | ||||
|  | ||||
| desktop/views/components/settings.2fa.vue: | ||||
|   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" | ||||
|   detail: "詳細..." | ||||
| @@ -902,25 +935,37 @@ desktop/views/components/settings.2fa.vue: | ||||
|   failed: "設定に失敗しました。トークンに誤りがないかご確認ください。" | ||||
|   info: "次回サインインからは、同様にパスワードに加えてデバイスに表示されているトークンを入力します。" | ||||
|  | ||||
| desktop/views/components/settings.api.vue: | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
|   regeneration-of-token: "万が一このトークンが漏れたりその可能性がある場合はトークンを再生成できます。" | ||||
|   regenerate-token: "トークンを再生成" | ||||
|   token: "Token:" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   console: | ||||
|     title: 'APIコンソール' | ||||
|     endpoint: 'エンドポイント' | ||||
|     parameter: 'パラメータ' | ||||
|     send: '送信' | ||||
|     sending: '応答待ち' | ||||
|     response: '結果' | ||||
|  | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "連携しているアプリケーションはありません" | ||||
|  | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "中" | ||||
| common/views/components/drive-settings.vue: | ||||
|   max: "容量" | ||||
|   in-use: "使用中" | ||||
|   stats: "統計" | ||||
|  | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "ミュートしているユーザーはいません" | ||||
| common/views/components/mute-and-block.vue: | ||||
|   mute-and-block: "ミュートとブロック" | ||||
|   mute: "ミュート" | ||||
|   block: "ブロック" | ||||
|   no-muted-users: "ミュートしているユーザーはいません" | ||||
|   no-blocked-users: "ブロックしているユーザーはいません" | ||||
|  | ||||
| desktop/views/components/settings.password.vue: | ||||
| common/views/components/password-settings.vue: | ||||
|   reset: "パスワードを変更する" | ||||
|   enter-current-password: "現在のパスワードを入力してください" | ||||
|   enter-new-password: "新しいパスワードを入力してください" | ||||
| @@ -928,21 +973,6 @@ desktop/views/components/settings.password.vue: | ||||
|   not-match: "新しいパスワードが一致しません" | ||||
|   changed: "パスワードを変更しました" | ||||
|  | ||||
| desktop/views/components/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   choice-avatar: "画像を選択" | ||||
|   name: "名前" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   profile-updated: "プロフィールを更新しました" | ||||
|  | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| @@ -971,7 +1001,6 @@ desktop/views/components/ui.header.vue: | ||||
|  | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "プロフィール" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
| @@ -1024,55 +1053,114 @@ desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "閉じる" | ||||
|  | ||||
| desktop/views/pages/admin/admin.vue: | ||||
| admin/views/index.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "ドライブ" | ||||
|   instance: "インスタンス" | ||||
|   emoji: "カスタム絵文字" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
|   announcements: "お知らせ" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
|  | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   invite: "招待" | ||||
|   accounts: "アカウント" | ||||
|   notes: "投稿" | ||||
|   drive: "ドライブ" | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "このインスタンス" | ||||
|   federated: "連合" | ||||
|  | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
| admin/views/instance.vue: | ||||
|   instance: "インスタンス" | ||||
|   instance-name: "インスタンス名" | ||||
|   instance-description: "インスタンスの紹介" | ||||
|   banner-url: "バナー画像URL" | ||||
|   disableRegistration: "ユーザー登録の受付を停止する" | ||||
|   disableLocalTimeline: "ローカルタイムラインを無効にする" | ||||
|   invite: "招待" | ||||
|   save: "保存" | ||||
|  | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の積算" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の積算" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
|  | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
|  | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|  | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
|  | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|  | ||||
| admin/views/emoji.vue: | ||||
|   add-emoji: | ||||
|     title: "絵文字の登録" | ||||
|     name: "絵文字名" | ||||
|     name-desc: "a~z 0~9 _ の文字が使えます。" | ||||
|     aliases: "エイリアス" | ||||
|     aliases-desc: "スペースで区切って複数設定できます。" | ||||
|     url: "絵文字画像URL" | ||||
|     add: "追加" | ||||
|   emojis: | ||||
|     title: "絵文字一覧" | ||||
|     update: "更新" | ||||
|     remove: "削除" | ||||
|  | ||||
| admin/views/announcements.vue: | ||||
|   announcements: "お知らせ" | ||||
|   save: "保存" | ||||
|   remove: "削除" | ||||
|   add: "追加" | ||||
|   title: "タイトル" | ||||
|   text: "内容" | ||||
|  | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
|  | ||||
| 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: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|  | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
| desktop/views/pages/deck/deck.user-column.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   images: "画像" | ||||
|   activity: "アクティビティ" | ||||
|   timeline: "タイムライン" | ||||
|   pinned-notes: "ピン留めされた投稿" | ||||
|   push-to-a-list: "リストに追加" | ||||
|  | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "詳しく..." | ||||
| @@ -1133,10 +1221,6 @@ desktop/views/pages/user/user.friends.vue: | ||||
|  | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
|  | ||||
| desktop/views/pages/user/user.home.vue: | ||||
|   last-used-at: "最終アクセス" | ||||
|  | ||||
| desktop/views/pages/user/user.photos.vue: | ||||
| @@ -1152,6 +1236,9 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "ミュートする" | ||||
|   muted: "ミュートしています" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロックする" | ||||
|   unblock: "ブロック解除" | ||||
|   block-confirm: "このユーザーをブロックしますか?" | ||||
|   push-to-a-list: "リストに追加" | ||||
|   list-pushed: "{user}を{list}に追加しました。" | ||||
|  | ||||
| @@ -1160,6 +1247,10 @@ desktop/views/pages/user/user.header.vue: | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   years-old: "歳" | ||||
|   year: "年" | ||||
|   month: "月" | ||||
|   day: "日" | ||||
|  | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "投稿" | ||||
| @@ -1198,7 +1289,6 @@ desktop/views/widgets/users.vue: | ||||
|   no-one: "いません!" | ||||
|  | ||||
| mobile/views/components/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   used: "使用中" | ||||
|   folder-count: "フォルダ" | ||||
|   count-separator: "、" | ||||
| @@ -1233,6 +1323,8 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
|  | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
| @@ -1320,7 +1412,6 @@ mobile/views/components/ui.nav.vue: | ||||
|   messaging: "メッセージ" | ||||
|   follow-requests: "フォロー申請" | ||||
|   search: "検索" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   user-lists: "リスト" | ||||
|   widgets: "ウィジェット" | ||||
| @@ -1348,7 +1439,6 @@ mobile/views/pages/user-lists.vue: | ||||
|   enter-list-name: "リスト名を入力してください" | ||||
|  | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   more: "もっと見る" | ||||
|  | ||||
| mobile/views/pages/signup.vue: | ||||
| @@ -1409,24 +1499,6 @@ mobile/views/pages/notifications.vue: | ||||
| mobile/views/pages/games/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
|  | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
|  | ||||
| mobile/views/pages/search.vue: | ||||
|   search: "検索" | ||||
|   empty: "「{}」に関する投稿は見つかりませんでした。" | ||||
| @@ -1471,6 +1543,10 @@ mobile/views/pages/settings.vue: | ||||
|   twitter-connect: "Twitterアカウントに接続する" | ||||
|   twitter-reconnect: "再接続する" | ||||
|   twitter-disconnect: "切断する" | ||||
|   github: "GitHub連携" | ||||
|   github-connect: "GitHubアカウントに接続する" | ||||
|   github-reconnect: "再接続する" | ||||
|   github-disconnect: "切断する" | ||||
|   update: "Misskey Update" | ||||
|   version: "バージョン:" | ||||
|   latest-version: "最新のバージョン:" | ||||
| @@ -1484,6 +1560,8 @@ mobile/views/pages/settings.vue: | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   mark-as-read-all-unread-notes: "すべての投稿を既読にする" | ||||
|   password: "パスワード" | ||||
|  | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
| @@ -1494,8 +1572,10 @@ mobile/views/pages/user.vue: | ||||
|   timeline: "タイムライン" | ||||
|   media: "メディア" | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
|   mute: "ミュート" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
|  | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "最近の投稿" | ||||
| @@ -1549,3 +1629,31 @@ docs: | ||||
|  | ||||
| dev/views/index.vue: | ||||
|   manage-apps: "アプリの管理" | ||||
|  | ||||
| dev/views/apps.vue: | ||||
|   manage-apps: "アプリを管理" | ||||
|   create-app: "アプリ作成" | ||||
|   app-missing: "アプリなし" | ||||
|  | ||||
| dev/views/new-app.vue: | ||||
|   create-app: "アプリケーションの作成" | ||||
|   app-name: "アプリケーション名" | ||||
|   app-name-desc: "あなたのアプリの名称。" | ||||
|   app-name-ex: "ex) Misskey for iOS" | ||||
|   app-overview: "アプリの概要" | ||||
|   app-desc: "あなたのアプリの簡単な説明や紹介。" | ||||
|   app-desc-ex: "ex) Misskey iOSクライアント。" | ||||
|   callback-url: "コールバックURL (オプション)" | ||||
|   callback-url-desc: "ユーザーが認証フォームで認証した際にリダイレクトするURLを設定できます。" | ||||
|   authority: "権限" | ||||
|   authority-desc: "ここで要求した機能だけがAPIからアクセスできます。" | ||||
|   authority-warning: "アプリ作成後も変更できますが、新たな権限を付与する場合、その時点で関連付けられているユーザーキーはすべて無効になります。" | ||||
|   account-read: "アカウントの情報を見る。" | ||||
|   account-write: "アカウントの情報を操作する。" | ||||
|   note-write: "投稿する。" | ||||
|   reaction-write: "リアクションしたりリアクションをキャンセルする。" | ||||
|   following-write: "フォローしたりフォロー解除する。" | ||||
|   drive-read: "ドライブを見る。" | ||||
|   drive-write: "ドライブを操作する。" | ||||
|   notification-read: "通知を見る。" | ||||
|   notification-write: "通知を操作する。" | ||||
|   | ||||
| @@ -17,7 +17,7 @@ common: | ||||
|     ui: "インターフェイス" | ||||
|     ui-desc: "このUIええ言うてたで、知らんけど。あんたの好みのUIなんて知ったこっちゃない。Misskeyは好きにいじれるからな、レイアウトやデザイン変えたり、色んなウィジェットひっつけたりして、あんただけのMisskey作って楽しんでな!" | ||||
|     drive: "ドライブ" | ||||
|     drive-desc: "「こないだの画像、どこやったかな…また投稿したいんやけど…」「さっきのファイルあのフォルダに直しといて」そんなこと言わんとって。Misskeyはもとからドライブ機能持っとるさかい、心配あらへん。ファイルの「わけわけ」したってな。" | ||||
|     drive-desc: "「こないだの画像、どこやったかな……また投稿したいんやけど……」「さっきのファイルあのフォルダに直しといて」そんなこと言わんとって。Misskeyはもとからドライブ機能持っとるさかい、心配あらへん。ファイルの「わけわけ」したってな。" | ||||
|     outro: "Misskeyの機能は無限大や!知らんけど。知らん言うとるやんけ、あんたが見に行けや!Misskeyは分散型SNSやから、ここがあかんくても他がある。阪神でもオリックスでもワイは応援するで!" | ||||
|   adblock: | ||||
|     detected: "広告ブロッカーを無効にしてや" | ||||
| @@ -25,6 +25,14 @@ common: | ||||
|   application-authorization: "アプリの連携" | ||||
|   close: "さいなら" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりせんといてください。アカウントが不正利用されるかも分からん。知らんけど。" | ||||
|   BSoD: | ||||
|     fatal-error: "あかん、やってもうたわ… (致命的なエラー" | ||||
|     update-browser-os: "ブラウザ(またはOS)のバージョン更新してくれへん?なおるかもしれんわ。" | ||||
|     error-code: "エラーコード" | ||||
|     browser-version: "ブラウザ バージョン" | ||||
|     client-version: "クライアント バージョン" | ||||
|     email-support: "それでもあかん?せやったら syuilotan@yahoo.co.jp に連絡してや!" | ||||
|     thanks: "Thank you おおきに。Misskey" | ||||
|   got-it: "ほい" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
| @@ -54,6 +62,7 @@ common: | ||||
|     years_ago: "{}年前" | ||||
|   month-and-day: "{month}月 {day}日" | ||||
|   trash: "ゴミ箱" | ||||
|   drive: "ドライブ" | ||||
|   weekday-short: | ||||
|     sunday: "日" | ||||
|     monday: "月" | ||||
| @@ -115,6 +124,12 @@ common: | ||||
|   reduce-motion: "UI、動き過ぎや、静かにしてや" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   do-not-use-in-production: '開発ビルドや。本番環境で使わんといて!知らんで!' | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "ちゃんとした情報見せてや!" | ||||
|   error: | ||||
|     title: '問題が起こったわ' | ||||
|     retry: 'もっぺん' | ||||
|   reversi: | ||||
|     drawn: "おあいこ" | ||||
|     my-turn: "あんさんのターンや" | ||||
| @@ -170,6 +185,8 @@ common: | ||||
|     rename: "名前を変更や!" | ||||
|     stack-left: "左に重ねんで!" | ||||
|     pop-right: "右に出すで!" | ||||
|   dev: "アプリの作成あかんかったわ。もっぺんやってみて。" | ||||
|   ai-chan-kawaii: "藍ちゃめっさべっぴんさんや" | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{{ app.name }}</i>があんさんのアカウントにアクセスすんのを<b>許可</b>してもええか?" | ||||
|   permission-ask: "このアプリは次の権限を要求してんで:" | ||||
| @@ -265,40 +282,40 @@ common/views/components/media-banner.vue: | ||||
|   sensitive: "見せたらあかん" | ||||
|   click-to-show: "押してみ、見せたるわ" | ||||
| common/views/components/theme.vue: | ||||
|   light-theme: "非ダークモード時に使用するテーマ" | ||||
|   dark-theme: "ダークモード時に使用するテーマ" | ||||
|   light-themes: "明るいテーマ" | ||||
|   dark-themes: "暗いテーマ" | ||||
|   install-a-theme: "テーマのインストール" | ||||
|   light-theme: "ナイトゲームちゃう時のテーマどないする?" | ||||
|   dark-theme: "ナイトゲームの時のテーマどないする?" | ||||
|   light-themes: "デイゲーム" | ||||
|   dark-themes: "ナイトゲーム" | ||||
|   install-a-theme: "テーマ入れるで" | ||||
|   theme-code: "テーマコード" | ||||
|   install: "インストール" | ||||
|   installed: "「{}」をインストールしました" | ||||
|   create-a-theme: "テーマの作成" | ||||
|   save-created-theme: "テーマを保存" | ||||
|   primary-color: "プライマリ カラー" | ||||
|   secondary-color: "セカンダリ カラー" | ||||
|   text-color: "文字色" | ||||
|   base-theme: "ベーステーマ" | ||||
|   installed: "「{}」を入れたで!" | ||||
|   create-a-theme: "テーマ作る" | ||||
|   save-created-theme: "テーマ保存" | ||||
|   primary-color: "この色一番重要や" | ||||
|   secondary-color: "次はこの色出したって" | ||||
|   text-color: "文字はこの色や!" | ||||
|   base-theme: "この色が背景や!" | ||||
|   base-theme-light: "Light" | ||||
|   base-theme-dark: "Dark" | ||||
|   theme-name: "テーマ名" | ||||
|   preview-created-theme: "プレビュー" | ||||
|   invalid-theme: "テーマが正しくありません。" | ||||
|   already-installed: "既にそのテーマはインストールされています。" | ||||
|   saved: "保存しました" | ||||
|   preview-created-theme: "試してみる" | ||||
|   invalid-theme: "このテーマあかんわ、なんか間違うとる" | ||||
|   already-installed: "このテーマもうあるで" | ||||
|   saved: "保存したで!" | ||||
|   manage-themes: "テーマの管理" | ||||
|   builtin-themes: "標準テーマ" | ||||
|   my-themes: "マイテーマ" | ||||
|   installed-themes: "インストールされたテーマ" | ||||
|   select-theme: "テーマを選択してください" | ||||
|   uninstall: "アンインストール" | ||||
|   uninstalled: "「{}」をアンインストールしました" | ||||
|   author: "作者" | ||||
|   builtin-themes: "いつものテーマ" | ||||
|   my-themes: "ワイのテーマ" | ||||
|   installed-themes: "入れたテーマ" | ||||
|   select-theme: "テーマ選んでや!" | ||||
|   uninstall: "ほかす" | ||||
|   uninstalled: "「{}」をほかしてもうたわ" | ||||
|   author: "作った人" | ||||
|   desc: "説明" | ||||
|   export: "エクスポート" | ||||
|   import: "インポート" | ||||
|   import-by-code: "またはコードをペースト" | ||||
|   theme-name-required: "テーマ名は必須です。" | ||||
|   import-by-code: "それかコードを貼っつける" | ||||
|   theme-name-required: "テーマ名は絶対要るで" | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "もうええわ" | ||||
|   show: "見たいやろ?" | ||||
| @@ -335,6 +352,7 @@ common/views/components/note-menu.vue: | ||||
|   detail: "もっと" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   unfavorite: "お気に入りやめる" | ||||
|   pin: "ピン留め" | ||||
|   unpin: "ピン留めやめる" | ||||
|   delete: "ほかす" | ||||
| @@ -368,7 +386,7 @@ common/views/components/signup.vue: | ||||
|   invitation-code: "招待コード" | ||||
|   invitation-info: "招待コードをもっとらんのやったら、<a href=\"{}\">管理者</a>まで連絡してや。" | ||||
|   username: "ユーザー名" | ||||
|   checking: "確認中や…" | ||||
|   checking: "確認中や……" | ||||
|   available: "使えるで" | ||||
|   unavailable: "もう使われとるで" | ||||
|   error: "通信あかんわ" | ||||
| @@ -415,6 +433,25 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "流行は自分で作るんや" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatやで" | ||||
|   is-bot: "このアカウントはBotやで" | ||||
|   is-locked: "他人のフォローは許可してからや!" | ||||
|   careful-bot: "Botからのフォローだけは許可制や" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシーってなんや?オカンの年齢か?" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存したで" | ||||
|   uploading: "アップロードしとります" | ||||
|   upload-failed: "これアップロードでけへんわ" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "見てみるわ…" | ||||
|   no-broadcasts: "お知らせはあらへんで" | ||||
| @@ -475,7 +512,7 @@ common/views/pages/follow.vue: | ||||
|   following: "フォローしとる" | ||||
|   follow: "フォロー" | ||||
|   request-pending: "フォローの許し待っとる" | ||||
|   follow-processing: "フォロー処理中" | ||||
|   follow-processing: "今フォロー処理やっとる‥" | ||||
|   follow-request: "フォロー許してくれや!言うてみる" | ||||
| desktop: | ||||
|   banner-crop-title: "どこバナーとして出す?" | ||||
| @@ -490,10 +527,10 @@ desktop: | ||||
|   choose-avatar: "アバターにする画像選んでや" | ||||
|   invalid-filetype: "この形式のファイル無理やねん" | ||||
| desktop/views/components/activity.chart.vue: | ||||
|   total: "黒いの… 全部" | ||||
|   notes: "青いの… 投稿" | ||||
|   replies: "赤いの… 返信" | ||||
|   renotes: "みどり… Renotes" | ||||
|   total: "黒いの ... 全部" | ||||
|   notes: "青いの ... 投稿" | ||||
|   replies: "赤いの ... 返信" | ||||
|   renotes: "碧いの ... Renotes" | ||||
| desktop/views/components/activity.vue: | ||||
|   title: "アクティビティ" | ||||
|   toggle: "表示変える" | ||||
| @@ -506,11 +543,14 @@ desktop/views/components/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減(統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
| @@ -540,7 +580,6 @@ desktop/views/components/crop-window.vue: | ||||
|   ok: "そうする" | ||||
| desktop/views/components/drive-window.vue: | ||||
|   used: "使うとる" | ||||
|   drive: "ドライブ" | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
| @@ -551,7 +590,7 @@ desktop/views/components/drive.file.vue: | ||||
|     unmark-as-sensitive: "やっぱ見せたるわ" | ||||
|     copy-url: "URLをコピー" | ||||
|     download: "ダウンロード" | ||||
|     else-files: "もっとあるで…" | ||||
|     else-files: "まだあんで..." | ||||
|     set-as-avatar: "アイコンにする" | ||||
|     set-as-banner: "バナーにする" | ||||
|     open-in-app: "アプリで開く" | ||||
| @@ -570,8 +609,6 @@ desktop/views/components/drive.folder.vue: | ||||
|     rename: "名前を変えるで" | ||||
|     rename-folder: "フォルダ名を変えるで" | ||||
|     input-new-folder-name: "新しいフォルダ名を入力してや" | ||||
| desktop/views/components/drive.nav-folder.vue: | ||||
|   drive: "ドライブ" | ||||
| desktop/views/components/drive.vue: | ||||
|   search: "検索" | ||||
|   load-more: "もっとあらへんのか!" | ||||
| @@ -585,7 +622,7 @@ desktop/views/components/drive.vue: | ||||
|   url-upload: "URLアップロード" | ||||
|   url-of-file: "このURLのファイルをアップロードしたいねん" | ||||
|   url-upload-requested: "アップロードしたい言うといたで" | ||||
|   may-take-time: "アップロード終わるまで時間かかるわ、知らんけど。たこ焼き何個食べれるやろか…" | ||||
|   may-take-time: "アップロード終わるんにちょい時間かかるかもしれへんわ。" | ||||
|   create-folder: "フォルダー作成" | ||||
|   folder-name: "フォルダー名" | ||||
|   contextmenu: | ||||
| @@ -602,7 +639,7 @@ desktop/views/components/follow-button.vue: | ||||
|   following: "フォローしとる" | ||||
|   follow: "フォロー" | ||||
|   request-pending: "フォローの許し待っとる" | ||||
|   follow-processing: "フォロー処理中" | ||||
|   follow-processing: "今フォロー処理やっとる‥" | ||||
|   follow-request: "フォロー許してくれや!言うてみる" | ||||
| desktop/views/components/followers-window.vue: | ||||
|   followers: "{} のフォロワー" | ||||
| @@ -615,7 +652,7 @@ desktop/views/components/following.vue: | ||||
| desktop/views/components/friends-maker.vue: | ||||
|   title: "おもろそうやな:" | ||||
|   empty: "おもろいユーザー居らんかったわ" | ||||
|   fetching: "読みこんどるで…" | ||||
|   fetching: "読み込んどります" | ||||
|   refresh: "もっとあるやろ!" | ||||
|   close: "さいなら" | ||||
| desktop/views/components/game-window.vue: | ||||
| @@ -639,7 +676,7 @@ desktop/views/components/note-detail.vue: | ||||
|   location: "ここおるで:" | ||||
|   renote: "Renote" | ||||
|   add-reaction: "リアクション" | ||||
| desktop/views/components/notes.note.vue: | ||||
| desktop/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   reply: "返す" | ||||
|   renote: "Renote" | ||||
| @@ -687,11 +724,11 @@ desktop/views/components/post-form-window.vue: | ||||
|   note: "新規投稿" | ||||
|   reply: "返す" | ||||
|   attaches: "添付: {}メディア" | ||||
|   uploading-media: "{}個のメディアを上げてるで…" | ||||
|   uploading-media: "{}個のメディアを上げとんねん……" | ||||
| desktop/views/components/progress-dialog.vue: | ||||
|   waiting: "待っとる" | ||||
| desktop/views/components/renote-form.vue: | ||||
|   quote: "持ってくる…" | ||||
|   quote: "取ってくる……" | ||||
|   cancel: "やめとくわ" | ||||
|   renote: "Renote" | ||||
|   reposting: "やっとります..." | ||||
| @@ -705,9 +742,9 @@ desktop/views/components/settings.vue: | ||||
|   profile: "プロフィール" | ||||
|   notification: "通知" | ||||
|   apps: "アプリ" | ||||
|   mute: "ミュート" | ||||
|   drive: "ドライブ" | ||||
|   security: "守護神セキュリティ" | ||||
|   mute-and-block: "ミュート/ブロック" | ||||
|   blocking: "ブロック" | ||||
|   security: "セキュリティ" | ||||
|   signin: "こんな感じでサインインしたらしいで" | ||||
|   password: "パスワード" | ||||
|   2fa: "二段階認証" | ||||
| @@ -725,8 +762,12 @@ desktop/views/components/settings.vue: | ||||
|   advanced: "もっと設定" | ||||
|   api-via-stream: "ストリームを経由したAPIリクエスト" | ||||
|   api-via-stream-desc: "この設定をオンにすると、WebSocket接続を経由してAPIリクエストが行われんで(パフォーマンス向上するかも、知らんけど)。オフにすると、ネイティブの fetch API が利用されるで。この設定はこのデバイスのみ有効やで。" | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使うとるとき、ナビゲーションが発生するときにページ移動せんで、一時的なカラムで受けれるようにするで" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "見た感じ" | ||||
|   customize: "ホームをカスタマイズ" | ||||
|   wallpaper: "壁紙" | ||||
|   choose-wallpaper: "壁紙選ぶ" | ||||
|   delete-wallpaper: "壁紙ほかす" | ||||
|   dark-mode: "夜にすんで" | ||||
| @@ -738,17 +779,19 @@ desktop/views/components/settings.vue: | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示すんで" | ||||
|   show-clock-on-header: "右上をカリヨン広場にする(時計表示)" | ||||
|   show-reply-target: "どこにリプライするんや見せて" | ||||
|   timeline: "タイムライン" | ||||
|   show-my-renotes: "わしのRenoteもタイムライン載せてくれや" | ||||
|   show-renoted-my-notes: "わしのRenoteもタイムライン載せてくれや" | ||||
|   show-local-renotes: "ローカル投稿のRenoteも見たいんや" | ||||
|   show-maps: "地図勝手にバァーって開いてくれ" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align-center: "真ん中" | ||||
|   deck-column-align-left: "左" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンド鳴らす" | ||||
|   enable-sounds-desc: "投稿やメッセージもろたとき、音鳴らしたるわ。大丈夫や、この設定はブラウザが覚えてくれとる。" | ||||
|   volume: "ボリューム" | ||||
|   test: "テスト" | ||||
|   mobile: "モバイル" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグなんて要らんわ" | ||||
|   language: "言語" | ||||
|   pick-language: "言語選んでや" | ||||
|   recommended: "おすすめ" | ||||
| @@ -767,7 +810,7 @@ desktop/views/components/settings.vue: | ||||
|   update: "Misskey Update" | ||||
|   version: "バージョン:" | ||||
|   latest-version: "最新のバージョン:" | ||||
|   update-checking: "アップデートはあらへんか…" | ||||
|   update-checking: "アップデートはあらへんか……" | ||||
|   do-update: "アップデートあるか見てみる" | ||||
|   update-settings: "もっと設定" | ||||
|   prevent-update: "アップデートしたないわ、また今度や(やめときや)" | ||||
| @@ -784,6 +827,10 @@ desktop/views/components/settings.vue: | ||||
|   tools: "ツール" | ||||
|   task-manager: "タスクマネージャ" | ||||
|   third-parties: "サードパーティ" | ||||
|   navbar-position: "ナビゲーションバーの位置" | ||||
|   navbar-position-top: "上" | ||||
|   navbar-position-left: "左" | ||||
|   navbar-position-right: "右" | ||||
| desktop/views/components/settings.2fa.vue: | ||||
|   intro: "二段階認証を設定すると、サインイン時にパスワードだけとちゃうくて、予め登録しておいた物理的なデバイス(例えばあんさんのスマートフォンなど)も必要になり、よりセキュリティが向上すんで。" | ||||
|   detail: "詳細..." | ||||
| @@ -802,41 +849,39 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "設定が完了したで!" | ||||
|   failed: "なんか設定に失敗したで。トークンを間違えとらんか確認してや。" | ||||
|   info: "次のサインインからは、パスワードに加えてデバイスに出とるトークンを入力してな。" | ||||
| desktop/views/components/settings.api.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」っちゅうキーでパラメータに付加してリクエストしてや。" | ||||
|   caution: "アカウントを不正利用されるかも知れんから、このトークンは第三者に教えたらあかんで(アプリなどにも入力しんといてな)。" | ||||
|   regeneration-of-token: "万が一このトークンが漏れたとかその可能性があったらトークンを再生成できるで。" | ||||
|   regenerate-token: "トークンを再生成" | ||||
|   token: "トークン:" | ||||
|   enter-password: "パスワードを入力してや" | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "API使うんやったらこのトークンを「i」っちゅうパラメータにくっつけてリクエストできるで。" | ||||
|   caution: "アカウント勝手にいじられるかも知れんから、このトークンは教えたらあかんし、アプリにも書いたらあかんで(これはフリちゃうで)" | ||||
|   regeneration-of-token: "トークン漏れてもうたんやったらもっかい生成できるで。" | ||||
|   regenerate-token: "トークンもっかい生成" | ||||
|   token: "Token:" | ||||
|   enter-password: "パスワードを入れてや" | ||||
|   console: | ||||
|     title: 'APIコンソール' | ||||
|     endpoint: 'エンドポイント' | ||||
|     parameter: 'パラメータ' | ||||
|     send: '送る' | ||||
|     sending: '応答待っとる' | ||||
|     response: 'こんなん返ってきたわ' | ||||
| 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: | ||||
|   reset: "パスワードを変更する" | ||||
| common/views/components/drive-settings.vue: | ||||
|   max: "容量" | ||||
|   in-use: "使うとる" | ||||
|   stats: "統計" | ||||
| common/views/components/mute-and-block.vue: | ||||
|   mute-and-block: "ミュートとブロック" | ||||
|   mute: "ミュート" | ||||
|   block: "ブロック" | ||||
|   no-muted-users: "ミュートしとるユーザーはおらんで" | ||||
|   no-blocked-users: "ブロックしとるユーザーはおらんで" | ||||
| common/views/components/password-settings.vue: | ||||
|   reset: "パスワード変える" | ||||
|   enter-current-password: "今のパスワードを入れてや" | ||||
|   enter-new-password: "さらのパスワード入れてや" | ||||
|   enter-new-password-again: "もういっぺんさらのパスワードを入れてや" | ||||
|   enter-new-password: "こんどのパスワード入れてや" | ||||
|   enter-new-password-again: "もっぺん入れてや" | ||||
|   not-match: "パスワードがおうとらん" | ||||
|   changed: "パスワード変えたわ" | ||||
| desktop/views/components/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   choice-avatar: "画像選んでや" | ||||
|   name: "名前" | ||||
|   location: "場所" | ||||
|   description: "ワイのこと" | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウント守る" | ||||
|   is-locked: "他人のフォローは許可してからや!" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotやで" | ||||
|   is-cat: "このアカウントはCatやで" | ||||
|   profile-updated: "プロフィールを更新したで" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は見せられへんわ" | ||||
|   deleted: "この投稿なんか無くなってもうたわ" | ||||
| @@ -861,7 +906,6 @@ desktop/views/components/ui.header.vue: | ||||
|   adjective: "はん" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "プロフィール" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー許してくれや!言うてみる" | ||||
| @@ -897,59 +941,117 @@ desktop/views/components/users-list.vue: | ||||
|   all: "すべて" | ||||
|   iknow: "知っとる" | ||||
|   load-more: "もっと" | ||||
|   fetching: "読みこんどるで…" | ||||
|   fetching: "読み込んどります" | ||||
| desktop/views/components/users-list-item.vue: | ||||
|   followed: "フォローされとるで" | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "さいなら" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
| admin/views/index.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "ドライブ" | ||||
|   instance: "インスタンス" | ||||
|   emoji: "カスタム絵文字" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   announcements: "知っといてや" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "知り合い全員や" | ||||
|   original-users: "ここの人らだけ" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   accounts: "アカウント" | ||||
|   notes: "投稿" | ||||
|   drive: "ドライブ" | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "ワイのインスタンス" | ||||
|   federated: "連合" | ||||
|   invite: "来てや" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   banner-url: "Banner URL" | ||||
|   disableRegistration: "Disable new user registration" | ||||
|   disableLocalTimeline: "Disable the local timeline" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減(統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の積算" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の積算" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結したで" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除したで" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしたで" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウントにせーへん" | ||||
|   unverify: "公式アカウントにはさせへんで" | ||||
|   unverified: "公式アカウントを解除したで" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| admin/views/emoji.vue: | ||||
|   add-emoji: | ||||
|     title: "絵文字の登録" | ||||
|     name: "絵文字名" | ||||
|     name-desc: "a~z 0~9 _ の文字が使えます。" | ||||
|     aliases: "エイリアス" | ||||
|     aliases-desc: "スペースで区切って複数設定できます。" | ||||
|     url: "絵文字画像URL" | ||||
|     add: "追加" | ||||
|   emojis: | ||||
|     title: "絵文字一覧" | ||||
|     update: "更新" | ||||
|     remove: "削除" | ||||
| admin/views/announcements.vue: | ||||
|   announcements: "お知らせ" | ||||
|   save: "保存" | ||||
|   remove: "削除" | ||||
|   add: "追加" | ||||
|   title: "タイトル" | ||||
|   text: "内容" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| 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: "この投稿は見せられへんわ" | ||||
|   deleted: "この投稿なんか無くなってもうたわ" | ||||
| desktop/views/pages/deck/deck.user-column.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   images: "画像" | ||||
|   activity: "やっとること" | ||||
|   timeline: "タイムライン" | ||||
|   pinned-notes: "ピン留めしはった投稿" | ||||
|   push-to-a-list: "リストに入れたる" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "ここの人らだけ" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
| desktop/views/pages/welcome.vue: | ||||
|   about: "もっと…" | ||||
|   about: "もうちょい……" | ||||
|   gotit: "ほい" | ||||
|   signin: "サインイン" | ||||
|   signup: "サインアップ" | ||||
|   signin-button: "サインイン中…" | ||||
|   signin-button: "やっとる" | ||||
|   signup-button: "サインアップ" | ||||
|   timeline: "タイムライン" | ||||
|   announcements: "知っときや" | ||||
| @@ -983,21 +1085,18 @@ desktop/views/pages/user-list.users.vue: | ||||
|   username: "ユーザー名" | ||||
| desktop/views/pages/user/user.followers-you-know.vue: | ||||
|   title: "知っとるフォロワー" | ||||
|   loading: "読み込んどる…" | ||||
|   loading: "読み込んどります" | ||||
|   no-users: "フォロワー全員知らんわ" | ||||
| desktop/views/pages/user/user.friends.vue: | ||||
|   title: "よう話すツレ" | ||||
|   loading: "読み込んどる…" | ||||
|   loading: "読み込んどります" | ||||
|   no-users: "よう話すツレは居らん" | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "このユーザーはあかんわ。凍結されとる。" | ||||
|   is-remote: "このユーザーはリモートユーザーや。" | ||||
|   view-remote: "ちゃんとした情報を見る" | ||||
| desktop/views/pages/user/user.home.vue: | ||||
|   last-used-at: "最後いつ来た?" | ||||
|   last-used-at: "最後いつ来はった?" | ||||
| desktop/views/pages/user/user.photos.vue: | ||||
|   title: "写真" | ||||
|   loading: "読み込んどる…" | ||||
|   loading: "読み込んどります" | ||||
|   no-photos: "写真はあらへんで" | ||||
| desktop/views/pages/user/user.profile.vue: | ||||
|   follows-you: "フォローされとるで" | ||||
| @@ -1007,6 +1106,9 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "ミュートする" | ||||
|   muted: "ミュートしとるで" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロックする" | ||||
|   unblock: "ブロック解除" | ||||
|   block-confirm: "このユーザーをブロックしますか?" | ||||
|   push-to-a-list: "リストに追加" | ||||
|   list-pushed: "{user}を{list}に追加したで。" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| @@ -1014,6 +1116,10 @@ desktop/views/pages/user/user.header.vue: | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   is-bot: "このアカウントはBotや" | ||||
|   years-old: "歳" | ||||
|   year: "年" | ||||
|   month: "月" | ||||
|   day: "日" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "投稿" | ||||
|   with-replies: "投稿と返信" | ||||
| @@ -1043,7 +1149,6 @@ desktop/views/widgets/users.vue: | ||||
|   refresh: "他を見る" | ||||
|   no-one: "おらん!" | ||||
| mobile/views/components/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   used: "使うとる" | ||||
|   folder-count: "フォルダ" | ||||
|   count-separator: "、" | ||||
| @@ -1073,6 +1178,8 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   hash: "ハッシュ(md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "ちょっと見せられへんわ" | ||||
|   mark-as-sensitive: "見たらあかん感じにしとく" | ||||
|   unmark-as-sensitive: "やっぱ見せたるわ" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "見たらあかんで" | ||||
|   click-to-show: "押してみ、見せたるわ" | ||||
| @@ -1083,12 +1190,12 @@ mobile/views/components/follow-button.vue: | ||||
|   following: "フォローしとる" | ||||
|   follow: "フォロー" | ||||
|   request-pending: "フォローの許し待っとる" | ||||
|   follow-processing: "フォロー処理中" | ||||
|   follow-processing: "今フォロー処理やっとる‥" | ||||
|   follow-request: "フォロー許してくれや!言うてみる" | ||||
| mobile/views/components/friends-maker.vue: | ||||
|   title: "おもろそうやな" | ||||
|   empty: "おすすめのユーザーはおらん。" | ||||
|   fetching: "読みこんどるで…" | ||||
|   fetching: "読み込んどります" | ||||
|   refresh: "もっとあるやろ!" | ||||
|   close: "さいなら" | ||||
| mobile/views/components/note.vue: | ||||
| @@ -1145,7 +1252,6 @@ mobile/views/components/ui.nav.vue: | ||||
|   messaging: "メッセージ" | ||||
|   follow-requests: "フォロー許してくれや!言うてみる" | ||||
|   search: "検索" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   user-lists: "リスト" | ||||
|   widgets: "ウィジェット" | ||||
| @@ -1168,7 +1274,6 @@ mobile/views/pages/user-lists.vue: | ||||
|   title: "リスト" | ||||
|   enter-list-name: "リスト名を入力してや" | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   more: "もっとあるやろ!" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "📦 始めようや" | ||||
| @@ -1213,23 +1318,6 @@ mobile/views/pages/notifications.vue: | ||||
|   read-all: "通知全部読んだか?" | ||||
| mobile/views/pages/games/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "ワイのこと" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatや" | ||||
|   is-locked: "他人のフォローは許してからや!" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー⇔オカンの年齢" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存したで" | ||||
|   uploading: "アップロードしとるで…" | ||||
|   upload-failed: "これアップロードでけへんわ" | ||||
| mobile/views/pages/search.vue: | ||||
|   search: "探す" | ||||
|   empty: "ワイは「{}」なんて投稿知らんわ、無いんちゃう?知らんけど。" | ||||
| @@ -1245,7 +1333,7 @@ mobile/views/pages/settings.vue: | ||||
|   specify-language: "言語選びや" | ||||
|   design: "見た感じ" | ||||
|   dark-mode: "ナイトゲームや!" | ||||
|   i-am-under-limited-internet: "電波がバァーっといけへんねん" | ||||
|   i-am-under-limited-internet: "電波と阪神がザコいんや" | ||||
|   circle-icons: "アイコンもタコ焼きも丸いやんな?" | ||||
|   contrasted-acct: "ユーザー名ようわからんし見やすしといて" | ||||
|   timeline: "タイムライン" | ||||
| @@ -1257,8 +1345,8 @@ mobile/views/pages/settings.vue: | ||||
|   post-style-standard: "標準" | ||||
|   post-style-smart: "べっぴんさん" | ||||
|   notification-position: "通知どこ見せる?" | ||||
|   notification-position-bottom: "ミナミ" | ||||
|   notification-position-top: "キタ" | ||||
|   notification-position-bottom: "ミナミの方" | ||||
|   notification-position-top: "キタの方" | ||||
|   theme: "テーマ" | ||||
|   behavior: "動き" | ||||
|   fetch-on-scroll: "スクロールしたらもっと見せてや" | ||||
| @@ -1275,7 +1363,7 @@ mobile/views/pages/settings.vue: | ||||
|   update: "あんたのMisskeyいつのや?" | ||||
|   version: "バージョン:" | ||||
|   latest-version: "いっちゃん新しいやつ:" | ||||
|   update-checking: "アップデートはあらへんか…" | ||||
|   update-checking: "アップデートあるか見とるで" | ||||
|   check-for-updates: "アップデートあるんかな?" | ||||
|   no-updates: "アップデートあらへんわ" | ||||
|   no-updates-desc: "つこてるMisskeyは最新や!" | ||||
| @@ -1285,6 +1373,8 @@ mobile/views/pages/settings.vue: | ||||
|   signout: "さいなら" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンド鳴らす" | ||||
|   mark-as-read-all-unread-notes: "全部もう読んだわ" | ||||
|   password: "パスワード" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされとるで" | ||||
|   following: "フォロー" | ||||
| @@ -1294,8 +1384,10 @@ mobile/views/pages/user.vue: | ||||
|   timeline: "タイムライン" | ||||
|   media: "メディア" | ||||
|   is-suspended: "このユーザーはあかんわ。凍結されとる。" | ||||
|   is-remote: "このユーザーは東京とかそこらへんのリモートユーザーや。" | ||||
|   view-remote: "ちゃんとした情報を見る" | ||||
|   mute: "ミュート" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロックやめたる" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "最近儲かりまっか?" | ||||
|   images: "画像" | ||||
| @@ -1306,16 +1398,16 @@ mobile/views/pages/user/home.vue: | ||||
|   followers-you-know: "知っとるフォロワー" | ||||
|   last-used-at: "最後いつ来た?" | ||||
| mobile/views/pages/user/home.followers-you-know.vue: | ||||
|   loading: "読み込んどる…" | ||||
|   loading: "読み込んどります" | ||||
|   no-users: "知っとるユーザーは居らん" | ||||
| mobile/views/pages/user/home.friends.vue: | ||||
|   loading: "読み込んどる…" | ||||
|   loading: "読み込んどります" | ||||
|   no-users: "よう話すユーザーは居らん" | ||||
| mobile/views/pages/user/home.notes.vue: | ||||
|   loading: "読み込んどる…" | ||||
|   loading: "読み込んどります" | ||||
|   no-notes: "投稿はあらへん" | ||||
| mobile/views/pages/user/home.photos.vue: | ||||
|   loading: "読み込んどる…" | ||||
|   loading: "読み込んどります" | ||||
|   no-photos: "写真はあらへんで" | ||||
| docs: | ||||
|   edit-this-page-on-github: "間違いや改善点を見つけましたか?" | ||||
| @@ -1341,3 +1433,29 @@ docs: | ||||
|       description: "説明" | ||||
| dev/views/index.vue: | ||||
|   manage-apps: "アプリの管理" | ||||
| dev/views/apps.vue: | ||||
|   manage-apps: "アプリを管理" | ||||
|   create-app: "アプリ作る" | ||||
|   app-missing: "アプリあらへん" | ||||
| dev/views/new-app.vue: | ||||
|   create-app: "アプリケーション作る" | ||||
|   app-name: "アプリケーションの名前" | ||||
|   app-name-desc: "あんたのアプリの名前。" | ||||
|   app-name-ex: "ex) 関西ミスキー保安協会" | ||||
|   app-overview: "このアプリどんなん?" | ||||
|   app-desc: "あんたのアプリどんなんか教えて" | ||||
|   app-desc-ex: "ex) 関西人なら誰でも口ずさめるこのCMがついにMisskeyへ。" | ||||
|   callback-url: "コールバックURL (無くてもええで)" | ||||
|   callback-url-desc: "ユーザーが認証フォームで認証した後どこに連れてくかを設定できるで" | ||||
|   authority: "権限" | ||||
|   authority-desc: "ここにチェックした機能しかAPIからアクセスできひんから気ぃつけてな" | ||||
|   authority-warning: "アプリ作った後でも変えれるけど、新しいやつ追加したらそん時関連付いてるユーザーキーは全部ほかされるで。" | ||||
|   account-read: "アカウントの情報見せて" | ||||
|   account-write: "アカウントの情報いじらせて" | ||||
|   note-write: "投稿させて" | ||||
|   reaction-write: "リアクションしたりそれをキャンセルさせて" | ||||
|   following-write: "フォローとかフォロー解除させて" | ||||
|   drive-read: "ドライブ見せて" | ||||
|   drive-write: "ドライブいじらせて" | ||||
|   notification-read: "通知見せて" | ||||
|   notification-write: "通知いじらせて" | ||||
|   | ||||
| @@ -25,6 +25,14 @@ common: | ||||
|   application-authorization: "앱의 연계" | ||||
|   close: "닫기" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   BSoD: | ||||
|     fatal-error: ":( 致命的な問題が発生しました。" | ||||
|     update-browser-os: "お使いのブラウザ(またはOS)のバージョンを更新すると解決する可能性があります。" | ||||
|     error-code: "エラーコード" | ||||
|     browser-version: "ブラウザ バージョン" | ||||
|     client-version: "クライアント バージョン" | ||||
|     email-support: "問題が解決しない場合は、上記の情報をお書き添えの上 syuilotan@yahoo.co.jp までご連絡ください。" | ||||
|     thanks: "Thank you for using Misskey." | ||||
|   got-it: "알았습니다" | ||||
|   customization-tips: | ||||
|     title: "사용자 정의 팁" | ||||
| @@ -54,6 +62,7 @@ common: | ||||
|     years_ago: "{}년전" | ||||
|   month-and-day: "{month}월 {day}일" | ||||
|   trash: "휴지통" | ||||
|   drive: "ドライブ" | ||||
|   weekday-short: | ||||
|     sunday: "일" | ||||
|     monday: "월" | ||||
| @@ -115,6 +124,12 @@ common: | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "이 장치만" | ||||
|   do-not-use-in-production: '이것은 개발 빌드입니다. 프로덕션 환경에서 사용하지 마십시오.' | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|   error: | ||||
|     title: '問題が発生しました' | ||||
|     retry: 'やり直す' | ||||
|   reversi: | ||||
|     drawn: "무승부" | ||||
|     my-turn: "당신의 차례입니다" | ||||
| @@ -170,6 +185,8 @@ common: | ||||
|     rename: "이름 변경" | ||||
|     stack-left: "左に重ねる" | ||||
|     pop-right: "右に出す" | ||||
|   dev: "アプリの作成に失敗しました。再度お試しください。" | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{{ app.name }}</i>があなたのアカウントにアクセスすることを<b>許可</b>しますか?" | ||||
|   permission-ask: "このアプリは次の権限を要求しています:" | ||||
| @@ -335,6 +352,7 @@ common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "링크 복사" | ||||
|   favorite: "お気に入り" | ||||
|   unfavorite: "お気に入り解除" | ||||
|   pin: "ピン留め" | ||||
|   unpin: "ピン留め解除" | ||||
|   delete: "削除" | ||||
| @@ -415,6 +433,25 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   careful-bot: "Botからのフォローだけ承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "確認中" | ||||
|   no-broadcasts: "お知らせはありません" | ||||
| @@ -506,11 +543,14 @@ desktop/views/components/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
| @@ -540,7 +580,6 @@ desktop/views/components/crop-window.vue: | ||||
|   ok: "決定" | ||||
| desktop/views/components/drive-window.vue: | ||||
|   used: "使用中" | ||||
|   drive: "ドライブ" | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
| @@ -570,8 +609,6 @@ desktop/views/components/drive.folder.vue: | ||||
|     rename: "名前を変更" | ||||
|     rename-folder: "フォルダ名の変更" | ||||
|     input-new-folder-name: "新しいフォルダ名を入力してください" | ||||
| desktop/views/components/drive.nav-folder.vue: | ||||
|   drive: "ドライブ" | ||||
| desktop/views/components/drive.vue: | ||||
|   search: "検索" | ||||
|   load-more: "もっと読み込む" | ||||
| @@ -639,7 +676,7 @@ desktop/views/components/note-detail.vue: | ||||
|   location: "位置情報" | ||||
|   renote: "Renote" | ||||
|   add-reaction: "リアクション" | ||||
| desktop/views/components/notes.note.vue: | ||||
| desktop/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   reply: "返信" | ||||
|   renote: "Renote" | ||||
| @@ -705,8 +742,8 @@ desktop/views/components/settings.vue: | ||||
|   profile: "プロフィール" | ||||
|   notification: "通知" | ||||
|   apps: "アプリ" | ||||
|   mute: "ミュート" | ||||
|   drive: "ドライブ" | ||||
|   mute-and-block: "ミュート/ブロック" | ||||
|   blocking: "ブロック" | ||||
|   security: "セキュリティ" | ||||
|   signin: "サインイン履歴" | ||||
|   password: "パスワード" | ||||
| @@ -725,8 +762,12 @@ desktop/views/components/settings.vue: | ||||
|   advanced: "詳細設定" | ||||
|   api-via-stream: "ストリームを経由したAPIリクエスト" | ||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "デザインと表示" | ||||
|   customize: "ホームをカスタマイズ" | ||||
|   wallpaper: "壁紙" | ||||
|   choose-wallpaper: "壁紙を選択" | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
| @@ -738,17 +779,19 @@ desktop/views/components/settings.vue: | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   timeline: "タイムライン" | ||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||
|   volume: "ボリューム" | ||||
|   test: "テスト" | ||||
|   mobile: "モバイル" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   language: "言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
| @@ -784,6 +827,10 @@ desktop/views/components/settings.vue: | ||||
|   tools: "ツール" | ||||
|   task-manager: "タスクマネージャ" | ||||
|   third-parties: "サードパーティ" | ||||
|   navbar-position: "ナビゲーションバーの位置" | ||||
|   navbar-position-top: "上" | ||||
|   navbar-position-left: "左" | ||||
|   navbar-position-right: "右" | ||||
| desktop/views/components/settings.2fa.vue: | ||||
|   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" | ||||
|   detail: "詳細..." | ||||
| @@ -802,41 +849,39 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "設定が完了しました!" | ||||
|   failed: "設定に失敗しました。トークンに誤りがないかご確認ください。" | ||||
|   info: "次回サインインからは、同様にパスワードに加えてデバイスに表示されているトークンを入力します。" | ||||
| desktop/views/components/settings.api.vue: | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
|   regeneration-of-token: "万が一このトークンが漏れたりその可能性がある場合はトークンを再生成できます。" | ||||
|   regenerate-token: "トークンを再生成" | ||||
|   token: "Token:" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   console: | ||||
|     title: 'APIコンソール' | ||||
|     endpoint: 'エンドポイント' | ||||
|     parameter: 'パラメータ' | ||||
|     send: '送信' | ||||
|     sending: '応答待ち' | ||||
|     response: '結果' | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "連携しているアプリケーションはありません" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "中" | ||||
| common/views/components/drive-settings.vue: | ||||
|   max: "容量" | ||||
|   in-use: "使用中" | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "ミュートしているユーザーはいません" | ||||
| desktop/views/components/settings.password.vue: | ||||
|   stats: "統計" | ||||
| common/views/components/mute-and-block.vue: | ||||
|   mute-and-block: "ミュートとブロック" | ||||
|   mute: "ミュート" | ||||
|   block: "ブロック" | ||||
|   no-muted-users: "ミュートしているユーザーはいません" | ||||
|   no-blocked-users: "ブロックしているユーザーはいません" | ||||
| common/views/components/password-settings.vue: | ||||
|   reset: "パスワードを変更する" | ||||
|   enter-current-password: "現在のパスワードを入力してください" | ||||
|   enter-new-password: "新しいパスワードを入力してください" | ||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||
|   not-match: "新しいパスワードが一致しません" | ||||
|   changed: "パスワードを変更しました" | ||||
| desktop/views/components/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   choice-avatar: "画像を選択" | ||||
|   name: "名前" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   profile-updated: "プロフィールを更新しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| @@ -861,7 +906,6 @@ desktop/views/components/ui.header.vue: | ||||
|   adjective: "さん" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "プロフィール" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
| @@ -903,42 +947,100 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
| admin/views/index.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "ドライブ" | ||||
|   instance: "インスタンス" | ||||
|   emoji: "カスタム絵文字" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   announcements: "お知らせ" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   accounts: "アカウント" | ||||
|   notes: "投稿" | ||||
|   drive: "ドライブ" | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "このインスタンス" | ||||
|   federated: "連合" | ||||
|   invite: "招待" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   banner-url: "Banner URL" | ||||
|   disableRegistration: "Disable new user registration" | ||||
|   disableLocalTimeline: "Disable the local timeline" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の積算" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の積算" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| admin/views/emoji.vue: | ||||
|   add-emoji: | ||||
|     title: "絵文字の登録" | ||||
|     name: "絵文字名" | ||||
|     name-desc: "a~z 0~9 _ の文字が使えます。" | ||||
|     aliases: "エイリアス" | ||||
|     aliases-desc: "スペースで区切って複数設定できます。" | ||||
|     url: "絵文字画像URL" | ||||
|     add: "追加" | ||||
|   emojis: | ||||
|     title: "絵文字一覧" | ||||
|     update: "更新" | ||||
|     remove: "削除" | ||||
| admin/views/announcements.vue: | ||||
|   announcements: "お知らせ" | ||||
|   save: "保存" | ||||
|   remove: "削除" | ||||
|   add: "追加" | ||||
|   title: "タイトル" | ||||
|   text: "内容" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| 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: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/pages/deck/deck.user-column.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   images: "画像" | ||||
|   activity: "アクティビティ" | ||||
|   timeline: "タイムライン" | ||||
|   pinned-notes: "ピン留めされた投稿" | ||||
|   push-to-a-list: "リストに追加" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
| @@ -991,9 +1093,6 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
| desktop/views/pages/user/user.home.vue: | ||||
|   last-used-at: "最終アクセス" | ||||
| desktop/views/pages/user/user.photos.vue: | ||||
|   title: "フォト" | ||||
| @@ -1007,6 +1106,9 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "ミュートする" | ||||
|   muted: "ミュートしています" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロックする" | ||||
|   unblock: "ブロック解除" | ||||
|   block-confirm: "このユーザーをブロックしますか?" | ||||
|   push-to-a-list: "リストに追加" | ||||
|   list-pushed: "{user}を{list}に追加しました。" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| @@ -1014,6 +1116,10 @@ desktop/views/pages/user/user.header.vue: | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   years-old: "歳" | ||||
|   year: "年" | ||||
|   month: "月" | ||||
|   day: "日" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "投稿" | ||||
|   with-replies: "投稿と返信" | ||||
| @@ -1043,7 +1149,6 @@ desktop/views/widgets/users.vue: | ||||
|   refresh: "他を見る" | ||||
|   no-one: "いません!" | ||||
| mobile/views/components/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   used: "使用中" | ||||
|   folder-count: "フォルダ" | ||||
|   count-separator: "、" | ||||
| @@ -1073,6 +1178,8 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -1145,7 +1252,6 @@ mobile/views/components/ui.nav.vue: | ||||
|   messaging: "メッセージ" | ||||
|   follow-requests: "フォロー申請" | ||||
|   search: "検索" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   user-lists: "リスト" | ||||
|   widgets: "ウィジェット" | ||||
| @@ -1168,7 +1274,6 @@ mobile/views/pages/user-lists.vue: | ||||
|   title: "リスト" | ||||
|   enter-list-name: "リスト名を入力してください" | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   more: "もっと見る" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "📦 始めましょう" | ||||
| @@ -1213,23 +1318,6 @@ mobile/views/pages/notifications.vue: | ||||
|   read-all: "すべての通知を既読にしますか?" | ||||
| mobile/views/pages/games/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
| mobile/views/pages/search.vue: | ||||
|   search: "検索" | ||||
|   empty: "「{}」に関する投稿は見つかりませんでした。" | ||||
| @@ -1285,6 +1373,8 @@ mobile/views/pages/settings.vue: | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   mark-as-read-all-unread-notes: "すべての投稿を既読にする" | ||||
|   password: "パスワード" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   following: "フォロー" | ||||
| @@ -1294,8 +1384,10 @@ mobile/views/pages/user.vue: | ||||
|   timeline: "タイムライン" | ||||
|   media: "メディア" | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
|   mute: "ミュート" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "最近の投稿" | ||||
|   images: "画像" | ||||
| @@ -1341,3 +1433,29 @@ docs: | ||||
|       description: "説明" | ||||
| dev/views/index.vue: | ||||
|   manage-apps: "アプリの管理" | ||||
| dev/views/apps.vue: | ||||
|   manage-apps: "アプリを管理" | ||||
|   create-app: "アプリ作成" | ||||
|   app-missing: "アプリなし" | ||||
| dev/views/new-app.vue: | ||||
|   create-app: "アプリケーションの作成" | ||||
|   app-name: "アプリケーション名" | ||||
|   app-name-desc: "あなたのアプリの名称。" | ||||
|   app-name-ex: "ex) Misskey for iOS" | ||||
|   app-overview: "アプリの概要" | ||||
|   app-desc: "あなたのアプリの簡単な説明や紹介。" | ||||
|   app-desc-ex: "ex) Misskey iOSクライアント。" | ||||
|   callback-url: "コールバックURL (オプション)" | ||||
|   callback-url-desc: "ユーザーが認証フォームで認証した際にリダイレクトするURLを設定できます。" | ||||
|   authority: "権限" | ||||
|   authority-desc: "ここで要求した機能だけがAPIからアクセスできます。" | ||||
|   authority-warning: "アプリ作成後も変更できますが、新たな権限を付与する場合、その時点で関連付けられているユーザーキーはすべて無効になります。" | ||||
|   account-read: "アカウントの情報を見る。" | ||||
|   account-write: "アカウントの情報を操作する。" | ||||
|   note-write: "投稿する。" | ||||
|   reaction-write: "リアクションしたりリアクションをキャンセルする。" | ||||
|   following-write: "フォローしたりフォロー解除する。" | ||||
|   drive-read: "ドライブを見る。" | ||||
|   drive-write: "ドライブを操作する。" | ||||
|   notification-read: "通知を見る。" | ||||
|   notification-write: "通知を操作する。" | ||||
|   | ||||
| @@ -25,6 +25,14 @@ common: | ||||
|   application-authorization: "アプリの連携" | ||||
|   close: "閉じる" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   BSoD: | ||||
|     fatal-error: ":( 致命的な問題が発生しました。" | ||||
|     update-browser-os: "お使いのブラウザ(またはOS)のバージョンを更新すると解決する可能性があります。" | ||||
|     error-code: "エラーコード" | ||||
|     browser-version: "ブラウザ バージョン" | ||||
|     client-version: "クライアント バージョン" | ||||
|     email-support: "問題が解決しない場合は、上記の情報をお書き添えの上 syuilotan@yahoo.co.jp までご連絡ください。" | ||||
|     thanks: "Thank you for using Misskey." | ||||
|   got-it: "わかった" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
| @@ -54,6 +62,7 @@ common: | ||||
|     years_ago: "{}jaar geleden" | ||||
|   month-and-day: "{month}月 {day}日" | ||||
|   trash: "ゴミ箱" | ||||
|   drive: "ドライブ" | ||||
|   weekday-short: | ||||
|     sunday: "Z" | ||||
|     monday: "M" | ||||
| @@ -115,6 +124,12 @@ common: | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|   error: | ||||
|     title: '問題が発生しました' | ||||
|     retry: 'やり直す' | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
| @@ -170,6 +185,8 @@ common: | ||||
|     rename: "名前を変更" | ||||
|     stack-left: "左に重ねる" | ||||
|     pop-right: "右に出す" | ||||
|   dev: "アプリの作成に失敗しました。再度お試しください。" | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{{ app.name }}</i>があなたのアカウントにアクセスすることを<b>許可</b>しますか?" | ||||
|   permission-ask: "このアプリは次の権限を要求しています:" | ||||
| @@ -335,6 +352,7 @@ common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "Deze notitie toevoegen aan favorieten" | ||||
|   unfavorite: "お気に入り解除" | ||||
|   pin: "Vastmaken aan profielpagina" | ||||
|   unpin: "ピン留め解除" | ||||
|   delete: "削除" | ||||
| @@ -415,6 +433,25 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   careful-bot: "Botからのフォローだけ承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "Bezig met ophalen" | ||||
|   no-broadcasts: "Geen uitzendingen" | ||||
| @@ -506,11 +543,14 @@ desktop/views/components/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
| @@ -540,7 +580,6 @@ desktop/views/components/crop-window.vue: | ||||
|   ok: "Oké" | ||||
| desktop/views/components/drive-window.vue: | ||||
|   used: "gebruikt" | ||||
|   drive: "Drive" | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "Gebruikersafbeelding" | ||||
|   banner: "Omslagfoto" | ||||
| @@ -570,8 +609,6 @@ desktop/views/components/drive.folder.vue: | ||||
|     rename: "Naam wijzigen" | ||||
|     rename-folder: "Mapnaam wijzigen" | ||||
|     input-new-folder-name: "Voer een nieuwe naam in" | ||||
| desktop/views/components/drive.nav-folder.vue: | ||||
|   drive: "Drive" | ||||
| desktop/views/components/drive.vue: | ||||
|   search: "Zoeken" | ||||
|   load-more: "Meer laden" | ||||
| @@ -639,12 +676,12 @@ desktop/views/components/note-detail.vue: | ||||
|   location: "Locatie" | ||||
|   renote: "Renote" | ||||
|   add-reaction: "リアクション" | ||||
| desktop/views/components/notes.note.vue: | ||||
|   reposted-by: "Hergeplaatst door {}" | ||||
|   reply: "Antwoord" | ||||
| desktop/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   reply: "返信" | ||||
|   renote: "Renote" | ||||
|   add-reaction: "Reactie toevoegen" | ||||
|   detail: "Details tonen" | ||||
|   add-reaction: "リアクション" | ||||
|   detail: "詳細" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/components/notes.vue: | ||||
| @@ -705,8 +742,8 @@ desktop/views/components/settings.vue: | ||||
|   profile: "Profiel" | ||||
|   notification: "Melding" | ||||
|   apps: "Apps" | ||||
|   mute: "Dempen" | ||||
|   drive: "Drive" | ||||
|   mute-and-block: "ミュート/ブロック" | ||||
|   blocking: "ブロック" | ||||
|   security: "Beveiliging" | ||||
|   signin: "Inloggeschiedenis" | ||||
|   password: "Wachtwoord" | ||||
| @@ -725,8 +762,12 @@ desktop/views/components/settings.vue: | ||||
|   advanced: "Geavanceerde instellingen" | ||||
|   api-via-stream: "API-verzoek via stream" | ||||
|   api-via-stream-desc: "API-verzoek wordt uitgevoerd via de WebSocket-verbinding i.p.v. de ingebouwde ophaal-API (voor verbeterde prestaties). Deze instelling wordt opgeslagen in je browser." | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "Ontwerp en weergave" | ||||
|   customize: "Startpagina aanpassen" | ||||
|   wallpaper: "壁紙" | ||||
|   choose-wallpaper: "壁紙を選択" | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "Donkere modus" | ||||
| @@ -738,17 +779,19 @@ desktop/views/components/settings.vue: | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "Antwoord-knop tonen" | ||||
|   timeline: "タイムライン" | ||||
|   show-my-renotes: "Mijn renote tonen op de tijdlijn" | ||||
|   show-renoted-my-notes: "Mijn gerenote bericht tonen op de tijdlijn" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "Kaart tonen" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   sound: "Geluid" | ||||
|   enable-sounds: "Geluid inschakelen" | ||||
|   enable-sounds-desc: "Een geluid afspelen bij het ontvangen van een bericht. Deze instelling wordt opgeslagen in je browser." | ||||
|   volume: "Volume" | ||||
|   test: "Testen" | ||||
|   mobile: "Mobiel" | ||||
|   disable-via-mobile: "Berichten niet markeren als 'via mobiel'" | ||||
|   language: "Taal" | ||||
|   pick-language: "Selecteer een taal" | ||||
|   recommended: "Aanbevolen" | ||||
| @@ -784,6 +827,10 @@ desktop/views/components/settings.vue: | ||||
|   tools: "Hulpmiddelen" | ||||
|   task-manager: "Taakbeheer" | ||||
|   third-parties: "Derde partij" | ||||
|   navbar-position: "ナビゲーションバーの位置" | ||||
|   navbar-position-top: "上" | ||||
|   navbar-position-left: "左" | ||||
|   navbar-position-right: "右" | ||||
| desktop/views/components/settings.2fa.vue: | ||||
|   intro: "Als je verificatie in twee stappen instelt, dan heb je niet alleen een wachtwoord nodig bij het inloggen, maar ook een geregistreerd fysiek apparaat (zoals je smartphone). Dit verhoogt de veiligheid. " | ||||
|   detail: "Details bekijken..." | ||||
| @@ -802,41 +849,39 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "Instellen voltooid!" | ||||
|   failed: "Instellen mislukt. Zorg ervoor dat de sleutel juist is." | ||||
|   info: "Vanaf nu moet je ook de op je apparaat getoonde sleutel tonen bij het inloggen op Misskey." | ||||
| desktop/views/components/settings.api.vue: | ||||
|   intro: "Als je toegang wilt tot de API, stel deze sleutel dan in als 'i' bij de verzoekparameters." | ||||
|   caution: "Laat deze sleutel niet zien aan derde partijen (en voer hem nergens anders in dan hier), anders kan je account gehackt worden." | ||||
|   regeneration-of-token: "Mocht deze sleutel tóch uitlekken, dan kun je hem opnieuw genereren." | ||||
|   regenerate-token: "Sleutel opnieuw genereren" | ||||
|   token: "Sleutel:" | ||||
|   enter-password: "Voer je wachtwoord in" | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
|   regeneration-of-token: "万が一このトークンが漏れたりその可能性がある場合はトークンを再生成できます。" | ||||
|   regenerate-token: "トークンを再生成" | ||||
|   token: "Token:" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   console: | ||||
|     title: 'APIコンソール' | ||||
|     endpoint: 'エンドポイント' | ||||
|     parameter: 'パラメータ' | ||||
|     send: '送信' | ||||
|     sending: '応答待ち' | ||||
|     response: '結果' | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "連携しているアプリケーションはありません" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "中" | ||||
| common/views/components/drive-settings.vue: | ||||
|   max: "容量" | ||||
|   in-use: "使用中" | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "Geen gedempte gebruikers" | ||||
| desktop/views/components/settings.password.vue: | ||||
|   reset: "Wachtwoord wijzigen" | ||||
|   enter-current-password: "Voer je huidige wachtwoord in" | ||||
|   enter-new-password: "Voer je nieuwe wachtwoord in" | ||||
|   enter-new-password-again: "Voer je nieuwe wachtwoord nogmaals in" | ||||
|   not-match: "Het nieuwe wachtwoord komt niet overeen" | ||||
|   changed: "Wachtwoord bijgewerkt" | ||||
| desktop/views/components/settings.profile.vue: | ||||
|   avatar: "Gebruikersafbeelding" | ||||
|   choice-avatar: "Kies een afbeelding" | ||||
|   name: "Naam" | ||||
|   location: "Locatie" | ||||
|   description: "Omschrijving" | ||||
|   birthday: "Geboortedatum" | ||||
|   save: "Profiel bijwerken" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "Dit account is een Bot" | ||||
|   is-cat: "Dit account is een Kat" | ||||
|   profile-updated: "プロフィールを更新しました" | ||||
|   stats: "統計" | ||||
| common/views/components/mute-and-block.vue: | ||||
|   mute-and-block: "ミュートとブロック" | ||||
|   mute: "ミュート" | ||||
|   block: "ブロック" | ||||
|   no-muted-users: "ミュートしているユーザーはいません" | ||||
|   no-blocked-users: "ブロックしているユーザーはいません" | ||||
| common/views/components/password-settings.vue: | ||||
|   reset: "パスワードを変更する" | ||||
|   enter-current-password: "現在のパスワードを入力してください" | ||||
|   enter-new-password: "新しいパスワードを入力してください" | ||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||
|   not-match: "新しいパスワードが一致しません" | ||||
|   changed: "パスワードを変更しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| @@ -861,7 +906,6 @@ desktop/views/components/ui.header.vue: | ||||
|   adjective: "さん" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "Je profiel" | ||||
|   drive: "Drive" | ||||
|   favorites: "Favorieten" | ||||
|   lists: "Lijsten" | ||||
|   follow-requests: "フォロー申請" | ||||
| @@ -903,42 +947,100 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "Uitvouwen" | ||||
|   close: "Sluiten" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
| admin/views/index.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "ドライブ" | ||||
|   instance: "インスタンス" | ||||
|   emoji: "カスタム絵文字" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   announcements: "お知らせ" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   accounts: "アカウント" | ||||
|   notes: "投稿" | ||||
|   drive: "ドライブ" | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "このインスタンス" | ||||
|   federated: "連合" | ||||
|   invite: "招待" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   banner-url: "Banner URL" | ||||
|   disableRegistration: "Disable new user registration" | ||||
|   disableLocalTimeline: "Disable the local timeline" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の積算" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の積算" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| admin/views/emoji.vue: | ||||
|   add-emoji: | ||||
|     title: "絵文字の登録" | ||||
|     name: "絵文字名" | ||||
|     name-desc: "a~z 0~9 _ の文字が使えます。" | ||||
|     aliases: "エイリアス" | ||||
|     aliases-desc: "スペースで区切って複数設定できます。" | ||||
|     url: "絵文字画像URL" | ||||
|     add: "追加" | ||||
|   emojis: | ||||
|     title: "絵文字一覧" | ||||
|     update: "更新" | ||||
|     remove: "削除" | ||||
| admin/views/announcements.vue: | ||||
|   announcements: "お知らせ" | ||||
|   save: "保存" | ||||
|   remove: "削除" | ||||
|   add: "追加" | ||||
|   title: "タイトル" | ||||
|   text: "内容" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| 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: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/pages/deck/deck.user-column.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   images: "画像" | ||||
|   activity: "アクティビティ" | ||||
|   timeline: "タイムライン" | ||||
|   pinned-notes: "ピン留めされた投稿" | ||||
|   push-to-a-list: "リストに追加" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
| @@ -991,10 +1093,7 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   no-users: "Geen gebruikers" | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
| desktop/views/pages/user/user.home.vue: | ||||
|   last-used-at: "Laatst actief: " | ||||
|   last-used-at: "最終アクセス" | ||||
| desktop/views/pages/user/user.photos.vue: | ||||
|   title: "Foto's" | ||||
|   loading: "Bezig met laden" | ||||
| @@ -1007,6 +1106,9 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "Dempen" | ||||
|   muted: "Dempend" | ||||
|   unmute: "Ontdempen" | ||||
|   block: "ブロックする" | ||||
|   unblock: "ブロック解除" | ||||
|   block-confirm: "このユーザーをブロックしますか?" | ||||
|   push-to-a-list: "リストに追加" | ||||
|   list-pushed: "{user}を{list}に追加しました。" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| @@ -1014,6 +1116,10 @@ desktop/views/pages/user/user.header.vue: | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   years-old: "歳" | ||||
|   year: "年" | ||||
|   month: "月" | ||||
|   day: "日" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "Berichten" | ||||
|   with-replies: "Berichten en antwoorden" | ||||
| @@ -1043,7 +1149,6 @@ desktop/views/widgets/users.vue: | ||||
|   refresh: "Anderen tonen" | ||||
|   no-one: "Niemand" | ||||
| mobile/views/components/drive.vue: | ||||
|   drive: "Drive" | ||||
|   used: "gebruikt" | ||||
|   folder-count: "Map(pen)" | ||||
|   count-separator: ", " | ||||
| @@ -1073,6 +1178,8 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   hash: "Hash (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -1145,7 +1252,6 @@ mobile/views/components/ui.nav.vue: | ||||
|   messaging: "Gesprekken" | ||||
|   follow-requests: "フォロー申請" | ||||
|   search: "Zoeken" | ||||
|   drive: "Drive" | ||||
|   favorites: "お気に入り" | ||||
|   user-lists: "リスト" | ||||
|   widgets: "ウィジェット" | ||||
| @@ -1168,7 +1274,6 @@ mobile/views/pages/user-lists.vue: | ||||
|   title: "リスト" | ||||
|   enter-list-name: "リスト名を入力してください" | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "Drive" | ||||
|   more: "もっと見る" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "📦 始めましょう" | ||||
| @@ -1213,23 +1318,6 @@ mobile/views/pages/notifications.vue: | ||||
|   read-all: "Weet je zeker dat je alle meldingen wilt markeren als gelezen?" | ||||
| mobile/views/pages/games/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "Profiel" | ||||
|   name: "Naam" | ||||
|   account: "Account" | ||||
|   location: "Locatie" | ||||
|   description: "Omschrijving" | ||||
|   birthday: "Geboortedatum" | ||||
|   avatar: "Gebruikersafbeelding" | ||||
|   banner: "Omslagfoto" | ||||
|   is-cat: "Dit account is een Kat" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "Profiel bijwerken" | ||||
|   saved: "Profiel bijgewerkt" | ||||
|   uploading: "Bezig met uploaden" | ||||
|   upload-failed: "Upload mislukt" | ||||
| mobile/views/pages/search.vue: | ||||
|   search: "Zoeken" | ||||
|   empty: "Geen berichten gevonden voor '{}'" | ||||
| @@ -1285,6 +1373,8 @@ mobile/views/pages/settings.vue: | ||||
|   signout: "Uitloggen" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   mark-as-read-all-unread-notes: "すべての投稿を既読にする" | ||||
|   password: "パスワード" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "Volgt jou" | ||||
|   following: "Volgend" | ||||
| @@ -1294,8 +1384,10 @@ mobile/views/pages/user.vue: | ||||
|   timeline: "Tijdlijn" | ||||
|   media: "Media" | ||||
|   is-suspended: "Dit account is geschorst." | ||||
|   is-remote: "Deze gebruiker is een externe gebruiker; de informatie is daarom niet volledig. " | ||||
|   view-remote: "Volledige informatie bekijken" | ||||
|   mute: "ミュート" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "Recente notities" | ||||
|   images: "Afbeeldingen" | ||||
| @@ -1304,7 +1396,7 @@ mobile/views/pages/user/home.vue: | ||||
|   domains: "Domeinnamen" | ||||
|   frequently-replied-users: "Frequent gesproken gebruikers" | ||||
|   followers-you-know: "Volgers die je kent" | ||||
|   last-used-at: "Laatst actief:" | ||||
|   last-used-at: "Laatst actief" | ||||
| mobile/views/pages/user/home.followers-you-know.vue: | ||||
|   loading: "Bezig met laden" | ||||
|   no-users: "Geen gebruikers" | ||||
| @@ -1341,3 +1433,29 @@ docs: | ||||
|       description: "Omschrijving" | ||||
| dev/views/index.vue: | ||||
|   manage-apps: "アプリの管理" | ||||
| dev/views/apps.vue: | ||||
|   manage-apps: "アプリを管理" | ||||
|   create-app: "アプリ作成" | ||||
|   app-missing: "アプリなし" | ||||
| dev/views/new-app.vue: | ||||
|   create-app: "アプリケーションの作成" | ||||
|   app-name: "アプリケーション名" | ||||
|   app-name-desc: "あなたのアプリの名称。" | ||||
|   app-name-ex: "ex) Misskey for iOS" | ||||
|   app-overview: "アプリの概要" | ||||
|   app-desc: "あなたのアプリの簡単な説明や紹介。" | ||||
|   app-desc-ex: "ex) Misskey iOSクライアント。" | ||||
|   callback-url: "コールバックURL (オプション)" | ||||
|   callback-url-desc: "ユーザーが認証フォームで認証した際にリダイレクトするURLを設定できます。" | ||||
|   authority: "権限" | ||||
|   authority-desc: "ここで要求した機能だけがAPIからアクセスできます。" | ||||
|   authority-warning: "アプリ作成後も変更できますが、新たな権限を付与する場合、その時点で関連付けられているユーザーキーはすべて無効になります。" | ||||
|   account-read: "アカウントの情報を見る。" | ||||
|   account-write: "アカウントの情報を操作する。" | ||||
|   note-write: "投稿する。" | ||||
|   reaction-write: "リアクションしたりリアクションをキャンセルする。" | ||||
|   following-write: "フォローしたりフォロー解除する。" | ||||
|   drive-read: "ドライブを見る。" | ||||
|   drive-write: "ドライブを操作する。" | ||||
|   notification-read: "通知を見る。" | ||||
|   notification-write: "通知を操作する。" | ||||
|   | ||||
| @@ -25,6 +25,14 @@ common: | ||||
|   application-authorization: "アプリの連携" | ||||
|   close: "Lukk" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   BSoD: | ||||
|     fatal-error: ":( 致命的な問題が発生しました。" | ||||
|     update-browser-os: "お使いのブラウザ(またはOS)のバージョンを更新すると解決する可能性があります。" | ||||
|     error-code: "エラーコード" | ||||
|     browser-version: "ブラウザ バージョン" | ||||
|     client-version: "クライアント バージョン" | ||||
|     email-support: "問題が解決しない場合は、上記の情報をお書き添えの上 syuilotan@yahoo.co.jp までご連絡ください。" | ||||
|     thanks: "Thank you for using Misskey." | ||||
|   got-it: "Skjønner!" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
| @@ -54,6 +62,7 @@ common: | ||||
|     years_ago: "{} år siden" | ||||
|   month-and-day: "{day}/{month}" | ||||
|   trash: "Papirkurv" | ||||
|   drive: "ドライブ" | ||||
|   weekday-short: | ||||
|     sunday: "S" | ||||
|     monday: "M" | ||||
| @@ -115,6 +124,12 @@ common: | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|   error: | ||||
|     title: '問題が発生しました' | ||||
|     retry: 'やり直す' | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
| @@ -170,6 +185,8 @@ common: | ||||
|     rename: "Endre navn" | ||||
|     stack-left: "左に重ねる" | ||||
|     pop-right: "Til høyre" | ||||
|   dev: "アプリの作成に失敗しました。再度お試しください。" | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{{ app.name }}</i>があなたのアカウントにアクセスすることを<b>許可</b>しますか?" | ||||
|   permission-ask: "このアプリは次の権限を要求しています:" | ||||
| @@ -335,6 +352,7 @@ common/views/components/note-menu.vue: | ||||
|   detail: "Detaljer" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "Merket som favoritt" | ||||
|   unfavorite: "お気に入り解除" | ||||
|   pin: "Fest til profilen din" | ||||
|   unpin: "ピン留め解除" | ||||
|   delete: "Slett" | ||||
| @@ -415,6 +433,25 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   careful-bot: "Botからのフォローだけ承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "Henter" | ||||
|   no-broadcasts: "お知らせはありません" | ||||
| @@ -506,11 +543,14 @@ desktop/views/components/charts.vue: | ||||
|   title: "Diagrammer" | ||||
|   per-day: "per dag" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "Innlegg" | ||||
|   users: "Brukere" | ||||
|   drive: "Disk" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
| @@ -540,7 +580,6 @@ desktop/views/components/crop-window.vue: | ||||
|   ok: "Ok" | ||||
| desktop/views/components/drive-window.vue: | ||||
|   used: "brukt" | ||||
|   drive: "Disk" | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "Avatar" | ||||
|   banner: "Banner" | ||||
| @@ -570,8 +609,6 @@ desktop/views/components/drive.folder.vue: | ||||
|     rename: "Endre navn" | ||||
|     rename-folder: "フォルダ名の変更" | ||||
|     input-new-folder-name: "新しいフォルダ名を入力してください" | ||||
| desktop/views/components/drive.nav-folder.vue: | ||||
|   drive: "Disk" | ||||
| desktop/views/components/drive.vue: | ||||
|   search: "Søk" | ||||
|   load-more: "もっと読み込む" | ||||
| @@ -639,12 +676,12 @@ desktop/views/components/note-detail.vue: | ||||
|   location: "Lokasjon" | ||||
|   renote: "Renote" | ||||
|   add-reaction: "リアクション" | ||||
| desktop/views/components/notes.note.vue: | ||||
| desktop/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   reply: "Svar" | ||||
|   reply: "返信" | ||||
|   renote: "Renote" | ||||
|   add-reaction: "リアクション" | ||||
|   detail: "Vis detaljer" | ||||
|   detail: "詳細" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/components/notes.vue: | ||||
| @@ -705,8 +742,8 @@ desktop/views/components/settings.vue: | ||||
|   profile: "プロフィール" | ||||
|   notification: "Notifikasjon" | ||||
|   apps: "Apper" | ||||
|   mute: "Demp" | ||||
|   drive: "Disk" | ||||
|   mute-and-block: "ミュート/ブロック" | ||||
|   blocking: "ブロック" | ||||
|   security: "セキュリティ" | ||||
|   signin: "サインイン履歴" | ||||
|   password: "Passord" | ||||
| @@ -725,8 +762,12 @@ desktop/views/components/settings.vue: | ||||
|   advanced: "Avanserte innstillinger" | ||||
|   api-via-stream: "ストリームを経由したAPIリクエスト" | ||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "デザインと表示" | ||||
|   customize: "ホームをカスタマイズ" | ||||
|   wallpaper: "壁紙" | ||||
|   choose-wallpaper: "壁紙を選択" | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
| @@ -738,17 +779,19 @@ desktop/views/components/settings.vue: | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   timeline: "タイムライン" | ||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   sound: "Lyd" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||
|   volume: "Volum" | ||||
|   test: "Test" | ||||
|   mobile: "Mobil" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   language: "Språk" | ||||
|   pick-language: "Velg språk" | ||||
|   recommended: "Anbefalt" | ||||
| @@ -784,6 +827,10 @@ desktop/views/components/settings.vue: | ||||
|   tools: "Verktøy" | ||||
|   task-manager: "タスクマネージャ" | ||||
|   third-parties: "サードパーティ" | ||||
|   navbar-position: "ナビゲーションバーの位置" | ||||
|   navbar-position-top: "上" | ||||
|   navbar-position-left: "左" | ||||
|   navbar-position-right: "右" | ||||
| desktop/views/components/settings.2fa.vue: | ||||
|   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" | ||||
|   detail: "Detaljer..." | ||||
| @@ -802,41 +849,39 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "設定が完了しました!" | ||||
|   failed: "設定に失敗しました。トークンに誤りがないかご確認ください。" | ||||
|   info: "次回サインインからは、同様にパスワードに加えてデバイスに表示されているトークンを入力します。" | ||||
| desktop/views/components/settings.api.vue: | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
|   regeneration-of-token: "万が一このトークンが漏れたりその可能性がある場合はトークンを再生成できます。" | ||||
|   regenerate-token: "トークンを再生成" | ||||
|   token: "Token:" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   console: | ||||
|     title: 'APIコンソール' | ||||
|     endpoint: 'エンドポイント' | ||||
|     parameter: 'パラメータ' | ||||
|     send: '送信' | ||||
|     sending: '応答待ち' | ||||
|     response: '結果' | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "連携しているアプリケーションはありません" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "Maks" | ||||
|   in-use: "I bruk" | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "ミュートしているユーザーはいません" | ||||
| desktop/views/components/settings.password.vue: | ||||
| common/views/components/drive-settings.vue: | ||||
|   max: "容量" | ||||
|   in-use: "使用中" | ||||
|   stats: "統計" | ||||
| common/views/components/mute-and-block.vue: | ||||
|   mute-and-block: "ミュートとブロック" | ||||
|   mute: "ミュート" | ||||
|   block: "ブロック" | ||||
|   no-muted-users: "ミュートしているユーザーはいません" | ||||
|   no-blocked-users: "ブロックしているユーザーはいません" | ||||
| common/views/components/password-settings.vue: | ||||
|   reset: "パスワードを変更する" | ||||
|   enter-current-password: "現在のパスワードを入力してください" | ||||
|   enter-new-password: "新しいパスワードを入力してください" | ||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||
|   not-match: "新しいパスワードが一致しません" | ||||
|   changed: "パスワードを変更しました" | ||||
| desktop/views/components/settings.profile.vue: | ||||
|   avatar: "Avatar" | ||||
|   choice-avatar: "Velg et bilde" | ||||
|   name: "Navn" | ||||
|   location: "Lokasjon" | ||||
|   description: "Om meg" | ||||
|   birthday: "Bursdag" | ||||
|   save: "Lagre profilen" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "Annet" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   profile-updated: "プロフィールを更新しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| @@ -861,7 +906,6 @@ desktop/views/components/ui.header.vue: | ||||
|   adjective: "-san" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "プロフィール" | ||||
|   drive: "Disk" | ||||
|   favorites: "Favoritter" | ||||
|   lists: "Lister" | ||||
|   follow-requests: "フォロー申請" | ||||
| @@ -903,42 +947,100 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "Lukk" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
| admin/views/index.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "Disk" | ||||
|   users: "Brukere" | ||||
|   update: "Oppdater" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   instance: "インスタンス" | ||||
|   emoji: "カスタム絵文字" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
|   announcements: "お知らせ" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   invite: "Inviter" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   accounts: "アカウント" | ||||
|   notes: "投稿" | ||||
|   drive: "ドライブ" | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "このインスタンス" | ||||
|   federated: "連合" | ||||
|   invite: "招待" | ||||
|   banner-url: "Banner URL" | ||||
|   disableRegistration: "Disable new user registration" | ||||
|   disableLocalTimeline: "Disable the local timeline" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の積算" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の積算" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "Suspender" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| admin/views/emoji.vue: | ||||
|   add-emoji: | ||||
|     title: "絵文字の登録" | ||||
|     name: "絵文字名" | ||||
|     name-desc: "a~z 0~9 _ の文字が使えます。" | ||||
|     aliases: "エイリアス" | ||||
|     aliases-desc: "スペースで区切って複数設定できます。" | ||||
|     url: "絵文字画像URL" | ||||
|     add: "追加" | ||||
|   emojis: | ||||
|     title: "絵文字一覧" | ||||
|     update: "更新" | ||||
|     remove: "削除" | ||||
| admin/views/announcements.vue: | ||||
|   announcements: "お知らせ" | ||||
|   save: "保存" | ||||
|   remove: "削除" | ||||
|   add: "追加" | ||||
|   title: "タイトル" | ||||
|   text: "内容" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| 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: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/pages/deck/deck.user-column.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   images: "画像" | ||||
|   activity: "アクティビティ" | ||||
|   timeline: "タイムライン" | ||||
|   pinned-notes: "ピン留めされた投稿" | ||||
|   push-to-a-list: "リストに追加" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
| @@ -991,9 +1093,6 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
| desktop/views/pages/user/user.home.vue: | ||||
|   last-used-at: "最終アクセス" | ||||
| desktop/views/pages/user/user.photos.vue: | ||||
|   title: "Bilder" | ||||
| @@ -1007,6 +1106,9 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "ミュートする" | ||||
|   muted: "ミュートしています" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロックする" | ||||
|   unblock: "ブロック解除" | ||||
|   block-confirm: "このユーザーをブロックしますか?" | ||||
|   push-to-a-list: "リストに追加" | ||||
|   list-pushed: "{user}を{list}に追加しました。" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| @@ -1014,6 +1116,10 @@ desktop/views/pages/user/user.header.vue: | ||||
|   following: "Følger" | ||||
|   followers: "フォロワー" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   years-old: "歳" | ||||
|   year: "年" | ||||
|   month: "月" | ||||
|   day: "日" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "Innlegg" | ||||
|   with-replies: "Innlegg og svar" | ||||
| @@ -1043,7 +1149,6 @@ desktop/views/widgets/users.vue: | ||||
|   refresh: "Oppdater" | ||||
|   no-one: "Ingen" | ||||
| mobile/views/components/drive.vue: | ||||
|   drive: "Disk" | ||||
|   used: "brukt" | ||||
|   folder-count: "Mappe(r)" | ||||
|   count-separator: "," | ||||
| @@ -1073,6 +1178,8 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "NSFW" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "NSFW" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -1145,7 +1252,6 @@ mobile/views/components/ui.nav.vue: | ||||
|   messaging: "Meldinger" | ||||
|   follow-requests: "フォロー申請" | ||||
|   search: "Søk" | ||||
|   drive: "Disk" | ||||
|   favorites: "Favoritter" | ||||
|   user-lists: "Lister" | ||||
|   widgets: "ウィジェット" | ||||
| @@ -1168,7 +1274,6 @@ mobile/views/pages/user-lists.vue: | ||||
|   title: "Lister" | ||||
|   enter-list-name: "リスト名を入力してください" | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "Disk" | ||||
|   more: "Vis mer" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "📦 始めましょう" | ||||
| @@ -1213,23 +1318,6 @@ mobile/views/pages/notifications.vue: | ||||
|   read-all: "すべての通知を既読にしますか?" | ||||
| mobile/views/pages/games/reversi.vue: | ||||
|   reversi: "Reversi" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "Navn" | ||||
|   account: "Konto" | ||||
|   location: "Lokasjon" | ||||
|   description: "Om meg" | ||||
|   birthday: "Bursdag" | ||||
|   avatar: "Avatar" | ||||
|   banner: "Banner" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "Avansert" | ||||
|   privacy: "プライバシー" | ||||
|   save: "Lagre profilen" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
| mobile/views/pages/search.vue: | ||||
|   search: "Søk" | ||||
|   empty: "「{}」に関する投稿は見つかりませんでした。" | ||||
| @@ -1285,6 +1373,8 @@ mobile/views/pages/settings.vue: | ||||
|   signout: "サインアウト" | ||||
|   sound: "Lyder" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   mark-as-read-all-unread-notes: "すべての投稿を既読にする" | ||||
|   password: "パスワード" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   following: "Følger" | ||||
| @@ -1294,8 +1384,10 @@ mobile/views/pages/user.vue: | ||||
|   timeline: "タイムライン" | ||||
|   media: "Media" | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
|   mute: "ミュート" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "Nylige innlegg" | ||||
|   images: "Bilder" | ||||
| @@ -1341,3 +1433,29 @@ docs: | ||||
|       description: "Beskrivelse" | ||||
| dev/views/index.vue: | ||||
|   manage-apps: "アプリの管理" | ||||
| dev/views/apps.vue: | ||||
|   manage-apps: "アプリを管理" | ||||
|   create-app: "アプリ作成" | ||||
|   app-missing: "アプリなし" | ||||
| dev/views/new-app.vue: | ||||
|   create-app: "アプリケーションの作成" | ||||
|   app-name: "アプリケーション名" | ||||
|   app-name-desc: "あなたのアプリの名称。" | ||||
|   app-name-ex: "ex) Misskey for iOS" | ||||
|   app-overview: "アプリの概要" | ||||
|   app-desc: "あなたのアプリの簡単な説明や紹介。" | ||||
|   app-desc-ex: "ex) Misskey iOSクライアント。" | ||||
|   callback-url: "コールバックURL (オプション)" | ||||
|   callback-url-desc: "ユーザーが認証フォームで認証した際にリダイレクトするURLを設定できます。" | ||||
|   authority: "権限" | ||||
|   authority-desc: "ここで要求した機能だけがAPIからアクセスできます。" | ||||
|   authority-warning: "アプリ作成後も変更できますが、新たな権限を付与する場合、その時点で関連付けられているユーザーキーはすべて無効になります。" | ||||
|   account-read: "アカウントの情報を見る。" | ||||
|   account-write: "アカウントの情報を操作する。" | ||||
|   note-write: "投稿する。" | ||||
|   reaction-write: "リアクションしたりリアクションをキャンセルする。" | ||||
|   following-write: "フォローしたりフォロー解除する。" | ||||
|   drive-read: "ドライブを見る。" | ||||
|   drive-write: "ドライブを操作する。" | ||||
|   notification-read: "通知を見る。" | ||||
|   notification-write: "通知を操作する。" | ||||
|   | ||||
| @@ -25,6 +25,14 @@ common: | ||||
|   application-authorization: "アプリの連携" | ||||
|   close: "Zamknij" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   BSoD: | ||||
|     fatal-error: ":( 致命的な問題が発生しました。" | ||||
|     update-browser-os: "お使いのブラウザ(またはOS)のバージョンを更新すると解決する可能性があります。" | ||||
|     error-code: "エラーコード" | ||||
|     browser-version: "ブラウザ バージョン" | ||||
|     client-version: "クライアント バージョン" | ||||
|     email-support: "問題が解決しない場合は、上記の情報をお書き添えの上 syuilotan@yahoo.co.jp までご連絡ください。" | ||||
|     thanks: "Thank you for using Misskey." | ||||
|   got-it: "Rozumiem!" | ||||
|   customization-tips: | ||||
|     title: "Wskazówki o dostosowywaniu" | ||||
| @@ -54,6 +62,7 @@ common: | ||||
|     years_ago: "{} lat temu" | ||||
|   month-and-day: "{month}-{day}" | ||||
|   trash: "Kosz" | ||||
|   drive: "ドライブ" | ||||
|   weekday-short: | ||||
|     sunday: "N" | ||||
|     monday: "Pn" | ||||
| @@ -115,6 +124,12 @@ common: | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|   error: | ||||
|     title: '問題が発生しました' | ||||
|     retry: 'やり直す' | ||||
|   reversi: | ||||
|     drawn: "Remis" | ||||
|     my-turn: "Twoja kolej" | ||||
| @@ -170,6 +185,8 @@ common: | ||||
|     rename: "Zmień nazwę" | ||||
|     stack-left: "Przypnij do lewej" | ||||
|     pop-right: "Odepnij w prawo" | ||||
|   dev: "アプリの作成に失敗しました。再度お試しください。" | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
| auth/views/form.vue: | ||||
|   share-access: "Czy chcesz <b>zezwolić</b> <i>{{ app.name }}</i> na dostęp do Twojego konta?" | ||||
|   permission-ask: "Ta aplikacja wymaga następujących uprawnień:" | ||||
| @@ -335,6 +352,7 @@ common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "Dodaj do ulubionych" | ||||
|   unfavorite: "お気に入り解除" | ||||
|   pin: "Przypnij do profilu" | ||||
|   unpin: "ピン留め解除" | ||||
|   delete: "Usuń" | ||||
| @@ -415,6 +433,25 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   careful-bot: "Botからのフォローだけ承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "Sprawdzanie" | ||||
|   no-broadcasts: "Brak transmisji" | ||||
| @@ -506,11 +543,14 @@ desktop/views/components/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
| @@ -540,7 +580,6 @@ desktop/views/components/crop-window.vue: | ||||
|   ok: "OK" | ||||
| desktop/views/components/drive-window.vue: | ||||
|   used: "wykorzystane" | ||||
|   drive: "Dysk" | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "Awatar" | ||||
|   banner: "Baner" | ||||
| @@ -570,8 +609,6 @@ desktop/views/components/drive.folder.vue: | ||||
|     rename: "Zmień nazwę" | ||||
|     rename-folder: "Zmień nazwę katalogu" | ||||
|     input-new-folder-name: "Wprowadź nową nazwę" | ||||
| desktop/views/components/drive.nav-folder.vue: | ||||
|   drive: "Dysk" | ||||
| desktop/views/components/drive.vue: | ||||
|   search: "Szukaj" | ||||
|   load-more: "Załaduj więcej" | ||||
| @@ -639,14 +676,14 @@ desktop/views/components/note-detail.vue: | ||||
|   location: "Informacje o lokalizacji" | ||||
|   renote: "Udostępnienie" | ||||
|   add-reaction: "Dodaj reakcję" | ||||
| desktop/views/components/notes.note.vue: | ||||
|   reposted-by: "Udostępniono przez {}" | ||||
|   reply: "Odpowiedz" | ||||
|   renote: "Udostępnij" | ||||
|   add-reaction: "Dodaj reakcję" | ||||
|   detail: "Pokaż szczegóły" | ||||
|   private: "ten wpis jest prywatny" | ||||
|   deleted: "ten wpis został usunięty" | ||||
| desktop/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   reply: "返信" | ||||
|   renote: "Renote" | ||||
|   add-reaction: "リアクション" | ||||
|   detail: "詳細" | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/components/notes.vue: | ||||
|   error: "Ładowanie nie powiodło się." | ||||
|   retry: "Spróbuj ponownie" | ||||
| @@ -705,8 +742,8 @@ desktop/views/components/settings.vue: | ||||
|   profile: "Profil" | ||||
|   notification: "Powiadomienia" | ||||
|   apps: "Aplikacje" | ||||
|   mute: "Wyciszanie" | ||||
|   drive: "Dysk" | ||||
|   mute-and-block: "ミュート/ブロック" | ||||
|   blocking: "ブロック" | ||||
|   security: "Bezpieczeństwo" | ||||
|   signin: "Historia logowań" | ||||
|   password: "Hasło" | ||||
| @@ -725,8 +762,12 @@ desktop/views/components/settings.vue: | ||||
|   advanced: "Ustawienia zaawansowane" | ||||
|   api-via-stream: "ストリームを経由したAPIリクエスト" | ||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "Wygląd i wyświetlanie" | ||||
|   customize: "Dostosuj stronę główną" | ||||
|   wallpaper: "壁紙" | ||||
|   choose-wallpaper: "Wybierz tło" | ||||
|   delete-wallpaper: "Usuń tło" | ||||
|   dark-mode: "Tryb ciemny" | ||||
| @@ -738,17 +779,19 @@ desktop/views/components/settings.vue: | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "Pokazuj cel odpowiedzi" | ||||
|   timeline: "タイムライン" | ||||
|   show-my-renotes: "Pokazuj moje udostępnienia na osi czasu" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "Automatycznie pokazuj mapę" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   sound: "Dźwięk" | ||||
|   enable-sounds: "Włącz dźwięk" | ||||
|   enable-sounds-desc: "Odtwarzaj dźwięk przy wstawianiu wpisów, wysyłaniu lub otrzymywaniu wiadomości. Opcja ta jest zapamiętywana przez przeglądarkę." | ||||
|   volume: "Głośność" | ||||
|   test: "Test" | ||||
|   mobile: "Wersja mobilna" | ||||
|   disable-via-mobile: "Nie oznaczaj wpisów jako „wysłane z telefonu”" | ||||
|   language: "Język" | ||||
|   pick-language: "Wybierz język" | ||||
|   recommended: "Zalecane" | ||||
| @@ -784,6 +827,10 @@ desktop/views/components/settings.vue: | ||||
|   tools: "Narzędzia" | ||||
|   task-manager: "Menedżer zadań" | ||||
|   third-parties: "Autorzy trzeci" | ||||
|   navbar-position: "ナビゲーションバーの位置" | ||||
|   navbar-position-top: "上" | ||||
|   navbar-position-left: "左" | ||||
|   navbar-position-right: "右" | ||||
| desktop/views/components/settings.2fa.vue: | ||||
|   intro: "Jeżeli skonfigurujesz uwierzytelnianie dwuetapowe, aby zablokować się będziesz potrzebować (oprócz hasła) kodu ze skonfigurowanego urządzenia (np. smartfonu), co zwiększy bezpieczeństwo." | ||||
|   detail: "Zobacz szczegóły…" | ||||
| @@ -802,41 +849,39 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "Pomyślnie ukończono konfigurację!" | ||||
|   failed: "Nie udało się skonfigurować uwierzytelniania dwuetapowego, upewnij się że wprowadziłeś prawidłowy token." | ||||
|   info: "Od teraz, wprowadzaj token wyświetlany na urządzeniu przy każdym logowaniu do Misskey." | ||||
| desktop/views/components/settings.api.vue: | ||||
|   intro: "Aby uzyskać dostęp do API, ustaw ten token jako klucz 'i' parametrów żądań." | ||||
|   caution: "Nie pokazuj tego tokenu osobom trzecim (nie wprowadzaj go nigdzie indziej), aby konto nie trafiło w niepowołane ręce." | ||||
|   regeneration-of-token: "W przypadku wycieku tokenu, możesz wygenerować nowy." | ||||
|   regenerate-token: "Wygeneruj nowy token" | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
|   regeneration-of-token: "万が一このトークンが漏れたりその可能性がある場合はトークンを再生成できます。" | ||||
|   regenerate-token: "トークンを再生成" | ||||
|   token: "Token:" | ||||
|   enter-password: "Wprowadź hasło" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   console: | ||||
|     title: 'APIコンソール' | ||||
|     endpoint: 'エンドポイント' | ||||
|     parameter: 'パラメータ' | ||||
|     send: '送信' | ||||
|     sending: '応答待ち' | ||||
|     response: '結果' | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "Brak zautoryzowanych aplikacji" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "Maksymalnie" | ||||
|   in-use: " w użyciu." | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "Brak wyciszonych użytkowników" | ||||
| desktop/views/components/settings.password.vue: | ||||
|   reset: "Zmień hasło" | ||||
|   enter-current-password: "Wprowadź obecne hasło" | ||||
|   enter-new-password: "Wprowadź nowe hasło" | ||||
|   enter-new-password-again: "Wprowadź ponownie nowe hasło" | ||||
|   not-match: "Nowe hasła nie pasują do siebie" | ||||
|   changed: "Pomyślnie zmieniono hasło" | ||||
| desktop/views/components/settings.profile.vue: | ||||
|   avatar: "Awatar" | ||||
|   choice-avatar: "Wybierz obraz" | ||||
|   name: "Nazwa" | ||||
|   location: "Lokalizacja" | ||||
|   description: "Opis" | ||||
|   birthday: "Data urodzenia" | ||||
|   save: "Aktualizuj profil" | ||||
|   locked-account: "Zabezpiecz swoje konto" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "Inne" | ||||
|   is-bot: "To konto jest prowadzone przez bota" | ||||
|   is-cat: "To konto jest prowadzone przez kota" | ||||
|   profile-updated: "Zaktualizowano profil" | ||||
| common/views/components/drive-settings.vue: | ||||
|   max: "容量" | ||||
|   in-use: "使用中" | ||||
|   stats: "統計" | ||||
| common/views/components/mute-and-block.vue: | ||||
|   mute-and-block: "ミュートとブロック" | ||||
|   mute: "ミュート" | ||||
|   block: "ブロック" | ||||
|   no-muted-users: "ミュートしているユーザーはいません" | ||||
|   no-blocked-users: "ブロックしているユーザーはいません" | ||||
| common/views/components/password-settings.vue: | ||||
|   reset: "パスワードを変更する" | ||||
|   enter-current-password: "現在のパスワードを入力してください" | ||||
|   enter-new-password: "新しいパスワードを入力してください" | ||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||
|   not-match: "新しいパスワードが一致しません" | ||||
|   changed: "パスワードを変更しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "ten wpis jest prywatny" | ||||
|   deleted: "ten wpis został usunięty" | ||||
| @@ -861,7 +906,6 @@ desktop/views/components/ui.header.vue: | ||||
|   adjective: "さん" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "Twój profil" | ||||
|   drive: "Dysk" | ||||
|   favorites: "Ulubione" | ||||
|   lists: "Listy" | ||||
|   follow-requests: "Prośby o śledzenie" | ||||
| @@ -903,42 +947,100 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "Pop-out" | ||||
|   close: "Zamknij" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
| admin/views/index.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "ドライブ" | ||||
|   instance: "インスタンス" | ||||
|   emoji: "カスタム絵文字" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   announcements: "お知らせ" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   accounts: "アカウント" | ||||
|   notes: "投稿" | ||||
|   drive: "ドライブ" | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "このインスタンス" | ||||
|   federated: "連合" | ||||
|   invite: "招待" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   banner-url: "Banner URL" | ||||
|   disableRegistration: "Disable new user registration" | ||||
|   disableLocalTimeline: "Disable the local timeline" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の積算" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の積算" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| admin/views/emoji.vue: | ||||
|   add-emoji: | ||||
|     title: "絵文字の登録" | ||||
|     name: "絵文字名" | ||||
|     name-desc: "a~z 0~9 _ の文字が使えます。" | ||||
|     aliases: "エイリアス" | ||||
|     aliases-desc: "スペースで区切って複数設定できます。" | ||||
|     url: "絵文字画像URL" | ||||
|     add: "追加" | ||||
|   emojis: | ||||
|     title: "絵文字一覧" | ||||
|     update: "更新" | ||||
|     remove: "削除" | ||||
| admin/views/announcements.vue: | ||||
|   announcements: "お知らせ" | ||||
|   save: "保存" | ||||
|   remove: "削除" | ||||
|   add: "追加" | ||||
|   title: "タイトル" | ||||
|   text: "内容" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| 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" | ||||
|   deleted: "ten wpis został usunięty" | ||||
| desktop/views/pages/deck/deck.user-column.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   images: "画像" | ||||
|   activity: "アクティビティ" | ||||
|   timeline: "タイムライン" | ||||
|   pinned-notes: "ピン留めされた投稿" | ||||
|   push-to-a-list: "リストに追加" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
| @@ -991,10 +1093,7 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   no-users: "Brak użytkowników" | ||||
| 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" | ||||
| desktop/views/pages/user/user.home.vue: | ||||
|   last-used-at: "Ostatnio aktywny: " | ||||
|   last-used-at: "最終アクセス" | ||||
| desktop/views/pages/user/user.photos.vue: | ||||
|   title: "Zdjęcia" | ||||
|   loading: "Ładowanie" | ||||
| @@ -1007,6 +1106,9 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "Wycisz" | ||||
|   muted: "Wyciszyłeś" | ||||
|   unmute: "Cofnij wyciszenie" | ||||
|   block: "ブロックする" | ||||
|   unblock: "ブロック解除" | ||||
|   block-confirm: "このユーザーをブロックしますか?" | ||||
|   push-to-a-list: "Dodaj do listy" | ||||
|   list-pushed: "Dodałeś(-aś) {user} do {list}." | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| @@ -1014,6 +1116,10 @@ desktop/views/pages/user/user.header.vue: | ||||
|   following: "Śledzeni" | ||||
|   followers: "Śledzący" | ||||
|   is-bot: "To konto jest botem" | ||||
|   years-old: "歳" | ||||
|   year: "年" | ||||
|   month: "月" | ||||
|   day: "日" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "Wpisy" | ||||
|   with-replies: "Wpisy i odpowiedzi" | ||||
| @@ -1043,7 +1149,6 @@ desktop/views/widgets/users.vue: | ||||
|   refresh: "Pokaż innych" | ||||
|   no-one: "Pusto" | ||||
| mobile/views/components/drive.vue: | ||||
|   drive: "Dysk" | ||||
|   used: "użyto" | ||||
|   folder-count: "Katalog(i)" | ||||
|   count-separator: ", " | ||||
| @@ -1073,6 +1178,8 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   hash: "Hash (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "To jest zawartość NSFW" | ||||
|   click-to-show: "Naciśnij aby wyświetlić" | ||||
| @@ -1145,7 +1252,6 @@ mobile/views/components/ui.nav.vue: | ||||
|   messaging: "Wiadomości" | ||||
|   follow-requests: "Prośby o śledzenie" | ||||
|   search: "Szukaj" | ||||
|   drive: "Dysk" | ||||
|   favorites: "Ulubione" | ||||
|   user-lists: "Listy" | ||||
|   widgets: "Widżety" | ||||
| @@ -1168,7 +1274,6 @@ mobile/views/pages/user-lists.vue: | ||||
|   title: "Listy" | ||||
|   enter-list-name: "Wprowadź nazwę listy" | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "Dysk" | ||||
|   more: "Załaduj więcej" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "Rozpocznijmy! 📦" | ||||
| @@ -1213,23 +1318,6 @@ mobile/views/pages/notifications.vue: | ||||
|   read-all: "Czy na pewno chcesz oznaczyć wszystkie powiadomienia jako przeczytane?" | ||||
| mobile/views/pages/games/reversi.vue: | ||||
|   reversi: "Reversi" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "Profil" | ||||
|   name: "Nazwa" | ||||
|   account: "Konto" | ||||
|   location: "Lokalizacja" | ||||
|   description: "Opis" | ||||
|   birthday: "Data urodzenia" | ||||
|   avatar: "Awatar" | ||||
|   banner: "Baner" | ||||
|   is-cat: "To konto jest prowadzone przez kota" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "Aktualizuj profil" | ||||
|   saved: "Pomyślnie zaktualizowano profil" | ||||
|   uploading: "Wysyłanie" | ||||
|   upload-failed: "Wysyłanie nie powiodło się" | ||||
| mobile/views/pages/search.vue: | ||||
|   search: "Szukaj" | ||||
|   empty: "Nie znaleziono wpisów zawierających '{}'" | ||||
| @@ -1285,6 +1373,8 @@ mobile/views/pages/settings.vue: | ||||
|   signout: "Wyloguj" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   mark-as-read-all-unread-notes: "すべての投稿を既読にする" | ||||
|   password: "パスワード" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "Śledzi Cię" | ||||
|   following: "Śledzeni" | ||||
| @@ -1294,8 +1384,10 @@ mobile/views/pages/user.vue: | ||||
|   timeline: "Oś czasu" | ||||
|   media: "Multimedia" | ||||
|   is-suspended: "To konto zostało zablokowane" | ||||
|   is-remote: "To jest użytkownik zdalnej instancji, informacje mogą nie być w pełni dokładne." | ||||
|   view-remote: "Wyświetl dokładne informacje" | ||||
|   mute: "ミュート" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "Ostatnie wpisy" | ||||
|   images: "Zdjęcia" | ||||
| @@ -1341,3 +1433,29 @@ docs: | ||||
|       description: "Opis" | ||||
| dev/views/index.vue: | ||||
|   manage-apps: "Zarządzaj aplikacjami" | ||||
| dev/views/apps.vue: | ||||
|   manage-apps: "アプリを管理" | ||||
|   create-app: "アプリ作成" | ||||
|   app-missing: "アプリなし" | ||||
| dev/views/new-app.vue: | ||||
|   create-app: "アプリケーションの作成" | ||||
|   app-name: "アプリケーション名" | ||||
|   app-name-desc: "あなたのアプリの名称。" | ||||
|   app-name-ex: "ex) Misskey for iOS" | ||||
|   app-overview: "アプリの概要" | ||||
|   app-desc: "あなたのアプリの簡単な説明や紹介。" | ||||
|   app-desc-ex: "ex) Misskey iOSクライアント。" | ||||
|   callback-url: "コールバックURL (オプション)" | ||||
|   callback-url-desc: "ユーザーが認証フォームで認証した際にリダイレクトするURLを設定できます。" | ||||
|   authority: "権限" | ||||
|   authority-desc: "ここで要求した機能だけがAPIからアクセスできます。" | ||||
|   authority-warning: "アプリ作成後も変更できますが、新たな権限を付与する場合、その時点で関連付けられているユーザーキーはすべて無効になります。" | ||||
|   account-read: "アカウントの情報を見る。" | ||||
|   account-write: "アカウントの情報を操作する。" | ||||
|   note-write: "投稿する。" | ||||
|   reaction-write: "リアクションしたりリアクションをキャンセルする。" | ||||
|   following-write: "フォローしたりフォロー解除する。" | ||||
|   drive-read: "ドライブを見る。" | ||||
|   drive-write: "ドライブを操作する。" | ||||
|   notification-read: "通知を見る。" | ||||
|   notification-write: "通知を操作する。" | ||||
|   | ||||
| @@ -25,6 +25,14 @@ common: | ||||
|   application-authorization: "Aplicativos autorizados" | ||||
|   close: "Fechar" | ||||
|   do-not-copy-paste: "Por favor, não digite ou copie o código aqui. A conta pode ser comprometida." | ||||
|   BSoD: | ||||
|     fatal-error: ":( 致命的な問題が発生しました。" | ||||
|     update-browser-os: "お使いのブラウザ(またはOS)のバージョンを更新すると解決する可能性があります。" | ||||
|     error-code: "エラーコード" | ||||
|     browser-version: "ブラウザ バージョン" | ||||
|     client-version: "クライアント バージョン" | ||||
|     email-support: "問題が解決しない場合は、上記の情報をお書き添えの上 syuilotan@yahoo.co.jp までご連絡ください。" | ||||
|     thanks: "Thank you for using Misskey." | ||||
|   got-it: "Entendi!" | ||||
|   customization-tips: | ||||
|     title: "Dicas de personalização" | ||||
| @@ -54,6 +62,7 @@ common: | ||||
|     years_ago: "{} ano(s) atrás" | ||||
|   month-and-day: "{day}/{month}" | ||||
|   trash: "Lixo" | ||||
|   drive: "ドライブ" | ||||
|   weekday-short: | ||||
|     sunday: "Dom" | ||||
|     monday: "Seg" | ||||
| @@ -115,6 +124,12 @@ common: | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|   error: | ||||
|     title: '問題が発生しました' | ||||
|     retry: 'やり直す' | ||||
|   reversi: | ||||
|     drawn: "Empatado" | ||||
|     my-turn: "Seu turno" | ||||
| @@ -170,6 +185,8 @@ common: | ||||
|     rename: "Renomear" | ||||
|     stack-left: "左に重ねる" | ||||
|     pop-right: "Acoplar à direita" | ||||
|   dev: "アプリの作成に失敗しました。再度お試しください。" | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
| auth/views/form.vue: | ||||
|   share-access: "Você <b>permite</b> que <i>{{ app.name }}</i> acesse sua conta?" | ||||
|   permission-ask: "Este aplicativo precisa das seguintes permissões:" | ||||
| @@ -335,6 +352,7 @@ common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   unfavorite: "お気に入り解除" | ||||
|   pin: "ピン留め" | ||||
|   unpin: "ピン留め解除" | ||||
|   delete: "削除" | ||||
| @@ -415,6 +433,25 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   careful-bot: "Botからのフォローだけ承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "確認中" | ||||
|   no-broadcasts: "お知らせはありません" | ||||
| @@ -506,11 +543,14 @@ desktop/views/components/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
| @@ -540,7 +580,6 @@ desktop/views/components/crop-window.vue: | ||||
|   ok: "決定" | ||||
| desktop/views/components/drive-window.vue: | ||||
|   used: "使用中" | ||||
|   drive: "ドライブ" | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
| @@ -570,8 +609,6 @@ desktop/views/components/drive.folder.vue: | ||||
|     rename: "名前を変更" | ||||
|     rename-folder: "フォルダ名の変更" | ||||
|     input-new-folder-name: "新しいフォルダ名を入力してください" | ||||
| desktop/views/components/drive.nav-folder.vue: | ||||
|   drive: "ドライブ" | ||||
| desktop/views/components/drive.vue: | ||||
|   search: "検索" | ||||
|   load-more: "もっと読み込む" | ||||
| @@ -639,7 +676,7 @@ desktop/views/components/note-detail.vue: | ||||
|   location: "位置情報" | ||||
|   renote: "Renote" | ||||
|   add-reaction: "リアクション" | ||||
| desktop/views/components/notes.note.vue: | ||||
| desktop/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   reply: "返信" | ||||
|   renote: "Renote" | ||||
| @@ -705,8 +742,8 @@ desktop/views/components/settings.vue: | ||||
|   profile: "プロフィール" | ||||
|   notification: "通知" | ||||
|   apps: "アプリ" | ||||
|   mute: "ミュート" | ||||
|   drive: "ドライブ" | ||||
|   mute-and-block: "ミュート/ブロック" | ||||
|   blocking: "ブロック" | ||||
|   security: "セキュリティ" | ||||
|   signin: "サインイン履歴" | ||||
|   password: "パスワード" | ||||
| @@ -725,8 +762,12 @@ desktop/views/components/settings.vue: | ||||
|   advanced: "詳細設定" | ||||
|   api-via-stream: "ストリームを経由したAPIリクエスト" | ||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "デザインと表示" | ||||
|   customize: "ホームをカスタマイズ" | ||||
|   wallpaper: "壁紙" | ||||
|   choose-wallpaper: "壁紙を選択" | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
| @@ -738,17 +779,19 @@ desktop/views/components/settings.vue: | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   timeline: "タイムライン" | ||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||
|   volume: "ボリューム" | ||||
|   test: "テスト" | ||||
|   mobile: "モバイル" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   language: "言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
| @@ -784,6 +827,10 @@ desktop/views/components/settings.vue: | ||||
|   tools: "ツール" | ||||
|   task-manager: "タスクマネージャ" | ||||
|   third-parties: "サードパーティ" | ||||
|   navbar-position: "ナビゲーションバーの位置" | ||||
|   navbar-position-top: "上" | ||||
|   navbar-position-left: "左" | ||||
|   navbar-position-right: "右" | ||||
| desktop/views/components/settings.2fa.vue: | ||||
|   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" | ||||
|   detail: "詳細..." | ||||
| @@ -802,41 +849,39 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "設定が完了しました!" | ||||
|   failed: "設定に失敗しました。トークンに誤りがないかご確認ください。" | ||||
|   info: "次回サインインからは、同様にパスワードに加えてデバイスに表示されているトークンを入力します。" | ||||
| desktop/views/components/settings.api.vue: | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
|   regeneration-of-token: "万が一このトークンが漏れたりその可能性がある場合はトークンを再生成できます。" | ||||
|   regenerate-token: "トークンを再生成" | ||||
|   token: "Token:" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   console: | ||||
|     title: 'APIコンソール' | ||||
|     endpoint: 'エンドポイント' | ||||
|     parameter: 'パラメータ' | ||||
|     send: '送信' | ||||
|     sending: '応答待ち' | ||||
|     response: '結果' | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "連携しているアプリケーションはありません" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "中" | ||||
| common/views/components/drive-settings.vue: | ||||
|   max: "容量" | ||||
|   in-use: "使用中" | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "ミュートしているユーザーはいません" | ||||
| desktop/views/components/settings.password.vue: | ||||
|   stats: "統計" | ||||
| common/views/components/mute-and-block.vue: | ||||
|   mute-and-block: "ミュートとブロック" | ||||
|   mute: "ミュート" | ||||
|   block: "ブロック" | ||||
|   no-muted-users: "ミュートしているユーザーはいません" | ||||
|   no-blocked-users: "ブロックしているユーザーはいません" | ||||
| common/views/components/password-settings.vue: | ||||
|   reset: "パスワードを変更する" | ||||
|   enter-current-password: "現在のパスワードを入力してください" | ||||
|   enter-new-password: "新しいパスワードを入力してください" | ||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||
|   not-match: "新しいパスワードが一致しません" | ||||
|   changed: "パスワードを変更しました" | ||||
| desktop/views/components/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   choice-avatar: "画像を選択" | ||||
|   name: "名前" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   profile-updated: "プロフィールを更新しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| @@ -861,7 +906,6 @@ desktop/views/components/ui.header.vue: | ||||
|   adjective: "さん" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "プロフィール" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
| @@ -903,42 +947,100 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
| admin/views/index.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   instance: "インスタンス" | ||||
|   emoji: "カスタム絵文字" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
|   announcements: "お知らせ" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   accounts: "アカウント" | ||||
|   notes: "投稿" | ||||
|   drive: "ドライブ" | ||||
|   users: "Usuários" | ||||
|   update: "Actualizações" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "Todos os usuários" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "このインスタンス" | ||||
|   federated: "連合" | ||||
|   invite: "招待" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   banner-url: "Banner URL" | ||||
|   disableRegistration: "Disable new user registration" | ||||
|   disableLocalTimeline: "Disable the local timeline" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の積算" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の積算" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| admin/views/emoji.vue: | ||||
|   add-emoji: | ||||
|     title: "絵文字の登録" | ||||
|     name: "絵文字名" | ||||
|     name-desc: "a~z 0~9 _ の文字が使えます。" | ||||
|     aliases: "エイリアス" | ||||
|     aliases-desc: "スペースで区切って複数設定できます。" | ||||
|     url: "絵文字画像URL" | ||||
|     add: "追加" | ||||
|   emojis: | ||||
|     title: "絵文字一覧" | ||||
|     update: "更新" | ||||
|     remove: "削除" | ||||
| admin/views/announcements.vue: | ||||
|   announcements: "お知らせ" | ||||
|   save: "保存" | ||||
|   remove: "削除" | ||||
|   add: "追加" | ||||
|   title: "タイトル" | ||||
|   text: "内容" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| 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: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/pages/deck/deck.user-column.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   images: "画像" | ||||
|   activity: "アクティビティ" | ||||
|   timeline: "タイムライン" | ||||
|   pinned-notes: "ピン留めされた投稿" | ||||
|   push-to-a-list: "リストに追加" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
| @@ -991,9 +1093,6 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
| desktop/views/pages/user/user.home.vue: | ||||
|   last-used-at: "最終アクセス" | ||||
| desktop/views/pages/user/user.photos.vue: | ||||
|   title: "フォト" | ||||
| @@ -1007,6 +1106,9 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "ミュートする" | ||||
|   muted: "ミュートしています" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロックする" | ||||
|   unblock: "ブロック解除" | ||||
|   block-confirm: "このユーザーをブロックしますか?" | ||||
|   push-to-a-list: "リストに追加" | ||||
|   list-pushed: "{user}を{list}に追加しました。" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| @@ -1014,6 +1116,10 @@ desktop/views/pages/user/user.header.vue: | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   years-old: "歳" | ||||
|   year: "年" | ||||
|   month: "月" | ||||
|   day: "日" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "投稿" | ||||
|   with-replies: "投稿と返信" | ||||
| @@ -1043,7 +1149,6 @@ desktop/views/widgets/users.vue: | ||||
|   refresh: "他を見る" | ||||
|   no-one: "いません!" | ||||
| mobile/views/components/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   used: "使用中" | ||||
|   folder-count: "フォルダ" | ||||
|   count-separator: "、" | ||||
| @@ -1073,6 +1178,8 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -1145,7 +1252,6 @@ mobile/views/components/ui.nav.vue: | ||||
|   messaging: "メッセージ" | ||||
|   follow-requests: "フォロー申請" | ||||
|   search: "検索" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   user-lists: "リスト" | ||||
|   widgets: "ウィジェット" | ||||
| @@ -1168,7 +1274,6 @@ mobile/views/pages/user-lists.vue: | ||||
|   title: "リスト" | ||||
|   enter-list-name: "リスト名を入力してください" | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   more: "もっと見る" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "📦 始めましょう" | ||||
| @@ -1213,23 +1318,6 @@ mobile/views/pages/notifications.vue: | ||||
|   read-all: "すべての通知を既読にしますか?" | ||||
| mobile/views/pages/games/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "Nome" | ||||
|   account: "Conta" | ||||
|   location: "Lugar" | ||||
|   description: "Biografia" | ||||
|   birthday: "Data de nascimento" | ||||
|   avatar: "Avatar" | ||||
|   banner: "Capa" | ||||
|   is-cat: "Esta conta é gato" | ||||
|   is-locked: "Pedido para seguir precisa ser aprovado" | ||||
|   advanced: "Avançado" | ||||
|   privacy: "Provacidade" | ||||
|   save: "Atualizar perfil" | ||||
|   saved: "Perfil atualizado" | ||||
|   uploading: "Enviando" | ||||
|   upload-failed: "Falha ao enviar" | ||||
| mobile/views/pages/search.vue: | ||||
|   search: "Pesquisar" | ||||
|   empty: "「{}」に関する投稿は見つかりませんでした。" | ||||
| @@ -1285,6 +1373,8 @@ mobile/views/pages/settings.vue: | ||||
|   signout: "Sair" | ||||
|   sound: "Sons" | ||||
|   enable-sounds: "Ativar sons" | ||||
|   mark-as-read-all-unread-notes: "すべての投稿を既読にする" | ||||
|   password: "パスワード" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "Te segue" | ||||
|   following: "Seguindo" | ||||
| @@ -1294,8 +1384,10 @@ mobile/views/pages/user.vue: | ||||
|   timeline: "Linha do tempo" | ||||
|   media: "Mídia" | ||||
|   is-suspended: "Esta conta foi suspensa" | ||||
|   is-remote: "Este é uma usuário remoto. O perfil que vê aqui pode não estar completo." | ||||
|   view-remote: "Ver o perfil completo." | ||||
|   mute: "ミュート" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "Notas recentes" | ||||
|   images: "Imagens" | ||||
| @@ -1304,7 +1396,7 @@ mobile/views/pages/user/home.vue: | ||||
|   domains: "Domínios" | ||||
|   frequently-replied-users: "Perguntas frequentes" | ||||
|   followers-you-know: "Seguidores que você conhece" | ||||
|   last-used-at: "Ativo pela última vez:" | ||||
|   last-used-at: "Ativo pela última vez" | ||||
| mobile/views/pages/user/home.followers-you-know.vue: | ||||
|   loading: "Carregando" | ||||
|   no-users: "知り合いのユーザーはいません" | ||||
| @@ -1341,3 +1433,29 @@ docs: | ||||
|       description: "Descrição" | ||||
| dev/views/index.vue: | ||||
|   manage-apps: "Gerenciar aplicativos" | ||||
| dev/views/apps.vue: | ||||
|   manage-apps: "アプリを管理" | ||||
|   create-app: "アプリ作成" | ||||
|   app-missing: "アプリなし" | ||||
| dev/views/new-app.vue: | ||||
|   create-app: "アプリケーションの作成" | ||||
|   app-name: "アプリケーション名" | ||||
|   app-name-desc: "あなたのアプリの名称。" | ||||
|   app-name-ex: "ex) Misskey for iOS" | ||||
|   app-overview: "アプリの概要" | ||||
|   app-desc: "あなたのアプリの簡単な説明や紹介。" | ||||
|   app-desc-ex: "ex) Misskey iOSクライアント。" | ||||
|   callback-url: "コールバックURL (オプション)" | ||||
|   callback-url-desc: "ユーザーが認証フォームで認証した際にリダイレクトするURLを設定できます。" | ||||
|   authority: "権限" | ||||
|   authority-desc: "ここで要求した機能だけがAPIからアクセスできます。" | ||||
|   authority-warning: "アプリ作成後も変更できますが、新たな権限を付与する場合、その時点で関連付けられているユーザーキーはすべて無効になります。" | ||||
|   account-read: "アカウントの情報を見る。" | ||||
|   account-write: "アカウントの情報を操作する。" | ||||
|   note-write: "投稿する。" | ||||
|   reaction-write: "リアクションしたりリアクションをキャンセルする。" | ||||
|   following-write: "フォローしたりフォロー解除する。" | ||||
|   drive-read: "ドライブを見る。" | ||||
|   drive-write: "ドライブを操作する。" | ||||
|   notification-read: "通知を見る。" | ||||
|   notification-write: "通知を操作する。" | ||||
|   | ||||
| @@ -3,9 +3,9 @@ meta: | ||||
|   lang: "Русский язык" | ||||
|   divider: "" | ||||
| common: | ||||
|   misskey: "A ⭐ of fediverse" | ||||
|   about-title: "A ⭐ of fediverse." | ||||
|   about: "Misskeyを見つけていただき、ありがとうございます。Misskeyは、地球で生まれた<b>分散マイクロブログSNS</b>です。Fediverse(様々なSNSで構成される宇宙)の中に存在するため、他のSNSと相互に繋がっています。暫し都会の喧騒から離れて、新しいインターネットにダイブしてみませんか。" | ||||
|   misskey: "Мы — ⭐ fediverse" | ||||
|   about-title: "Мы — ⭐ fediverse" | ||||
|   about: "Спасибо, что нашли Misskey. Misskey — это <b>децентрализованная платформа для микроблоггинга</b> родом с планеты Земля. Поскольку она существует внутри Fediverse (вселенной различных социальных платформ), она связана с другими платформами. Отдохните от шума большого города — и познакомьтесь с новым интернетом." | ||||
|   intro: | ||||
|     title: "Misskeyって?" | ||||
|     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" | ||||
| @@ -25,6 +25,14 @@ common: | ||||
|   application-authorization: "アプリの連携" | ||||
|   close: "閉じる" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   BSoD: | ||||
|     fatal-error: ":( 致命的な問題が発生しました。" | ||||
|     update-browser-os: "お使いのブラウザ(またはOS)のバージョンを更新すると解決する可能性があります。" | ||||
|     error-code: "エラーコード" | ||||
|     browser-version: "ブラウザ バージョン" | ||||
|     client-version: "クライアント バージョン" | ||||
|     email-support: "問題が解決しない場合は、上記の情報をお書き添えの上 syuilotan@yahoo.co.jp までご連絡ください。" | ||||
|     thanks: "Thank you for using Misskey." | ||||
|   got-it: "わかった" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
| @@ -54,6 +62,7 @@ common: | ||||
|     years_ago: "{}年前" | ||||
|   month-and-day: "{month}月 {day}日" | ||||
|   trash: "ゴミ箱" | ||||
|   drive: "ドライブ" | ||||
|   weekday-short: | ||||
|     sunday: "日" | ||||
|     monday: "月" | ||||
| @@ -115,6 +124,12 @@ common: | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|   error: | ||||
|     title: '問題が発生しました' | ||||
|     retry: 'やり直す' | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
| @@ -170,6 +185,8 @@ common: | ||||
|     rename: "名前を変更" | ||||
|     stack-left: "左に重ねる" | ||||
|     pop-right: "右に出す" | ||||
|   dev: "アプリの作成に失敗しました。再度お試しください。" | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{{ app.name }}</i>があなたのアカウントにアクセスすることを<b>許可</b>しますか?" | ||||
|   permission-ask: "このアプリは次の権限を要求しています:" | ||||
| @@ -335,6 +352,7 @@ common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   unfavorite: "お気に入り解除" | ||||
|   pin: "ピン留め" | ||||
|   unpin: "ピン留め解除" | ||||
|   delete: "削除" | ||||
| @@ -415,6 +433,25 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   careful-bot: "Botからのフォローだけ承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "確認中" | ||||
|   no-broadcasts: "お知らせはありません" | ||||
| @@ -506,11 +543,14 @@ desktop/views/components/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
| @@ -540,7 +580,6 @@ desktop/views/components/crop-window.vue: | ||||
|   ok: "決定" | ||||
| desktop/views/components/drive-window.vue: | ||||
|   used: "使用中" | ||||
|   drive: "ドライブ" | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
| @@ -570,8 +609,6 @@ desktop/views/components/drive.folder.vue: | ||||
|     rename: "名前を変更" | ||||
|     rename-folder: "フォルダ名の変更" | ||||
|     input-new-folder-name: "新しいフォルダ名を入力してください" | ||||
| desktop/views/components/drive.nav-folder.vue: | ||||
|   drive: "ドライブ" | ||||
| desktop/views/components/drive.vue: | ||||
|   search: "検索" | ||||
|   load-more: "もっと読み込む" | ||||
| @@ -639,7 +676,7 @@ desktop/views/components/note-detail.vue: | ||||
|   location: "位置情報" | ||||
|   renote: "Renote" | ||||
|   add-reaction: "リアクション" | ||||
| desktop/views/components/notes.note.vue: | ||||
| desktop/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   reply: "返信" | ||||
|   renote: "Renote" | ||||
| @@ -705,8 +742,8 @@ desktop/views/components/settings.vue: | ||||
|   profile: "プロフィール" | ||||
|   notification: "通知" | ||||
|   apps: "アプリ" | ||||
|   mute: "ミュート" | ||||
|   drive: "ドライブ" | ||||
|   mute-and-block: "ミュート/ブロック" | ||||
|   blocking: "ブロック" | ||||
|   security: "セキュリティ" | ||||
|   signin: "サインイン履歴" | ||||
|   password: "パスワード" | ||||
| @@ -725,8 +762,12 @@ desktop/views/components/settings.vue: | ||||
|   advanced: "詳細設定" | ||||
|   api-via-stream: "ストリームを経由したAPIリクエスト" | ||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "デザインと表示" | ||||
|   customize: "ホームをカスタマイズ" | ||||
|   wallpaper: "壁紙" | ||||
|   choose-wallpaper: "壁紙を選択" | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
| @@ -738,17 +779,19 @@ desktop/views/components/settings.vue: | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   timeline: "タイムライン" | ||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||
|   volume: "ボリューム" | ||||
|   test: "テスト" | ||||
|   mobile: "モバイル" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   language: "言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
| @@ -784,6 +827,10 @@ desktop/views/components/settings.vue: | ||||
|   tools: "ツール" | ||||
|   task-manager: "タスクマネージャ" | ||||
|   third-parties: "サードパーティ" | ||||
|   navbar-position: "ナビゲーションバーの位置" | ||||
|   navbar-position-top: "上" | ||||
|   navbar-position-left: "左" | ||||
|   navbar-position-right: "右" | ||||
| desktop/views/components/settings.2fa.vue: | ||||
|   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" | ||||
|   detail: "詳細..." | ||||
| @@ -802,41 +849,39 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "設定が完了しました!" | ||||
|   failed: "設定に失敗しました。トークンに誤りがないかご確認ください。" | ||||
|   info: "次回サインインからは、同様にパスワードに加えてデバイスに表示されているトークンを入力します。" | ||||
| desktop/views/components/settings.api.vue: | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
|   regeneration-of-token: "万が一このトークンが漏れたりその可能性がある場合はトークンを再生成できます。" | ||||
|   regenerate-token: "トークンを再生成" | ||||
|   token: "Token:" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   console: | ||||
|     title: 'APIコンソール' | ||||
|     endpoint: 'エンドポイント' | ||||
|     parameter: 'パラメータ' | ||||
|     send: '送信' | ||||
|     sending: '応答待ち' | ||||
|     response: '結果' | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "連携しているアプリケーションはありません" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "中" | ||||
| common/views/components/drive-settings.vue: | ||||
|   max: "容量" | ||||
|   in-use: "使用中" | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "ミュートしているユーザーはいません" | ||||
| desktop/views/components/settings.password.vue: | ||||
|   stats: "統計" | ||||
| common/views/components/mute-and-block.vue: | ||||
|   mute-and-block: "ミュートとブロック" | ||||
|   mute: "ミュート" | ||||
|   block: "ブロック" | ||||
|   no-muted-users: "ミュートしているユーザーはいません" | ||||
|   no-blocked-users: "ブロックしているユーザーはいません" | ||||
| common/views/components/password-settings.vue: | ||||
|   reset: "パスワードを変更する" | ||||
|   enter-current-password: "現在のパスワードを入力してください" | ||||
|   enter-new-password: "新しいパスワードを入力してください" | ||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||
|   not-match: "新しいパスワードが一致しません" | ||||
|   changed: "パスワードを変更しました" | ||||
| desktop/views/components/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   choice-avatar: "画像を選択" | ||||
|   name: "名前" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   profile-updated: "プロフィールを更新しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| @@ -861,7 +906,6 @@ desktop/views/components/ui.header.vue: | ||||
|   adjective: "さん" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "プロフィール" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
| @@ -903,42 +947,100 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
| admin/views/index.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "ドライブ" | ||||
|   instance: "インスタンス" | ||||
|   emoji: "カスタム絵文字" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   announcements: "お知らせ" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   accounts: "アカウント" | ||||
|   notes: "投稿" | ||||
|   drive: "ドライブ" | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "このインスタンス" | ||||
|   federated: "連合" | ||||
|   invite: "招待" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   banner-url: "Banner URL" | ||||
|   disableRegistration: "Disable new user registration" | ||||
|   disableLocalTimeline: "Disable the local timeline" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の積算" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の積算" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| admin/views/emoji.vue: | ||||
|   add-emoji: | ||||
|     title: "絵文字の登録" | ||||
|     name: "絵文字名" | ||||
|     name-desc: "a~z 0~9 _ の文字が使えます。" | ||||
|     aliases: "エイリアス" | ||||
|     aliases-desc: "スペースで区切って複数設定できます。" | ||||
|     url: "絵文字画像URL" | ||||
|     add: "追加" | ||||
|   emojis: | ||||
|     title: "絵文字一覧" | ||||
|     update: "更新" | ||||
|     remove: "削除" | ||||
| admin/views/announcements.vue: | ||||
|   announcements: "お知らせ" | ||||
|   save: "保存" | ||||
|   remove: "削除" | ||||
|   add: "追加" | ||||
|   title: "タイトル" | ||||
|   text: "内容" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| 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: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/pages/deck/deck.user-column.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   images: "画像" | ||||
|   activity: "アクティビティ" | ||||
|   timeline: "タイムライン" | ||||
|   pinned-notes: "ピン留めされた投稿" | ||||
|   push-to-a-list: "リストに追加" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
| @@ -991,9 +1093,6 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
| desktop/views/pages/user/user.home.vue: | ||||
|   last-used-at: "最終アクセス" | ||||
| desktop/views/pages/user/user.photos.vue: | ||||
|   title: "フォト" | ||||
| @@ -1007,6 +1106,9 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "ミュートする" | ||||
|   muted: "ミュートしています" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロックする" | ||||
|   unblock: "ブロック解除" | ||||
|   block-confirm: "このユーザーをブロックしますか?" | ||||
|   push-to-a-list: "リストに追加" | ||||
|   list-pushed: "{user}を{list}に追加しました。" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| @@ -1014,6 +1116,10 @@ desktop/views/pages/user/user.header.vue: | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   years-old: "歳" | ||||
|   year: "年" | ||||
|   month: "月" | ||||
|   day: "日" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "投稿" | ||||
|   with-replies: "投稿と返信" | ||||
| @@ -1043,7 +1149,6 @@ desktop/views/widgets/users.vue: | ||||
|   refresh: "他を見る" | ||||
|   no-one: "いません!" | ||||
| mobile/views/components/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   used: "使用中" | ||||
|   folder-count: "フォルダ" | ||||
|   count-separator: "、" | ||||
| @@ -1073,6 +1178,8 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -1145,7 +1252,6 @@ mobile/views/components/ui.nav.vue: | ||||
|   messaging: "メッセージ" | ||||
|   follow-requests: "フォロー申請" | ||||
|   search: "検索" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   user-lists: "リスト" | ||||
|   widgets: "ウィジェット" | ||||
| @@ -1168,7 +1274,6 @@ mobile/views/pages/user-lists.vue: | ||||
|   title: "リスト" | ||||
|   enter-list-name: "リスト名を入力してください" | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   more: "もっと見る" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "📦 始めましょう" | ||||
| @@ -1213,23 +1318,6 @@ mobile/views/pages/notifications.vue: | ||||
|   read-all: "すべての通知を既読にしますか?" | ||||
| mobile/views/pages/games/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
| mobile/views/pages/search.vue: | ||||
|   search: "検索" | ||||
|   empty: "「{}」に関する投稿は見つかりませんでした。" | ||||
| @@ -1285,6 +1373,8 @@ mobile/views/pages/settings.vue: | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   mark-as-read-all-unread-notes: "すべての投稿を既読にする" | ||||
|   password: "パスワード" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   following: "フォロー" | ||||
| @@ -1294,8 +1384,10 @@ mobile/views/pages/user.vue: | ||||
|   timeline: "タイムライン" | ||||
|   media: "メディア" | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
|   mute: "ミュート" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "最近の投稿" | ||||
|   images: "画像" | ||||
| @@ -1341,3 +1433,29 @@ docs: | ||||
|       description: "説明" | ||||
| dev/views/index.vue: | ||||
|   manage-apps: "アプリの管理" | ||||
| dev/views/apps.vue: | ||||
|   manage-apps: "アプリを管理" | ||||
|   create-app: "アプリ作成" | ||||
|   app-missing: "アプリなし" | ||||
| dev/views/new-app.vue: | ||||
|   create-app: "アプリケーションの作成" | ||||
|   app-name: "アプリケーション名" | ||||
|   app-name-desc: "あなたのアプリの名称。" | ||||
|   app-name-ex: "ex) Misskey for iOS" | ||||
|   app-overview: "アプリの概要" | ||||
|   app-desc: "あなたのアプリの簡単な説明や紹介。" | ||||
|   app-desc-ex: "ex) Misskey iOSクライアント。" | ||||
|   callback-url: "コールバックURL (オプション)" | ||||
|   callback-url-desc: "ユーザーが認証フォームで認証した際にリダイレクトするURLを設定できます。" | ||||
|   authority: "権限" | ||||
|   authority-desc: "ここで要求した機能だけがAPIからアクセスできます。" | ||||
|   authority-warning: "アプリ作成後も変更できますが、新たな権限を付与する場合、その時点で関連付けられているユーザーキーはすべて無効になります。" | ||||
|   account-read: "アカウントの情報を見る。" | ||||
|   account-write: "アカウントの情報を操作する。" | ||||
|   note-write: "投稿する。" | ||||
|   reaction-write: "リアクションしたりリアクションをキャンセルする。" | ||||
|   following-write: "フォローしたりフォロー解除する。" | ||||
|   drive-read: "ドライブを見る。" | ||||
|   drive-write: "ドライブを操作する。" | ||||
|   notification-read: "通知を見る。" | ||||
|   notification-write: "通知を操作する。" | ||||
|   | ||||
| @@ -25,6 +25,14 @@ common: | ||||
|   application-authorization: "アプリの連携" | ||||
|   close: "閉じる" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   BSoD: | ||||
|     fatal-error: ":( 致命的な問題が発生しました。" | ||||
|     update-browser-os: "お使いのブラウザ(またはOS)のバージョンを更新すると解決する可能性があります。" | ||||
|     error-code: "エラーコード" | ||||
|     browser-version: "ブラウザ バージョン" | ||||
|     client-version: "クライアント バージョン" | ||||
|     email-support: "問題が解決しない場合は、上記の情報をお書き添えの上 syuilotan@yahoo.co.jp までご連絡ください。" | ||||
|     thanks: "Thank you for using Misskey." | ||||
|   got-it: "わかった" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
| @@ -54,6 +62,7 @@ common: | ||||
|     years_ago: "{}年前" | ||||
|   month-and-day: "{month}月 {day}日" | ||||
|   trash: "ゴミ箱" | ||||
|   drive: "ドライブ" | ||||
|   weekday-short: | ||||
|     sunday: "日" | ||||
|     monday: "月" | ||||
| @@ -115,6 +124,12 @@ common: | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|   error: | ||||
|     title: '問題が発生しました' | ||||
|     retry: 'やり直す' | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
| @@ -170,6 +185,8 @@ common: | ||||
|     rename: "名前を変更" | ||||
|     stack-left: "左に重ねる" | ||||
|     pop-right: "右に出す" | ||||
|   dev: "アプリの作成に失敗しました。再度お試しください。" | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{{ app.name }}</i>があなたのアカウントにアクセスすることを<b>許可</b>しますか?" | ||||
|   permission-ask: "このアプリは次の権限を要求しています:" | ||||
| @@ -335,6 +352,7 @@ common/views/components/note-menu.vue: | ||||
|   detail: "詳細" | ||||
|   copy-link: "リンクをコピー" | ||||
|   favorite: "お気に入り" | ||||
|   unfavorite: "お気に入り解除" | ||||
|   pin: "ピン留め" | ||||
|   unpin: "ピン留め解除" | ||||
|   delete: "削除" | ||||
| @@ -415,6 +433,25 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   careful-bot: "Botからのフォローだけ承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "確認中" | ||||
|   no-broadcasts: "お知らせはありません" | ||||
| @@ -506,11 +543,14 @@ desktop/views/components/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
| @@ -540,7 +580,6 @@ desktop/views/components/crop-window.vue: | ||||
|   ok: "決定" | ||||
| desktop/views/components/drive-window.vue: | ||||
|   used: "使用中" | ||||
|   drive: "ドライブ" | ||||
| desktop/views/components/drive.file.vue: | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
| @@ -570,8 +609,6 @@ desktop/views/components/drive.folder.vue: | ||||
|     rename: "名前を変更" | ||||
|     rename-folder: "フォルダ名の変更" | ||||
|     input-new-folder-name: "新しいフォルダ名を入力してください" | ||||
| desktop/views/components/drive.nav-folder.vue: | ||||
|   drive: "ドライブ" | ||||
| desktop/views/components/drive.vue: | ||||
|   search: "検索" | ||||
|   load-more: "もっと読み込む" | ||||
| @@ -639,7 +676,7 @@ desktop/views/components/note-detail.vue: | ||||
|   location: "位置情報" | ||||
|   renote: "Renote" | ||||
|   add-reaction: "リアクション" | ||||
| desktop/views/components/notes.note.vue: | ||||
| desktop/views/components/note.vue: | ||||
|   reposted-by: "{}がRenote" | ||||
|   reply: "返信" | ||||
|   renote: "Renote" | ||||
| @@ -705,8 +742,8 @@ desktop/views/components/settings.vue: | ||||
|   profile: "プロフィール" | ||||
|   notification: "通知" | ||||
|   apps: "アプリ" | ||||
|   mute: "ミュート" | ||||
|   drive: "ドライブ" | ||||
|   mute-and-block: "ミュート/ブロック" | ||||
|   blocking: "ブロック" | ||||
|   security: "セキュリティ" | ||||
|   signin: "サインイン履歴" | ||||
|   password: "パスワード" | ||||
| @@ -725,8 +762,12 @@ desktop/views/components/settings.vue: | ||||
|   advanced: "詳細設定" | ||||
|   api-via-stream: "ストリームを経由したAPIリクエスト" | ||||
|   api-via-stream-desc: "この設定をオンにすると、websocket接続を経由してAPIリクエストが行われます(パフォーマンス向上が期待できます)。オフにすると、ネイティブの fetch APIが利用されます。この設定はこのデバイスのみ有効です。" | ||||
|   deck-nav: "デッキ内ナビゲーション" | ||||
|   deck-nav-desc: "デッキを使用しているとき、ナビゲーションが発生する際にページ遷移を行わずに一時的なカラムで受けるようにします。" | ||||
|   deck-default: "デッキをデフォルトのUIにする" | ||||
|   display: "デザインと表示" | ||||
|   customize: "ホームをカスタマイズ" | ||||
|   wallpaper: "壁紙" | ||||
|   choose-wallpaper: "壁紙を選択" | ||||
|   delete-wallpaper: "壁紙を削除" | ||||
|   dark-mode: "ダークモード" | ||||
| @@ -738,17 +779,19 @@ desktop/views/components/settings.vue: | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   timeline: "タイムライン" | ||||
|   show-my-renotes: "自分の行ったRenoteをタイムラインに表示する" | ||||
|   show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示する" | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||
|   volume: "ボリューム" | ||||
|   test: "テスト" | ||||
|   mobile: "モバイル" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   language: "言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
| @@ -784,6 +827,10 @@ desktop/views/components/settings.vue: | ||||
|   tools: "ツール" | ||||
|   task-manager: "タスクマネージャ" | ||||
|   third-parties: "サードパーティ" | ||||
|   navbar-position: "ナビゲーションバーの位置" | ||||
|   navbar-position-top: "上" | ||||
|   navbar-position-left: "左" | ||||
|   navbar-position-right: "右" | ||||
| desktop/views/components/settings.2fa.vue: | ||||
|   intro: "二段階認証を設定すると、サインイン時にパスワードだけでなく、予め登録しておいた物理的なデバイス(例えばあなたのスマートフォンなど)も必要になり、よりセキュリティが向上します。" | ||||
|   detail: "詳細..." | ||||
| @@ -802,41 +849,39 @@ desktop/views/components/settings.2fa.vue: | ||||
|   success: "設定が完了しました!" | ||||
|   failed: "設定に失敗しました。トークンに誤りがないかご確認ください。" | ||||
|   info: "次回サインインからは、同様にパスワードに加えてデバイスに表示されているトークンを入力します。" | ||||
| desktop/views/components/settings.api.vue: | ||||
| common/views/components/api-settings.vue: | ||||
|   intro: "APIを利用するには、上記のトークンを「i」というキーでパラメータに付加してリクエストします。" | ||||
|   caution: "アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。" | ||||
|   regeneration-of-token: "万が一このトークンが漏れたりその可能性がある場合はトークンを再生成できます。" | ||||
|   regenerate-token: "トークンを再生成" | ||||
|   token: "Token:" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   console: | ||||
|     title: 'APIコンソール' | ||||
|     endpoint: 'エンドポイント' | ||||
|     parameter: 'パラメータ' | ||||
|     send: '送信' | ||||
|     sending: '応答待ち' | ||||
|     response: '結果' | ||||
| desktop/views/components/settings.apps.vue: | ||||
|   no-apps: "連携しているアプリケーションはありません" | ||||
| desktop/views/components/settings.drive.vue: | ||||
|   max: "中" | ||||
| common/views/components/drive-settings.vue: | ||||
|   max: "容量" | ||||
|   in-use: "使用中" | ||||
| desktop/views/components/settings.mute.vue: | ||||
|   no-users: "ミュートしているユーザーはいません" | ||||
| desktop/views/components/settings.password.vue: | ||||
|   stats: "統計" | ||||
| common/views/components/mute-and-block.vue: | ||||
|   mute-and-block: "ミュートとブロック" | ||||
|   mute: "ミュート" | ||||
|   block: "ブロック" | ||||
|   no-muted-users: "ミュートしているユーザーはいません" | ||||
|   no-blocked-users: "ブロックしているユーザーはいません" | ||||
| common/views/components/password-settings.vue: | ||||
|   reset: "パスワードを変更する" | ||||
|   enter-current-password: "現在のパスワードを入力してください" | ||||
|   enter-new-password: "新しいパスワードを入力してください" | ||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||
|   not-match: "新しいパスワードが一致しません" | ||||
|   changed: "パスワードを変更しました" | ||||
| desktop/views/components/settings.profile.vue: | ||||
|   avatar: "アイコン" | ||||
|   choice-avatar: "画像を選択" | ||||
|   name: "名前" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   save: "保存" | ||||
|   locked-account: "アカウントの保護" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   other: "その他" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   profile-updated: "プロフィールを更新しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| @@ -861,7 +906,6 @@ desktop/views/components/ui.header.vue: | ||||
|   adjective: "さん" | ||||
| desktop/views/components/ui.header.account.vue: | ||||
|   profile: "プロフィール" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   lists: "リスト" | ||||
|   follow-requests: "フォロー申請" | ||||
| @@ -903,42 +947,100 @@ desktop/views/components/users-list-item.vue: | ||||
| desktop/views/components/window.vue: | ||||
|   popout: "ポップアウト" | ||||
|   close: "閉じる" | ||||
| desktop/views/pages/admin/admin.vue: | ||||
| admin/views/index.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   drive: "ドライブ" | ||||
|   instance: "インスタンス" | ||||
|   emoji: "カスタム絵文字" | ||||
|   users: "ユーザー" | ||||
|   update: "更新" | ||||
| desktop/views/pages/admin/admin.dashboard.vue: | ||||
|   announcements: "お知らせ" | ||||
|   hashtags: "ハッシュタグ" | ||||
|   back-to-misskey: "Misskeyに戻る" | ||||
| admin/views/dashboard.vue: | ||||
|   dashboard: "ダッシュボード" | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
|   all-notes: "全ての投稿" | ||||
|   original-notes: "このインスタンスの投稿" | ||||
|   accounts: "アカウント" | ||||
|   notes: "投稿" | ||||
|   drive: "ドライブ" | ||||
|   instances: "インスタンス" | ||||
|   this-instance: "このインスタンス" | ||||
|   federated: "連合" | ||||
|   invite: "招待" | ||||
| desktop/views/pages/admin/admin.suspend-user.vue: | ||||
|   banner-url: "Banner URL" | ||||
|   disableRegistration: "Disable new user registration" | ||||
|   disableLocalTimeline: "Disable the local timeline" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
|   per-hour: "1時間ごと" | ||||
|   federation: "フェデレーション" | ||||
|   notes: "投稿" | ||||
|   users: "ユーザー" | ||||
|   drive: "ドライブ" | ||||
|   network: "ネットワーク" | ||||
|   charts: | ||||
|     federation-instances: "インスタンスの増減" | ||||
|     federation-instances-total: "インスタンスの積算" | ||||
|     notes: "投稿の増減 (統合)" | ||||
|     local-notes: "投稿の増減 (ローカル)" | ||||
|     remote-notes: "投稿の増減 (リモート)" | ||||
|     notes-total: "投稿の積算" | ||||
|     users: "ユーザーの増減" | ||||
|     users-total: "ユーザーの積算" | ||||
|     drive: "ドライブ使用量の増減" | ||||
|     drive-total: "ドライブ使用量の積算" | ||||
|     drive-files: "ドライブのファイル数の増減" | ||||
|     drive-files-total: "ドライブのファイル数の積算" | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
| desktop/views/pages/admin/admin.unsuspend-user.vue: | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
| desktop/views/pages/admin/admin.verify-user.vue: | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
| desktop/views/pages/admin/admin.unverify-user.vue: | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
| admin/views/emoji.vue: | ||||
|   add-emoji: | ||||
|     title: "絵文字の登録" | ||||
|     name: "絵文字名" | ||||
|     name-desc: "a~z 0~9 _ の文字が使えます。" | ||||
|     aliases: "エイリアス" | ||||
|     aliases-desc: "スペースで区切って複数設定できます。" | ||||
|     url: "絵文字画像URL" | ||||
|     add: "追加" | ||||
|   emojis: | ||||
|     title: "絵文字一覧" | ||||
|     update: "更新" | ||||
|     remove: "削除" | ||||
| admin/views/announcements.vue: | ||||
|   announcements: "お知らせ" | ||||
|   save: "保存" | ||||
|   remove: "削除" | ||||
|   add: "追加" | ||||
|   title: "タイトル" | ||||
|   text: "内容" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| 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: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
| desktop/views/pages/deck/deck.user-column.vue: | ||||
|   posts: "投稿" | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   images: "画像" | ||||
|   activity: "アクティビティ" | ||||
|   timeline: "タイムライン" | ||||
|   pinned-notes: "ピン留めされた投稿" | ||||
|   push-to-a-list: "リストに追加" | ||||
| desktop/views/pages/stats/stats.vue: | ||||
|   all-users: "全てのユーザー" | ||||
|   original-users: "このインスタンスのユーザー" | ||||
| @@ -991,9 +1093,6 @@ desktop/views/pages/user/user.friends.vue: | ||||
|   no-users: "よく話すユーザーはいません" | ||||
| desktop/views/pages/user/user.vue: | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
| desktop/views/pages/user/user.home.vue: | ||||
|   last-used-at: "最終アクセス" | ||||
| desktop/views/pages/user/user.photos.vue: | ||||
|   title: "フォト" | ||||
| @@ -1007,6 +1106,9 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   mute: "ミュートする" | ||||
|   muted: "ミュートしています" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロックする" | ||||
|   unblock: "ブロック解除" | ||||
|   block-confirm: "このユーザーをブロックしますか?" | ||||
|   push-to-a-list: "リストに追加" | ||||
|   list-pushed: "{user}を{list}に追加しました。" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| @@ -1014,6 +1116,10 @@ desktop/views/pages/user/user.header.vue: | ||||
|   following: "フォロー" | ||||
|   followers: "フォロワー" | ||||
|   is-bot: "このアカウントはBotです" | ||||
|   years-old: "歳" | ||||
|   year: "年" | ||||
|   month: "月" | ||||
|   day: "日" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "投稿" | ||||
|   with-replies: "投稿と返信" | ||||
| @@ -1043,7 +1149,6 @@ desktop/views/widgets/users.vue: | ||||
|   refresh: "他を見る" | ||||
|   no-one: "いません!" | ||||
| mobile/views/components/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   used: "使用中" | ||||
|   folder-count: "フォルダ" | ||||
|   count-separator: "、" | ||||
| @@ -1073,6 +1178,8 @@ mobile/views/components/drive.file-detail.vue: | ||||
|   hash: "ハッシュ (md5)" | ||||
|   exif: "EXIF" | ||||
|   nsfw: "閲覧注意" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
| mobile/views/components/media-image.vue: | ||||
|   sensitive: "閲覧注意" | ||||
|   click-to-show: "クリックして表示" | ||||
| @@ -1145,7 +1252,6 @@ mobile/views/components/ui.nav.vue: | ||||
|   messaging: "メッセージ" | ||||
|   follow-requests: "フォロー申請" | ||||
|   search: "検索" | ||||
|   drive: "ドライブ" | ||||
|   favorites: "お気に入り" | ||||
|   user-lists: "リスト" | ||||
|   widgets: "ウィジェット" | ||||
| @@ -1168,7 +1274,6 @@ mobile/views/pages/user-lists.vue: | ||||
|   title: "リスト" | ||||
|   enter-list-name: "リスト名を入力してください" | ||||
| mobile/views/pages/drive.vue: | ||||
|   drive: "ドライブ" | ||||
|   more: "もっと見る" | ||||
| mobile/views/pages/signup.vue: | ||||
|   lets-start: "📦 始めましょう" | ||||
| @@ -1213,23 +1318,6 @@ mobile/views/pages/notifications.vue: | ||||
|   read-all: "すべての通知を既読にしますか?" | ||||
| mobile/views/pages/games/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
| mobile/views/pages/settings/settings.profile.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
|   is-cat: "このアカウントはCatです" | ||||
|   is-locked: "フォローを承認制にする" | ||||
|   advanced: "その他" | ||||
|   privacy: "プライバシー" | ||||
|   save: "保存" | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
| mobile/views/pages/search.vue: | ||||
|   search: "検索" | ||||
|   empty: "「{}」に関する投稿は見つかりませんでした。" | ||||
| @@ -1285,6 +1373,8 @@ mobile/views/pages/settings.vue: | ||||
|   signout: "サインアウト" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   mark-as-read-all-unread-notes: "すべての投稿を既読にする" | ||||
|   password: "パスワード" | ||||
| mobile/views/pages/user.vue: | ||||
|   follows-you: "フォローされています" | ||||
|   following: "フォロー" | ||||
| @@ -1294,8 +1384,10 @@ mobile/views/pages/user.vue: | ||||
|   timeline: "タイムライン" | ||||
|   media: "メディア" | ||||
|   is-suspended: "このユーザーは凍結されています。" | ||||
|   is-remote: "このユーザーはリモートユーザーです。" | ||||
|   view-remote: "正確な情報を見る" | ||||
|   mute: "ミュート" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "最近の投稿" | ||||
|   images: "画像" | ||||
| @@ -1341,3 +1433,29 @@ docs: | ||||
|       description: "説明" | ||||
| dev/views/index.vue: | ||||
|   manage-apps: "アプリの管理" | ||||
| dev/views/apps.vue: | ||||
|   manage-apps: "アプリを管理" | ||||
|   create-app: "アプリ作成" | ||||
|   app-missing: "アプリなし" | ||||
| dev/views/new-app.vue: | ||||
|   create-app: "アプリケーションの作成" | ||||
|   app-name: "アプリケーション名" | ||||
|   app-name-desc: "あなたのアプリの名称。" | ||||
|   app-name-ex: "ex) Misskey for iOS" | ||||
|   app-overview: "アプリの概要" | ||||
|   app-desc: "あなたのアプリの簡単な説明や紹介。" | ||||
|   app-desc-ex: "ex) Misskey iOSクライアント。" | ||||
|   callback-url: "コールバックURL (オプション)" | ||||
|   callback-url-desc: "ユーザーが認証フォームで認証した際にリダイレクトするURLを設定できます。" | ||||
|   authority: "権限" | ||||
|   authority-desc: "ここで要求した機能だけがAPIからアクセスできます。" | ||||
|   authority-warning: "アプリ作成後も変更できますが、新たな権限を付与する場合、その時点で関連付けられているユーザーキーはすべて無効になります。" | ||||
|   account-read: "アカウントの情報を見る。" | ||||
|   account-write: "アカウントの情報を操作する。" | ||||
|   note-write: "投稿する。" | ||||
|   reaction-write: "リアクションしたりリアクションをキャンセルする。" | ||||
|   following-write: "フォローしたりフォロー解除する。" | ||||
|   drive-read: "ドライブを見る。" | ||||
|   drive-write: "ドライブを操作する。" | ||||
|   notification-read: "通知を見る。" | ||||
|   notification-write: "通知を操作する。" | ||||
|   | ||||
							
								
								
									
										83
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										83
									
								
								package.json
									
									
									
									
									
								
							| @@ -1,8 +1,8 @@ | ||||
| { | ||||
| 	"name": "misskey", | ||||
| 	"author": "syuilo <i@syuilo.com>", | ||||
| 	"version": "10.11.0", | ||||
| 	"clientVersion": "1.0.10473", | ||||
| 	"version": "10.38.5", | ||||
| 	"clientVersion": "1.0.11513", | ||||
| 	"codename": "nighthike", | ||||
| 	"main": "./built/index.js", | ||||
| 	"private": true, | ||||
| @@ -20,26 +20,27 @@ | ||||
| 		"format": "gulp format" | ||||
| 	}, | ||||
| 	"dependencies": { | ||||
| 		"@fortawesome/fontawesome-svg-core": "1.2.4", | ||||
| 		"@fortawesome/free-brands-svg-icons": "5.3.1", | ||||
| 		"@fortawesome/free-regular-svg-icons": "5.3.1", | ||||
| 		"@fortawesome/free-solid-svg-icons": "5.3.1", | ||||
| 		"@fortawesome/fontawesome-svg-core": "1.2.6", | ||||
| 		"@fortawesome/free-brands-svg-icons": "5.4.1", | ||||
| 		"@fortawesome/free-regular-svg-icons": "5.4.1", | ||||
| 		"@fortawesome/free-solid-svg-icons": "5.4.1", | ||||
| 		"@koa/cors": "2.2.2", | ||||
| 		"@prezzemolo/rap": "0.1.2", | ||||
| 		"@prezzemolo/zip": "0.0.3", | ||||
| 		"@types/bcryptjs": "2.4.2", | ||||
| 		"@types/chai-http": "3.0.5", | ||||
| 		"@types/dateformat": "1.0.1", | ||||
| 		"@types/debug": "0.0.31", | ||||
| 		"@types/deep-equal": "1.0.1", | ||||
| 		"@types/double-ended-queue": "2.1.0", | ||||
| 		"@types/elasticsearch": "5.0.27", | ||||
| 		"@types/elasticsearch": "5.0.28", | ||||
| 		"@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-uglify": "3.0.6", | ||||
| 		"@types/gulp-util": "3.0.34", | ||||
| 		"@types/is-root": "1.0.0", | ||||
| 		"@types/is-url": "1.2.28", | ||||
| @@ -57,60 +58,61 @@ | ||||
| 		"@types/koa__cors": "2.2.3", | ||||
| 		"@types/minio": "7.0.0", | ||||
| 		"@types/mkdirp": "0.5.2", | ||||
| 		"@types/mocha": "5.2.3", | ||||
| 		"@types/mocha": "5.2.5", | ||||
| 		"@types/mongodb": "3.1.12", | ||||
| 		"@types/ms": "0.7.30", | ||||
| 		"@types/node": "10.11.7", | ||||
| 		"@types/node": "10.12.2", | ||||
| 		"@types/oauth": "0.9.1", | ||||
| 		"@types/portscanner": "2.1.0", | ||||
| 		"@types/pug": "2.0.4", | ||||
| 		"@types/qrcode": "1.3.0", | ||||
| 		"@types/ratelimiter": "2.1.28", | ||||
| 		"@types/redis": "2.8.7", | ||||
| 		"@types/request": "2.47.1", | ||||
| 		"@types/request": "2.48.0", | ||||
| 		"@types/request-promise-native": "1.0.15", | ||||
| 		"@types/rimraf": "2.0.2", | ||||
| 		"@types/seedrandom": "2.4.27", | ||||
| 		"@types/sharp": "0.17.10", | ||||
| 		"@types/sharp": "0.21.0", | ||||
| 		"@types/showdown": "1.7.5", | ||||
| 		"@types/single-line-log": "1.1.0", | ||||
| 		"@types/speakeasy": "2.0.2", | ||||
| 		"@types/speakeasy": "2.0.3", | ||||
| 		"@types/systeminformation": "3.23.0", | ||||
| 		"@types/tinycolor2": "1.4.1", | ||||
| 		"@types/tmp": "0.0.33", | ||||
| 		"@types/uuid": "3.4.4", | ||||
| 		"@types/webpack": "4.4.16", | ||||
| 		"@types/webpack": "4.4.17", | ||||
| 		"@types/webpack-stream": "3.2.10", | ||||
| 		"@types/websocket": "0.0.40", | ||||
| 		"@types/ws": "6.0.1", | ||||
| 		"animejs": "2.2.0", | ||||
| 		"apexcharts": "2.1.9", | ||||
| 		"autobind-decorator": "2.1.0", | ||||
| 		"autosize": "4.0.2", | ||||
| 		"autwh": "0.1.0", | ||||
| 		"bcryptjs": "2.4.3", | ||||
| 		"bee-queue": "1.2.2", | ||||
| 		"bootstrap-vue": "2.0.0-rc.11", | ||||
| 		"cafy": "11.3.0", | ||||
| 		"cafy": "12.0.0", | ||||
| 		"chai": "4.2.0", | ||||
| 		"chai-http": "4.2.0", | ||||
| 		"chalk": "2.4.1", | ||||
| 		"chart.js": "2.7.2", | ||||
| 		"commander": "2.19.0", | ||||
| 		"crc-32": "1.2.0", | ||||
| 		"css-loader": "1.0.0", | ||||
| 		"css-loader": "1.0.1", | ||||
| 		"dateformat": "3.0.3", | ||||
| 		"debug": "4.1.0", | ||||
| 		"deep-equal": "1.0.1", | ||||
| 		"deepcopy": "0.6.3", | ||||
| 		"diskusage": "0.2.5", | ||||
| 		"dompurify": "1.0.5", | ||||
| 		"double-ended-queue": "2.1.0-0", | ||||
| 		"elasticsearch": "15.1.1", | ||||
| 		"elasticsearch": "15.2.0", | ||||
| 		"emojilib": "2.3.0", | ||||
| 		"escape-regexp": "0.0.1", | ||||
| 		"eslint": "5.0.1", | ||||
| 		"eslint": "5.8.0", | ||||
| 		"eslint-plugin-vue": "4.7.1", | ||||
| 		"eventemitter3": "3.1.0", | ||||
| 		"exif-js": "2.3.0", | ||||
| 		"file-loader": "2.0.0", | ||||
| 		"file-type": "10.0.0", | ||||
| 		"file-type": "10.3.0", | ||||
| 		"fuckadblock": "3.2.1", | ||||
| 		"gulp": "3.9.1", | ||||
| 		"gulp-cssnano": "2.1.3", | ||||
| @@ -127,17 +129,16 @@ | ||||
| 		"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.20", | ||||
| 		"html-minifier": "3.5.21", | ||||
| 		"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.12.0", | ||||
| 		"jsdom": "12.2.0", | ||||
| 		"jsdom": "13.0.0", | ||||
| 		"json5": "2.1.0", | ||||
| 		"json5-loader": "1.0.1", | ||||
| 		"koa": "2.5.1", | ||||
| 		"koa": "2.6.1", | ||||
| 		"koa-bodyparser": "4.2.1", | ||||
| 		"koa-compress": "3.0.0", | ||||
| 		"koa-favicon": "2.0.1", | ||||
| @@ -150,14 +151,13 @@ | ||||
| 		"koa-slow": "2.1.0", | ||||
| 		"koa-views": "6.1.4", | ||||
| 		"loader-utils": "1.1.0", | ||||
| 		"lodash.assign": "4.2.0", | ||||
| 		"mecab-async": "0.1.2", | ||||
| 		"merge-options": "1.0.1", | ||||
| 		"minio": "7.0.1", | ||||
| 		"mkdirp": "0.5.1", | ||||
| 		"mocha": "5.2.0", | ||||
| 		"moji": "0.5.1", | ||||
| 		"mongodb": "3.1.1", | ||||
| 		"mongodb": "3.1.8", | ||||
| 		"monk": "6.0.6", | ||||
| 		"ms": "2.1.1", | ||||
| 		"nan": "2.11.1", | ||||
| @@ -176,7 +176,7 @@ | ||||
| 		"qrcode": "1.3.0", | ||||
| 		"ratelimiter": "3.2.0", | ||||
| 		"recaptcha-promise": "0.1.3", | ||||
| 		"reconnecting-websocket": "4.1.5", | ||||
| 		"reconnecting-websocket": "4.1.10", | ||||
| 		"redis": "2.8.0", | ||||
| 		"request": "2.88.0", | ||||
| 		"request-promise-native": "1.0.5", | ||||
| @@ -187,7 +187,7 @@ | ||||
| 		"sass-loader": "7.1.0", | ||||
| 		"seedrandom": "2.4.4", | ||||
| 		"sharp": "0.21.0", | ||||
| 		"showdown": "1.8.6", | ||||
| 		"showdown": "1.8.7", | ||||
| 		"showdown-highlightjs-extension": "0.1.2", | ||||
| 		"single-line-log": "1.1.2", | ||||
| 		"speakeasy": "2.0.0", | ||||
| @@ -196,31 +196,31 @@ | ||||
| 		"stylus": "0.54.5", | ||||
| 		"stylus-loader": "3.0.2", | ||||
| 		"summaly": "2.2.0", | ||||
| 		"systeminformation": "3.45.7", | ||||
| 		"systeminformation": "3.45.9", | ||||
| 		"syuilo-password-strength": "0.0.1", | ||||
| 		"textarea-caret": "3.1.0", | ||||
| 		"tinycolor2": "1.4.1", | ||||
| 		"tmp": "0.0.33", | ||||
| 		"ts-loader": "4.4.1", | ||||
| 		"ts-loader": "5.3.0", | ||||
| 		"ts-node": "7.0.1", | ||||
| 		"tslint": "5.10.0", | ||||
| 		"typescript": "2.9.2", | ||||
| 		"typescript-eslint-parser": "20.0.0", | ||||
| 		"typescript": "3.1.5", | ||||
| 		"typescript-eslint-parser": "20.1.1", | ||||
| 		"uglify-es": "3.3.9", | ||||
| 		"url-loader": "1.1.2", | ||||
| 		"uuid": "3.3.2", | ||||
| 		"v-animate-css": "0.0.2", | ||||
| 		"vue": "2.5.17", | ||||
| 		"vue-chartjs": "3.4.0", | ||||
| 		"vue-color": "2.7.0", | ||||
| 		"vue-content-loading": "1.5.3", | ||||
| 		"vue-cropperjs": "2.2.2", | ||||
| 		"vue-js-modal": "1.3.26", | ||||
| 		"vue-json-tree-view": "2.1.4", | ||||
| 		"vue-loader": "15.4.2", | ||||
| 		"vue-router": "3.0.1", | ||||
| 		"vue-style-loader": "4.1.2", | ||||
| 		"vue-svg-inline-loader": "1.2.0", | ||||
| 		"vue-sweetalert2": "1.5.5", | ||||
| 		"vue-svg-inline-loader": "1.2.1", | ||||
| 		"vue-sweetalert2": "1.5.6", | ||||
| 		"vue-template-compiler": "2.5.17", | ||||
| 		"vuedraggable": "2.16.0", | ||||
| 		"vuewordcloud": "18.7.11", | ||||
| @@ -228,17 +228,10 @@ | ||||
| 		"vuex-persistedstate": "2.5.4", | ||||
| 		"web-push": "3.3.3", | ||||
| 		"webfinger.js": "2.6.6", | ||||
| 		"webpack": "4.20.2", | ||||
| 		"webpack": "4.23.1", | ||||
| 		"webpack-cli": "3.1.2", | ||||
| 		"websocket": "1.0.28", | ||||
| 		"ws": "6.1.0", | ||||
| 		"xev": "2.0.1" | ||||
| 	}, | ||||
| 	"greenkeeper": { | ||||
| 		"ignore": [ | ||||
| 			"deepcopy", | ||||
| 			"cafy", | ||||
| 			"@types/gulp" | ||||
| 		] | ||||
| 	} | ||||
| } | ||||
|   | ||||
							
								
								
									
										122
									
								
								src/chart/drive.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										122
									
								
								src/chart/drive.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,122 @@ | ||||
| import autobind from 'autobind-decorator'; | ||||
| import Chart, { Obj } from './'; | ||||
| import DriveFile, { IDriveFile } from '../models/drive-file'; | ||||
| import { isLocalUser } from '../models/user'; | ||||
|  | ||||
| /** | ||||
|  * ドライブに関するチャート | ||||
|  */ | ||||
| type DriveLog = { | ||||
| 	local: { | ||||
| 		/** | ||||
| 		 * 集計期間時点での、全ドライブファイル数 | ||||
| 		 */ | ||||
| 		totalCount: number; | ||||
|  | ||||
| 		/** | ||||
| 		 * 集計期間時点での、全ドライブファイルの合計サイズ | ||||
| 		 */ | ||||
| 		totalSize: number; | ||||
|  | ||||
| 		/** | ||||
| 		 * 増加したドライブファイル数 | ||||
| 		 */ | ||||
| 		incCount: number; | ||||
|  | ||||
| 		/** | ||||
| 		 * 増加したドライブ使用量 | ||||
| 		 */ | ||||
| 		incSize: number; | ||||
|  | ||||
| 		/** | ||||
| 		 * 減少したドライブファイル数 | ||||
| 		 */ | ||||
| 		decCount: number; | ||||
|  | ||||
| 		/** | ||||
| 		 * 減少したドライブ使用量 | ||||
| 		 */ | ||||
| 		decSize: number; | ||||
| 	}; | ||||
|  | ||||
| 	remote: DriveLog['local']; | ||||
| }; | ||||
|  | ||||
| class DriveChart extends Chart<DriveLog> { | ||||
| 	constructor() { | ||||
| 		super('drive'); | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	protected async getTemplate(init: boolean, latest?: DriveLog): Promise<DriveLog> { | ||||
| 		const calcSize = (local: boolean) => DriveFile | ||||
| 			.aggregate([{ | ||||
| 				$match: { | ||||
| 					'metadata._user.host': local ? null : { $ne: null }, | ||||
| 					'metadata.deletedAt': { $exists: false } | ||||
| 				} | ||||
| 			}, { | ||||
| 				$project: { | ||||
| 					length: true | ||||
| 				} | ||||
| 			}, { | ||||
| 				$group: { | ||||
| 					_id: null, | ||||
| 					usage: { $sum: '$length' } | ||||
| 				} | ||||
| 			}]) | ||||
| 			.then(res => res.length > 0 ? res[0].usage : 0); | ||||
|  | ||||
| 		const [localCount, remoteCount, localSize, remoteSize] = init ? await Promise.all([ | ||||
| 			DriveFile.count({ 'metadata._user.host': null }), | ||||
| 			DriveFile.count({ 'metadata._user.host': { $ne: null } }), | ||||
| 			calcSize(true), | ||||
| 			calcSize(false) | ||||
| 		]) : [ | ||||
| 			latest ? latest.local.totalCount : 0, | ||||
| 			latest ? latest.remote.totalCount : 0, | ||||
| 			latest ? latest.local.totalSize : 0, | ||||
| 			latest ? latest.remote.totalSize : 0 | ||||
| 		]; | ||||
|  | ||||
| 		return { | ||||
| 			local: { | ||||
| 				totalCount: localCount, | ||||
| 				totalSize: localSize, | ||||
| 				incCount: 0, | ||||
| 				incSize: 0, | ||||
| 				decCount: 0, | ||||
| 				decSize: 0 | ||||
| 			}, | ||||
| 			remote: { | ||||
| 				totalCount: remoteCount, | ||||
| 				totalSize: remoteSize, | ||||
| 				incCount: 0, | ||||
| 				incSize: 0, | ||||
| 				decCount: 0, | ||||
| 				decSize: 0 | ||||
| 			} | ||||
| 		}; | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	public async update(file: IDriveFile, isAdditional: boolean) { | ||||
| 		const update: Obj = {}; | ||||
|  | ||||
| 		update.totalCount = isAdditional ? 1 : -1; | ||||
| 		update.totalSize = isAdditional ? file.length : -file.length; | ||||
| 		if (isAdditional) { | ||||
| 			update.incCount = 1; | ||||
| 			update.incSize = file.length; | ||||
| 		} else { | ||||
| 			update.decCount = 1; | ||||
| 			update.decSize = file.length; | ||||
| 		} | ||||
|  | ||||
| 		await this.inc({ | ||||
| 			[isLocalUser(file.metadata._user) ? 'local' : 'remote']: update | ||||
| 		}); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| export default new DriveChart(); | ||||
							
								
								
									
										66
									
								
								src/chart/federation.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								src/chart/federation.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,66 @@ | ||||
| import autobind from 'autobind-decorator'; | ||||
| import Chart, { Obj } from '.'; | ||||
| import Instance from '../models/instance'; | ||||
|  | ||||
| /** | ||||
|  * フェデレーションに関するチャート | ||||
|  */ | ||||
| type FederationLog = { | ||||
| 	instance: { | ||||
| 		/** | ||||
| 		 * インスタンス数の合計 | ||||
| 		 */ | ||||
| 		total: number; | ||||
|  | ||||
| 		/** | ||||
| 		 * 増加インスタンス数 | ||||
| 		 */ | ||||
| 		inc: number; | ||||
|  | ||||
| 		/** | ||||
| 		 * 減少インスタンス数 | ||||
| 		 */ | ||||
| 		dec: number; | ||||
| 	}; | ||||
| }; | ||||
|  | ||||
| class FederationChart extends Chart<FederationLog> { | ||||
| 	constructor() { | ||||
| 		super('federation'); | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	protected async getTemplate(init: boolean, latest?: FederationLog): Promise<FederationLog> { | ||||
| 		const [total] = init ? await Promise.all([ | ||||
| 			Instance.count({}) | ||||
| 		]) : [ | ||||
| 			latest ? latest.instance.total : 0 | ||||
| 		]; | ||||
|  | ||||
| 		return { | ||||
| 			instance: { | ||||
| 				total: total, | ||||
| 				inc: 0, | ||||
| 				dec: 0 | ||||
| 			} | ||||
| 		}; | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	public async update(isAdditional: boolean) { | ||||
| 		const update: Obj = {}; | ||||
|  | ||||
| 		update.total = isAdditional ? 1 : -1; | ||||
| 		if (isAdditional) { | ||||
| 			update.inc = 1; | ||||
| 		} else { | ||||
| 			update.dec = 1; | ||||
| 		} | ||||
|  | ||||
| 		await this.inc({ | ||||
| 			instance: update | ||||
| 		}); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| export default new FederationChart(); | ||||
							
								
								
									
										56
									
								
								src/chart/hashtag.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								src/chart/hashtag.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,56 @@ | ||||
| import autobind from 'autobind-decorator'; | ||||
| import Chart, { Obj } from './'; | ||||
| import { IUser, isLocalUser } from '../models/user'; | ||||
| import db from '../db/mongodb'; | ||||
|  | ||||
| /** | ||||
|  * ハッシュタグに関するチャート | ||||
|  */ | ||||
| type HashtagLog = { | ||||
| 	local: { | ||||
| 		/** | ||||
| 		 * 投稿された数 | ||||
| 		 */ | ||||
| 		count: number; | ||||
| 	}; | ||||
|  | ||||
| 	remote: HashtagLog['local']; | ||||
| }; | ||||
|  | ||||
| class HashtagChart extends Chart<HashtagLog> { | ||||
| 	constructor() { | ||||
| 		super('hashtag', true); | ||||
|  | ||||
| 		// 後方互換性のため | ||||
| 		db.get('chart.hashtag').findOne().then(doc => { | ||||
| 			if (doc != null && doc.data.local == null) { | ||||
| 				db.get('chart.hashtag').drop(); | ||||
| 			} | ||||
| 		}); | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	protected async getTemplate(init: boolean, latest?: HashtagLog): Promise<HashtagLog> { | ||||
| 		return { | ||||
| 			local: { | ||||
| 				count: 0 | ||||
| 			}, | ||||
| 			remote: { | ||||
| 				count: 0 | ||||
| 			} | ||||
| 		}; | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	public async update(hashtag: string, user: IUser) { | ||||
| 		const update: Obj = { | ||||
| 			count: 1 | ||||
| 		}; | ||||
|  | ||||
| 		await this.incIfUnique({ | ||||
| 			[isLocalUser(user) ? 'local' : 'remote']: update | ||||
| 		}, 'users', user._id.toHexString(), hashtag); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| export default new HashtagChart(); | ||||
							
								
								
									
										324
									
								
								src/chart/index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										324
									
								
								src/chart/index.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,324 @@ | ||||
| /** | ||||
|  * チャートエンジン | ||||
|  */ | ||||
|  | ||||
| const nestedProperty = require('nested-property'); | ||||
| import autobind from 'autobind-decorator'; | ||||
| import * as mongo from 'mongodb'; | ||||
| import db from '../db/mongodb'; | ||||
| import { ICollection } from 'monk'; | ||||
|  | ||||
| export type Obj = { [key: string]: any }; | ||||
|  | ||||
| export type Partial<T> = { | ||||
| 	[P in keyof T]?: Partial<T[P]>; | ||||
| }; | ||||
|  | ||||
| type ArrayValue<T> = { | ||||
| 	[P in keyof T]: T[P] extends number ? Array<T[P]> : ArrayValue<T[P]>; | ||||
| }; | ||||
|  | ||||
| type Span = 'day' | 'hour'; | ||||
|  | ||||
| type Log<T extends Obj> = { | ||||
| 	_id: mongo.ObjectID; | ||||
|  | ||||
| 	/** | ||||
| 	 * 集計のグループ | ||||
| 	 */ | ||||
| 	group?: any; | ||||
|  | ||||
| 	/** | ||||
| 	 * 集計日時 | ||||
| 	 */ | ||||
| 	date: Date; | ||||
|  | ||||
| 	/** | ||||
| 	 * 集計期間 | ||||
| 	 */ | ||||
| 	span: Span; | ||||
|  | ||||
| 	/** | ||||
| 	 * データ | ||||
| 	 */ | ||||
| 	data: T; | ||||
|  | ||||
| 	/** | ||||
| 	 * ユニークインクリメント用 | ||||
| 	 */ | ||||
| 	unique?: Obj; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * 様々なチャートの管理を司るクラス | ||||
|  */ | ||||
| export default abstract class Chart<T> { | ||||
| 	protected collection: ICollection<Log<T>>; | ||||
| 	protected abstract async getTemplate(init: boolean, latest?: T, group?: any): Promise<T>; | ||||
|  | ||||
| 	constructor(name: string, grouped = false) { | ||||
| 		this.collection = db.get<Log<T>>(`chart.${name}`); | ||||
| 		if (grouped) { | ||||
| 			this.collection.createIndex({ span: -1, date: -1, group: -1 }, { unique: true }); | ||||
| 		} else { | ||||
| 			this.collection.createIndex({ span: -1, date: -1 }, { unique: true }); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	private convertQuery(x: Obj, path: string): Obj { | ||||
| 		const query: Obj = {}; | ||||
|  | ||||
| 		const dive = (x: Obj, path: string) => { | ||||
| 			Object.entries(x).forEach(([k, v]) => { | ||||
| 				const p = path ? `${path}.${k}` : k; | ||||
| 				if (typeof v === 'number') { | ||||
| 					query[p] = v; | ||||
| 				} else { | ||||
| 					dive(v, p); | ||||
| 				} | ||||
| 			}); | ||||
| 		}; | ||||
|  | ||||
| 		dive(x, path); | ||||
|  | ||||
| 		return query; | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	private getCurrentDate(): [number, number, number, number] { | ||||
| 		const now = new Date(); | ||||
|  | ||||
| 		const y = now.getFullYear(); | ||||
| 		const m = now.getMonth(); | ||||
| 		const d = now.getDate(); | ||||
| 		const h = now.getHours(); | ||||
|  | ||||
| 		return [y, m, d, h]; | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	private getLatestLog(span: Span, group?: any): Promise<Log<T>> { | ||||
| 		return this.collection.findOne({ | ||||
| 			group: group, | ||||
| 			span: span | ||||
| 		}, { | ||||
| 			sort: { | ||||
| 				date: -1 | ||||
| 			} | ||||
| 		}); | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	private async getCurrentLog(span: Span, group?: any): Promise<Log<T>> { | ||||
| 		const [y, m, d, h] = this.getCurrentDate(); | ||||
|  | ||||
| 		const current = | ||||
| 			span == 'day' ? new Date(y, m, d) : | ||||
| 			span == 'hour' ? new Date(y, m, d, h) : | ||||
| 			null; | ||||
|  | ||||
| 		// 現在(今日または今のHour)のログ | ||||
| 		const currentLog = await this.collection.findOne({ | ||||
| 			group: group, | ||||
| 			span: span, | ||||
| 			date: current | ||||
| 		}); | ||||
|  | ||||
| 		// ログがあればそれを返して終了 | ||||
| 		if (currentLog != null) { | ||||
| 			return currentLog; | ||||
| 		} | ||||
|  | ||||
| 		let log: Log<T>; | ||||
| 		let data: T; | ||||
|  | ||||
| 		// 集計期間が変わってから、初めてのチャート更新なら | ||||
| 		// 最も最近のログを持ってくる | ||||
| 		// * 例えば集計期間が「日」である場合で考えると、 | ||||
| 		// * 昨日何もチャートを更新するような出来事がなかった場合は、 | ||||
| 		// * ログがそもそも作られずドキュメントが存在しないということがあり得るため、 | ||||
| 		// * 「昨日の」と決め打ちせずに「もっとも最近の」とします | ||||
| 		const latest = await this.getLatestLog(span, group); | ||||
|  | ||||
| 		if (latest != null) { | ||||
| 			// 空ログデータを作成 | ||||
| 			data = await this.getTemplate(false, latest.data); | ||||
| 		} else { | ||||
| 			// ログが存在しなかったら | ||||
| 			// (Misskeyインスタンスを建てて初めてのチャート更新時など | ||||
| 			// または何らかの理由でチャートコレクションを抹消した場合) | ||||
|  | ||||
| 			// 初期ログデータを作成 | ||||
| 			data = await this.getTemplate(true, null, group); | ||||
| 		} | ||||
|  | ||||
| 		try { | ||||
| 			// 新規ログ挿入 | ||||
| 			log = await this.collection.insert({ | ||||
| 				group: group, | ||||
| 				span: span, | ||||
| 				date: current, | ||||
| 				data: data | ||||
| 			}); | ||||
| 		} catch (e) { | ||||
| 			// 11000 is duplicate key error | ||||
| 			// 並列動作している他のチャートエンジンプロセスと処理が重なる場合がある | ||||
| 			// その場合は再度最も新しいログを持ってくる | ||||
| 			if (e.code === 11000) { | ||||
| 				log = await this.getLatestLog(span, group); | ||||
| 			} else { | ||||
| 				console.error(e); | ||||
| 				throw e; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return log; | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	protected commit(query: Obj, group?: any, uniqueKey?: string, uniqueValue?: string): void { | ||||
| 		const update = (log: Log<T>) => { | ||||
| 			// ユニークインクリメントの場合、指定のキーに指定の値が既に存在していたら弾く | ||||
| 			if ( | ||||
| 				uniqueKey && | ||||
| 				log.unique && | ||||
| 				log.unique[uniqueKey] && | ||||
| 				log.unique[uniqueKey].includes(uniqueValue) | ||||
| 			) return; | ||||
|  | ||||
| 			// ユニークインクリメントの指定のキーに値を追加 | ||||
| 			if (uniqueKey) { | ||||
| 				query['$push'] = { | ||||
| 					[`unique.${uniqueKey}`]: uniqueValue | ||||
| 				}; | ||||
| 			} | ||||
|  | ||||
| 			// ログ更新 | ||||
| 			this.collection.update({ | ||||
| 				_id: log._id | ||||
| 			}, query); | ||||
| 		}; | ||||
|  | ||||
| 		this.getCurrentLog('day', group).then(log => update(log)); | ||||
| 		this.getCurrentLog('hour', group).then(log => update(log)); | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	protected inc(inc: Partial<T>, group?: any): void { | ||||
| 		this.commit({ | ||||
| 			$inc: this.convertQuery(inc, 'data') | ||||
| 		}, group); | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	protected incIfUnique(inc: Partial<T>, key: string, value: string, group?: any): void { | ||||
| 		this.commit({ | ||||
| 			$inc: this.convertQuery(inc, 'data') | ||||
| 		}, group, key, value); | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	public async getChart(span: Span, range: number, group?: any): Promise<ArrayValue<T>> { | ||||
| 		const promisedChart: Promise<T>[] = []; | ||||
|  | ||||
| 		const [y, m, d, h] = this.getCurrentDate(); | ||||
|  | ||||
| 		const gt = | ||||
| 			span == 'day' ? new Date(y, m, d - range) : | ||||
| 			span == 'hour' ? new Date(y, m, d, h - range) : | ||||
| 			null; | ||||
|  | ||||
| 		// ログ取得 | ||||
| 		let logs = await this.collection.find({ | ||||
| 			group: group, | ||||
| 			span: span, | ||||
| 			date: { | ||||
| 				$gt: gt | ||||
| 			} | ||||
| 		}, { | ||||
| 			sort: { | ||||
| 				date: -1 | ||||
| 			}, | ||||
| 			fields: { | ||||
| 				_id: 0 | ||||
| 			} | ||||
| 		}); | ||||
|  | ||||
| 		// 要求された範囲にログがひとつもなかったら | ||||
| 		if (logs.length == 0) { | ||||
| 			// もっとも新しいログを持ってくる | ||||
| 			// (すくなくともひとつログが無いと隙間埋めできないため) | ||||
| 			const recentLog = await this.collection.findOne({ | ||||
| 				group: group, | ||||
| 				span: span | ||||
| 			}, { | ||||
| 				sort: { | ||||
| 					date: -1 | ||||
| 				}, | ||||
| 				fields: { | ||||
| 					_id: 0 | ||||
| 				} | ||||
| 			}); | ||||
|  | ||||
| 			if (recentLog) { | ||||
| 				logs = [recentLog]; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		// 整形 | ||||
| 		for (let i = (range - 1); i >= 0; i--) { | ||||
| 			const current = | ||||
| 				span == 'day' ? new Date(y, m, d - i) : | ||||
| 				span == 'hour' ? new Date(y, m, d, h - i) : | ||||
| 				null; | ||||
|  | ||||
| 			const log = logs.find(l => l.date.getTime() == current.getTime()); | ||||
|  | ||||
| 			if (log) { | ||||
| 				promisedChart.unshift(Promise.resolve(log.data)); | ||||
| 			} else { | ||||
| 				// 隙間埋め | ||||
| 				const latest = logs.find(l => l.date.getTime() < current.getTime()); | ||||
| 				promisedChart.unshift(this.getTemplate(false, latest ? latest.data : null)); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		const chart = await Promise.all(promisedChart); | ||||
|  | ||||
| 		const res: ArrayValue<T> = {} as any; | ||||
|  | ||||
| 		/** | ||||
| 		 * [{ | ||||
| 		 * 	xxxxx: 1, yyyyy: 5 | ||||
| 		 * }, { | ||||
| 		 * 	xxxxx: 2, yyyyy: 6 | ||||
| 		 * }, { | ||||
| 		 * 	xxxxx: 3, yyyyy: 7 | ||||
| 		 * }] | ||||
| 		 * | ||||
| 		 * を | ||||
| 		 * | ||||
| 		 * { | ||||
| 		 * 	xxxxx: [1, 2, 3], | ||||
| 		 * 	yyyyy: [5, 6, 7] | ||||
| 		 * } | ||||
| 		 * | ||||
| 		 * にする | ||||
| 		 */ | ||||
| 		const dive = (x: Obj, path?: string) => { | ||||
| 			Object.entries(x).forEach(([k, v]) => { | ||||
| 				const p = path ? `${path}.${k}` : k; | ||||
| 				if (typeof v == 'object') { | ||||
| 					dive(v, p); | ||||
| 				} else { | ||||
| 					nestedProperty.set(res, p, chart.map(s => nestedProperty.get(s, p))); | ||||
| 				} | ||||
| 			}); | ||||
| 		}; | ||||
|  | ||||
| 		dive(chart[0]); | ||||
|  | ||||
| 		return res; | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										64
									
								
								src/chart/network.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								src/chart/network.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,64 @@ | ||||
| import autobind from 'autobind-decorator'; | ||||
| import Chart, { Partial } from './'; | ||||
|  | ||||
| /** | ||||
|  * ネットワークに関するチャート | ||||
|  */ | ||||
| type NetworkLog = { | ||||
| 	/** | ||||
| 	 * 受信したリクエスト数 | ||||
| 	 */ | ||||
| 	incomingRequests: number; | ||||
|  | ||||
| 	/** | ||||
| 	 * 送信したリクエスト数 | ||||
| 	 */ | ||||
| 	outgoingRequests: number; | ||||
|  | ||||
| 	/** | ||||
| 	 * 応答時間の合計 | ||||
| 	 * TIP: (totalTime / incomingRequests) でひとつのリクエストに平均でどれくらいの時間がかかったか知れる | ||||
| 	 */ | ||||
| 	totalTime: number; | ||||
|  | ||||
| 	/** | ||||
| 	 * 合計受信データ量 | ||||
| 	 */ | ||||
| 	incomingBytes: number; | ||||
|  | ||||
| 	/** | ||||
| 	 * 合計送信データ量 | ||||
| 	 */ | ||||
| 	outgoingBytes: number; | ||||
| }; | ||||
|  | ||||
| class NetworkChart extends Chart<NetworkLog> { | ||||
| 	constructor() { | ||||
| 		super('network'); | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	protected async getTemplate(init: boolean, latest?: NetworkLog): Promise<NetworkLog> { | ||||
| 		return { | ||||
| 			incomingRequests: 0, | ||||
| 			outgoingRequests: 0, | ||||
| 			totalTime: 0, | ||||
| 			incomingBytes: 0, | ||||
| 			outgoingBytes: 0 | ||||
| 		}; | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	public async update(incomingRequests: number, time: number, incomingBytes: number, outgoingBytes: number) { | ||||
| 		const inc: Partial<NetworkLog> = { | ||||
| 			incomingRequests: incomingRequests, | ||||
| 			totalTime: time, | ||||
| 			incomingBytes: incomingBytes, | ||||
| 			outgoingBytes: outgoingBytes | ||||
| 		}; | ||||
|  | ||||
| 		await this.inc(inc); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| export default new NetworkChart(); | ||||
							
								
								
									
										114
									
								
								src/chart/notes.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										114
									
								
								src/chart/notes.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,114 @@ | ||||
| import autobind from 'autobind-decorator'; | ||||
| import Chart, { Obj } from '.'; | ||||
| import Note, { INote } from '../models/note'; | ||||
| import { isLocalUser } from '../models/user'; | ||||
|  | ||||
| /** | ||||
|  * 投稿に関するチャート | ||||
|  */ | ||||
| type NotesLog = { | ||||
| 	local: { | ||||
| 		/** | ||||
| 		 * 集計期間時点での、全投稿数 | ||||
| 		 */ | ||||
| 		total: number; | ||||
|  | ||||
| 		/** | ||||
| 		 * 増加した投稿数 | ||||
| 		 */ | ||||
| 		inc: number; | ||||
|  | ||||
| 		/** | ||||
| 		 * 減少した投稿数 | ||||
| 		 */ | ||||
| 		dec: number; | ||||
|  | ||||
| 		diffs: { | ||||
| 			/** | ||||
| 			 * 通常の投稿数の差分 | ||||
| 			 */ | ||||
| 			normal: number; | ||||
|  | ||||
| 			/** | ||||
| 			 * リプライの投稿数の差分 | ||||
| 			 */ | ||||
| 			reply: number; | ||||
|  | ||||
| 			/** | ||||
| 			 * Renoteの投稿数の差分 | ||||
| 			 */ | ||||
| 			renote: number; | ||||
| 		}; | ||||
| 	}; | ||||
|  | ||||
| 	remote: NotesLog['local']; | ||||
| }; | ||||
|  | ||||
| class NotesChart extends Chart<NotesLog> { | ||||
| 	constructor() { | ||||
| 		super('notes'); | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	protected async getTemplate(init: boolean, latest?: NotesLog): Promise<NotesLog> { | ||||
| 		const [localCount, remoteCount] = init ? await Promise.all([ | ||||
| 			Note.count({ '_user.host': null }), | ||||
| 			Note.count({ '_user.host': { $ne: null } }) | ||||
| 		]) : [ | ||||
| 			latest ? latest.local.total : 0, | ||||
| 			latest ? latest.remote.total : 0 | ||||
| 		]; | ||||
|  | ||||
| 		return { | ||||
| 			local: { | ||||
| 				total: localCount, | ||||
| 				inc: 0, | ||||
| 				dec: 0, | ||||
| 				diffs: { | ||||
| 					normal: 0, | ||||
| 					reply: 0, | ||||
| 					renote: 0 | ||||
| 				} | ||||
| 			}, | ||||
| 			remote: { | ||||
| 				total: remoteCount, | ||||
| 				inc: 0, | ||||
| 				dec: 0, | ||||
| 				diffs: { | ||||
| 					normal: 0, | ||||
| 					reply: 0, | ||||
| 					renote: 0 | ||||
| 				} | ||||
| 			} | ||||
| 		}; | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	public async update(note: INote, isAdditional: boolean) { | ||||
| 		const update: Obj = { | ||||
| 			diffs: {} | ||||
| 		}; | ||||
|  | ||||
| 		update.total = isAdditional ? 1 : -1; | ||||
|  | ||||
| 		if (isAdditional) { | ||||
| 			update.inc = 1; | ||||
| 		} else { | ||||
| 			update.dec = 1; | ||||
| 		} | ||||
|  | ||||
| 		if (note.replyId != null) { | ||||
| 			update.diffs.reply = isAdditional ? 1 : -1; | ||||
| 		} else if (note.renoteId != null) { | ||||
| 			update.diffs.renote = isAdditional ? 1 : -1; | ||||
| 		} else { | ||||
| 			update.diffs.normal = isAdditional ? 1 : -1; | ||||
| 		} | ||||
|  | ||||
| 		await this.inc({ | ||||
| 			[isLocalUser(note._user) ? 'local' : 'remote']: update | ||||
| 		}); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| export default new NotesChart(); | ||||
							
								
								
									
										101
									
								
								src/chart/per-user-drive.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										101
									
								
								src/chart/per-user-drive.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,101 @@ | ||||
| import autobind from 'autobind-decorator'; | ||||
| import Chart, { Obj } from './'; | ||||
| import DriveFile, { IDriveFile } from '../models/drive-file'; | ||||
|  | ||||
| /** | ||||
|  * ユーザーごとのドライブに関するチャート | ||||
|  */ | ||||
| type PerUserDriveLog = { | ||||
| 	/** | ||||
| 	 * 集計期間時点での、全ドライブファイル数 | ||||
| 	 */ | ||||
| 	totalCount: number; | ||||
|  | ||||
| 	/** | ||||
| 	 * 集計期間時点での、全ドライブファイルの合計サイズ | ||||
| 	 */ | ||||
| 	totalSize: number; | ||||
|  | ||||
| 	/** | ||||
| 	 * 増加したドライブファイル数 | ||||
| 	 */ | ||||
| 	incCount: number; | ||||
|  | ||||
| 	/** | ||||
| 	 * 増加したドライブ使用量 | ||||
| 	 */ | ||||
| 	incSize: number; | ||||
|  | ||||
| 	/** | ||||
| 	 * 減少したドライブファイル数 | ||||
| 	 */ | ||||
| 	decCount: number; | ||||
|  | ||||
| 	/** | ||||
| 	 * 減少したドライブ使用量 | ||||
| 	 */ | ||||
| 	decSize: number; | ||||
| }; | ||||
|  | ||||
| class PerUserDriveChart extends Chart<PerUserDriveLog> { | ||||
| 	constructor() { | ||||
| 		super('perUserDrive', true); | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	protected async getTemplate(init: boolean, latest?: PerUserDriveLog, group?: any): Promise<PerUserDriveLog> { | ||||
| 		const calcSize = () => DriveFile | ||||
| 			.aggregate([{ | ||||
| 				$match: { | ||||
| 					'metadata.userId': group, | ||||
| 					'metadata.deletedAt': { $exists: false } | ||||
| 				} | ||||
| 			}, { | ||||
| 				$project: { | ||||
| 					length: true | ||||
| 				} | ||||
| 			}, { | ||||
| 				$group: { | ||||
| 					_id: null, | ||||
| 					usage: { $sum: '$length' } | ||||
| 				} | ||||
| 			}]) | ||||
| 			.then(res => res.length > 0 ? res[0].usage : 0); | ||||
|  | ||||
| 		const [count, size] = init ? await Promise.all([ | ||||
| 			DriveFile.count({ 'metadata.userId': group }), | ||||
| 			calcSize() | ||||
| 		]) : [ | ||||
| 			latest ? latest.totalCount : 0, | ||||
| 			latest ? latest.totalSize : 0 | ||||
| 		]; | ||||
|  | ||||
| 		return { | ||||
| 			totalCount: count, | ||||
| 			totalSize: size, | ||||
| 			incCount: 0, | ||||
| 			incSize: 0, | ||||
| 			decCount: 0, | ||||
| 			decSize: 0 | ||||
| 		}; | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	public async update(file: IDriveFile, isAdditional: boolean) { | ||||
| 		const update: Obj = {}; | ||||
|  | ||||
| 		update.totalCount = isAdditional ? 1 : -1; | ||||
| 		update.totalSize = isAdditional ? file.length : -file.length; | ||||
| 		if (isAdditional) { | ||||
| 			update.incCount = 1; | ||||
| 			update.incSize = file.length; | ||||
| 		} else { | ||||
| 			update.decCount = 1; | ||||
| 			update.decSize = file.length; | ||||
| 		} | ||||
|  | ||||
| 		await this.inc(update, file.metadata.userId); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| export default new PerUserDriveChart(); | ||||
							
								
								
									
										128
									
								
								src/chart/per-user-following.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										128
									
								
								src/chart/per-user-following.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,128 @@ | ||||
| import autobind from 'autobind-decorator'; | ||||
| import Chart, { Obj } from './'; | ||||
| import Following from '../models/following'; | ||||
| import { IUser, isLocalUser } from '../models/user'; | ||||
|  | ||||
| /** | ||||
|  * ユーザーごとのフォローに関するチャート | ||||
|  */ | ||||
| type PerUserFollowingLog = { | ||||
| 	local: { | ||||
| 		/** | ||||
| 		 * フォローしている | ||||
| 		 */ | ||||
| 		followings: { | ||||
| 			/** | ||||
| 			 * 合計 | ||||
| 			 */ | ||||
| 			total: number; | ||||
|  | ||||
| 			/** | ||||
| 			 * フォローした数 | ||||
| 			 */ | ||||
| 			inc: number; | ||||
|  | ||||
| 			/** | ||||
| 			 * フォロー解除した数 | ||||
| 			 */ | ||||
| 			dec: number; | ||||
| 		}; | ||||
|  | ||||
| 		/** | ||||
| 		 * フォローされている | ||||
| 		 */ | ||||
| 		followers: { | ||||
| 			/** | ||||
| 			 * 合計 | ||||
| 			 */ | ||||
| 			total: number; | ||||
|  | ||||
| 			/** | ||||
| 			 * フォローされた数 | ||||
| 			 */ | ||||
| 			inc: number; | ||||
|  | ||||
| 			/** | ||||
| 			 * フォロー解除された数 | ||||
| 			 */ | ||||
| 			dec: number; | ||||
| 		}; | ||||
| 	}; | ||||
|  | ||||
| 	remote: PerUserFollowingLog['local']; | ||||
| }; | ||||
|  | ||||
| class PerUserFollowingChart extends Chart<PerUserFollowingLog> { | ||||
| 	constructor() { | ||||
| 		super('perUserFollowing', true); | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	protected async getTemplate(init: boolean, latest?: PerUserFollowingLog, group?: any): Promise<PerUserFollowingLog> { | ||||
| 		const [ | ||||
| 			localFollowingsCount, | ||||
| 			localFollowersCount, | ||||
| 			remoteFollowingsCount, | ||||
| 			remoteFollowersCount | ||||
| 		] = init ? await Promise.all([ | ||||
| 			Following.count({ followerId: group, '_followee.host': null }), | ||||
| 			Following.count({ followeeId: group, '_follower.host': null }), | ||||
| 			Following.count({ followerId: group, '_followee.host': { $ne: null } }), | ||||
| 			Following.count({ followeeId: group, '_follower.host': { $ne: null } }) | ||||
| 		]) : [ | ||||
| 			latest ? latest.local.followings.total : 0, | ||||
| 			latest ? latest.local.followers.total : 0, | ||||
| 			latest ? latest.remote.followings.total : 0, | ||||
| 			latest ? latest.remote.followers.total : 0 | ||||
| 		]; | ||||
|  | ||||
| 		return { | ||||
| 			local: { | ||||
| 				followings: { | ||||
| 					total: localFollowingsCount, | ||||
| 					inc: 0, | ||||
| 					dec: 0 | ||||
| 				}, | ||||
| 				followers: { | ||||
| 					total: localFollowersCount, | ||||
| 					inc: 0, | ||||
| 					dec: 0 | ||||
| 				} | ||||
| 			}, | ||||
| 			remote: { | ||||
| 				followings: { | ||||
| 					total: remoteFollowingsCount, | ||||
| 					inc: 0, | ||||
| 					dec: 0 | ||||
| 				}, | ||||
| 				followers: { | ||||
| 					total: remoteFollowersCount, | ||||
| 					inc: 0, | ||||
| 					dec: 0 | ||||
| 				} | ||||
| 			} | ||||
| 		}; | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	public async update(follower: IUser, followee: IUser, isFollow: boolean) { | ||||
| 		const update: Obj = {}; | ||||
|  | ||||
| 		update.total = isFollow ? 1 : -1; | ||||
|  | ||||
| 		if (isFollow) { | ||||
| 			update.inc = 1; | ||||
| 		} else { | ||||
| 			update.dec = 1; | ||||
| 		} | ||||
|  | ||||
| 		this.inc({ | ||||
| 			[isLocalUser(follower) ? 'local' : 'remote']: { followings: update } | ||||
| 		}, follower._id); | ||||
| 		this.inc({ | ||||
| 			[isLocalUser(followee) ? 'local' : 'remote']: { followers: update } | ||||
| 		}, followee._id); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| export default new PerUserFollowingChart(); | ||||
							
								
								
									
										94
									
								
								src/chart/per-user-notes.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										94
									
								
								src/chart/per-user-notes.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,94 @@ | ||||
| import autobind from 'autobind-decorator'; | ||||
| import Chart, { Obj } from './'; | ||||
| import Note, { INote } from '../models/note'; | ||||
| import { IUser } from '../models/user'; | ||||
|  | ||||
| /** | ||||
|  * ユーザーごとの投稿に関するチャート | ||||
|  */ | ||||
| type PerUserNotesLog = { | ||||
| 	/** | ||||
| 	 * 集計期間時点での、全投稿数 | ||||
| 	 */ | ||||
| 	total: number; | ||||
|  | ||||
| 	/** | ||||
| 	 * 増加した投稿数 | ||||
| 	 */ | ||||
| 	inc: number; | ||||
|  | ||||
| 	/** | ||||
| 	 * 減少した投稿数 | ||||
| 	 */ | ||||
| 	dec: number; | ||||
|  | ||||
| 	diffs: { | ||||
| 		/** | ||||
| 		 * 通常の投稿数の差分 | ||||
| 		 */ | ||||
| 		normal: number; | ||||
|  | ||||
| 		/** | ||||
| 		 * リプライの投稿数の差分 | ||||
| 		 */ | ||||
| 		reply: number; | ||||
|  | ||||
| 		/** | ||||
| 		 * Renoteの投稿数の差分 | ||||
| 		 */ | ||||
| 		renote: number; | ||||
| 	}; | ||||
| }; | ||||
|  | ||||
| class PerUserNotesChart extends Chart<PerUserNotesLog> { | ||||
| 	constructor() { | ||||
| 		super('perUserNotes', true); | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	protected async getTemplate(init: boolean, latest?: PerUserNotesLog, group?: any): Promise<PerUserNotesLog> { | ||||
| 		const [count] = init ? await Promise.all([ | ||||
| 			Note.count({ userId: group, deletedAt: null }), | ||||
| 		]) : [ | ||||
| 			latest ? latest.total : 0 | ||||
| 		]; | ||||
|  | ||||
| 		return { | ||||
| 			total: count, | ||||
| 			inc: 0, | ||||
| 			dec: 0, | ||||
| 			diffs: { | ||||
| 				normal: 0, | ||||
| 				reply: 0, | ||||
| 				renote: 0 | ||||
| 			} | ||||
| 		}; | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	public async update(user: IUser, note: INote, isAdditional: boolean) { | ||||
| 		const update: Obj = { | ||||
| 			diffs: {} | ||||
| 		}; | ||||
|  | ||||
| 		update.total = isAdditional ? 1 : -1; | ||||
|  | ||||
| 		if (isAdditional) { | ||||
| 			update.inc = 1; | ||||
| 		} else { | ||||
| 			update.dec = 1; | ||||
| 		} | ||||
|  | ||||
| 		if (note.replyId != null) { | ||||
| 			update.diffs.reply = isAdditional ? 1 : -1; | ||||
| 		} else if (note.renoteId != null) { | ||||
| 			update.diffs.renote = isAdditional ? 1 : -1; | ||||
| 		} else { | ||||
| 			update.diffs.normal = isAdditional ? 1 : -1; | ||||
| 		} | ||||
|  | ||||
| 		await this.inc(update, user._id); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| export default new PerUserNotesChart(); | ||||
							
								
								
									
										45
									
								
								src/chart/per-user-reactions.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								src/chart/per-user-reactions.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,45 @@ | ||||
| import autobind from 'autobind-decorator'; | ||||
| import Chart from './'; | ||||
| import { IUser, isLocalUser } from '../models/user'; | ||||
| import { INote } from '../models/note'; | ||||
|  | ||||
| /** | ||||
|  * ユーザーごとのリアクションに関するチャート | ||||
|  */ | ||||
| type PerUserReactionsLog = { | ||||
| 	local: { | ||||
| 		/** | ||||
| 		 * リアクションされた数 | ||||
| 		 */ | ||||
| 		count: number; | ||||
| 	}; | ||||
|  | ||||
| 	remote: PerUserReactionsLog['local']; | ||||
| }; | ||||
|  | ||||
| class PerUserReactionsChart extends Chart<PerUserReactionsLog> { | ||||
| 	constructor() { | ||||
| 		super('perUserReaction', true); | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	protected async getTemplate(init: boolean, latest?: PerUserReactionsLog, group?: any): Promise<PerUserReactionsLog> { | ||||
| 		return { | ||||
| 			local: { | ||||
| 				count: 0 | ||||
| 			}, | ||||
| 			remote: { | ||||
| 				count: 0 | ||||
| 			} | ||||
| 		}; | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	public async update(user: IUser, note: INote) { | ||||
| 		this.inc({ | ||||
| 			[isLocalUser(user) ? 'local' : 'remote']: { count: 1 } | ||||
| 		}, note.userId); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| export default new PerUserReactionsChart(); | ||||
							
								
								
									
										75
									
								
								src/chart/users.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								src/chart/users.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,75 @@ | ||||
| import autobind from 'autobind-decorator'; | ||||
| import Chart, { Obj } from './'; | ||||
| import User, { IUser, isLocalUser } from '../models/user'; | ||||
|  | ||||
| /** | ||||
|  * ユーザーに関するチャート | ||||
|  */ | ||||
| type UsersLog = { | ||||
| 	local: { | ||||
| 		/** | ||||
| 		 * 集計期間時点での、全ユーザー数 | ||||
| 		 */ | ||||
| 		total: number; | ||||
|  | ||||
| 		/** | ||||
| 		 * 増加したユーザー数 | ||||
| 		 */ | ||||
| 		inc: number; | ||||
|  | ||||
| 		/** | ||||
| 		 * 減少したユーザー数 | ||||
| 		 */ | ||||
| 		dec: number; | ||||
| 	}; | ||||
|  | ||||
| 	remote: UsersLog['local']; | ||||
| }; | ||||
|  | ||||
| class UsersChart extends Chart<UsersLog> { | ||||
| 	constructor() { | ||||
| 		super('users'); | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	protected async getTemplate(init: boolean, latest?: UsersLog): Promise<UsersLog> { | ||||
| 		const [localCount, remoteCount] = init ? await Promise.all([ | ||||
| 			User.count({ host: null }), | ||||
| 			User.count({ host: { $ne: null } }) | ||||
| 		]) : [ | ||||
| 			latest ? latest.local.total : 0, | ||||
| 			latest ? latest.remote.total : 0 | ||||
| 		]; | ||||
|  | ||||
| 		return { | ||||
| 			local: { | ||||
| 				total: localCount, | ||||
| 				inc: 0, | ||||
| 				dec: 0 | ||||
| 			}, | ||||
| 			remote: { | ||||
| 				total: remoteCount, | ||||
| 				inc: 0, | ||||
| 				dec: 0 | ||||
| 			} | ||||
| 		}; | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| 	public async update(user: IUser, isAdditional: boolean) { | ||||
| 		const update: Obj = {}; | ||||
|  | ||||
| 		update.total = isAdditional ? 1 : -1; | ||||
| 		if (isAdditional) { | ||||
| 			update.inc = 1; | ||||
| 		} else { | ||||
| 			update.dec = 1; | ||||
| 		} | ||||
|  | ||||
| 		await this.inc({ | ||||
| 			[isLocalUser(user) ? 'local' : 'remote']: update | ||||
| 		}); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| export default new UsersChart(); | ||||
							
								
								
									
										150
									
								
								src/client/app/admin/assets/header-icon.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										150
									
								
								src/client/app/admin/assets/header-icon.svg
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,150 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||
| <!-- Created with Inkscape (http://www.inkscape.org/) --> | ||||
| 
 | ||||
| <svg | ||||
|    xmlns:dc="http://purl.org/dc/elements/1.1/" | ||||
|    xmlns:cc="http://creativecommons.org/ns#" | ||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" | ||||
|    xmlns:svg="http://www.w3.org/2000/svg" | ||||
|    xmlns="http://www.w3.org/2000/svg" | ||||
|    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" | ||||
|    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" | ||||
|    width="512" | ||||
|    height="512" | ||||
|    viewBox="0 0 135.46667 135.46667" | ||||
|    version="1.1" | ||||
|    id="svg8" | ||||
|    inkscape:version="0.92.1 r15371" | ||||
|    sodipodi:docname="header-icon.dark.svg" | ||||
|    inkscape:export-filename="C:\Users\syuilo\projects\misskey\assets\favicon\32.png" | ||||
|    inkscape:export-xdpi="6" | ||||
|    inkscape:export-ydpi="6"> | ||||
|   <defs | ||||
|      id="defs2"> | ||||
|     <inkscape:path-effect | ||||
|        effect="simplify" | ||||
|        id="path-effect5115" | ||||
|        is_visible="true" | ||||
|        steps="1" | ||||
|        threshold="0.000408163" | ||||
|        smooth_angles="360" | ||||
|        helper_size="0" | ||||
|        simplify_individual_paths="false" | ||||
|        simplify_just_coalesce="false" | ||||
|        simplifyindividualpaths="false" | ||||
|        simplifyJustCoalesce="false" /> | ||||
|     <inkscape:path-effect | ||||
|        effect="simplify" | ||||
|        id="path-effect5111" | ||||
|        is_visible="true" | ||||
|        steps="1" | ||||
|        threshold="0.000408163" | ||||
|        smooth_angles="360" | ||||
|        helper_size="0" | ||||
|        simplify_individual_paths="false" | ||||
|        simplify_just_coalesce="false" | ||||
|        simplifyindividualpaths="false" | ||||
|        simplifyJustCoalesce="false" /> | ||||
|     <inkscape:path-effect | ||||
|        effect="simplify" | ||||
|        id="path-effect5104" | ||||
|        is_visible="true" | ||||
|        steps="1" | ||||
|        threshold="0.000408163" | ||||
|        smooth_angles="360" | ||||
|        helper_size="0" | ||||
|        simplify_individual_paths="false" | ||||
|        simplify_just_coalesce="false" | ||||
|        simplifyindividualpaths="false" | ||||
|        simplifyJustCoalesce="false" /> | ||||
|   </defs> | ||||
|   <sodipodi:namedview | ||||
|      id="base" | ||||
|      pagecolor="#ffffff" | ||||
|      bordercolor="#666666" | ||||
|      borderopacity="1.0" | ||||
|      inkscape:pageopacity="0.0" | ||||
|      inkscape:pageshadow="2" | ||||
|      inkscape:zoom="1.4142136" | ||||
|      inkscape:cx="114.309" | ||||
|      inkscape:cy="251.50613" | ||||
|      inkscape:document-units="px" | ||||
|      inkscape:current-layer="g4502" | ||||
|      showgrid="true" | ||||
|      units="px" | ||||
|      inkscape:snap-bbox="true" | ||||
|      inkscape:bbox-nodes="true" | ||||
|      inkscape:snap-bbox-edge-midpoints="false" | ||||
|      inkscape:snap-smooth-nodes="true" | ||||
|      inkscape:snap-center="true" | ||||
|      inkscape:snap-page="true" | ||||
|      inkscape:window-width="1920" | ||||
|      inkscape:window-height="1027" | ||||
|      inkscape:window-x="-8" | ||||
|      inkscape:window-y="1072" | ||||
|      inkscape:window-maximized="1" | ||||
|      inkscape:snap-object-midpoints="true" | ||||
|      inkscape:snap-midpoints="true" | ||||
|      inkscape:object-paths="true" | ||||
|      fit-margin-top="0" | ||||
|      fit-margin-left="0" | ||||
|      fit-margin-right="0" | ||||
|      fit-margin-bottom="0" | ||||
|      objecttolerance="1" | ||||
|      guidetolerance="1" | ||||
|      inkscape:snap-nodes="false" | ||||
|      inkscape:snap-others="false"> | ||||
|     <inkscape:grid | ||||
|        type="xygrid" | ||||
|        id="grid4504" | ||||
|        spacingx="4.2333334" | ||||
|        spacingy="4.2333334" | ||||
|        empcolor="#ff3fff" | ||||
|        empopacity="0.25098039" | ||||
|        empspacing="4" /> | ||||
|   </sodipodi:namedview> | ||||
|   <metadata | ||||
|      id="metadata5"> | ||||
|     <rdf:RDF> | ||||
|       <cc:Work | ||||
|          rdf:about=""> | ||||
|         <dc:format>image/svg+xml</dc:format> | ||||
|         <dc:type | ||||
|            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> | ||||
|         <dc:title></dc:title> | ||||
|       </cc:Work> | ||||
|     </rdf:RDF> | ||||
|   </metadata> | ||||
|   <g | ||||
|      inkscape:label="レイヤー 1" | ||||
|      inkscape:groupmode="layer" | ||||
|      id="layer1" | ||||
|      transform="translate(-30.809093,-111.78601)"> | ||||
|     <g | ||||
|        id="g4502" | ||||
|        transform="matrix(1.096096,0,0,1.096096,-2.960633,-44.023579)"> | ||||
|       <g | ||||
|          style="fill-opacity:1" | ||||
|          transform="translate(-1.3333333e-6,-1.3439941e-6)" | ||||
|          id="g5125"> | ||||
|         <g | ||||
|            transform="matrix(0.91391326,0,0,0.91391326,7.9719907,17.595761)" | ||||
|            id="text4489" | ||||
|            style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:141.03404236px;line-height:476.69509888px;font-family:'OTADESIGN Rounded';-inkscape-font-specification:'OTADESIGN Rounded';letter-spacing:0px;word-spacing:0px;fill-opacity:1;stroke:none;stroke-width:0.28950602px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" | ||||
|            aria-label="Mi"> | ||||
|           <path | ||||
|              sodipodi:nodetypes="zccssscssccscczzzccsccsscscsccz" | ||||
|              inkscape:connector-curvature="0" | ||||
|              id="path5210" | ||||
|              style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-family:'OTADESIGN Rounded';-inkscape-font-specification:'OTADESIGN Rounded';fill-opacity:1;stroke-width:0.28950602px" | ||||
|              d="m 75.196381,231.17126 c -5.855419,0.0202 -10.885068,-3.50766 -13.2572,-7.61584 -1.266603,-1.79454 -3.772419,-2.43291 -3.807919,0 v 11.2332 c 0,4.51309 -1.645397,8.41504 -4.936191,11.70583 -3.196772,3.19677 -7.098714,4.79516 -11.705826,4.79516 -4.513089,0 -8.415031,-1.59839 -11.705825,-4.79516 -3.196772,-3.29079 -4.795158,-7.19274 -4.795158,-11.70583 v -61.7729 c 0,-3.47884 0.987238,-6.6286 2.961715,-9.44928 2.068499,-2.91471 4.701135,-4.9362 7.897906,-6.06447 1.786431,-0.65816 3.666885,-0.98724 5.641362,-0.98724 5.077225,0 9.308247,1.97448 12.693064,5.92343 1.786431,1.97448 2.820681,3.00873 3.102749,3.10275 0,0 13.408119,16.21319 13.78421,16.49526 0.376091,0.28206 1.480789,2.43848 4.127113,2.43848 2.646324,0 3.89218,-2.15642 4.26827,-2.43848 0.376091,-0.28207 13.784088,-16.49526 13.784088,-16.49526 0.09402,0.094 1.081261,-0.94022 2.961715,-3.10275 3.478837,-3.94895 7.756866,-5.92343 12.834096,-5.92343 1.88045,0 3.76091,0.32908 5.64136,0.98724 3.19677,1.12827 5.7824,3.14976 7.75688,6.06447 2.06849,2.82068 3.10274,5.97044 3.10274,9.44928 v 61.7729 c 0,4.51309 -1.6454,8.41504 -4.93619,11.70583 -3.19677,3.19677 -7.09871,4.79516 -11.70582,4.79516 -4.51309,0 -8.41504,-1.59839 -11.705828,-4.79516 -3.196772,-3.29079 -4.795158,-7.19274 -4.795158,-11.70583 v -11.2332 c -0.277898,-3.06563 -2.987588,-1.13379 -3.948953,0 -2.538613,4.70114 -7.401781,7.59567 -13.2572,7.61584 z" /> | ||||
|           <path | ||||
|              inkscape:connector-curvature="0" | ||||
|              id="path5212" | ||||
|              style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-family:'OTADESIGN Rounded';-inkscape-font-specification:'OTADESIGN Rounded';fill-opacity:1;stroke-width:0.28950602px" | ||||
|              d="m 145.83461,185.00361 q -5.92343,0 -10.15445,-4.08999 -4.08999,-4.23102 -4.08999,-10.15445 0,-5.92343 4.08999,-10.01342 4.23102,-4.23102 10.15445,-4.23102 5.92343,0 10.15445,4.23102 4.23102,4.08999 4.23102,10.01342 0,5.92343 -4.23102,10.15445 -4.23102,4.08999 -10.15445,4.08999 z m 0.14103,2.82068 q 5.92343,0 10.01342,4.23102 4.23102,4.23102 4.23102,10.15445 v 34.83541 q 0,5.92343 -4.23102,10.15445 -4.08999,4.08999 -10.01342,4.08999 -5.92343,0 -10.15445,-4.08999 -4.23102,-4.23102 -4.23102,-10.15445 v -34.83541 q 0,-5.92343 4.23102,-10.15445 4.23102,-4.23102 10.15445,-4.23102 z" /> | ||||
|         </g> | ||||
|       </g> | ||||
|     </g> | ||||
|   </g> | ||||
| </svg> | ||||
| After Width: | Height: | Size: 7.0 KiB | 
							
								
								
									
										27
									
								
								src/client/app/admin/script.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								src/client/app/admin/script.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | ||||
| /** | ||||
|  * Admin | ||||
|  */ | ||||
|  | ||||
| import VueRouter from 'vue-router'; | ||||
|  | ||||
| // Style | ||||
| import './style.styl'; | ||||
|  | ||||
| import init from '../init'; | ||||
| import Index from './views/index.vue'; | ||||
|  | ||||
| init(launch => { | ||||
| 	document.title = 'Admin'; | ||||
|  | ||||
| 	// Init router | ||||
| 	const router = new VueRouter({ | ||||
| 		mode: 'history', | ||||
| 		base: '/admin/', | ||||
| 		routes: [ | ||||
| 			{ path: '/', component: Index }, | ||||
| 		] | ||||
| 	}); | ||||
|  | ||||
| 	// Launch the app | ||||
| 	launch(router); | ||||
| }); | ||||
							
								
								
									
										6
									
								
								src/client/app/admin/style.styl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								src/client/app/admin/style.styl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | ||||
| @import "../app" | ||||
| @import "../reset" | ||||
|  | ||||
| html | ||||
| 	height 100% | ||||
| 	background var(--bg) | ||||
							
								
								
									
										71
									
								
								src/client/app/admin/views/announcements.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										71
									
								
								src/client/app/admin/views/announcements.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,71 @@ | ||||
| <template> | ||||
| <div class="cdeuzmsthagexbkpofbmatmugjuvogfb"> | ||||
| 	<ui-card> | ||||
| 		<div slot="title">%fa:broadcast-tower% %i18n:@announcements%</div> | ||||
| 		<section v-for="(announcement, i) in announcements" class="fit-top"> | ||||
| 			<ui-input v-model="announcement.title" @change="save"> | ||||
| 				<span>%i18n:@title%</span> | ||||
| 			</ui-input> | ||||
| 			<ui-textarea v-model="announcement.text"> | ||||
| 				<span>%i18n:@text%</span> | ||||
| 			</ui-textarea> | ||||
| 			<ui-horizon-group> | ||||
| 				<ui-button @click="save">%fa:save R% %i18n:@save%</ui-button> | ||||
| 				<ui-button @click="remove(i)">%fa:trash-alt R% %i18n:@remove%</ui-button> | ||||
| 			</ui-horizon-group> | ||||
| 		</section> | ||||
| 		<section> | ||||
| 			<ui-button @click="add">%fa:plus% %i18n:@add%</ui-button> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from "vue"; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	data() { | ||||
| 		return { | ||||
| 			announcements: [], | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	created() { | ||||
| 		(this as any).os.getMeta().then(meta => { | ||||
| 			this.announcements = meta.broadcasts; | ||||
| 		}); | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		add() { | ||||
| 			this.announcements.push({ | ||||
| 				title: '', | ||||
| 				text: '' | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		remove(i) { | ||||
| 			this.announcements = this.announcements.filter((_, j) => j !== i); | ||||
| 			this.save(); | ||||
| 		}, | ||||
|  | ||||
| 		save() { | ||||
| 			(this as any).api('admin/update-meta', { | ||||
| 				broadcasts: this.announcements | ||||
| 			}).then(() => { | ||||
| 				//(this as any).os.apis.dialog({ text: `Saved` }); | ||||
| 			}).catch(e => { | ||||
| 				//(this as any).os.apis.dialog({ text: `Failed ${e}` }); | ||||
| 			}); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .cdeuzmsthagexbkpofbmatmugjuvogfb | ||||
| 	@media (min-width 500px) | ||||
| 		padding 16px | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										105
									
								
								src/client/app/admin/views/ap-log.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										105
									
								
								src/client/app/admin/views/ap-log.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,105 @@ | ||||
| <template> | ||||
| <div class="hyhctythnmwihguaaapnbrbszsjqxpio"> | ||||
| 	<table> | ||||
| 		<thead> | ||||
| 			<tr> | ||||
| 				<th>%fa:exchange-alt% In/Out</th> | ||||
| 				<th>%fa:server% Host</th> | ||||
| 				<th>%fa:bolt% Activity</th> | ||||
| 				<th>%fa:user% Actor</th> | ||||
| 			</tr> | ||||
| 		</thead> | ||||
| 		<tbody> | ||||
| 			<tr v-for="log in logs" :key="log.id"> | ||||
| 				<td :class="log.direction">{{ log.direction == 'in' ? '<' : '>' }} {{ log.direction }}</td> | ||||
| 				<td>{{ log.host }}</td> | ||||
| 				<td>{{ log.activity }}</td> | ||||
| 				<td>@{{ log.actor }}</td> | ||||
| 			</tr> | ||||
| 		</tbody> | ||||
| 	</table> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	data() { | ||||
| 		return { | ||||
| 			logs: [], | ||||
| 			connection: null | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	mounted() { | ||||
| 		this.connection = (this as any).os.stream.useSharedConnection('apLog'); | ||||
| 		this.connection.on('log', this.onLog); | ||||
| 		this.connection.on('logs', this.onLogs); | ||||
| 		this.connection.send('requestLog', { | ||||
| 			id: Math.random().toString().substr(2, 8), | ||||
| 			length: 50 | ||||
| 		}); | ||||
| 	}, | ||||
|  | ||||
| 	beforeDestroy() { | ||||
| 		this.connection.dispose(); | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		onLog(log) { | ||||
| 			log.id = Math.random(); | ||||
| 			this.logs.unshift(log); | ||||
| 			if (this.logs.length > 50) this.logs.pop(); | ||||
| 		}, | ||||
|  | ||||
| 		onLogs(logs) { | ||||
| 			logs.reverse().forEach(log => this.onLog(log)); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .hyhctythnmwihguaaapnbrbszsjqxpio | ||||
| 	display block | ||||
| 	padding 12px 16px 16px 16px | ||||
| 	height 250px | ||||
| 	overflow hidden | ||||
| 	box-shadow 0 2px 4px rgba(0, 0, 0, 0.1) | ||||
| 	background var(--adminDashboardCardBg) | ||||
| 	border-radius 8px | ||||
|  | ||||
| 	> table | ||||
| 		width 100% | ||||
| 		max-width 100% | ||||
| 		overflow auto | ||||
| 		border-spacing 0 | ||||
| 		border-collapse collapse | ||||
| 		color var(--adminDashboardCardFg) | ||||
| 		font-size 14px | ||||
|  | ||||
| 		thead | ||||
| 			border-bottom solid 1px var(--adminDashboardCardDivider) | ||||
|  | ||||
| 			tr | ||||
| 				th | ||||
| 					font-weight normal | ||||
| 					text-align left | ||||
|  | ||||
| 		tbody | ||||
| 			tr | ||||
| 				&:nth-child(odd) | ||||
| 					background rgba(0, 0, 0, 0.025) | ||||
|  | ||||
| 		th, td | ||||
| 			padding 8px 16px | ||||
| 			min-width 128px | ||||
|  | ||||
| 		td.in | ||||
| 			color #d26755 | ||||
|  | ||||
| 		td.out | ||||
| 			color #55bb83 | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										469
									
								
								src/client/app/admin/views/charts.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										469
									
								
								src/client/app/admin/views/charts.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,469 @@ | ||||
| <template> | ||||
| <div class="qvgidhudpqhjttdhxubzuyrhyzgslujw"> | ||||
| 	<header> | ||||
| 		<b>%fa:chart-bar R% %i18n:@title%:</b> | ||||
| 		<select v-model="src"> | ||||
| 			<optgroup label="%i18n:@federation%"> | ||||
| 				<option value="federation-instances">%i18n:@charts.federation-instances%</option> | ||||
| 				<option value="federation-instances-total">%i18n:@charts.federation-instances-total%</option> | ||||
| 			</optgroup> | ||||
| 			<optgroup label="%i18n:@users%"> | ||||
| 				<option value="users">%i18n:@charts.users%</option> | ||||
| 				<option value="users-total">%i18n:@charts.users-total%</option> | ||||
| 			</optgroup> | ||||
| 			<optgroup label="%i18n:@notes%"> | ||||
| 				<option value="notes">%i18n:@charts.notes%</option> | ||||
| 				<option value="local-notes">%i18n:@charts.local-notes%</option> | ||||
| 				<option value="remote-notes">%i18n:@charts.remote-notes%</option> | ||||
| 				<option value="notes-total">%i18n:@charts.notes-total%</option> | ||||
| 			</optgroup> | ||||
| 			<optgroup label="%i18n:@drive%"> | ||||
| 				<option value="drive-files">%i18n:@charts.drive-files%</option> | ||||
| 				<option value="drive-files-total">%i18n:@charts.drive-files-total%</option> | ||||
| 				<option value="drive">%i18n:@charts.drive%</option> | ||||
| 				<option value="drive-total">%i18n:@charts.drive-total%</option> | ||||
| 			</optgroup> | ||||
| 			<optgroup label="%i18n:@network%"> | ||||
| 				<option value="network-requests">%i18n:@charts.network-requests%</option> | ||||
| 				<option value="network-time">%i18n:@charts.network-time%</option> | ||||
| 				<option value="network-usage">%i18n:@charts.network-usage%</option> | ||||
| 			</optgroup> | ||||
| 		</select> | ||||
| 		<div> | ||||
| 			<span @click="span = 'day'" :class="{ active: span == 'day' }">%i18n:@per-day%</span> | <span @click="span = 'hour'" :class="{ active: span == 'hour' }">%i18n:@per-hour%</span> | ||||
| 		</div> | ||||
| 	</header> | ||||
| 	<div ref="chart"></div> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import * as tinycolor from 'tinycolor2'; | ||||
| import * as ApexCharts from 'apexcharts'; | ||||
|  | ||||
| const limit = 90; | ||||
|  | ||||
| const sum = (...arr) => arr.reduce((r, a) => r.map((b, i) => a[i] + b)); | ||||
| const negate = arr => arr.map(x => -x); | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	data() { | ||||
| 		return { | ||||
| 			chart: null, | ||||
| 			src: 'notes', | ||||
| 			span: 'hour', | ||||
| 			chartInstance: null | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	computed: { | ||||
| 		data(): any { | ||||
| 			if (this.chart == null) return null; | ||||
| 			switch (this.src) { | ||||
| 				case 'federation-instances': return this.federationInstancesChart(false); | ||||
| 				case 'federation-instances-total': return this.federationInstancesChart(true); | ||||
| 				case 'users': return this.usersChart(false); | ||||
| 				case 'users-total': return this.usersChart(true); | ||||
| 				case 'notes': return this.notesChart('combined'); | ||||
| 				case 'local-notes': return this.notesChart('local'); | ||||
| 				case 'remote-notes': return this.notesChart('remote'); | ||||
| 				case 'notes-total': return this.notesTotalChart(); | ||||
| 				case 'drive': return this.driveChart(); | ||||
| 				case 'drive-total': return this.driveTotalChart(); | ||||
| 				case 'drive-files': return this.driveFilesChart(); | ||||
| 				case 'drive-files-total': return this.driveFilesTotalChart(); | ||||
| 				case 'network-requests': return this.networkRequestsChart(); | ||||
| 				case 'network-time': return this.networkTimeChart(); | ||||
| 				case 'network-usage': return this.networkUsageChart(); | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
| 		stats(): any[] { | ||||
| 			const stats = | ||||
| 				this.span == 'day' ? this.chart.perDay : | ||||
| 				this.span == 'hour' ? this.chart.perHour : | ||||
| 				null; | ||||
|  | ||||
| 			return stats; | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	watch: { | ||||
| 		src() { | ||||
| 			this.render(); | ||||
| 		}, | ||||
|  | ||||
| 		span() { | ||||
| 			this.render(); | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	async mounted() { | ||||
| 		this.now = new Date(); | ||||
|  | ||||
| 		const [perHour, perDay] = await Promise.all([Promise.all([ | ||||
| 			(this as any).api('charts/federation', { limit: limit, span: 'hour' }), | ||||
| 			(this as any).api('charts/users', { limit: limit, span: 'hour' }), | ||||
| 			(this as any).api('charts/notes', { limit: limit, span: 'hour' }), | ||||
| 			(this as any).api('charts/drive', { limit: limit, span: 'hour' }), | ||||
| 			(this as any).api('charts/network', { limit: limit, span: 'hour' }) | ||||
| 		]), Promise.all([ | ||||
| 			(this as any).api('charts/federation', { limit: limit, span: 'day' }), | ||||
| 			(this as any).api('charts/users', { limit: limit, span: 'day' }), | ||||
| 			(this as any).api('charts/notes', { limit: limit, span: 'day' }), | ||||
| 			(this as any).api('charts/drive', { limit: limit, span: 'day' }), | ||||
| 			(this as any).api('charts/network', { limit: limit, span: 'day' }) | ||||
| 		])]); | ||||
|  | ||||
| 		const chart = { | ||||
| 			perHour: { | ||||
| 				federation: perHour[0], | ||||
| 				users: perHour[1], | ||||
| 				notes: perHour[2], | ||||
| 				drive: perHour[3], | ||||
| 				network: perHour[4] | ||||
| 			}, | ||||
| 			perDay: { | ||||
| 				federation: perDay[0], | ||||
| 				users: perDay[1], | ||||
| 				notes: perDay[2], | ||||
| 				drive: perDay[3], | ||||
| 				network: perDay[4] | ||||
| 			} | ||||
| 		}; | ||||
|  | ||||
| 		this.chart = chart; | ||||
|  | ||||
| 		this.render(); | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		setSrc(src) { | ||||
| 			this.src = src; | ||||
| 		}, | ||||
|  | ||||
| 		render() { | ||||
| 			if (this.chartInstance) { | ||||
| 				this.chartInstance.destroy(); | ||||
| 			} | ||||
|  | ||||
| 			this.chartInstance = new ApexCharts(this.$refs.chart, { | ||||
| 				chart: { | ||||
| 					type: 'area', | ||||
| 					height: 300, | ||||
| 					animations: { | ||||
| 						dynamicAnimation: { | ||||
| 							enabled: false | ||||
| 						} | ||||
| 					}, | ||||
| 					toolbar: { | ||||
| 						show: false | ||||
| 					}, | ||||
| 					zoom: { | ||||
| 						enabled: false | ||||
| 					} | ||||
| 				}, | ||||
| 				dataLabels: { | ||||
| 					enabled: false | ||||
| 				}, | ||||
| 				grid: { | ||||
| 					clipMarkers: false, | ||||
| 					borderColor: 'rgba(0, 0, 0, 0.1)' | ||||
| 				}, | ||||
| 				stroke: { | ||||
| 					curve: 'straight', | ||||
| 					width: 2 | ||||
| 				}, | ||||
| 				legend: { | ||||
| 					labels: { | ||||
| 						color: tinycolor(getComputedStyle(document.documentElement).getPropertyValue('--text')).toRgbString() | ||||
| 					}, | ||||
| 				}, | ||||
| 				xaxis: { | ||||
| 					type: 'datetime', | ||||
| 					labels: { | ||||
| 						style: { | ||||
| 							colors: tinycolor(getComputedStyle(document.documentElement).getPropertyValue('--text')).toRgbString() | ||||
| 						} | ||||
| 					}, | ||||
| 					axisBorder: { | ||||
| 						color: 'rgba(0, 0, 0, 0.1)' | ||||
| 					}, | ||||
| 					axisTicks: { | ||||
| 						color: 'rgba(0, 0, 0, 0.1)' | ||||
| 					}, | ||||
| 				}, | ||||
| 				yaxis: { | ||||
| 					labels: { | ||||
| 						formatter: this.data.bytes ? v => Vue.filter('bytes')(v, 0) : v => Vue.filter('number')(v), | ||||
| 						style: { | ||||
| 							color: tinycolor(getComputedStyle(document.documentElement).getPropertyValue('--text')).toRgbString() | ||||
| 						} | ||||
| 					} | ||||
| 				}, | ||||
| 				series: this.data.series | ||||
| 			}); | ||||
|  | ||||
| 			this.chartInstance.render(); | ||||
| 		}, | ||||
|  | ||||
| 		getDate(i: number) { | ||||
| 			const y = this.now.getFullYear(); | ||||
| 			const m = this.now.getMonth(); | ||||
| 			const d = this.now.getDate(); | ||||
| 			const h = this.now.getHours(); | ||||
|  | ||||
| 			return ( | ||||
| 				this.span == 'day' ? new Date(y, m, d - i) : | ||||
| 				this.span == 'hour' ? new Date(y, m, d, h - i) : | ||||
| 				null | ||||
| 			); | ||||
| 		}, | ||||
|  | ||||
| 		format(arr) { | ||||
| 			return arr.map((v, i) => ({ x: this.getDate(i).getTime(), y: v })); | ||||
| 		}, | ||||
|  | ||||
| 		federationInstancesChart(total: boolean): any { | ||||
| 			return { | ||||
| 				series: [{ | ||||
| 					data: this.format(total | ||||
| 						? this.stats.federation.instance.total | ||||
| 						: sum(this.stats.federation.instance.inc, negate(this.stats.federation.instance.dec)) | ||||
| 					) | ||||
| 				}] | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		notesChart(type: string): any { | ||||
| 			return { | ||||
| 				series: [{ | ||||
| 					name: 'All', | ||||
| 					type: 'line', | ||||
| 					data: this.format(type == 'combined' | ||||
| 						? sum(this.stats.notes.local.inc, negate(this.stats.notes.local.dec), this.stats.notes.remote.inc, negate(this.stats.notes.remote.dec)) | ||||
| 						: sum(this.stats.notes[type].inc, negate(this.stats.notes[type].dec)) | ||||
| 					) | ||||
| 				}, { | ||||
| 					name: 'Renotes', | ||||
| 					type: 'area', | ||||
| 					data: this.format(type == 'combined' | ||||
| 						? sum(this.stats.notes.local.diffs.renote, this.stats.notes.remote.diffs.renote) | ||||
| 						: this.stats.notes[type].diffs.renote | ||||
| 					) | ||||
| 				}, { | ||||
| 					name: 'Replies', | ||||
| 					type: 'area', | ||||
| 					data: this.format(type == 'combined' | ||||
| 						? sum(this.stats.notes.local.diffs.reply, this.stats.notes.remote.diffs.reply) | ||||
| 						: this.stats.notes[type].diffs.reply | ||||
| 					) | ||||
| 				}, { | ||||
| 					name: 'Normal', | ||||
| 					type: 'area', | ||||
| 					data: this.format(type == 'combined' | ||||
| 						? sum(this.stats.notes.local.diffs.normal, this.stats.notes.remote.diffs.normal) | ||||
| 						: this.stats.notes[type].diffs.normal | ||||
| 					) | ||||
| 				}] | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		notesTotalChart(): any { | ||||
| 			return { | ||||
| 				series: [{ | ||||
| 					name: 'Combined', | ||||
| 					data: this.format(sum(this.stats.notes.local.total, this.stats.notes.remote.total)) | ||||
| 				}, { | ||||
| 					name: 'Local', | ||||
| 					data: this.format(this.stats.notes.local.total) | ||||
| 				}, { | ||||
| 					name: 'Remote', | ||||
| 					data: this.format(this.stats.notes.remote.total) | ||||
| 				}] | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		usersChart(total: boolean): any { | ||||
| 			return { | ||||
| 				series: [{ | ||||
| 					name: 'Combined', | ||||
| 					data: this.format(total | ||||
| 						? sum(this.stats.users.local.total, this.stats.users.remote.total) | ||||
| 						: sum(this.stats.users.local.inc, negate(this.stats.users.local.dec), this.stats.users.remote.inc, negate(this.stats.users.remote.dec)) | ||||
| 					) | ||||
| 				}, { | ||||
| 					name: 'Local', | ||||
| 					data: this.format(total | ||||
| 						? this.stats.users.local.total | ||||
| 						: sum(this.stats.users.local.inc, negate(this.stats.users.local.dec)) | ||||
| 					) | ||||
| 				}, { | ||||
| 					name: 'Remote', | ||||
| 					data: this.format(total | ||||
| 						? this.stats.users.remote.total | ||||
| 						: sum(this.stats.users.remote.inc, negate(this.stats.users.remote.dec)) | ||||
| 					) | ||||
| 				}] | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		driveChart(): any { | ||||
| 			return { | ||||
| 				bytes: true, | ||||
| 				series: [{ | ||||
| 					name: 'All', | ||||
| 					data: this.format( | ||||
| 						sum( | ||||
| 							this.stats.drive.local.incSize, | ||||
| 							negate(this.stats.drive.local.decSize), | ||||
| 							this.stats.drive.remote.incSize, | ||||
| 							negate(this.stats.drive.remote.decSize) | ||||
| 						) | ||||
| 					) | ||||
| 				}, { | ||||
| 					name: 'Local +', | ||||
| 					data: this.format(this.stats.drive.local.incSize) | ||||
| 				}, { | ||||
| 					name: 'Local -', | ||||
| 					data: this.format(negate(this.stats.drive.local.decSize)) | ||||
| 				}, { | ||||
| 					name: 'Remote +', | ||||
| 					data: this.format(this.stats.drive.remote.incSize) | ||||
| 				}, { | ||||
| 					name: 'Remote -', | ||||
| 					data: this.format(negate(this.stats.drive.remote.decSize)) | ||||
| 				}] | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		driveTotalChart(): any { | ||||
| 			return { | ||||
| 				bytes: true, | ||||
| 				series: [{ | ||||
| 					name: 'Combined', | ||||
| 					data: this.format(sum(this.stats.drive.local.totalSize, this.stats.drive.remote.totalSize)) | ||||
| 				}, { | ||||
| 					name: 'Local', | ||||
| 					data: this.format(this.stats.drive.local.totalSize) | ||||
| 				}, { | ||||
| 					name: 'Remote', | ||||
| 					data: this.format(this.stats.drive.remote.totalSize) | ||||
| 				}] | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		driveFilesChart(): any { | ||||
| 			return { | ||||
| 				series: [{ | ||||
| 					name: 'All', | ||||
| 					data: this.format( | ||||
| 						sum( | ||||
| 							this.stats.drive.local.incCount, | ||||
| 							negate(this.stats.drive.local.decCount), | ||||
| 							this.stats.drive.remote.incCount, | ||||
| 							negate(this.stats.drive.remote.decCount) | ||||
| 						) | ||||
| 					) | ||||
| 				}, { | ||||
| 					name: 'Local +', | ||||
| 					data: this.format(this.stats.drive.local.incCount) | ||||
| 				}, { | ||||
| 					name: 'Local -', | ||||
| 					data: this.format(negate(this.stats.drive.local.decCount)) | ||||
| 				}, { | ||||
| 					name: 'Remote +', | ||||
| 					data: this.format(this.stats.drive.remote.incCount) | ||||
| 				}, { | ||||
| 					name: 'Remote -', | ||||
| 					data: this.format(negate(this.stats.drive.remote.decCount)) | ||||
| 				}] | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		driveFilesTotalChart(): any { | ||||
| 			return { | ||||
| 				series: [{ | ||||
| 					name: 'Combined', | ||||
| 					data: this.format(sum(this.stats.drive.local.totalCount, this.stats.drive.remote.totalCount)) | ||||
| 				}, { | ||||
| 					name: 'Local', | ||||
| 					data: this.format(this.stats.drive.local.totalCount) | ||||
| 				}, { | ||||
| 					name: 'Remote', | ||||
| 					data: this.format(this.stats.drive.remote.totalCount) | ||||
| 				}] | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		networkRequestsChart(): any { | ||||
| 			return { | ||||
| 				series: [{ | ||||
| 					name: 'Incoming', | ||||
| 					data: this.format(this.stats.network.incomingRequests) | ||||
| 				}] | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		networkTimeChart(): any { | ||||
| 			const data = []; | ||||
|  | ||||
| 			for (let i = 0; i < limit; i++) { | ||||
| 				data.push(this.stats.network.incomingRequests[i] != 0 ? (this.stats.network.totalTime[i] / this.stats.network.incomingRequests[i]) : 0); | ||||
| 			} | ||||
|  | ||||
| 			return { | ||||
| 				series: [{ | ||||
| 					name: 'Avg time', | ||||
| 					data: this.format(data) | ||||
| 				}] | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		networkUsageChart(): any { | ||||
| 			return { | ||||
| 				bytes: true, | ||||
| 				series: [{ | ||||
| 					name: 'Incoming', | ||||
| 					data: this.format(this.stats.network.incomingBytes) | ||||
| 				}, { | ||||
| 					name: 'Outgoing', | ||||
| 					data: this.format(this.stats.network.outgoingBytes) | ||||
| 				}] | ||||
| 			}; | ||||
| 		}, | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .qvgidhudpqhjttdhxubzuyrhyzgslujw | ||||
| 	display block | ||||
| 	flex 1 | ||||
| 	padding 32px 24px | ||||
| 	padding-bottom 0 | ||||
| 	box-shadow 0 2px 4px rgba(0, 0, 0, 0.1) | ||||
| 	background var(--face) | ||||
| 	border-radius 8px | ||||
|  | ||||
| 	> header | ||||
| 		display flex | ||||
| 		margin 0 8px | ||||
| 		padding 0 0 8px 0 | ||||
| 		font-size 1em | ||||
| 		color var(--adminDashboardCardFg) | ||||
| 		border-bottom solid 1px var(--adminDashboardCardDivider) | ||||
|  | ||||
| 		> b | ||||
| 			margin-right 8px | ||||
|  | ||||
| 		> *:last-child | ||||
| 			margin-left auto | ||||
|  | ||||
| 			* | ||||
| 				&:not(.active) | ||||
| 					color var(--primary) | ||||
| 					cursor pointer | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										180
									
								
								src/client/app/admin/views/cpu-memory.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										180
									
								
								src/client/app/admin/views/cpu-memory.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,180 @@ | ||||
| <template> | ||||
| <div class="zyknedwtlthezamcjlolyusmipqmjgxz"> | ||||
| 	<div> | ||||
| 		<header> | ||||
| 			<span>%fa:microchip% CPU <span>{{ cpuP }}%</span></span> | ||||
| 			<span v-if="meta">{{ meta.cpu.model }}</span> | ||||
| 		</header> | ||||
| 		<div ref="cpu"></div> | ||||
| 	</div> | ||||
| 	<div> | ||||
| 		<header> | ||||
| 			<span>%fa:memory% MEM <span>{{ memP }}%</span></span> | ||||
| 			<span v-if="meta"></span> | ||||
| 		</header> | ||||
| 		<div ref="mem"></div> | ||||
| 	</div> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import * as ApexCharts from 'apexcharts'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: ['connection'], | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			stats: [], | ||||
| 			cpuChart: null, | ||||
| 			memChart: null, | ||||
| 			cpuP: '', | ||||
| 			memP: '', | ||||
| 			meta: null | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	watch: { | ||||
| 		stats(stats) { | ||||
| 			this.cpuChart.updateSeries([{ | ||||
| 				data: stats.map((x, i) => ({ x: i, y: x.cpu_usage })) | ||||
| 			}]); | ||||
| 			this.memChart.updateSeries([{ | ||||
| 				data: stats.map((x, i) => ({ x: i, y: (x.mem.used / x.mem.total) })) | ||||
| 			}]); | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	mounted() { | ||||
| 		(this as any).os.getMeta().then(meta => { | ||||
| 			this.meta = meta; | ||||
| 		}); | ||||
|  | ||||
| 		this.connection.on('stats', this.onStats); | ||||
| 		this.connection.on('statsLog', this.onStatsLog); | ||||
| 		this.connection.send('requestLog', { | ||||
| 			id: Math.random().toString().substr(2, 8), | ||||
| 			length: 200 | ||||
| 		}); | ||||
|  | ||||
| 		const chartOpts = { | ||||
| 			chart: { | ||||
| 				type: 'area', | ||||
| 				height: 200, | ||||
| 				animations: { | ||||
| 					dynamicAnimation: { | ||||
| 						enabled: false | ||||
| 					} | ||||
| 				}, | ||||
| 				toolbar: { | ||||
| 					show: false | ||||
| 				}, | ||||
| 				zoom: { | ||||
| 					enabled: false | ||||
| 				} | ||||
| 			}, | ||||
| 			dataLabels: { | ||||
| 				enabled: false | ||||
| 			}, | ||||
| 			grid: { | ||||
| 				clipMarkers: false, | ||||
| 				borderColor: 'rgba(0, 0, 0, 0.1)' | ||||
| 			}, | ||||
| 			stroke: { | ||||
| 				curve: 'straight', | ||||
| 				width: 2 | ||||
| 			}, | ||||
| 			tooltip: { | ||||
| 				enabled: false | ||||
| 			}, | ||||
| 			series: [{ | ||||
| 				data: [] | ||||
| 			}], | ||||
| 			xaxis: { | ||||
| 				type: 'numeric', | ||||
| 				labels: { | ||||
| 					show: false | ||||
| 				}, | ||||
| 				tooltip: { | ||||
| 					enabled: false | ||||
| 				} | ||||
| 			}, | ||||
| 			yaxis: { | ||||
| 				show: false, | ||||
| 				min: 0, | ||||
| 				max: 1 | ||||
| 			} | ||||
| 		}; | ||||
|  | ||||
| 		this.cpuChart = new ApexCharts(this.$refs.cpu, chartOpts); | ||||
| 		this.memChart = new ApexCharts(this.$refs.mem, chartOpts); | ||||
|  | ||||
| 		this.cpuChart.render(); | ||||
| 		this.memChart.render(); | ||||
| 	}, | ||||
|  | ||||
| 	beforeDestroy() { | ||||
| 		this.connection.off('stats', this.onStats); | ||||
| 		this.connection.off('statsLog', this.onStatsLog); | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		onStats(stats) { | ||||
| 			this.stats.push(stats); | ||||
| 			if (this.stats.length > 200) this.stats.shift(); | ||||
|  | ||||
| 			this.cpuP = (stats.cpu_usage * 100).toFixed(0); | ||||
| 			this.memP = (stats.mem.used / stats.mem.total * 100).toFixed(0); | ||||
| 		}, | ||||
|  | ||||
| 		onStatsLog(statsLog) { | ||||
| 			statsLog.reverse().forEach(stats => this.onStats(stats)); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .zyknedwtlthezamcjlolyusmipqmjgxz | ||||
| 	display flex | ||||
|  | ||||
| 	> div | ||||
| 		display block | ||||
| 		flex 1 | ||||
| 		padding 20px 12px 0 12px | ||||
| 		box-shadow 0 2px 4px rgba(0, 0, 0, 0.1) | ||||
| 		background var(--face) | ||||
| 		border-radius 8px | ||||
|  | ||||
| 		&:first-child | ||||
| 			margin-right 16px | ||||
|  | ||||
| 		> header | ||||
| 			display flex | ||||
| 			padding 0 8px | ||||
| 			margin-bottom -16px | ||||
| 			color var(--adminDashboardCardFg) | ||||
| 			font-size 14px | ||||
|  | ||||
| 			> span | ||||
| 				&:last-child | ||||
| 					margin-left auto | ||||
| 					opacity 0.7 | ||||
|  | ||||
| 				> span | ||||
| 					opacity 0.7 | ||||
|  | ||||
| 		> div | ||||
| 			margin-bottom -10px | ||||
|  | ||||
| 	@media (max-width 1000px) | ||||
| 		display block | ||||
| 		margin-bottom 26px | ||||
|  | ||||
| 		> div | ||||
| 			&:first-child | ||||
| 				margin-right 0 | ||||
| 				margin-bottom 26px | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										236
									
								
								src/client/app/admin/views/dashboard.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										236
									
								
								src/client/app/admin/views/dashboard.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,236 @@ | ||||
| <template> | ||||
| <div class="obdskegsannmntldydackcpzezagxqfy"> | ||||
| 	<header v-if="meta"> | ||||
| 		<p><b>Misskey</b><span>{{ meta.version }}</span></p> | ||||
| 		<p><b>Machine</b><span>{{ meta.machine }}</span></p> | ||||
| 		<p><b>OS</b><span>{{ meta.os }}</span></p> | ||||
| 		<p><b>Node</b><span>{{ meta.node }}</span></p> | ||||
| 		<p>%i18n:common.ai-chan-kawaii%</p> | ||||
| 	</header> | ||||
|  | ||||
| 	<div v-if="stats" class="stats"> | ||||
| 		<div> | ||||
| 			<div> | ||||
| 				<div>%fa:user%</div> | ||||
| 				<div> | ||||
| 					<span>%i18n:@accounts%</span> | ||||
| 					<b class="primary">{{ stats.originalUsersCount | number }}</b> | ||||
| 				</div> | ||||
| 			</div> | ||||
| 			<div> | ||||
| 				<span>%fa:home% %i18n:@this-instance%</span> | ||||
| 				<span @click="setChartSrc('users')">%fa:chart-bar R%</span> | ||||
| 			</div> | ||||
| 		</div> | ||||
| 		<div> | ||||
| 			<div> | ||||
| 				<div>%fa:pencil-alt%</div> | ||||
| 				<div> | ||||
| 					<span>%i18n:@notes%</span> | ||||
| 					<b class="primary">{{ stats.originalNotesCount | number }}</b> | ||||
| 				</div> | ||||
| 			</div> | ||||
| 			<div> | ||||
| 				<span>%fa:home% %i18n:@this-instance%</span> | ||||
| 				<span @click="setChartSrc('notes')">%fa:chart-bar R%</span> | ||||
| 			</div> | ||||
| 		</div> | ||||
| 		<div> | ||||
| 			<div> | ||||
| 				<div>%fa:database%</div> | ||||
| 				<div> | ||||
| 					<span>%i18n:@drive%</span> | ||||
| 					<b>{{ stats.driveUsageLocal | bytes }}</b> | ||||
| 				</div> | ||||
| 			</div> | ||||
| 			<div> | ||||
| 				<span>%fa:home% %i18n:@this-instance%</span> | ||||
| 				<span @click="setChartSrc('drive')">%fa:chart-bar R%</span> | ||||
| 			</div> | ||||
| 		</div> | ||||
| 		<div> | ||||
| 			<div> | ||||
| 				<div>%fa:hdd R%</div> | ||||
| 				<div> | ||||
| 					<span>%i18n:@instances%</span> | ||||
| 					<b>{{ stats.instances | number }}</b> | ||||
| 				</div> | ||||
| 			</div> | ||||
| 			<div> | ||||
| 				<span>%fa:globe% %i18n:@federated%</span> | ||||
| 				<span @click="setChartSrc('federation-instances-total')">%fa:chart-bar R%</span> | ||||
| 			</div> | ||||
| 		</div> | ||||
| 	</div> | ||||
|  | ||||
| 	<div class="charts"> | ||||
| 		<x-charts ref="charts"/> | ||||
| 	</div> | ||||
|  | ||||
| 	<div class="cpu-memory"> | ||||
| 		<x-cpu-memory :connection="connection"/> | ||||
| 	</div> | ||||
|  | ||||
| 	<div class="ap"> | ||||
| 		<x-ap-log/> | ||||
| 	</div> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from "vue"; | ||||
| import XCpuMemory from "./cpu-memory.vue"; | ||||
| import XCharts from "./charts.vue"; | ||||
| import XApLog from "./ap-log.vue"; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	components: { | ||||
| 		XCpuMemory, | ||||
| 		XCharts, | ||||
| 		XApLog | ||||
| 	}, | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			stats: null, | ||||
| 			connection: null, | ||||
| 			meta: null | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	created() { | ||||
| 		this.connection = (this as any).os.stream.useSharedConnection('serverStats'); | ||||
|  | ||||
| 		(this as any).os.getMeta().then(meta => { | ||||
| 			this.meta = meta; | ||||
| 		}); | ||||
|  | ||||
| 		(this as any).api('stats').then(stats => { | ||||
| 			this.stats = stats; | ||||
| 		}); | ||||
| 	}, | ||||
|  | ||||
| 	beforeDestroy() { | ||||
| 		this.connection.dispose(); | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		setChartSrc(src) { | ||||
| 			this.$refs.charts.setSrc(src); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .obdskegsannmntldydackcpzezagxqfy | ||||
| 	padding 16px | ||||
|  | ||||
| 	@media (min-width 500px) | ||||
| 		padding 32px | ||||
|  | ||||
| 	> header | ||||
| 		display flex | ||||
| 		margin-bottom 16px | ||||
| 		padding-bottom 16px | ||||
| 		border-bottom solid 1px var(--adminDashboardHeaderBorder) | ||||
| 		color var(--adminDashboardHeaderFg) | ||||
| 		font-size 14px | ||||
| 		white-space nowrap | ||||
|  | ||||
| 		@media (max-width 1000px) | ||||
| 			display none | ||||
|  | ||||
| 		> p | ||||
| 			display block | ||||
| 			margin 0 32px 0 0 | ||||
| 			overflow hidden | ||||
| 			text-overflow ellipsis | ||||
|  | ||||
| 			> b | ||||
| 				&:after | ||||
| 					content ':' | ||||
| 					margin-right 8px | ||||
|  | ||||
| 			&:last-child | ||||
| 				margin-left auto | ||||
| 				margin-right 0 | ||||
|  | ||||
| 	> .stats | ||||
| 		display flex | ||||
| 		justify-content space-between | ||||
| 		margin-bottom 16px | ||||
|  | ||||
| 		> div | ||||
| 			flex 1 | ||||
| 			margin-right 16px | ||||
| 			color var(--adminDashboardCardFg) | ||||
| 			box-shadow 0 2px 4px rgba(0, 0, 0, 0.1) | ||||
| 			background var(--adminDashboardCardBg) | ||||
| 			border-radius 8px | ||||
|  | ||||
| 			&:last-child | ||||
| 				margin-right 0 | ||||
|  | ||||
| 			> div:first-child | ||||
| 				display flex | ||||
| 				align-items center | ||||
| 				text-align center | ||||
|  | ||||
| 				&:last-child | ||||
| 					margin-right 0 | ||||
|  | ||||
| 				> div:first-child | ||||
| 					padding 16px 24px | ||||
| 					font-size 28px | ||||
|  | ||||
| 				> div:last-child | ||||
| 					flex 1 | ||||
| 					padding 16px 32px 16px 0 | ||||
| 					text-align right | ||||
|  | ||||
| 					> span | ||||
| 						font-size 70% | ||||
| 						opacity 0.7 | ||||
|  | ||||
| 					> b | ||||
| 						display block | ||||
|  | ||||
| 						&.primary | ||||
| 							color var(--primary) | ||||
|  | ||||
| 			> div:last-child | ||||
| 				display flex | ||||
| 				padding 6px 16px | ||||
| 				border-top solid 1px var(--adminDashboardCardDivider) | ||||
|  | ||||
| 				> span | ||||
| 					font-size 70% | ||||
| 					opacity 0.7 | ||||
|  | ||||
| 					&:last-child | ||||
| 						margin-left auto | ||||
| 						cursor pointer | ||||
|  | ||||
| 		@media (max-width 900px) | ||||
| 			display grid | ||||
| 			grid-template-columns 1fr 1fr | ||||
| 			grid-template-rows 1fr 1fr | ||||
| 			gap 16px | ||||
|  | ||||
| 			> div | ||||
| 				margin-right 0 | ||||
|  | ||||
| 		@media (max-width 500px) | ||||
| 			display block | ||||
|  | ||||
| 			> div:not(:last-child) | ||||
| 				margin-bottom 16px | ||||
|  | ||||
| 	> .charts | ||||
| 		margin-bottom 16px | ||||
|  | ||||
| 	> .cpu-memory | ||||
| 		margin-bottom 16px | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										117
									
								
								src/client/app/admin/views/emoji.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										117
									
								
								src/client/app/admin/views/emoji.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,117 @@ | ||||
| <template> | ||||
| <div class="tumhkfkmgtvzljezfvmgkeurkfncshbe"> | ||||
| 	<ui-card> | ||||
| 		<div slot="title">%fa:plus% %i18n:@add-emoji.title%</div> | ||||
| 		<section class="fit-top"> | ||||
| 			<ui-horizon-group inputs> | ||||
| 				<ui-input v-model="name"> | ||||
| 					<span>%i18n:@add-emoji.name%</span> | ||||
| 					<span slot="text">%i18n:@add-emoji.name-desc%</span> | ||||
| 				</ui-input> | ||||
| 				<ui-input v-model="aliases"> | ||||
| 					<span>%i18n:@add-emoji.aliases%</span> | ||||
| 					<span slot="text">%i18n:@add-emoji.aliases-desc%</span> | ||||
| 				</ui-input> | ||||
| 			</ui-horizon-group> | ||||
| 			<ui-input v-model="url"> | ||||
| 				<span>%i18n:@add-emoji.url%</span> | ||||
| 			</ui-input> | ||||
| 			<ui-button @click="add">%i18n:@add-emoji.add%</ui-button> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
|  | ||||
| 	<ui-card> | ||||
| 		<div slot="title">%fa:grin R% %i18n:@emojis.title%</div> | ||||
| 		<section v-for="emoji in emojis"> | ||||
| 			<img :src="emoji.url" :alt="emoji.name" style="width: 64px;"/> | ||||
| 			<ui-horizon-group inputs> | ||||
| 				<ui-input v-model="emoji.name"> | ||||
| 					<span>%i18n:@add-emoji.name%</span> | ||||
| 				</ui-input> | ||||
| 				<ui-input v-model="emoji.aliases"> | ||||
| 					<span>%i18n:@add-emoji.aliases%</span> | ||||
| 				</ui-input> | ||||
| 			</ui-horizon-group> | ||||
| 			<ui-input v-model="emoji.url"> | ||||
| 				<span>%i18n:@add-emoji.url%</span> | ||||
| 			</ui-input> | ||||
| 			<ui-horizon-group> | ||||
| 				<ui-button @click="updateEmoji(emoji)">%fa:save R% %i18n:@emojis.update%</ui-button> | ||||
| 				<ui-button @click="removeEmoji(emoji)">%fa:trash-alt R% %i18n:@emojis.remove%</ui-button> | ||||
| 			</ui-horizon-group> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from "vue"; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	data() { | ||||
| 		return { | ||||
| 			name: '', | ||||
| 			url: '', | ||||
| 			aliases: '', | ||||
| 			emojis: [] | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	mounted() { | ||||
| 		this.fetchEmojis(); | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		add() { | ||||
| 			(this as any).api('admin/emoji/add', { | ||||
| 				name: this.name, | ||||
| 				url: this.url, | ||||
| 				aliases: this.aliases.split(' ') | ||||
| 			}).then(() => { | ||||
| 				//(this as any).os.apis.dialog({ text: `Added` }); | ||||
| 				this.fetchEmojis(); | ||||
| 			}).catch(e => { | ||||
| 				//(this as any).os.apis.dialog({ text: `Failed ${e}` }); | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		fetchEmojis() { | ||||
| 			(this as any).api('admin/emoji/list').then(emojis => { | ||||
| 				emojis.forEach(e => e.aliases = (e.aliases || []).join(' ')); | ||||
| 				this.emojis = emojis; | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		updateEmoji(emoji) { | ||||
| 			(this as any).api('admin/emoji/update', { | ||||
| 				id: emoji.id, | ||||
| 				name: emoji.name, | ||||
| 				url: emoji.url, | ||||
| 				aliases: emoji.aliases.split(' ') | ||||
| 			}).then(() => { | ||||
| 				//(this as any).os.apis.dialog({ text: `Updated` }); | ||||
| 			}).catch(e => { | ||||
| 				//(this as any).os.apis.dialog({ text: `Failed ${e}` }); | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		removeEmoji(emoji) { | ||||
| 			(this as any).api('admin/emoji/remove', { | ||||
| 				id: emoji.id | ||||
| 			}).then(() => { | ||||
| 				//(this as any).os.apis.dialog({ text: `Removed` }); | ||||
| 				this.fetchEmojis(); | ||||
| 			}).catch(e => { | ||||
| 				//(this as any).os.apis.dialog({ text: `Failed ${e}` }); | ||||
| 			}); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .tumhkfkmgtvzljezfvmgkeurkfncshbe | ||||
| 	@media (min-width 500px) | ||||
| 		padding 16px | ||||
|  | ||||
| </style> | ||||
| @@ -1,8 +1,12 @@ | ||||
| <template> | ||||
| <div class="jdnqwkzlnxcfftthoybjxrebyolvoucw mk-admin-card"> | ||||
| 	<header>%i18n:@hided-tags%</header> | ||||
| 	<textarea v-model="hidedTags"></textarea> | ||||
| 	<button class="ui" @click="save">%i18n:@save%</button> | ||||
| <div> | ||||
| 	<ui-card> | ||||
| 		<div slot="title">%i18n:@hided-tags%</div> | ||||
| 		<section> | ||||
| 			<textarea class="jdnqwkzlnxcfftthoybjxrebyolvoucw" v-model="hidedTags"></textarea> | ||||
| 			<ui-button @click="save">%i18n:@save%</ui-button> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
| </div> | ||||
| </template> | ||||
| 
 | ||||
| @@ -25,9 +29,9 @@ export default Vue.extend({ | ||||
| 			(this as any).api('admin/update-meta', { | ||||
| 				hidedTags: this.hidedTags.split('\n') | ||||
| 			}).then(() => { | ||||
| 				(this as any).os.apis.dialog({ text: `Saved` }); | ||||
| 				//(this as any).os.apis.dialog({ text: `Saved` }); | ||||
| 			}).catch(e => { | ||||
| 				(this as any).os.apis.dialog({ text: `Failed ${e}` }); | ||||
| 				//(this as any).os.apis.dialog({ text: `Failed ${e}` }); | ||||
| 			}); | ||||
| 		} | ||||
| 	} | ||||
| @@ -35,11 +39,8 @@ export default Vue.extend({ | ||||
| </script> | ||||
| 
 | ||||
| <style lang="stylus" scoped> | ||||
| 
 | ||||
| 
 | ||||
| .jdnqwkzlnxcfftthoybjxrebyolvoucw | ||||
| 	textarea | ||||
| 		width 100% | ||||
| 		min-height 300px | ||||
| 	width 100% | ||||
| 	min-height 300px | ||||
| 
 | ||||
| </style> | ||||
							
								
								
									
										260
									
								
								src/client/app/admin/views/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										260
									
								
								src/client/app/admin/views/index.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,260 @@ | ||||
| <template> | ||||
| <div class="mk-admin" :class="{ isMobile }"> | ||||
| 	<header v-show="isMobile"> | ||||
| 		<button class="nav" @click="navOpend = true">%fa:bars%</button> | ||||
| 		<span>MisskeyMyAdmin</span> | ||||
| 	</header> | ||||
| 	<div class="nav-backdrop" | ||||
| 		v-if="navOpend && isMobile" | ||||
| 		@click="navOpend = false" | ||||
| 		@touchstart="navOpend = false" | ||||
| 	></div> | ||||
| 	<nav v-show="navOpend"> | ||||
| 		<div class="mi"> | ||||
| 			<img svg-inline src="../assets/header-icon.svg"/> | ||||
| 		</div> | ||||
| 		<div class="me"> | ||||
| 			<img class="avatar" :src="$store.state.i.avatarUrl" alt="avatar"/> | ||||
| 			<p class="name">{{ $store.state.i | userName }}</p> | ||||
| 		</div> | ||||
| 		<ul> | ||||
| 			<li @click="nav('dashboard')" :class="{ active: page == 'dashboard' }">%fa:home .fw%%i18n:@dashboard%</li> | ||||
| 			<li @click="nav('instance')" :class="{ active: page == 'instance' }">%fa:cog .fw%%i18n:@instance%</li> | ||||
| 			<li @click="nav('users')" :class="{ active: page == 'users' }">%fa:users .fw%%i18n:@users%</li> | ||||
| 			<li @click="nav('emoji')" :class="{ active: page == 'emoji' }">%fa:grin R .fw%%i18n:@emoji%</li> | ||||
| 			<li @click="nav('announcements')" :class="{ active: page == 'announcements' }">%fa:broadcast-tower .fw%%i18n:@announcements%</li> | ||||
| 			<li @click="nav('hashtags')" :class="{ active: page == 'hashtags' }">%fa:hashtag .fw%%i18n:@hashtags%</li> | ||||
|  | ||||
| 			<!-- <li @click="nav('drive')" :class="{ active: page == 'drive' }">%fa:cloud .fw%%i18n:common.drive%</li> --> | ||||
| 			<!-- <li @click="nav('update')" :class="{ active: page == 'update' }">%i18n:@update%</li> --> | ||||
| 		</ul> | ||||
| 		<div class="back-to-misskey"> | ||||
| 			<a href="/">%fa:arrow-left% %i18n:@back-to-misskey%</a> | ||||
| 		</div> | ||||
| 		<div class="version"> | ||||
| 			<small>Misskey {{ version }}</small> | ||||
| 		</div> | ||||
| 	</nav> | ||||
| 	<main> | ||||
| 		<div v-show="page == 'dashboard'"><x-dashboard/></div> | ||||
| 		<div v-show="page == 'instance'"><x-instance/></div> | ||||
| 		<div v-if="page == 'users'"><x-users/></div> | ||||
| 		<div v-show="page == 'emoji'"><x-emoji/></div> | ||||
| 		<div v-show="page == 'announcements'"><x-announcements/></div> | ||||
| 		<div v-show="page == 'hashtags'"><x-hashtags/></div> | ||||
| 		<div v-if="page == 'drive'"></div> | ||||
| 		<div v-if="page == 'update'"></div> | ||||
| 	</main> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from "vue"; | ||||
| import { version } from '../../config'; | ||||
| import XDashboard from "./dashboard.vue"; | ||||
| import XInstance from "./instance.vue"; | ||||
| import XEmoji from "./emoji.vue"; | ||||
| import XAnnouncements from "./announcements.vue"; | ||||
| import XHashtags from "./hashtags.vue"; | ||||
| import XUsers from "./users.vue"; | ||||
|  | ||||
| // Detect the user agent | ||||
| const ua = navigator.userAgent.toLowerCase(); | ||||
| const isMobile = /mobile|iphone|ipad|android/.test(ua); | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	components: { | ||||
| 		XDashboard, | ||||
| 		XInstance, | ||||
| 		XEmoji, | ||||
| 		XAnnouncements, | ||||
| 		XHashtags, | ||||
| 		XUsers | ||||
| 	}, | ||||
| 	provide: { | ||||
| 		isMobile | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| 			page: 'dashboard', | ||||
| 			version, | ||||
| 			isMobile, | ||||
| 			navOpend: !isMobile | ||||
| 		}; | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		nav(page: string) { | ||||
| 			this.page = page; | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus"> | ||||
| .mk-admin | ||||
| 	$headerHeight = 48px | ||||
|  | ||||
| 	display flex | ||||
| 	height 100% | ||||
|  | ||||
| 	> header | ||||
| 		position fixed | ||||
| 		top 0 | ||||
| 		z-index 10000 | ||||
| 		width 100% | ||||
| 		color var(--mobileHeaderFg) | ||||
| 		background-color var(--mobileHeaderBg) | ||||
| 		box-shadow 0 1px 0 rgba(#000, 0.075) | ||||
|  | ||||
| 		&, * | ||||
| 			user-select none | ||||
|  | ||||
| 		> span | ||||
| 			display block | ||||
| 			line-height $headerHeight | ||||
| 			text-align center | ||||
|  | ||||
| 		> .nav | ||||
| 			display block | ||||
| 			position absolute | ||||
| 			top 0 | ||||
| 			left 0 | ||||
| 			z-index 10001 | ||||
| 			padding 0 | ||||
| 			width $headerHeight | ||||
| 			font-size 1.4em | ||||
| 			line-height $headerHeight | ||||
| 			border-right solid 1px rgba(#000, 0.1) | ||||
|  | ||||
| 			> [data-fa] | ||||
| 				transition all 0.2s ease | ||||
|  | ||||
| 	> nav | ||||
| 		position fixed | ||||
| 		z-index 20001 | ||||
| 		top 0 | ||||
| 		left 0 | ||||
| 		width 250px | ||||
| 		height 100vh | ||||
| 		overflow auto | ||||
| 		background #333 | ||||
| 		color #fff | ||||
|  | ||||
| 		> .mi | ||||
| 			text-align center | ||||
|  | ||||
| 			> svg | ||||
| 				width 24px | ||||
| 				height 82px | ||||
| 				vertical-align top | ||||
| 				fill #fff | ||||
| 				opacity 0.7 | ||||
|  | ||||
| 		> .me | ||||
| 			display flex | ||||
| 			margin 0 16px 16px 16px | ||||
| 			padding 16px 0 | ||||
| 			align-items center | ||||
| 			border-top solid 1px #555 | ||||
| 			border-bottom solid 1px #555 | ||||
|  | ||||
| 			> .avatar | ||||
| 				height 48px | ||||
| 				border-radius 100% | ||||
| 				vertical-align middle | ||||
|  | ||||
| 			> .name | ||||
| 				margin 0 16px | ||||
| 				padding 0 | ||||
| 				color #fff | ||||
| 				overflow hidden | ||||
| 				text-overflow ellipsis | ||||
| 				white-space nowrap | ||||
| 				font-size 15px | ||||
|  | ||||
| 		> .back-to-misskey | ||||
| 			margin 16px 16px 0 16px | ||||
| 			padding 0 | ||||
| 			border-top solid 1px #555 | ||||
|  | ||||
| 			> a | ||||
| 				display block | ||||
| 				padding 16px 4px | ||||
| 				color inherit | ||||
| 				text-decoration none | ||||
| 				color #eee | ||||
| 				font-size 15px | ||||
|  | ||||
| 				&:hover | ||||
| 					color #fff | ||||
|  | ||||
| 				> [data-fa] | ||||
| 					margin-right 6px | ||||
|  | ||||
| 		> .version | ||||
| 			margin 0 16px 16px 16px | ||||
| 			padding-top 16px | ||||
| 			border-top solid 1px #555 | ||||
| 			text-align center | ||||
|  | ||||
| 			> small | ||||
| 				opacity 0.7 | ||||
|  | ||||
| 		> ul | ||||
| 			margin 0 | ||||
| 			padding 0 | ||||
| 			list-style none | ||||
| 			font-size 15px | ||||
|  | ||||
| 			> li | ||||
| 				display block | ||||
| 				padding 10px 16px | ||||
| 				margin 0 | ||||
| 				cursor pointer | ||||
| 				user-select none | ||||
| 				color #eee | ||||
| 				transition margin-left 0.2s ease | ||||
|  | ||||
| 				&:hover | ||||
| 					color #fff | ||||
|  | ||||
| 				> [data-fa] | ||||
| 					margin-right 6px | ||||
|  | ||||
| 				&.active | ||||
| 					margin-left 8px | ||||
| 					color var(--primary) !important | ||||
|  | ||||
| 					&:after | ||||
| 						content "" | ||||
| 						display block | ||||
| 						position absolute | ||||
| 						top 0 | ||||
| 						right 0 | ||||
| 						bottom 0 | ||||
| 						margin auto 0 | ||||
| 						height 0 | ||||
| 						border-top solid 16px transparent | ||||
| 						border-right solid 16px var(--bg) | ||||
| 						border-bottom solid 16px transparent | ||||
| 						border-left solid 16px transparent | ||||
|  | ||||
| 	> .nav-backdrop | ||||
| 		position fixed | ||||
| 		top 0 | ||||
| 		left 0 | ||||
| 		z-index 20000 | ||||
| 		width 100% | ||||
| 		height 100% | ||||
| 		background var(--mobileNavBackdrop) | ||||
|  | ||||
| 	> main | ||||
| 		width 100% | ||||
| 		padding 0 0 0 250px | ||||
| 		max-width 1300px | ||||
|  | ||||
| 	&.isMobile | ||||
| 		> main | ||||
| 			padding $headerHeight 0 0 0 | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										85
									
								
								src/client/app/admin/views/instance.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										85
									
								
								src/client/app/admin/views/instance.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,85 @@ | ||||
| <template> | ||||
| <div class="axbwjelsbymowqjyywpirzhdlszoncqs"> | ||||
| 	<ui-card> | ||||
| 		<div slot="title">%fa:cog% %i18n:@instance%</div> | ||||
| 		<section class="fit-top"> | ||||
| 			<ui-input v-model="name">%i18n:@instance-name%</ui-input> | ||||
| 			<ui-textarea v-model="description">%i18n:@instance-description%</ui-textarea> | ||||
| 			<ui-input v-model="bannerUrl">%i18n:@banner-url%</ui-input> | ||||
| 			<ui-button @click="updateMeta">%i18n:@save%</ui-button> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
|  | ||||
| 	<ui-card> | ||||
| 		<div slot="title">%i18n:@disable-registration%</div> | ||||
| 		<section> | ||||
| 			<input type="checkbox" v-model="disableRegistration" @change="updateMeta"> | ||||
| 			<button class="ui" @click="invite">%i18n:@invite%</button> | ||||
| 			<p v-if="inviteCode">Code: <code>{{ inviteCode }}</code></p> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
|  | ||||
| 	<ui-card> | ||||
| 		<div slot="title">%i18n:@disable-local-timeline%</div> | ||||
| 		<section> | ||||
| 			<input type="checkbox" v-model="disableLocalTimeline" @change="updateMeta"> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from "vue"; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	data() { | ||||
| 		return { | ||||
| 			disableRegistration: false, | ||||
| 			disableLocalTimeline: false, | ||||
| 			bannerUrl: null, | ||||
| 			name: null, | ||||
| 			description: null, | ||||
| 			inviteCode: null, | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	created() { | ||||
| 		(this as any).os.getMeta().then(meta => { | ||||
| 			this.bannerUrl = meta.bannerUrl; | ||||
| 			this.name = meta.name; | ||||
| 			this.description = meta.description; | ||||
| 		}); | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		invite() { | ||||
| 			(this as any).api('admin/invite').then(x => { | ||||
| 				this.inviteCode = x.code; | ||||
| 			}).catch(e => { | ||||
| 				//(this as any).os.apis.dialog({ text: `Failed ${e}` }); | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		updateMeta() { | ||||
| 			(this as any).api('admin/update-meta', { | ||||
| 				disableRegistration: this.disableRegistration, | ||||
| 				disableLocalTimeline: this.disableLocalTimeline, | ||||
| 				bannerUrl: this.bannerUrl, | ||||
| 				name: this.name, | ||||
| 				description: this.description | ||||
| 			}).then(() => { | ||||
| 				//(this as any).os.apis.dialog({ text: `Saved` }); | ||||
| 			}).catch(e => { | ||||
| 				//(this as any).os.apis.dialog({ text: `Failed ${e}` }); | ||||
| 			}); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .axbwjelsbymowqjyywpirzhdlszoncqs | ||||
| 	@media (min-width 500px) | ||||
| 		padding 16px | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										136
									
								
								src/client/app/admin/views/users.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										136
									
								
								src/client/app/admin/views/users.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,136 @@ | ||||
| <template> | ||||
| <div class="ucnffhbtogqgscfmqcymwmmupoknpfsw"> | ||||
| 	<ui-card> | ||||
| 		<div slot="title">%i18n:@verify-user%</div> | ||||
| 		<section class="fit-top"> | ||||
| 			<ui-input v-model="verifyUsername" type="text"> | ||||
| 				<span slot="prefix">@</span> | ||||
| 			</ui-input> | ||||
| 			<ui-button @click="verifyUser" :disabled="verifying">%i18n:@verify%</ui-button> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
|  | ||||
| 	<ui-card> | ||||
| 		<div slot="title">%i18n:@unverify-user%</div> | ||||
| 		<section class="fit-top"> | ||||
| 			<ui-input v-model="unverifyUsername" type="text"> | ||||
| 				<span slot="prefix">@</span> | ||||
| 			</ui-input> | ||||
| 			<ui-button @click="unverifyUser" :disabled="unverifying">%i18n:@unverify%</ui-button> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
|  | ||||
| 	<ui-card> | ||||
| 		<div slot="title">%i18n:@suspend-user%</div> | ||||
| 		<section class="fit-top"> | ||||
| 			<ui-input v-model="suspendUsername" type="text"> | ||||
| 				<span slot="prefix">@</span> | ||||
| 			</ui-input> | ||||
| 			<ui-button @click="suspendUser" :disabled="suspending">%i18n:@suspend%</ui-button> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
|  | ||||
| 	<ui-card> | ||||
| 		<div slot="title">%i18n:@unsuspend-user%</div> | ||||
| 		<section class="fit-top"> | ||||
| 			<ui-input v-model="unsuspendUsername" type="text"> | ||||
| 				<span slot="prefix">@</span> | ||||
| 			</ui-input> | ||||
| 			<ui-button @click="unsuspendUser" :disabled="unsuspending">%i18n:@unsuspend%</ui-button> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from "vue"; | ||||
| import parseAcct from "../../../../misc/acct/parse"; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	data() { | ||||
| 		return { | ||||
| 			verifyUsername: null, | ||||
| 			verifying: false, | ||||
| 			unverifyUsername: null, | ||||
| 			unverifying: false, | ||||
| 			suspendUsername: null, | ||||
| 			suspending: false, | ||||
| 			unsuspendUsername: null, | ||||
| 			unsuspending: false | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		async verifyUser() { | ||||
| 			this.verifying = true; | ||||
|  | ||||
| 			const process = async () => { | ||||
| 				const user = await (this as any).os.api('users/show', parseAcct(this.verifyUsername)); | ||||
| 				await (this as any).os.api('admin/verify-user', { userId: user.id }); | ||||
| 				//(this as any).os.apis.dialog({ text: '%i18n:@verified%' }); | ||||
| 			}; | ||||
|  | ||||
| 			await process().catch(e => { | ||||
| 				//(this as any).os.apis.dialog({ text: `Failed: ${e}` }); | ||||
| 			}); | ||||
|  | ||||
| 			this.verifying = false; | ||||
| 		}, | ||||
|  | ||||
| 		async unverifyUser() { | ||||
| 			this.unverifying = true; | ||||
|  | ||||
| 			const process = async () => { | ||||
| 				const user = await (this as any).os.api('users/show', parseAcct(this.unverifyUsername)); | ||||
| 				await (this as any).os.api('admin/unverify-user', { userId: user.id }); | ||||
| 				//(this as any).os.apis.dialog({ text: '%i18n:@unverified%' }); | ||||
| 			}; | ||||
|  | ||||
| 			await process().catch(e => { | ||||
| 				//(this as any).os.apis.dialog({ text: `Failed: ${e}` }); | ||||
| 			}); | ||||
|  | ||||
| 			this.unverifying = false; | ||||
| 		}, | ||||
|  | ||||
| 		async suspendUser() { | ||||
| 			this.suspending = true; | ||||
|  | ||||
| 			const process = async () => { | ||||
| 				const user = await (this as any).os.api('users/show', parseAcct(this.suspendUsername)); | ||||
| 				await (this as any).os.api('admin/suspend-user', { userId: user.id }); | ||||
| 				//(this as any).os.apis.dialog({ text: '%i18n:@suspended%' }); | ||||
| 			}; | ||||
|  | ||||
| 			await process().catch(e => { | ||||
| 				//(this as any).os.apis.dialog({ text: `Failed: ${e}` }); | ||||
| 			}); | ||||
|  | ||||
| 			this.suspending = false; | ||||
| 		}, | ||||
|  | ||||
| 		async unsuspendUser() { | ||||
| 			this.unsuspending = true; | ||||
|  | ||||
| 			const process = async () => { | ||||
| 				const user = await (this as any).os.api('users/show', parseAcct(this.unsuspendUsername)); | ||||
| 				await (this as any).os.api('admin/unsuspend-user', { userId: user.id }); | ||||
| 				//(this as any).os.apis.dialog({ text: '%i18n:@unsuspended%' }); | ||||
| 			}; | ||||
|  | ||||
| 			await process().catch(e => { | ||||
| 				//(this as any).os.apis.dialog({ text: `Failed: ${e}` }); | ||||
| 			}); | ||||
|  | ||||
| 			this.unsuspending = false; | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .ucnffhbtogqgscfmqcymwmmupoknpfsw | ||||
| 	@media (min-width 500px) | ||||
| 		padding 16px | ||||
|  | ||||
| </style> | ||||
| @@ -46,6 +46,7 @@ | ||||
| 	if (`${url.pathname}/`.startsWith('/docs/')) app = 'docs'; | ||||
| 	if (`${url.pathname}/`.startsWith('/dev/')) app = 'dev'; | ||||
| 	if (`${url.pathname}/`.startsWith('/auth/')) app = 'auth'; | ||||
| 	if (`${url.pathname}/`.startsWith('/admin/')) app = 'admin'; | ||||
| 	//#endregion | ||||
|  | ||||
| 	//#region Detect the user language | ||||
| @@ -142,7 +143,7 @@ | ||||
| 		localStorage.setItem('shouldFlush', 'false'); | ||||
|  | ||||
| 		// Random | ||||
| 		localStorage.setItem('salt', Math.random().toString()); | ||||
| 		localStorage.setItem('salt', Math.random().toString().substr(2, 8)); | ||||
|  | ||||
| 		// Clear cache (service worker) | ||||
| 		try { | ||||
|   | ||||
| @@ -46,6 +46,16 @@ const getKeyMap = keymap => Object.entries(keymap).map(([patterns, callback]): a | ||||
|  | ||||
| const ignoreElemens = ['input', 'textarea']; | ||||
|  | ||||
| function match(e: KeyboardEvent, patterns: action['patterns']): boolean { | ||||
| 	const key = e.code.toLowerCase(); | ||||
| 	return patterns.some(pattern => pattern.which.includes(key) && | ||||
| 		pattern.ctrl == e.ctrlKey && | ||||
| 		pattern.shift == e.shiftKey && | ||||
| 		pattern.alt == e.altKey && | ||||
| 		e.metaKey == false | ||||
| 	); | ||||
| } | ||||
|  | ||||
| export default { | ||||
| 	install(Vue) { | ||||
| 		Vue.directive('hotkey', { | ||||
| @@ -55,37 +65,27 @@ export default { | ||||
| 				const actions = getKeyMap(binding.value); | ||||
|  | ||||
| 				// flatten | ||||
| 				const reservedKeys = concat(concat(actions.map(a => a.patterns.map(p => p.which)))); | ||||
| 				const reservedKeys = concat(actions.map(a => a.patterns)); | ||||
|  | ||||
| 				el.dataset.reservedKeys = reservedKeys.map(key => `'${key}'`).join(' '); | ||||
| 				el._misskey_reservedKeys = reservedKeys; | ||||
|  | ||||
| 				el._keyHandler = (e: KeyboardEvent) => { | ||||
| 					const key = e.code.toLowerCase(); | ||||
|  | ||||
| 					const targetReservedKeys = document.activeElement ? ((document.activeElement as any).dataset || {}).reservedKeys || '' : ''; | ||||
| 					const targetReservedKeys = document.activeElement ? ((document.activeElement as any)._misskey_reservedKeys || []) : []; | ||||
| 					if (document.activeElement && ignoreElemens.some(el => document.activeElement.matches(el))) return; | ||||
|  | ||||
| 					for (const action of actions) { | ||||
| 						if (el._hotkey_global && targetReservedKeys.includes(`'${key}'`)) break; | ||||
|  | ||||
| 						const matched = action.patterns.some(pattern => { | ||||
| 							const matched = pattern.which.includes(key) && | ||||
| 								pattern.ctrl == e.ctrlKey && | ||||
| 								pattern.shift == e.shiftKey && | ||||
| 								pattern.alt == e.altKey && | ||||
| 								e.metaKey == false; | ||||
|  | ||||
| 							if (matched) { | ||||
| 								e.preventDefault(); | ||||
| 								e.stopPropagation(); | ||||
| 								action.callback(e); | ||||
| 								return true; | ||||
| 							} else { | ||||
| 								return false; | ||||
| 							} | ||||
| 						}); | ||||
| 						const matched = match(e, action.patterns); | ||||
|  | ||||
| 						if (matched) { | ||||
| 							if (el._hotkey_global) { | ||||
| 								if (match(e, targetReservedKeys)) { | ||||
| 									return; | ||||
| 								} | ||||
| 							} | ||||
|  | ||||
| 							e.preventDefault(); | ||||
| 							e.stopPropagation(); | ||||
| 							action.callback(e); | ||||
| 							break; | ||||
| 						} | ||||
| 					} | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| import MiOS from '../../mios'; | ||||
| import { version as current } from '../../config'; | ||||
| import { clientVersion as current } from '../../config'; | ||||
|  | ||||
| export default async function(mios: MiOS, force = false, silent = false) { | ||||
| 	const meta = await mios.getMeta(force); | ||||
|   | ||||
| @@ -1,7 +1,8 @@ | ||||
| import parse from '../../../../mfm/parse'; | ||||
| import { sum } from '../../../../prelude/array'; | ||||
| import MkNoteMenu from '..//views/components/note-menu.vue'; | ||||
| import MkNoteMenu from '../views/components/note-menu.vue'; | ||||
| import MkReactionPicker from '../views/components/reaction-picker.vue'; | ||||
| import Ok from '../views/components/ok.vue'; | ||||
|  | ||||
| function focus(el, fn) { | ||||
| 	const target = fn(el); | ||||
| @@ -28,10 +29,12 @@ export default (opts: Opts = {}) => ({ | ||||
| 	computed: { | ||||
| 		keymap(): any { | ||||
| 			return { | ||||
| 				'r|left': () => this.reply(true), | ||||
| 				'r': () => this.reply(true), | ||||
| 				'e|a|plus': () => this.react(true), | ||||
| 				'q|right': () => this.renote(true), | ||||
| 				'ctrl+q|ctrl+right': this.renoteDirectly, | ||||
| 				'q': () => this.renote(true), | ||||
| 				'f|b': this.favorite, | ||||
| 				'delete|ctrl+d': this.del, | ||||
| 				'ctrl+q': this.renoteDirectly, | ||||
| 				'up|k|shift+tab': this.focusBefore, | ||||
| 				'down|j|tab': this.focusAfter, | ||||
| 				'esc': this.blur, | ||||
| @@ -129,6 +132,20 @@ export default (opts: Opts = {}) => ({ | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		favorite() { | ||||
| 			(this as any).api('notes/favorites/create', { | ||||
| 				noteId: this.appearNote.id | ||||
| 			}).then(() => { | ||||
| 				(this as any).os.new(Ok); | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		del() { | ||||
| 			(this as any).api('notes/delete', { | ||||
| 				noteId: this.appearNote.id | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		menu(viaKeyboard = false) { | ||||
| 			(this as any).os.new(MkNoteMenu, { | ||||
| 				source: this.$refs.menuButton, | ||||
|   | ||||
| @@ -9,7 +9,7 @@ import MiOS from '../../mios'; | ||||
|  */ | ||||
| export default class Stream extends EventEmitter { | ||||
| 	private stream: ReconnectingWebsocket; | ||||
| 	private state: string; | ||||
| 	public state: string; | ||||
| 	private sharedConnectionPools: Pool[] = []; | ||||
| 	private sharedConnections: SharedConnection[] = []; | ||||
| 	private nonSharedConnections: NonSharedConnection[] = []; | ||||
| @@ -156,7 +156,7 @@ class Pool { | ||||
| 		this.channel = channel; | ||||
| 		this.stream = stream; | ||||
|  | ||||
| 		this.id = Math.random().toString(); | ||||
| 		this.id = Math.random().toString().substr(2, 8); | ||||
|  | ||||
| 		this.stream.on('_disconnected_', this.onStreamDisconnected); | ||||
| 	} | ||||
| @@ -275,7 +275,7 @@ class NonSharedConnection extends Connection { | ||||
| 		super(stream, channel); | ||||
|  | ||||
| 		this.params = params; | ||||
| 		this.id = Math.random().toString(); | ||||
| 		this.id = Math.random().toString().substr(2, 8); | ||||
|  | ||||
| 		this.connect(); | ||||
| 	} | ||||
|   | ||||
							
								
								
									
										72
									
								
								src/client/app/common/views/components/api-settings.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										72
									
								
								src/client/app/common/views/components/api-settings.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,72 @@ | ||||
| <template> | ||||
| <ui-card> | ||||
| 	<div slot="title">%fa:key% API</div> | ||||
|  | ||||
| 	<section class="fit-top"> | ||||
| 		<ui-input :value="$store.state.i.token" readonly> | ||||
| 			<span>%i18n:@token%</span> | ||||
| 		</ui-input> | ||||
| 		<p>%i18n:@intro%</p> | ||||
| 		<ui-info warn>%i18n:@caution%</ui-info> | ||||
| 		<p>%i18n:@regeneration-of-token%</p> | ||||
| 		<ui-button @click="regenerateToken">%fa:sync-alt% %i18n:@regenerate-token%</ui-button> | ||||
| 	</section> | ||||
|  | ||||
| 	<section> | ||||
| 		<header>%fa:terminal% %i18n:@console.title%</header> | ||||
| 		<ui-input v-model="endpoint"> | ||||
| 			<span>%i18n:@console.endpoint%</span> | ||||
| 		</ui-input> | ||||
| 		<ui-textarea v-model="body"> | ||||
| 			<span>%i18n:@console.parameter% (JSON or JSON5)</span> | ||||
| 		</ui-textarea> | ||||
| 		<ui-button @click="send" :disabled="sending"> | ||||
| 			<template v-if="sending">%i18n:@console.sending%</template> | ||||
| 			<template v-else>%fa:paper-plane% %i18n:@console.send%</template> | ||||
| 		</ui-button> | ||||
| 		<ui-textarea v-if="res" v-model="res" readonly tall> | ||||
| 			<span>%i18n:@console.response%</span> | ||||
| 		</ui-textarea> | ||||
| 	</section> | ||||
| </ui-card> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import * as JSON5 from 'json5'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	data() { | ||||
| 		return { | ||||
| 			endpoint: '', | ||||
| 			body: '{}', | ||||
| 			res: null, | ||||
| 			sending: false | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		regenerateToken() { | ||||
| 			(this as any).apis.input({ | ||||
| 				title: '%i18n:@enter-password%', | ||||
| 				type: 'password' | ||||
| 			}).then(password => { | ||||
| 				(this as any).api('i/regenerate_token', { | ||||
| 					password: password | ||||
| 				}); | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		send() { | ||||
| 			this.sending = true; | ||||
| 			(this as any).api(this.endpoint, JSON5.parse(this.body)).then(res => { | ||||
| 				this.sending = false; | ||||
| 				this.res = JSON5.stringify(res, null, 2); | ||||
| 			}, err => { | ||||
| 				this.sending = false; | ||||
| 				this.res = JSON5.stringify(err, null, 2); | ||||
| 			}); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
| @@ -14,9 +14,10 @@ | ||||
| 	</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> | ||||
| 			<span class="emoji" v-if="emoji.url"><img :src="emoji.url" :alt="emoji.emoji"/></span> | ||||
| 			<span class="emoji" v-else>{{ emoji.emoji }}</span> | ||||
| 			<span class="name" v-html="emoji.name.replace(q, `<b>${q}</b>`)"></span> | ||||
| 			<span class="alias" v-if="emoji.alias">({{ emoji.alias }})</span> | ||||
| 			<span class="alias" v-if="emoji.aliasOf">({{ emoji.aliasOf }})</span> | ||||
| 		</li> | ||||
| 	</ol> | ||||
| </div> | ||||
| @@ -27,14 +28,21 @@ import Vue from 'vue'; | ||||
| import * as emojilib from 'emojilib'; | ||||
| import contains from '../../../common/scripts/contains'; | ||||
|  | ||||
| type EmojiDef = { | ||||
| 	emoji: string; | ||||
| 	name: string; | ||||
| 	aliasOf?: string; | ||||
| 	url?: string; | ||||
| }; | ||||
|  | ||||
| const lib = Object.entries(emojilib.lib).filter((x: any) => { | ||||
| 	return x[1].category != 'flags'; | ||||
| }); | ||||
|  | ||||
| const emjdb = lib.map((x: any) => ({ | ||||
| const emjdb: EmojiDef[] = lib.map((x: any) => ({ | ||||
| 	emoji: x[1].char, | ||||
| 	name: x[0], | ||||
| 	alias: null | ||||
| 	aliasOf: null | ||||
| })); | ||||
|  | ||||
| lib.forEach((x: any) => { | ||||
| @@ -43,7 +51,7 @@ lib.forEach((x: any) => { | ||||
| 			emjdb.push({ | ||||
| 				emoji: x[1].char, | ||||
| 				name: k, | ||||
| 				alias: x[0] | ||||
| 				aliasOf: x[0] | ||||
| 			}); | ||||
| 		}); | ||||
| 	} | ||||
| @@ -61,7 +69,8 @@ export default Vue.extend({ | ||||
| 			hashtags: [], | ||||
| 			emojis: [], | ||||
| 			select: -1, | ||||
| 			emojilib | ||||
| 			emojilib, | ||||
| 			emojiDb: [] as EmojiDef[] | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| @@ -90,6 +99,34 @@ export default Vue.extend({ | ||||
| 	}, | ||||
|  | ||||
| 	mounted() { | ||||
| 		//#region Construct Emoji DB | ||||
| 		const customEmojis = (this.os.getMetaSync() || { emojis: [] }).emojis || []; | ||||
| 		const emojiDefinitions: EmojiDef[] = []; | ||||
|  | ||||
| 		customEmojis.forEach(x => { | ||||
| 			emojiDefinitions.push({ | ||||
| 				name: x.name, | ||||
| 				emoji: `:${x.name}:`, | ||||
| 				url: x.url | ||||
| 			}); | ||||
|  | ||||
| 			if (x.aliases) { | ||||
| 				x.aliases.forEach(alias => { | ||||
| 					emojiDefinitions.push({ | ||||
| 						name: alias, | ||||
| 						aliasOf: x.name, | ||||
| 						emoji: `:${x.name}:`, | ||||
| 						url: x.url | ||||
| 					}); | ||||
| 				}); | ||||
| 			} | ||||
| 		}); | ||||
|  | ||||
| 		emojiDefinitions.sort((a, b) => a.name.length - b.name.length); | ||||
|  | ||||
| 		this.emojiDb = emojiDefinitions.concat(emjdb); | ||||
| 		//#endregion | ||||
|  | ||||
| 		this.textarea.addEventListener('keydown', this.onKeydown); | ||||
|  | ||||
| 		Array.from(document.querySelectorAll('body *')).forEach(el => { | ||||
| @@ -169,22 +206,25 @@ export default Vue.extend({ | ||||
| 				} | ||||
| 			} else if (this.type == 'emoji') { | ||||
| 				const matched = []; | ||||
| 				emjdb.some(x => { | ||||
| 					if (x.name.indexOf(this.q) == 0 && !x.alias && !matched.some(y => y.emoji == x.emoji)) matched.push(x); | ||||
| 					return matched.length == 30; | ||||
| 				const max = 30; | ||||
|  | ||||
| 				this.emojiDb.some(x => { | ||||
| 					if (x.name.startsWith(this.q) && !x.aliasOf && !matched.some(y => y.emoji == x.emoji)) matched.push(x); | ||||
| 					return matched.length == max; | ||||
| 				}); | ||||
| 				if (matched.length < 30) { | ||||
| 					emjdb.some(x => { | ||||
| 						if (x.name.indexOf(this.q) == 0 && !matched.some(y => y.emoji == x.emoji)) matched.push(x); | ||||
| 						return matched.length == 30; | ||||
| 				if (matched.length < max) { | ||||
| 					this.emojiDb.some(x => { | ||||
| 						if (x.name.startsWith(this.q) && !matched.some(y => y.emoji == x.emoji)) matched.push(x); | ||||
| 						return matched.length == max; | ||||
| 					}); | ||||
| 				} | ||||
| 				if (matched.length < 30) { | ||||
| 					emjdb.some(x => { | ||||
| 						if (x.name.indexOf(this.q) > -1 && !matched.some(y => y.emoji == x.emoji)) matched.push(x); | ||||
| 						return matched.length == 30; | ||||
| 				if (matched.length < max) { | ||||
| 					this.emojiDb.some(x => { | ||||
| 						if (x.name.includes(this.q) && !matched.some(y => y.emoji == x.emoji)) matched.push(x); | ||||
| 						return matched.length == max; | ||||
| 					}); | ||||
| 				} | ||||
|  | ||||
| 				this.emojis = matched; | ||||
| 			} | ||||
| 		}, | ||||
| @@ -340,6 +380,10 @@ export default Vue.extend({ | ||||
| 			margin 0 4px 0 0 | ||||
| 			width 24px | ||||
|  | ||||
| 			> img | ||||
| 				width 24px | ||||
| 				vertical-align bottom | ||||
|  | ||||
| 		.name | ||||
| 			color var(--autocompleteItemText) | ||||
|  | ||||
|   | ||||
							
								
								
									
										171
									
								
								src/client/app/common/views/components/drive-settings.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										171
									
								
								src/client/app/common/views/components/drive-settings.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,171 @@ | ||||
| <template> | ||||
| <ui-card> | ||||
| 	<div slot="title">%fa:cloud% %i18n:common.drive%</div> | ||||
|  | ||||
| 	<section v-if="!fetching" class="juakhbxthdewydyreaphkepoxgxvfogn"> | ||||
| 		<div class="meter"><div :style="meterStyle"></div></div> | ||||
| 		<p>%i18n:@max%: <b>{{ capacity | bytes }}</b> %i18n:@in-use%: <b>{{ usage | bytes }}</b></p> | ||||
| 	</section> | ||||
|  | ||||
| 	<section> | ||||
| 		<header>%i18n:@stats%</header> | ||||
| 		<div ref="chart" style="margin-bottom: -16px; color: #000;"></div> | ||||
| 	</section> | ||||
| </ui-card> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import * as tinycolor from 'tinycolor2'; | ||||
| import * as ApexCharts from 'apexcharts'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	data() { | ||||
| 		return { | ||||
| 			fetching: true, | ||||
| 			usage: null, | ||||
| 			capacity: null | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	computed: { | ||||
| 		meterStyle(): any { | ||||
| 			return { | ||||
| 				width: `${this.usage / this.capacity * 100}%`, | ||||
| 				background: tinycolor({ | ||||
| 					h: 180 - (this.usage / this.capacity * 180), | ||||
| 					s: 0.7, | ||||
| 					l: 0.5 | ||||
| 				}) | ||||
| 			}; | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	mounted() { | ||||
| 		(this as any).api('drive').then(info => { | ||||
| 			this.capacity = info.capacity; | ||||
| 			this.usage = info.usage; | ||||
| 			this.fetching = false; | ||||
|  | ||||
| 			this.$nextTick(() => { | ||||
| 				this.renderChart(); | ||||
| 			}); | ||||
| 		}); | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		renderChart() { | ||||
| 			(this as any).api('charts/user/drive', { | ||||
| 				userId: this.$store.state.i.id, | ||||
| 				span: 'day', | ||||
| 				limit: 21 | ||||
| 			}).then(stats => { | ||||
| 				const addition = []; | ||||
| 				const deletion = []; | ||||
|  | ||||
| 				const now = new Date(); | ||||
| 				const y = now.getFullYear(); | ||||
| 				const m = now.getMonth(); | ||||
| 				const d = now.getDate(); | ||||
|  | ||||
| 				for (let i = 0; i < 21; i++) { | ||||
| 					const x = new Date(y, m, d - i); | ||||
| 					addition.push([ | ||||
| 						x, | ||||
| 						stats.incSize[i] | ||||
| 					]); | ||||
| 					deletion.push([ | ||||
| 						x, | ||||
| 						-stats.decSize[i] | ||||
| 					]); | ||||
| 				} | ||||
|  | ||||
| 				const chart = new ApexCharts(this.$refs.chart, { | ||||
| 					chart: { | ||||
| 						type: 'bar', | ||||
| 						stacked: true, | ||||
| 						height: 150, | ||||
| 						zoom: { | ||||
| 							enabled: false | ||||
| 						} | ||||
| 					}, | ||||
| 					plotOptions: { | ||||
| 						bar: { | ||||
| 							columnWidth: '90%', | ||||
| 							endingShape: 'rounded' | ||||
| 						} | ||||
| 					}, | ||||
| 					grid: { | ||||
| 						clipMarkers: false, | ||||
| 						borderColor: 'rgba(0, 0, 0, 0.1)' | ||||
| 					}, | ||||
| 					tooltip: { | ||||
| 						shared: true, | ||||
| 						intersect: false | ||||
| 					}, | ||||
| 					dataLabels: { | ||||
| 						enabled: false | ||||
| 					}, | ||||
| 					legend: { | ||||
| 						show: false | ||||
| 					}, | ||||
| 					series: [{ | ||||
| 						name: 'Additions', | ||||
| 						data: addition | ||||
| 					}, { | ||||
| 						name: 'Deletions', | ||||
| 						data: deletion | ||||
| 					}], | ||||
| 					xaxis: { | ||||
| 						type: 'datetime', | ||||
| 						labels: { | ||||
| 							style: { | ||||
| 								colors: tinycolor(getComputedStyle(document.documentElement).getPropertyValue('--text')).toRgbString() | ||||
| 							} | ||||
| 						}, | ||||
| 						axisBorder: { | ||||
| 							color: 'rgba(0, 0, 0, 0.1)' | ||||
| 						}, | ||||
| 						axisTicks: { | ||||
| 							color: 'rgba(0, 0, 0, 0.1)' | ||||
| 						}, | ||||
| 						crosshairs: { | ||||
| 							width: 1, | ||||
| 							opacity: 1 | ||||
| 						} | ||||
| 					}, | ||||
| 					yaxis: { | ||||
| 						labels: { | ||||
| 							formatter: v => Vue.filter('bytes')(v, 0), | ||||
| 							style: { | ||||
| 								color: tinycolor(getComputedStyle(document.documentElement).getPropertyValue('--text')).toRgbString() | ||||
| 							} | ||||
| 						} | ||||
| 					} | ||||
| 				}); | ||||
|  | ||||
| 				chart.render(); | ||||
| 			}); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .juakhbxthdewydyreaphkepoxgxvfogn | ||||
| 	> .meter | ||||
| 		$size = 12px | ||||
|  | ||||
| 		margin-bottom 16px | ||||
| 		background rgba(0, 0, 0, 0.1) | ||||
| 		border-radius ($size / 2) | ||||
| 		overflow hidden | ||||
|  | ||||
| 		> div | ||||
| 			height $size | ||||
| 			border-radius ($size / 2) | ||||
|  | ||||
| 	> p | ||||
| 		margin 0 | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										19
									
								
								src/client/app/common/views/components/error.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								src/client/app/common/views/components/error.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | ||||
| <template> | ||||
| <div class="wjqjnyhzogztorhrdgcpqlkxhkmuetgj"> | ||||
| 	<p>%fa:exclamation-triangle% %i18n:common.error.title%</p> | ||||
| 	<ui-button @click="() => $emit('retry')">%i18n:common.error.retry%</ui-button> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .wjqjnyhzogztorhrdgcpqlkxhkmuetgj | ||||
| 	max-width 350px | ||||
| 	margin 0 auto | ||||
| 	padding 32px | ||||
| 	text-align center | ||||
| 	color var(--text) | ||||
|  | ||||
| 	> p | ||||
| 		margin 0 0 8px 0 | ||||
|  | ||||
| </style> | ||||
| @@ -1,5 +1,5 @@ | ||||
| <template> | ||||
| <a class="a" href="https://github.com/syuilo/misskey" target="_blank" title="View source on Github"> | ||||
| <a class="a" href="https://github.com/syuilo/misskey" target="_blank" title="View source on GitHub"> | ||||
| 	<svg width="80" height="80" viewBox="0 0 250 250" aria-hidden="aria-hidden"> | ||||
| 		<path d="M0,0 L115,115 L130,115 L142,142 L250,250 L250,0 Z"></path> | ||||
| 		<path class="octo-arm" d="M128.3,109.0 C113.8,99.7 119.0,89.6 119.0,89.6 C122.0,82.7 120.5,78.6 120.5,78.6 C119.2,72.0 123.4,76.3 123.4,76.3 C127.3,80.9 125.5,87.3 125.5,87.3 C122.9,97.6 130.6,101.9 134.4,103.2" fill="currentColor"></path> | ||||
|   | ||||
							
								
								
									
										63
									
								
								src/client/app/common/views/components/github-setting.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										63
									
								
								src/client/app/common/views/components/github-setting.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,63 @@ | ||||
| <template> | ||||
| <div class="mk-github-setting"> | ||||
| 	<p>%i18n:@description%<a :href="`${docsUrl}/link-to-github`" target="_blank">%i18n:@detail%</a></p> | ||||
| 	<p class="account" v-if="$store.state.i.github" :title="`GitHub ID: ${$store.state.i.github.id}`">%i18n:@connected-to%: <a :href="`https://github.com/${$store.state.i.github.login}`" target="_blank">@{{ $store.state.i.github.login }}</a></p> | ||||
| 	<p> | ||||
| 		<a :href="`${apiUrl}/connect/github`" target="_blank" @click.prevent="connect">{{ $store.state.i.github ? '%i18n:@reconnect%' : '%i18n:@connect%' }}</a> | ||||
| 		<span v-if="$store.state.i.github"> or </span> | ||||
| 		<a :href="`${apiUrl}/disconnect/github`" target="_blank" v-if="$store.state.i.github" @click.prevent="disconnect">%i18n:@disconnect%</a> | ||||
| 	</p> | ||||
| 	<p class="id" v-if="$store.state.i.github">GitHub ID: {{ $store.state.i.github.id }}</p> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { apiUrl, docsUrl } from '../../../config'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	data() { | ||||
| 		return { | ||||
| 			form: null, | ||||
| 			apiUrl, | ||||
| 			docsUrl | ||||
| 		}; | ||||
| 	}, | ||||
| 	mounted() { | ||||
| 		this.$watch('$store.state.i', () => { | ||||
| 			if (this.$store.state.i.github && this.form) | ||||
| 				this.form.close(); | ||||
| 		}, { | ||||
| 			deep: true | ||||
| 		}); | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		connect() { | ||||
| 			this.form = window.open(apiUrl + '/connect/github', | ||||
| 				'github_connect_window', | ||||
| 				'height=570, width=520'); | ||||
| 		}, | ||||
|  | ||||
| 		disconnect() { | ||||
| 			window.open(apiUrl + '/disconnect/github', | ||||
| 				'github_disconnect_window', | ||||
| 				'height=570, width=520'); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .mk-github-setting | ||||
| 	.account | ||||
| 		border solid 1px #e1e8ed | ||||
| 		border-radius 4px | ||||
| 		padding 16px | ||||
|  | ||||
| 		a | ||||
| 			font-weight bold | ||||
| 			color inherit | ||||
|  | ||||
| 	.id | ||||
| 		color #8899a6 | ||||
| </style> | ||||
| @@ -1,5 +1,12 @@ | ||||
| import Vue from 'vue'; | ||||
|  | ||||
| import muteAndBlock from './mute-and-block.vue'; | ||||
| import error from './error.vue'; | ||||
| import apiSettings from './api-settings.vue'; | ||||
| import passwordSettings from './password-settings.vue'; | ||||
| import driveSettings from './drive-settings.vue'; | ||||
| import profileEditor from './profile-editor.vue'; | ||||
| import noteSkeleton from './note-skeleton.vue'; | ||||
| import theme from './theme.vue'; | ||||
| import instance from './instance.vue'; | ||||
| import cwButton from './cw-button.vue'; | ||||
| @@ -30,20 +37,30 @@ import messaging from './messaging.vue'; | ||||
| import messagingRoom from './messaging-room.vue'; | ||||
| import urlPreview from './url-preview.vue'; | ||||
| import twitterSetting from './twitter-setting.vue'; | ||||
| import githubSetting from './github-setting.vue'; | ||||
| import fileTypeIcon from './file-type-icon.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 uiHorizonGroup from './ui/horizon-group.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'; | ||||
| import uiInfo from './ui/info.vue'; | ||||
| import formButton from './ui/form/button.vue'; | ||||
| import formRadio from './ui/form/radio.vue'; | ||||
|  | ||||
| Vue.component('mk-mute-and-block', muteAndBlock); | ||||
| Vue.component('mk-error', error); | ||||
| Vue.component('mk-api-settings', apiSettings); | ||||
| Vue.component('mk-password-settings', passwordSettings); | ||||
| Vue.component('mk-drive-settings', driveSettings); | ||||
| Vue.component('mk-profile-editor', profileEditor); | ||||
| Vue.component('mk-note-skeleton', noteSkeleton); | ||||
| Vue.component('mk-theme', theme); | ||||
| Vue.component('mk-instance', instance); | ||||
| Vue.component('mk-cw-button', cwButton); | ||||
| @@ -74,16 +91,19 @@ Vue.component('mk-messaging', messaging); | ||||
| Vue.component('mk-messaging-room', messagingRoom); | ||||
| Vue.component('mk-url-preview', urlPreview); | ||||
| Vue.component('mk-twitter-setting', twitterSetting); | ||||
| Vue.component('mk-github-setting', githubSetting); | ||||
| Vue.component('mk-file-type-icon', fileTypeIcon); | ||||
| Vue.component('mk-reversi', Reversi); | ||||
| Vue.component('mk-welcome-timeline', welcomeTimeline); | ||||
| Vue.component('ui-input', uiInput); | ||||
| Vue.component('ui-button', uiButton); | ||||
| Vue.component('ui-horizon-group', uiHorizonGroup); | ||||
| 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); | ||||
| Vue.component('ui-info', uiInfo); | ||||
| Vue.component('form-button', formButton); | ||||
| Vue.component('form-radio', formRadio); | ||||
|   | ||||
| @@ -354,7 +354,7 @@ export default Vue.extend({ | ||||
| 		max-width 600px | ||||
| 		margin 0 auto | ||||
| 		padding 0 | ||||
| 		//background rgba(var(--face), 0.95) | ||||
| 		background var(--messagingRoomBg) | ||||
| 		background-clip content-box | ||||
|  | ||||
| 		> .new-message | ||||
|   | ||||
| @@ -3,7 +3,6 @@ import * as emojilib from 'emojilib'; | ||||
| import { length } from 'stringz'; | ||||
| 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'; | ||||
| import { concat } from '../../../../../prelude/array'; | ||||
| @@ -25,6 +24,9 @@ export default Vue.component('misskey-flavored-markdown', { | ||||
| 		i: { | ||||
| 			type: Object, | ||||
| 			default: null | ||||
| 		}, | ||||
| 		customEmojis: { | ||||
| 			required: false, | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| @@ -114,25 +116,23 @@ export default Vue.component('misskey-flavored-markdown', { | ||||
| 				} | ||||
|  | ||||
| 				case 'mention': { | ||||
| 					return (createElement as any)('a', { | ||||
| 					return (createElement as any)('router-link', { | ||||
| 						attrs: { | ||||
| 							href: `${url}/@${getAcct(token)}`, | ||||
| 							target: '_blank', | ||||
| 							to: `/${token.canonical}`, | ||||
| 							dataIsMe: (this as any).i && getAcct((this as any).i) == getAcct(token), | ||||
| 							style: 'color:var(--mfmMention);' | ||||
| 						}, | ||||
| 						directives: [{ | ||||
| 							name: 'user-preview', | ||||
| 							value: token.content | ||||
| 							value: token.canonical | ||||
| 						}] | ||||
| 					}, token.content); | ||||
| 					}, token.canonical); | ||||
| 				} | ||||
|  | ||||
| 				case 'hashtag': { | ||||
| 					return [createElement('a', { | ||||
| 					return [createElement('router-link', { | ||||
| 						attrs: { | ||||
| 							href: `${url}/tags/${encodeURIComponent(token.hashtag)}`, | ||||
| 							target: '_blank', | ||||
| 							to: `/tags/${encodeURIComponent(token.hashtag)}`, | ||||
| 							style: 'color:var(--mfmHashtag);' | ||||
| 						} | ||||
| 					}, token.content)]; | ||||
| @@ -188,6 +188,22 @@ export default Vue.component('misskey-flavored-markdown', { | ||||
| 				} | ||||
|  | ||||
| 				case 'emoji': { | ||||
| 					//#region カスタム絵文字 | ||||
| 					if (this.customEmojis != null) { | ||||
| 						const customEmoji = this.customEmojis.find(e => e.name == token.emoji || (e.aliases || []).includes(token.emoji)); | ||||
| 						if (customEmoji) { | ||||
| 							return [createElement('img', { | ||||
| 								attrs: { | ||||
| 									src: customEmoji.url, | ||||
| 									alt: token.emoji, | ||||
| 									title: token.emoji, | ||||
| 									style: 'height: 2.5em; vertical-align: middle;' | ||||
| 								} | ||||
| 							})]; | ||||
| 						} | ||||
| 					} | ||||
| 					//#endregion | ||||
|  | ||||
| 					const emoji = emojilib.lib[token.emoji]; | ||||
| 					return [createElement('span', emoji ? emoji.char : token.content)]; | ||||
| 				} | ||||
|   | ||||
							
								
								
									
										52
									
								
								src/client/app/common/views/components/mute-and-block.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								src/client/app/common/views/components/mute-and-block.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,52 @@ | ||||
| <template> | ||||
| <ui-card> | ||||
| 	<div slot="title">%fa:ban% %i18n:@mute-and-block%</div> | ||||
|  | ||||
| 	<section> | ||||
| 		<header>%i18n:@mute%</header> | ||||
| 		<ui-info v-if="!muteFetching && mute.length == 0">%i18n:@no-muted-users%</ui-info> | ||||
| 		<div class="users" v-if="mute.length != 0"> | ||||
| 			<div v-for="user in mute" :key="user.id"> | ||||
| 				<p><b>{{ user | userName }}</b> @{{ user | acct }}</p> | ||||
| 			</div> | ||||
| 		</div> | ||||
| 	</section> | ||||
|  | ||||
| 	<section> | ||||
| 		<header>%i18n:@block%</header> | ||||
| 		<ui-info v-if="!blockFetching && block.length == 0">%i18n:@no-blocked-users%</ui-info> | ||||
| 		<div class="users" v-if="block.length != 0"> | ||||
| 			<div v-for="user in block" :key="user.id"> | ||||
| 				<p><b>{{ user | userName }}</b> @{{ user | acct }}</p> | ||||
| 			</div> | ||||
| 		</div> | ||||
| 	</section> | ||||
| </ui-card> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	data() { | ||||
| 		return { | ||||
| 			muteFetching: true, | ||||
| 			blockFetching: true, | ||||
| 			mute: [], | ||||
| 			block: [] | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	mounted() { | ||||
| 		(this as any).api('mute/list').then(mute => { | ||||
| 			this.mute = mute.map(x => x.mutee); | ||||
| 			this.muteFetching = false; | ||||
| 		}); | ||||
|  | ||||
| 		(this as any).api('blocking/list').then(blocking => { | ||||
| 			this.block = blocking.map(x => x.blockee); | ||||
| 			this.blockFetching = false; | ||||
| 		}); | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
| @@ -2,8 +2,6 @@ | ||||
| <span class="mk-nav"> | ||||
| 	<a :href="aboutUrl">%i18n:@about%</a> | ||||
| 	<i>・</i> | ||||
| 	<a href="/stats">%i18n:@stats%</a> | ||||
| 	<i>・</i> | ||||
| 	<a :href="repositoryUrl">%i18n:@repository%</a> | ||||
| 	<i>・</i> | ||||
| 	<a :href="feedbackUrl" target="_blank">%i18n:@feedback%</a> | ||||
|   | ||||
| @@ -2,11 +2,11 @@ | ||||
| <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:star%</span> | ||||
| 	<span class="is-admin" v-if="note.user.isAdmin">admin</span> | ||||
| 	<span class="is-bot" v-if="note.user.isBot">bot</span> | ||||
| 	<span class="is-cat" v-if="note.user.isCat">cat</span> | ||||
| 	<span class="username"><mk-acct :user="note.user"/></span> | ||||
| 	<span class="is-verified" v-if="note.user.isVerified" title="%i18n:common.verified-user%">%fa:star%</span> | ||||
| 	<div class="info"> | ||||
| 		<span class="app" v-if="note.app && !mini">via <b>{{ note.app.name }}</b></span> | ||||
| 		<span class="mobile" v-if="note.viaMobile">%fa:mobile-alt%</span> | ||||
| @@ -68,10 +68,6 @@ export default Vue.extend({ | ||||
| 		&:hover | ||||
| 			text-decoration underline | ||||
|  | ||||
| 	> .is-verified | ||||
| 		margin-right 8px | ||||
| 		color #4dabf7 | ||||
|  | ||||
| 	> .is-admin | ||||
| 	> .is-bot | ||||
| 	> .is-cat | ||||
| @@ -95,6 +91,10 @@ export default Vue.extend({ | ||||
| 		color var(--noteHeaderAcct) | ||||
| 		flex-shrink 2147483647 | ||||
|  | ||||
| 	> .is-verified | ||||
| 		margin 0 .5em 0 0 | ||||
| 		color #4dabf7 | ||||
|  | ||||
| 	> .info | ||||
| 		margin-left auto | ||||
| 		font-size 0.9em | ||||
|   | ||||
| @@ -22,7 +22,19 @@ export default Vue.extend({ | ||||
| 				icon: '%fa:link%', | ||||
| 				text: '%i18n:@copy-link%', | ||||
| 				action: this.copyLink | ||||
| 			}, null]; | ||||
| 			}]; | ||||
|  | ||||
| 			if (this.note.uri) { | ||||
| 				items.push({ | ||||
| 					icon: '%fa:external-link-square-alt%', | ||||
| 					text: '%i18n:@remote%', | ||||
| 					action: () => { | ||||
| 						window.open(this.note.uri, '_blank'); | ||||
| 					} | ||||
| 				}); | ||||
| 			} | ||||
|  | ||||
| 			items.push(null); | ||||
|  | ||||
| 			if (this.note.isFavorited) { | ||||
| 				items.push({ | ||||
| @@ -63,16 +75,6 @@ export default Vue.extend({ | ||||
| 				}); | ||||
| 			} | ||||
|  | ||||
| 			if (this.note.uri) { | ||||
| 				items.push({ | ||||
| 					icon: '%fa:external-link-square-alt%', | ||||
| 					text: '%i18n:@remote%', | ||||
| 					action: () => { | ||||
| 						window.open(this.note.uri, '_blank'); | ||||
| 					} | ||||
| 				}); | ||||
| 			} | ||||
|  | ||||
| 			return items; | ||||
| 		} | ||||
| 	}, | ||||
|   | ||||
							
								
								
									
										52
									
								
								src/client/app/common/views/components/note-skeleton.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								src/client/app/common/views/components/note-skeleton.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,52 @@ | ||||
| <template> | ||||
| <div> | ||||
| 	<vue-content-loading v-if="width" :width="width" :height="100" :primary="primary" :secondary="secondary"> | ||||
| 		<circle cx="30" cy="30" r="30" /> | ||||
| 		<rect x="75" y="13" rx="4" ry="4" :width="150 + r1" height="15" /> | ||||
| 		<rect x="75" y="39" rx="4" ry="4" :width="260 + r2" height="10" /> | ||||
| 		<rect x="75" y="59" rx="4" ry="4" :width="230 + r3" height="10" /> | ||||
| 	</vue-content-loading> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import VueContentLoading from 'vue-content-loading'; | ||||
| import * as tinycolor from 'tinycolor2'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	components: { | ||||
| 		VueContentLoading, | ||||
| 	}, | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			width: 0, | ||||
| 			r1: (Math.random() * 100) - 50, | ||||
| 			r2: (Math.random() * 100) - 50, | ||||
| 			r3: (Math.random() * 100) - 50 | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	computed: { | ||||
| 		text(): tinycolor.Instance { | ||||
| 			const text = tinycolor(getComputedStyle(document.documentElement).getPropertyValue('--text')); | ||||
| 			return text; | ||||
| 		}, | ||||
|  | ||||
| 		primary(): string { | ||||
| 			return '#' + this.text.clone().toHex(); | ||||
| 		}, | ||||
|  | ||||
| 		secondary(): string { | ||||
| 			return '#' + this.text.clone().darken(20).toHex(); | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	mounted() { | ||||
| 		let width = this.$el.clientWidth; | ||||
| 		if (width < 400) width = 400; | ||||
| 		this.width = width; | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
| @@ -1,6 +1,6 @@ | ||||
| <template> | ||||
| <div> | ||||
| 	<button @click="reset" class="ui primary">%i18n:@reset%</button> | ||||
| 	<ui-button @click="reset">%i18n:@reset%</ui-button> | ||||
| </div> | ||||
| </template> | ||||
| 
 | ||||
| @@ -49,6 +49,7 @@ | ||||
| 
 | ||||
| 		<div> | ||||
| 			<ui-switch v-model="isCat" @change="save(false)">%i18n:@is-cat%</ui-switch> | ||||
| 			<ui-switch v-model="isBot" @change="save(false)">%i18n:@is-bot%</ui-switch> | ||||
| 			<ui-switch v-model="alwaysMarkNsfw">%i18n:common.always-mark-nsfw%</ui-switch> | ||||
| 		</div> | ||||
| 	</section> | ||||
| @@ -58,6 +59,7 @@ | ||||
| 
 | ||||
| 		<div> | ||||
| 			<ui-switch v-model="isLocked" @change="save(false)">%i18n:@is-locked%</ui-switch> | ||||
| 			<ui-switch v-model="carefulBot" @change="save(false)">%i18n:@careful-bot%</ui-switch> | ||||
| 		</div> | ||||
| 	</section> | ||||
| </ui-card> | ||||
| @@ -65,7 +67,7 @@ | ||||
| 
 | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { apiUrl, host } from '../../../../config'; | ||||
| import { apiUrl, host } from '../../../config'; | ||||
| 
 | ||||
| export default Vue.extend({ | ||||
| 	data() { | ||||
| @@ -79,7 +81,9 @@ export default Vue.extend({ | ||||
| 			avatarId: null, | ||||
| 			bannerId: null, | ||||
| 			isCat: false, | ||||
| 			isBot: false, | ||||
| 			isLocked: false, | ||||
| 			carefulBot: false, | ||||
| 			saving: false, | ||||
| 			avatarUploading: false, | ||||
| 			bannerUploading: false | ||||
| @@ -102,7 +106,9 @@ export default Vue.extend({ | ||||
| 		this.avatarId = this.$store.state.i.avatarId; | ||||
| 		this.bannerId = this.$store.state.i.bannerId; | ||||
| 		this.isCat = this.$store.state.i.isCat; | ||||
| 		this.isBot = this.$store.state.i.isBot; | ||||
| 		this.isLocked = this.$store.state.i.isLocked; | ||||
| 		this.carefulBot = this.$store.state.i.carefulBot; | ||||
| 	}, | ||||
| 
 | ||||
| 	methods: { | ||||
| @@ -161,7 +167,9 @@ export default Vue.extend({ | ||||
| 				avatarId: this.avatarId, | ||||
| 				bannerId: this.bannerId, | ||||
| 				isCat: this.isCat, | ||||
| 				isLocked: this.isLocked | ||||
| 				isBot: this.isBot, | ||||
| 				isLocked: this.isLocked, | ||||
| 				carefulBot: this.carefulBot | ||||
| 			}).then(i => { | ||||
| 				this.saving = false; | ||||
| 				this.$store.state.i.avatarId = i.avatarId; | ||||
| @@ -13,6 +13,7 @@ | ||||
| 	<ui-input v-if="user && user.twoFactorEnabled" v-model="token" type="number" required styl="fill"/> | ||||
| 	<ui-button type="submit" :disabled="signing">{{ signing ? '%i18n:@signing-in%' : '%i18n:@signin%' }}</ui-button> | ||||
| 	<p style="margin: 8px 0;">%i18n:@or% <a :href="`${apiUrl}/signin/twitter`">%i18n:@signin-with-twitter%</a></p> | ||||
| 	<p style="margin: 8px 0;">%i18n:@or% <a :href="`${apiUrl}/signin/github`">%i18n:@signin-with-github%</a></p> | ||||
| </form> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -1,5 +1,10 @@ | ||||
| <template> | ||||
| <component class="dmtdnykelhudezerjlfpbhgovrgnqqgr" :is="link ? 'a' : 'button'" :class="[styl, { inline, primary }]" :type="type" @click="$emit('click')"> | ||||
| <component class="dmtdnykelhudezerjlfpbhgovrgnqqgr" | ||||
| 	:is="link ? 'a' : 'button'" | ||||
| 	:class="[styl, { inline, primary }]" | ||||
| 	:type="type" | ||||
| 	@click="$emit('click')" | ||||
| > | ||||
| 	<slot></slot> | ||||
| </component> | ||||
| </template> | ||||
| @@ -7,6 +12,7 @@ | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| export default Vue.extend({ | ||||
| 	inject: ['horizonGrouped'], | ||||
| 	props: { | ||||
| 		type: { | ||||
| 			type: String, | ||||
| @@ -20,7 +26,9 @@ export default Vue.extend({ | ||||
| 		inline: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 			default(): boolean { | ||||
| 				return this.horizonGrouped; | ||||
| 			} | ||||
| 		}, | ||||
| 		link: { | ||||
| 			type: Boolean, | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| <template> | ||||
| <div class="ui-card"> | ||||
| <div class="ui-card" :class="{ shadow: $store.state.settings.useShadow }"> | ||||
| 	<header> | ||||
| 		<slot name="title"></slot> | ||||
| 	</header> | ||||
| @@ -24,7 +24,10 @@ export default Vue.extend({ | ||||
| 	margin 16px | ||||
| 	color var(--faceText) | ||||
| 	background var(--face) | ||||
| 	box-shadow 0 3px 1px -2px rgba(#000, 0.2), 0 2px 2px 0 rgba(#000, 0.14), 0 1px 5px 0 rgba(#000, 0.12) | ||||
| 	border-radius var(--round) | ||||
|  | ||||
| 	&.shadow | ||||
| 		box-shadow 0 3px 1px -2px rgba(#000, 0.2), 0 2px 2px 0 rgba(#000, 0.14), 0 1px 5px 0 rgba(#000, 0.12) | ||||
|  | ||||
| 	> header | ||||
| 		padding 16px | ||||
|   | ||||
							
								
								
									
										35
									
								
								src/client/app/common/views/components/ui/horizon-group.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								src/client/app/common/views/components/ui/horizon-group.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | ||||
| <template> | ||||
| <div class="pfzekjfwkwvadvlujpdnnxfggqgqjoze" :class="{ inputs }"> | ||||
| 	<slot></slot> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| export default Vue.extend({ | ||||
| 	provide: { | ||||
| 		horizonGrouped: true | ||||
| 	}, | ||||
| 	props: { | ||||
| 		inputs: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .pfzekjfwkwvadvlujpdnnxfggqgqjoze | ||||
| 	display flex | ||||
|  | ||||
| 	&.inputs | ||||
| 		margin 32px 0 | ||||
|  | ||||
| 	> * | ||||
| 		flex 1 | ||||
|  | ||||
| 		&:not(:last-child) | ||||
| 			margin-right 16px | ||||
| </style> | ||||
							
								
								
									
										43
									
								
								src/client/app/common/views/components/ui/info.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								src/client/app/common/views/components/ui/info.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,43 @@ | ||||
| <template> | ||||
| <div class="ymxyweixqwsxauxldgpvecjepnwxbylu" :class="{ warn }"> | ||||
| 	<i v-if="warn">%fa:exclamation-triangle%</i> | ||||
| 	<i v-else>%fa:info-circle%</i> | ||||
| 	<slot></slot> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| export default Vue.extend({ | ||||
| 	props: { | ||||
| 		warn: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		}, | ||||
| 	}, | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .ymxyweixqwsxauxldgpvecjepnwxbylu | ||||
| 	margin 16px 0 | ||||
| 	padding 16px | ||||
| 	font-size 90% | ||||
| 	background var(--infoBg) | ||||
| 	color var(--infoFg) | ||||
|  | ||||
| 	&.warn | ||||
| 		background var(--infoWarnBg) | ||||
| 		color var(--infoWarnFg) | ||||
|  | ||||
| 	&:first-child | ||||
| 		margin-top 0 | ||||
|  | ||||
| 	&:last-child | ||||
| 		margin-bottom 0 | ||||
|  | ||||
| 	> i | ||||
| 		margin-right 4px | ||||
|  | ||||
| </style> | ||||
| @@ -1,5 +1,5 @@ | ||||
| <template> | ||||
| <div class="ui-input" :class="[{ focused, filled }, styl]"> | ||||
| <div class="ui-input" :class="[{ focused, filled, inline }, 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"> | ||||
| @@ -41,6 +41,7 @@ import Vue from 'vue'; | ||||
| const getPasswordStrength = require('syuilo-password-strength'); | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	inject: ['horizonGrouped'], | ||||
| 	props: { | ||||
| 		value: { | ||||
| 			required: false | ||||
| @@ -72,6 +73,13 @@ export default Vue.extend({ | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		}, | ||||
| 		inline: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default(): boolean { | ||||
| 				return this.horizonGrouped; | ||||
| 			} | ||||
| 		}, | ||||
| 		styl: { | ||||
| 			type: String, | ||||
| 			required: false, | ||||
| @@ -122,17 +130,19 @@ export default Vue.extend({ | ||||
| 		} | ||||
| 	}, | ||||
| 	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'; | ||||
| 		this.$nextTick(() => { | ||||
| 			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'; | ||||
| 			if (this.$refs.suffix) { | ||||
| 				if (this.$refs.suffix.offsetWidth) { | ||||
| 					this.$refs.input.style.paddingRight = this.$refs.suffix.offsetWidth + 'px'; | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 		}); | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		focus() { | ||||
| @@ -335,4 +345,8 @@ root(fill) | ||||
| 	&:not(.fill) | ||||
| 		root(false) | ||||
|  | ||||
| 	&.inline | ||||
| 		display inline-block | ||||
| 		margin 0 | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -1,17 +1,17 @@ | ||||
| <template> | ||||
| <div class="ui-textarea" :class="{ focused, filled }"> | ||||
| <div class="ui-textarea" :class="{ focused, filled, tall }"> | ||||
| 	<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> | ||||
| 			: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> | ||||
| @@ -41,7 +41,12 @@ export default Vue.extend({ | ||||
| 		autocomplete: { | ||||
| 			type: String, | ||||
| 			required: false | ||||
| 		} | ||||
| 		}, | ||||
| 		tall: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		}, | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| @@ -66,6 +71,9 @@ export default Vue.extend({ | ||||
| root(fill) | ||||
| 	margin 42px 0 32px 0 | ||||
|  | ||||
| 	&:last-child | ||||
| 		margin-bottom 0 | ||||
|  | ||||
| 	> .input | ||||
| 		padding 12px | ||||
|  | ||||
| @@ -157,6 +165,11 @@ root(fill) | ||||
| 				left 0 !important | ||||
| 				transform scale(0.75) | ||||
|  | ||||
| 	&.tall | ||||
| 		> .input | ||||
| 			> textarea | ||||
| 				min-height 200px | ||||
|  | ||||
| .ui-textarea.fill | ||||
| 	root(true) | ||||
|  | ||||
|   | ||||
| @@ -14,7 +14,7 @@ | ||||
| 					</div> | ||||
| 				</header> | ||||
| 				<div class="text"> | ||||
| 					<misskey-flavored-markdown v-if="note.text" :text="note.text"/> | ||||
| 					<misskey-flavored-markdown v-if="note.text" :text="note.text" :customEmojis="note.emojis"/> | ||||
| 				</div> | ||||
| 			</div> | ||||
| 		</div> | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| import * as getCaretCoordinates from 'textarea-caret'; | ||||
| import MkAutocomplete from '../components/autocomplete.vue'; | ||||
| import renderAcct from '../../../../../misc/acct/render'; | ||||
| import { toASCII } from 'punycode'; | ||||
|  | ||||
| export default { | ||||
| 	bind(el, binding, vn) { | ||||
| @@ -188,7 +188,7 @@ class Autocomplete { | ||||
| 			const trimmedBefore = before.substring(0, before.lastIndexOf('@')); | ||||
| 			const after = source.substr(caret); | ||||
|  | ||||
| 			const acct = renderAcct(value); | ||||
| 			const acct = value.host === null ? value.username : `${value.username}@${toASCII(value.host)}`; | ||||
|  | ||||
| 			// 挿入 | ||||
| 			this.text = `${trimmedBefore}@${acct} ${after}`; | ||||
| @@ -222,13 +222,15 @@ class Autocomplete { | ||||
| 			const trimmedBefore = before.substring(0, before.lastIndexOf(':')); | ||||
| 			const after = source.substr(caret); | ||||
|  | ||||
| 			if (value.startsWith(':')) value = value + ' '; | ||||
|  | ||||
| 			// 挿入 | ||||
| 			this.text = trimmedBefore + value + after; | ||||
|  | ||||
| 			// キャレットを戻す | ||||
| 			this.vm.$nextTick(() => { | ||||
| 				this.textarea.focus(); | ||||
| 				const pos = trimmedBefore.length + 1; | ||||
| 				const pos = trimmedBefore.length + (value.startsWith(':') ? value.length : 1); | ||||
| 				this.textarea.setSelectionRange(pos, pos); | ||||
| 			}); | ||||
| 		} | ||||
|   | ||||
| @@ -1,6 +1,7 @@ | ||||
| import Vue from 'vue'; | ||||
|  | ||||
| Vue.filter('bytes', (v, digits = 0) => { | ||||
| 	if (v == null) return '?'; | ||||
| 	const sizes = ['B', 'KB', 'MB', 'GB', 'TB']; | ||||
| 	if (v == 0) return '0'; | ||||
| 	const isMinus = v < 0; | ||||
|   | ||||
| @@ -1,5 +1,6 @@ | ||||
| import Vue from 'vue'; | ||||
|  | ||||
| Vue.filter('number', (n) => { | ||||
| 	if (n == null) return 'N/A'; | ||||
| 	return n.toLocaleString(); | ||||
| }); | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
|  | ||||
| 		<p :class="$style.fetching" v-if="fetching">%fa:spinner .pulse .fw%%i18n:common.loading%<mk-ellipsis/></p> | ||||
| 		<div :class="$style.stream" v-if="!fetching && images.length > 0"> | ||||
| 			<div v-for="image in images" :class="$style.img" :style="`background-image: url(${image.url})`"></div> | ||||
| 			<div v-for="image in images" :class="$style.img" :style="`background-image: url(${image.thumbnailUrl || image.url})`"></div> | ||||
| 		</div> | ||||
| 		<p :class="$style.empty" v-if="!fetching && images.length == 0">%i18n:@no-photos%</p> | ||||
| 	</mk-widget-container> | ||||
| @@ -73,9 +73,6 @@ export default define({ | ||||
| 		border-radius 8px | ||||
|  | ||||
| .stream | ||||
| 	display -webkit-flex | ||||
| 	display -moz-flex | ||||
| 	display -ms-flex | ||||
| 	display flex | ||||
| 	justify-content center | ||||
| 	flex-wrap wrap | ||||
|   | ||||
| @@ -114,7 +114,7 @@ export default define({ | ||||
| 		this.connection.on('stats', this.onStats); | ||||
| 		this.connection.on('statsLog', this.onStatsLog); | ||||
| 		this.connection.send('requestLog',{ | ||||
| 			id: Math.random().toString() | ||||
| 			id: Math.random().toString().substr(2, 8) | ||||
| 		}); | ||||
| 	}, | ||||
| 	beforeDestroy() { | ||||
|   | ||||
| @@ -44,7 +44,6 @@ export default define({ | ||||
| 		}, | ||||
| 		fetch() { | ||||
| 			fetch(`https://api.rss2json.com/v1/api.json?rss_url=${this.props.url}`, { | ||||
| 				cache: 'no-cache' | ||||
| 			}).then(res => { | ||||
| 				res.json().then(feed => { | ||||
| 					this.items = feed.items; | ||||
|   | ||||
| @@ -92,7 +92,7 @@ export default Vue.extend({ | ||||
| 		this.connection.on('stats', this.onStats); | ||||
| 		this.connection.on('statsLog', this.onStatsLog); | ||||
| 		this.connection.send('requestLog', { | ||||
| 			id: Math.random().toString() | ||||
| 			id: Math.random().toString().substr(2, 8) | ||||
| 		}); | ||||
| 	}, | ||||
| 	beforeDestroy() { | ||||
|   | ||||
| @@ -3,7 +3,7 @@ | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import { version, codename } from '../../../config'; | ||||
| import { clientVersion as version, codename } from '../../../config'; | ||||
| import define from '../../../common/define-widget'; | ||||
| export default define({ | ||||
| 	name: 'version' | ||||
|   | ||||
| @@ -3,6 +3,7 @@ declare const _LANGS_: string; | ||||
| declare const _THEME_COLOR_: string; | ||||
| declare const _COPYRIGHT_: string; | ||||
| declare const _VERSION_: string; | ||||
| declare const _CLIENT_VERSION_: string; | ||||
| declare const _CODENAME_: string; | ||||
| declare const _ENV_: string; | ||||
|  | ||||
| @@ -18,5 +19,6 @@ export const langs = _LANGS_; | ||||
| export const themeColor = _THEME_COLOR_; | ||||
| export const copyright = _COPYRIGHT_; | ||||
| export const version = _VERSION_; | ||||
| export const clientVersion = _CLIENT_VERSION_; | ||||
| export const codename = _CODENAME_; | ||||
| export const env = _ENV_; | ||||
|   | ||||
| @@ -9,14 +9,14 @@ export default (os: OS) => opts => { | ||||
| 			note: o.renote, | ||||
| 			animation: o.animation == null ? true : o.animation | ||||
| 		}); | ||||
| 		if (opts.cb) vm.$once('closed', opts.cb); | ||||
| 		if (o.cb) vm.$once('closed', o.cb); | ||||
| 		document.body.appendChild(vm.$el); | ||||
| 	} else { | ||||
| 		const vm = os.new(PostFormWindow, { | ||||
| 			reply: o.reply, | ||||
| 			animation: o.animation == null ? true : o.animation | ||||
| 		}); | ||||
| 		if (opts.cb) vm.$once('closed', opts.cb); | ||||
| 		if (o.cb) vm.$once('closed', o.cb); | ||||
| 		document.body.appendChild(vm.$el); | ||||
| 	} | ||||
| }; | ||||
|   | ||||
| @@ -21,9 +21,8 @@ import updateAvatar from './api/update-avatar'; | ||||
| import updateBanner from './api/update-banner'; | ||||
|  | ||||
| import MkIndex from './views/pages/index.vue'; | ||||
| import MkHome from './views/pages/home.vue'; | ||||
| import MkDeck from './views/pages/deck/deck.vue'; | ||||
| import MkAdmin from './views/pages/admin/admin.vue'; | ||||
| import MkStats from './views/pages/stats/stats.vue'; | ||||
| import MkUser from './views/pages/user/user.vue'; | ||||
| import MkFavorites from './views/pages/favorites.vue'; | ||||
| import MkSelectDrive from './views/pages/selectdrive.vue'; | ||||
| @@ -54,9 +53,8 @@ init(async (launch) => { | ||||
| 		mode: 'history', | ||||
| 		routes: [ | ||||
| 			{ path: '/', name: 'index', component: MkIndex }, | ||||
| 			{ path: '/home', name: 'home', component: MkHome }, | ||||
| 			{ path: '/deck', name: 'deck', component: MkDeck }, | ||||
| 			{ path: '/admin', name: 'admin', component: MkAdmin }, | ||||
| 			{ path: '/stats', name: 'stats', component: MkStats }, | ||||
| 			{ path: '/i/customize-home', component: MkHomeCustomize }, | ||||
| 			{ path: '/i/favorites', component: MkFavorites }, | ||||
| 			{ path: '/i/messaging/:user', component: MkMessagingRoom }, | ||||
| @@ -64,11 +62,11 @@ init(async (launch) => { | ||||
| 			{ path: '/i/drive/folder/:folder', component: MkDrive }, | ||||
| 			{ path: '/selectdrive', component: MkSelectDrive }, | ||||
| 			{ path: '/search', component: MkSearch }, | ||||
| 			{ path: '/tags/:tag', component: MkTag }, | ||||
| 			{ path: '/tags/:tag', name: 'tag', component: MkTag }, | ||||
| 			{ path: '/share', component: MkShare }, | ||||
| 			{ path: '/reversi/:game?', component: MkReversi }, | ||||
| 			{ path: '/@:user', component: MkUser }, | ||||
| 			{ path: '/notes/:note', component: MkNote }, | ||||
| 			{ path: '/@:user', name: 'user', component: MkUser }, | ||||
| 			{ path: '/notes/:note', name: 'note', component: MkNote }, | ||||
| 			{ path: '/authorize-follow', component: MkFollow } | ||||
| 		] | ||||
| 	}); | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user