Compare commits
	
		
			854 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 6c3f052996 | ||
|   | 33b0c87fb1 | ||
|   | 5c490e7521 | ||
|   | 54961235a4 | ||
|   | 17eca2a18f | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 137f3ee609 | ||
|   | 498f6e9be2 | ||
|   | a5e841f59c | ||
|   | 9adab1e85e | ||
|   | 4288a843cb | ||
|   | 1669f5b265 | ||
|   | 1157298eb8 | ||
|   | 948a65bf39 | ||
|   | 20c076b369 | ||
|   | b67ed64116 | ||
|   | 1da3777bfb | ||
|   | ea6aa40b09 | ||
|   | b002651194 | ||
|   | 1452512daf | ||
|   | 0e7778bebf | ||
|   | 698fbdf88b | ||
|   | 7b738deabf | ||
|   | 3c65e7b76e | ||
|   | 3fc427b699 | ||
|   | 03667e1fe6 | ||
|   | 5cfd000a7d | ||
|   | fa66eac096 | ||
|   | 70eb75b7e6 | ||
|   | 2f6187a26a | ||
|   | 167da988da | ||
|   | 6935e647a6 | ||
|   | 743eca4a95 | ||
|   | 78598a92f9 | ||
|   | 94598ab555 | ||
|   | c5bdee086d | ||
|   | c6cfc3f908 | ||
|   | 84b488a912 | ||
|   | ec4d5857d8 | ||
|   | 4576641105 | ||
|   | 572e475b39 | ||
|   | 882a30fabe | ||
|   | feec35bf4f | ||
|   | c9fea5a7a0 | ||
|   | 00f3a1e1ec | ||
|   | 5a8cc7851b | ||
|   | 9d81d06853 | ||
|   | 4fce5d8066 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 329e367bda | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | ce056bf936 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | c6ab5faba6 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 6ce0804b43 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | a7a6563281 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 0a084a3363 | ||
|   | beeb8de6da | ||
|   | e73297f260 | ||
|   | b408ef5ba5 | ||
|   | 50539099ab | ||
|   | 9a3a77cff0 | ||
|   | cdc07945af | ||
|   | 9f9194ab5c | ||
|   | 136a087ae7 | ||
|   | b9e91afa26 | ||
|   | f943e39c89 | ||
|   | 75bdbff36d | ||
|   | 43930e6a84 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 57d0c19a98 | ||
|   | 66a11378d2 | ||
|   | 62b680cadd | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 1e1ac13999 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | d27c454674 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 3263eaec32 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | de4e9a857c | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | d838876ab1 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 03336f01b5 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | d212d693a4 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | d17fcd8e48 | ||
|   | 49b3ee36bd | ||
|   | 100d7adc3d | ||
|   | 68b1fea6bb | ||
|   | 4de6e1e28a | ||
|   | 84f8c34e90 | ||
|   | 77567cf114 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 3cf8e1917c | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 84cbabec29 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | b88c65ab67 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 10782822de | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 5457172aa5 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | d20a2c7080 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | c01098de16 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 0b14a57d55 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 405d104208 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 83e3316f06 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 2037d4c21d | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 6cabf052b1 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 359e1b2e6e | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 7b553b13ac | ||
|   | 79872ec3e8 | ||
|   | e9df7265fa | ||
|   | 1ade89be35 | ||
|   | 3356f7113f | ||
|   | e6495ea6e2 | ||
|   | 629991443a | ||
|   | 6848f05ea5 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | e58dd71829 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 1afa2f1202 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | f322cb444a | ||
|   | 69c3c4e3dc | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 488e6feed9 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 40891aca48 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | cd0e557991 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 679f8ad614 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 00c647c736 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 1ac6af6ad1 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | a5d7099a3c | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | e9c8a0f5d5 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | adcda0889e | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 95cbcdd379 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | a5e8eb4b7b | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | ed440f80f3 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 4e2ef94107 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | de690e0622 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 062e1a4940 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | cc3779b197 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 92dc34b51a | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | f8ee615640 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 5dde8b4bdc | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 2c70055a87 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | db8ab8b890 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 28da5c5a31 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | b345aad52c | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | aa5af89dfc | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 9a3a74db34 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 328619f1fc | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 121e12785f | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | cc3f0737a2 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | bc3714139f | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 9200379997 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 0ee664db2b | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 86487e6f66 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | adc2bcc59b | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 21a54f559a | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 145e16c266 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 68f4edd0ee | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 7fd6a134d1 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 0db8d566e2 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | c6f6291fc0 | ||
|   | c2d79450ea | ||
|   | d58ae601f7 | ||
|   | 3ad73ad7d9 | ||
|   | f0c4df1cc5 | ||
|   | 839784bc8c | ||
|   | b758ec96ef | ||
|   | 2f8ceb9d22 | ||
|   | e05ae5ebc2 | ||
|   | ebc43be4b3 | ||
|   | 8543278ce3 | ||
|   | 9a98de7bd8 | ||
|   | e1d69fb4ad | ||
|   | 946f9b4a2b | ||
|   | 9a270e59a4 | ||
|   | 2112fb3896 | ||
|   | d1bd9fa552 | ||
|   | 393bd76959 | ||
|   | 97165fbaf5 | ||
|   | feca9940bc | ||
|   | fbbc7d005d | ||
|   | af5b4749b0 | ||
|   | b4e5fe7e71 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 1671aef0bd | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | ffe5a12773 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 9ca01b65de | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | f50ed905a8 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | d7156b8cdd | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 14442ffa18 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | d454596c33 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 7d510cf780 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 8121cbf10c | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | d34d20c393 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | e773c272be | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 0c072249d8 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | d0b7b662b4 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 4b5aa286a0 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 2310c74d0b | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | af251bf0c4 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 16204ac13b | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 7c8645fe29 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | bd82173caa | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 2e8a0b0fac | ||
|   | 38b7f4364c | ||
|   | 3a33e406c7 | ||
|   | 8d0c5268d1 | ||
|   | 08bec5abd9 | ||
|   | cc4b6e5eea | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | e6cb07bef4 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 249bfcc5f0 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 108c4b4342 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 38befa51ac | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 6a76118710 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | f049694fa1 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 515a6b74a2 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | d1291b3b4c | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | d2abc28a2b | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 12142f8c5e | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 41d7a8de66 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | c7a65c13aa | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | fbf0baadba | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | ea31e62795 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 910b145f42 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 952a793f80 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 46f2ffaa5c | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 45ba7989c1 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | c4cf3331e9 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 6d75ca0bcb | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 050fb55326 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 9d1d9c3540 | ||
|   | fdde966808 | ||
|   | c6ce7b1045 | ||
|   | ce743054d6 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 99970b6864 | ||
|   | 42110bcd33 | ||
|   | 9677b0bfb1 | ||
|   | a7762972fa | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | dda3b4152e | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | b7aa6d6c1f | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 909a3b805f | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 848d2e00e7 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 642662941f | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 0028a529a8 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 62131e864b | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 0c58b43831 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 5a3d6c4fba | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | a031fa3875 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 721ed97a83 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 944927ac2d | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 7705749d28 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | cf7f42ebc4 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | f195968b6d | ||
|   | 4d6bffdc8a | ||
|   | f62c6a05a9 | ||
|   | fa550a2a78 | ||
|   | 960c27375c | ||
|   | e87b3e2933 | ||
|   | 133766bf8c | ||
|   | aa6b25e9e7 | ||
|   | abde13221f | ||
|   | cb17be5e2b | ||
|   | 17d62b689d | ||
|   | 9bf5dc67f5 | ||
|   | 4eab9b4354 | ||
|   | d39c153c57 | ||
|   | e5992742d4 | ||
|   | 72ed803c2a | ||
|   | 9ec0e59431 | ||
|   | 5328ed64f3 | ||
|   | 33e8d61d65 | ||
|   | 3584786387 | ||
|   | 34f662ead5 | ||
|   | 2d53481cf5 | ||
|   | 10fb029609 | ||
|   | 0281961f15 | ||
|   | fede4eeb89 | ||
|   | ab50d5ef20 | ||
|   | f4e02d4a4c | ||
|   | 167640df8d | ||
|   | fe01437aa4 | ||
|   | 037fce4d6a | ||
|   | db8b824b84 | ||
|   | b71f62535d | ||
|   | e9a1e281b9 | ||
|   | 0144408500 | ||
|   | 7660839e40 | ||
|   | d1ca851ebe | ||
|   | 35a281d443 | ||
|   | c2690fff47 | ||
|   | c3a73a41d1 | ||
|   | b72baa3295 | ||
|   | 73ce22c8a4 | ||
|   | c4f7e6659f | ||
|   | 0739ae006d | ||
|   | eaa92e784d | ||
|   | 48589e0da1 | ||
|   | 0044d83801 | ||
|   | 50e917d232 | ||
|   | ccd14e0462 | ||
|   | d0c0104546 | ||
|   | cd34ade638 | ||
|   | 3f91e33a8c | ||
|   | 17cc996288 | ||
|   | 385776dc0f | ||
|   | e52278c371 | ||
|   | 7ffc8c1eda | ||
|   | 1359615c82 | ||
|   | 7a7a56940c | ||
|   | bcbe83cb38 | ||
|   | 37f983aee3 | ||
|   | 77de3f2b9d | ||
|   | f655b54937 | ||
|   | cac99ebdd4 | ||
|   | f0d0a1546a | ||
|   | 8e8459fa55 | ||
|   | d53c55ecb5 | ||
|   | ea33d61a90 | ||
|   | 2fcc3388dd | ||
|   | ef7f033c32 | ||
|   | 7aa54dc92e | ||
|   | d10ad1b413 | ||
|   | 34063a0b84 | ||
|   | 8c9d975d69 | ||
|   | 03b072b894 | ||
|   | d1bed49808 | ||
|   | 6c3417d9b5 | ||
|   | ba65226460 | ||
|   | 9c9cd168ee | ||
|   | abb3d2a8d9 | ||
|   | 637fe8a04b | ||
|   | be321e95e5 | ||
|   | ed46c1486c | ||
|   | c9fcfc6862 | ||
|   | 8495e37566 | ||
|   | 247bd43ae2 | ||
|   | a6685b1559 | ||
|   | 66c4e8064b | ||
|   | 9d1fa3f202 | ||
|   | a6985d7dc7 | ||
|   | 027c021ac9 | ||
|   | 604205ec09 | ||
|   | 77db016866 | ||
|   | c6a009dbae | ||
|   | 4299e3f90c | ||
|   | 19f4812c03 | ||
|   | d01c465a8d | ||
|   | 4f1409601e | ||
|   | 52cffe0864 | ||
|   | 0866d5c055 | ||
|   | 78c08f6503 | ||
|   | 27d0ac3d75 | ||
|   | a8776002f3 | ||
|   | 31aa008566 | ||
|   | 9d405b4581 | ||
|   | 80c490a18b | ||
|   | 30c9c3739f | ||
|   | ee0e7a09e0 | ||
|   | bfd9577f0d | ||
|   | 0cada4ca76 | ||
|   | a718ccc0b6 | ||
|   | 1fcfd8e645 | ||
|   | c6dd932a0b | ||
|   | b79eed01e0 | ||
|   | 3a7dbe9764 | ||
|   | bef2534fa8 | ||
|   | 888dcd2559 | ||
|   | 2b69fca6bd | ||
|   | 7d088d42b4 | ||
|   | f8ad303b13 | ||
|   | 3c59c6fc9b | ||
|   | 7353d729d7 | ||
|   | 62591e0e7a | ||
|   | 012f15d84b | ||
|   | e57c6f94d2 | ||
|   | 40b27e8ad8 | ||
|   | 055e9f21b7 | ||
|   | d7085b17fe | ||
|   | 0d4d7c9c0c | ||
|   | 99209d36e1 | ||
|   | e2a9a0ff3d | ||
|   | ab166959a4 | ||
|   | ab692cfa3d | ||
|   | c3ae6f3a4a | ||
|   | 5ef4a52bbd | ||
|   | 582768a5e4 | ||
|   | 1852d1cc6f | ||
|   | 7a5a541a4e | ||
|   | 72b03e009c | ||
|   | 1b113c1045 | ||
|   | 54959557ea | ||
|   | d44cb7f256 | ||
|   | 3d063c95d1 | ||
|   | 09cab605fc | ||
|   | 666c8c0498 | ||
|   | d3e764d7f9 | ||
|   | 7060625adf | ||
|   | 21b6e23e98 | ||
|   | a0f794e372 | ||
|   | 9195504329 | ||
|   | 8c5d9dd549 | ||
|   | 580f6a5b6c | ||
|   | 74e76b460b | ||
|   | c4570b37b7 | ||
|   | cd0b0012d9 | ||
|   | c055b4d32d | ||
|   | 75a9ff832a | ||
|   | b64d3af1f3 | ||
|   | fb6605bb40 | ||
|   | 3bfae80fa7 | ||
|   | cb16cb0610 | ||
|   | 0baed1a275 | ||
|   | 42162c8015 | ||
|   | 0fab0c416d | ||
|   | e2e262c8ce | ||
|   | cf6596203b | ||
|   | 471911a54f | ||
|   | 9394f4f540 | ||
|   | 4e968216ad | ||
|   | 84a7a9555f | ||
|   | 8d12fd152b | ||
|   | 629b765abc | ||
|   | 63a89fa84a | ||
|   | a3f89236a0 | ||
|   | 01560abafb | ||
|   | b5698026ba | ||
|   | 6258ce75b7 | ||
|   | 6f34c74027 | ||
|   | 8add4f359b | ||
|   | d8933c135f | ||
|   | eb350e8d6c | ||
|   | 615fedd64d | ||
|   | 25bd82ecaa | ||
|   | e0938e5e3a | ||
|   | ec5e6c8443 | ||
|   | 25d8077474 | ||
|   | 06083f40d9 | ||
|   | ec203f7f79 | ||
|   | 1b30d7d47a | ||
|   | d9be9c958f | ||
|   | ed09796e0d | ||
|   | 4bfa29c0ab | ||
|   | 4804bbb211 | ||
|   | 749102f9c2 | ||
|   | 0bcb1434b0 | ||
|   | 2e537e618c | ||
|   | fe3b7a2ad3 | ||
|   | 90db793fd0 | ||
|   | 7bd2a6ad61 | ||
|   | 745f4d2439 | ||
|   | 254cfaea28 | ||
|   | d4da5a1eea | ||
|   | c0f8297414 | ||
|   | 834cb2ea1a | ||
|   | d82769abd4 | ||
|   | adf01ed4a4 | ||
|   | 09c007b3aa | ||
|   | 526ff177aa | ||
|   | 0e40d4e796 | ||
|   | 172ebab7bd | ||
|   | aa4493fe5c | ||
|   | a68a88f79e | ||
|   | 1de7dc94e1 | ||
|   | 59cb7992e2 | ||
|   | 87b15df47b | ||
|   | 6932d86240 | ||
|   | 87f61e714a | ||
|   | 5762e2d9ba | ||
|   | f0691c8a4f | ||
|   | 6d7e4fe2a1 | ||
|   | 7dc789f470 | ||
|   | 190d1bbf3c | ||
|   | a755dd5f9e | ||
|   | 0846a7b94e | ||
|   | d8be0511f1 | ||
|   | fb07116a4c | ||
|   | fe453c15e3 | ||
|   | 059aeef6a0 | ||
|   | 30e25451d6 | ||
|   | 7f0fd55c9a | ||
|   | 0e9b496deb | ||
|   | 8294c18e70 | ||
|   | 39575b4696 | ||
|   | 29e9801d5c | ||
|   | eaf83bffb0 | ||
|   | bb25ece745 | ||
|   | 754b5629e4 | ||
|   | ee63403548 | ||
|   | 87edeb41da | ||
|   | 41fe804587 | ||
|   | 02466acc4b | ||
|   | 8470a64e6b | ||
|   | 9939e0f9a9 | ||
|   | ce5f552d0c | ||
|   | 7d4c535233 | ||
|   | 57cd0fb93f | ||
|   | a15299ae53 | ||
|   | 1df7abfbb9 | ||
|   | 85a0f696bc | ||
|   | ba3c62bf9c | ||
|   | c17e97b6a6 | ||
|   | 2d80cd0e7b | ||
|   | eedc572f0c | ||
|   | 2de1df3514 | ||
|   | 2d96af1255 | ||
|   | 163325ef89 | ||
|   | 23979bf09a | ||
|   | 7199e6f4e0 | ||
|   | a40f38b2b5 | ||
|   | 00a17ed5d4 | ||
|   | b594366f06 | ||
|   | e9284930df | ||
|   | ea7504f564 | ||
|   | c1f6d996f6 | ||
|   | df71dbb024 | ||
|   | f104e9b6cc | ||
|   | e29b5c2326 | ||
|   | 925868dcdb | ||
|   | d7df26d92b | ||
|   | 42d1c67d56 | ||
|   | c2d7929391 | ||
|   | 5864b52a81 | ||
|   | 493d32b3dc | ||
|   | ed141338fb | ||
|   | 95db488c48 | ||
|   | d5e1e523b6 | ||
|   | cd0f8a4ef9 | ||
|   | 6dac505af9 | ||
|   | 9d398040cb | ||
|   | aa55acedc9 | ||
|   | eb70d6f226 | ||
|   | 36f0963d78 | ||
|   | c3c111529e | ||
|   | 2dbab66cfe | ||
|   | 01238d6b1a | ||
|   | c34f302b1c | ||
|   | 6870262f8d | ||
|   | c54d5e7040 | ||
|   | 0ace009a54 | ||
|   | 48e8ee440b | ||
|   | 9855405b89 | ||
|   | 122076e8ea | ||
|   | 7c5ac2cbb4 | ||
|   | ccda2181c1 | ||
|   | b5fe4ba9be | ||
|   | fd9c7d525a | ||
|   | 080574e13d | ||
|   | ee0a445590 | ||
|   | bb342c7601 | ||
|   | ed17636fb9 | ||
|   | c59d7d941a | ||
|   | 377377595a | ||
|   | d63aef9963 | ||
|   | e9b28fa3c0 | ||
|   | be255dc583 | ||
|   | 18eb7c6087 | ||
|   | cf29e69813 | ||
|   | 132da7e3c0 | ||
|   | 26df23bb64 | ||
|   | 76389ad619 | ||
|   | 7cde8cfbf2 | ||
|   | 4eb2ddac4e | ||
|   | dc51eef27c | ||
|   | bff8a23cbc | ||
|   | 9c5efb9da0 | ||
|   | 48b8320e5e | ||
|   | 9b2ed96c1c | ||
|   | 69d9aa71f2 | ||
|   | 13683780cd | ||
|   | d780e5b251 | ||
|   | 917d3d0bd3 | ||
|   | 4b19c53697 | ||
|   | 2d40a15d2b | ||
|   | 2bdcd22ad4 | ||
|   | f73a4e1304 | ||
|   | b265cdbd84 | ||
|   | a04d8b95c2 | ||
|   | 0e9a8c0cd4 | ||
|   | 5ae8a3c7e8 | ||
|   | 70ee172128 | ||
|   | b9febc00f9 | ||
|   | 0112e2f7ec | ||
|   | 60736bab2a | ||
|   | fb7c4ee21a | ||
|   | e93c06cd00 | ||
|   | 0a99345909 | ||
|   | 3d08ff7cb4 | ||
|   | 057ce73ba1 | ||
|   | 66b07578c5 | ||
|   | de3b365563 | ||
|   | 7bb8d8b27e | ||
|   | 9008664606 | ||
|   | 7374905c28 | ||
|   | 718e20de60 | ||
|   | 73d166323d | ||
|   | 3589fc6f4f | ||
|   | feed6c7acc | ||
|   | 2522e7388d | ||
|   | 09cfd620bb | ||
|   | 362e95263d | ||
|   | c6837b9fdf | ||
|   | 71878f93e4 | ||
|   | f5d43b1f25 | ||
|   | 770e7378be | ||
|   | b9a8620d2f | ||
|   | d1c8b2993e | ||
|   | 01e9b3c2f6 | ||
|   | 57203de4cb | ||
|   | 74d0e83a8a | ||
|   | 9eee5644b9 | ||
|   | 9fe6f9417e | ||
|   | e7de5f6051 | ||
|   | 60d81d74e3 | ||
|   | 2701a7e85f | ||
|   | 31a0afdaab | ||
|   | 9f87545901 | ||
|   | 9f94f60ede | ||
|   | 0ca3c0bca1 | ||
|   | 27611cef77 | ||
|   | 30df8ea121 | ||
|   | 595ad04ddb | ||
|   | 6b8354ccbf | ||
|   | 1b9d316e7c | ||
|   | a8adc46f3b | ||
|   | 0efa969a15 | ||
|   | 14b7f05af4 | ||
|   | cf43dd6ec5 | ||
|   | b5a1fdd4c7 | ||
|   | b32737cdff | ||
|   | 8e9717a5fc | ||
|   | 3e28b296e3 | ||
|   | 056fef70da | ||
|   | 55be9cc9d1 | ||
|   | 3f2ffcea97 | ||
|   | b07d037cb5 | ||
|   | 4feccdfd92 | ||
|   | f1ef85b636 | ||
|   | cf9266eab9 | ||
|   | 4a1552fb3c | ||
|   | e5863c2867 | ||
|   | 58211fc6a7 | ||
|   | bd54e44b35 | ||
|   | e1f2e364a4 | ||
|   | 186b26e103 | ||
|   | 74706a8d2c | ||
|   | 7e2b6b6369 | ||
|   | 1a2de1a051 | ||
|   | 83900cbca6 | ||
|   | 166bc19131 | ||
|   | da874f3383 | ||
|   | 9c30b23358 | ||
|   | b8350d5093 | ||
|   | 58f7af8927 | ||
|   | c3b9c7b74b | ||
|   | 9415618992 | ||
|   | 1c200c9b94 | ||
|   | ce8fa8e423 | ||
|   | a4b7a9db03 | ||
|   | 280eeb9d75 | ||
|   | 3f71b14637 | ||
|   | 705d40ab37 | ||
|   | b39850de01 | ||
|   | b9c5e95b85 | ||
|   | 0c1de7b1b6 | ||
|   | 0a4499fd03 | ||
|   | b663a47331 | ||
|   | eb275a62a6 | ||
|   | e18caa3396 | ||
|   | eb15d31ebf | ||
|   | e7f1ab2d01 | ||
|   | 9d3beb3174 | ||
|   | b6c3399abe | ||
|   | b505874613 | ||
|   | 0a28573845 | ||
|   | 937df577f1 | ||
|   | e54fd6c2cb | ||
|   | 3caea9d33e | ||
|   | b9e9631195 | ||
|   | 76bded455a | ||
|   | c94d9210ed | ||
|   | 0f5db9558c | ||
|   | 35a8c37922 | ||
|   | 6ff84a1061 | ||
|   | aae9bc4cf4 | ||
|   | 426c2fa5d1 | ||
|   | dab728278c | ||
|   | 7555ab097a | ||
|   | 5b5b64d251 | ||
|   | eb84445796 | ||
|   | 364bd9ae74 | ||
|   | d4b0761549 | ||
|   | f8e06f12fd | ||
|   | 320352bf4b | ||
|   | 3c66990263 | ||
|   | 7cbe95a1cf | ||
|   | c89abda3fb | ||
|   | 90348f4ac7 | ||
|   | 08293f368f | ||
|   | d5378dab27 | ||
|   | 91648d1bd4 | ||
|   | 66d6e71f06 | ||
|   | a0ea5776ab | ||
|   | 9b73e897df | ||
|   | debc0086fa | ||
|   | 065ec8e170 | ||
|   | 11f8d742eb | ||
|   | adf4f5410a | ||
|   | 8ff2694cad | ||
|   | 191c064611 | ||
|   | d327bb8ff1 | ||
|   | 80bebea9e6 | ||
|   | cf3fc97202 | ||
|   | 5b28d7bf90 | ||
|   | 5f8fb43cc9 | ||
|   | 6eff6ee451 | ||
|   | c2ab3a15f4 | ||
|   | a100e13a18 | ||
|   | a591a334ed | ||
|   | ca2e53bd6e | ||
|   | d4b4b61535 | ||
|   | 440deb4624 | ||
|   | bbb0130522 | ||
|   | b6a4061097 | ||
|   | 48c94907c2 | ||
|   | 4fd06369d3 | ||
|   | 27a17b467d | ||
|   | c25cf7f89a | ||
|   | ade11aa447 | ||
|   | 3799708daf | ||
|   | 462204e204 | ||
|   | 752669bf5e | ||
|   | b08e3f59d3 | ||
|   | 443b45e509 | ||
|   | b2bed61088 | ||
|   | be516d3c1e | ||
|   | f5b41e1fbf | ||
|   | e9afc1d867 | ||
|   | a891f7e862 | ||
|   | b715ea4621 | ||
|   | ea13efe495 | ||
|   | 37f862947b | ||
|   | ecb0861be4 | ||
|   | 624c9f3418 | ||
|   | 1b75984046 | ||
|   | 157f1c66dc | ||
|   | cb41391bae | ||
|   | acc88825fc | ||
|   | 233a837e35 | ||
|   | 9e4456ac1b | ||
|   | 83e1068da3 | ||
|   | 1fd345f563 | ||
|   | 37c16e5b45 | ||
|   | ca25b9acc1 | ||
|   | c3022d38f7 | ||
|   | 3599f16d22 | ||
|   | 3f78f6f6bb | ||
|   | 41f66e4299 | ||
|   | 0d36b144cf | ||
|   | aa652aac8a | ||
|   | 8dbdab4a47 | ||
|   | 90c07a220f | ||
|   | 23e2a870cc | ||
|   | dc8eb7d4fe | ||
|   | fd363f5617 | ||
|   | 1726ff3977 | ||
|   | 93aba74463 | ||
|   | 99955f0af9 | ||
|   | 30cf154542 | ||
|   | f2c33b06cf | ||
|   | f12473e677 | ||
|   | e845db01bf | ||
|   | 7f76a73eee | ||
|   | 3c2d94ace3 | ||
|   | 1e2239f527 | ||
|   | 1851daf9fd | ||
|   | f378f26e5e | ||
|   | cda6bc3404 | ||
|   | 071c7e6a58 | ||
|   | 010e1b3ba4 | ||
|   | 66de51c1ca | ||
|   | 265d6bda15 | ||
|   | fecb12bae1 | ||
|   | 83ec906ee7 | ||
|   | d44fbf58c9 | ||
|   | 9c4a789a4e | ||
|   | bfa1705bad | ||
|   | 2876f2188c | ||
|   | 579c0043c3 | ||
|   | 0fa57957a4 | ||
|   | 05cb0b0ec5 | ||
|   | 4b24e96dfb | ||
|   | c7eab37177 | ||
|   | c7d0b6cb29 | ||
|   | 22ee087bb9 | ||
|   | 2480fcdc53 | ||
|   | 7e093aee5e | ||
|   | dd8413a485 | ||
|   | 925f2912a9 | ||
|   | ed00ea0865 | ||
|   | 3f19d221b7 | ||
|   | 808271838b | ||
|   | ac0950fdef | ||
|   | 38f306ba73 | ||
|   | 5c1748d63d | ||
|   | c00cddf5b0 | ||
|   | baf3274748 | ||
|   | 9e0515e563 | ||
|   | 9c0404c407 | ||
|   | 0b85177690 | ||
|   | 7ec28ced40 | ||
|   | 19ae3b66ec | ||
|   | 0118dee3e5 | ||
|   | 9201714313 | ||
|   | 8b9c1efd7e | ||
|   | 111eb43fd9 | ||
|   | f2964101d1 | ||
|   | 6b2c289029 | ||
|   | fd2573c068 | ||
|   | df0e9d75fe | ||
|   | 2bc86756c8 | ||
|   | fb91ab4080 | ||
|   | 0b4d29ed1e | ||
|   | 2a8c65e2c3 | ||
|   | ffc7f42efc | ||
|   | 7c38cda8ee | ||
|   | d3f5001679 | ||
|   | 83d9a4b6d9 | ||
|   | 9760e08af4 | ||
|   | 8d48e4c76e | ||
|   | a1e0c866aa | ||
|   | 8380222baf | ||
|   | eda7d60c26 | ||
|   | ddf92c3e2c | ||
|   | 9bb528eb6e | ||
|   | 9756957ac1 | ||
|   | af0205b77d | ||
|   | 3f0da5453d | ||
|   | 923c3071f0 | ||
|   | a8584973e2 | ||
|   | 886766cca5 | ||
|   | 974abbe826 | ||
|   | 61bdf51e90 | ||
|   | 9bee9d20f7 | ||
|   | 7aee3b88eb | ||
|   | d08184f5fe | ||
|   | ae08232bfb | ||
|   | 2b5e4b57bd | ||
|   | 35ae13a490 | ||
|   | 74f55b4d3f | ||
|   | abe9440021 | ||
|   | 6a95b94aaa | ||
|   | 21ee38d813 | ||
|   | 9681a906d5 | ||
|   | 2ca760bee6 | ||
|   | da9f916daa | ||
|   | bc05b83a24 | ||
|   | 620e0a9df6 | ||
|   | 38ad4f7098 | ||
|   | 05c7cacdd1 | ||
|   | baa49271df | ||
|   | e2cbe70966 | ||
|   | 6a98301cc9 | ||
|   | 81f1df7472 | ||
|   | abc296cdcc | ||
|   | 4df5ec82ce | ||
|   | 3963ed8ff7 | ||
|   | 11141c878c | ||
|   | b1a2046a7f | ||
|   | e44322c9bf | ||
|   | 2e6462bf1b | 
| @@ -4,7 +4,7 @@ executors: | ||||
|   docker: | ||||
|     working_directory: /tmp/workspace | ||||
|     docker: | ||||
|       - image: docker:latest | ||||
|       - image: docker:12.10.1 | ||||
|  | ||||
| jobs: | ||||
|   docker: | ||||
| @@ -15,7 +15,8 @@ jobs: | ||||
|     executor: docker | ||||
|     steps: | ||||
|       - checkout | ||||
|       - setup_remote_docker | ||||
|       - setup_remote_docker: | ||||
|           version: 19.03.13 | ||||
|       - run: | ||||
|           name: Build | ||||
|           command: | | ||||
| @@ -31,7 +32,7 @@ jobs: | ||||
|                     apk update && apk add jq | ||||
|                     docker tag misskey/misskey misskey/misskey:$(cat package.json | jq -r .version) | ||||
|                     docker login -u $DOCKERHUB_USERNAME -p $DOCKERHUB_PASSWORD | ||||
|                     docker push misskey/misskey | ||||
|                     docker push -a misskey/misskey | ||||
|                    else | ||||
|                     echo -e '\033[0;33mAborted deploying to Docker Hub\033[0;39m' | ||||
|                   fi | ||||
|   | ||||
| @@ -154,3 +154,6 @@ id: 'aid' | ||||
|  | ||||
| # Media Proxy | ||||
| #mediaProxy: https://example.com/proxy | ||||
|  | ||||
| # Sign to ActivityPub GET request (default: false) | ||||
| #signToActivityPubGet: true | ||||
|   | ||||
| @@ -5,8 +5,10 @@ | ||||
| .vscode | ||||
| Dockerfile | ||||
| build/ | ||||
| built/ | ||||
| db/ | ||||
| docker-compose.yml | ||||
| elasticsearch/ | ||||
| node_modules/ | ||||
| redis/ | ||||
| files/ | ||||
|   | ||||
							
								
								
									
										2
									
								
								.github/workflows/nodejs.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/nodejs.yml
									
									
									
									
										vendored
									
									
								
							| @@ -12,7 +12,7 @@ jobs: | ||||
|  | ||||
|     strategy: | ||||
|       matrix: | ||||
|         node-version: [11.10.x, 12.x, 13.x, 14.x] | ||||
|         node-version: [12.x, 14.x, 15.x] | ||||
|  | ||||
|     services: | ||||
|       postgres: | ||||
|   | ||||
							
								
								
									
										2
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -12,7 +12,7 @@ report.*.json | ||||
| # config | ||||
| /.config/* | ||||
| !/.config/example.yml | ||||
| !/.config/mongo_initdb_example.js | ||||
| !/.config/docker_example.env | ||||
|  | ||||
| # misskey | ||||
| /build | ||||
|   | ||||
| @@ -1 +1 @@ | ||||
| v12.11.1 | ||||
| v14.15.1 | ||||
|   | ||||
							
								
								
									
										2367
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										2367
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,6 +1,12 @@ | ||||
| # Contribution guide | ||||
| :v: Thanks for your contributions :v: | ||||
|  | ||||
| ## When you contribute... | ||||
| - 任意のIssueについて、せっかく実装してくださっても、実装方法や設計の認識が揃ってないとマージできない/しないことになりかねないので、初めにそのIssue上で着手することを宣言し、必要に応じて他メンバーと実装方法や設計のすり合わせを行ってください。宣言することは作業が他の人と被るのを防止する効果もあります。 | ||||
|   - 設計に迷った時はプロジェクトリーダーの判断を仰いでください。 | ||||
| - 時間や優先度の都合上、提出してくださったPRが長期間放置されることもありますがご理解ください。 | ||||
|   - 温度感高めで見てほしいものは責付いてください。 | ||||
|  | ||||
| ## Issues | ||||
| Feature suggestions and bug reports are filed in https://github.com/syuilo/misskey/issues . | ||||
|  | ||||
|   | ||||
| @@ -1,9 +1,7 @@ | ||||
| FROM node:14.2.0-alpine AS base | ||||
| FROM node:14.15.1-alpine AS base | ||||
|  | ||||
| ENV NODE_ENV=production | ||||
|  | ||||
| RUN npm i -g npm@latest | ||||
|  | ||||
| WORKDIR /misskey | ||||
|  | ||||
| FROM base AS builder | ||||
| @@ -12,6 +10,7 @@ RUN apk add --no-cache \ | ||||
|     autoconf \ | ||||
|     automake \ | ||||
|     file \ | ||||
| 		git \ | ||||
|     g++ \ | ||||
|     gcc \ | ||||
|     libc-dev \ | ||||
|   | ||||
							
								
								
									
										81
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										81
									
								
								README.md
									
									
									
									
									
								
							| @@ -6,8 +6,9 @@ | ||||
| [](https://circleci.com/gh/syuilo/misskey) | ||||
| [](https://david-dm.org/syuilo/misskey) | ||||
| [](http://makeapullrequest.com) | ||||
| [](https://github.com/humanetech-community/awesome-humane-tech) | ||||
|  | ||||
| **A forever evolving, sophisticated microblogging platform.** | ||||
| **A forever evolving, interplanetary microblogging platform.** | ||||
|  | ||||
| <p align="justify"> | ||||
| <a href="https://join.misskey.page/">Misskey</a> is a decentralized microblogging platform born on Earth. | ||||
| @@ -112,99 +113,103 @@ Please see the [Contribution Guide](./CONTRIBUTING.md). | ||||
| <td><img src="https://c8.patreon.com/2/200/20832595" alt="Roujo " width="100"></td> | ||||
| <td><img src="https://c8.patreon.com/2/200/27956229" alt="Oliver Maximilian Seidel" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/12190916/fb7fa7983c14425f890369535b1506a4/3.png?token-time=2145916800&token-hash=oH_i7gJjNT7Ot6j9JiVwy7ZJIBqACVnzLqlz4YrDAZA%3D" alt="weepjp " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/605366/c9dc408fdcbf412fb183ca5b06235f8d/1.jpeg?token-time=2145916800&token-hash=oaqsjLqOFjWN5I9hm2epOaTXaEtKwQUy5OW-EpAz6-g%3D" alt="Jon Leibowitz" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/19045173/cb91c0f345c24d4ebfd05f19906d5e26/1.png?token-time=2145916800&token-hash=o_zKBytJs_AxHwSYw_5R8eD0eSJe3RoTR3kR3Q0syN0%3D" alt="kiritan " width="100"></td> | ||||
| <td><img src="https://c8.patreon.com/2/200/27648259" alt="みなしま " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/24430516/b1964ac5b9f746d2a12ff53dbc9aa40a/1.jpg?token-time=2145916800&token-hash=bmEiMGYpp3bS7hCCbymjGGsHBZM3AXuBOFO3Kro37PU%3D" alt="Eduardo Quiros" width="100"></td> | ||||
| </tr><tr> | ||||
| <td><a href="https://www.patreon.com/user?u=20832595">Roujo </a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=27956229">Oliver Maximilian Seidel</a></td> | ||||
| <td><a href="https://www.patreon.com/weepjp">weepjp </a></td> | ||||
| <td><a href="https://www.patreon.com/jonleibowitz">Jon Leibowitz</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=19045173">kiritan </a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=27648259">みなしま </a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=24430516">Eduardo Quiros</a></td> | ||||
| </tr></table> | ||||
| <table><tr> | ||||
| <td><img src="https://c8.patreon.com/2/200/776209" alt="Denshi " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/14215107/1cbe1912c26143919fa0faca16f12ce1/4.jpg?token-time=2145916800&token-hash=BslMqDjTjz8KYANLvxL87agHTugHa0dMPUzT-hwR6Vk%3D" alt="Nesakko" width="100"></td> | ||||
| <td><img src="https://c8.patreon.com/2/200/776209" alt="Demogrognard" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/3075183/c2ae575c604e420297f000ccc396e395/1.jpeg?token-time=2145916800&token-hash=O9qmPtpo6wWb0OuvnkEekhk_1WO2MTdytLr7ZgsAr80%3D" alt="Liaizon Wakest" width="100"></td> | ||||
| <td><img src="https://c8.patreon.com/2/200/557245" alt="mkatze " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/23915207/25428766ecd745478e600b3d7f871eb2/1.png?token-time=2145916800&token-hash=urCLLA4KjJZX92Y1CxcBP4d8bVTHGkiaPnQZp-Tqz68%3D" alt="kabo2468y " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/8249688/4aacf36b6b244ab1bc6653591b6640df/2.png?token-time=2145916800&token-hash=1ZEf2w6L34253cZXS_HlVevLEENWS9QqrnxGUAYblPo%3D" alt="AureoleArk " width="100"></td> | ||||
| <td><img src="https://c8.patreon.com/2/200/21285325" alt="Nie(sha) " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5670915/ee175f0bfb6347ffa4ea101a8c097bff/1.jpg?token-time=2145916800&token-hash=mPLM9CA-riFHx-myr3bLZJuH2xBRHA9se5VbHhLIOuA%3D" alt="osapon " width="100"></td> | ||||
| <td><img src="https://c8.patreon.com/2/200/16869916" alt="見当かなみ " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/18899730/6a22797f68254034a854d69ea2445fc8/1.png?token-time=2145916800&token-hash=b_uj57yxo5VzkSOUS7oXE_762dyOTB_oxzbO6lFNG3k%3D" alt="YuzuRyo61 " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5788159/af42076ab3354bb49803cfba65f94bee/1.jpg?token-time=2145916800&token-hash=iSaxp_Yr2-ZiU2YVi9rcpZZj9mj3UvNSMrZr4CU4qtA%3D" alt="mewl hayabusa" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/36813045/29876ea679d443bcbba3c3f16edab8c2/2.jpeg?token-time=2145916800&token-hash=YCKWnIhrV9rjUCV9KqtJnEqjy_uGYF3WMXftjUdpi7o%3D" alt="Wataru Manji (manji0)" width="100"></td> | ||||
| </tr><tr> | ||||
| <td><a href="https://www.patreon.com/user?u=776209">Denshi </a></td> | ||||
| <td><a href="https://www.patreon.com/Nesakko">Nesakko</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=776209">Demogrognard</a></td> | ||||
| <td><a href="https://www.patreon.com/wakest">Liaizon Wakest</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=557245">mkatze </a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=23915207">kabo2468y </a></td> | ||||
| <td><a href="https://www.patreon.com/AureoleArk">AureoleArk </a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=21285325">Nie(sha) </a></td> | ||||
| <td><a href="https://www.patreon.com/osapon">osapon </a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=16869916">見当かなみ </a></td> | ||||
| <td><a href="https://www.patreon.com/Yuzulia">YuzuRyo61 </a></td> | ||||
| <td><a href="https://www.patreon.com/hs_sh_net">mewl hayabusa</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=36813045">Wataru Manji (manji0)</a></td> | ||||
| </tr></table> | ||||
| <table><tr> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/18899730/6a22797f68254034a854d69ea2445fc8/1.png?token-time=2145916800&token-hash=b_uj57yxo5VzkSOUS7oXE_762dyOTB_oxzbO6lFNG3k%3D" alt="YuzuRyo61 " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5788159/af42076ab3354bb49803cfba65f94bee/1.jpg?token-time=2145916800&token-hash=iSaxp_Yr2-ZiU2YVi9rcpZZj9mj3UvNSMrZr4CU4qtA%3D" alt="mewl hayabusa" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/28779508/3cd4cb7f017f4ee0864341e3464d42f9/1.png?token-time=2145916800&token-hash=eGQtR15be44kgvh8fw2Jx8Db4Bv15YBp2ldxh0EKRxA%3D" alt="S Y" width="100"></td> | ||||
| <td><img src="https://c8.patreon.com/2/200/16542964" alt="Takumi Sugita" width="100"></td> | ||||
| <td><img src="https://c8.patreon.com/2/200/17866454" alt="sikyosyounin " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5881381/6235ca5d3fb04c8e95ef5b4ff2abcc18/3.png?token-time=2145916800&token-hash=KjfQL8nf3AIf6WqzLshBYAyX44piAqOAZiYXgZS_H6A%3D" alt="YUKIMOCHI" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/38837364/9421361c54c645ac8f5fc442a40c32e9/1.png?token-time=2145916800&token-hash=TUZB48Nem3BeUPLBH6s3P6WyKBnQOy0xKaDSTBBUNzA%3D" alt="xianon" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/26340354/08834cf767b3449e93098ef73a434e2f/2.png?token-time=2145916800&token-hash=nyM8DnKRL8hR47HQ619mUzsqVRpkWZjgtgBU9RY15Uc%3D" alt="totokoro " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/19356899/496b4681d33b4520bd7688e0fd19c04d/2.jpeg?token-time=2145916800&token-hash=_sTj3dUBOhn9qwiJ7F19Qd-yWWfUqJC_0jG1h0agEqQ%3D" alt="sheeta.s " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5827393/59893c191dda408f9cabd0f20a3a5627/1.jpeg?token-time=2145916800&token-hash=i9N05vOph-eP1LTLb9_npATjYOpntL0ZsHNaZFSsPmE%3D" alt="motcha " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/20494440/540beaf2445f408ea6597bc61e077bb3/1.png?token-time=2145916800&token-hash=UJ0JQge64Bx9XmN_qYA1inMQhrWf4U91fqz7VAKJeSg%3D" alt="axtuki1 " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/13737140/1adf7835017d479280d90fe8d30aade2/1.png?token-time=2145916800&token-hash=0pdle8h5pDZrww0BDOjdz6zO-HudeGTh36a3qi1biVU%3D" alt="Satsuki Yanagi" width="100"></td> | ||||
| </tr><tr> | ||||
| <td><a href="https://www.patreon.com/Yuzulia">YuzuRyo61 </a></td> | ||||
| <td><a href="https://www.patreon.com/hs_sh_net">mewl hayabusa</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=28779508">S Y</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=16542964">Takumi Sugita</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=17866454">sikyosyounin </a></td> | ||||
| <td><a href="https://www.patreon.com/yukimochi">YUKIMOCHI</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=38837364">xianon</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=26340354">totokoro </a></td> | ||||
| </tr></table> | ||||
| <table><tr> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/19356899/496b4681d33b4520bd7688e0fd19c04d/2.jpeg?token-time=2145916800&token-hash=_sTj3dUBOhn9qwiJ7F19Qd-yWWfUqJC_0jG1h0agEqQ%3D" alt="sheeta.s " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5827393/59893c191dda408f9cabd0f20a3a5627/1.jpeg?token-time=2145916800&token-hash=i9N05vOph-eP1LTLb9_npATjYOpntL0ZsHNaZFSsPmE%3D" alt="motcha " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/20494440/540beaf2445f408ea6597bc61e077bb3/1.png?token-time=2145916800&token-hash=UJ0JQge64Bx9XmN_qYA1inMQhrWf4U91fqz7VAKJeSg%3D" alt="axtuki1 " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/13737140/1adf7835017d479280d90fe8d30aade2/1.png?token-time=2145916800&token-hash=0pdle8h5pDZrww0BDOjdz6zO-HudeGTh36a3qi1biVU%3D" alt="Satsuki Yanagi" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/17880724/311738c8a48f4a6b9443c2445a75adde/1.jpg?token-time=2145916800&token-hash=nVAntpybQrznE0rg05keLrSE6ogPKJXB13rmrJng42c%3D" alt="takimura " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/13100201/fc5be4fa90444f09a9c8a06f72385272/1.png?token-time=2145916800&token-hash=i8PjlgfOB2LPEdbtWyx8ZPsBKhGcNZqcw_FQmH71UGU%3D" alt="aqz tamaina" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/9109588/e3cffc48d20a4e43afe04123e696781d/3.png?token-time=2145916800&token-hash=T_VIUA0IFIbleZv4pIjiszZGnQonwn34sLCYFIhakBo%3D" alt="nafuchoco " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/16900731/619ab87cc08448439222631ebb26802f/1.gif?token-time=2145916800&token-hash=o27K7M02s1z-LkDUEO5Oa7cu-GviRXeOXxryi4o_6VU%3D" alt="Atsuko Tominaga" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/4389829/9f709180ac714651a70f74a82f3ffdb9/3.png?token-time=2145916800&token-hash=FTm3WVom4dJ9NwWMU4OpCL_8Yc13WiwEbKrDPyTZTPs%3D" alt="natalie" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/26144593/9514b10a5c1b42a3af58621aee213d1d/1.png?token-time=2145916800&token-hash=v1PYRsjzu4c_mndN4Hvi_dlispZJsuGRCQeNS82pUSM%3D" alt="EBISUME" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5923936/2a743cbfbff946c2af3f09026047c0da/2.png?token-time=2145916800&token-hash=h6yphW1qnM0n_NOWaf8qtszMRLXEwIxfk5beu4RxdT0%3D" alt="noellabo " width="100"></td> | ||||
| </tr><tr> | ||||
| <td><a href="https://www.patreon.com/user?u=19356899">sheeta.s </a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=5827393">motcha </a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=20494440">axtuki1 </a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=13737140">Satsuki Yanagi</a></td> | ||||
| <td><a href="https://www.patreon.com/takimura">takimura </a></td> | ||||
| <td><a href="https://www.patreon.com/aqz">aqz tamaina</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=9109588">nafuchoco </a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=16900731">Atsuko Tominaga</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=4389829">natalie</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=26144593">EBISUME</a></td> | ||||
| <td><a href="https://www.patreon.com/noellabo">noellabo </a></td> | ||||
| </tr></table> | ||||
| <table><tr> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/17880724/311738c8a48f4a6b9443c2445a75adde/1.jpg?token-time=2145916800&token-hash=nVAntpybQrznE0rg05keLrSE6ogPKJXB13rmrJng42c%3D" alt="takimura " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/13100201/fc5be4fa90444f09a9c8a06f72385272/1.png?token-time=2145916800&token-hash=i8PjlgfOB2LPEdbtWyx8ZPsBKhGcNZqcw_FQmH71UGU%3D" alt="aqz tamaina" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/28295158/cd2451bfb94a449dbf705ef4718cd355/2.jpeg?token-time=2145916800&token-hash=MRv3BxufHPuCyiBSxU5UYmLGvD6YZlhtSFRfMWg2k4U%3D" alt="012 " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/9109588/e3cffc48d20a4e43afe04123e696781d/3.png?token-time=2145916800&token-hash=T_VIUA0IFIbleZv4pIjiszZGnQonwn34sLCYFIhakBo%3D" alt="nafuchoco " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/16900731/619ab87cc08448439222631ebb26802f/1.gif?token-time=2145916800&token-hash=o27K7M02s1z-LkDUEO5Oa7cu-GviRXeOXxryi4o_6VU%3D" alt="Atsuko Tominaga" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/4389829/9f709180ac714651a70f74a82f3ffdb9/3.png?token-time=2145916800&token-hash=FTm3WVom4dJ9NwWMU4OpCL_8Yc13WiwEbKrDPyTZTPs%3D" alt="natalie " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/26144593/9514b10a5c1b42a3af58621aee213d1d/1.png?token-time=2145916800&token-hash=v1PYRsjzu4c_mndN4Hvi_dlispZJsuGRCQeNS82pUSM%3D" alt="EBISUME" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5923936/2a743cbfbff946c2af3f09026047c0da/2.png?token-time=2145916800&token-hash=h6yphW1qnM0n_NOWaf8qtszMRLXEwIxfk5beu4RxdT0%3D" alt="noellabo " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/2384390/5681180e1efb46a8b28e0e8d4c8b9037/1.jpg?token-time=2145916800&token-hash=SJcMy-Q1BcS940-LFUVOMfR7-5SgrzsEQGhYb3yowFk%3D" alt="CG " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/18072312/98e894d960314fa7bc236a72a39488fe/1.jpg?token-time=2145916800&token-hash=7bkMqTwHPRsJPGAq42PYdDXDZBVGLqdgr1ZmBxX8GFQ%3D" alt="Hekovic " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/24641572/b4fd175424814f15b0ca9178d2d2d2e4/1.png?token-time=2145916800&token-hash=e2fyqdbuJbpCckHcwux7rbuW6OPkKdERcus0u2wIEWU%3D" alt="uroco @99" width="100"></td> | ||||
| </tr><tr> | ||||
| <td><a href="https://www.patreon.com/takimura">takimura </a></td> | ||||
| <td><a href="https://www.patreon.com/aqz">aqz tamaina</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=28295158">012 </a></td> | ||||
| <td><a href="https://www.patreon.com/nijimiss">nafuchoco </a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=16900731">Atsuko Tominaga</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=4389829">natalie </a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=26144593">EBISUME</a></td> | ||||
| <td><a href="https://www.patreon.com/noellabo">noellabo </a></td> | ||||
| <td><a href="https://www.patreon.com/Corset">CG </a></td> | ||||
| <td><a href="https://www.patreon.com/hekovic">Hekovic </a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=24641572">uroco @99</a></td> | ||||
| </tr></table> | ||||
| <table><tr> | ||||
| <td><img src="https://c8.patreon.com/2/200/14661394" alt="Chandler " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5731881/4b6038e6cda34c04b83a5fcce3806a93/1.png?token-time=2145916800&token-hash=hBayGfOmQH3kRMdNnDe4oCZD_9fsJWSt29xXR3KRMVk%3D" alt="Nokotaro Takeda" width="100"></td> | ||||
| <td><img src="https://c8.patreon.com/2/200/23932002" alt="nenohi " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/9481273/7fa89168e72943859c3d3c96e424ed31/4.jpeg?token-time=2145916800&token-hash=5w1QV1qXe-NdWbdFmp1H7O_-QBsSiV0haumk3XTHIEg%3D" alt="Efertone " width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/12531784/93a45137841849329ba692da92ac7c60/1.jpeg?token-time=2145916800&token-hash=vGe7wXGqmA8Q7m-kDNb6fyGdwk-Dxk4F-ut8ZZu51RM%3D" alt="Takashi Shibuya" width="100"></td> | ||||
| </tr><tr> | ||||
| <td><a href="https://www.patreon.com/Corset">CG </a></td> | ||||
| <td><a href="https://www.patreon.com/hekovic">Hekovic </a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=24641572">uroco @99</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=14661394">Chandler </a></td> | ||||
| <td><a href="https://www.patreon.com/takenoko">Nokotaro Takeda</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=23932002">nenohi </a></td> | ||||
| <td><a href="https://www.patreon.com/efertone">Efertone </a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=12531784">Takashi Shibuya</a></td> | ||||
| </tr></table> | ||||
|  | ||||
| **Last updated:** Thu, 07 May 2020 18:00:08 UTC | ||||
| **Last updated:** Sun, 26 Jul 2020 07:00:10 UTC | ||||
| <!-- PATREON_END --> | ||||
|  | ||||
| [backer-url]: #backers | ||||
|   | ||||
| @@ -1,3 +1,7 @@ | ||||
| files: | ||||
|   - source: /locales/ja-JP.yml | ||||
|     translation: /locales/%locale%.yml | ||||
|     update_option: update_as_unapproved | ||||
|   - source: /src/docs/ja-JP/*.md | ||||
|     translation: /src/docs/%locale%/%original_file_name% | ||||
|     update_option: update_as_unapproved | ||||
|   | ||||
| @@ -13,6 +13,8 @@ services: | ||||
|     networks: | ||||
|       - internal_network | ||||
|       - external_network | ||||
|     volumes: | ||||
|       - ./files:/misskey/files | ||||
|  | ||||
|   redis: | ||||
|     restart: always | ||||
|   | ||||
| @@ -4,3 +4,30 @@ Docs for users are located in `src/docs`. | ||||
|  | ||||
| これらのドキュメントはMisskeyの開発者またはMisskeyインスタンス運営者向けです。 | ||||
| 利用者向けのドキュメントは`src/docs`にあります。 | ||||
|  | ||||
| 这些文档是为 Misskey 的贡献者,或是 Misskey 实例的管理者准备的。 | ||||
| 为用户准备的文档放置在 `src/docs` 文件夹中。 | ||||
|  | ||||
| ## 日本語版 | ||||
|  | ||||
| - [Misskey構築の手引き](./setup.ja.md) | ||||
| - [運営ガイド](./manage.ja.md) | ||||
| - [Dockerを使ったMisskey構築方法](./docker.ja.md) | ||||
|  | ||||
| ## English Version | ||||
|  | ||||
| - [Misskey Setup and Installation Guide](./setup.en.md) | ||||
| - [Management guide](./manage.en.md) | ||||
| - [Docker Guide](./docker.en.md) | ||||
|  | ||||
| ## Française Version | ||||
|  | ||||
| - [Guide d'installation et de configuration de Misskey](./setup.fr.md) | ||||
| - [Guide d'administration](./manage.fr.md) | ||||
| - [Guide Docker](./docker.fr.md) | ||||
|  | ||||
| ## 简体中文版 | ||||
|  | ||||
| - [Misskey 设置和安装指南](./setup.zh.md) | ||||
| - [运营指南](./manage.zh.md) | ||||
| - [Docker 部署指南](./docker.zh.md) | ||||
|   | ||||
| @@ -3,7 +3,8 @@ Docker Guide | ||||
|  | ||||
| This guide describes how to install and setup Misskey with Docker. | ||||
|  | ||||
| [Japanese version also available - 日本語版もあります](./docker.ja.md) | ||||
| - [Japanese version also available - 日本語版もあります](./docker.ja.md) | ||||
| - [Simplified Chinese version also available - 简体中文版同样可用](./docker.zh.md) | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
|   | ||||
| @@ -3,8 +3,9 @@ Guide Docker | ||||
|  | ||||
| Ce guide explique comment installer et configurer Misskey avec Docker. | ||||
|  | ||||
| [Version japonaise également disponible - Japanese version also available - 日本語版もあります](./docker.ja.md)   | ||||
| [Version anglaise également disponible - English version also available - 英語版もあります](./docker.en.md) | ||||
| - [Version japonaise également disponible - Japanese version also available - 日本語版もあります](./docker.ja.md)   | ||||
| - [Version anglaise également disponible - English version also available - 英語版もあります](./docker.en.md) | ||||
| - [Version Chinois simplifié également disponible - Simplified Chinese version also available - 简体中文版同样可用](./docker.zh.md) | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
|   | ||||
| @@ -3,7 +3,8 @@ Dockerを使ったMisskey構築方法 | ||||
|  | ||||
| このガイドはDockerを使ったMisskeyセットアップ方法について解説します。 | ||||
|  | ||||
| [英語版もあります - English version also available](./docker.en.md) | ||||
| - [英語版もあります - English version also available](./docker.en.md) | ||||
| - [简体中文版同样可用 - Simplified Chinese version also available](./docker.zh.md) | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
|   | ||||
							
								
								
									
										96
									
								
								docs/docker.zh.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										96
									
								
								docs/docker.zh.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,96 @@ | ||||
| Docker 部署指南 | ||||
| ================================================================ | ||||
|  | ||||
| 这份指南描述了如何使用Docker安装并设置 Misskey 。 | ||||
|  | ||||
| - [日本語版もあります - Japanese version also available](./docker.ja.md) | ||||
| - [英語版もあります - English version also available](./docker.en.md) | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| *1.* 下载 Misskey | ||||
| ---------------------------------------------------------------- | ||||
| 1. 克隆 Misskey 项目的 master 分支。 | ||||
|  | ||||
| 	`git clone -b master git://github.com/syuilo/misskey.git` | ||||
|  | ||||
| 2. 进入 misskey 文件夹。 | ||||
|  | ||||
| 	`cd misskey` | ||||
|  | ||||
| 3. 检查 [最新发布版](https://github.com/syuilo/misskey/releases/latest) 标签。 | ||||
|  | ||||
| 	`git checkout master` | ||||
|  | ||||
| *2.* 配置 Misskey | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| 可以按照如下方式创建配置文件: | ||||
|  | ||||
| ``` bash | ||||
| cd .config | ||||
| cp example.yml default.yml | ||||
| cp docker_example.env docker.env | ||||
| ``` | ||||
|  | ||||
| ### `default.yml` | ||||
|  | ||||
| 这个文件的编辑工作基本与非 Docker 环境的版本相同。 | ||||
| 但请注意, Postgresql、 Redis 和 Elasticsearch 的 **主机名(hostname)** 配置不应该是 `localhost` ,它们被设置在 `docker-compose.yml` 文件中。 | ||||
| 以下是默认的主机名: | ||||
|  | ||||
| | 服务          | 主机名   | | ||||
| |---------------|----------| | ||||
| | Postgresql    | `db`     | | ||||
| | Redis         | `redis`  | | ||||
| | Elasticsearch | `es`     | | ||||
|  | ||||
| ### `docker.env` | ||||
|  | ||||
| 在这个文件中配置 Postgresql 。 | ||||
| 至少需要如下这些配置: | ||||
|  | ||||
| | 名称                |  描述         | | ||||
| |---------------------|---------------| | ||||
| | `POSTGRES_PASSWORD` |  数据库密码   | | ||||
| | `POSTGRES_USER`     |  数据库用户名 | | ||||
| | `POSTGRES_DB`       |  数据库名     | | ||||
|  | ||||
| *3.* 配置 Docker | ||||
| ---------------------------------------------------------------- | ||||
| 编辑 `docker-compose.yml` 文件。 | ||||
|  | ||||
| *4.* 构建 Misskey | ||||
| ---------------------------------------------------------------- | ||||
| 使用如下的方式构建Misskey: | ||||
|  | ||||
| `docker-compose build` | ||||
|  | ||||
| *5.* 初始化数据库 | ||||
| ---------------------------------------------------------------- | ||||
| ``` bash | ||||
| docker-compose run --rm web yarn run init | ||||
| ``` | ||||
|  | ||||
| *6.* 完成了! | ||||
| ---------------------------------------------------------------- | ||||
| 干得不错!现在您拥有了一个可以运行Misskey的环境啦。 | ||||
|  | ||||
| ### 正常启动 | ||||
| 只需要 `docker-compose up -d` 即可。玩得愉快! | ||||
|  | ||||
| ### 如何将您的 Misskey 服务器升级至最新版本 | ||||
| 1. `git stash` | ||||
| 2. `git checkout master` | ||||
| 3. `git pull` | ||||
| 4. `git stash pop` | ||||
| 5. `docker-compose build` | ||||
| 6. 检查 [更新日志](../CHANGELOG.md) 以获取升级迁移信息。 | ||||
| 7. `docker-compose stop && docker-compose up -d` | ||||
|  | ||||
| ### 如何执行 [控制台指令](manage.zh.md): | ||||
| `docker-compose run --rm web node built/tools/mark-admin @example` | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| 如果您有任何疑问或是困惑,欢迎与我们联系! | ||||
| @@ -53,7 +53,6 @@ server { | ||||
|         proxy_set_header X-Real-IP $remote_addr; | ||||
|         proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
|         proxy_set_header X-Forwarded-Proto https; | ||||
|         proxy_set_header Accept-Encoding ""; | ||||
|         proxy_http_version 1.1; | ||||
|         proxy_redirect off; | ||||
|  | ||||
|   | ||||
							
								
								
									
										14
									
								
								docs/manage.zh.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								docs/manage.zh.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| # 运营指南 | ||||
|  | ||||
| ## 检查任务队列的状态 | ||||
| 即将到来…… | ||||
|  | ||||
| ## 设置用户为管理员 | ||||
| ``` shell | ||||
| node built/tools/mark-admin (用户名) | ||||
| ``` | ||||
|  | ||||
| 样例 | ||||
| ``` shell | ||||
| node built/tools/mark-admin @syuilo | ||||
| ``` | ||||
| @@ -4,7 +4,8 @@ Misskey Setup and Installation Guide | ||||
| We thank you for your interest in setting up your Misskey server! | ||||
| This guide describes how to install and setup Misskey. | ||||
|  | ||||
| [Japanese version also available - 日本語版もあります](./setup.ja.md) | ||||
| - [Japanese version also available - 日本語版もあります](./setup.ja.md) | ||||
| - [Simplified Chinese version also available - 简体中文版同样可用](./setup.zh.md) | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| @@ -22,8 +23,8 @@ adduser --disabled-password --disabled-login misskey | ||||
| Please install and setup these softwares: | ||||
|  | ||||
| #### Dependencies :package: | ||||
| * **[Node.js](https://nodejs.org/en/)** >= 11.10.1 | ||||
| * **[PostgreSQL](https://www.postgresql.org/)** >= 10 | ||||
| * **[Node.js](https://nodejs.org/en/)** (12.x, 14.x) | ||||
| * **[PostgreSQL](https://www.postgresql.org/)** (>= 10) | ||||
| * **[Redis](https://redis.io/)** | ||||
|  | ||||
| ##### Optional | ||||
|   | ||||
| @@ -4,7 +4,9 @@ Guide d'installation et de configuration de Misskey | ||||
| Nous vous remerçions de l'intrêt que vous manifestez pour l'installation de votre propre instance Misskey ! | ||||
| Ce guide décrit les étapes à suivre afin d'installer et de configurer une instance Misskey. | ||||
|  | ||||
| [La version en japonnais est également disponible sur - 日本語版もあります](./setup.ja.md) | ||||
| - [La version en japonnais est également disponible sur - 日本語版もあります](./setup.ja.md) | ||||
| - [Version anglaise également disponible - English version also available - 英語版もあります](./setup.en.md) | ||||
| - [Version Chinois simplifié également disponible - Simplified Chinese version also available - 简体中文版同样可用](./setup.zh.md) | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| @@ -22,8 +24,8 @@ adduser --disabled-password --disabled-login misskey | ||||
| Installez les paquets suivants : | ||||
|  | ||||
| #### Dépendences :package: | ||||
| * **[Node.js](https://nodejs.org/en/)** >= 11.10.1 | ||||
| * **[PostgreSQL](https://www.postgresql.org/)** >= 10 | ||||
| * **[Node.js](https://nodejs.org/en/)** (12.x, 14.x) | ||||
| * **[PostgreSQL](https://www.postgresql.org/)** (>= 10) | ||||
| * **[Redis](https://redis.io/)** | ||||
|  | ||||
| ##### Optionnels | ||||
|   | ||||
| @@ -4,7 +4,8 @@ Misskey構築の手引き | ||||
| Misskeyサーバーの構築にご関心をお寄せいただきありがとうございます! | ||||
| このガイドではMisskeyのインストール・セットアップ方法について解説します。 | ||||
|  | ||||
| [英語版もあります - English version also available](./setup.en.md) | ||||
| - [英語版もあります - English version also available](./setup.en.md) | ||||
| - [简体中文版同样可用 - Simplified Chinese version also available](./setup.zh.md) | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| @@ -22,7 +23,7 @@ adduser --disabled-password --disabled-login misskey | ||||
| これらのソフトウェアをインストール・設定してください: | ||||
|  | ||||
| #### 依存関係 :package: | ||||
| * **[Node.js](https://nodejs.org/en/)** (11.10.1以上) | ||||
| * **[Node.js](https://nodejs.org/en/)** (12.x, 14.x) | ||||
| * **[PostgreSQL](https://www.postgresql.org/)** (10以上) | ||||
| * **[Redis](https://redis.io/)** | ||||
|  | ||||
|   | ||||
							
								
								
									
										146
									
								
								docs/setup.zh.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										146
									
								
								docs/setup.zh.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,146 @@ | ||||
| Misskey 设置和安装指南 | ||||
| ================================================================ | ||||
|  | ||||
| 非常感谢您对构建 Misskey 服务器的关注! | ||||
| 这份指南描述了 Misskey 的安装与设置流程。 | ||||
|  | ||||
| - [日本語版もあります - Japanese version also available](./setup.ja.md) | ||||
| - [英語版もあります - English version also available](./setup.en.md) | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| *1.* 创建 Misskey 用户 | ||||
| ---------------------------------------------------------------- | ||||
| 直接使用 root 用户来运行 misskey 也许并不是一个好主意,因此我们有必要创建一个专用的用户。 | ||||
| 以 Debian 为例: | ||||
|  | ||||
| ``` bash | ||||
| adduser --disabled-password --disabled-login misskey | ||||
| ``` | ||||
|  | ||||
| *2.* 安装依赖 | ||||
| ---------------------------------------------------------------- | ||||
| 请安装并设置如下这些软件: | ||||
|  | ||||
| #### Dependencies :package: | ||||
| * **[Node.js](https://nodejs.org/en/)** (12.x, 14.x) | ||||
| * **[PostgreSQL](https://www.postgresql.org/)** (>= 10) | ||||
| * **[Redis](https://redis.io/)** | ||||
|  | ||||
| ##### Optional | ||||
| * [Yarn](https://yarnpkg.com/) *可选,但出于安全因素考虑还是推荐安装。如果您没有安装, 您需要使用 `npx yarn` 来代替 `yarn`.* | ||||
| * [Elasticsearch](https://www.elastic.co/) - 为了启用搜索功能,这个搜索引擎是有必要的。 | ||||
| * [FFmpeg](https://www.ffmpeg.org/) | ||||
|  | ||||
| *3.* 安装 Misskey | ||||
| ---------------------------------------------------------------- | ||||
| 1. 连接至 misskey 用户. | ||||
|  | ||||
| 	`su - misskey` | ||||
|  | ||||
| 2. 克隆 Misskey 项目的 master 分支。 | ||||
|  | ||||
| 	`git clone -b master git://github.com/syuilo/misskey.git` | ||||
|  | ||||
| 3. 进入 misskey 文件夹。 | ||||
|  | ||||
| 	`cd misskey` | ||||
|  | ||||
| 4. 检查 [最新发布版](https://github.com/syuilo/misskey/releases/latest) 标签。 | ||||
|  | ||||
| 	`git checkout master` | ||||
|  | ||||
| 5. 安装 Misskey 的依赖。 | ||||
|  | ||||
| 	`yarn` | ||||
|  | ||||
| *4.* 配置 Misskey | ||||
| ---------------------------------------------------------------- | ||||
| 1. 复制 `.config/example.yml` 并重命名为 `default.yml`。 | ||||
|  | ||||
| 	`cp .config/example.yml .config/default.yml` | ||||
|  | ||||
| 2. 编辑 `default.yml` | ||||
|  | ||||
| *5.* 构建 Misskey | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| 使用如下的指令构建 Misskey : | ||||
|  | ||||
| `NODE_ENV=production yarn build` | ||||
|  | ||||
| 如果您使用的是 Debian , 您需要安装 `build-essential`, `python` 环境包。 | ||||
|  | ||||
| 如果您仍然遇到有关某些模块的错误,您可以使用 node-gyp: | ||||
|  | ||||
| 1. `npx node-gyp configure` | ||||
| 2. `npx node-gyp build` | ||||
| 3. `NODE_ENV=production yarn build` | ||||
|  | ||||
| *6.* 初始化数据库 | ||||
| ---------------------------------------------------------------- | ||||
| ``` bash | ||||
| yarn run init | ||||
| ``` | ||||
|  | ||||
| *7.* 完成了! | ||||
| ---------------------------------------------------------------- | ||||
| 干得不错!现在您拥有了一个可以运行Misskey的环境啦。 | ||||
|  | ||||
| ### 正常启动 | ||||
| 只需要 `NODE_ENV=production npm start` 即可。玩得愉快! | ||||
|  | ||||
| ### 使用 systemd 来启动 | ||||
|  | ||||
| 1. 在此处创建一个 systemd 服务: | ||||
|  | ||||
| 	`/etc/systemd/system/misskey.service` | ||||
|  | ||||
| 2. 编辑它,粘贴如下内容并保存: | ||||
|  | ||||
| 	``` | ||||
| 	[Unit] | ||||
| 	Description=Misskey daemon | ||||
|  | ||||
| 	[Service] | ||||
| 	Type=simple | ||||
| 	User=misskey | ||||
| 	ExecStart=/usr/bin/npm start | ||||
| 	WorkingDirectory=/home/misskey/misskey | ||||
| 	Environment="NODE_ENV=production" | ||||
| 	TimeoutSec=60 | ||||
| 	StandardOutput=syslog | ||||
| 	StandardError=syslog | ||||
| 	SyslogIdentifier=misskey | ||||
| 	Restart=always | ||||
|  | ||||
| 	[Install] | ||||
| 	WantedBy=multi-user.target | ||||
| 	``` | ||||
|  | ||||
| 3. 重启 systemd 并设置 misskey 服务自动启动: | ||||
|  | ||||
| 	`systemctl daemon-reload ; systemctl enable misskey` | ||||
|  | ||||
| 4. 启动 misskey 服务: | ||||
|  | ||||
| 	`systemctl start misskey` | ||||
|  | ||||
| 您可以使用 `systemctl status misskey` 来检查服务是否正在运行。 | ||||
|  | ||||
| ### 如何将您的 Misskey 服务器升级至最新版本 | ||||
| 1. `git checkout master` | ||||
| 2. `git pull` | ||||
| 3. `yarn install` | ||||
| 4. `NODE_ENV=production yarn build` | ||||
| 5. `yarn migrate` | ||||
| 6. 重启您的 Misskey 进程来应用改变。 | ||||
| 7. 尽情享受吧! | ||||
|  | ||||
| 如果您在更新时遇到任何问题,请尝试以下操作: | ||||
| 1. `yarn clean` 或是 `yarn cleanall` | ||||
| 2. 重试升级 (请不要忘记 `yarn install` ) | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| 如果您有任何疑问或是困惑,欢迎与我们联系! | ||||
							
								
								
									
										44
									
								
								gulpfile.ts
									
									
									
									
									
								
							
							
						
						
									
										44
									
								
								gulpfile.ts
									
									
									
									
									
								
							| @@ -7,11 +7,11 @@ import * as gulp from 'gulp'; | ||||
| import * as ts from 'gulp-typescript'; | ||||
| import * as rimraf from 'rimraf'; | ||||
| import * as rename from 'gulp-rename'; | ||||
| const cleanCSS = require('gulp-clean-css'); | ||||
| const sass = require('gulp-dart-sass'); | ||||
| const fiber = require('fibers'); | ||||
| import * as replace from 'gulp-replace'; | ||||
| const terser = require('gulp-terser'); | ||||
| const cssnano = require('gulp-cssnano'); | ||||
|  | ||||
| const locales = require('./locales'); | ||||
| const locales: { [x: string]: any } = require('./locales'); | ||||
| const meta = require('./package.json'); | ||||
|  | ||||
| gulp.task('build:ts', () => { | ||||
| @@ -28,21 +28,39 @@ gulp.task('build:copy:views', () => | ||||
| 	gulp.src('./src/server/web/views/**/*').pipe(gulp.dest('./built/server/web/views')) | ||||
| ); | ||||
|  | ||||
| gulp.task('build:copy:fonts', () => | ||||
| 	gulp.src('./node_modules/three/examples/fonts/**/*').pipe(gulp.dest('./built/client/assets/fonts/')) | ||||
| ); | ||||
|  | ||||
| gulp.task('build:copy:locales', cb => { | ||||
| 	fs.mkdirSync('./built/client/assets/locales', { recursive: true }); | ||||
|  | ||||
| 	const v = { '_version_': meta.version }; | ||||
|  | ||||
| 	for (const [lang, locale] of Object.entries(locales)) { | ||||
| 		fs.writeFileSync(`./built/client/assets/locales/${lang}.${meta.version}.json`, JSON.stringify(locale), 'utf-8'); | ||||
| 		fs.writeFileSync(`./built/client/assets/locales/${lang}.${meta.version}.json`, JSON.stringify({ ...locale, ...v }), 'utf-8'); | ||||
| 	} | ||||
|  | ||||
| 	cb(); | ||||
| }); | ||||
|  | ||||
| gulp.task('build:copy:fonts', () => | ||||
| 	gulp.src('./node_modules/three/examples/fonts/**/*').pipe(gulp.dest('./built/client/assets/fonts/')) | ||||
| ); | ||||
| gulp.task('build:client:script', () => { | ||||
| 	return gulp.src(['./src/server/web/boot.js']) | ||||
| 		.pipe(replace('VERSION', JSON.stringify(meta.version))) | ||||
| 		.pipe(replace('LANGS', JSON.stringify(Object.keys(locales)))) | ||||
| 		.pipe(terser({ | ||||
| 			toplevel: true | ||||
| 		})) | ||||
| 		.pipe(gulp.dest('./built/server/web/')); | ||||
| }); | ||||
|  | ||||
| gulp.task('build:copy', gulp.parallel('build:copy:views', 'build:copy:locales', 'build:copy:fonts', () => | ||||
| gulp.task('build:client:style', () => { | ||||
| 	return gulp.src(['./src/server/web/style.css']) | ||||
| 		.pipe(cssnano()) | ||||
| 		.pipe(gulp.dest('./built/server/web/')); | ||||
| }); | ||||
|  | ||||
| gulp.task('build:copy', gulp.parallel('build:copy:locales', 'build:copy:views', 'build:client:script', 'build:client:style', 'build:copy:fonts', () => | ||||
| 	gulp.src([ | ||||
| 		'./src/emojilist.json', | ||||
| 		'./src/server/web/views/**/*', | ||||
| @@ -59,13 +77,6 @@ gulp.task('cleanall', gulp.parallel('clean', cb => | ||||
| 	rimraf('./node_modules', cb) | ||||
| )); | ||||
|  | ||||
| gulp.task('build:client:styles', () => | ||||
| 	gulp.src('./src/client/style.scss') | ||||
| 		.pipe(sass({ fiber })) | ||||
| 		.pipe(cleanCSS()) | ||||
| 		.pipe(gulp.dest('./built/client/assets/')) | ||||
| ); | ||||
|  | ||||
| gulp.task('copy:client', () => | ||||
| 		gulp.src([ | ||||
| 			'./assets/**/*', | ||||
| @@ -85,7 +96,6 @@ gulp.task('copy:docs', () => | ||||
| ); | ||||
|  | ||||
| gulp.task('build:client', gulp.parallel( | ||||
| 	'build:client:styles', | ||||
| 	'copy:client', | ||||
| 	'copy:docs' | ||||
| )); | ||||
|   | ||||
							
								
								
									
										559
									
								
								locales/ar-SA.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										559
									
								
								locales/ar-SA.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,559 @@ | ||||
| --- | ||||
| _lang_: "العربية" | ||||
| introMisskey: "اهلا بك! ميسكي هو منصة تدوين مصغر لا مركزية ومفتوحة المصدر.\nيمكنك مشاركة \"ملاحظات\" عن ما يجري حولك، وإخبار الجميع عن نفسك 📡\nتسمح لك \"الانفعالات\" بتعبير عن شعورك حول ملاحظات الآخرين 👍\nاكتشف عالمًا جديدًا 🚀" | ||||
| monthAndDay: "{day}/{month}" | ||||
| search: "البحث" | ||||
| notifications: "الإشعارات" | ||||
| username: "اسم المستخدم" | ||||
| password: "الكلمة السرية" | ||||
| fetchingAsApObject: "جارٍ جلبه مِن الفديفرس…" | ||||
| ok: " حسناً" | ||||
| gotIt: "فهِمت" | ||||
| cancel: " إلغاء" | ||||
| enterUsername: "أدخِل إسم مسخدم" | ||||
| noNotes: "لم يتم العثور على أية ملاحظات" | ||||
| noNotifications: "ليس هناك أية اشعارات" | ||||
| instance: "مثيل الخادم" | ||||
| settings: "الاعدادات" | ||||
| basicSettings: "الاعدادات الأساسية" | ||||
| otherSettings: "إعدادات أخرى" | ||||
| openInWindow: "افتح في نافذة جديدة" | ||||
| profile: "الملف التعريفي" | ||||
| timeline: "الخيط الزمني" | ||||
| noAccountDescription: "لم يكتب هذا المستخدم سيرته بعد." | ||||
| login: "لِج" | ||||
| loggingIn: "جارٍ تسجيل الدخول" | ||||
| logout: "الخروج" | ||||
| signup: "أنشئ حسابًا" | ||||
| uploading: "عملية الإرسال جارية" | ||||
| save: "حفظ" | ||||
| users: "المستخدمون" | ||||
| addUser: "اضافة مستخدم" | ||||
| favorite: "إضافة إلى المفضلة" | ||||
| favorites: "المفضلات" | ||||
| unfavorite: "إزالة من المفضلة" | ||||
| pin: "دبّسها على الصفحة الشخصية" | ||||
| unpin: "ألغ تثبيتها من ملفك الشخصي" | ||||
| copyContent: "انسخ المحتوى" | ||||
| copyLink: "انسخ الرابط" | ||||
| delete: "حذف" | ||||
| deleteAndEdit: "إزالة وإعادة الصياغة" | ||||
| deleteAndEditConfirm: "أمتأكد من حذف الملاحظة؟ ستفقد كل مشاركاتها، والتفاعلات، والردود عليها." | ||||
| addToList: "أضفه إلى قائمة" | ||||
| sendMessage: "أرسل رسالة" | ||||
| copyUsername: "انسخ اسم المستخدم" | ||||
| searchUser: "ابحث عن مستخدمين" | ||||
| reply: "رد" | ||||
| loadMore: "عرض المزيد" | ||||
| youGotNewFollower: "يتابعك" | ||||
| receiveFollowRequest: "تلقيت طلب متابعة" | ||||
| followRequestAccepted: "قُبل طلب المتابعة" | ||||
| mention: "أشر الى" | ||||
| mentions: "الإشارات" | ||||
| directNotes: "الملاحظات المباشرة" | ||||
| importAndExport: "إستورد / صدر" | ||||
| import: "استيراد" | ||||
| export: "تصدير" | ||||
| files: "الملفات" | ||||
| download: "تنزيل" | ||||
| driveFileDeleteConfirm: "أمتأكد من حذف ملف {name}؟ كل الملاحظات المُرفق بها هذا الملف ستحذف." | ||||
| unfollowConfirm: "أمتأكد من إلغاء متابعة {name}؟" | ||||
| lists: "القوائم" | ||||
| noLists: "ليس لديك أية قائمة" | ||||
| note: "ملاحظة" | ||||
| notes: "الملاحظات" | ||||
| following: "المتابَعون" | ||||
| followers: "المتابِعين" | ||||
| followsYou: "يتابعك" | ||||
| createList: "إنشاء قائمة" | ||||
| manageLists: "إدارة القوائم" | ||||
| error: "خطأ" | ||||
| somethingHappened: "حدث خطأ" | ||||
| retry: "حاول مجددًا" | ||||
| pageLoadError: "فشل تحميل الصفحة" | ||||
| enterListName: "اسم القائمة" | ||||
| privacy: "الخصوصية" | ||||
| makeFollowManuallyApprove: "القبول يدويا طلبات الإشتراك" | ||||
| defaultNoteVisibility: "مدى الرؤية الافتراضي" | ||||
| follow: "تابِع" | ||||
| followRequest: "طلب اشتراك" | ||||
| followRequests: "طلبات الإشتراك" | ||||
| unfollow: "إلغاء الاشتراك" | ||||
| followRequestPending: "طلبات الإشتراك المعلّقة" | ||||
| enterEmoji: "أدخل إيموجي" | ||||
| unrenote: "إلغاء مشاركة الملاحظة" | ||||
| quote: "اقتبس" | ||||
| pinnedNote: "ملاحظة مدبسة" | ||||
| you: "أنت" | ||||
| clickToShow: "اضغط للعرض" | ||||
| sensitive: "محتوى حساس" | ||||
| add: "إضافة" | ||||
| reaction: "تفاعل" | ||||
| rememberNoteVisibility: "تذكر إعدادت مدى رؤية الملاحظات" | ||||
| attachCancel: "أزل المرفق" | ||||
| enterFileName: "ادخل اسم الملف" | ||||
| mute: "اكتم" | ||||
| unmute: "إلغاء الكتم" | ||||
| block: "احجب" | ||||
| unblock: "إلغاء الحجب" | ||||
| suspend: "علِق" | ||||
| unsuspend: "ألغ التعليق" | ||||
| blockConfirm: "أمتأكد من حجب هذا الحساب؟" | ||||
| unblockConfirm: "أمتأكد من إلغاء حجب هذا الحساب؟" | ||||
| selectList: "اختر قائمة" | ||||
| editWidgetsExit: "تم" | ||||
| customEmojis: "إيموجي مخصص" | ||||
| addEmoji: "إضافة إيموجي" | ||||
| cacheRemoteFiles: "خزن مؤقتا الملفات البعيدة" | ||||
| autoAcceptFollowed: "اقبل طلبات المتابعة تلقائيا من الحسابات المتابَعة" | ||||
| addAcount: "إضافة حساب" | ||||
| loginFailed: "فشل الولوج" | ||||
| showOnRemote: "رؤيته على مثيل الخادم البُعدي" | ||||
| general: "الرئيسية" | ||||
| wallpaper: "خلفية الشاشة" | ||||
| setWallpaper: "استخدم خلفية الشاشة" | ||||
| removeWallpaper: "إزالة خلفية الشاشة" | ||||
| searchWith: "البحث: {q}" | ||||
| youHaveNoLists: "لا تمتلك أية قائمة" | ||||
| followConfirm: "أتريد متابعة {name}؟" | ||||
| proxyAccount: "حساب وكيل البروكسي" | ||||
| host: "المضيف" | ||||
| selectUser: "حدّد مستخدمًا" | ||||
| recipient: "المرسَل إليه·ها" | ||||
| annotation: "التعليقات" | ||||
| federation: "الفديرالية" | ||||
| instances: "مثيل الخادم" | ||||
| latestRequestSentAt: "آخر طلب أرسِل في" | ||||
| latestRequestReceivedAt: "آخر طلب تُلقي في" | ||||
| storageUsage: "مساحة التخزين المستخدمة" | ||||
| charts: "المنحنيات البيانية" | ||||
| perHour: "في الساعة" | ||||
| perDay: "في اليوم" | ||||
| stopActivityDelivery: "وقف إرسال النشاط" | ||||
| blockThisInstance: "احجب مثيل الخادم هذا" | ||||
| operations: "الإجراءات" | ||||
| software: "البرنامج" | ||||
| version: "الإصدار" | ||||
| metadata: "البيانات الوصفية" | ||||
| withNFiles: "{n} ملف (ملفات)" | ||||
| monitor: "شاشة التحكم" | ||||
| jobQueue: "قائمة الانتظار" | ||||
| cpuAndMemory: "وحدة المعالجة المركزية والذاكرة" | ||||
| network: "الشبكة" | ||||
| disk: "قرص التخزين" | ||||
| instanceInfo: "معلومات مثيل الخادم" | ||||
| statistics: "الإحصائيات" | ||||
| clearQueue: "تفريغ قائمة الإنتظار" | ||||
| muteAndBlock: "تم كتمها / تم حجبها" | ||||
| mutedUsers: "الحسابات التي تم كتمها" | ||||
| blockedUsers: "الحسابات التي تم حظرها" | ||||
| noUsers: "ليس هناك مستخدمون" | ||||
| editProfile: "تعديل الملف التعريفي" | ||||
| noteDeleteConfirm: "هل تريد حذف هذه الملاحظة؟" | ||||
| pinLimitExceeded: "لا يمكنك تدبيس الملاحظات بعد الآن." | ||||
| intro: "لقد انتهت عملية تنصيب Misskey. الرجاء إنشاء حساب إداري." | ||||
| done: "تمّ" | ||||
| processing: "المعالجة جارية" | ||||
| preview: "معاينة" | ||||
| default: "افتراضي" | ||||
| noCustomEmojis: "ليس هناك إيموجيات" | ||||
| federating: "الفديرالية جارية" | ||||
| blocked: "محجوب" | ||||
| suspended: "مُعلّق" | ||||
| all: "الكل" | ||||
| notResponding: "لا يستجيب" | ||||
| changePassword: "تغيير الكلمة السرية" | ||||
| security: "الأمان" | ||||
| more: "المزيد!" | ||||
| featured: "المتداولة" | ||||
| usernameOrUserId: "اسم المستخدم أو معرّفه" | ||||
| noSuchUser: "لم يُعثَر على المستخدم" | ||||
| lookup: "البحث" | ||||
| announcements: "الإعلانات" | ||||
| imageUrl: "عنوان URL للصورة" | ||||
| remove: "حذف" | ||||
| removed: "تم حذفه بنجاح" | ||||
| removeAreYouSure: "متأكد من أنك تريد حذف {x}؟" | ||||
| deleteAreYouSure: "متأكد من أنك تريد حذف {x}؟" | ||||
| saved: "تم حفظه" | ||||
| messaging: "الدردشة" | ||||
| upload: "تحميل" | ||||
| fromDrive: "من المخزن" | ||||
| fromUrl: "من عنوان URL" | ||||
| uploadFromUrl: "التحميل عبر URL" | ||||
| explore: "استكشاف" | ||||
| games: "ألعاب Misskey" | ||||
| messageRead: "مقروءة" | ||||
| startMessaging: "ابدأ الدردشة" | ||||
| tos: "شروط الخدمة" | ||||
| start: "البداية" | ||||
| home: "الرئيسي" | ||||
| activity: "النشاط" | ||||
| images: "الصور" | ||||
| birthday: "تاريخ الميلاد" | ||||
| yearsOld: "{age} سنة" | ||||
| registeredDate: "انظم في" | ||||
| location: "المكان" | ||||
| theme: "المظهر" | ||||
| themeForLightMode: "الحلة في الوضع الفاتح" | ||||
| themeForDarkMode: "الحلة في الوضع الداكن" | ||||
| light: "فاتح" | ||||
| dark: "داكن" | ||||
| lightThemes: "الحلة الفاتحة" | ||||
| darkThemes: "الحلة الداكنة" | ||||
| drive: "قرص التخرين" | ||||
| fileName: "اسم الملف" | ||||
| selectFile: "اختر ملفًا" | ||||
| selectFiles: "اختر ملفات" | ||||
| selectFolder: "اختر مجلدًا" | ||||
| selectFolders: "اختر مجلدات" | ||||
| renameFile: "إعادة تسمية الملف" | ||||
| folderName: "اسم المجلد" | ||||
| createFolder: "أنشئ مجلدًا" | ||||
| renameFolder: "إعادة تسمية المجلد" | ||||
| deleteFolder: "احذف هذا المجلد" | ||||
| addFile: "إضافة ملف" | ||||
| emptyDrive: "قرص التخزين فارغ" | ||||
| emptyFolder: "هذا المجلد فارغ" | ||||
| unableToDelete: "لا يمكن حذفه" | ||||
| inputNewFileName: "ادخل الإسم الجديد للملف" | ||||
| inputNewFolderName: "ادخل الإسم الجديد للمجلد" | ||||
| copyUrl: "انسخ عنوان URL" | ||||
| rename: "إعادة التسمية" | ||||
| avatar: "الصورة الرمزية" | ||||
| banner: "الصورة الرأسية" | ||||
| nsfw: "محتوى حساس" | ||||
| disconnectedFromServer: "قُطِع الإتصال بالخادم" | ||||
| reload: "انعش" | ||||
| doNothing: "تجاهل" | ||||
| watch: "راقب" | ||||
| unwatch: "إلغاء المراقبة" | ||||
| accept: "السماح" | ||||
| reject: "رفض" | ||||
| normal: "عادي" | ||||
| instanceName: "اسم مثيل الخادم" | ||||
| instanceDescription: "وصف مثيل الخادم" | ||||
| maintainerName: "المدير" | ||||
| maintainerEmail: "عنوان بريد المدير الإلكتروني" | ||||
| tosUrl: "عنوان URL لشروط الخدمة" | ||||
| thisYear: "هذا العام" | ||||
| thisMonth: "هذا الشهر" | ||||
| today: "اليوم" | ||||
| dayX: "{day}" | ||||
| monthX: "{month}" | ||||
| yearX: "{year}" | ||||
| pages: "الصفحات" | ||||
| connectSerice: "أوصل" | ||||
| disconnectSerice: "قطع الاتصال" | ||||
| enableLocalTimeline: "تفعيل الخيط المحلي" | ||||
| enableGlobalTimeline: "تفعيل الخيط الزمني الشامل" | ||||
| registration: "إنشاء حساب" | ||||
| enableRegistration: "تفعيل إنشاء الحسابات الجديدة" | ||||
| invite: "دعوة" | ||||
| basicInfo: "المعلومات الأساسية " | ||||
| pinnedNotes: "ملاحظة مدبسة" | ||||
| hcaptchaSiteKey: "مفتاح الموقع" | ||||
| hcaptchaSecretKey: "المفتاح السري" | ||||
| recaptcha: "reCAPTCHA" | ||||
| enableRecaptcha: "تمكين reCAPTCHA" | ||||
| recaptchaSiteKey: "مفتاح الموقع" | ||||
| recaptchaSecretKey: "المفتاح السري" | ||||
| antennas: "الهوائيات" | ||||
| manageAntennas: "إدارة الهوائيات" | ||||
| name: "الإسم" | ||||
| antennaSource: "مصدر الهوائي" | ||||
| antennaKeywords: "الكلمات المفتاحية للإستقبال" | ||||
| withReplies: "بالردود" | ||||
| notesAndReplies: "الملاحظات والردود" | ||||
| withFiles: "بالمرفقات" | ||||
| silence: "اكتم" | ||||
| unsilence: "إلغاء الكتم" | ||||
| popularUsers: "المستخدمون الشائعون" | ||||
| exploreFediverse: "استكشف الفديفرس" | ||||
| popularTags: "الوسوم الرائجة" | ||||
| userList: "القوائم" | ||||
| about: "عن" | ||||
| aboutMisskey: "عن Misskey" | ||||
| administrator: "المدير" | ||||
| token: "الرمز المميز" | ||||
| twoStepAuthentication: "الإستيثاق بعاملَيْن" | ||||
| moderator: "مشرِف" | ||||
| nUsersMentioned: "{n} مستخدمين تمت الإشارة إليهم" | ||||
| securityKey: "مفتاح الأمان" | ||||
| securityKeyName: "اسم المفتاح" | ||||
| lastUsed: "آخر استخدام" | ||||
| unregister: "إلغاء التسجيل" | ||||
| passwordLessLogin: "لِج مِن دون كلمة سرية" | ||||
| resetPassword: "أعد تعيين كلمتك السرية" | ||||
| newPasswordIs: "كلمتك السرية الجديدة هي {password}" | ||||
| share: "شارِك" | ||||
| notFound: "غير موجود" | ||||
| help: "المساعدة" | ||||
| inputMessageHere: "اكتب رسالتك هنا" | ||||
| close: "اغلق" | ||||
| group: "الفريق" | ||||
| groups: "الفِرَق" | ||||
| createGroup: "انشئ فريقًا" | ||||
| invites: "دعوة" | ||||
| groupName: "اسم الفريق" | ||||
| members: "الأعضاء" | ||||
| transfer: "نقل" | ||||
| messagingWithUser: "الدردشة مع مستخدم آخر" | ||||
| messagingWithGroup: "دردشة جماعية" | ||||
| title: "العنوان" | ||||
| text: "النص" | ||||
| enable: "تشغيل" | ||||
| next: "التالية" | ||||
| retype: "أعد الكتابة" | ||||
| noteOf: "ملاحظات {user}" | ||||
| inviteToGroup: "دعوة إلى فريق" | ||||
| noMessagesYet: "ليس هناك رسائل بعد" | ||||
| newMessageExists: "لقد تلقيت رسالة جديدة" | ||||
| invitations: "دعوة" | ||||
| invitationCode: "رمز الدعوة" | ||||
| checking: "التحقق جارٍ" | ||||
| available: "متوفر" | ||||
| unavailable: "غير متوفر" | ||||
| tooShort: "قصير جدًا" | ||||
| tooLong: "طويل جدًا" | ||||
| weakPassword: "الكلمة السرية ضعيفة" | ||||
| normalPassword: "الكلمة السرية جيدة" | ||||
| strongPassword: "الكلمة السرية قوية" | ||||
| passwordMatched: "التطابق صحيح!" | ||||
| passwordNotMatched: "غير متطابقتان" | ||||
| signinWith: "الولوج عبر {x}" | ||||
| or: "أو" | ||||
| uiLanguage: "لغة واجهة المستخدم" | ||||
| aboutX: "عن {x}" | ||||
| useOsNativeEmojis: "استخدم الإيموجيات الخاصة بنظام التشغيل" | ||||
| youHaveNoGroups: "لا تمتلك أية فِرَق" | ||||
| noHistory: "السجل فارغ" | ||||
| doing: "انتظر لحظة" | ||||
| category: "الفئات" | ||||
| tags: "الوسوم" | ||||
| docSource: "مصدر هذا المستند" | ||||
| createAccount: "أنشئ حسابًا" | ||||
| existingAcount: "الحسابات الموجودة" | ||||
| regenerate: "أعِد التوليد" | ||||
| fontSize: "حجم الخط" | ||||
| dashboard: "لوحة التحكم" | ||||
| local: "المحلي" | ||||
| remote: "بُعدي" | ||||
| total: "المجموع" | ||||
| weekOverWeekChanges: "أسبوعيا" | ||||
| dayOverDayChanges: "يوميا" | ||||
| appearance: "المظهر" | ||||
| accountSettings: "إعدادات الحساب" | ||||
| promotion: "ترقية" | ||||
| promote: "روِّج" | ||||
| numberOfDays: "عدد الأيام" | ||||
| hideThisNote: "إخفاء هذه الملاحظة" | ||||
| deleteAll: "حذف الكل" | ||||
| sounds: "الرنات" | ||||
| listen: "استمع" | ||||
| none: "لا شيء" | ||||
| volume: "مستوى الصوت" | ||||
| details: "التفاصيل" | ||||
| chooseEmoji: "اختر إيموجي" | ||||
| recentUsed: "المستخدمة مؤخرا" | ||||
| install: "التثبيت" | ||||
| uninstall: "إلغاء التثبيت" | ||||
| installedApps: "التطبيقات المُخوّلة" | ||||
| lastUsedDate: "آخر استخدام" | ||||
| state: "الحالة" | ||||
| sort: "ترتيب حسب" | ||||
| output: "الخارجة" | ||||
| updateRemoteUser: "تحديث المعلومات عن المستخدم البعيد" | ||||
| sidebar: "الشريط الجانبي" | ||||
| addItem: "إضافة عنصر" | ||||
| rooms: "الغرفة" | ||||
| relays: "المُرَحلات" | ||||
| addRelay: "إضافة مُرحّل" | ||||
| addedRelays: "المرحلات التي تم إضافتها" | ||||
| deletedNote: "ملاحظة محذوفة" | ||||
| invisibleNote: "ملاحظة مخفية" | ||||
| poll: "استطلاع رأي" | ||||
| themeEditor: "مصمم القوالب" | ||||
| plugins: "الإضافات" | ||||
| pluginInstallWarn: "يرجى تنصيب إضافات ذات مصدر موثوق منه فقط." | ||||
| smtpHost: "المضيف" | ||||
| smtpUser: "اسم المستخدم" | ||||
| smtpPass: "الكلمة السرية" | ||||
| display: "المظهر" | ||||
| public: "للعامة" | ||||
| _mfm: | ||||
|   mention: "أشر الى" | ||||
|   quote: "اقتبس" | ||||
|   emoji: "إيموجي مخصص" | ||||
|   search: "البحث" | ||||
| _reversi: | ||||
|   total: "المجموع" | ||||
| _channel: | ||||
|   featured: "المتداوَلة" | ||||
| _sidebar: | ||||
|   full: "كامل" | ||||
|   icon: "الصورة الرمزية" | ||||
|   hide: "إخفاء" | ||||
| _theme: | ||||
|   explore: "استكشف قوالب المظهر" | ||||
|   install: "تنصيب قالب" | ||||
|   manage: "إدارة القوالب" | ||||
|   code: "شيفرة القالب" | ||||
|   installed: "تم تنصيب {name}" | ||||
|   make: "إنشاء قالب" | ||||
|   alpha: "الشفافية" | ||||
|   keys: | ||||
|     mention: "أشر الى" | ||||
|     messageBg: "خلفية الدردشة" | ||||
| _sfx: | ||||
|   note: "الملاحظات" | ||||
|   noteMy: "ملاحظتي" | ||||
|   notification: "الإشعارات" | ||||
|   chat: "الدردشة" | ||||
| _ago: | ||||
|   unknown: "مجهول" | ||||
|   future: "المستقبَل" | ||||
|   justNow: "اللحظة" | ||||
|   secondsAgo: "منذ {n} ثوانٍ" | ||||
|   minutesAgo: "منذ {n} دقائق" | ||||
|   hoursAgo: "منذ {n} ساعة" | ||||
|   daysAgo: "منذ {n} أيام" | ||||
|   weeksAgo: "منذ {n} أسابيع" | ||||
|   monthsAgo: "منذ {n} أشهر" | ||||
|   yearsAgo: "منذ {n} سنوات" | ||||
| _time: | ||||
|   second: "ثا" | ||||
|   minute: "د" | ||||
|   hour: "سا" | ||||
|   day: "ي" | ||||
| _tutorial: | ||||
|   title: "كيف تستخدم Misskey" | ||||
|   step1_1: "مرحبًا!" | ||||
| _2fa: | ||||
|   registerKey: "تسجيل مفتاح أمان جديد" | ||||
| _permissions: | ||||
|   "write:account": "تعديل معلومات حسابك" | ||||
|   "read:notifications": "اظهر الإشعارات" | ||||
| _weekday: | ||||
|   sunday: "الأحد" | ||||
|   monday: "الإثنين" | ||||
|   tuesday: "الثلاثاء" | ||||
|   wednesday: "الأربعاء" | ||||
|   thursday: "الخميس" | ||||
|   friday: "الجمعة" | ||||
|   saturday: "السبت" | ||||
| _widgets: | ||||
|   memo: "ملاحظة لاصقة" | ||||
|   notifications: "الإشعارات" | ||||
|   timeline: "الخيط الزمني" | ||||
|   calendar: "التقويم" | ||||
|   trends: "المتداوَلة" | ||||
|   clock: "الساعة" | ||||
|   rss: "تدفق RSS" | ||||
|   activity: "النشاط" | ||||
|   photos: "الصور" | ||||
|   federation: "الفديرالية" | ||||
| _cw: | ||||
|   hide: "إخفاء" | ||||
|   show: "عرض المزيد" | ||||
|   chars: "{count} أحرف" | ||||
|   files: "{count} ملفات" | ||||
| _poll: | ||||
|   noOnlyOneChoice: "تحتاج إلى خيارَين على الأقل" | ||||
|   choiceN: "الخيار {n}" | ||||
|   noMore: "لا يمكنك إضافة خيارات أخرى" | ||||
|   canMultipleVote: "السماح بالإجابات المتعددة" | ||||
|   expiration: "ينتهي استطلاع الرأي في" | ||||
|   infinite: "أبدًا" | ||||
|   at: "تاريخ الإنتهاء" | ||||
|   after: "ينتهي بعد…" | ||||
|   deadlineDate: "تاريخ الانتهاء" | ||||
|   deadlineTime: "سا" | ||||
|   duration: "المدة" | ||||
|   votesCount: "{n} أصوات" | ||||
|   totalVotes: "المجموع {n} أصوات" | ||||
|   vote: "قم بالتصويت" | ||||
|   showResult: "اعرض النتائج" | ||||
|   voted: "تم التصويت" | ||||
|   closed: "انتهى" | ||||
|   remainingDays: "{d} أيام و {h} ساعات متبقية" | ||||
|   remainingHours: "{h} ساعات و {m} دقائق متبقية" | ||||
|   remainingMinutes: "{m} دقائق و {s} ثوانٍ متبقية" | ||||
|   remainingSeconds: "{s} ثوانٍ متبقية" | ||||
| _visibility: | ||||
|   public: "للعامة" | ||||
|   home: "الرئيسي" | ||||
|   followers: "المتابِعين" | ||||
|   specified: "مباشرة" | ||||
|   localOnly: "المحلي فقط" | ||||
| _postForm: | ||||
|   replyPlaceholder: "رد على هذه الملاحظة…" | ||||
|   quotePlaceholder: "اقتبس هذه الملاحظة…" | ||||
| _profile: | ||||
|   name: "الإسم" | ||||
|   username: "اسم المستخدم" | ||||
|   youCanIncludeHashtags: "يمكنك أيضًا إضافة وسوم إلى نبذتك التعريفية." | ||||
| _exportOrImport: | ||||
|   allNotes: "كل الملاحظات" | ||||
|   followingList: "المتابَعون" | ||||
|   muteList: "اكتم" | ||||
|   blockingList: "احجب" | ||||
|   userLists: "القوائم" | ||||
| _charts: | ||||
|   usersTotal: "مجموع عدد المستخدمين والمستخدمات" | ||||
|   activeUsers: "المستخدمون النشطون" | ||||
| _timelines: | ||||
|   home: "الرئيسي" | ||||
|   local: "المحلي" | ||||
|   social: "الاجتماعي" | ||||
|   global: "الشامل" | ||||
| _rooms: | ||||
|   _roomType: | ||||
|     default: "افتراضي" | ||||
|   _furnitures: | ||||
|     monitor: "شاشة التحكم" | ||||
|     banknote: "أوراق نقدية" | ||||
| _pages: | ||||
|   blocks: | ||||
|     image: "الصور" | ||||
|   script: | ||||
|     categories: | ||||
|       list: "القوائم" | ||||
|     blocks: | ||||
|       _strReplace: | ||||
|         arg1: "نص" | ||||
|         arg3: "استُبدِل بـ" | ||||
|       _join: | ||||
|         arg1: "القوائم" | ||||
|         arg2: "فاصل" | ||||
|       add: "إضافة" | ||||
|       _randomPick: | ||||
|         arg1: "القوائم" | ||||
|       _dailyRandomPick: | ||||
|         arg1: "القوائم" | ||||
|       _seedRandomPick: | ||||
|         arg2: "القوائم" | ||||
|       _pick: | ||||
|         arg1: "القوائم" | ||||
|       _listLen: | ||||
|         arg1: "القوائم" | ||||
|     types: | ||||
|       array: "القوائم" | ||||
| _notification: | ||||
|   youGotPoll: "شارك {name} في استطلاع الرأي" | ||||
|   youGotMessagingMessageFromUser: "لقد تلقيت رسالة مِن {name}" | ||||
|   youGotMessagingMessageFromGroup: "لقد أرسِلَت رسالة إلى الفريق {name}" | ||||
|   youWereFollowed: "يتابعك" | ||||
|   _types: | ||||
|     follow: "المتابَعون" | ||||
|     mention: "أشر الى" | ||||
|     quote: "اقتبس" | ||||
|     reaction: "تفاعل" | ||||
| _deck: | ||||
|   _columns: | ||||
|     notifications: "الإشعارات" | ||||
|     tl: "الخيط الزمني" | ||||
|     antenna: "الهوائيات" | ||||
|     list: "القوائم" | ||||
|     mentions: "الإشارات" | ||||
|     direct: "مباشرة" | ||||
| @@ -16,6 +16,9 @@ noNotes: "Keine Notizen" | ||||
| noNotifications: "Keine Benachrichtigungen" | ||||
| instance: "Instanz" | ||||
| settings: "Einstellungen" | ||||
| basicSettings: "Allgemeine Einstellungen" | ||||
| otherSettings: "Andere Einstellungen" | ||||
| openInWindow: "In Fenster öffnen" | ||||
| profile: "Profil" | ||||
| timeline: "Chronik" | ||||
| noAccountDescription: "Dieser Nutzer hat seine Profilbeschreibung noch nicht ausgefüllt." | ||||
| @@ -30,6 +33,9 @@ addUser: "Benutzer hinzufügen" | ||||
| favorite: "Zu Favoriten hinzufügen" | ||||
| favorites: "Favoriten" | ||||
| unfavorite: "Aus Favoriten entfernen" | ||||
| favorited: "Zu Favoriten hinzugefügt." | ||||
| alreadyFavorited: "Bereits zu den Favoriten hinzugefügt." | ||||
| cantFavorite: "Hinzufügen zu Favoriten fehlgeschlagen." | ||||
| pin: "Anheften" | ||||
| unpin: "Lösen" | ||||
| copyContent: "Inhalt kopieren" | ||||
| @@ -40,11 +46,13 @@ deleteAndEditConfirm: "Möchtest du diese Notiz wirklich löschen und bearbeiten | ||||
| addToList: "Zu Liste hinzufügen" | ||||
| sendMessage: "Nachricht senden" | ||||
| copyUsername: "Benutzernamen kopieren" | ||||
| searchUser: "Benutzersuche" | ||||
| reply: "Antworten" | ||||
| loadMore: "Mehr anzeigen" | ||||
| youGotNewFollower: "Du hast einen neuen Follower" | ||||
| receiveFollowRequest: "Follow-Anfrage erhalten." | ||||
| receiveFollowRequest: "Follow-Anfrage erhalten" | ||||
| followRequestAccepted: "Follow-Anfrage akzeptiert" | ||||
| mention: "Erwähnung" | ||||
| mentions: "Erwähnungen" | ||||
| directNotes: "Direktnachrichten" | ||||
| importAndExport: "Importieren und Exportieren" | ||||
| @@ -65,8 +73,11 @@ followers: "Gefolgt von" | ||||
| followsYou: "Folgt dir" | ||||
| createList: "Liste erstellen" | ||||
| manageLists: "Listen verwalten" | ||||
| error: "Ein Problem ist aufgetreten" | ||||
| error: "Fehler" | ||||
| somethingHappened: "Ein Fehler ist aufgetreten" | ||||
| retry: "Wiederholen" | ||||
| pageLoadError: "Laden der Seite fehlgeschlagen." | ||||
| pageLoadErrorDescription: "Dieser Fehler wird meist durch Netzwerkfehler oder den Browser-Cache verursacht. Versuche den Browser-Cache zu leeren und es nach kurzer Zeit noch einmal zu probieren." | ||||
| enterListName: "Listennamen eingeben" | ||||
| privacy: "Privatsphäre" | ||||
| makeFollowManuallyApprove: "Follow-Anfragen benötigen Bestätigung" | ||||
| @@ -79,18 +90,22 @@ followRequestPending: "Ausstehende Follow-Anfrage" | ||||
| enterEmoji: "Gib ein Emoji ein" | ||||
| renote: "Renote" | ||||
| unrenote: "Renote zurücknehmen" | ||||
| renoted: "Renote getätigt." | ||||
| cantRenote: "Renote dieses Beitrags nicht möglich." | ||||
| cantReRenote: "Renote einer Renote nicht möglich." | ||||
| quote: "Zitieren" | ||||
| pinnedNote: "Angepinnte Notiz" | ||||
| you: "Du" | ||||
| clickToShow: "Klicke, um diesen Inhalt anzusehen" | ||||
| sensitive: "Dieser Inhalt ist NSFW" | ||||
| sensitive: "NSFW" | ||||
| add: "Hinzufügen" | ||||
| reaction: "Reaktionen" | ||||
| reactionSettingDescription: "Gib deine Lieblingsreaktionen ein, um sie der Reaktionsauswahl hinzuzufügen." | ||||
| reactionSettingDescription2: "Ziehe zum Anordnen, Klicke zum Löschen,  Drücke \"+\" zum Hinzufügen" | ||||
| rememberNoteVisibility: "Notizsichtbarkeit merken" | ||||
| attachCancel: "Anhang entfernen" | ||||
| markAsSensitive: "Als sensitiv markieren" | ||||
| unmarkAsSensitive: "Markierung als sensitiv zurücknehmen" | ||||
| markAsSensitive: "Als NSFW markieren" | ||||
| unmarkAsSensitive: "Markierung als NSFW zurücknehmen" | ||||
| enterFileName: "Dateinamen eingeben" | ||||
| mute: "Stummschalten" | ||||
| unmute: "Stummschaltung aufheben" | ||||
| @@ -103,7 +118,12 @@ unblockConfirm: "Möchtest du diese Blockierung wirklich aufheben?" | ||||
| suspendConfirm: "Möchtest du diesen Benutzer wirklich sperren?" | ||||
| unsuspendConfirm: "Möchtest du die Sperrung dieses Benutzers wirklich aufheben?" | ||||
| selectList: "Wähle eine Liste aus" | ||||
| selectAntenna: "Antenne auswählen" | ||||
| selectWidget: "Widget auswählen" | ||||
| editWidgets: "Widgets bearbeiten" | ||||
| editWidgetsExit: "Fertig" | ||||
| customEmojis: "Benutzerdefinierte Emojis" | ||||
| emoji: "Emoji" | ||||
| emojiName: "Emojiname" | ||||
| emojiUrl: "Emoji-URL" | ||||
| addEmoji: "Emoji hinzufügen" | ||||
| @@ -111,7 +131,9 @@ settingGuide: "Empfohlene Einstellung" | ||||
| cacheRemoteFiles: "Dateien von anderen Instanzen im Cache speichern" | ||||
| cacheRemoteFilesDescription: "Wenn diese Einstellung deaktiviert ist, werden Dateien anderer Instanzen direkt von dort geladen. Hierdurch wird Speicherplatz gespart, aber mehr Bandbreite verbraucht, da keine Vorschaubilder generiert werden." | ||||
| flagAsBot: "Als Bot markieren" | ||||
| flagAsBotDescription: "Wenn dieser Account durch ein Programm gesteuert wird, setze diesen Haken. Falls aktiviert, agiert es als Flag für andere Entwickler um endlose Kettenreaktionen mit anderen Bots zu verhindern und lässt Misskey's interne Systeme diesen Account als Bot behandeln." | ||||
| flagAsCat: "Als Katze markieren" | ||||
| flagAsCatDescription: "Setze diese Flag um dieses Benutzerkonto als Katze zu markieren." | ||||
| autoAcceptFollowed: "Follow-Anfragen automatisch akzeptieren" | ||||
| addAcount: "Benutzerkonto hinzufügen" | ||||
| loginFailed: "Login fehlgeschlagen" | ||||
| @@ -161,7 +183,7 @@ clearCachedFilesConfirm: "Sollen alle im Cache gespeicherten Dateien von anderen | ||||
| blockedInstances: "Blockierte Instanzen" | ||||
| blockedInstancesDescription: "Gib den Hostnamen der Instanz an, die blockiert werden soll. Blockierte Instanzen können nicht mehr mit dieser kommunizieren." | ||||
| muteAndBlock: "Stummgeschaltet / Blockiert" | ||||
| mutedUsers: "Stummgestellte Benutzer" | ||||
| mutedUsers: "Stummgeschaltete Benutzer" | ||||
| blockedUsers: "Blockierte Benutzer" | ||||
| noUsers: "Keine Benutzer" | ||||
| editProfile: "Profil bearbeiten" | ||||
| @@ -173,7 +195,6 @@ processing: "In Bearbeitung" | ||||
| preview: "Vorschau" | ||||
| default: "Standard" | ||||
| noCustomEmojis: "Es existieren keine Emojis" | ||||
| customEmojisOfRemote: "Emojis von anderen Instanzen" | ||||
| noJobs: "Es gibt keine Jobs" | ||||
| federating: "Föderiert" | ||||
| blocked: "Blockiert" | ||||
| @@ -202,8 +223,10 @@ imageUrl: "Bild-URL" | ||||
| remove: "Löschen" | ||||
| removed: "Erfolgreich gelöscht" | ||||
| removeAreYouSure: "Möchtest du \"{x}\" wirklich löschen?" | ||||
| deleteAreYouSure: "Möchtest du \"{x}\" wirklich löschen?" | ||||
| resetAreYouSure: "Wirklich zurücksetzen?" | ||||
| saved: "Gespeichert" | ||||
| messaging: "Privatnachrichten" | ||||
| messaging: "Chat" | ||||
| upload: "Hochladen" | ||||
| fromDrive: "Aus Drive" | ||||
| fromUrl: "Von einer URL" | ||||
| @@ -215,12 +238,12 @@ explore: "Erkunden" | ||||
| games: "Misskey Spiele" | ||||
| messageRead: "Gelesen" | ||||
| noMoreHistory: "Kein weiterer Verlauf vorhanden" | ||||
| startMessaging: "Neue Privatnachricht erstellen" | ||||
| startMessaging: "Neuen Chat erstellen" | ||||
| nUsersRead: "Von {n} gelesen" | ||||
| agreeTo: "Ich stimme {0} zu" | ||||
| tos: "Nutzungsbedingungen" | ||||
| start: "Anfangen" | ||||
| home: "Startseite" | ||||
| home: "Home" | ||||
| remoteUserCaution: "Diese Informationen sind möglicherweise veraltet, da der Benutzer von einer anderen Instanz stammt." | ||||
| activity: "Aktivität" | ||||
| images: "Bilder" | ||||
| @@ -259,7 +282,8 @@ copyUrl: "URL kopieren" | ||||
| rename: "Umbenennen" | ||||
| avatar: "Profilbild" | ||||
| banner: "Banner" | ||||
| nsfw: "Dieser Inhalt ist NSFW" | ||||
| nsfw: "NSFW" | ||||
| whenServerDisconnected: "Bei Verbindungsverlust zum Server" | ||||
| disconnectedFromServer: "Verbindung zum Server wurde getrennt" | ||||
| reload: "Aktualisieren" | ||||
| doNothing: "Ignorieren" | ||||
| @@ -300,6 +324,10 @@ bannerUrl: "Banner-URL" | ||||
| basicInfo: "Basisdaten" | ||||
| pinnedUsers: "Angepinnte Benutzer" | ||||
| pinnedUsersDescription: "Gib einen Benutzernamen pro Zeile ein. Diese werden im \"Erkunden\" Tab angezeigt." | ||||
| pinnedPages: "Angepinnte Seiten" | ||||
| pinnedPagesDescription: "Gib hier die Pfäde zu den Seiten an, die du an die Spitze dieser Instanz anheften möchtest, getrennt durch neue Zeilen." | ||||
| pinnedClipId: "ID des angehefteten Clips" | ||||
| pinnedNotes: "Angepinnte Notizen" | ||||
| hcaptcha: "hCaptcha" | ||||
| enableHcaptcha: "hCaptcha aktivieren" | ||||
| hcaptchaSiteKey: "Site key" | ||||
| @@ -340,13 +368,6 @@ popularTags: "Beliebte Schlagwörter" | ||||
| userList: "Listen" | ||||
| about: "Über" | ||||
| aboutMisskey: "Über Misskey" | ||||
| aboutMisskeyText: "Misskey ist Open-Source-Software die von syuilo seit 2014 entwickelt wird." | ||||
| misskeyMembers: "Misskey wird momentan von den unten aufgelisteten Mitgliedern weiterentwickelt und instand gehalten:" | ||||
| misskeySource: "Der Quelltext ist hier verfügbar:" | ||||
| misskeyTranslation: "Hilf dabei, Misskey zu übersetzen:" | ||||
| misskeyDonate: "Spende an Misskey, um die Weiterentwicklung zu unterstützen:" | ||||
| morePatrons: "Wir schätzen ebenso die Unterstützung vieler anderer hier nicht gelisteter Personen sehr. Danke! 🥰" | ||||
| patrons: "UnterstützerInnen" | ||||
| administrator: "Administrator" | ||||
| token: "Token" | ||||
| twoStepAuthentication: "Zwei-Faktor-Authentifizierung" | ||||
| @@ -360,9 +381,6 @@ unregister: "Deaktivieren" | ||||
| passwordLessLogin: "Passwortloses Anmelden einrichten" | ||||
| resetPassword: "Passwort zurücksetzen" | ||||
| newPasswordIs: "Das neue Passwort ist \"{password}\"" | ||||
| autoReloadWhenDisconnected: "Automatisch aktualisieren wenn die Serververbindung getrennt wird" | ||||
| autoNoteWatch: "Notizen automatisch beobachten" | ||||
| autoNoteWatchDescription: "Werde über Notizen, auf die du reagiert oder geantwortet hast, informiert" | ||||
| reduceUiAnimation: "Animationen der Benutzeroberfläche reduzieren" | ||||
| share: "Teilen" | ||||
| notFound: "Nicht gefunden" | ||||
| @@ -384,8 +402,8 @@ invites: "Einladungen" | ||||
| groupName: "Gruppenname" | ||||
| members: "Mitglieder" | ||||
| transfer: "Übertragen" | ||||
| messagingWithUser: "Privatnachrichten mit einem Benutzer" | ||||
| messagingWithGroup: "Privatnachrichten mit einer Gruppe" | ||||
| messagingWithUser: "Privatchat" | ||||
| messagingWithGroup: "Gruppenchat" | ||||
| title: "Betreff" | ||||
| text: "Text" | ||||
| enable: "Aktivieren" | ||||
| @@ -400,6 +418,7 @@ noMessagesYet: "Noch keine Nachrichten" | ||||
| newMessageExists: "Du hast eine neue Nachricht" | ||||
| onlyOneFileCanBeAttached: "Es kann pro Nachricht nur eine Datei angehängt werden" | ||||
| signinRequired: "Anmeldung erforderlich" | ||||
| invitations: "Einladungen" | ||||
| invitationCode: "Einladungscode" | ||||
| checking: "Wird überprüft..." | ||||
| available: "Verfügbar" | ||||
| @@ -423,6 +442,7 @@ useOsNativeEmojis: "Eingebaute Emojis des Betriebssystems benutzen" | ||||
| youHaveNoGroups: "Keine Gruppen vorhanden" | ||||
| joinOrCreateGroup: "Lass dich zu einer Gruppe einladen oder erstelle deine eigene." | ||||
| noHistory: "Kein Verlauf" | ||||
| signinHistory: "Anmeldungsverlauf" | ||||
| disableAnimatedMfm: "MFM, die Animationen enthalten, deaktivieren" | ||||
| doing: "In Bearbeitung" | ||||
| category: "Kategorie" | ||||
| @@ -440,8 +460,8 @@ remote: "Fremd" | ||||
| total: "Gesamt" | ||||
| weekOverWeekChanges: "Wöchentlich" | ||||
| dayOverDayChanges: "Täglich" | ||||
| accessibility: "Barrierefreiheit" | ||||
| clinetSettings: "Client-Einstellungen" | ||||
| appearance: "Aussehen" | ||||
| clientSettings: "Client-Einstellungen" | ||||
| accountSettings: "Benutzerkonto-Einstellungen" | ||||
| promotion: "Hervorgehoben" | ||||
| promote: "Hervorheben" | ||||
| @@ -464,6 +484,7 @@ objectStorageUseSSL: "SSL verwenden" | ||||
| objectStorageUseSSLDesc: "Deaktiviere dies falls du für die API-Verbindungen kein HTTPS verwenden wirst" | ||||
| objectStorageUseProxy: "Über Proxy verbinden" | ||||
| objectStorageUseProxyDesc: "Deaktiviere dies falls du keinen Proxy für den Objektspeicher verwenden wirst" | ||||
| objectStorageSetPublicRead: "Bei Upload auf \"public-read\" stellen" | ||||
| serverLogs: "Serverprotokolle" | ||||
| deleteAll: "Alle löschen" | ||||
| showFixedPostForm: "Bereich zum Schreiben neuer Notizen am Anfang der Chronik anzeigen" | ||||
| @@ -471,7 +492,10 @@ newNoteRecived: "Es gibt neue Notizen" | ||||
| sounds: "Töne" | ||||
| listen: "Anhören" | ||||
| none: "Keine" | ||||
| showInPage: "In Seite anzeigen" | ||||
| popout: "Pop-Up" | ||||
| volume: "Lautstärke" | ||||
| masterVolume: "Gesamtlautstärke" | ||||
| details: "Details" | ||||
| chooseEmoji: "Wähle ein Emoji" | ||||
| unableToProcess: "Der Vorgang konnte nicht abgeschlossen werden." | ||||
| @@ -506,21 +530,354 @@ relays: "Relays" | ||||
| addRelay: "Relay hinzufügen" | ||||
| inboxUrl: "inbox-URL" | ||||
| addedRelays: "Hinzugefügte Relays" | ||||
| serviceworkerInfo: "Muss für Push-Benachrichtigungen aktiviert sein." | ||||
| deletedNote: "Gelöschte Notiz" | ||||
| invisibleNote: "Private Notiz" | ||||
| enableInfiniteScroll: "Automatisch mehr Notizen laden" | ||||
| visibility: "Sichtbarkeit" | ||||
| poll: "Umfrage" | ||||
| useCw: "Inhalt verstecken" | ||||
| enablePlayer: "Video-Player öffnen" | ||||
| disablePlayer: "Video-Player schließen" | ||||
| expandTweet: "Tweet ausklappen" | ||||
| themeEditor: "Farbthemen-Editor" | ||||
| description: "Beschreibung" | ||||
| author: "Autor" | ||||
| leaveConfirm: "Es gibt unspeicherte Änderungen. Möchtest du diese verwerfen?" | ||||
| manage: "Verwaltung" | ||||
| plugins: "Plugins" | ||||
| pluginInstallWarn: "Installiere nur vertrauenswürdige Plugins." | ||||
| deck: "Deck" | ||||
| undeck: "Deck verlassen" | ||||
| useBlurEffectForModal: "Weichzeichnungseffekt für Modals verwenden" | ||||
| useFullReactionPicker: "Vollständige Reaktionsauswahl nutzen" | ||||
| width: "Breite" | ||||
| height: "Höhe" | ||||
| large: "Groß" | ||||
| medium: "Mittel" | ||||
| small: "Klein" | ||||
| generateAccessToken: "Zugriffstoken generieren" | ||||
| permission: "Berechtigungen" | ||||
| enableAll: "Alle aktivieren" | ||||
| disableAll: "Alle deaktivieren" | ||||
| tokenRequested: "Benutzerkontozugriff gewähren" | ||||
| pluginTokenRequestedDescription: "Dieses Plugin wird die hier konfigurierten Berechtigungen verwenden können." | ||||
| notificationType: "Benachrichtigungstyp" | ||||
| edit: "Bearbeiten" | ||||
| useStarForReactionFallback: "Verwende ★ falls das Reaktions-Emoji unbekannt ist" | ||||
| emailConfig: "Email-Server Konfiguration" | ||||
| enableEmail: "Email-Versand aktivieren" | ||||
| emailConfigInfo: "Zur Email-Bestätigung bei Registrierung und zum Zurücksetzen des Passworts verwendet" | ||||
| email: "Email" | ||||
| emailAddress: "Email-Adresse" | ||||
| smtpConfig: "SMTP-Server Konfiguration" | ||||
| smtpHost: "Host" | ||||
| smtpPort: "Port" | ||||
| smtpUser: "Benutzername" | ||||
| smtpPass: "Passwort" | ||||
| emptyToDisableSmtpAuth: "Benutzername und Passwort leer lassen um SMTP-Verifizierung zu deaktivieren" | ||||
| smtpSecure: "Für SMTP-Verbindungen implizit SSL/TLS verwenden" | ||||
| smtpSecureInfo: "Schalte dies aus, falls du STARTTLS verwendest" | ||||
| testEmail: "Email-Versand testen" | ||||
| wordMute: "Wort-Stummschaltung" | ||||
| userSaysSomething: "{name} hat etwas gesagt." | ||||
| makeActive: "Aktivieren" | ||||
| display: "Anzeige" | ||||
| copy: "Kopieren" | ||||
| metrics: "Metriken" | ||||
| overview: "Übersicht" | ||||
| logs: "Logs" | ||||
| delayed: "Verzögert" | ||||
| database: "Datenbank" | ||||
| channel: "Kanäle" | ||||
| create: "Erstellen" | ||||
| notificationSetting: "Benachrichtigungseinstellungen" | ||||
| notificationSettingDesc: "Wähle die Art der anzuzeigenden Benachrichtigung" | ||||
| useGlobalSetting: "Globale Einstellung verwenden" | ||||
| useGlobalSettingDesc: "Wenn dies eingeschaltet ist, werden die Benachrichtigungseinstellungen deines Benutzerkontos verwendet. Wenn dies ausgeschaltet ist, können individuelle Einstellungen vorgenommen werden." | ||||
| other: "Andere" | ||||
| regenerateLoginToken: "Login-Token regenerieren" | ||||
| regenerateLoginTokenDescription: "Den bei Logins intern verwendeten Token regenerieren. Normalerweise wird dies nicht benötigt. Bei Regeneration werden alle Geräte ausgeloggt." | ||||
| setMultipleBySeparatingWithSpace: "Trenne Elemente durch ein Leerzeichen um mehrere Einstellungen zu kofigurieren." | ||||
| fileIdOrUrl: "Datei-ID oder URL" | ||||
| chatOpenBehavior: "Verhalten des Chatfensters bei Öffnung" | ||||
| behavior: "Verhalten" | ||||
| sample: "Beispiel" | ||||
| abuseReports: "Melden" | ||||
| reportAbuse: "Melden" | ||||
| reportAbuseOf: "{name} melden" | ||||
| fillAbuseReportDescription: "Bitte gib Details für diese Meldung an. Falls es sich um eine spezielle Notiz handelt, bitte gib dessen URL an." | ||||
| abuseReported: "Die Meldung wurde versendet. Vielen Dank." | ||||
| send: "Senden" | ||||
| abuseMarkAsResolved: "Meldung als gelöst markieren" | ||||
| openInNewTab: "In neuem Tab öffnen" | ||||
| openInSideView: "In Seitenansicht öffnen" | ||||
| defaultNavigationBehaviour: "Standardnavigationsverhalten" | ||||
| editTheseSettingsMayBreakAccount: "Bei Bearbeitung dieser Einstellungen besteht die Gefahr, dein Benutzerkonto zu beschädigen." | ||||
| instanceTicker: "Instanz-Informationen von Notizen" | ||||
| waitingFor: "Warte auf {x}" | ||||
| random: "Zufällig" | ||||
| system: "System" | ||||
| switchUi: "UI wechseln" | ||||
| desktop: "Desktop" | ||||
| clip: "Clip" | ||||
| createNew: "Neu erstellen" | ||||
| optional: "Optional" | ||||
| createNewClip: "Neuen Clip erstellen" | ||||
| public: "Öffentlich" | ||||
| i18nInfo: "Misskey wird durch freiwillige Helfer in viele verschiedene Sprachen übersetzt. Unter {link} kannst du mithelfen." | ||||
| manageAccessTokens: "Zugriffstoken verwalten" | ||||
| accountInfo: "Benutzerkonto-Informationen" | ||||
| notesCount: "Anzahl von Notizen" | ||||
| repliesCount: "Anzahl gesendeter Antworten" | ||||
| renotesCount: "Anzahl gesendeter Renotes" | ||||
| repliedCount: "Anzahl erhaltener Antworten" | ||||
| renotedCount: "Anzahl erhaltener Renotes" | ||||
| followingCount: "Anzahl gefolgter Benutzer" | ||||
| followersCount: "Anzahl an Followern" | ||||
| sentReactionsCount: "Anzahl gesendeter Reaktionen" | ||||
| receivedReactionsCount: "Anzahl erhaltener Reaktionen" | ||||
| pollVotesCount: "Anzahl beantworteter Umfragen" | ||||
| pollVotedCount: "Anzahl erhaltener Umfrageantworten" | ||||
| yes: "Ja" | ||||
| no: "Nein" | ||||
| driveFilesCount: "Anzahl von Drive-Dateien" | ||||
| driveUsage: "Drive-Auslastung" | ||||
| noCrawle: "Crawler-Indexierung ablehnen" | ||||
| noCrawleDescription: "Suchmaschinen bitten, die eigene Profilseite, Notizen, Seiten usw. nicht zu indexieren" | ||||
| lockedAccountInfo: "Auch wenn du Follow-Anfragen auf manuelle Bestätigung setzt, wird jeder deine Notizen öffentlich sehen können, sofern du die Notizsichtbarkeit nicht auf \"Nur Follower\" setzt." | ||||
| alwaysMarkSensitive: "Immer als NSFW markieren" | ||||
| loadRawImages: "Anstatt Vorschaubild immer volles Bild laden" | ||||
| disableShowingAnimatedImages: "Animierte Bilder nicht abspielen" | ||||
| verificationEmailSent: "Eine Verifizierungsnachricht wurde versendet. Besuche den dort enthaltenen Link, um die Verifizierung abzuschließen." | ||||
| notSet: "Nicht konfiguriert" | ||||
| emailVerified: "Email-Adresse bestätigt" | ||||
| noteFavoritesCount: "Anzahl favorisierter Notizen" | ||||
| pageLikesCount: "Anzahl der Seiten, die mir gefallen" | ||||
| pageLikedCount: "Anzahl erhaltener \"Gefällt mir\" auf Seiten" | ||||
| reversiCount: "Anzahl von Reversi-Runden" | ||||
| contact: "Kontakt" | ||||
| useSystemFont: "Standardschriftart des Systems verwenden" | ||||
| clips: "Clips" | ||||
| experimentalFeatures: "Experimentelle Funktionalitäten" | ||||
| developer: "Entwickler" | ||||
| makeExplorable: "Benutzerkonto in \"Erkunden\" sichtbar machen" | ||||
| makeExplorableDescription: "Wenn diese Option deaktiviert ist, ist dein Benutzerkonto nicht im \"Erkunden\"-Bereich sichtbar." | ||||
| showGapBetweenNotesInTimeline: "Abstände zwischen Notizen auf der Chronik anzeigen" | ||||
| duplicate: "Duplizieren" | ||||
| left: "Links" | ||||
| center: "Mitte" | ||||
| wide: "Breit" | ||||
| narrow: "Schmal" | ||||
| reloadToApplySetting: "Einstellungen treten nach einer Aktualisierung der Seite in Kraft. Jetzt aktualisieren?" | ||||
| _aboutMisskey: | ||||
|   about: "Misskey ist Open-Source-Software die von syuilo seit 2014 entwickelt wird." | ||||
|   contributors: "Hauptmitwirkende" | ||||
|   allContributors: "Alle Mitwirkenden" | ||||
|   source: "Quellcode" | ||||
|   translation: "Misskey übersetzen" | ||||
|   donate: "An Misskey spenden" | ||||
|   morePatrons: "Wir schätzen ebenso die Unterstützung vieler anderer hier nicht gelisteter Personen sehr. Danke! 🥰" | ||||
|   patrons: "UnterstützerInnen" | ||||
| _nsfw: | ||||
|   respect: "Als NSFW markierte Bilder verdecken" | ||||
|   ignore: "Als NSFW markierte Bilder nicht verdecken" | ||||
|   force: "Alle Medien verdecken" | ||||
| _mfm: | ||||
|   cheatSheet: "MFM Spickzettel" | ||||
|   intro: "MFM ist eine an vielen Stellen verwendbare und Misskey-exklusive Markup-Sprache. Hier kannst du eine Liste von verfügbarer MFM-Syntax anschauen." | ||||
|   dummy: "Misskey erweitert die Welt des Fediverse" | ||||
|   mention: "Erwähnung" | ||||
|   mentionDescription: "Mit At-Zeichen und Nutzername kann ein individueller Nutzer angegeben werden." | ||||
|   hashtag: "Hashtag" | ||||
|   hashtagDescription: "Mit einer Raute und Text kann ein Hashtag angegeben werden." | ||||
|   url: "URL" | ||||
|   urlDescription: "URLs können angezeigt werden." | ||||
|   link: "Link" | ||||
|   linkDescription: "Ein spezifizierter Textabschnitt kann als URL angezeigt werden." | ||||
|   bold: "Fett" | ||||
|   boldDescription: "Zeichen zur Betonung dicker erscheinen lassen." | ||||
|   small: "Klein" | ||||
|   smallDescription: "Inhalt klein und dünn erscheinen lassen." | ||||
|   center: "Zentrieren" | ||||
|   centerDescription: "Inhalt zentriert anzeigen lassen." | ||||
|   inlineCode: "Code (Eingebettet)" | ||||
|   inlineCodeDescription: "Syntax-Hervorhebung für (Programm-)Code eingebettet anzeigen lassen." | ||||
|   blockCode: "Code (Block)" | ||||
|   blockCodeDescription: "Syntax-Hervorhebung für mehrzeiligen (Programm-)Code als Block anzeigen lassen." | ||||
|   inlineMath: "Mathe (Eingebettet)" | ||||
|   inlineMathDescription: "Mathematische Formeln (KaTeX) eingebettet anzeigen." | ||||
|   blockMath: "Mathe (Block)" | ||||
|   blockMathDescription: "Mehrzeilige mathematische Formeln (KaTeX) als Block einbetten." | ||||
|   quote: "Zitationen" | ||||
|   quoteDescription: "Inhalt als Zitat anzeigen lassen." | ||||
|   emoji: "Benutzerdefinierte Emojis" | ||||
|   emojiDescription: "Emoji-Namen mit Doppelpunkten umschließen, um benutzerdefinierte Emojis anzeigen zu lassen." | ||||
|   search: "Suche" | ||||
|   searchDescription: "Eine vorgefertige Suchanfragebox anzeigen lassen." | ||||
|   flip: "Spiegelung" | ||||
|   flipDescription: "Inhalt horizontal oder vertikal gespiegelt anzeigen lassen." | ||||
|   jelly: "Animation (Dehnen)" | ||||
|   jellyDescription: "Verleiht eine sich dehnende Animation." | ||||
|   tada: "Animation (Tada)" | ||||
|   tadaDescription: "Verleiht eine Animation mit \"Tada!\"-Gefühl" | ||||
|   jump: "Animation (Sprung)" | ||||
|   jumpDescription: "Verleiht eine springende Animation." | ||||
|   bounce: "Animation (Federn)" | ||||
|   bounceDescription: "Erzeugt eine federnde Animation." | ||||
|   shake: "Animation (Zittern)" | ||||
|   shakeDescription: "Verleiht eine zitternde Animation." | ||||
|   twitch: "Animation (Zucken)" | ||||
|   twitchDescription: "Verleiht eine sehr stark zuckende Animation." | ||||
|   spin: "Animation (Rotieren)" | ||||
|   spinDescription: "Verleiht eine rotierende Animation." | ||||
| _reversi: | ||||
|   reversi: "Reversi" | ||||
|   gameSettings: "Spieleinstellungen" | ||||
|   chooseBoard: "Spielbrett auswählen" | ||||
|   blackOrWhite: "Schwarz/Weiß" | ||||
|   blackIs: "{name} spielt Schwarz" | ||||
|   rules: "Regeln" | ||||
|   botSettings: "Optionen des Computergegners" | ||||
|   thisGameIsStartedSoon: "Dieses Spiel beginnt in wenigen Sekunden" | ||||
|   waitingForOther: "Warte auf den Zug des Gegenspielers" | ||||
|   waitingForMe: "Warte auf deinen Zug" | ||||
|   waitingBoth: "Mach dich bereit" | ||||
|   ready: "Bereit" | ||||
|   cancelReady: "Nicht bereit" | ||||
|   opponentTurn: "Zug deines Gegners" | ||||
|   myTurn: "Dein Zug" | ||||
|   turnOf: "Zug von {name}" | ||||
|   pastTurnOf: "Zug von {name}" | ||||
|   surrender: "Aufgeben" | ||||
|   surrendered: "durch Aufgabe" | ||||
|   drawn: "Unentschieden" | ||||
|   won: "{name} hat gesiegt" | ||||
|   black: "Schwarz" | ||||
|   white: "Weiß" | ||||
|   total: "Gesamt" | ||||
|   turnCount: " Zug {count}" | ||||
|   myGames: "Meine Runden" | ||||
|   allGames: "Alle Runden" | ||||
|   ended: "Beendet" | ||||
|   playing: "Laufend" | ||||
|   isLlotheo: "Der mit weniger Steinen gewinnt (Llotheo)" | ||||
|   loopedMap: "Wiederholendes Spielbrett" | ||||
|   canPutEverywhere: "Steine können überall platziert werden" | ||||
| _instanceTicker: | ||||
|   none: "Nie anzeigen" | ||||
|   remote: "Für Benutzer fremder Instanzen anzeigen" | ||||
|   always: "Immer anzeigen" | ||||
| _serverDisconnectedBehavior: | ||||
|   reload: "Automatisch aktualisieren" | ||||
|   dialog: "Warnungsfenster zeigen" | ||||
|   quiet: "Unaufdringlich warnen" | ||||
| _channel: | ||||
|   create: "Kanal erstellen" | ||||
|   edit: "Kanal bearbeiten" | ||||
|   setBanner: "Kanalbanner festlegen" | ||||
|   removeBanner: "Kanalbanner entfernen" | ||||
|   featured: "Trends" | ||||
|   owned: "Besitzt" | ||||
|   following: "Gefolgt" | ||||
|   usersCount: "{n} Teilnehmer" | ||||
|   notesCount: "{n} Notizen" | ||||
| _sidebar: | ||||
|   full: "Voll" | ||||
|   icon: "Symbole" | ||||
|   hide: "Ausblenden" | ||||
| _wordMute: | ||||
|   muteWords: "Wort stummschalten" | ||||
|   muteWordsDescription: "Mit Leerzeichen für eine \"UND\"-Verknüpfung trennen, durch Zeilenumbrüche für eine \"ODER\"-Verknüpfung trennen." | ||||
|   muteWordsDescription2: "Umgib Schlüsselworter mit Schrägstrichen, um Reguläre Ausdrücke zu verwenden." | ||||
|   softDescription: "Notizen, die die eingestellten Konditionen erfüllen, in der Chronik ausblenden" | ||||
|   hardDescription: "Verhindern, dass Notizen, die die eingestellten Konditionen erfüllen, der Chronik hinzugefügt werden. Zudem werden diese Notizen auch nicht der Chronik hinzugefügt, falls die Konditionen geändert werden." | ||||
|   soft: "Leicht" | ||||
|   hard: "Schwer" | ||||
|   mutedNotes: "Stummgeschaltete Notizen" | ||||
| _theme: | ||||
|   explore: "Themen erforschen" | ||||
|   install: "Thema installieren" | ||||
|   manage: "Themaverwaltung" | ||||
|   code: "Themencode" | ||||
|   code: "Themen-Code" | ||||
|   installed: "{name} wurde installiert" | ||||
|   installedThemes: "Installierte Themen" | ||||
|   builtinThemes: "Eingebaute Themen" | ||||
|   alreadyInstalled: "Dieses Thema ist bereits installiert" | ||||
|   invalid: "Themenformat ist ungültig" | ||||
|   make: "Farbthema erstellen" | ||||
|   base: "Basis" | ||||
|   addConstant: "Konstante hinzufügen" | ||||
|   constant: "Konstante" | ||||
|   defaultValue: "Standardwert" | ||||
|   color: "Farbe" | ||||
|   refProp: "Eigenschaft referenzieren" | ||||
|   refConst: "Konstante referenzieren" | ||||
|   key: "Schlüssel" | ||||
|   func: "Funktionen" | ||||
|   funcKind: "Funktionstyp" | ||||
|   argument: "Parameter" | ||||
|   basedProp: "Referenzierte Eigenschaft" | ||||
|   alpha: "Transparenz" | ||||
|   darken: "Verdunkeln" | ||||
|   lighten: "Erhellen" | ||||
|   inputConstantName: "Name der Konstanten eingeben" | ||||
|   importInfo: "Du kannst hier Themen-Code einfügen, um ihn in den Editor zu importieren" | ||||
|   deleteConstantConfirm: "Die Konstante {const} wirklich löschen?" | ||||
|   keys: | ||||
|     accent: "Akzentfarbe" | ||||
|     bg: "Hintergrund" | ||||
|     fg: "Text" | ||||
|     focus: "Fokus" | ||||
|     indicator: "Indikator" | ||||
|     panel: "Panel" | ||||
|     shadow: "Schatten" | ||||
|     header: "Kopfzeile" | ||||
|     navBg: "Hintergrund der Seitenleiste" | ||||
|     navFg: "Text der Seitenleiste" | ||||
|     navHoverFg: "Text der Seitenleiste (Mouseover)" | ||||
|     navActive: "Text der Seitenleiste (Aktiv)" | ||||
|     navIndicator: "Indikator der Seitenleiste" | ||||
|     link: "Link" | ||||
|     hashtag: "Hashtag" | ||||
|     mention: "Erwähnungen" | ||||
|     mentionMe: "Erwähnungen (Ich)" | ||||
|     renote: "Renote" | ||||
|     modalBg: "Hintergrund des Modals" | ||||
|     divider: "Trenner" | ||||
|     scrollbarHandle: "Griff des Scrollbalkens" | ||||
|     scrollbarHandleHover: "Griff des Scrollbalkens (Mouseover)" | ||||
|     dateLabelFg: "Text von Datumsbeschriftungen" | ||||
|     infoBg: "Hintergrund von Informationen" | ||||
|     infoFg: "Text von Informationen" | ||||
|     infoWarnBg: "Hintergrund von Warnungen" | ||||
|     infoWarnFg: "Text von Informationen" | ||||
|     cwBg: "Hintergrund von versteckten Inhalten" | ||||
|     cwFg: "Text von versteckten Inhalten" | ||||
|     cwHoverBg: "Hintergrund von versteckten Inhalten (Mouseover)" | ||||
|     toastBg: "Hintergrund von Benachrichtigungen" | ||||
|     toastFg: "Text von Benachrichtigungen" | ||||
|     buttonBg: "Hintergrund von Schaltflächen" | ||||
|     buttonHoverBg: "Hintergrund von Schaltflächen (Mouseover)" | ||||
|     inputBorder: "Rahmen des Eingabefelds" | ||||
|     listItemHoverBg: "Hintergrund von Listeneinträgen (Mouseover)" | ||||
|     driveFolderBg: "Hintergrund von Drive-Ordnern" | ||||
|     wallpaperOverlay: "Hintergrundbild-Overlay" | ||||
|     badge: "Wappen" | ||||
|     messageBg: "Hintergrund von Chats" | ||||
|     accentDarken: "Akzent (Verdunkelt)" | ||||
|     accentLighten: "Akzent (Erhellt)" | ||||
|     fgHighlighted: "Hervorgehobener Text" | ||||
| _sfx: | ||||
|   note: "Notizen" | ||||
|   noteMy: "Meine Notizen" | ||||
|   notification: "Benachrichtigungen" | ||||
|   chat: "Privatnachrichten" | ||||
|   chat: "Chat" | ||||
|   chatBg: "Nachrichten (Hintergrund)" | ||||
|   antenna: "Antennen" | ||||
|   channel: "Kanalbenachrichtigung" | ||||
|   reversiPutBlack: "Reversi: Schwarz macht einen Zug" | ||||
|   reversiPutWhite: "Reversi: Weiß macht einen Zug" | ||||
| _ago: | ||||
|   unknown: "Unbekannt" | ||||
|   future: "Zukunft" | ||||
| @@ -580,15 +937,15 @@ _permissions: | ||||
|   "write:favorites": "Deine Favoriten-Liste bearbeiten" | ||||
|   "read:following": "Deine Follower-Liste lesen" | ||||
|   "write:following": "Anderen Benutzern folgen oder entfolgen" | ||||
|   "read:messaging": "Privatnachrichten lesen" | ||||
|   "write:messaging": "Privatnachrichten schicken oder löschen" | ||||
|   "read:messaging": "Chats lesen" | ||||
|   "write:messaging": "Chatnachrichten schicken oder löschen" | ||||
|   "read:mutes": "Stummschaltungen lesen" | ||||
|   "write:mutes": "Stummschaltungen bearbeiten" | ||||
|   "write:notes": "Notizen schreiben oder löschen" | ||||
|   "read:notifications": "Benachrichtigungen lesen" | ||||
|   "write:notifications": "Mit Benachrichtigungen arbeiten" | ||||
|   "write:notifications": "Benachrichtigungen bearbeiten" | ||||
|   "read:reactions": "Reaktionen lesen" | ||||
|   "write:reactions": "Reaktionen hinzufügen und bearbeiten" | ||||
|   "write:reactions": "Reaktionen hinzufügen und ändern" | ||||
|   "write:votes": "In Umfragen abstimmen" | ||||
|   "read:pages": "Deine Seiten lesen" | ||||
|   "write:pages": "Deine Seiten bearbeiten oder löschen" | ||||
| @@ -596,6 +953,8 @@ _permissions: | ||||
|   "write:page-likes": "Liste der Seiten, die mir gefallen, bearbeiten" | ||||
|   "read:user-groups": "Benutzergruppen lesen" | ||||
|   "write:user-groups": "Benutzergruppen bearbeiten oder löschen" | ||||
|   "read:channels": "Kanäle lesen" | ||||
|   "write:channels": "Kanäle bearbeiten" | ||||
| _auth: | ||||
|   shareAccess: "Möchtest du \"{name}\" authorisieren, auf dieses Benuzerkonto zugreifen zu können?" | ||||
|   shareAccessAsk: "Bist du dir sicher, dass du diese Anwendung authorisieren möchtest, auf dein Benutzerkonto zugreifen zu können?" | ||||
| @@ -627,12 +986,16 @@ _widgets: | ||||
|   rss: "RSS-Reader" | ||||
|   activity: "Aktivität" | ||||
|   photos: "Fotos" | ||||
|   digitalClock: "Digitaluhr" | ||||
|   federation: "Föderation" | ||||
|   postForm: "Neue Notiz anfertigen" | ||||
|   slideshow: "Diashow" | ||||
|   button: "Knopf" | ||||
| _cw: | ||||
|   hide: "Ausblenden" | ||||
|   show: "Mehr anzeigen" | ||||
|   chars: "{count} Zeichen" | ||||
|   files: "{count} Dateien" | ||||
|   poll: "Umfrage" | ||||
| _poll: | ||||
|   noOnlyOneChoice: "Mindestens zwei Antwortmöglichkeiten werden benötigt." | ||||
|   choiceN: "Auswahl {n}" | ||||
| @@ -665,9 +1028,11 @@ _visibility: | ||||
|   specified: "Direkt" | ||||
|   specifiedDescription: "Nur für bestimmte Benutzer sichtbar" | ||||
|   localOnly: "Nur Lokal" | ||||
|   localOnlyDescription: "Unsichtbar für Benutzer anderer Instanzen" | ||||
| _postForm: | ||||
|   replyPlaceholder: "Dieser Notiz antworten..." | ||||
|   quotePlaceholder: "Diese Notiz zitieren..." | ||||
|   channelPlaceholder: "In einen Kanal senden" | ||||
|   _placeholders: | ||||
|     a: "Was machst du momentan?" | ||||
|     b: "Was ist um dich herum los?" | ||||
| @@ -680,9 +1045,13 @@ _profile: | ||||
|   username: "Benutzername" | ||||
|   description: "Über mich" | ||||
|   youCanIncludeHashtags: "Du kannst auch Hashtags in deiner Beschreibung verwenden." | ||||
|   metadata: "Andere Informationen" | ||||
|   metadata: "Zusätzliche Informationen" | ||||
|   metadataEdit: "Zusätzliche Informationen bearbeiten" | ||||
|   metadataDescription: "Du kannst auf deinem Profil vier zusätzliche Informationsblöcke anzeigen lassen." | ||||
|   metadataLabel: "Name" | ||||
|   metadataContent: "Inhalt" | ||||
|   changeAvatar: "Profilbild ändern" | ||||
|   changeBanner: "Banner ändern" | ||||
| _exportOrImport: | ||||
|   allNotes: "Alle Notizen" | ||||
|   followingList: "Gefolgte Benutzer" | ||||
| @@ -781,6 +1150,7 @@ _rooms: | ||||
|     holo-display: "Holographischer Bildschirm" | ||||
|     energy-drink: "Energy Drink" | ||||
|     doll-ai: "Ai-Puppe" | ||||
|     banknote: "Geldscheine" | ||||
| _pages: | ||||
|   newPage: "Seite erstellen" | ||||
|   editPage: "Diese Seite bearbeiten" | ||||
| @@ -788,6 +1158,7 @@ _pages: | ||||
|   created: "Seite erfolgreich erstellt" | ||||
|   updated: "Seite erfolgreich aktualisiert" | ||||
|   deleted: "Seite erfolgreich gelöscht" | ||||
|   pageSetting: "Seiteneinstellungen" | ||||
|   nameAlreadyExists: "Die angegebene Seiten-URL existiert bereits" | ||||
|   invalidNameTitle: "Die angegebene Seiten-URL ist ungültig" | ||||
|   invalidNameText: "Überprüfe, ob der Seitentitel nicht leer ist" | ||||
| @@ -798,7 +1169,9 @@ _pages: | ||||
|   unlike: "\"Gefällt mir\" entfernen" | ||||
|   my: "Meine Seiten" | ||||
|   liked: "Seiten, die mir gefallen" | ||||
|   featured: "Beliebt" | ||||
|   inspector: "Inspektor" | ||||
|   contents: "Inhalt" | ||||
|   content: "Inhalt" | ||||
|   variables: "Variablen" | ||||
|   title: "Titel" | ||||
| @@ -822,7 +1195,7 @@ _pages: | ||||
|     text: "Text" | ||||
|     textarea: "Textfeld" | ||||
|     section: "Abschnitt" | ||||
|     image: "Bilder" | ||||
|     image: "Bild" | ||||
|     button: "Knopf" | ||||
|     if: "Falls" | ||||
|     _if: | ||||
| @@ -837,7 +1210,7 @@ _pages: | ||||
|       name: "Variablenname" | ||||
|       text: "Titel" | ||||
|       default: "Standardwert" | ||||
|     textareaInput: "Eingabe des mehrzeiligen Textfelds" | ||||
|     textareaInput: "Mehrzeiliges Texteingabefeld" | ||||
|     _textareaInput: | ||||
|       name: "Variablenname" | ||||
|       text: "Titel" | ||||
| @@ -852,6 +1225,11 @@ _pages: | ||||
|       id: "Leinwand-ID" | ||||
|       width: "Breite" | ||||
|       height: "Höhe" | ||||
|     note: "Eingebettete Notiz" | ||||
|     _note: | ||||
|       id: "Notiz ID" | ||||
|       idDescription: "Du kannst alternativ auch die Notiz-URL angeben." | ||||
|       detailed: "Detailierte Ansicht" | ||||
|     switch: "Fallunterscheidung" | ||||
|     _switch: | ||||
|       name: "Variablenname" | ||||
| @@ -1066,3 +1444,50 @@ _relayStatus: | ||||
|   requesting: "Ausstehend" | ||||
|   accepted: "Akzeptiert" | ||||
|   rejected: "Abgelehnt" | ||||
| _notification: | ||||
|   fileUploaded: "Datei erfolgreich hochgeladen" | ||||
|   youGotMention: "{name} hat dich erwähnt" | ||||
|   youGotReply: "{name} hat dir geantwortet" | ||||
|   youGotQuote: "{name} hat dich zitiert" | ||||
|   youRenoted: "Renote deiner Notiz von {name}" | ||||
|   youGotPoll: "{name} hat auf deiner Umfrage abgestimmt" | ||||
|   youGotMessagingMessageFromUser: "{name} hat dir eine Chatnachricht gesendet" | ||||
|   youGotMessagingMessageFromGroup: "In die Gruppe {name} wurde eine Chatnachricht gesendet" | ||||
|   youWereFollowed: "Du hast einen neuen Follower" | ||||
|   youReceivedFollowRequest: "Du hast eine Follow-Anfrage erhalten" | ||||
|   yourFollowRequestAccepted: "Deine Follow-Anfrage wurde akzeptiert" | ||||
|   youWereInvitedToGroup: "Du wurdest in eine Gruppe eingeladen" | ||||
|   _types: | ||||
|     all: "Alle" | ||||
|     follow: "Neue Follower" | ||||
|     mention: "Erwähnungen" | ||||
|     reply: "Antworten" | ||||
|     renote: "Renotes" | ||||
|     quote: "Zitationen" | ||||
|     reaction: "Reaktionen" | ||||
|     pollVote: "Antworten auf Umfragen" | ||||
|     receiveFollowRequest: "Follow-Anfrage erhalten" | ||||
|     followRequestAccepted: "Follow-Anfrage akzeptiert" | ||||
|     groupInvited: "Gruppeneinladung erhalten" | ||||
|     app: "Benachrichtigungen von Apps" | ||||
| _deck: | ||||
|   alwaysShowMainColumn: "Hauptspalte immer zeigen" | ||||
|   columnAlign: "Spalten ausrichten" | ||||
|   columnMargin: "Spaltenabstand" | ||||
|   columnHeaderHeight: "Spaltenkopfhöhe" | ||||
|   addColumn: "Spalte hinzufügen" | ||||
|   swapLeft: "Nach links verschieben" | ||||
|   swapRight: "Nach rechts verschieben" | ||||
|   swapUp: "Nach oben verschieben" | ||||
|   swapDown: "Nach unten verschieben" | ||||
|   stackLeft: "Nach links stapeln" | ||||
|   popRight: "Nach rechts vom Stapel nehmen" | ||||
|   _columns: | ||||
|     main: "Hauptspalte" | ||||
|     widgets: "Widgets" | ||||
|     notifications: "Benachrichtigungen" | ||||
|     tl: "Chronik" | ||||
|     antenna: "Antennen" | ||||
|     list: "Listen" | ||||
|     mentions: "Erwähnungen" | ||||
|     direct: "Direkt" | ||||
|   | ||||
| @@ -16,6 +16,9 @@ noNotes: "No notes" | ||||
| noNotifications: "No notifications" | ||||
| instance: "Instance" | ||||
| settings: "Settings" | ||||
| basicSettings: "Basic Settings" | ||||
| otherSettings: "Other Settings" | ||||
| openInWindow: "Open in window" | ||||
| profile: "Profile" | ||||
| timeline: "Timeline" | ||||
| noAccountDescription: "This user has not written their bio yet." | ||||
| @@ -29,7 +32,10 @@ users: "Users" | ||||
| addUser: "Add a user" | ||||
| favorite: "Favorite" | ||||
| favorites: "Favorites" | ||||
| unfavorite: "Undo favorite" | ||||
| unfavorite: "Unfavorite" | ||||
| favorited: "Added to favorites." | ||||
| alreadyFavorited: "Already added to favorites." | ||||
| cantFavorite: "Couldn't add to favorites." | ||||
| pin: "Pin to profile" | ||||
| unpin: "Unpin from profile" | ||||
| copyContent: "Copy contents" | ||||
| @@ -40,11 +46,13 @@ deleteAndEditConfirm: "Are you sure you want to delete this note and edit it? Yo | ||||
| addToList: "Add to list" | ||||
| sendMessage: "Send a message" | ||||
| copyUsername: "Copy username" | ||||
| searchUser: "User search" | ||||
| reply: "Reply" | ||||
| loadMore: "Load more" | ||||
| youGotNewFollower: "Followed you" | ||||
| receiveFollowRequest: "Follow request received" | ||||
| followRequestAccepted: "Follow request accepted" | ||||
| mention: "Mention" | ||||
| mentions: "Mentions" | ||||
| directNotes: "Direct notes" | ||||
| importAndExport: "Import / Export" | ||||
| @@ -65,8 +73,11 @@ followers: "Followers" | ||||
| followsYou: "Follows you" | ||||
| createList: "Create list" | ||||
| manageLists: "Manage lists" | ||||
| error: "Something happened :(" | ||||
| error: "Error" | ||||
| somethingHappened: "An error occurred" | ||||
| retry: "Retry" | ||||
| pageLoadError: "Failed to load page" | ||||
| pageLoadErrorDescription: "This is normally caused by network errors or the browser's cache. Try clearung the cache and then try again after waiting a little while." | ||||
| enterListName: "List name" | ||||
| privacy: "Privacy" | ||||
| makeFollowManuallyApprove: "Follow requests require approval" | ||||
| @@ -79,6 +90,9 @@ followRequestPending: "Pending follow request" | ||||
| enterEmoji: "Enter an emoji" | ||||
| renote: "Renote" | ||||
| unrenote: "Unrenote" | ||||
| renoted: "Renoted." | ||||
| cantRenote: "This post can't be renoted." | ||||
| cantReRenote: "A renote can't be renoted." | ||||
| quote: "Quote" | ||||
| pinnedNote: "Pinned note" | ||||
| you: "You" | ||||
| @@ -87,6 +101,7 @@ sensitive: "NSFW" | ||||
| add: "Add" | ||||
| reaction: "Reaction" | ||||
| reactionSettingDescription: "Assign your favorite reactions which want to pin in reaction picker." | ||||
| reactionSettingDescription2: "Drag to reorder, Click to delete, Press \"+\" to add" | ||||
| rememberNoteVisibility: "Remember note visibility settings" | ||||
| attachCancel: "Remove attachment" | ||||
| markAsSensitive: "Mark as NSFW" | ||||
| @@ -103,7 +118,12 @@ unblockConfirm: "Are you sure that you want to unblock this account?" | ||||
| suspendConfirm: "Are you sure that you want to suspend this account?" | ||||
| unsuspendConfirm: "Are you sure you that want to unsuspend this account?" | ||||
| selectList: "Select a list" | ||||
| selectAntenna: "Select an Antenna" | ||||
| selectWidget: "Select a widget" | ||||
| editWidgets: "Edit widgets" | ||||
| editWidgetsExit: "Done" | ||||
| customEmojis: "Custom Emoji" | ||||
| emoji: "Emoji" | ||||
| emojiName: "Emoji name" | ||||
| emojiUrl: "Emoji URL" | ||||
| addEmoji: "Add an emoji" | ||||
| @@ -111,7 +131,9 @@ settingGuide: "Suggested Configuration" | ||||
| cacheRemoteFiles: "Cache remote files" | ||||
| cacheRemoteFilesDescription: "When this setting is disabled, remote files are loaded directly from the remote instance. Disabling this will decrease storage usage, but will increase traffic, because thumbnails will not be generated." | ||||
| flagAsBot: "This account is a bot" | ||||
| flagAsBotDescription: "If this account is controlled by a program, set this option. If enabled, it will act as flag for other developers to prevent endless interaction chains with other bots and adjust Misskey's internal systems to treat this account as a bot." | ||||
| flagAsCat: "This account is a cat" | ||||
| flagAsCatDescription: "Toggle this flag on for this account to be marked as a cat." | ||||
| autoAcceptFollowed: "Automatically approve follow requests from users you're following" | ||||
| addAcount: "Add Account" | ||||
| loginFailed: "Failed to sign in" | ||||
| @@ -173,7 +195,6 @@ processing: "Processing" | ||||
| preview: "Preview" | ||||
| default: "Default" | ||||
| noCustomEmojis: "There are no emojis" | ||||
| customEmojisOfRemote: "Emojis from other instances" | ||||
| noJobs: "There are no jobs" | ||||
| federating: "Federating" | ||||
| blocked: "Blocked" | ||||
| @@ -202,6 +223,8 @@ imageUrl: "Image URL" | ||||
| remove: "Delete" | ||||
| removed: "Successfully deleted" | ||||
| removeAreYouSure: "Are you sure that you want to delete \"{x}\"?" | ||||
| deleteAreYouSure: "Are you sure that you want to delete \"{x}\"?" | ||||
| resetAreYouSure: "Really reset?" | ||||
| saved: "Saved" | ||||
| messaging: "Messaging" | ||||
| upload: "Upload" | ||||
| @@ -260,6 +283,7 @@ rename: "Rename" | ||||
| avatar: "Avatar" | ||||
| banner: "Banner" | ||||
| nsfw: "NSFW" | ||||
| whenServerDisconnected: "When losing connection to the server" | ||||
| disconnectedFromServer: "Connection to the server was interrupted." | ||||
| reload: "Refresh" | ||||
| doNothing: "Ignore" | ||||
| @@ -300,6 +324,10 @@ bannerUrl: "Banner image URL" | ||||
| basicInfo: "Basic info" | ||||
| pinnedUsers: "Pinned user" | ||||
| pinnedUsersDescription: "List one username per line. Users listed here will be pinned under \"Explore\" tab." | ||||
| pinnedPages: "Pinned pages" | ||||
| pinnedPagesDescription: "Enter the paths of the pages you want to pin to the top page of this instance, separated by new lines." | ||||
| pinnedClipId: "ID of the pinned clip" | ||||
| pinnedNotes: "Pinned notes" | ||||
| hcaptcha: "hCaptcha" | ||||
| enableHcaptcha: "Enable hCaptcha" | ||||
| hcaptchaSiteKey: "Site key" | ||||
| @@ -340,13 +368,6 @@ popularTags: "Trending Tags" | ||||
| userList: "Lists" | ||||
| about: "About" | ||||
| aboutMisskey: "About Misskey" | ||||
| aboutMisskeyText: "Misskey is an open-source software developed by syuilo since 2014." | ||||
| misskeyMembers: "It is currently developed and maintained by the members listed below:" | ||||
| misskeySource: "Source code is available here:" | ||||
| misskeyTranslation: "Help us with your contribution to translate Misskey:" | ||||
| misskeyDonate: "Help us to keep improving the software by donating here:" | ||||
| morePatrons: "We really appreciate the support of many other helpers not listed here. Thank you! 🥰" | ||||
| patrons: "Backers" | ||||
| administrator: "Admin" | ||||
| token: "Token" | ||||
| twoStepAuthentication: "Two-factor authentication" | ||||
| @@ -360,9 +381,6 @@ unregister: "Unregister" | ||||
| passwordLessLogin: "Set up password-less login" | ||||
| resetPassword: "Reset password" | ||||
| newPasswordIs: "The new password is \"{password}\"" | ||||
| autoReloadWhenDisconnected: "Auto refresh when disconnected from server" | ||||
| autoNoteWatch: "Watch note automatically" | ||||
| autoNoteWatchDescription: "Get notified about the notes which you reactioned or replied." | ||||
| reduceUiAnimation: "Reduce UI animation" | ||||
| share: "Share" | ||||
| notFound: "Not found" | ||||
| @@ -393,13 +411,14 @@ next: "Next" | ||||
| retype: "Enter again" | ||||
| noteOf: "{user}'s notes" | ||||
| inviteToGroup: "Invite to group" | ||||
| maxNoteTextLength: "Character limit of the note" | ||||
| maxNoteTextLength: "Character limit of notes" | ||||
| quoteAttached: "Quoted" | ||||
| quoteQuestion: "Do you want to append a quote?" | ||||
| noMessagesYet: "No messages yet" | ||||
| newMessageExists: "You've got a new message" | ||||
| onlyOneFileCanBeAttached: "You can only attach one file to a message" | ||||
| signinRequired: "Please sign in" | ||||
| invitations: "Invitations" | ||||
| invitationCode: "Invitation code" | ||||
| checking: "Checking" | ||||
| available: "Available" | ||||
| @@ -423,6 +442,7 @@ useOsNativeEmojis: "Use OS native Emojis" | ||||
| youHaveNoGroups: "You have no groups" | ||||
| joinOrCreateGroup: "Get invited to join the groups or you can create your own group." | ||||
| noHistory: "No history items" | ||||
| signinHistory: "Login history" | ||||
| disableAnimatedMfm: "Disable MFM with animation" | ||||
| doing: "On my way" | ||||
| category: "Category" | ||||
| @@ -440,8 +460,8 @@ remote: "Remote" | ||||
| total: "Total" | ||||
| weekOverWeekChanges: "Weekly" | ||||
| dayOverDayChanges: "Daily" | ||||
| accessibility: "Accessibility" | ||||
| clinetSettings: "Client Settings" | ||||
| appearance: "Appearance" | ||||
| clientSettings: "Client settings" | ||||
| accountSettings: "Account Settings" | ||||
| promotion: "Promoted" | ||||
| promote: "Promote" | ||||
| @@ -464,6 +484,7 @@ objectStorageUseSSL: "Use SSL" | ||||
| objectStorageUseSSLDesc: "Turn off this if you are not going to use HTTPS for API connection" | ||||
| objectStorageUseProxy: "Connect over Proxy" | ||||
| objectStorageUseProxyDesc: "Turn off this if you are not going to use Proxy for ObjectStorage connection" | ||||
| objectStorageSetPublicRead: "Set \"public-read\" on upload" | ||||
| serverLogs: "Server logs" | ||||
| deleteAll: "Delete all" | ||||
| showFixedPostForm: "Display the posting form at the top of the timeline" | ||||
| @@ -471,7 +492,10 @@ newNoteRecived: "You've got a new note" | ||||
| sounds: "Sounds" | ||||
| listen: "Listen" | ||||
| none: "None" | ||||
| showInPage: "Show in page" | ||||
| popout: "Pop-out" | ||||
| volume: "Volume" | ||||
| masterVolume: "Master volume" | ||||
| details: "Details" | ||||
| chooseEmoji: "Choose an emoji" | ||||
| unableToProcess: "The operation could not be completed." | ||||
| @@ -506,14 +530,344 @@ relays: "Relays" | ||||
| addRelay: "Add Relay" | ||||
| inboxUrl: "Inbox URL" | ||||
| addedRelays: "Added Relays" | ||||
| serviceworkerInfo: "Must be enabled for push notifications." | ||||
| deletedNote: "Deleted note" | ||||
| invisibleNote: "Invisible note" | ||||
| enableInfiniteScroll: "Enable infinite scrolling" | ||||
| visibility: "Visiblility" | ||||
| poll: "Poll" | ||||
| useCw: "Hide content" | ||||
| enablePlayer: "Open video player" | ||||
| disablePlayer: "Close video player" | ||||
| expandTweet: "Expand tweet" | ||||
| themeEditor: "Theme editor" | ||||
| description: "Description" | ||||
| author: "Author" | ||||
| leaveConfirm: "There are unsaved changes. Do you want to discard them?" | ||||
| manage: "Management" | ||||
| plugins: "Plugins" | ||||
| pluginInstallWarn: "Please do not install untrustworthy plugins." | ||||
| deck: "Deck" | ||||
| undeck: "Leave Deck" | ||||
| useBlurEffectForModal: "Use blur effect for modals" | ||||
| useFullReactionPicker: "Use full-size reaction picker" | ||||
| width: "Width" | ||||
| height: "Height" | ||||
| large: "Big" | ||||
| medium: "Medium" | ||||
| small: "Small" | ||||
| generateAccessToken: "Generate access token" | ||||
| permission: "Permissions" | ||||
| enableAll: "Enable all" | ||||
| disableAll: "Disable all" | ||||
| tokenRequested: "Grant access to account" | ||||
| pluginTokenRequestedDescription: "This plugin will be able to use the permissions set here." | ||||
| notificationType: "Notification type" | ||||
| edit: "Edit" | ||||
| useStarForReactionFallback: "Use ★ as fallback if the reaction emoji is unknown" | ||||
| emailConfig: "Email server configuration" | ||||
| enableEmail: "Enable email distribution" | ||||
| emailConfigInfo: "Used to confirm your email during sign-up and if you forget your password" | ||||
| email: "Email" | ||||
| emailAddress: "Email address" | ||||
| smtpConfig: "SMTP Server configuration" | ||||
| smtpHost: "Host" | ||||
| smtpPort: "Port" | ||||
| smtpUser: "Username" | ||||
| smtpPass: "Password" | ||||
| emptyToDisableSmtpAuth: "Leave username and password empty to disable SMTP verification" | ||||
| smtpSecure: "Use implicit SSL/TLS for SMTP connections" | ||||
| smtpSecureInfo: "Turn this off when using STARTTLS" | ||||
| testEmail: "Test email delivery" | ||||
| wordMute: "Word mute" | ||||
| userSaysSomething: "{name} said something" | ||||
| makeActive: "Activate" | ||||
| display: "Display" | ||||
| copy: "Copy" | ||||
| metrics: "Metrics" | ||||
| overview: "Overview" | ||||
| logs: "Logs" | ||||
| delayed: "Delayed" | ||||
| database: "Database" | ||||
| channel: "Channels" | ||||
| create: "Create" | ||||
| notificationSetting: "Notification settings" | ||||
| notificationSettingDesc: "Select the type of notification to display" | ||||
| useGlobalSetting: "Use global setting" | ||||
| useGlobalSettingDesc: "If turned on, your account's notification settings will be used. If turned off, individual configurations can be made." | ||||
| other: "Other" | ||||
| regenerateLoginToken: "Regenerate login token" | ||||
| regenerateLoginTokenDescription: "Regenerate the token used internally during login. Normally this action is not necessary. If regenerated, all devices will be logged out." | ||||
| setMultipleBySeparatingWithSpace: "You can set multiple by separating them with spaces." | ||||
| fileIdOrUrl: "File-ID or URL" | ||||
| chatOpenBehavior: "Behavior of the chat window when opened" | ||||
| behavior: "Behavior" | ||||
| sample: "Sample" | ||||
| abuseReports: "Reports" | ||||
| reportAbuse: "Report" | ||||
| reportAbuseOf: "Report {name}" | ||||
| fillAbuseReportDescription: "Please fill in the report details. If it is about a specific note, please include its URL." | ||||
| abuseReported: "Your report has been sent. Thank you very much." | ||||
| send: "Send" | ||||
| abuseMarkAsResolved: "Mark report as resolved" | ||||
| openInNewTab: "Open in new tab" | ||||
| openInSideView: "Open in side view" | ||||
| defaultNavigationBehaviour: "Default navigation behavior" | ||||
| editTheseSettingsMayBreakAccount: "Editing these settings may damage your account." | ||||
| instanceTicker: "Instance information of notes" | ||||
| waitingFor: "Waiting for {x}" | ||||
| random: "Random" | ||||
| system: "System" | ||||
| switchUi: "Switch UI" | ||||
| desktop: "Desktop" | ||||
| clip: "Clip" | ||||
| createNew: "Create new" | ||||
| optional: "Optional" | ||||
| createNewClip: "Create new clip" | ||||
| public: "Public" | ||||
| i18nInfo: "Misskey is being translated into various languages by volunteers. You can help at {link}." | ||||
| manageAccessTokens: "Manage access tokens" | ||||
| accountInfo: "Account Info" | ||||
| notesCount: "Amount of notes" | ||||
| repliesCount: "Amount of replies sent" | ||||
| renotesCount: "Amount of renotes sent" | ||||
| repliedCount: "Amount of replies received" | ||||
| renotedCount: "Amount of renotes received" | ||||
| followingCount: "Amount of followed accounts" | ||||
| followersCount: "Amount of followers" | ||||
| sentReactionsCount: "Amount of sent reactions" | ||||
| receivedReactionsCount: "Amount of received reactions" | ||||
| pollVotesCount: "Amount of sent poll votes" | ||||
| pollVotedCount: "Amount of received poll votes" | ||||
| yes: "Yes" | ||||
| no: "No" | ||||
| driveFilesCount: "Amount of drive files" | ||||
| driveUsage: "Drive space usage" | ||||
| noCrawle: "Reject crawler indexing" | ||||
| noCrawleDescription: "Ask search engines not to index your profile page, notes, Pages, etc" | ||||
| lockedAccountInfo: "Unless you set your note visiblity to \"Followers only\", your notes are visible to anyone even if you require followers to be manually approved." | ||||
| alwaysMarkSensitive: "Mark NSFW by default" | ||||
| loadRawImages: "Display image attachments fully instead of thumbnails" | ||||
| disableShowingAnimatedImages: "Don't play animated images" | ||||
| verificationEmailSent: "A verification email has been sent. Please access the included link to complete verification." | ||||
| notSet: "Not set" | ||||
| emailVerified: "Email has been verified" | ||||
| noteFavoritesCount: "Amount of favorite notes" | ||||
| pageLikesCount: "Amount of received Page likes" | ||||
| pageLikedCount: "Amount of liked Pages" | ||||
| reversiCount: "Number of Reversi matches" | ||||
| contact: "Contact" | ||||
| useSystemFont: "Use the system's default font" | ||||
| clips: "Clips" | ||||
| experimentalFeatures: "Experimental features" | ||||
| developer: "Developer" | ||||
| makeExplorable: "Make account visible in \"Explore\"" | ||||
| makeExplorableDescription: "If you turn this off, your account will not show up in the \"Explore\" section." | ||||
| showGapBetweenNotesInTimeline: "Show a gap between posts on the timeline" | ||||
| duplicate: "Duplicate" | ||||
| left: "Left" | ||||
| center: "Center" | ||||
| wide: "Wide" | ||||
| narrow: "Narrow" | ||||
| reloadToApplySetting: "Settings will be applied upon page reload. Reload now?" | ||||
| _aboutMisskey: | ||||
|   about: "Misskey is open-source software being developed by syuilo since 2014." | ||||
|   contributors: "Main contributors" | ||||
|   allContributors: "All contributors" | ||||
|   source: "Source code" | ||||
|   translation: "Translate Misskey" | ||||
|   donate: "Donate to Misskey" | ||||
|   morePatrons: "We really appreciate the support of many other helpers not listed here. Thank you! 🥰" | ||||
|   patrons: "Backers" | ||||
| _nsfw: | ||||
|   respect: "Hide NSFW media" | ||||
|   ignore: "Don't hide NSFW media" | ||||
|   force: "Hide all media" | ||||
| _mfm: | ||||
|   cheatSheet: "MFM Cheatsheet" | ||||
|   intro: "MFM is a Misskey-exclusive markup language that can be used in many places. Here you can view a list of all available MFM syntax." | ||||
|   dummy: "Misskey expands the world of the Fediverse" | ||||
|   mention: "Mention" | ||||
|   mentionDescription: "Using an At-Symbol and a username, you can specify a specific user." | ||||
|   hashtag: "Hashtag" | ||||
|   hashtagDescription: "Using a number sign and text, you can specify a hashtag." | ||||
|   url: "URL" | ||||
|   urlDescription: "URLs can be displayed." | ||||
|   link: "Link" | ||||
|   linkDescription: "Specific parts of text can be displayed as URL." | ||||
|   bold: "Bold" | ||||
|   boldDescription: "Highlights letters by making them thicker." | ||||
|   small: "Small" | ||||
|   smallDescription: "Displays contents small and thinn." | ||||
|   center: "Center" | ||||
|   centerDescription: "Displays content centered." | ||||
|   inlineCode: "Code (Inline)" | ||||
|   inlineCodeDescription: "Displays inline syntax highlighting for (program-)code." | ||||
|   blockCode: "Code (Block)" | ||||
|   blockCodeDescription: "Displays syntax highlighting for multi-line (program-)code in a block." | ||||
|   inlineMath: "Math (In-line)" | ||||
|   inlineMathDescription: "Display math formulas (KaTeX) in-line" | ||||
|   blockMath: "Math (Block)" | ||||
|   blockMathDescription: "Display multi-line Math formulas (KaTeX) in a block" | ||||
|   quote: "Quote" | ||||
|   quoteDescription: "Displays content as quote." | ||||
|   emoji: "Custom Emoji" | ||||
|   emojiDescription: "By surrounding a custom emoji name with colons, custom emoji can be displayed." | ||||
|   search: "Search" | ||||
|   searchDescription: "Displays a search box with pre-entered text." | ||||
|   flip: "Flip" | ||||
|   flipDescription: "Flips content horizontally or vertically." | ||||
|   jelly: "Animation (Jelly)" | ||||
|   jellyDescription: "Infuses a jelly-like animation." | ||||
|   tada: "Animation (Tada)" | ||||
|   tadaDescription: "Infuses a \"Tada!\"-like animation." | ||||
|   jump: "Animation (Jump)" | ||||
|   jumpDescription: "Infuses a jumping animation." | ||||
|   bounce: "Animation (Bounce)" | ||||
|   bounceDescription: "Causes a bouncy animation." | ||||
|   shake: "Animation (Shake)" | ||||
|   shakeDescription: "Infuses a shaking animation." | ||||
|   twitch: "Animation (Twitch)" | ||||
|   twitchDescription: "Infuses a strongly twitching animation." | ||||
|   spin: "Animation (Spin)" | ||||
|   spinDescription: "Infuses a spinning animation." | ||||
| _reversi: | ||||
|   reversi: "Reversi" | ||||
|   gameSettings: "Game settings" | ||||
|   chooseBoard: "Choose a board" | ||||
|   blackOrWhite: "Black/White" | ||||
|   blackIs: "{name} is playing Black" | ||||
|   rules: "Rules" | ||||
|   botSettings: "Bot options" | ||||
|   thisGameIsStartedSoon: "The game will start in a few seconds" | ||||
|   waitingForOther: "Waiting for the opponent's turn" | ||||
|   waitingForMe: "Waiting for your turn" | ||||
|   waitingBoth: "Get ready" | ||||
|   ready: "Ready" | ||||
|   cancelReady: "Cancel ready" | ||||
|   opponentTurn: "Opponent's turn" | ||||
|   myTurn: "Your turn" | ||||
|   turnOf: "{name}'s turn" | ||||
|   pastTurnOf: "{name}'s turn" | ||||
|   surrender: "Surrender" | ||||
|   surrendered: "By surrender" | ||||
|   drawn: "Draw" | ||||
|   won: "{name}'s win" | ||||
|   black: "Black" | ||||
|   white: "White" | ||||
|   total: "Total" | ||||
|   turnCount: "Turn {count}" | ||||
|   myGames: "My rounds" | ||||
|   allGames: "All rounds" | ||||
|   ended: "Ended" | ||||
|   playing: "Currently playing" | ||||
|   isLlotheo: "The one with fewer stones wins (Llotheo)" | ||||
|   loopedMap: "Looped map" | ||||
|   canPutEverywhere: "Tiles are placeable everywhere" | ||||
| _instanceTicker: | ||||
|   none: "Never show" | ||||
|   remote: "Show for remote users" | ||||
|   always: "Always show" | ||||
| _serverDisconnectedBehavior: | ||||
|   reload: "Automatically reload" | ||||
|   dialog: "Show warning dialog" | ||||
|   quiet: "Show unobtrusive warning" | ||||
| _channel: | ||||
|   create: "Create channel" | ||||
|   edit: "Edit channel" | ||||
|   setBanner: "Set banner" | ||||
|   removeBanner: "Remove banner" | ||||
|   featured: "Trending" | ||||
|   owned: "Owned" | ||||
|   following: "Followed" | ||||
|   usersCount: "{n} Participants" | ||||
|   notesCount: "{n} Notes" | ||||
| _sidebar: | ||||
|   full: "Full" | ||||
|   icon: "Icons" | ||||
|   hide: "Hide" | ||||
| _wordMute: | ||||
|   muteWords: "Word to mute" | ||||
|   muteWordsDescription: "Separate with spaces for AND condition. Separate with line breaks for OR." | ||||
|   muteWordsDescription2: "Surround keywords by slashes to use regular expressions." | ||||
|   softDescription: "Hide notes fulfilling the set conditions from the timeline." | ||||
|   hardDescription: "Prevent notes fulfilling the set conditions from being added to the timeline. In addition, these notes will not be added to the timeline even if the conditions are changed." | ||||
|   soft: "Soft" | ||||
|   hard: "Hard" | ||||
|   mutedNotes: "Muted notes" | ||||
| _theme: | ||||
|   explore: "Explore Themes" | ||||
|   install: "Install theme" | ||||
|   manage: "Themes manager" | ||||
|   code: "Theme code" | ||||
|   installed: "{name} has been installed" | ||||
|   installedThemes: "Installed themes" | ||||
|   builtinThemes: "Built-in themes" | ||||
|   alreadyInstalled: "The theme is already installed" | ||||
|   invalid: "Theme format is invalid" | ||||
|   make: "Make a theme" | ||||
|   base: "Base" | ||||
|   addConstant: "Add constant" | ||||
|   constant: "Constant" | ||||
|   defaultValue: "Default value" | ||||
|   color: "Color" | ||||
|   refProp: "Reference a property" | ||||
|   refConst: "Reference a constant" | ||||
|   key: "Key" | ||||
|   func: "Functions" | ||||
|   funcKind: "Function type" | ||||
|   argument: "Argument" | ||||
|   basedProp: "Referenced property" | ||||
|   alpha: "Opacity" | ||||
|   darken: "Darken" | ||||
|   lighten: "Lighten" | ||||
|   inputConstantName: "Enter a name for the constant" | ||||
|   importInfo: "If you enter theme code here, you can import it to the theme editor" | ||||
|   deleteConstantConfirm: "Do you really want to delete the constant {const}?" | ||||
|   keys: | ||||
|     accent: "Accent" | ||||
|     bg: "Background" | ||||
|     fg: "Text" | ||||
|     focus: "Focus" | ||||
|     indicator: "Indicator" | ||||
|     panel: "Panel" | ||||
|     shadow: "Shadow" | ||||
|     header: "Header" | ||||
|     navBg: "Sidebar background" | ||||
|     navFg: "Sidebar text" | ||||
|     navHoverFg: "Sidebar text (Hover)" | ||||
|     navActive: "Sidebar text (Active)" | ||||
|     navIndicator: "Sidebar indicator" | ||||
|     link: "Link" | ||||
|     hashtag: "Hashtag" | ||||
|     mention: "Mention" | ||||
|     mentionMe: "Mentions (Me)" | ||||
|     renote: "Renote" | ||||
|     modalBg: "Modal background" | ||||
|     divider: "Divider" | ||||
|     scrollbarHandle: "Scrollbar handle" | ||||
|     scrollbarHandleHover: "Scrollbar handle (Hover)" | ||||
|     dateLabelFg: "Text of date labels" | ||||
|     infoBg: "Information background" | ||||
|     infoFg: "Information text" | ||||
|     infoWarnBg: "Warning background" | ||||
|     infoWarnFg: "Warning text" | ||||
|     cwBg: "CW background" | ||||
|     cwFg: "CW text" | ||||
|     cwHoverBg: "CW background (Hover)" | ||||
|     toastBg: "Notification background" | ||||
|     toastFg: "Notification text" | ||||
|     buttonBg: "Button background" | ||||
|     buttonHoverBg: "Button background (Hover)" | ||||
|     inputBorder: "Input field border" | ||||
|     listItemHoverBg: "List item background (Hover)" | ||||
|     driveFolderBg: "Drive folder background" | ||||
|     wallpaperOverlay: "Wallpaper overlay" | ||||
|     badge: "Badge" | ||||
|     messageBg: "Chat background" | ||||
|     accentDarken: "Accent (Darkened)" | ||||
|     accentLighten: "Accent (Lightened)" | ||||
|     fgHighlighted: "Highlighted Text" | ||||
| _sfx: | ||||
|   note: "New note" | ||||
|   noteMy: "My note" | ||||
| @@ -521,6 +875,9 @@ _sfx: | ||||
|   chat: "Messaging" | ||||
|   chatBg: "Messaging (Background)" | ||||
|   antenna: "Antenna Reception" | ||||
|   channel: "Channel notifications" | ||||
|   reversiPutBlack: "Reversi: Black makes a move" | ||||
|   reversiPutWhite: "Reversi: White makes a move" | ||||
| _ago: | ||||
|   unknown: "Unknown" | ||||
|   future: "Future" | ||||
| @@ -596,6 +953,8 @@ _permissions: | ||||
|   "write:page-likes": "Edit likes on pages" | ||||
|   "read:user-groups": "View user groups" | ||||
|   "write:user-groups": "Edit or delete user groups" | ||||
|   "read:channels": "Read channels" | ||||
|   "write:channels": "Modify channels" | ||||
| _auth: | ||||
|   shareAccess: "Would you like to authorize \"{name}\" to access this account?" | ||||
|   shareAccessAsk: "Are you sure you want to authorize this application to access your account?" | ||||
| @@ -627,12 +986,16 @@ _widgets: | ||||
|   rss: "RSS reader" | ||||
|   activity: "Activity" | ||||
|   photos: "Photos" | ||||
|   digitalClock: "Digital clock" | ||||
|   federation: "Federation" | ||||
|   postForm: "Compose a note" | ||||
|   slideshow: "Slideshow" | ||||
|   button: "Button" | ||||
| _cw: | ||||
|   hide: "Hide" | ||||
|   show: "Load more" | ||||
|   chars: "{count} characters" | ||||
|   files: "{count} file(s)" | ||||
|   poll: "Poll" | ||||
| _poll: | ||||
|   noOnlyOneChoice: "At least two choices are needed" | ||||
|   choiceN: "Choice {n}" | ||||
| @@ -665,9 +1028,11 @@ _visibility: | ||||
|   specified: "Direct" | ||||
|   specifiedDescription: "Post to specified users only" | ||||
|   localOnly: "Local only" | ||||
|   localOnlyDescription: "Not visible to remote users" | ||||
| _postForm: | ||||
|   replyPlaceholder: "Reply to this note..." | ||||
|   quotePlaceholder: "Quote this note..." | ||||
|   channelPlaceholder: "Post to channel" | ||||
|   _placeholders: | ||||
|     a: "What are you up to?" | ||||
|     b: "What's happening around you?" | ||||
| @@ -680,9 +1045,13 @@ _profile: | ||||
|   username: "Username" | ||||
|   description: "Bio" | ||||
|   youCanIncludeHashtags: "You can also include hashtags in your bio." | ||||
|   metadata: "Other information" | ||||
|   metadata: "Additional Information" | ||||
|   metadataEdit: "Edit additional Information" | ||||
|   metadataDescription: "You can display up to four additional information sections in your profile." | ||||
|   metadataLabel: "Label" | ||||
|   metadataContent: "Content" | ||||
|   changeAvatar: "Change avatar" | ||||
|   changeBanner: "Change banner" | ||||
| _exportOrImport: | ||||
|   allNotes: "All notes" | ||||
|   followingList: "Following" | ||||
| @@ -780,6 +1149,8 @@ _rooms: | ||||
|     cup-noodle: "Cup noodle" | ||||
|     holo-display: "Holographic display" | ||||
|     energy-drink: "Energy drink" | ||||
|     doll-ai: "Ai doll" | ||||
|     banknote: "Pile of money" | ||||
| _pages: | ||||
|   newPage: "Create a page" | ||||
|   editPage: "Edit this page" | ||||
| @@ -787,6 +1158,7 @@ _pages: | ||||
|   created: "Successfully created a page!" | ||||
|   updated: "Successfully updated the page!" | ||||
|   deleted: "The page has been deleted" | ||||
|   pageSetting: "Page settings" | ||||
|   nameAlreadyExists: "The specified page URL already exists" | ||||
|   invalidNameTitle: "The specified page URL is invalid" | ||||
|   invalidNameText: "Check whether that is not a blank" | ||||
| @@ -797,7 +1169,9 @@ _pages: | ||||
|   unlike: "Undo like" | ||||
|   my: "My pages" | ||||
|   liked: "Liked pages" | ||||
|   featured: "Featured" | ||||
|   inspector: "Inspector" | ||||
|   contents: "Content" | ||||
|   content: "Page block" | ||||
|   variables: "Variables" | ||||
|   title: "Title" | ||||
| @@ -851,6 +1225,11 @@ _pages: | ||||
|       id: "Canvas ID" | ||||
|       width: "Width" | ||||
|       height: "Height" | ||||
|     note: "Embedded note" | ||||
|     _note: | ||||
|       id: "Note ID" | ||||
|       idDescription: "You can also paste the Note's URL to set it instead." | ||||
|       detailed: "Detailed view" | ||||
|     switch: "Switch" | ||||
|     _switch: | ||||
|       name: "Variable name" | ||||
| @@ -1065,3 +1444,50 @@ _relayStatus: | ||||
|   requesting: "Pending" | ||||
|   accepted: "Accepted" | ||||
|   rejected: "Rejected" | ||||
| _notification: | ||||
|   fileUploaded: "File successfully uploaded" | ||||
|   youGotMention: "{name} mentioned you" | ||||
|   youGotReply: "{name} replied to you" | ||||
|   youGotQuote: "{name} quoted you" | ||||
|   youRenoted: "{name} renoted you" | ||||
|   youGotPoll: "{name} voted on your poll" | ||||
|   youGotMessagingMessageFromUser: "{name} sent you a message" | ||||
|   youGotMessagingMessageFromGroup: "A message was sent to the {name} group" | ||||
|   youWereFollowed: "Followed you" | ||||
|   youReceivedFollowRequest: "You've received a follow request" | ||||
|   yourFollowRequestAccepted: "Your follow request was accepted" | ||||
|   youWereInvitedToGroup: "Invited to group" | ||||
|   _types: | ||||
|     all: "All" | ||||
|     follow: "Follows" | ||||
|     mention: "Mentions" | ||||
|     reply: "Replies" | ||||
|     renote: "Renotes" | ||||
|     quote: "Quotes" | ||||
|     reaction: "Reactions" | ||||
|     pollVote: "Votes on polls" | ||||
|     receiveFollowRequest: "Follow request received" | ||||
|     followRequestAccepted: "Follow request accepted" | ||||
|     groupInvited: "Invited to groups" | ||||
|     app: "Notifications from apps" | ||||
| _deck: | ||||
|   alwaysShowMainColumn: "Always show main column" | ||||
|   columnAlign: "Align columns" | ||||
|   columnMargin: "Margin between columns" | ||||
|   columnHeaderHeight: " Column header height" | ||||
|   addColumn: "Add column" | ||||
|   swapLeft: "Swap to left" | ||||
|   swapRight: "Swap to right" | ||||
|   swapUp: "Swap with above" | ||||
|   swapDown: "Swap with below" | ||||
|   stackLeft: "Stack on the left" | ||||
|   popRight: "Pop to the right" | ||||
|   _columns: | ||||
|     main: "Main" | ||||
|     widgets: "Widgets" | ||||
|     notifications: "Notifications" | ||||
|     tl: "Timeline" | ||||
|     antenna: "Antennas" | ||||
|     list: "Lists" | ||||
|     mentions: "Mentions" | ||||
|     direct: "Direct" | ||||
|   | ||||
| @@ -16,6 +16,9 @@ noNotes: "No hay notas" | ||||
| noNotifications: "No hay notificaciones" | ||||
| instance: "Instancia" | ||||
| settings: "Configuración" | ||||
| basicSettings: "Configuración Básica" | ||||
| otherSettings: "Configuración avanzada" | ||||
| openInWindow: "Abrir en una ventana" | ||||
| profile: "Perfil" | ||||
| timeline: "Linea de tiempo" | ||||
| noAccountDescription: "Este usuario no tiene una descripción" | ||||
| @@ -26,10 +29,13 @@ signup: "Registrarse" | ||||
| uploading: "Cargando" | ||||
| save: "Guardar" | ||||
| users: "Usuarios" | ||||
| addUser: "Añadir usuario" | ||||
| addUser: "Agregar usuario" | ||||
| favorite: "Favorito" | ||||
| favorites: "Favoritos" | ||||
| unfavorite: "Quitar de favoritos" | ||||
| favorited: "Añadido a favoritos" | ||||
| alreadyFavorited: "Ya había sido añadido a favoritos" | ||||
| cantFavorite: "No fue añadido a favoritos" | ||||
| pin: "Fijar" | ||||
| unpin: "Desfijar" | ||||
| copyContent: "Copiar contenido" | ||||
| @@ -40,11 +46,13 @@ deleteAndEditConfirm: "¿Quieres borrar y editar este nota? Las reacciones, reno | ||||
| addToList: "Agregar a lista" | ||||
| sendMessage: "Énviar mensaje" | ||||
| copyUsername: "Copiar nombre de usuario" | ||||
| searchUser: "Búsqueda de usuarios" | ||||
| reply: "Responder" | ||||
| loadMore: "Ver más" | ||||
| youGotNewFollower: "te ha seguido" | ||||
| receiveFollowRequest: "Recibiste una solicitud de seguimiento" | ||||
| followRequestAccepted: "La solicitud de seguimiento fue aceptada" | ||||
| mention: "Menciones" | ||||
| mentions: "Menciones" | ||||
| directNotes: "Notas directas" | ||||
| importAndExport: "Importar y Exportar" | ||||
| @@ -65,8 +73,11 @@ followers: "Seguidores" | ||||
| followsYou: "Te sigue" | ||||
| createList: "Crear lista" | ||||
| manageLists: "Administrar listas" | ||||
| error: "Ocurrió un problema" | ||||
| error: "Error" | ||||
| somethingHappened: "Ocurrió un error" | ||||
| retry: "Reintentar" | ||||
| pageLoadError: "Error al leer la página" | ||||
| pageLoadErrorDescription: "Normalmente es debido a la red o al caché del navegador. Por favor limpie el caché o intente más tarde." | ||||
| enterListName: "Ingrese nombre de lista" | ||||
| privacy: "Privacidad" | ||||
| makeFollowManuallyApprove: "Aprobar manualmente las solicitudes de seguimiento" | ||||
| @@ -79,14 +90,18 @@ followRequestPending: "Solicitudes de seguimiento pendientes" | ||||
| enterEmoji: "Ingresar emojis" | ||||
| renote: "Renotar" | ||||
| unrenote: "Quitar renota" | ||||
| renoted: "Renotado" | ||||
| cantRenote: "No se puede renotar este post" | ||||
| cantReRenote: "No se puede renotar una renota" | ||||
| quote: "Citar" | ||||
| pinnedNote: "Nota fijada" | ||||
| you: "Tú" | ||||
| clickToShow: "Click para ver" | ||||
| sensitive: "Marcado como sensible" | ||||
| add: "Añadir" | ||||
| add: "Agregar" | ||||
| reaction: "Reacción" | ||||
| reactionSettingDescription: "Asigne sus reacción favoritas que desean anclar en el selector de reacciones." | ||||
| reactionSettingDescription2: "Arrastre para reordenar, click para borrar, apriete la tecla + para añadir." | ||||
| rememberNoteVisibility: "Recordar visibilidad" | ||||
| attachCancel: "Quitar adjunto" | ||||
| markAsSensitive: "Marcar como sensible" | ||||
| @@ -103,17 +118,24 @@ unblockConfirm: "¿Quiere dejar de bloquear esta cuenta?" | ||||
| suspendConfirm: "¿Quiere suspender esta cuenta?" | ||||
| unsuspendConfirm: "¿Quiere dejar de suspender esta cuenta?" | ||||
| selectList: "Seleccione una lista" | ||||
| selectAntenna: "Seleccionar antena" | ||||
| selectWidget: "Seleccionar widget" | ||||
| editWidgets: "Editar widgets" | ||||
| editWidgetsExit: "Terminar edición" | ||||
| customEmojis: "Emojis personalizados" | ||||
| emoji: "Emoji" | ||||
| emojiName: "Nombre del emoji" | ||||
| emojiUrl: "URL de la imágen del emoji" | ||||
| addEmoji: "Añadir emoji" | ||||
| addEmoji: "Agregar emoji" | ||||
| settingGuide: "Configuración sugerida" | ||||
| cacheRemoteFiles: "Mantener en cache los archivos remotos" | ||||
| cacheRemoteFilesDescription: "Si desactiva esta configuración, Los archivos remotos se cargarán desde el link directo sin usar la caché. Con eso se puede ahorrar almacenamiento del servidor, pero eso aumentará el tráfico al no crear miniaturas." | ||||
| flagAsBot: "Esta cuenta es un bot" | ||||
| flagAsBotDescription: "En caso de que esta cuenta fuera usada por un programa, active esta opción. Al hacerlo, esta opción servirá para otros desarrolladores para evitar cadenas infinitas de reacciones, y ajustará los sistemas internos de Misskey para que trate a esta cuenta como un bot." | ||||
| flagAsCat: "Esta cuenta es un gato" | ||||
| flagAsCatDescription: "En caso de que declare que esta cuenta es de un gato, active esta opción." | ||||
| autoAcceptFollowed: "Aceptar automáticamente las solicitudes de seguimiento de los usuarios que sigues" | ||||
| addAcount: "Añadir cuenta" | ||||
| addAcount: "Agregar cuenta" | ||||
| loginFailed: "Error al iniciar sesión." | ||||
| showOnRemote: "Ver en una instancia remota" | ||||
| general: "General" | ||||
| @@ -173,7 +195,6 @@ processing: "Procesando" | ||||
| preview: "Vista previa" | ||||
| default: "Predeterminado" | ||||
| noCustomEmojis: "No hay emojis personalizados" | ||||
| customEmojisOfRemote: "Emojis remotos" | ||||
| noJobs: "No hay trabajos" | ||||
| federating: "Federando" | ||||
| blocked: "Bloqueando" | ||||
| @@ -202,6 +223,8 @@ imageUrl: "URL de la imágen" | ||||
| remove: "Borrar" | ||||
| removed: "Borrado" | ||||
| removeAreYouSure: "¿Desea borrar \"{x}\"?" | ||||
| deleteAreYouSure: "¿Desea borrar \"{x}\"?" | ||||
| resetAreYouSure: "¿Desea reestablecer?" | ||||
| saved: "Guardado" | ||||
| messaging: "Chat" | ||||
| upload: "Subir" | ||||
| @@ -247,7 +270,7 @@ folderName: "Nombre de la carpeta" | ||||
| createFolder: "Crear carpeta" | ||||
| renameFolder: "Renombrar carpeta" | ||||
| deleteFolder: "Borrar carpeta" | ||||
| addFile: "Añadir archivo" | ||||
| addFile: "Agregar archivo" | ||||
| emptyDrive: "El drive está vacío" | ||||
| emptyFolder: "La carpeta está vacía" | ||||
| unableToDelete: "No se puede borrar" | ||||
| @@ -260,6 +283,7 @@ rename: "Renombrar" | ||||
| avatar: "Avatar" | ||||
| banner: "Banner" | ||||
| nsfw: "Marcado como sensible" | ||||
| whenServerDisconnected: "Cuando se pierda la conexión con el servidor" | ||||
| disconnectedFromServer: "Desconectado del servidor" | ||||
| reload: "Recargar" | ||||
| doNothing: "No hacer nada" | ||||
| @@ -300,6 +324,10 @@ bannerUrl: "URL de la imagen del banner" | ||||
| basicInfo: "Información básica" | ||||
| pinnedUsers: "Usuarios fijados" | ||||
| pinnedUsersDescription: "Describir los usuarios que quiere fijar en la página \"Descubrir\" separados por una linea nueva" | ||||
| pinnedPages: "Páginas fijadas" | ||||
| pinnedPagesDescription: "Describa las rutas de las páginas que desea fijar a la página principal de la instancia, separadas por lineas nuevas" | ||||
| pinnedClipId: "Id del clip fijado" | ||||
| pinnedNotes: "Nota fijada" | ||||
| hcaptcha: "hCaptcha" | ||||
| enableHcaptcha: "Habilitar hCaptcha" | ||||
| hcaptchaSiteKey: "Clave del sitio" | ||||
| @@ -340,13 +368,6 @@ popularTags: "Etiquetas populares" | ||||
| userList: "Lista" | ||||
| about: "Información" | ||||
| aboutMisskey: "Sobre Misskey" | ||||
| aboutMisskeyText: "Misskey es un software de código abierto, desarrollado por syuilo desde el 2014" | ||||
| misskeyMembers: "Es creado y mantenido por los miembros aquí listados:" | ||||
| misskeySource: "El código fuente está disponible aquí:" | ||||
| misskeyTranslation: "Ayúdanos con tu contribución para traducir Misskey:" | ||||
| misskeyDonate: "Puedes contribuir al desarrollo de Misskey donando aquí:" | ||||
| morePatrons: "Muchas más personas nos apoyan. Muchas gracias🥰" | ||||
| patrons: "Patrocinadores" | ||||
| administrator: "Administrador" | ||||
| token: "Token" | ||||
| twoStepAuthentication: "Autenticación de dos factores" | ||||
| @@ -360,9 +381,6 @@ unregister: "Cancelar registro" | ||||
| passwordLessLogin: "Iniciar sesión sin contraseña" | ||||
| resetPassword: "Resetear contraseña" | ||||
| newPasswordIs: "La nueva contraseña es \"{password}\"" | ||||
| autoReloadWhenDisconnected: "Recargar automáticamente cuando el servidor está desconectado" | ||||
| autoNoteWatch: "Ver nota automáticamente" | ||||
| autoNoteWatchDescription: "Recibe notificaciones sobre las notas de otros usuarios que a los que respondiste y reaccionaste" | ||||
| reduceUiAnimation: "Reducir la animación de la UI" | ||||
| share: "Compartir" | ||||
| notFound: "No se encuentra" | ||||
| @@ -400,6 +418,7 @@ noMessagesYet: "Aún no hay chat" | ||||
| newMessageExists: "Tienes un mensaje nuevo" | ||||
| onlyOneFileCanBeAttached: "Solo se puede añadir un archivo al mensaje" | ||||
| signinRequired: "Iniciar sesión" | ||||
| invitations: "Invitar" | ||||
| invitationCode: "Código de invitación" | ||||
| checking: "Comprobando" | ||||
| available: "Disponible" | ||||
| @@ -423,6 +442,7 @@ useOsNativeEmojis: "Usa los emojis nativos de la plataforma" | ||||
| youHaveNoGroups: "Sin grupos" | ||||
| joinOrCreateGroup: "Obtenga una invitación para unirse al grupos o puede crear su propio grupo." | ||||
| noHistory: "No hay datos en el historial" | ||||
| signinHistory: "Historial de ingresos" | ||||
| disableAnimatedMfm: "Deshabilitar MFM que tiene animaciones" | ||||
| doing: "Voy en camino" | ||||
| category: "Categoría" | ||||
| @@ -440,8 +460,8 @@ remote: "Remoto" | ||||
| total: "Total" | ||||
| weekOverWeekChanges: "Dif semanal" | ||||
| dayOverDayChanges: "Dif diaria" | ||||
| accessibility: "Accesibilidad" | ||||
| clinetSettings: "Ajustes del cliente" | ||||
| appearance: "Apariencia" | ||||
| clientSettings: "Configuración del cliente" | ||||
| accountSettings: "Ajustes de cuenta" | ||||
| promotion: "Promovido" | ||||
| promote: "Promover" | ||||
| @@ -464,6 +484,7 @@ objectStorageUseSSL: "Usar SSL" | ||||
| objectStorageUseSSLDesc: "Desactive esto si no va a usar HTTPS para la conexión API" | ||||
| objectStorageUseProxy: "Conectarse a través de Proxy" | ||||
| objectStorageUseProxyDesc: "Desactive esto si no va a usar Proxy para la conexión de Almacenamiento de objetos" | ||||
| objectStorageSetPublicRead: "Seleccionar \"public-read\" al subir " | ||||
| serverLogs: "Registros del servidor" | ||||
| deleteAll: "Eliminar todos" | ||||
| showFixedPostForm: "Mostrar el formulario de las entradas encima de la línea de tiempo" | ||||
| @@ -471,7 +492,10 @@ newNoteRecived: "Tienes una nota nuevo" | ||||
| sounds: "Sonidos" | ||||
| listen: "Escuchar" | ||||
| none: "Ninguna" | ||||
| showInPage: "Mostrar en la página" | ||||
| popout: "Popout" | ||||
| volume: "Volumen" | ||||
| masterVolume: "Volumen principal" | ||||
| details: "Detalles" | ||||
| chooseEmoji: "Elije un emoji" | ||||
| unableToProcess: "La operación no se puede llevar a cabo" | ||||
| @@ -506,6 +530,203 @@ relays: "Relés" | ||||
| addRelay: "Agregar relé" | ||||
| inboxUrl: "Inbox URL" | ||||
| addedRelays: "Relés añadidos" | ||||
| serviceworkerInfo: "Se necesita activar para usar las notificaciones push" | ||||
| deletedNote: "Nota eliminada" | ||||
| invisibleNote: "Nota oculta" | ||||
| enableInfiniteScroll: "Activar scroll infinito" | ||||
| visibility: "Visibilidad" | ||||
| poll: "Encuesta" | ||||
| useCw: "Esconder contenidos" | ||||
| enablePlayer: "Abrir reproductor" | ||||
| disablePlayer: "Cerrar reproductor" | ||||
| expandTweet: "Expandir tweet" | ||||
| themeEditor: "Editor de temas" | ||||
| description: "Descripción" | ||||
| author: "Autor" | ||||
| leaveConfirm: "Hay modificaciones sin guardar. ¿Desea descartarlas?" | ||||
| manage: "Administrar" | ||||
| plugins: "Plugins" | ||||
| pluginInstallWarn: "Por favor no instale plugins que no son de confianza" | ||||
| deck: "Deck" | ||||
| undeck: "Quitar deck" | ||||
| useBlurEffectForModal: "Usar efecto borroso en modales" | ||||
| useFullReactionPicker: "Reacción" | ||||
| width: "Ancho" | ||||
| height: "Altura" | ||||
| large: "Grande" | ||||
| medium: "Mediano" | ||||
| small: "Pequeño" | ||||
| generateAccessToken: "Generar token de acceso" | ||||
| permission: "Permisos" | ||||
| enableAll: "Activar todo" | ||||
| disableAll: "Desactivar todo" | ||||
| tokenRequested: "Permiso de acceso a la cuenta" | ||||
| pluginTokenRequestedDescription: "Este plugin podrá usar los permisos descritos aquí" | ||||
| notificationType: "Tipo de notificación" | ||||
| edit: "Editar" | ||||
| useStarForReactionFallback: "En caso de que los emojis de reacciones no sean claros, usar en su lugar una estrella" | ||||
| emailConfig: "Configuración del servidor de correos" | ||||
| enableEmail: "Activar el envío de correos electrónicos" | ||||
| emailConfigInfo: "Usar en caso de validación de correo electrónico y pedido de contraseña" | ||||
| email: "Correo" | ||||
| emailAddress: "Correo electrónico" | ||||
| smtpConfig: "Configuración del servidor SMTP" | ||||
| smtpHost: "Host" | ||||
| smtpPort: "Puerto" | ||||
| smtpUser: "Nombre de usuario" | ||||
| smtpPass: "Contraseña" | ||||
| emptyToDisableSmtpAuth: "Deje el nombre del usuario y la contraseña en blanco para deshabilitar la autenticación SMTP" | ||||
| smtpSecure: "Usar SSL/TLS implícito en la conexión SMTP" | ||||
| smtpSecureInfo: "Apagar cuando se use STARTTLS" | ||||
| testEmail: "Prueba de envío" | ||||
| wordMute: "Silenciar palabras" | ||||
| userSaysSomething: "{name} dijo algo" | ||||
| makeActive: "Activar" | ||||
| display: "Apariencia" | ||||
| copy: "Copiar" | ||||
| metrics: "Métricas" | ||||
| overview: "Resumen" | ||||
| logs: "Registros" | ||||
| delayed: "atrasado" | ||||
| database: "Base de datos" | ||||
| channel: "Canal" | ||||
| create: "Crear" | ||||
| notificationSetting: "Ajustes de Notificaciones" | ||||
| notificationSettingDesc: "Por favor elija el tipo de notificación a mostrar" | ||||
| useGlobalSetting: "Usar ajustes globales" | ||||
| useGlobalSettingDesc: "Al activarse, se usará la configuración de notificaciones de la cuenta, al desactivarse se pueden hacer configuraciones particulares." | ||||
| other: "Otro" | ||||
| regenerateLoginToken: "Regenerar token de login" | ||||
| regenerateLoginTokenDescription: "Regenerar el token usado internamente durante el login. No siempre es necesario hacerlo. Al hacerlo de nuevo, se deslogueará en todos los dispositivos." | ||||
| setMultipleBySeparatingWithSpace: "Puedes añadir mas de uno, separado por espacios." | ||||
| fileIdOrUrl: "Id del archivo o URL" | ||||
| chatOpenBehavior: "Comportamiento al abrir el chat" | ||||
| behavior: "Comportamiento" | ||||
| sample: "Muestra" | ||||
| abuseReports: "Reportes" | ||||
| reportAbuse: "Reportar" | ||||
| reportAbuseOf: "Reportar a {name}" | ||||
| fillAbuseReportDescription: "Ingrese los detalles del reporte. Si hay una nota en particular, ingrese la URL de esta." | ||||
| abuseReported: "Se ha enviado el reporte. Muchas gracias." | ||||
| send: "Enviar" | ||||
| abuseMarkAsResolved: "Marcar reporte como resuelto" | ||||
| openInNewTab: "Abrir en una Nueva Pestaña" | ||||
| openInSideView: "Abrir en una vista al costado" | ||||
| defaultNavigationBehaviour: "Navegación por defecto" | ||||
| editTheseSettingsMayBreakAccount: "Editar estas configuraciones puede dañar su cuenta." | ||||
| instanceTicker: "Información de notas de la instancia" | ||||
| waitingFor: "Esperando a {x}" | ||||
| random: "Aleatorio" | ||||
| system: "Sistema" | ||||
| switchUi: "Cambiar interfaz de usuario" | ||||
| desktop: "Escritorio" | ||||
| clip: "Clip" | ||||
| createNew: "Crear" | ||||
| optional: "Opcional" | ||||
| createNewClip: "Crear clip nuevo" | ||||
| public: "Público" | ||||
| i18nInfo: "Misskey está siendo traducido a varios idiomas gracias a voluntarios. Se puede colaborar traduciendo en {link}" | ||||
| manageAccessTokens: "Administrar tokens de acceso" | ||||
| accountInfo: "Información de la Cuenta" | ||||
| notesCount: "Cantidad de notas" | ||||
| repliesCount: "Cantidad de respuestas hechas" | ||||
| renotesCount: "Cantidad de renotas hechas" | ||||
| repliedCount: "Cantidad de respuestas recibidas" | ||||
| renotedCount: "Cantidad de renotas recibidas" | ||||
| followingCount: "Cantidad de seguidos" | ||||
| followersCount: "Cantidad de seguidores" | ||||
| sentReactionsCount: "Cantidad de reacciones hechas" | ||||
| receivedReactionsCount: "Cantidad de reacciones recibidas" | ||||
| pollVotesCount: "Cantidad de votaciones hechas" | ||||
| pollVotedCount: "Cantidad de votaciones recibidas" | ||||
| yes: "Si" | ||||
| no: "No" | ||||
| driveFilesCount: "Cantidad de archivos en el drive" | ||||
| driveUsage: "Uso del drive" | ||||
| noCrawle: "Rechazar indexación del crawler" | ||||
| noCrawleDescription: "Pedir a los motores de búsqueda que no indexen tu perfil, notas, páginas, etc." | ||||
| clips: "Clip" | ||||
| _mfm: | ||||
|   cheatSheet: "Hoja de referencia de MFM" | ||||
|   intro: "MFM es un lenguaje de marcado dedicado que se puede usar en varios lugares dentro de Misskey. Aquí puede ver una lista de sintaxis disponibles en MFM." | ||||
|   mention: "Menciones" | ||||
|   mentionDescription: "El signo @ seguido de un nombre de usuario se puede utilizar para notificar a un usuario en particular." | ||||
|   hashtag: "Hashtag" | ||||
|   url: "URL" | ||||
|   link: "Vínculo" | ||||
|   bold: "Negrita" | ||||
|   center: "Centrar" | ||||
|   blockCode: "Código (bloque)" | ||||
|   blockCodeDescription: "Código de resaltado de sintaxis, como programas de varias líneas con bloques." | ||||
|   quote: "Citar" | ||||
|   emoji: "Emojis personalizados" | ||||
|   search: "Buscar" | ||||
|   flip: "Echar de un capirotazo" | ||||
|   flipDescription: "Voltea el contenido hacia arriba / abajo o hacia la izquierda / derecha." | ||||
| _reversi: | ||||
|   reversi: "Reversi" | ||||
|   gameSettings: "Configuración del juego" | ||||
|   chooseBoard: "Elegir tablero" | ||||
|   blackOrWhite: "Blancas/Negras" | ||||
|   blackIs: "{name} juega con fichas negras" | ||||
|   rules: "Reglas" | ||||
|   botSettings: "Opciones del bot" | ||||
|   thisGameIsStartedSoon: "El juego empezará en segundos" | ||||
|   waitingForOther: "Esperando el turno del adversario" | ||||
|   waitingForMe: "Esperando mi turno" | ||||
|   waitingBoth: "Prepárate" | ||||
|   ready: "Listo" | ||||
|   cancelReady: "No estoy listo" | ||||
|   opponentTurn: "Turno del adversario" | ||||
|   myTurn: "Mi turno" | ||||
|   turnOf: "Turno de {name}" | ||||
|   pastTurnOf: "Turno de {name}" | ||||
|   surrender: "Rendirse" | ||||
|   surrendered: "Por rendirse" | ||||
|   drawn: "Empate" | ||||
|   won: "{name} ha ganado" | ||||
|   black: "Negro" | ||||
|   white: "Blanco" | ||||
|   total: "Total" | ||||
|   turnCount: "Turno {count}" | ||||
|   myGames: "Mis juegos" | ||||
|   allGames: "Todos los juegos" | ||||
|   ended: "Finalizado" | ||||
|   playing: "Jugando" | ||||
|   isLlotheo: "El que tenga menos fichas gana (LLoTheO)" | ||||
|   loopedMap: "Mapa en bucle" | ||||
|   canPutEverywhere: "Puedes colocar donde quieras" | ||||
| _instanceTicker: | ||||
|   none: "No mostrar" | ||||
|   remote: "Mostrar a usuarios remotos" | ||||
|   always: "Mostrar siempre" | ||||
| _serverDisconnectedBehavior: | ||||
|   reload: "Recargar automáticamente" | ||||
|   dialog: "Mostrar diálogo de advertencia" | ||||
|   quiet: "Advertencia discreta" | ||||
| _channel: | ||||
|   create: "Crear canal" | ||||
|   edit: "Editar canal" | ||||
|   setBanner: "Elegir banner" | ||||
|   removeBanner: "Borrar banner" | ||||
|   featured: "Tendencias" | ||||
|   owned: "Dueño" | ||||
|   following: "Siguiendo" | ||||
|   usersCount: "{n} participantes" | ||||
|   notesCount: "{n} notas" | ||||
| _sidebar: | ||||
|   full: "Completo" | ||||
|   icon: "Avatar" | ||||
|   hide: "Ocultar" | ||||
| _wordMute: | ||||
|   muteWords: "Palabras que silenciar" | ||||
|   muteWordsDescription: "Separar con espacios indica una declaracion And, separar con lineas nuevas indica una declaracion Or。" | ||||
|   muteWordsDescription2: "Encerrar las palabras clave entre numerales para usar expresiones regulares" | ||||
|   softDescription: "Ocultar en la linea de tiempo las notas que cumplen las condiciones" | ||||
|   hardDescription: "Evitar que se agreguen a la linea de tiempo las notas que cumplen las condiciones. Las notas no agregadas seguirán quitadas aunque cambien las condiciones." | ||||
|   soft: "Suave" | ||||
|   hard: "Duro" | ||||
|   mutedNotes: "Notas silenciadas" | ||||
| _theme: | ||||
|   explore: "Explorar temas" | ||||
|   install: "Instalar tema" | ||||
| @@ -514,6 +735,69 @@ _theme: | ||||
|   installed: "{name} ha sido instalado" | ||||
|   alreadyInstalled: "Este tema ya está instalado" | ||||
|   invalid: "El formato del tema no es válido" | ||||
|   make: "Crear tema" | ||||
|   base: "Base" | ||||
|   addConstant: "Agregar constante" | ||||
|   constant: "Constante" | ||||
|   defaultValue: "Valor predeterminado" | ||||
|   color: "Color" | ||||
|   refProp: "Hacer referencia a propiedad" | ||||
|   refConst: "Hacer referencia a constante" | ||||
|   key: "Clave" | ||||
|   func: "funciones" | ||||
|   funcKind: "Tipo de función" | ||||
|   argument: "Argumento" | ||||
|   basedProp: "Nombre de la propiedad referenciada" | ||||
|   alpha: "Opacidad" | ||||
|   darken: "Oscuridad" | ||||
|   lighten: "Brillo" | ||||
|   inputConstantName: "Por favor ingrese el nombre de la constante" | ||||
|   importInfo: "Pegando el código del tema aquí, puede importarlo al editor" | ||||
|   deleteConstantConfirm: "¿Desea borrar la constante {const}?" | ||||
|   keys: | ||||
|     accent: "Acento" | ||||
|     bg: "Fondo" | ||||
|     fg: "Texto" | ||||
|     focus: "Enfoque" | ||||
|     indicator: "Indicador" | ||||
|     panel: "Panel" | ||||
|     shadow: "Sombra" | ||||
|     header: "Cabezal" | ||||
|     navBg: "Fondo de la barra lateral" | ||||
|     navFg: "Texto de la barra lateral" | ||||
|     navHoverFg: "Texto de la barra lateral (hover)" | ||||
|     navActive: "Texto de la barra lateral (activo)" | ||||
|     navIndicator: "Indicador de la barra lateral" | ||||
|     link: "Vínculo" | ||||
|     hashtag: "Hashtag" | ||||
|     mention: "Menciones" | ||||
|     mentionMe: "Menciones (yo)" | ||||
|     renote: "Renotar" | ||||
|     modalBg: "Fondo modal" | ||||
|     divider: "Divisor" | ||||
|     scrollbarHandle: "Cuadro de la barra de desplazamiento" | ||||
|     scrollbarHandleHover: "Cuadro de la barra de desplazamiento (hover)" | ||||
|     dateLabelFg: "Texto de la etiqueta de fecha" | ||||
|     infoBg: "Fondo de información" | ||||
|     infoFg: "Texto de información" | ||||
|     infoWarnBg: "Fondo de advertencias" | ||||
|     infoWarnFg: "Texto de advertencias" | ||||
|     cwBg: "Fondo del botón CW" | ||||
|     cwFg: "Texto del botón CW" | ||||
|     cwHoverBg: "Fondo del botón CW (hover)" | ||||
|     toastBg: "Fondo de notificaciones" | ||||
|     toastFg: "Texto de notificaciones" | ||||
|     buttonBg: "Fondo de botón" | ||||
|     buttonHoverBg: "Fondo de botón (hover)" | ||||
|     inputBorder: "Borde de los campos de entrada" | ||||
|     listItemHoverBg: "Fondo de elemento de listas (hover)" | ||||
|     driveFolderBg: "Fondo de capeta del drive" | ||||
|     wallpaperOverlay: "Transparencia del fondo de pantalla" | ||||
|     badge: "Medalla" | ||||
|     messageBg: "Fondo de chat" | ||||
|     accentDarken: "Acento (oscuro)" | ||||
|     accentLighten: "Acento (claro)" | ||||
|     fgHighlighted: "Texto resaltado" | ||||
| _sfx: | ||||
|   note: "Notas" | ||||
|   noteMy: "Nota (a mí mismo)" | ||||
| @@ -521,6 +805,7 @@ _sfx: | ||||
|   chat: "Chat" | ||||
|   chatBg: "Chat (Fondo)" | ||||
|   antenna: "Antena receptora" | ||||
|   channel: "Notificaciones del canal" | ||||
| _ago: | ||||
|   unknown: "Desconocido" | ||||
|   future: "Futuro" | ||||
| @@ -596,6 +881,8 @@ _permissions: | ||||
|   "write:page-likes": "Administrar páginas que te gustan" | ||||
|   "read:user-groups": "Ver grupos de usuarios" | ||||
|   "write:user-groups": "Administrar grupos de usuarios" | ||||
|   "read:channels": "Ver canal" | ||||
|   "write:channels": "Modificar canal" | ||||
| _auth: | ||||
|   shareAccess: "¿Desea permitir el acceso a la cuenta \"{name}\"?" | ||||
|   shareAccessAsk: "¿Está seguro de que desea autorizar esta aplicación para acceder a su cuenta?" | ||||
| @@ -627,12 +914,15 @@ _widgets: | ||||
|   rss: "Lector RSS" | ||||
|   activity: "Actividad" | ||||
|   photos: "Fotos" | ||||
|   digitalClock: "Reloj digital" | ||||
|   federation: "Federación" | ||||
|   postForm: "Formulario" | ||||
|   button: "Botón" | ||||
| _cw: | ||||
|   hide: "Ocultar" | ||||
|   show: "Ver más" | ||||
|   chars: "{count} caracteres" | ||||
|   files: "{count} archivos" | ||||
|   poll: "Encuesta" | ||||
| _poll: | ||||
|   noOnlyOneChoice: "Se necesitan al menos 2 opciones" | ||||
|   choiceN: "Opción {n}" | ||||
| @@ -665,9 +955,11 @@ _visibility: | ||||
|   specified: "Mensaje directo" | ||||
|   specifiedDescription: "Visible sólo para los usuarios elegidos" | ||||
|   localOnly: "Solo local" | ||||
|   localOnlyDescription: "Oculto para usuarios remotos" | ||||
| _postForm: | ||||
|   replyPlaceholder: "Responder a esta nota" | ||||
|   quotePlaceholder: "Citar esta nota" | ||||
|   channelPlaceholder: "Postear en el canal" | ||||
|   _placeholders: | ||||
|     a: "¿Qué haces?" | ||||
|     b: "¿Te pasó algo?" | ||||
| @@ -680,7 +972,6 @@ _profile: | ||||
|   username: "Nombre de usuario" | ||||
|   description: "Descripción" | ||||
|   youCanIncludeHashtags: "Puedes añadir hashtags" | ||||
|   metadata: "Información adicional" | ||||
|   metadataLabel: "Etiqueta" | ||||
|   metadataContent: "Contenido" | ||||
| _exportOrImport: | ||||
| @@ -780,6 +1071,8 @@ _rooms: | ||||
|     cup-noodle: "Taza de sopa de fideos" | ||||
|     holo-display: "Poster holográfico" | ||||
|     energy-drink: "Bebida energética" | ||||
|     doll-ai: "Muñeca" | ||||
|     banknote: "Billetes" | ||||
| _pages: | ||||
|   newPage: "Crear página" | ||||
|   editPage: "Editar página" | ||||
| @@ -798,6 +1091,7 @@ _pages: | ||||
|   my: "Mis páginas" | ||||
|   liked: "Páginas que me gustan" | ||||
|   inspector: "Inspector" | ||||
|   contents: "Contenido" | ||||
|   content: "Bloque de página" | ||||
|   variables: "Variables" | ||||
|   title: "Título" | ||||
| @@ -1065,3 +1359,47 @@ _relayStatus: | ||||
|   requesting: "Pendiente" | ||||
|   accepted: "Aceptar" | ||||
|   rejected: "Rechazada" | ||||
| _notification: | ||||
|   fileUploaded: "Archivo subido" | ||||
|   youGotMention: "Mención de {name}" | ||||
|   youGotReply: "Respuesta de {name}" | ||||
|   youGotQuote: "Citado por {name}" | ||||
|   youRenoted: "Renotado por {name}" | ||||
|   youGotPoll: "Encuestado por {name}" | ||||
|   youGotMessagingMessageFromUser: "{name} comenzó un chat contigo" | ||||
|   youGotMessagingMessageFromGroup: "Tienes un chat de {name}" | ||||
|   youWereFollowed: "te ha seguido" | ||||
|   youReceivedFollowRequest: "Has mandado una solicitud de seguimiento" | ||||
|   yourFollowRequestAccepted: "Tu solicitud de seguimiento fue aceptada" | ||||
|   youWereInvitedToGroup: "Invitado al grupo" | ||||
|   _types: | ||||
|     all: "Todo" | ||||
|     follow: "Siguiendo" | ||||
|     mention: "Menciones" | ||||
|     reply: "Respuestas" | ||||
|     renote: "Renotar" | ||||
|     quote: "Citar" | ||||
|     reaction: "Reacción" | ||||
|     pollVote: "Votado en la encuesta" | ||||
|     receiveFollowRequest: "Recibió una solicitud de seguimiento" | ||||
|     followRequestAccepted: "El seguimiento fue aceptado" | ||||
|     groupInvited: "Invitado al grupo" | ||||
|     app: "Notificaciones desde aplicaciones" | ||||
| _deck: | ||||
|   alwaysShowMainColumn: "Siempre mostrar la columna principal" | ||||
|   columnAlign: "Alinear columnas" | ||||
|   addColumn: "Agregar columna" | ||||
|   swapLeft: "Mover a la izquierda" | ||||
|   swapRight: "Mover a la derecha" | ||||
|   swapUp: "Mover arriba" | ||||
|   swapDown: "Mover abajo" | ||||
|   stackLeft: "Apilar a la izquierda" | ||||
|   popRight: "Sacar a la derecha" | ||||
|   _columns: | ||||
|     widgets: "Widgets" | ||||
|     notifications: "Notificaciones" | ||||
|     tl: "Linea de tiempo" | ||||
|     antenna: "Antenas" | ||||
|     list: "Listas" | ||||
|     mentions: "Menciones" | ||||
|     direct: "Mensaje directo" | ||||
|   | ||||
| @@ -1,28 +1,31 @@ | ||||
| --- | ||||
| _lang_: "Français" | ||||
| introMisskey: "Bienvenue ! Misskey est un service de microblogage décentralisé et open-source.\nÉcrivez des « notes » pour partager ce qui se passe, ou pour parler de vous à tout le monde 📡\nAvec la fonction « réactions », vous pouvez également ajouter une réaction rapide aux notes de chacun 👍\nExplorez un nouveau monde 🚀" | ||||
| introMisskey: "Bienvenue ! Misskey est un service de microblogage décentralisé, libre et ouvert.\nÉcrivez des « notes » et partagez ce qui se passe à l’instant présent, autour de vous avec les autres 📡\nLa fonction « réactions », vous permet également d’ajouter une réaction rapide aux notes des autres utilisateur·rice·s 👍\nExplorons un nouveau monde 🚀" | ||||
| monthAndDay: "{day}/{month}" | ||||
| search: "Rechercher" | ||||
| notifications: "Notifications" | ||||
| username: "Nom d'utilisateur·rice" | ||||
| username: "Nom d’utilisateur·rice" | ||||
| password: "Mot de passe" | ||||
| fetchingAsApObject: "Récupération depuis le Fediverse" | ||||
| ok: "Soumettre" | ||||
| gotIt: "J'ai compris !" | ||||
| fetchingAsApObject: "Récupération depuis le fédiverse …" | ||||
| ok: "OK" | ||||
| gotIt: "J’ai compris !" | ||||
| cancel: "Annuler" | ||||
| enterUsername: "Entrer un nom d'utilisateur·rice" | ||||
| enterUsername: "Entrer un nom d’utilisateur·rice" | ||||
| renotedBy: "Renoté par {user}" | ||||
| noNotes: "Pas de notes" | ||||
| noNotifications: "Pas de notifications" | ||||
| noNotes: "Aucune note" | ||||
| noNotifications: "Aucune notification" | ||||
| instance: "Instance" | ||||
| settings: "Paramètres" | ||||
| basicSettings: "Paramètres basiques" | ||||
| otherSettings: "Autres paramètres" | ||||
| openInWindow: "Ouvrir dans une nouvelle fenêtre" | ||||
| profile: "Profil" | ||||
| timeline: "Fil d'actualité" | ||||
| noAccountDescription: "L'utilisateur·rice n'a pas encore renseigné de présentation sur son profil" | ||||
| timeline: "Fil" | ||||
| noAccountDescription: "L’utilisateur·rice n’a pas encore renseigné de biographie de présentation sur son profil." | ||||
| login: "Se connecter" | ||||
| loggingIn: "Connexion en cours" | ||||
| logout: "Se déconnecter" | ||||
| signup: "S'inscrire" | ||||
| signup: "S’inscrire" | ||||
| uploading: "Envoi en cours" | ||||
| save: "Enregistrer" | ||||
| users: "Utilisateur·rice·s" | ||||
| @@ -36,43 +39,47 @@ copyContent: "Copier le contenu" | ||||
| copyLink: "Copier le lien" | ||||
| delete: "Supprimer" | ||||
| deleteAndEdit: "Supprimer et réécrire" | ||||
| deleteAndEditConfirm: "Êtes-vous sûr·e de vouloir effacer cette note et la modifier ? Vous perdrez toutes les réactions, renotes et réponses." | ||||
| deleteAndEditConfirm: "Êtes-vous sûr·e de vouloir supprimer cette note et la reformuler ? Vous perdrez toutes les réactions, renotes et réponses y afférentes." | ||||
| addToList: "Ajouter à une liste" | ||||
| sendMessage: "Envoyer un message" | ||||
| copyUsername: "Copier le nom d'utilisateur" | ||||
| copyUsername: "Copier le nom d’utilisateur·rice" | ||||
| searchUser: "Chercher un·e utilisateur·rice" | ||||
| reply: "Répondre" | ||||
| loadMore: "Voir plus" | ||||
| loadMore: "Afficher plus …" | ||||
| youGotNewFollower: "Vous suit" | ||||
| receiveFollowRequest: "Demande de suivi reçue" | ||||
| followRequestAccepted: "La demande d'abonnement a été acceptée" | ||||
| receiveFollowRequest: "Demande d’abonnement reçue" | ||||
| followRequestAccepted: "La demande d’abonnement a été acceptée" | ||||
| mention: "Mentionner" | ||||
| mentions: "Mentions" | ||||
| directNotes: "Messages directs" | ||||
| directNotes: "Notes directes" | ||||
| importAndExport: "Import et export" | ||||
| import: "Importer" | ||||
| export: "Exporter" | ||||
| files: "Fichiers" | ||||
| download: "Télécharger" | ||||
| driveFileDeleteConfirm: "Êtes-vous sûr·e de vouloir supprimer le fichier \"{name}\" ? Les notes avec ce fichier joint seront aussi supprimées." | ||||
| unfollowConfirm: "Se désabonner de {name} ?" | ||||
| exportRequested: "Vous avez demandé une exportation. Cela pourrait prendre un peu de temps. Une fois l'exportation terminée, le fichier résultant sera ajouté dans le Drive." | ||||
| unfollowConfirm: "Désirez-vous vous désabonner de {name} ?" | ||||
| exportRequested: "Vous avez demandé une exportation. L’opération pourrait prendre un peu de temps. Une terminée, le fichier résultant sera ajouté au Drive." | ||||
| importRequested: "Vous avez initié un import. Cela pourrait prendre un peu de temps." | ||||
| lists: "Listes" | ||||
| noLists: "Aucune liste" | ||||
| note: "Note" | ||||
| noLists: "Vous n’avez aucune liste" | ||||
| note: "Notes" | ||||
| notes: "Notes" | ||||
| following: "Abonnements" | ||||
| followers: "Abonné·e·s" | ||||
| followsYou: "Vous suit" | ||||
| createList: "Créer une liste" | ||||
| manageLists: "Gérer les listes" | ||||
| error: "Une erreur est survenue" | ||||
| error: "Erreur" | ||||
| somethingHappened: "Une erreur est survenue" | ||||
| retry: "Réessayer" | ||||
| pageLoadError: "Le chargement de la page a échoué" | ||||
| enterListName: "Nom de la liste" | ||||
| privacy: "Confidentialité" | ||||
| makeFollowManuallyApprove: "Approuver manuellement les demandes de suivi" | ||||
| makeFollowManuallyApprove: "Accepter manuellement les demandes d’abonnement" | ||||
| defaultNoteVisibility: "Visibilité par défaut" | ||||
| follow: "S'abonner" | ||||
| followRequest: "Demande de suivi" | ||||
| follow: "S’abonner" | ||||
| followRequest: "Demande d’abonnement" | ||||
| followRequests: "Demandes d’abonnement" | ||||
| unfollow: "Se désabonner" | ||||
| followRequestPending: "En attente d’approbation" | ||||
| @@ -86,7 +93,7 @@ clickToShow: "Cliquer pour afficher" | ||||
| sensitive: "Contenu sensible" | ||||
| add: "Ajouter" | ||||
| reaction: "Réactions" | ||||
| reactionSettingDescription: "Choisissez vos réactions préférées que vous souhaitez épingler dans le sélecteur de réaction." | ||||
| reactionSettingDescription: "Choisissez vos réactions préférées que vous souhaitez épingler dans le sélecteur de réactions." | ||||
| rememberNoteVisibility: "Se souvenir de la visibilité des notes" | ||||
| attachCancel: "Supprimer le fichier attaché" | ||||
| markAsSensitive: "Marquer comme sensible" | ||||
| @@ -103,25 +110,30 @@ unblockConfirm: "Êtes-vous sûr·e de vouloir débloquer ce compte ?" | ||||
| suspendConfirm: "Êtes-vous sûr·e de vouloir suspendre ce compte ?" | ||||
| unsuspendConfirm: "Êtes-vous sûr·e de vouloir annuler la suspension de ce compte ?" | ||||
| selectList: "Sélectionner une liste" | ||||
| selectAntenna: "Sélectionner une antenne" | ||||
| selectWidget: "Sélectionner un widget" | ||||
| editWidgets: "Modifier les widgets" | ||||
| editWidgetsExit: "Fait" | ||||
| customEmojis: "Émojis personnalisés" | ||||
| emoji: "Émoji" | ||||
| emojiName: "Nom de l’émoji" | ||||
| emojiUrl: "URL de l’émoji" | ||||
| addEmoji: "Ajouter un émoji" | ||||
| settingGuide: "Configuration suggérée" | ||||
| settingGuide: "Configuration proposée" | ||||
| cacheRemoteFiles: "Mise en cache des fichiers distants" | ||||
| cacheRemoteFilesDescription: "Quand ce paramètre est désactivé, les fichiers distants sont chargés directement depuis l'instance distante. Désactiver cela diminuera l'utilisation du stockage, mais augmentera le trafic réseau, puisque les miniatures ne seront pas générées." | ||||
| cacheRemoteFilesDescription: "Lorsque cette option est désactivée, les fichiers distants sont chargés directement depuis l’instance distante. La désactiver diminuera certes l’utilisation de l’espace de stockage local mais augmentera le trafic réseau puisque les miniatures ne seront plus générées." | ||||
| flagAsBot: "Ce compte est un robot" | ||||
| flagAsCat: "Ce compte est un chat" | ||||
| autoAcceptFollowed: "Approuver automatiquement les demandes de suivi venant d'utilisateur·rice·s que vous suivez" | ||||
| autoAcceptFollowed: "Accepter automatiquement les demandes d’abonnement venant d’utilisateur·rice·s que vous suivez" | ||||
| addAcount: "Ajouter un compte" | ||||
| loginFailed: "Échec de la connexion" | ||||
| showOnRemote: "Voir sur l'instance distante" | ||||
| showOnRemote: "Voir sur l’instance distante" | ||||
| general: "Général" | ||||
| wallpaper: "Fond d'écran" | ||||
| setWallpaper: "Définir le fond d'écran" | ||||
| removeWallpaper: "Supprimer le fond d'écran" | ||||
| wallpaper: "Fond d’écran" | ||||
| setWallpaper: "Définir le fond d’écran" | ||||
| removeWallpaper: "Supprimer le fond d’écran" | ||||
| searchWith: "Recherche : {q}" | ||||
| youHaveNoLists: "Vous n'avez aucune liste" | ||||
| youHaveNoLists: "Vous n’avez aucune liste" | ||||
| followConfirm: "Êtes-vous sûr·e de vouloir suivre {name} ?" | ||||
| proxyAccount: "Compte proxy" | ||||
| proxyAccountDescription: "Un compte proxy se comporte, dans certaines conditions, comme un·e abonné·e distant·e pour les utilisateurs d'autres instances. Par exemple, quand un·e utilisateur·rice ajoute un·e utilisateur·rice distant·e à une liste, ses notes ne seront pas visibles sur l'instance si personne ne suit cet·te utilisateur·rice. Le compte proxy va donc suivre cet·te utilisateur·rice pour que ses notes soient acheminées." | ||||
| @@ -139,7 +151,7 @@ storageUsage: "Stockage utilisé" | ||||
| charts: "Graphiques" | ||||
| perHour: "par heure" | ||||
| perDay: "par jour" | ||||
| stopActivityDelivery: "Arrêter l'envoi d'activités" | ||||
| stopActivityDelivery: "Arrêter l’envoi de l’activité" | ||||
| blockThisInstance: "Bloquer cette instance" | ||||
| operations: "Opérations" | ||||
| software: "Logiciel" | ||||
| @@ -151,10 +163,10 @@ jobQueue: "File d’attente" | ||||
| cpuAndMemory: "Processeur et mémoire" | ||||
| network: "Réseau" | ||||
| disk: "Disque" | ||||
| instanceInfo: "Informations sur l'instance" | ||||
| instanceInfo: "Informations sur l’instance" | ||||
| statistics: "Statistiques" | ||||
| clearQueue: "Vider la file d'attente" | ||||
| clearQueueConfirmTitle: "Êtes-vous sûr·e de vouloir vider la file d'attente ?" | ||||
| clearQueue: "Vider la file d’attente" | ||||
| clearQueueConfirmTitle: "Êtes-vous sûr·e de vouloir vider la file d’attente ?" | ||||
| clearQueueConfirmText: "Les notes non distribuées ne seront pas livrées. Normalement, vous n'avez PAS besoin d'effectuer cette opération." | ||||
| clearCachedFiles: "Vider le cache" | ||||
| clearCachedFilesConfirm: "Êtes-vous sûr·e de vouloir vider le cache de fichiers distants ?" | ||||
| @@ -163,18 +175,17 @@ blockedInstancesDescription: "Listez les instances que vous désirez bloquer, un | ||||
| muteAndBlock: "Masqué·e·s / Bloqué·e·s" | ||||
| mutedUsers: "Utilisateur·rice·s en sourdine" | ||||
| blockedUsers: "Utilisateur·rice·s bloqué·e·s" | ||||
| noUsers: "Il n'y a aucun utilisateur·rice" | ||||
| noUsers: "Il n’y a pas d’utilisateur·rice·s" | ||||
| editProfile: "Modifier votre profil" | ||||
| noteDeleteConfirm: "Êtes-vous sûr·e de vouloir supprimer cette note ?" | ||||
| pinLimitExceeded: "Vous ne pouvez plus épingler d'autres notes." | ||||
| intro: "L'installation de Misskey est terminée ! Créons le compte administrateur." | ||||
| pinLimitExceeded: "Vous ne pouvez plus épingler d’autres notes." | ||||
| intro: "L’installation de Misskey est terminée ! Veuillez créer un compte administrateur." | ||||
| done: "Terminé" | ||||
| processing: "Traitement en cours" | ||||
| preview: "Prévisualisation" | ||||
| default: "Par défaut" | ||||
| noCustomEmojis: "Il n'y a pas d’émoji" | ||||
| customEmojisOfRemote: "Émojis d'autres instances" | ||||
| noJobs: "Il n'y a aucune tâche planifiée" | ||||
| noJobs: "Il n’y a aucune tâche planifiée" | ||||
| federating: "En cours de fédération" | ||||
| blocked: "Bloqué·e" | ||||
| suspended: "Suspendu·e" | ||||
| @@ -183,8 +194,8 @@ subscribing: "Abonné" | ||||
| publishing: "Publié" | ||||
| notResponding: "Ne répond pas" | ||||
| instanceFollowing: "Abonnements une instance" | ||||
| instanceFollowers: "Abonné·e·s de l'instance" | ||||
| instanceUsers: "Utilisateur·rice·s de l'instance" | ||||
| instanceFollowers: "Abonné·e·s de l’instance" | ||||
| instanceUsers: "Utilisateur·rice·s de cette l’instance" | ||||
| changePassword: "Modifier votre mot de passe" | ||||
| security: "Sécurité" | ||||
| retypedNotMatch: "Les saisies ne correspondent pas." | ||||
| @@ -194,7 +205,7 @@ newPasswordRetype: "Répéter le nouveau mot de passe" | ||||
| attachFile: "Joindre un fichier" | ||||
| more: "Plus !" | ||||
| featured: "Tendances" | ||||
| usernameOrUserId: "Nom d'utilisateur ou ID utilisateur" | ||||
| usernameOrUserId: "Nom d’utilisateur·rice ou ID utilisateur" | ||||
| noSuchUser: "Utilisateur·rice non trouvé" | ||||
| lookup: "Recherche" | ||||
| announcements: "Annonces" | ||||
| @@ -202,6 +213,7 @@ imageUrl: "URL de l’image" | ||||
| remove: "Supprimer" | ||||
| removed: "Supprimé" | ||||
| removeAreYouSure: "Supprimer «{x}» ?" | ||||
| deleteAreYouSure: "Supprimer «{x}» ?" | ||||
| saved: "Enregistré" | ||||
| messaging: "Discuter" | ||||
| upload: "Téléverser" | ||||
| @@ -214,15 +226,15 @@ uploadFromUrlMayTakeTime: "Le téléversement de votre fichier peut prendre un c | ||||
| explore: "Découvrir" | ||||
| games: "Jeux de Misskey" | ||||
| messageRead: "Lus" | ||||
| noMoreHistory: "Il n'y a plus d'historique" | ||||
| noMoreHistory: "Il n’y a plus d’historique" | ||||
| startMessaging: "Commencer à discuter" | ||||
| nUsersRead: "Lu par {n} personnes" | ||||
| agreeTo: "J'accepte {0}" | ||||
| agreeTo: "J’accepte {0}" | ||||
| tos: "les conditions d’utilisation" | ||||
| start: "Commencer" | ||||
| home: "Principal" | ||||
| remoteUserCaution: "Les informations peuvent être incomplètes, parce que l'utilisateur·rice est d'une instance distante." | ||||
| activity: "Activités" | ||||
| remoteUserCaution: "Les informations de ce compte risqueraient d’être incomplètes du fait que l’utilisateur·rice provient d’une instance distante." | ||||
| activity: "Activité" | ||||
| images: "Images" | ||||
| birthday: "Date de naissance" | ||||
| yearsOld: "{age} ans" | ||||
| @@ -260,6 +272,7 @@ rename: "Renommer" | ||||
| avatar: "Avatar" | ||||
| banner: "Bannière" | ||||
| nsfw: "Contenu sensible" | ||||
| whenServerDisconnected: "Lorsque la connexion au serveur est perdue" | ||||
| disconnectedFromServer: "Déconnecté·e du serveur" | ||||
| reload: "Rafraîchir" | ||||
| doNothing: "Ignorer" | ||||
| @@ -271,12 +284,12 @@ reject: "Refuser" | ||||
| normal: "Normal" | ||||
| instanceName: "Nom de l’instance" | ||||
| instanceDescription: "Description de l’instance" | ||||
| maintainerName: "Nom de l'administrateur·rice" | ||||
| maintainerEmail: "Email de l'administrateur·rice" | ||||
| maintainerName: "L’administrateur·rice" | ||||
| maintainerEmail: "Email de l’administrateur·rice" | ||||
| tosUrl: "URL des conditions d’utilisation" | ||||
| thisYear: "Cette année" | ||||
| thisMonth: "Ce mois-ci" | ||||
| today: "Aujourd'hui" | ||||
| today: "Aujourd’hui" | ||||
| dayX: "{day}" | ||||
| monthX: "{month}" | ||||
| yearX: "{year}" | ||||
| @@ -287,19 +300,20 @@ disconnectSerice: "Déconnecter" | ||||
| enableLocalTimeline: "Activer le fil local" | ||||
| enableGlobalTimeline: "Activer le fil global" | ||||
| disablingTimelinesInfo: "Si vous désactivez ces fils, les administrateurs et les modérateurs pourront toujours y accéder." | ||||
| registration: "S'inscrire" | ||||
| enableRegistration: "Autoriser n’importe qui à s’inscrire" | ||||
| registration: "S’inscrire" | ||||
| enableRegistration: "Autoriser les nouvelles inscriptions" | ||||
| invite: "Inviter" | ||||
| proxyRemoteFiles: "Proxy fichiers distants" | ||||
| proxyRemoteFilesDescription: "Si vous activez ce paramètre, les fichiers distants non stockés ou supprimés en raison d'une capacité excédentaire seront affichés via un proxy local et généreront une miniature. Cela n'affectera pas le stockage du serveur." | ||||
| driveCapacityPerLocalAccount: "Volume du Drive par utilisateur local" | ||||
| driveCapacityPerRemoteAccount: "Volume du Drive par utilisateur distant" | ||||
| inMb: "en mégaoctets" | ||||
| iconUrl: "URL de l'image de l'icône" | ||||
| bannerUrl: "URL de l'image de la bannière" | ||||
| iconUrl: "URL de l’image de l’avatar" | ||||
| bannerUrl: "URL de l’image de la bannière" | ||||
| basicInfo: "Informations basiques" | ||||
| pinnedUsers: "Utilisateur·rice épinglé·e" | ||||
| pinnedUsersDescription: "Listez les utilisateur·rice·s que vous souhaitez voir épinglé·e·s sur la page \"Découvrir\", un·e par ligne." | ||||
| pinnedNotes: "Note épinglée" | ||||
| hcaptcha: "hCaptcha" | ||||
| enableHcaptcha: "Activer hCaptcha" | ||||
| hcaptchaSiteKey: "Clé du site" | ||||
| @@ -308,26 +322,26 @@ recaptcha: "reCAPTCHA" | ||||
| enableRecaptcha: "Activer reCAPTCHA" | ||||
| recaptchaSiteKey: "Clé du site" | ||||
| recaptchaSecretKey: "Clé secrète" | ||||
| avoidMultiCaptchaConfirm: "L'utilisation de plusieurs Captchas peut provoquer des interférences. Souhaitez-vous désactiver l'autre Captcha? Vous pouvez laisser plusieurs Captcha activés en appuyant sur Annuler." | ||||
| antennas: "Antenne" | ||||
| manageAntennas: "Gestion d'antenne" | ||||
| avoidMultiCaptchaConfirm: "L’utilisation de plusieurs Captchas peut provoquer des interférences. Souhaitez-vous désactiver l’autre Captcha ? Vous pouvez laisser plusieurs Captcha activés en appuyant sur Annuler." | ||||
| antennas: "Antennes" | ||||
| manageAntennas: "Gestion des antennes" | ||||
| name: "Nom" | ||||
| antennaSource: "Recevoir la source" | ||||
| antennaSource: "Source de l’antenne" | ||||
| antennaKeywords: "Mots clés à recevoir" | ||||
| antennaExcludeKeywords: "Mots clés à exclure" | ||||
| antennaKeywordsDescription: "Séparez avec des espaces pour une condition ET. Séparez avec un saut de ligne pour une condition OU." | ||||
| notifyAntenna: "Notifier les nouvelles notes" | ||||
| withFileAntenna: "Notes uniquement avec fichiers joints" | ||||
| antennaKeywordsDescription: "Séparer avec des espaces pour la condition AND. Séparer avec un saut de ligne pour une condition OR." | ||||
| notifyAntenna: "Me notifier pour les nouvelles notes" | ||||
| withFileAntenna: "Notes ayant des attachements uniquement" | ||||
| serviceworker: "ServiceWorker" | ||||
| enableServiceworker: "Activer ServiceWorker" | ||||
| antennaUsersDescription: "Spécifiez les noms d'utilisateurs séparés par des sauts de ligne" | ||||
| antennaUsersDescription: "Saisissez un seul nom d’utilisateur·rice par ligne" | ||||
| caseSensitive: "Sensible à la casse" | ||||
| withReplies: "Inclure les réponses" | ||||
| connectedTo: "Vous êtes connectés aux services suivants" | ||||
| notesAndReplies: "Notes et Réponses" | ||||
| withFiles: "Avec fichiers joints" | ||||
| silence: "Mettre en sourdine" | ||||
| silenceConfirm: "Êtes-vous sûr·e de vouloir mettre l'utilisateur·rice en sourdine ?" | ||||
| silenceConfirm: "Êtes-vous sûr·e de vouloir mettre l’utilisateur·rice en sourdine ?" | ||||
| unsilence: "Annuler la mise en sourdine" | ||||
| unsilenceConfirm: "Êtes-vous sûr·e de vouloir annuler la mise en sourdine de cette utilisateur·rice ?" | ||||
| popularUsers: "Utilisateur·rice·s populaires" | ||||
| @@ -340,13 +354,6 @@ popularTags: "Mots-clés populaires" | ||||
| userList: "Listes" | ||||
| about: "Informations" | ||||
| aboutMisskey: "À propos de Misskey" | ||||
| aboutMisskeyText: "Misskey est un logiciel open source, développé par syuilo depuis 2014." | ||||
| misskeyMembers: "Il est développé et maintenu par les membres listés ci-dessous :" | ||||
| misskeySource: "Le code source est disponible ici:" | ||||
| misskeyTranslation: "Aidez-nous avec votre contribution à traduire Misskey:" | ||||
| misskeyDonate: "Vous pouvez contribuer au développement de Misskey en faisant un don ici:" | ||||
| morePatrons: "Nous apprécions vraiment le soutien de nombreuses autres personnes non mentionnées ici. Merci à toutes et à tous ! 🥰" | ||||
| patrons: "Supporteurs" | ||||
| administrator: "Administrateur" | ||||
| token: "Jeton" | ||||
| twoStepAuthentication: "Authentification à deux facteurs" | ||||
| @@ -360,13 +367,10 @@ unregister: "Se désinscrire" | ||||
| passwordLessLogin: "Connectez-vous sans mot de passe" | ||||
| resetPassword: "Réinitialiser mot de passe" | ||||
| newPasswordIs: "Votre nouveau mot de passe est \"{password}\"" | ||||
| autoReloadWhenDisconnected: "Rechargement automatique lorsque le serveur se déconnecte" | ||||
| autoNoteWatch: "Surveiller automatique pour les notes" | ||||
| autoNoteWatchDescription: "Soyez informé des notes auxquelles vous avez réagi ou répondu." | ||||
| reduceUiAnimation: "Réduire l'animation de l'interface" | ||||
| reduceUiAnimation: "Réduire les animations dans l’interface" | ||||
| share: "Partager" | ||||
| notFound: "Non trouvé" | ||||
| notFoundDescription: "Aucune page ne correspond à l'URL spécifiée." | ||||
| notFoundDescription: "Aucune page ne correspond à l’URL spécifiée." | ||||
| uploadFolder: "Emplacement de téléversement par défaut" | ||||
| cacheClear: "Vider le cache" | ||||
| markAsReadAllNotifications: "Marquer toutes les notifications comme lues" | ||||
| @@ -398,8 +402,9 @@ quoteAttached: "Avec citation" | ||||
| quoteQuestion: "Souhaitez-vous ajoutez une citation ?" | ||||
| noMessagesYet: "Pas encore discuté" | ||||
| newMessageExists: "Vous avez un nouveau message" | ||||
| onlyOneFileCanBeAttached: "Vous ne pouvez joindre qu'un seul fichier au message" | ||||
| onlyOneFileCanBeAttached: "Vous ne pouvez joindre qu’un seul fichier au message" | ||||
| signinRequired: "Veuillez vous connecter" | ||||
| invitations: "Inviter" | ||||
| invitationCode: "Code d’invitation" | ||||
| checking: "Vérification" | ||||
| available: "Disponible" | ||||
| @@ -414,16 +419,16 @@ passwordMatched: "Combinaison correcte !" | ||||
| passwordNotMatched: "Ne correspond pas" | ||||
| signinWith: "Connectez-vous avec {x}" | ||||
| signinFailed: "Échec d’authentification. Veuillez vérifier que votre nom d’utilisateur et mot de passe sont corrects." | ||||
| tapSecurityKey: "Touchez la clé de sécurité" | ||||
| tapSecurityKey: "Appuyez sur votre clé de sécurité" | ||||
| or: "OU" | ||||
| uiLanguage: "Langue d'affichage de l'interface" | ||||
| uiLanguage: "Langue d’affichage de l’interface" | ||||
| groupInvited: "Invité au groupe" | ||||
| aboutX: "À propos de {x}" | ||||
| useOsNativeEmojis: "Utiliser les émojis natifs du système" | ||||
| youHaveNoGroups: "Vous n'avez aucune groupe" | ||||
| youHaveNoGroups: "Vous n’avez aucun groupe" | ||||
| joinOrCreateGroup: "Soyez invité à rejoindre les groupes ou vous pouvez créer votre propre groupe." | ||||
| noHistory: "Pas d'historique" | ||||
| disableAnimatedMfm: "Désactiver MFM qui a des animations" | ||||
| disableAnimatedMfm: "Désactiver MFM ayant des animations" | ||||
| doing: "Attends une seconde" | ||||
| category: "Catégories" | ||||
| tags: "Étiquettes" | ||||
| @@ -433,15 +438,15 @@ existingAcount: "Comptes existants" | ||||
| regenerate: "Régénérer" | ||||
| fontSize: "Taille de la police" | ||||
| noFollowRequests: "Vous n’avez aucune demande d’abonnement en attente" | ||||
| openImageInNewTab: "Ouvrir l'image dans un nouvel onglet" | ||||
| openImageInNewTab: "Ouvrir les images dans un nouvel onglet" | ||||
| dashboard: "Tableau de bord" | ||||
| local: "Local" | ||||
| remote: "Distant" | ||||
| total: "Total" | ||||
| weekOverWeekChanges: "Diff hebdo" | ||||
| dayOverDayChanges: "Diff quotidien" | ||||
| accessibility: "Accessibilité" | ||||
| clinetSettings: "Paramètres du client" | ||||
| appearance: "Aspect" | ||||
| clientSettings: "Paramètres du client" | ||||
| accountSettings: "Paramètres du compte" | ||||
| promotion: "Promu" | ||||
| promote: "Promouvoir" | ||||
| @@ -451,7 +456,7 @@ showFeaturedNotesInTimeline: "Afficher les notes en vedette dans fil d'actualit | ||||
| objectStorage: "Stockage d'objets" | ||||
| useObjectStorage: "Utiliser le stockage d'objets" | ||||
| objectStorageBaseUrl: "Base URL" | ||||
| objectStorageBaseUrlDesc: "Préfixe d'URL utilisé pour construire l'URL vers le référencement d'objet (média). Spécifiez son URL si vous utilisez un CDN ou un proxy, sinon spécifiez l'adresse accessible au public selon le guide de service que vous allez utiliser. i.g 'https://<bucket>.s3.amazonaws.com' pour AWS S3 et 'https://storage.googleapis.com/<bucket>' pour GCS." | ||||
| objectStorageBaseUrlDesc: "Préfixe d’URL utilisé pour construire l’URL vers le référencement d’objet (média). Spécifiez son URL si vous utilisez un CDN ou un proxy, sinon spécifiez l’adresse accessible au public selon le guide de service que vous allez utiliser. P.ex. 'https://<bucket>.s3.amazonaws.com' pour AWS S3 et 'https://storage.googleapis.com/<bucket>' pour GCS." | ||||
| objectStorageBucket: "Bucket" | ||||
| objectStorageBucketDesc: "Veuillez spécifier le nom du compartiment utilisé sur le service configuré." | ||||
| objectStoragePrefix: "Prefix" | ||||
| @@ -471,10 +476,11 @@ newNoteRecived: "Vous avez une nouvelle note" | ||||
| sounds: "Sons" | ||||
| listen: "Écouter" | ||||
| none: "Rien" | ||||
| popout: "Fenêtre contextuelle" | ||||
| volume: "Volume" | ||||
| details: "Détails" | ||||
| chooseEmoji: "Choisissez un émoji" | ||||
| unableToProcess: "L'opération n'a pas pu être complétée" | ||||
| unableToProcess: "L’opération n’a pas pu être complétée." | ||||
| recentUsed: "Récemment utilisé" | ||||
| install: "Installation" | ||||
| uninstall: "Désinstaller" | ||||
| @@ -495,7 +501,7 @@ updateRemoteUser: "Mettre à jour les informations de l’utilisateur·rice dist | ||||
| deleteAllFiles: "Supprimer tous les fichiers" | ||||
| deleteAllFilesConfirm: "Êtes vous surs de vouloir supprimer tous les fichiers ?" | ||||
| removeAllFollowing: "Retenir tous les abonnements" | ||||
| removeAllFollowingDescription: "Se désabonner de tous les comptes de {host}. Exécutez cette commande si l'instance n'existe plus." | ||||
| removeAllFollowingDescription: "Se désabonner de tous les comptes de {host}. Veuillez lancer cette action uniquement si l’instance n’existe plus." | ||||
| userSuspended: "Cette utilisateur·trice a été suspendue." | ||||
| userSilenced: "Cette utilisateur·trice a été masquer." | ||||
| sidebar: "Barre latérale" | ||||
| @@ -506,6 +512,98 @@ relays: "Relais" | ||||
| addRelay: "Ajouter un relais" | ||||
| inboxUrl: "Inbox URL" | ||||
| addedRelays: "Relais ajoutés" | ||||
| serviceworkerInfo: "Devrait être activé pour les notifications push." | ||||
| deletedNote: "Note supprimée" | ||||
| invisibleNote: "Note invisible" | ||||
| enableInfiniteScroll: "Activer le défilement infini" | ||||
| visibility: "Visibilité" | ||||
| poll: "Sondage" | ||||
| useCw: "Masquer le contenu" | ||||
| enablePlayer: "Activer le lecteur vidéo" | ||||
| disablePlayer: "Désactiver le lecteur vidéo" | ||||
| expandTweet: "Étendre le tweet" | ||||
| themeEditor: "Éditeur de thèmes" | ||||
| description: "Description" | ||||
| author: "Auteur·rice" | ||||
| leaveConfirm: "Vous avez des modifications non-sauvegardées. Voulez-vous les ignorer ?" | ||||
| manage: "Gestion" | ||||
| plugins: "Extensions" | ||||
| pluginInstallWarn: "N’installez que des extensions provenant de sources de confiance." | ||||
| deck: "Deck" | ||||
| undeck: "Quitter le deck" | ||||
| useBlurEffectForModal: "Utiliser un effet de flou pour les modals" | ||||
| width: "Largeur" | ||||
| height: "Hauteur" | ||||
| generateAccessToken: "Générer un jeton d'accès" | ||||
| permission: "Autorisations " | ||||
| enableAll: "Tout activer" | ||||
| disableAll: "Tout désactiver" | ||||
| tokenRequested: "Autoriser l'accès au compte" | ||||
| pluginTokenRequestedDescription: "Ce plugin pourra utiliser les autorisations définies ici." | ||||
| notificationType: "Type de notifications" | ||||
| edit: "Editer" | ||||
| useStarForReactionFallback: "Utiliser ★ comme alternative si l’émoji de réaction est inconnu" | ||||
| emailConfig: "Configuration du serveur email" | ||||
| enableEmail: "Activer la distribution de courriel" | ||||
| emailConfigInfo: "Utilisé pour confirmer votre adresse de courriel et la réinitialisation de votre mot de passe en cas d’oubli." | ||||
| smtpConfig: "Paramètres du serveur SMTP" | ||||
| smtpHost: "Hôte" | ||||
| smtpPort: "Port" | ||||
| smtpUser: "Nom d’utilisateur·rice" | ||||
| smtpPass: "Mot de passe" | ||||
| emptyToDisableSmtpAuth: "Laisser le nom d’utilisateur et le mot de passe vides pour désactiver la vérification SMTP" | ||||
| smtpSecure: "Utiliser SSL/TLS implicitement dans les connexions SMTP" | ||||
| smtpSecureInfo: "Désactiver cette option lorsque STARTTLS est utilisé" | ||||
| testEmail: "Tester la distribution de courriel" | ||||
| wordMute: "Filtre de mots" | ||||
| userSaysSomething: "{name} a dit quelque chose" | ||||
| makeActive: "Activer" | ||||
| display: "Affichage" | ||||
| copy: "Copier" | ||||
| metrics: "Métriques" | ||||
| overview: "Aperçu" | ||||
| logs: "Journaux" | ||||
| delayed: "en retard" | ||||
| database: "Base de données" | ||||
| channel: "Canaux" | ||||
| create: "Créer" | ||||
| notificationSetting: "Paramètres des notifications " | ||||
| notificationSettingDesc: "Sélectionnez le type de notification à afficher" | ||||
| useGlobalSetting: "Utiliser paramètre général" | ||||
| other: "Autre" | ||||
| regenerateLoginToken: "Régénérer le jeton de connexion" | ||||
| setMultipleBySeparatingWithSpace: "Vous pouvez définir plus d’un, séparés par des espaces." | ||||
| fileIdOrUrl: "ID du fichier ou URL" | ||||
| chatOpenBehavior: "Comportement de la fenêtre de discussion lors de son ouverture" | ||||
| random: "Aléatoire" | ||||
| public: "Public" | ||||
| _mfm: | ||||
|   mention: "Mentionner" | ||||
|   hashtag: "Hashtags" | ||||
|   link: "Lien" | ||||
|   center: "Centrée" | ||||
|   quote: "Citer" | ||||
|   emoji: "Émojis personnalisés" | ||||
|   search: "Rechercher" | ||||
| _reversi: | ||||
|   total: "Total" | ||||
| _serverDisconnectedBehavior: | ||||
|   reload: "Rechargement automatique" | ||||
| _channel: | ||||
|   create: "Créer un canal" | ||||
|   edit: "Éditer le canal" | ||||
|   removeBanner: "Supprimer la bannière" | ||||
|   featured: "Tendances" | ||||
|   usersCount: "{n} Participants" | ||||
|   notesCount: "{n} Notes" | ||||
| _sidebar: | ||||
|   full: "Complet" | ||||
|   icon: "Avatar" | ||||
|   hide: "Masquer" | ||||
| _wordMute: | ||||
|   muteWords: "Mot à mettre en sourdine" | ||||
|   muteWordsDescription: "Séparer avec des espaces pour la condition AND. Séparer avec un saut de ligne pour une condition OR." | ||||
|   mutedNotes: "Notes mises en sourdine" | ||||
| _theme: | ||||
|   explore: "Explorer les thèmes" | ||||
|   install: "Installer un thème" | ||||
| @@ -514,13 +612,45 @@ _theme: | ||||
|   installed: "{name} a été installé" | ||||
|   alreadyInstalled: "Ce thème est déjà installé" | ||||
|   invalid: "Le format du thème n'est pas valide" | ||||
|   make: "Créer un thème" | ||||
|   base: "Base" | ||||
|   addConstant: "Ajouter une constante" | ||||
|   constant: "Constante" | ||||
|   defaultValue: "Valeur par défaut" | ||||
|   color: "Couleur" | ||||
|   key: "Clé " | ||||
|   func: "Fonction" | ||||
|   argument: "Argument" | ||||
|   alpha: "Transparence" | ||||
|   darken: "Assombrir" | ||||
|   importInfo: "Vous pouvez importer un thème vers l’éditeur de thèmes en saisissant son code ici." | ||||
|   keys: | ||||
|     bg: "Arrière-plan" | ||||
|     fg: "Texte" | ||||
|     focus: "Mise au point" | ||||
|     indicator: "Indicateur" | ||||
|     panel: "Panneau" | ||||
|     shadow: "Ombre" | ||||
|     header: "Entête" | ||||
|     navBg: "Fond de la barre latérale" | ||||
|     navFg: "Texte de la barre latérale" | ||||
|     link: "Lien" | ||||
|     hashtag: "Hashtags" | ||||
|     mention: "Mentionner" | ||||
|     mentionMe: "Mentions (Moi)" | ||||
|     renote: "Renote" | ||||
|     divider: "Séparateur" | ||||
|     infoWarnFg: "Texte d’avertissement" | ||||
|     cwBg: "Arrière-plan du CW" | ||||
|     badge: "Badge" | ||||
|     messageBg: "Arrière plan de la discussion" | ||||
| _sfx: | ||||
|   note: "Nouvelle note" | ||||
|   noteMy: "Ma note" | ||||
|   notification: "Notifications" | ||||
|   chat: "Discuter" | ||||
|   chatBg: "Discuter (De fond)" | ||||
|   antenna: "Réception d'antenne" | ||||
|   antenna: "Réception de l’antenne" | ||||
| _ago: | ||||
|   unknown: "Inconnu" | ||||
|   future: "Futur" | ||||
| @@ -541,9 +671,9 @@ _tutorial: | ||||
|   title: "Comment utiliser Misskey" | ||||
|   step1_1: "Bienvenue," | ||||
|   step1_2: "Cette page est appelée « un fil ». Elle affiche les « notes » des personnes auxquelles vous êtes abonné dans un ordre chronologique." | ||||
|   step1_3: "Vous n'avez pas encore publier de notes et personne n'est encore abonnements, vous ne devriez donc rien voir dans fil d'actualité." | ||||
|   step1_3: "Votre fil est actuellement vide vu que vous ne suivez aucun compte et que vous n’avez publié aucune note, pour l’instant." | ||||
|   step2_1: "Procédons d’abord à la préparation de votre profil avant d’écrire une note et/ou de vous abonner à un compte." | ||||
|   step2_2: "En fournissant quelques informations sur vous, il sera plus facile pour les autres de vous abonne." | ||||
|   step2_2: "En fournissant quelques informations sur vous, il sera plus facile pour les autres de s’abonner à votre compte." | ||||
|   step3_1: "Vous avez fini de créer votre profil ?" | ||||
|   step3_2: "L’étape suivante consiste à créer une note. Vous pouvez commencer en cliquant sur l’icône crayon sur l’écran." | ||||
|   step3_3: "Remplissez le cadran et cliquez sur le bouton en haut à droite pour envoyer." | ||||
| @@ -551,7 +681,7 @@ _tutorial: | ||||
|   step4_1: "Avez-vous publié votre première note ?" | ||||
|   step4_2: "Youpi ! Celle-ci est maintenant affiché sur votre fil d’actualité." | ||||
|   step5_1: "Maintenant, essayons de nous abonner à d’autres personnes afin de rendre votre fil plus vivant." | ||||
|   step5_2: "{featured} affiche les notes en tendance sur cette instance. {explore} vous permet de trouver les utilisateur·rice·s en tendance. Essayez de vous abonner aux gens que vous aimez !" | ||||
|   step5_2: "La page {featured} affiche les notes en tendance sur la présente instance et {explore} vous permet de trouver des utilisateur·rice·s en tendance. Essayez de vous abonner aux gens que vous aimez !" | ||||
|   step5_3: "Pour pouvoir suivre d’autres utilisateur·rice, cliquez sur leur avatar afin d’afficher la page du profil utilisateur ensuite appuyez sur le bouton « S’abonner »." | ||||
|   step5_4: "Si l’autre utilisateur possède une icône sous forme d’un cadenas à côté de son nom, il devra accepter votre demande d’abonnement manuellement." | ||||
|   step6_1: "Maintenant, vous êtes en mesure de voir s’afficher les notes des autres utilisateur·rice·s sur votre propre fil." | ||||
| @@ -562,11 +692,11 @@ _tutorial: | ||||
|   step7_3: "Bon courage et amusez-vous bien sur Misskey 🚀" | ||||
| _2fa: | ||||
|   alreadyRegistered: "Cette étape à déjà été complétée" | ||||
|   registerDevice: "Ajouter un appareil" | ||||
|   registerDevice: "Ajouter un nouvel appareil" | ||||
|   registerKey: "S’inscrire la clé" | ||||
|   step1: "Tout d'abord, installez une application d'authentification, telle que {a} ou {b}, sur votre appareil." | ||||
|   step2: "Ensuite, scannez le code QR affiché avec l'application." | ||||
|   step3: "Entrez le jeton affiché sur l'application et vous avez terminé." | ||||
|   step2: "Ensuite, scannez le code QR affiché sur l’écran." | ||||
|   step3: "Entrez le jeton affiché sur votre application pour compléter la configuration." | ||||
|   step4: "Lorsque vous vous connectez, entrez le jeton de la même manière." | ||||
|   securityKeyInfo: "Vous pouvez configurer l'authentification WebAuthN pour sécuriser davantage le processus de connexion avec non seulement la clé de sécurité matérielle qui prend en charge FIDO2, mais également l'authentification par empreinte digitale ou PIN sur votre appareil." | ||||
| _permissions: | ||||
| @@ -578,7 +708,7 @@ _permissions: | ||||
|   "write:drive": "Écrire sur le Drive" | ||||
|   "read:favorites": "Afficher les favoris" | ||||
|   "write:favorites": "Écrire des favoris" | ||||
|   "read:following": "Voir les informations de l'abonné" | ||||
|   "read:following": "Voir les informations de vos abonnements" | ||||
|   "write:following": "Abonnements/Se désabonner" | ||||
|   "read:messaging": "Cherche à discuter" | ||||
|   "write:messaging": "Contrôler le discuter" | ||||
| @@ -596,19 +726,21 @@ _permissions: | ||||
|   "write:page-likes": "Mettre à jour les favoris sur les Pages" | ||||
|   "read:user-groups": "Voir les groupes d'utilisateur·rice·s" | ||||
|   "write:user-groups": "Éditer les groupes des utilisateur·rice·s" | ||||
|   "read:channels": "Lire les canaux" | ||||
|   "write:channels": "Modifier les canaux" | ||||
| _auth: | ||||
|   shareAccess: "Autoriser \"{name}\" à accéder à votre compte ?" | ||||
|   shareAccessAsk: "Voulez-vous vraiment autoriser cette application à accéder à votre compte?" | ||||
|   permissionAsk: "Cette application nécessite les autorisations suivantes " | ||||
|   pleaseGoBack: "Veillez retourner à l'application" | ||||
|   permissionAsk: "Cette application nécessite les autorisations suivantes :" | ||||
|   pleaseGoBack: "Veuillez retourner à l’application" | ||||
|   callback: "Retour vers l’application" | ||||
|   denied: "Accès refusé" | ||||
| _antennaSources: | ||||
|   all: "Toutes les notes" | ||||
|   homeTimeline: "Notes de l'utilisateur auquel je m'abonne" | ||||
|   users: "Notes des un ou plusieurs utilisateurs spécifiés" | ||||
|   userList: "Notes pour les utilisateurs de la liste spécifiée" | ||||
|   userGroup: "Notes pour les utilisateurs de la groupe spécifiée" | ||||
|   homeTimeline: "Notes venant des utilisateur·rice·s auxquel·les je suis abonné" | ||||
|   users: "Notes venant de la part d’utilisateur·rice·s précis" | ||||
|   userList: "Notes venant d’une liste spécifique" | ||||
|   userGroup: "Notes venant d’utilisateur·rice·s du groupe spécifié" | ||||
| _weekday: | ||||
|   sunday: "Dimanche" | ||||
|   monday: "Lundi" | ||||
| @@ -620,19 +752,22 @@ _weekday: | ||||
| _widgets: | ||||
|   memo: "Note collante" | ||||
|   notifications: "Notifications" | ||||
|   timeline: "Fil d'actualité" | ||||
|   timeline: "Fil" | ||||
|   calendar: "Calendrier" | ||||
|   trends: "Tendances" | ||||
|   clock: "Horloge" | ||||
|   rss: "Lecteur de flux RSS" | ||||
|   activity: "Activités" | ||||
|   activity: "Activité" | ||||
|   photos: "Photos" | ||||
|   digitalClock: "Horloge numérique" | ||||
|   federation: "Fédération" | ||||
|   postForm: "Formulaire à publier" | ||||
|   button: "Bouton" | ||||
| _cw: | ||||
|   hide: "Masquer" | ||||
|   show: "Voir plus" | ||||
|   show: "Afficher plus …" | ||||
|   chars: "{count} caractères" | ||||
|   files: "{count} fichiers" | ||||
|   poll: "Sondage" | ||||
| _poll: | ||||
|   noOnlyOneChoice: "Au moins 2 réponses nécéssaires" | ||||
|   choiceN: "Choix {n}" | ||||
| @@ -641,7 +776,7 @@ _poll: | ||||
|   expiration: "Fin du sondage" | ||||
|   infinite: "Illimité" | ||||
|   at: "Choisir une date" | ||||
|   after: "Chosir une durée" | ||||
|   after: "Choisir la durée" | ||||
|   deadlineDate: "Date de fin" | ||||
|   deadlineTime: "Heure de fin" | ||||
|   duration: "Durée" | ||||
| @@ -665,11 +800,13 @@ _visibility: | ||||
|   specified: "Direct" | ||||
|   specifiedDescription: "Publier uniquement aux utilisateur·rice·s mentionné·e·s" | ||||
|   localOnly: "Local seulement" | ||||
|   localOnlyDescription: "Caché pour les utilisateurs distant" | ||||
| _postForm: | ||||
|   replyPlaceholder: "Répondre à cette note ..." | ||||
|   quotePlaceholder: "Citez cette note ..." | ||||
|   channelPlaceholder: "Publier vers le canal" | ||||
|   _placeholders: | ||||
|     a: "Qu'est-ce qu'il se passe ?" | ||||
|     a: "Quoi de neuf ?" | ||||
|     b: "Quoi de neuf ?" | ||||
|     c: "Qu’avez-vous en tête ?" | ||||
|     d: "Désirez-vous publier quelques mots ?" | ||||
| @@ -677,10 +814,9 @@ _postForm: | ||||
|     f: "En attente de vos écrits ..." | ||||
| _profile: | ||||
|   name: "Nom" | ||||
|   username: "Nom d'utilisateur·rice" | ||||
|   username: "Nom d’utilisateur·rice" | ||||
|   description: "À propos de moi" | ||||
|   youCanIncludeHashtags: "Vous pouvez également inclure des hashtags." | ||||
|   metadata: "Informations complémentaires" | ||||
|   metadataLabel: "Étiquette" | ||||
|   metadataContent: "Contenu" | ||||
| _exportOrImport: | ||||
| @@ -690,15 +826,15 @@ _exportOrImport: | ||||
|   blockingList: "Bloquer" | ||||
|   userLists: "Listes" | ||||
| _charts: | ||||
|   federationInstancesIncDec: "Variation du nombre d'instances" | ||||
|   federationInstancesTotal: "Nombre d'instances au total" | ||||
|   federationInstancesIncDec: "Variation du nombre des instances fédérées" | ||||
|   federationInstancesTotal: "Nombre total des instances fédérées" | ||||
|   usersIncDec: "Variation du nombre d'utilisateur·rice·s" | ||||
|   usersTotal: "Nombre d'utilisateur·rice·s au total" | ||||
|   usersTotal: "Nombre des utilisateur·rice·s au total" | ||||
|   activeUsers: "Utilisateur·rice·s actif·ve·s" | ||||
|   notesIncDec: "Variation du nombre d'notes" | ||||
|   notesIncDec: "Variation du nombre des notes" | ||||
|   localNotesIncDec: "Variation du nombre de notes local" | ||||
|   remoteNotesIncDec: "Variation du nombre d’notes distant" | ||||
|   notesTotal: "Nombre d'notes au total" | ||||
|   notesTotal: "Nombre total des notes" | ||||
|   filesIncDec: "Variation du nombre de fichiers" | ||||
|   filesTotal: "Nombre de fichiers au total" | ||||
|   storageUsageIncDec: "Variation de l'utilisation du stockage" | ||||
| @@ -707,8 +843,8 @@ _instanceCharts: | ||||
|   requests: "Requêtes" | ||||
|   users: "Variation du nombre d'utilisateur·rice·s" | ||||
|   usersTotal: "Nombre d'utilisateur·rice·s au total cumulé" | ||||
|   notes: "Variation du nombre d'notes" | ||||
|   notesTotal: "Nombre d'notes au total cumulé" | ||||
|   notes: "Variation du nombre des notes" | ||||
|   notesTotal: "Nombre total cumulé des notes" | ||||
|   ff: "Variation des abonné·e·s" | ||||
|   ffTotal: "Nombre d'abonné·e·s au total cumulé" | ||||
|   cacheSize: "Variation de la taille du cache" | ||||
| @@ -780,6 +916,8 @@ _rooms: | ||||
|     cup-noodle: "Bol de nouilles" | ||||
|     holo-display: "Affichage holographique" | ||||
|     energy-drink: "Boisson énergétique" | ||||
|     doll-ai: "Poupée Ai" | ||||
|     banknote: "Billets de banque" | ||||
| _pages: | ||||
|   newPage: "Créer une page" | ||||
|   editPage: "Modifier une page" | ||||
| @@ -789,7 +927,7 @@ _pages: | ||||
|   deleted: "La page a bien été supprimée" | ||||
|   nameAlreadyExists: "La URL de page spécifiée existe déjà" | ||||
|   invalidNameTitle: "La URL de la page spécifiée n’est pas valide" | ||||
|   invalidNameText: "Assurez-vous qu'il n'est pas vide" | ||||
|   invalidNameText: "Assurez-vous qu’il n’est pas vide" | ||||
|   editThisPage: "Éditer cette page" | ||||
|   viewSource: "Afficher la source" | ||||
|   viewPage: "Afficher la page" | ||||
| @@ -798,6 +936,7 @@ _pages: | ||||
|   my: "Mes pages" | ||||
|   liked: "Pages favorites" | ||||
|   inspector: "Inspecteur" | ||||
|   contents: "Contenu" | ||||
|   content: "Bloc de page" | ||||
|   variables: "Variables" | ||||
|   title: "Titre" | ||||
| @@ -812,7 +951,7 @@ _pages: | ||||
|   eyeCatchingImageRemove: "Supprimer une image attirante" | ||||
|   chooseBlock: "Ajouter un bloc" | ||||
|   selectType: "Choisir un type" | ||||
|   enterVariableName: "Veuillez entrer un nom de variable" | ||||
|   enterVariableName: "Veuillez entrer un nom pour votre variable" | ||||
|   variableNameIsAlreadyUsed: "Cette variable est déjà utilisée" | ||||
|   contentBlocks: "Contenu" | ||||
|   inputBlocks: "Entrée" | ||||
| @@ -872,8 +1011,8 @@ _pages: | ||||
|         resetRandom: "Réinitialiser le nombre aléatoire" | ||||
|         pushEvent: "Envoyer un évènement" | ||||
|         _pushEvent: | ||||
|           event: "Nom de l'évènement" | ||||
|           message: "Message à afficher lorsque appuyé" | ||||
|           event: "Nom de l’évènement" | ||||
|           message: "Message à afficher lorsqu’il est activé" | ||||
|           variable: "Variable à envoyer" | ||||
|           no-variable: "Rien" | ||||
|         callAiScript: "Appeler AiScript" | ||||
| @@ -902,8 +1041,8 @@ _pages: | ||||
|       multiLineText: "Texte (Multi-lignes)" | ||||
|       textList: "Liste de texte" | ||||
|       _textList: | ||||
|         info: "Veuillez séparer chacun avec une nouvelle ligne" | ||||
|       strLen: "Longueur d'un texte" | ||||
|         info: "Veuillez séparer chaque entrée avec un saut de ligne" | ||||
|       strLen: "Longueur du texte" | ||||
|       _strLen: | ||||
|         arg1: "Texte" | ||||
|       strPick: "Extraire un caractère" | ||||
| @@ -1065,3 +1204,41 @@ _relayStatus: | ||||
|   requesting: "En attente" | ||||
|   accepted: "Accepté" | ||||
|   rejected: "Refusée" | ||||
| _notification: | ||||
|   fileUploaded: "Le fichier a été téléversé !" | ||||
|   youGotMention: "{name} vous a mentionné" | ||||
|   youGotReply: "Réponse de {name}" | ||||
|   youGotQuote: "Cité·e par {name}" | ||||
|   youRenoted: "{name} vous a Renoté" | ||||
|   youGotPoll: "{name} a participé à votre sondage" | ||||
|   youGotMessagingMessageFromUser: "{name} vous envoyé un message" | ||||
|   youGotMessagingMessageFromGroup: "Un message a été envoyé au groupe {name}" | ||||
|   youWereFollowed: "Vous suit" | ||||
|   youReceivedFollowRequest: "Vous avez reçu une demande d’abonnement" | ||||
|   yourFollowRequestAccepted: "Votre demande d’abonnement a été accepté" | ||||
|   youWereInvitedToGroup: "Invité au groupe" | ||||
|   _types: | ||||
|     all: "Toutes" | ||||
|     follow: "Abonnements" | ||||
|     mention: "Mentionner" | ||||
|     reply: "Réponses" | ||||
|     renote: "Renote" | ||||
|     quote: "Citer" | ||||
|     reaction: "Réactions" | ||||
|     groupInvited: "Invité aux groupes" | ||||
|     app: "Notifications provenant des apps" | ||||
| _deck: | ||||
|   alwaysShowMainColumn: "Toujours afficher la colonne principale" | ||||
|   columnAlign: "Aligner les colonnes" | ||||
|   addColumn: "Ajouter une colonne" | ||||
|   swapLeft: "Déplacer à gauche" | ||||
|   swapRight: "Déplacer à droite" | ||||
|   stackLeft: "Empiler à gauche" | ||||
|   _columns: | ||||
|     widgets: "Widgets" | ||||
|     notifications: "Notifications" | ||||
|     tl: "Fil" | ||||
|     antenna: "Antennes" | ||||
|     list: "Listes" | ||||
|     mentions: "Mentions" | ||||
|     direct: "Direct" | ||||
|   | ||||
| @@ -14,17 +14,25 @@ const merge = (...args) => args.reduce((a, c) => ({ | ||||
| }), {}); | ||||
|  | ||||
| const languages = [ | ||||
| 	//'cs-CZ', | ||||
| 	//'da-DK', | ||||
| 	'ar-SA', | ||||
| 	'cs-CZ', | ||||
| 	'da-DK', | ||||
| 	'de-DE', | ||||
| 	'en-US', | ||||
| 	'es-ES', | ||||
| 	'fr-FR', | ||||
| 	'ja-JP', | ||||
| 	'ja-KS', | ||||
| 	'kab-KAB', | ||||
| 	'kn-IN', | ||||
| 	'ko-KR', | ||||
| 	//'nl-NL', | ||||
| 	//'pl-PL', | ||||
| 	'nl-NL', | ||||
| 	'no-NO', | ||||
| 	'pl-PL', | ||||
| 	'pt-PT', | ||||
| 	'ru-RU', | ||||
| 	'ug-CN', | ||||
| 	'uk-UA', | ||||
| 	'zh-CN', | ||||
| 	'zh-TW', | ||||
| ]; | ||||
|   | ||||
| @@ -16,6 +16,9 @@ noNotes: "ノートはありません" | ||||
| noNotifications: "通知はありません" | ||||
| instance: "インスタンス" | ||||
| settings: "設定" | ||||
| basicSettings: "基本設定" | ||||
| otherSettings: "その他の設定" | ||||
| openInWindow: "ウィンドウで開く" | ||||
| profile: "プロフィール" | ||||
| timeline: "タイムライン" | ||||
| noAccountDescription: "自己紹介はありません" | ||||
| @@ -30,6 +33,9 @@ addUser: "ユーザーを追加" | ||||
| favorite: "お気に入り" | ||||
| favorites: "お気に入り" | ||||
| unfavorite: "お気に入り解除" | ||||
| favorited: "お気に入りに登録しました。" | ||||
| alreadyFavorited: "既にお気に入りに登録されています。" | ||||
| cantFavorite: "お気に入りに登録できませんでした。" | ||||
| pin: "ピン留め" | ||||
| unpin: "ピン留め解除" | ||||
| copyContent: "内容をコピー" | ||||
| @@ -40,11 +46,13 @@ deleteAndEditConfirm: "このノートを削除してもう一度編集します | ||||
| addToList: "リストに追加" | ||||
| sendMessage: "メッセージを送信" | ||||
| copyUsername: "ユーザー名をコピー" | ||||
| searchUser: "ユーザーを検索" | ||||
| reply: "返信" | ||||
| loadMore: "もっと見る" | ||||
| youGotNewFollower: "フォローされました" | ||||
| receiveFollowRequest: "フォローリクエストされました" | ||||
| followRequestAccepted: "フォローが承認されました" | ||||
| mention: "メンション" | ||||
| mentions: "あなた宛て" | ||||
| directNotes: "ダイレクト投稿" | ||||
| importAndExport: "インポートとエクスポート" | ||||
| @@ -65,8 +73,11 @@ followers: "フォロワー" | ||||
| followsYou: "フォローされています" | ||||
| createList: "リスト作成" | ||||
| manageLists: "リストの管理" | ||||
| error: "問題が発生しました" | ||||
| error: "エラー" | ||||
| somethingHappened: "問題が発生しました" | ||||
| retry: "再試行" | ||||
| pageLoadError: "ページの読み込みに失敗しました。" | ||||
| pageLoadErrorDescription: "これは通常、ネットワークまたはブラウザキャッシュが原因です。キャッシュをクリアするか、しばらく待ってから再度試してください。" | ||||
| enterListName: "リスト名を入力" | ||||
| privacy: "プライバシー" | ||||
| makeFollowManuallyApprove: "フォローを承認制にする" | ||||
| @@ -79,6 +90,9 @@ followRequestPending: "フォロー許可待ち" | ||||
| enterEmoji: "絵文字を入力" | ||||
| renote: "Renote" | ||||
| unrenote: "Renote解除" | ||||
| renoted: "Renoteしました。" | ||||
| cantRenote: "この投稿はRenoteできません。" | ||||
| cantReRenote: "RenoteをRenoteすることはできません。" | ||||
| quote: "引用" | ||||
| pinnedNote: "ピン留めされたノート" | ||||
| you: "あなた" | ||||
| @@ -87,6 +101,7 @@ sensitive: "閲覧注意" | ||||
| add: "追加" | ||||
| reaction: "リアクション" | ||||
| reactionSettingDescription: "リアクションピッカーに表示するリアクションを設定します。" | ||||
| reactionSettingDescription2: "ドラッグして並び替え、クリックして削除、+を押して追加します。" | ||||
| rememberNoteVisibility: "公開範囲を記憶する" | ||||
| attachCancel: "添付取り消し" | ||||
| markAsSensitive: "閲覧注意にする" | ||||
| @@ -103,7 +118,12 @@ unblockConfirm: "ブロック解除しますか?" | ||||
| suspendConfirm: "凍結しますか?" | ||||
| unsuspendConfirm: "解凍しますか?" | ||||
| selectList: "リストを選択" | ||||
| selectAntenna: "アンテナを選択" | ||||
| selectWidget: "ウィジェットを選択" | ||||
| editWidgets: "ウィジェットを編集" | ||||
| editWidgetsExit: "編集を終了" | ||||
| customEmojis: "カスタム絵文字" | ||||
| emoji: "絵文字" | ||||
| emojiName: "絵文字名" | ||||
| emojiUrl: "絵文字画像URL" | ||||
| addEmoji: "絵文字を追加" | ||||
| @@ -111,7 +131,9 @@ settingGuide: "おすすめ設定" | ||||
| cacheRemoteFiles: "リモートのファイルをキャッシュする" | ||||
| cacheRemoteFilesDescription: "この設定を無効にすると、リモートファイルをキャッシュせず直リンクするようになります。サーバーのストレージを節約できますが、サムネイルが生成されないので通信量が増加します。" | ||||
| flagAsBot: "Botとして設定" | ||||
| flagAsBotDescription: "このアカウントがプログラムによって運用される場合は、このフラグをオンにします。オンにすると、反応の連鎖を防ぐためのフラグとして他の開発者に役立ったり、Misskeyのシステム上での扱いがBotに合ったものになります。" | ||||
| flagAsCat: "Catとして設定" | ||||
| flagAsCatDescription: "このアカウントが猫であることを示す場合は、このフラグをオンにします。" | ||||
| autoAcceptFollowed: "フォロー中ユーザーからのフォロリクを自動承認" | ||||
| addAcount: "アカウント追加" | ||||
| loginFailed: "ログインに失敗しました" | ||||
| @@ -173,7 +195,6 @@ processing: "処理中" | ||||
| preview: "プレビュー" | ||||
| default: "デフォルト" | ||||
| noCustomEmojis: "絵文字はありません" | ||||
| customEmojisOfRemote: "リモートの絵文字" | ||||
| noJobs: "ジョブはありません" | ||||
| federating: "連合中" | ||||
| blocked: "ブロック中" | ||||
| @@ -202,6 +223,8 @@ imageUrl: "画像URL" | ||||
| remove: "削除" | ||||
| removed: "削除しました" | ||||
| removeAreYouSure: "「{x}」を削除しますか?" | ||||
| deleteAreYouSure: "「{x}」を削除しますか?" | ||||
| resetAreYouSure: "リセットしますか?" | ||||
| saved: "保存しました" | ||||
| messaging: "チャット" | ||||
| upload: "アップロード" | ||||
| @@ -260,6 +283,7 @@ rename: "名前を変更" | ||||
| avatar: "アイコン" | ||||
| banner: "バナー" | ||||
| nsfw: "閲覧注意" | ||||
| whenServerDisconnected: "サーバーとの接続が失われたとき" | ||||
| disconnectedFromServer: "サーバーから切断されました" | ||||
| reload: "リロード" | ||||
| doNothing: "なにもしない" | ||||
| @@ -300,6 +324,10 @@ bannerUrl: "バナー画像のURL" | ||||
| basicInfo: "基本情報" | ||||
| pinnedUsers: "ピン留めユーザー" | ||||
| pinnedUsersDescription: "「みつける」ページなどにピン留めしたいユーザーを改行で区切って記述します。" | ||||
| pinnedPages: "ピン留めページ" | ||||
| pinnedPagesDescription: "インスタンスのトップページにピン留めしたいページのパスを改行で区切って記述します。" | ||||
| pinnedClipId: "ピン留めするクリップのID" | ||||
| pinnedNotes: "ピン留めされたノート" | ||||
| hcaptcha: "hCaptcha" | ||||
| enableHcaptcha: "hCaptchaを有効にする" | ||||
| hcaptchaSiteKey: "サイトキー" | ||||
| @@ -340,13 +368,6 @@ popularTags: "人気のタグ" | ||||
| userList: "リスト" | ||||
| about: "情報" | ||||
| aboutMisskey: "Misskeyについて" | ||||
| aboutMisskeyText: "Misskeyはsyuiloによって2014年から開発されている、オープンソースのソフトウェアです。" | ||||
| misskeyMembers: "現在以下のメンバーによって開発・メンテナンスされています:" | ||||
| misskeySource: "ソースコードはここで公開されています:" | ||||
| misskeyTranslation: "Misskeyの翻訳にご協力をお願いします:" | ||||
| misskeyDonate: "Misskeyに寄付をして開発をサポートできます:" | ||||
| morePatrons: "他にも多くの方が支援してくれています。ありがとうございます🥰" | ||||
| patrons: "支援者" | ||||
| administrator: "管理者" | ||||
| token: "トークン" | ||||
| twoStepAuthentication: "二段階認証" | ||||
| @@ -360,9 +381,6 @@ unregister: "登録を解除" | ||||
| passwordLessLogin: "パスワード無しログイン" | ||||
| resetPassword: "パスワードをリセット" | ||||
| newPasswordIs: "新しいパスワードは「{password}」です" | ||||
| autoReloadWhenDisconnected: "サーバー切断時に自動リロード" | ||||
| autoNoteWatch: "ノートの自動ウォッチ" | ||||
| autoNoteWatchDescription: "あなたがリアクションしたり返信したりした他のユーザーのノートに関する通知を受け取るようにします。" | ||||
| reduceUiAnimation: "UIのアニメーションを減らす" | ||||
| share: "共有" | ||||
| notFound: "見つかりません" | ||||
| @@ -400,6 +418,7 @@ noMessagesYet: "まだチャットはありません" | ||||
| newMessageExists: "新しいメッセージがあります" | ||||
| onlyOneFileCanBeAttached: "メッセージに添付できるファイルはひとつです" | ||||
| signinRequired: "ログインしてください" | ||||
| invitations: "招待" | ||||
| invitationCode: "招待コード" | ||||
| checking: "確認しています" | ||||
| available: "利用できます" | ||||
| @@ -423,6 +442,7 @@ useOsNativeEmojis: "OSネイティブの絵文字を使用" | ||||
| youHaveNoGroups: "グループがありません" | ||||
| joinOrCreateGroup: "既存のグループに招待してもらうか、新しくグループを作成してください。" | ||||
| noHistory: "履歴はありません" | ||||
| signinHistory: "ログイン履歴" | ||||
| disableAnimatedMfm: "動きのあるMFMを無効にする" | ||||
| doing: "やっています" | ||||
| category: "カテゴリ" | ||||
| @@ -440,8 +460,8 @@ remote: "リモート" | ||||
| total: "合計" | ||||
| weekOverWeekChanges: "前週比" | ||||
| dayOverDayChanges: "前日比" | ||||
| accessibility: "アクセシビリティ" | ||||
| clinetSettings: "クライアント設定" | ||||
| appearance: "アピアランス" | ||||
| clientSettings: "クライアント設定" | ||||
| accountSettings: "アカウント設定" | ||||
| promotion: "プロモーション" | ||||
| promote: "プロモート" | ||||
| @@ -464,6 +484,7 @@ objectStorageUseSSL: "SSLを使用する" | ||||
| objectStorageUseSSLDesc: "API接続にhttpsを使用しない場合はオフにしてください" | ||||
| objectStorageUseProxy: "Proxyを利用する" | ||||
| objectStorageUseProxyDesc: "API接続にproxyを利用しない場合はオフにしてください" | ||||
| objectStorageSetPublicRead: "アップロード時に'public-read'を設定する" | ||||
| serverLogs: "サーバーログ" | ||||
| deleteAll: "全て削除" | ||||
| showFixedPostForm: "タイムライン上部に投稿フォームを表示する" | ||||
| @@ -471,7 +492,10 @@ newNoteRecived: "新しいノートがあります" | ||||
| sounds: "サウンド" | ||||
| listen: "聴く" | ||||
| none: "なし" | ||||
| showInPage: "ページで表示" | ||||
| popout: "ポップアウト" | ||||
| volume: "音量" | ||||
| masterVolume: "マスター音量" | ||||
| details: "詳細" | ||||
| chooseEmoji: "絵文字を選択" | ||||
| unableToProcess: "操作を完了できません" | ||||
| @@ -506,6 +530,280 @@ relays: "リレー" | ||||
| addRelay: "リレーの追加" | ||||
| inboxUrl: "inboxのURL" | ||||
| addedRelays: "追加済みのリレー" | ||||
| serviceworkerInfo: "プッシュ通知を行うには有効する必要があります。" | ||||
| deletedNote: "削除された投稿" | ||||
| invisibleNote: "非公開の投稿" | ||||
| enableInfiniteScroll: "自動でもっと見る" | ||||
| visibility: "公開範囲" | ||||
| poll: "アンケート" | ||||
| useCw: "内容を隠す" | ||||
| enablePlayer: "プレイヤーを開く" | ||||
| disablePlayer: "プレイヤーを閉じる" | ||||
| expandTweet: "ツイートを展開する" | ||||
| themeEditor: "テーマエディター" | ||||
| description: "説明" | ||||
| author: "作者" | ||||
| leaveConfirm: "未保存の変更があります。破棄しますか?" | ||||
| manage: "管理" | ||||
| plugins: "プラグイン" | ||||
| pluginInstallWarn: "信頼できないプラグインはインストールしないでください。" | ||||
| deck: "デッキ" | ||||
| undeck: "デッキ解除" | ||||
| useBlurEffectForModal: "モーダルにぼかし効果を使用" | ||||
| useFullReactionPicker: "フル機能リアクションピッカーを使用" | ||||
| width: "幅" | ||||
| height: "高さ" | ||||
| large: "大" | ||||
| medium: "中" | ||||
| small: "小" | ||||
| generateAccessToken: "アクセストークンの発行" | ||||
| permission: "権限" | ||||
| enableAll: "全て有効にする" | ||||
| disableAll: "全て無効にする" | ||||
| tokenRequested: "アカウントへのアクセス許可" | ||||
| pluginTokenRequestedDescription: "このプラグインはここで設定した権限を行使できるようになります。" | ||||
| notificationType: "通知の種類" | ||||
| edit: "編集" | ||||
| useStarForReactionFallback: "リアクション絵文字が不明な場合、代わりに★を使う" | ||||
| emailConfig: "メールサーバー設定" | ||||
| enableEmail: "メール配信機能を有効化する" | ||||
| emailConfigInfo: "メールアドレスの確認やパスワードリセットの際に使います" | ||||
| email: "メール" | ||||
| emailAddress: "メールアドレス" | ||||
| smtpConfig: "SMTP サーバーの設定" | ||||
| smtpHost: "ホスト" | ||||
| smtpPort: "ポート" | ||||
| smtpUser: "ユーザー名" | ||||
| smtpPass: "パスワード" | ||||
| emptyToDisableSmtpAuth: "ユーザー名とパスワードを空欄にすることで、SMTP認証を無効化出来ます" | ||||
| smtpSecure: "SMTP 接続に暗黙的なSSL/TLSを使用する" | ||||
| smtpSecureInfo: "STARTTLS使用時はオフにします。" | ||||
| testEmail: "配信テスト" | ||||
| wordMute: "ワードミュート" | ||||
| userSaysSomething: "{name}が何かを言いました" | ||||
| makeActive: "アクティブにする" | ||||
| display: "表示" | ||||
| copy: "コピー" | ||||
| metrics: "メトリクス" | ||||
| overview: "概要" | ||||
| logs: "ログ" | ||||
| delayed: "遅延" | ||||
| database: "データベース" | ||||
| channel: "チャンネル" | ||||
| create: "作成" | ||||
| notificationSetting: "通知設定" | ||||
| notificationSettingDesc: "表示する通知の種別を選択してください。" | ||||
| useGlobalSetting: "グローバル設定を使う" | ||||
| useGlobalSettingDesc: "オンにすると、アカウントの通知設定が使用されます。オフにすると、個別に設定できるようになります。" | ||||
| other: "その他" | ||||
| regenerateLoginToken: "ログイントークンを再生成" | ||||
| regenerateLoginTokenDescription: "ログインに使用される内部トークンを再生成します。通常この操作を行う必要はありません。再生成すると、全てのデバイスでログアウトされます。" | ||||
| setMultipleBySeparatingWithSpace: "スペースで区切って複数設定できます。" | ||||
| fileIdOrUrl: "ファイルIDまたはURL" | ||||
| chatOpenBehavior: "チャットを開くときの動作" | ||||
| behavior: "動作" | ||||
| sample: "サンプル" | ||||
| abuseReports: "通報" | ||||
| reportAbuse: "通報" | ||||
| reportAbuseOf: "{name}を通報する" | ||||
| fillAbuseReportDescription: "通報理由の詳細を記入してください。対象のノートがある場合はそのURLも記入してください。" | ||||
| abuseReported: "内容が送信されました。ご報告ありがとうございました。" | ||||
| send: "送信" | ||||
| abuseMarkAsResolved: "対応済みにする" | ||||
| openInNewTab: "新しいタブで開く" | ||||
| openInSideView: "サイドビューで開く" | ||||
| defaultNavigationBehaviour: "デフォルトのナビゲーション" | ||||
| editTheseSettingsMayBreakAccount: "これらの設定を編集するとアカウントが破損する可能性があります。" | ||||
| instanceTicker: "ノートのインスタンス情報" | ||||
| waitingFor: "{x}を待っています" | ||||
| random: "ランダム" | ||||
| system: "システム" | ||||
| switchUi: "UI切り替え" | ||||
| desktop: "デスクトップ" | ||||
| clip: "クリップ" | ||||
| createNew: "新規作成" | ||||
| optional: "任意" | ||||
| createNewClip: "新しいクリップを作成" | ||||
| public: "パブリック" | ||||
| i18nInfo: "Misskeyは有志によって様々な言語に翻訳されています。{link}で翻訳に協力できます。" | ||||
| manageAccessTokens: "アクセストークンの管理" | ||||
| accountInfo: "アカウント情報" | ||||
| notesCount: "ノートの数" | ||||
| repliesCount: "返信した数" | ||||
| renotesCount: "Renoteした数" | ||||
| repliedCount: "返信された数" | ||||
| renotedCount: "Renoteされた数" | ||||
| followingCount: "フォロー数" | ||||
| followersCount: "フォロワー数" | ||||
| sentReactionsCount: "リアクションした数" | ||||
| receivedReactionsCount: "リアクションされた数" | ||||
| pollVotesCount: "アンケートに投票した数" | ||||
| pollVotedCount: "アンケートに投票された数" | ||||
| yes: "はい" | ||||
| no: "いいえ" | ||||
| driveFilesCount: "ドライブのファイル数" | ||||
| driveUsage: "ドライブ使用量" | ||||
| noCrawle: "クローラーによるインデックスを拒否" | ||||
| noCrawleDescription: "検索エンジンにあなたのユーザーページ、ノート、Pagesなどのコンテンツを登録(インデックス)しないよう要請します。" | ||||
| lockedAccountInfo: "フォローを承認制にしても、ノートの公開範囲を「フォロワー」にしない限り、誰でもあなたのノートを見ることができます。" | ||||
| alwaysMarkSensitive: "デフォルトでメディアを閲覧注意にする" | ||||
| loadRawImages: "添付画像のサムネイルをオリジナル画質にする" | ||||
| disableShowingAnimatedImages: "アニメーション画像を再生しない" | ||||
| verificationEmailSent: "確認のメールを送信しました。メールに記載されたリンクにアクセスして、設定を完了してください。" | ||||
| notSet: "未設定" | ||||
| emailVerified: "メールアドレスが確認されました" | ||||
| noteFavoritesCount: "お気に入りノートの数" | ||||
| pageLikesCount: "Pageにいいねした数" | ||||
| pageLikedCount: "Pageにいいねされた数" | ||||
| reversiCount: "リバーシの対局数" | ||||
| contact: "連絡先" | ||||
| useSystemFont: "システムのデフォルトのフォントを使う" | ||||
| clips: "クリップ" | ||||
| experimentalFeatures: "実験的機能" | ||||
| developer: "開発者" | ||||
| makeExplorable: "アカウントを見つけやすくする" | ||||
| makeExplorableDescription: "オフにすると、「みつける」にアカウントが載らなくなります。" | ||||
| showGapBetweenNotesInTimeline: "タイムラインのノートを離して表示" | ||||
| duplicate: "複製" | ||||
| left: "左" | ||||
| center: "中央" | ||||
| wide: "広い" | ||||
| narrow: "狭い" | ||||
| reloadToApplySetting: "設定はページリロード後に反映されます。今すぐリロードしますか?" | ||||
|  | ||||
| _aboutMisskey: | ||||
|   about: "Misskeyはsyuiloによって2014年から開発されている、オープンソースのソフトウェアです。" | ||||
|   contributors: "主なコントリビューター" | ||||
|   allContributors: "全てのコントリビューター" | ||||
|   source: "ソースコード" | ||||
|   translation: "Misskeyを翻訳" | ||||
|   donate: "Misskeyに寄付" | ||||
|   morePatrons: "他にも多くの方が支援してくれています。ありがとうございます🥰" | ||||
|   patrons: "支援者" | ||||
|  | ||||
| _nsfw: | ||||
|   respect: "閲覧注意のメディアは隠す" | ||||
|   ignore: "閲覧注意のメディアを隠さない" | ||||
|   force: "常にメディアを隠す" | ||||
|  | ||||
| _mfm: | ||||
|   cheatSheet: "MFMチートシート" | ||||
|   intro: "MFMは、Misskey内の様々な場所で使用できる専用のマークアップ言語です。ここでは、MFMで使用可能な構文一覧が確認できます。" | ||||
|   dummy: "MisskeyでFediverseの世界が広がります" | ||||
|   mention: "メンション" | ||||
|   mentionDescription: "アットマーク + ユーザー名で、特定のユーザーを示すことができます。" | ||||
|   hashtag: "ハッシュタグ" | ||||
|   hashtagDescription: "ナンバーサイン + タグで、ハッシュタグを示すことができます。" | ||||
|   url: "URL" | ||||
|   urlDescription: "URLを示すことができます。" | ||||
|   link: "リンク" | ||||
|   linkDescription: "文章の特定の範囲を、URLに紐づけることができます。" | ||||
|   bold: "太字" | ||||
|   boldDescription: "文字を太く表示して強調することができます。" | ||||
|   small: "目立たなく" | ||||
|   smallDescription: "内容を小さく・薄く表示させることができます。" | ||||
|   center: "中央寄せ" | ||||
|   centerDescription: "内容を中央寄せで表示させることができます。" | ||||
|   inlineCode: "コード(インライン)" | ||||
|   inlineCodeDescription: "プログラムなどのコードをインラインでシンタックスハイライトします。" | ||||
|   blockCode: "コード(ブロック)" | ||||
|   blockCodeDescription: "複数行のプログラムなどのコードをブロックでシンタックスハイライトします。" | ||||
|   inlineMath: "数式(インライン)" | ||||
|   inlineMathDescription: "数式(KaTeX)をインラインで表示します。" | ||||
|   blockMath: "数式(ブロック)" | ||||
|   blockMathDescription: "複数行の数式(KaTeX)をブロックで表示します。" | ||||
|   quote: "引用" | ||||
|   quoteDescription: "内容が引用であることを示すことができます。" | ||||
|   emoji: "カスタム絵文字" | ||||
|   emojiDescription: "コロンでカスタム絵文字名を囲むと、カスタム絵文字を表示させることができます。" | ||||
|   search: "検索" | ||||
|   searchDescription: "入力済み検索ボックスを表示させることができます。" | ||||
|   flip: "反転" | ||||
|   flipDescription: "内容を上下または左右に反転させます。" | ||||
|   jelly: "アニメーション(びよんびよん)" | ||||
|   jellyDescription: "びよんびよんするアニメーションを与えます。" | ||||
|   tada: "アニメーション(じゃーん)" | ||||
|   tadaDescription: "ジャーン!という感じのアニメーションを与えます。" | ||||
|   jump: "アニメーション(ジャンプ)" | ||||
|   jumpDescription: "飛び跳ねるようなアニメーションを与えます。" | ||||
|   bounce: "アニメーション(バウンド)" | ||||
|   bounceDescription: "ぽよんぽよん弾むようなアニメーションを与えます。" | ||||
|   shake: "アニメーション(ぶるぶる)" | ||||
|   shakeDescription: "ぶるぶるするアニメーションを与えます。" | ||||
|   twitch: "アニメーション(ブレ)" | ||||
|   twitchDescription: "激しくブレるアニメーションを与えます。" | ||||
|   spin: "アニメーション(回転)" | ||||
|   spinDescription: "回転するアニメーションを与えます。" | ||||
|  | ||||
| _reversi: | ||||
|   reversi: "リバーシ" | ||||
|   gameSettings: "対局の設定" | ||||
|   chooseBoard: "ボードを選択" | ||||
|   blackOrWhite: "先行/後攻" | ||||
|   blackIs: "{name}が黒(先行)" | ||||
|   rules: "ルール" | ||||
|   botSettings: "Botのオプション" | ||||
|   thisGameIsStartedSoon: "対局は数秒後に開始されます" | ||||
|   waitingForOther: "相手の準備が完了するのを待っています" | ||||
|   waitingForMe: "あなたの準備が完了するのを待っています" | ||||
|   waitingBoth: "準備してください" | ||||
|   ready: "準備完了" | ||||
|   cancelReady: "準備を再開" | ||||
|   opponentTurn: "相手のターンです" | ||||
|   myTurn: "あなたのターンです" | ||||
|   turnOf: "{name}のターンです" | ||||
|   pastTurnOf: "{name}のターン" | ||||
|   surrender: "投了" | ||||
|   surrendered: "投了により" | ||||
|   drawn: "引き分け" | ||||
|   won: "{name}の勝ち" | ||||
|   black: "黒" | ||||
|   white: "白" | ||||
|   total: "合計" | ||||
|   turnCount: "{count}ターン目" | ||||
|   myGames: "自分の対局" | ||||
|   allGames: "みんなの対局" | ||||
|   ended: "終了" | ||||
|   playing: "対局中" | ||||
|   isLlotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   loopedMap: "ループマップ" | ||||
|   canPutEverywhere: "どこでも置けるモード" | ||||
|  | ||||
| _instanceTicker: | ||||
|   none: "表示しない" | ||||
|   remote: "リモートユーザーに表示" | ||||
|   always: "常に表示" | ||||
|  | ||||
| _serverDisconnectedBehavior: | ||||
|   reload: "自動でリロード" | ||||
|   dialog: "ダイアログで警告" | ||||
|   quiet: "控えめに警告" | ||||
|  | ||||
| _channel: | ||||
|   create: "チャンネルを作成" | ||||
|   edit: "チャンネルを編集" | ||||
|   setBanner: "バナーを設定" | ||||
|   removeBanner: "バナーを削除" | ||||
|   featured: "トレンド" | ||||
|   owned: "管理中" | ||||
|   following: "フォロー中" | ||||
|   usersCount: "{n}人が参加中" | ||||
|   notesCount: "{n}投稿があります" | ||||
|  | ||||
| _sidebar: | ||||
|   full: "フル" | ||||
|   icon: "アイコン" | ||||
|   hide: "隠す" | ||||
|  | ||||
| _wordMute: | ||||
|   muteWords: "ミュートするワード" | ||||
|   muteWordsDescription: "スペースで区切るとAND指定になり、改行で区切るとOR指定になります。" | ||||
|   muteWordsDescription2: "キーワードをスラッシュで囲むと正規表現になります。" | ||||
|   softDescription: "指定した条件のノートをタイムラインから隠します。" | ||||
|   hardDescription: "指定した条件のノートをタイムラインに追加しないようにします。追加されなかったノートは、条件を変更しても除外されたままになります。" | ||||
|   soft: "ソフト" | ||||
|   hard: "ハード" | ||||
|   mutedNotes: "ミュートされたノート" | ||||
|  | ||||
| _theme: | ||||
|   explore: "テーマを探す" | ||||
| @@ -513,8 +811,74 @@ _theme: | ||||
|   manage: "テーマの管理" | ||||
|   code: "テーマコード" | ||||
|   installed: "{name}をインストールしました" | ||||
|   installedThemes: "インストールされたテーマ" | ||||
|   builtinThemes: "標準のテーマ" | ||||
|   alreadyInstalled: "そのテーマは既にインストールされています" | ||||
|   invalid: "テーマの形式が間違っています" | ||||
|   make: "テーマを作る" | ||||
|   base: "ベース" | ||||
|   addConstant: "定数を追加" | ||||
|   constant: "定数" | ||||
|   defaultValue: "デフォルト値" | ||||
|   color: "色" | ||||
|   refProp: "プロパティを参照" | ||||
|   refConst: "定数を参照" | ||||
|   key: "キー" | ||||
|   func: "関数" | ||||
|   funcKind: "関数の種類" | ||||
|   argument: "引数" | ||||
|   basedProp: "元にするプロパティの名前" | ||||
|   alpha: "不透明度" | ||||
|   darken: "暗さ" | ||||
|   lighten: "明るさ" | ||||
|   inputConstantName: "定数名を入力してください" | ||||
|   importInfo: "ここにテーマコードを貼り付けて、エディターにインポートできます" | ||||
|   deleteConstantConfirm: "定数 {const} を削除しても良いですか?" | ||||
|  | ||||
|   keys: | ||||
|     accent: "アクセント" | ||||
|     bg: "背景" | ||||
|     fg: "文字" | ||||
|     focus: "フォーカス" | ||||
|     indicator: "インジケーター" | ||||
|     panel: "パネル" | ||||
|     shadow: "影" | ||||
|     header: "ヘッダー" | ||||
|     navBg: "サイドバーの背景" | ||||
|     navFg: "サイドバーの文字" | ||||
|     navHoverFg: "サイドバー文字(ホバー)" | ||||
|     navActive: "サイドバー文字(アクティブ)" | ||||
|     navIndicator: "サイドバーのインジケーター" | ||||
|     link: "リンク" | ||||
|     hashtag: "ハッシュタグ" | ||||
|     mention: "メンション" | ||||
|     mentionMe: "あなた宛てメンション" | ||||
|     renote: "Renote" | ||||
|     modalBg: "モーダルの背景" | ||||
|     divider: "分割線" | ||||
|     scrollbarHandle: "スクロールバーの取っ手" | ||||
|     scrollbarHandleHover: "スクロールバーの取っ手(ホバー)" | ||||
|     dateLabelFg: "日付ラベルの文字" | ||||
|     infoBg: "情報の背景" | ||||
|     infoFg: "情報の文字" | ||||
|     infoWarnBg: "警告の背景" | ||||
|     infoWarnFg: "警告の文字" | ||||
|     cwBg: "CW ボタンの背景" | ||||
|     cwFg: "CW ボタンの文字" | ||||
|     cwHoverBg: "CW ボタンの背景 (ホバー)" | ||||
|     toastBg: "通知トーストの背景" | ||||
|     toastFg: "通知トーストの文字" | ||||
|     buttonBg: "ボタンの背景" | ||||
|     buttonHoverBg: "ボタンの背景 (ホバー)" | ||||
|     inputBorder: "入力ボックスの縁取り" | ||||
|     listItemHoverBg: "リスト項目の背景 (ホバー)" | ||||
|     driveFolderBg: "ドライブフォルダーの背景" | ||||
|     wallpaperOverlay: "壁紙のオーバーレイ" | ||||
|     badge: "バッジ" | ||||
|     messageBg: "チャットの背景" | ||||
|     accentDarken: "アクセント (暗め)" | ||||
|     accentLighten: "アクセント (明るめ)" | ||||
|     fgHighlighted: "強調された文字" | ||||
|  | ||||
| _sfx: | ||||
|   note: "ノート" | ||||
| @@ -523,6 +887,9 @@ _sfx: | ||||
|   chat: "チャット" | ||||
|   chatBg: "チャット(バックグラウンド)" | ||||
|   antenna: "アンテナ受信" | ||||
|   channel: "チャンネル通知" | ||||
|   reversiPutBlack: "リバーシ: 黒が打ったとき" | ||||
|   reversiPutWhite: "リバーシ: 白が打ったとき" | ||||
|  | ||||
| _ago: | ||||
|   unknown: "謎" | ||||
| @@ -603,6 +970,8 @@ _permissions: | ||||
|   "write:page-likes": "ページのいいねを操作する" | ||||
|   "read:user-groups": "ユーザーグループを見る" | ||||
|   "write:user-groups": "ユーザーグループを操作する" | ||||
|   "read:channels": "チャンネルを見る" | ||||
|   "write:channels": "チャンネルを操作する" | ||||
|  | ||||
| _auth: | ||||
|   shareAccess: "「{name}」がアカウントにアクセスすることを許可しますか?" | ||||
| @@ -638,13 +1007,17 @@ _widgets: | ||||
|   rss: "RSSリーダー" | ||||
|   activity: "アクティビティ" | ||||
|   photos: "フォト" | ||||
|   digitalClock: "デジタル時計" | ||||
|   federation: "連合" | ||||
|   postForm: "投稿フォーム" | ||||
|   slideshow: "スライドショー" | ||||
|   button: "ボタン" | ||||
|  | ||||
| _cw: | ||||
|   hide: "隠す" | ||||
|   show: "もっと見る" | ||||
|   chars: "{count}文字" | ||||
|   files: "{count}ファイル" | ||||
|   poll: "アンケート" | ||||
|  | ||||
| _poll: | ||||
|   noOnlyOneChoice: "選択肢は最低2つ必要です" | ||||
| @@ -679,10 +1052,12 @@ _visibility: | ||||
|   specified: "ダイレクト" | ||||
|   specifiedDescription: "指定したユーザーのみに公開" | ||||
|   localOnly: "ローカルのみ" | ||||
|   localOnlyDescription: "リモートユーザーには非公開" | ||||
|  | ||||
| _postForm: | ||||
|   replyPlaceholder: "このノートに返信..." | ||||
|   quotePlaceholder: "このノートを引用..." | ||||
|   channelPlaceholder: "チャンネルに投稿..." | ||||
|   _placeholders: | ||||
|     a: "いまどうしてる?" | ||||
|     b: "何かありましたか?" | ||||
| @@ -696,9 +1071,13 @@ _profile: | ||||
|   username: "ユーザー名" | ||||
|   description: "自己紹介" | ||||
|   youCanIncludeHashtags: "ハッシュタグを含めることができます。" | ||||
|   metadata: "補足情報" | ||||
|   metadata: "追加情報" | ||||
|   metadataEdit: "追加情報を編集" | ||||
|   metadataDescription: "プロフィールに表として4つまでの追加情報を表示することができます。" | ||||
|   metadataLabel: "ラベル" | ||||
|   metadataContent: "内容" | ||||
|   changeAvatar: "アバター画像を変更" | ||||
|   changeBanner: "バナー画像を変更" | ||||
|  | ||||
| _exportOrImport: | ||||
|   allNotes: "全てのノート" | ||||
| @@ -811,6 +1190,7 @@ _pages: | ||||
|   created: "ページを作成しました" | ||||
|   updated: "ページを更新しました" | ||||
|   deleted: "ページを削除しました" | ||||
|   pageSetting: "ページ設定" | ||||
|   nameAlreadyExists: "指定されたページURLは既に存在しています" | ||||
|   invalidNameTitle: "不正なページURLです" | ||||
|   invalidNameText: "空白でないか確認してください" | ||||
| @@ -821,7 +1201,9 @@ _pages: | ||||
|   unlike: "いいね解除" | ||||
|   my: "自分のページ" | ||||
|   liked: "いいねしたページ" | ||||
|   featured: "人気" | ||||
|   inspector: "インスペクター" | ||||
|   contents: "コンテンツ" | ||||
|   content: "ページブロック" | ||||
|   variables: "変数" | ||||
|   title: "タイトル" | ||||
| @@ -882,6 +1264,12 @@ _pages: | ||||
|       width: "幅" | ||||
|       height: "高さ" | ||||
|  | ||||
|     note: "ノート埋め込み" | ||||
|     _note: | ||||
|       id: "ノートID" | ||||
|       idDescription: "ノートURLをペーストして設定することもできます。" | ||||
|       detailed: "詳細な表示" | ||||
|  | ||||
|     switch: "スイッチ" | ||||
|     _switch: | ||||
|       name: "変数名" | ||||
| @@ -1101,3 +1489,54 @@ _relayStatus: | ||||
|   requesting: "承認待ち" | ||||
|   accepted: "承認済み" | ||||
|   rejected: "拒否済み" | ||||
|  | ||||
| _notification: | ||||
|   fileUploaded: "ファイルがアップロードされました" | ||||
|   youGotMention: "{name}からのメンション" | ||||
|   youGotReply: "{name}からのリプライ" | ||||
|   youGotQuote: "{name}による引用" | ||||
|   youRenoted: "{name}がRenoteしました" | ||||
|   youGotPoll: "{name}が投票しました" | ||||
|   youGotMessagingMessageFromUser: "{name}からのチャットがあります" | ||||
|   youGotMessagingMessageFromGroup: "{name}のチャットがあります" | ||||
|   youWereFollowed: "フォローされました" | ||||
|   youReceivedFollowRequest: "フォローリクエストが来ました" | ||||
|   yourFollowRequestAccepted: "フォローリクエストが承認されました" | ||||
|   youWereInvitedToGroup: "グループに招待されました" | ||||
|  | ||||
|   _types: | ||||
|     all: "すべて" | ||||
|     follow: "フォロー" | ||||
|     mention: "メンション" | ||||
|     reply: "リプライ" | ||||
|     renote: "Renote" | ||||
|     quote: "引用" | ||||
|     reaction: "リアクション" | ||||
|     pollVote: "アンケートに投票された" | ||||
|     receiveFollowRequest: "フォロー申請を受け取った" | ||||
|     followRequestAccepted: "フォローが受理された" | ||||
|     groupInvited: "グループに招待された" | ||||
|     app: "連携アプリからの通知" | ||||
|  | ||||
| _deck: | ||||
|   alwaysShowMainColumn: "常にメインカラムを表示" | ||||
|   columnAlign: "カラムの寄せ" | ||||
|   columnMargin: "カラム間のマージン" | ||||
|   columnHeaderHeight: "カラムのヘッダー幅" | ||||
|   addColumn: "カラムを追加" | ||||
|   swapLeft: "左に移動" | ||||
|   swapRight: "右に移動" | ||||
|   swapUp: "上に移動" | ||||
|   swapDown: "下に移動" | ||||
|   stackLeft: "左に重ねる" | ||||
|   popRight: "右に出す" | ||||
|  | ||||
|   _columns: | ||||
|     main: "メイン" | ||||
|     widgets: "ウィジェット" | ||||
|     notifications: "通知" | ||||
|     tl: "タイムライン" | ||||
|     antenna: "アンテナ" | ||||
|     list: "リスト" | ||||
|     mentions: "あなた宛て" | ||||
|     direct: "ダイレクト" | ||||
|   | ||||
| @@ -1,12 +1,12 @@ | ||||
| --- | ||||
| _lang_: "日本語 (関西弁)" | ||||
| introMisskey: "ようこそ!Misskeyは、オープンソースの分散型マイクロブログサービスやねん。\n「ノート」を作成しぃ、いま起こっとることを共有したり、あんたについて皆に発信しよう📡\n「リアクション」機能で、皆のノートに素はよ反応を追加することもできます✌\n新しい世界を探検しよう🚀" | ||||
| introMisskey: "ようこそ!Misskeyってのは、オープンソースの分散型マイクロブログサービスやねん。\n「ノート」を作成し、いま起こっとることを共有したり、あんたんこととか皆に伝えていこう📡\n「リアクション」機能で、皆のノートに素はよ反応を追加することもできるんやで✌\n新しい世界を探検してみらん?🚀" | ||||
| monthAndDay: "{month}月 {day}日" | ||||
| search: "探す" | ||||
| notifications: "通知" | ||||
| username: "ユーザー名" | ||||
| password: "パスワード" | ||||
| fetchingAsApObject: "連合に照会中" | ||||
| fetchingAsApObject: "今ちと連合に照会しとるで" | ||||
| ok: "おっけー" | ||||
| gotIt: "ほい" | ||||
| cancel: "やめとくわ" | ||||
| @@ -16,60 +16,96 @@ noNotes: "ノートはあらへん" | ||||
| noNotifications: "通知はあらへん" | ||||
| instance: "インスタンス" | ||||
| settings: "設定" | ||||
| basicSettings: "基本設定" | ||||
| otherSettings: "その他の設定" | ||||
| openInWindow: "ウィンドウで開いてや" | ||||
| profile: "プロフィール" | ||||
| timeline: "タイムライン" | ||||
| noAccountDescription: "自己紹介はあらへん" | ||||
| login: "ログイン" | ||||
| loggingIn: "ログインしとります" | ||||
| loggingIn: "ログインしよるで" | ||||
| logout: "ログアウト" | ||||
| signup: "新規登録" | ||||
| uploading: "アップロードしとります" | ||||
| save: "保存" | ||||
| uploading: "アップロードしよるで" | ||||
| save: "とっとく" | ||||
| users: "ユーザー" | ||||
| addUser: "ユーザー増やす" | ||||
| addUser: "ユーザーを追加や" | ||||
| favorite: "お気に入り" | ||||
| favorites: "お気に入り" | ||||
| unfavorite: "お気に入りやめる" | ||||
| pin: "ピン留め" | ||||
| unpin: "ピン留めやめる" | ||||
| unfavorite: "やっぱ気に入らん" | ||||
| favorited: "お気に入りに登録したで" | ||||
| alreadyFavorited: "もうお気に入りに入れとるがな。" | ||||
| cantFavorite: "アカン、お気に入り登録できへんかったで。" | ||||
| pin: "ピン留めしとく" | ||||
| unpin: "やっぱピン留めせん" | ||||
| copyContent: "内容をコピー" | ||||
| copyLink: "リンクをコピー" | ||||
| delete: "ほかす" | ||||
| deleteAndEdit: "ほかして直す" | ||||
| deleteAndEditConfirm: "このノートをほかしてもっかい直す?このノートへのリアクション、Remote、返信も全部消えんで" | ||||
| deleteAndEditConfirm: "このノートをほかしてもっかい直す?このノートへのリアクション、Renote、返信も全部消えるんやけどそれでもええん?" | ||||
| addToList: "リストに入れたる" | ||||
| sendMessage: "メッセージを送る" | ||||
| copyUsername: "ユーザー名をコピー" | ||||
| searchUser: "ユーザーを検索" | ||||
| reply: "返す" | ||||
| loadMore: "もっとあるやろ!" | ||||
| youGotNewFollower: "フォローされたで" | ||||
| receiveFollowRequest: "フォローリクエストされたで" | ||||
| followRequestAccepted: "フォローが承認されたで" | ||||
| mention: "メンション" | ||||
| mentions: "あんた宛て" | ||||
| directNotes: "ダイレクト投稿" | ||||
| importAndExport: "インポートとエクスポート" | ||||
| import: "インポート" | ||||
| export: "エクスポート" | ||||
| files: "ファイル" | ||||
| download: "ダウンロード" | ||||
| driveFileDeleteConfirm: "ファイル「{name}」を消してしもうてええか?このファイルを添付したノートも消えてまうで。" | ||||
| unfollowConfirm: "{name}のフォローを解除してもええんか?" | ||||
| exportRequested: "エクスポートしてな、ってリクエストしたけど、これ多分めっちゃ時間かかるで。エクスポート終わったら「ドライブ」に突っ込んどくで。" | ||||
| importRequested: "インポートしてな、ってリクエストしたけど、これ多分めっちゃ時間かかるで。" | ||||
| lists: "リスト" | ||||
| noLists: "リストはあらへん" | ||||
| noLists: "リストなんてあらへんで" | ||||
| note: "ノート" | ||||
| notes: "ノート" | ||||
| following: "フォロー" | ||||
| followers: "フォロワー" | ||||
| followsYou: "フォローされとるで" | ||||
| error: "問題が発生してん" | ||||
| createList: "リスト作る" | ||||
| manageLists: "リストの管理" | ||||
| error: "エラー" | ||||
| somethingHappened: "なんかアカンことが起こったで" | ||||
| retry: "もっぺんやる?" | ||||
| pageLoadError: "ページの読み込みに失敗してしもうたで…" | ||||
| pageLoadErrorDescription: "これは普通、ネットワークかブラウザキャッシュが原因やからね。キャッシュをクリアするか、もうちっとだけ待ってくれへんか?" | ||||
| enterListName: "リスト名を入れてや" | ||||
| privacy: "プライバシーってなんや?オカンの年齢か?" | ||||
| makeFollowManuallyApprove: "他人のフォローは許可してからや!" | ||||
| privacy: "プライバシーってなんぞや?" | ||||
| makeFollowManuallyApprove: "他人からのフォローは自分が決める" | ||||
| defaultNoteVisibility: "もとからの公開範囲" | ||||
| follow: "フォロー" | ||||
| followRequest: "フォロー許してくれや!言うてみる" | ||||
| followRequests: "フォロー許してくれや!" | ||||
| followRequest: "フォローを頼む" | ||||
| followRequests: "フォローを頼む" | ||||
| unfollow: "フォローやめる" | ||||
| followRequestPending: "フォロー許してくれるん待っとる" | ||||
| enterEmoji: "絵文字を入れてや" | ||||
| renote: "Renote" | ||||
| unrenote: "Renoteやめる" | ||||
| renoted: "Renoteしたで。" | ||||
| cantRenote: "この投稿はRenoteできへんらしい。" | ||||
| cantReRenote: "すまん、今このRenoteにRenoteはできへんのや。" | ||||
| quote: "引用" | ||||
| pinnedNote: "ピン留めされとるノート" | ||||
| you: "あんた" | ||||
| clickToShow: "押してみ、見せたるわ" | ||||
| sensitive: "見たらあかんで" | ||||
| clickToShow: "押したら見えるようになるで" | ||||
| sensitive: "ちょっとアカンやつやで" | ||||
| add: "増やす" | ||||
| reaction: "リアクション" | ||||
| attachCancel: "くっつけるのやめよか" | ||||
| markAsSensitive: "ちょっと見せられへんわ" | ||||
| unmarkAsSensitive: "別にええんじゃね?" | ||||
| reactionSettingDescription: "リアクションピッカーに出しとくリアクションを選んでや。" | ||||
| reactionSettingDescription2: "ドラッグして並び替え、クリックして削除、+を押すと追加できるで。" | ||||
| rememberNoteVisibility: "公開範囲覚えといて" | ||||
| attachCancel: "やっぱ添付やめてくれん?" | ||||
| markAsSensitive: "ちょっとこれはアカン" | ||||
| unmarkAsSensitive: "そこまでアカンことないやろ" | ||||
| enterFileName: "ファイル名を入れてや" | ||||
| mute: "ミュート" | ||||
| unmute: "ミュートやめたる" | ||||
| @@ -77,45 +113,362 @@ block: "ブロック" | ||||
| unblock: "ブロックやめたる" | ||||
| suspend: "凍結" | ||||
| unsuspend: "溶かす" | ||||
| blockConfirm: "ブロックしてもええんか?" | ||||
| unblockConfirm: "ブロックやめたるってほんまか?" | ||||
| suspendConfirm: "凍結してしもうてええか?" | ||||
| unsuspendConfirm: "解凍するけどええか?" | ||||
| selectList: "リストを選ぶ" | ||||
| selectAntenna: "アンテナを選ぶ" | ||||
| selectWidget: "ウィジェットを選ぶ" | ||||
| editWidgets: "ウィジェットをいじる" | ||||
| editWidgetsExit: "編集終ったで" | ||||
| customEmojis: "カスタム絵文字" | ||||
| emoji: "絵文字" | ||||
| emojiName: "絵文字名" | ||||
| emojiUrl: "絵文字画像URL" | ||||
| addEmoji: "絵文字を追加" | ||||
| settingGuide: "ええ感じの設定" | ||||
| cacheRemoteFiles: "リモートのファイルをキャッシュする" | ||||
| cacheRemoteFilesDescription: "この設定をチャラにすると、リモートファイルをキャッシュせず直リンクするようになります。サーバーのストレージを節約できますが、サムネイルが生成されへんので通信量が増加します。" | ||||
| loginFailed: "ログインに失敗してん" | ||||
| cacheRemoteFilesDescription: "この設定を切っとくと、リモートファイルをキャッシュせず直リンクするようになってしまうんやで? サーバーのストレージは節約できるんやけど、かわりにサムネイルが作られんくなるから通信量が増えるで?" | ||||
| flagAsBot: "Botやで" | ||||
| flagAsBotDescription: "もしこのアカウントがプログラムによって運用されるんやったら、このフラグをオンにしてたのむで。オンにすると、反応の連鎖を防ぐためのフラグとして他の開発者に役立ったり、Misskeyのシステム上での扱いがBotに合ったもんになるんやで。" | ||||
| flagAsCat: "Catやで" | ||||
| flagAsCatDescription: "ワレ、猫ちゃんならこのフラグをつけてみ?" | ||||
| autoAcceptFollowed: "フォローしとるユーザーからのフォローリクエストには勝手に許可しとくで。" | ||||
| addAcount: "アカウント追加" | ||||
| loginFailed: "ログインに失敗してしもうた…" | ||||
| showOnRemote: "リモートで見る" | ||||
| general: "全般" | ||||
| wallpaper: "壁紙" | ||||
| removeWallpaper: "壁紙ほかす" | ||||
| youHaveNoLists: "リストはあらへん" | ||||
| setWallpaper: "壁紙を設定" | ||||
| removeWallpaper: "壁紙を削除" | ||||
| searchWith: "検索: {q}" | ||||
| youHaveNoLists: "リストがあらへんで?" | ||||
| followConfirm: "{name}をフォローしてええか?" | ||||
| proxyAccount: "プロキシアカウント" | ||||
| proxyAccountDescription: "プロキシアカウントは、代わりにフォローしてくれるアカウントや。例えば、551に豚まんが無いときやったり、ユーザーがリモートユーザーをアカウントに入れたとき、リストに入れられたユーザーが誰からもフォローされてないと寂しいやん。寂しいし、アクティビティも配達されへんから、プロキシアカウントがフォローしてくれるで。ええやつやん…" | ||||
| host: "ホスト" | ||||
| selectUser: "ユーザーを選ぶ" | ||||
| recipient: "宛先" | ||||
| annotation: "注釈" | ||||
| federation: "連合" | ||||
| instances: "インスタンス" | ||||
| registeredAt: "初観測" | ||||
| latestRequestSentAt: "ちょっと前のリクエスト送信" | ||||
| latestRequestReceivedAt: "ちょっと前のリクエスト受信" | ||||
| latestStatus: "ちょっと前のステータス" | ||||
| storageUsage: "ストレージ使うた量" | ||||
| charts: "チャート" | ||||
| perHour: "1時間ごと" | ||||
| perDay: "1日ごと" | ||||
| stopActivityDelivery: "アクティビティの配送をやめる" | ||||
| blockThisInstance: "このインスタンスをブロック" | ||||
| operations: "操作" | ||||
| software: "ソフトウェア" | ||||
| version: "バージョン" | ||||
| metadata: "メタデータ" | ||||
| withNFiles: "{n}個のファイル" | ||||
| monitor: "モニター" | ||||
| jobQueue: "ジョブキュー" | ||||
| cpuAndMemory: "CPUとメモリ" | ||||
| network: "ネットワーク" | ||||
| disk: "ディスク" | ||||
| instanceInfo: "インスタンス情報" | ||||
| statistics: "統計" | ||||
| clearQueue: "キューにさいなら" | ||||
| clearQueueConfirmTitle: "キューをクリアしまっか?" | ||||
| clearQueueConfirmText: "未配達の投稿は配送されなくなるで。通常この操作を行う必要はあらへんや。" | ||||
| clearCachedFiles: "キャッシュにさいなら" | ||||
| clearCachedFilesConfirm: "キャッシュされとるリモートファイルを全部削除しまっか?" | ||||
| blockedInstances: "インスタンスブロック" | ||||
| blockedInstancesDescription: "ブロックしたいインスタンスのホストを改行で区切って設定してな。ブロックされてもうたインスタンスとはもう金輪際やり取りできひんくなるで。" | ||||
| muteAndBlock: "ミュートとブロック" | ||||
| mutedUsers: "ミュートしたユーザー" | ||||
| blockedUsers: "ブロックしたユーザー" | ||||
| noUsers: "ユーザーはおらへん" | ||||
| editProfile: "プロフィールをいじる" | ||||
| noteDeleteConfirm: "このノートを削除しまっか?" | ||||
| pinLimitExceeded: "これ以上ピン留めできひん" | ||||
| intro: "Misskeyのインストールが完了してん!管理者アカウントを作ってや。" | ||||
| done: "でけた" | ||||
| processing: "処理しとる" | ||||
| preview: "プレビュー" | ||||
| default: "デフォルト" | ||||
| noCustomEmojis: "絵文字はあらへん" | ||||
| noJobs: "ジョブはあらへん" | ||||
| federating: "連合しとる" | ||||
| blocked: "ブロックしとる" | ||||
| suspended: "配信せぇへん" | ||||
| all: "みな" | ||||
| subscribing: "購読しとる" | ||||
| publishing: "配信しとる" | ||||
| notResponding: "応答してへんで" | ||||
| instanceFollowing: "インスタンスのフォロー" | ||||
| instanceFollowers: "インスタンスのフォロワー\n" | ||||
| instanceUsers: "インスタンスのユーザー" | ||||
| changePassword: "パスワード変える" | ||||
| security: "セキュリティ" | ||||
| retypedNotMatch: "そやないねん。" | ||||
| currentPassword: "今のパスワード" | ||||
| newPassword: "今度のパスワード" | ||||
| newPasswordRetype: "今度のパスワード(もっぺん入れて)" | ||||
| attachFile: "ファイルくっつけて" | ||||
| more: "他ないんか!" | ||||
| featured: "ハイライト" | ||||
| usernameOrUserId: "ユーザー名かユーザーID" | ||||
| noSuchUser: "ユーザーが見つからへんで" | ||||
| lookup: "見てきて" | ||||
| announcements: "これ知っといてな" | ||||
| imageUrl: "画像URL" | ||||
| remove: "ほかす" | ||||
| removed: "削除したで!" | ||||
| removeAreYouSure: "「{x}」はなおしてしもてええか?" | ||||
| deleteAreYouSure: "「{x}」はなおしてしもてええか?" | ||||
| resetAreYouSure: "リセットしてええん?" | ||||
| saved: "保存したで!" | ||||
| messaging: "チャット" | ||||
| upload: "アップロード" | ||||
| fromDrive: "ドライブから" | ||||
| fromUrl: "URLから" | ||||
| uploadFromUrl: "URLアップロード" | ||||
| uploadFromUrlDescription: "このURLのファイルをアップロードしたいねん" | ||||
| uploadFromUrlRequested: "アップロードしたい言うといたで" | ||||
| uploadFromUrlMayTakeTime: "アップロード終わるんにちょい時間かかるかもしれへんわ。" | ||||
| explore: "みつける" | ||||
| games: "Misskey Games" | ||||
| messageRead: "もう読んだ" | ||||
| noMoreHistory: "これより過去の履歴はあらへんで" | ||||
| startMessaging: "チャットやるで" | ||||
| nUsersRead: "{n}人が読んでもうた" | ||||
| agreeTo: "{0}はええで" | ||||
| tos: "利用規約" | ||||
| start: "始める" | ||||
| home: "ホーム" | ||||
| remoteUserCaution: "リモートユーザーやから、ちゃんとした情報とちゃうで。" | ||||
| activity: "アクティビティ" | ||||
| images: "画像" | ||||
| birthday: "生まれた日" | ||||
| yearsOld: "{age}歳" | ||||
| registeredDate: "始めた日" | ||||
| location: "場所" | ||||
| theme: "テーマ" | ||||
| themeForLightMode: "ライトモードではこのテーマつこて" | ||||
| themeForDarkMode: "ダークモードではこのテーマつこて" | ||||
| light: "ライト" | ||||
| dark: "ダーク" | ||||
| lightThemes: "デイゲーム" | ||||
| darkThemes: "ナイトゲーム" | ||||
| syncDeviceDarkMode: "試合開始時間はデバイスのダークモードと一緒や" | ||||
| drive: "ドライブ" | ||||
| fileName: "ファイル名" | ||||
| selectFile: "ファイル選んでや" | ||||
| selectFiles: "ファイル選んでや" | ||||
| selectFolder: "フォルダ選んでや" | ||||
| selectFolders: "フォルダ選んでや" | ||||
| renameFile: "ファイル名をいらう" | ||||
| nsfw: "見たらあかんで" | ||||
| folderName: "フォルダー名" | ||||
| createFolder: "フォルダー作る" | ||||
| renameFolder: "フォルダー名を変える" | ||||
| deleteFolder: "フォルダーを消してまう" | ||||
| addFile: "ファイルを追加" | ||||
| emptyDrive: "ドライブにはなんも残っとらん" | ||||
| emptyFolder: "ふぉろだーにはなんも残っとらん" | ||||
| unableToDelete: "消そうおもってんけどな、あかんかったわ" | ||||
| inputNewFileName: "今度のファイル名は何にするん?" | ||||
| inputNewFolderName: "今度のフォルダ名は何にするん?" | ||||
| circularReferenceFolder: "移動先のフォルダーは、移動するフォルダーのサブフォルダーや。" | ||||
| hasChildFilesOrFolders: "このフォルダ、まだなんか入っとるから消されへん" | ||||
| copyUrl: "URLをコピー" | ||||
| rename: "名前を変えるで" | ||||
| avatar: "アイコン" | ||||
| banner: "バナー" | ||||
| nsfw: "ちょっとアカンやつやで" | ||||
| whenServerDisconnected: "サーバーとの接続が失くなってしもうたとき" | ||||
| disconnectedFromServer: "サーバーが機嫌悪いねん" | ||||
| reload: "リロード" | ||||
| doNothing: "何もせんとく" | ||||
| reloadConfirm: "リロードしてええか?" | ||||
| watch: "ウォッチ" | ||||
| unwatch: "ウォッチやめる" | ||||
| accept: "ええで" | ||||
| reject: "あかん" | ||||
| normal: "ええ感じ" | ||||
| instanceName: "インスタンス名" | ||||
| instanceDescription: "インスタンスの紹介" | ||||
| maintainerName: "管理者の名前" | ||||
| maintainerEmail: "管理者のメールアドレス" | ||||
| tosUrl: "利用規約のURL" | ||||
| thisYear: "今年" | ||||
| thisMonth: "今月" | ||||
| today: "今日" | ||||
| dayX: "{day}日" | ||||
| monthX: "{month}月" | ||||
| yearX: "{year}年" | ||||
| pages: "ページ" | ||||
| integration: "つないで" | ||||
| connectSerice: "つなげる" | ||||
| disconnectSerice: "切ってまう" | ||||
| enableLocalTimeline: "ローカルタイムラインを使えるようにする" | ||||
| enableGlobalTimeline: "グローバルタイムラインを使えるようにする" | ||||
| disablingTimelinesInfo: "ここらへんのタイムラインを使えんようにしてしもても、管理者とモデレーターは使えるままになってるで、そうやなかったら不便やからな。" | ||||
| registration: "登録" | ||||
| enableRegistration: "一見さんでも誰でもいらっしゃ~い" | ||||
| invite: "来てや" | ||||
| proxyRemoteFiles: "リモートのファイルをプロキシする" | ||||
| proxyRemoteFilesDescription: "この設定を入れると、保存しとらんかったり、お腹いっぱいになってしもたせいで保存できんかったリモートファイルをローカルでプロキシして、サムネイル作ってもらうことができるで。サーバーの腹具合には影響せんけどな。" | ||||
| driveCapacityPerLocalAccount: "ローカルユーザーひとりあたりのドライブ容量" | ||||
| driveCapacityPerRemoteAccount: "リモートユーザーひとりあたりのドライブ容量" | ||||
| inMb: "メガバイト単位" | ||||
| iconUrl: "アイコン画像のURL" | ||||
| bannerUrl: "バナー画像のURL" | ||||
| basicInfo: "基本情報" | ||||
| pinnedUsers: "ピン留めしたユーザー" | ||||
| pinnedUsersDescription: "「みつける」ページとかにピン留めしたいユーザーをここに書けばええんやで。他ん人との名前は改行で区切ればええんやで。" | ||||
| pinnedPages: "ピン留めページ" | ||||
| pinnedNotes: "ピン留めされとるノート" | ||||
| hcaptcha: "hCaptcha(キャプチャ)" | ||||
| enableHcaptcha: "hCaptcha(キャプチャ)をつけとく" | ||||
| hcaptchaSiteKey: "サイトキー" | ||||
| hcaptchaSecretKey: "シークレットキー" | ||||
| recaptcha: "reCAPTCHA" | ||||
| enableRecaptcha: "reCAPTCHA(リキャプチャ)を有効にする" | ||||
| recaptchaSiteKey: "サイトキー" | ||||
| recaptchaSecretKey: "シークレットキー" | ||||
| avoidMultiCaptchaConfirm: "ぎょうさんのCaptchaをつこてしまうと、仲良うせんことがあるんや。他のCaptchaをなおしとこか?別にキャンセルしてもろうたらCaptchaは消されへんで済むけど知らんで。" | ||||
| antennas: "アンテナ" | ||||
| manageAntennas: "アンテナいじる" | ||||
| name: "名前" | ||||
| antennaSource: "受信ソース(このソースは食われへん)" | ||||
| antennaKeywords: "受信キーワード" | ||||
| antennaExcludeKeywords: "除外キーワード" | ||||
| antennaKeywordsDescription: "スペースで区切ったるとAND指定で、改行で区切ったるとOR指定や" | ||||
| notifyAntenna: "新しいノートを追加すんで" | ||||
| withFileAntenna: "なんか添付されたノートだけ" | ||||
| serviceworker: "ServiceWorker" | ||||
| enableServiceworker: "ServiceWorkerをつこて" | ||||
| antennaUsersDescription: "ユーザー名を改行で区切ったってな" | ||||
| caseSensitive: "大文字と小文字は別もんや" | ||||
| withReplies: "返信も入れたって" | ||||
| connectedTo: "次のアカウントに繋がっとるで" | ||||
| notesAndReplies: "投稿と返信" | ||||
| withFiles: "ファイル付いとる" | ||||
| silence: "サイレンス" | ||||
| silenceConfirm: "サイレンスしよか?" | ||||
| unsilence: "サイレンスやめるで" | ||||
| unsilenceConfirm: "サイレンスやめよか?" | ||||
| popularUsers: "人気のユーザー" | ||||
| recentlyUpdatedUsers: "ちょっと前に投稿したばっかりのユーザー" | ||||
| recentlyRegisteredUsers: "ちょっと前に始めたばっかりのユーザー" | ||||
| recentlyDiscoveredUsers: "最近見っけたユーザー" | ||||
| exploreUsersCount: "{count}もユーザーおるで" | ||||
| exploreFediverse: "Fediverseを探ってみる" | ||||
| popularTags: "人気のタグ" | ||||
| userList: "リスト" | ||||
| about: "情報" | ||||
| aboutMisskey: "Misskeyってなんや?" | ||||
| administrator: "管理者" | ||||
| token: "トークン" | ||||
| twoStepAuthentication: "二段階認証" | ||||
| moderator: "モデレーター" | ||||
| nUsersMentioned: "{n}人が投稿" | ||||
| securityKey: "セキュリティキー" | ||||
| securityKeyName: "キーの名前" | ||||
| registerSecurityKey: "セキュリティキーを登録するで" | ||||
| lastUsed: "最後につこうた日" | ||||
| unregister: "登録やめる" | ||||
| passwordLessLogin: "パスワード無くてもログインできるようにする" | ||||
| resetPassword: "パスワードをリセット" | ||||
| newPasswordIs: "今度のパスワードは「{password}」や" | ||||
| reduceUiAnimation: "UIの動きやアニメーションを減らしてくれや。" | ||||
| share: "わけわけ" | ||||
| notFound: "見つからへんね" | ||||
| notFoundDescription: "指定されたURLに該当するページはあらへんやった。" | ||||
| uploadFolder: "とりあえずここへアップロード" | ||||
| cacheClear: "キャッシュをほかす" | ||||
| markAsReadAllNotifications: "通知はもう全て読んだわっ" | ||||
| markAsReadAllUnreadNotes: "投稿は全て読んだわっ" | ||||
| markAsReadAllTalkMessages: "チャットはもうぜんぶ読んだわっ" | ||||
| help: "ヘルプ" | ||||
| inputMessageHere: "ここにメッセージ書いてや" | ||||
| close: "さいなら" | ||||
| group: "グループ" | ||||
| groups: "グループ" | ||||
| createGroup: "グループを作るで" | ||||
| ownedGroups: "所有しとるグループ" | ||||
| joinedGroups: "参加しとるグループ" | ||||
| invites: "来てや" | ||||
| groupName: "グループ名" | ||||
| members: "メンバー" | ||||
| transfer: "譲渡" | ||||
| messagingWithUser: "ユーザーとチャット" | ||||
| messagingWithGroup: "グループでチャット" | ||||
| title: "タイトル" | ||||
| text: "テキスト" | ||||
| enable: "有効にするで" | ||||
| next: "次" | ||||
| retype: "もっかい入力" | ||||
| noteOf: "{user}のノート" | ||||
| inviteToGroup: "グループに招く" | ||||
| maxNoteTextLength: "ノートの文字数制限" | ||||
| quoteAttached: "引用付いとるで" | ||||
| quoteQuestion: "引用として添付してもええか?" | ||||
| noMessagesYet: "まだチャットはあらへんで" | ||||
| newMessageExists: "新しいメッセージがきたで" | ||||
| onlyOneFileCanBeAttached: "すまん、メッセージに添付できるファイルはひとつだけなんや。" | ||||
| signinRequired: "ログインしてくれへん?" | ||||
| invitations: "来てや" | ||||
| invitationCode: "招待コード" | ||||
| checking: "確認しとるで" | ||||
| available: "利用できる\n" | ||||
| unavailable: "利用できん" | ||||
| usernameInvalidFormat: "a~z、A~Z、0~9、_が使えるで" | ||||
| tooShort: "短すぎやろ!" | ||||
| tooLong: "長すぎやろ!" | ||||
| weakPassword: "弱いパスワード" | ||||
| normalPassword: "普通のパスワード" | ||||
| strongPassword: "ええ感じのパスワード" | ||||
| passwordMatched: "よし!一致や!" | ||||
| passwordNotMatched: "一致しとらんで?" | ||||
| signinWith: "{x}でログイン" | ||||
| or: "それか" | ||||
| uiLanguage: "UIの表示言語" | ||||
| groupInvited: "グループに招待されとるで" | ||||
| aboutX: "{x}について" | ||||
| useOsNativeEmojis: "OSネイティブの絵文字を使う" | ||||
| youHaveNoGroups: "グループがあらへんねぇ。" | ||||
| noHistory: "履歴はあらへんねぇ。" | ||||
| signinHistory: "ログイン履歴" | ||||
| doing: "やっとるがな" | ||||
| category: "カテゴリ" | ||||
| tags: "タグ" | ||||
| docSource: "このドキュメントのソース" | ||||
| createAccount: "アカウントを作成" | ||||
| existingAcount: "既存のアカウント" | ||||
| regenerate: "再生成" | ||||
| fontSize: "フォントサイズ" | ||||
| noFollowRequests: "フォロー申請はあらへんで" | ||||
| openImageInNewTab: "画像を新しいタブで開く" | ||||
| dashboard: "ダッシュボード" | ||||
| local: "ローカル" | ||||
| remote: "リモート" | ||||
| smtpHost: "ホスト" | ||||
| smtpUser: "ユーザー名" | ||||
| smtpPass: "パスワード" | ||||
| _mfm: | ||||
|   mention: "メンション" | ||||
|   quote: "引用" | ||||
|   emoji: "カスタム絵文字" | ||||
|   search: "探す" | ||||
| _sidebar: | ||||
|   icon: "アイコン" | ||||
| _theme: | ||||
|   keys: | ||||
|     mention: "メンション" | ||||
|     renote: "Renote" | ||||
| _sfx: | ||||
|   note: "ノート" | ||||
|   notification: "通知" | ||||
|   chat: "チャット" | ||||
| _ago: | ||||
|   unknown: "謎" | ||||
|   future: "未来" | ||||
| @@ -142,6 +495,8 @@ _antennaSources: | ||||
| _widgets: | ||||
|   notifications: "通知" | ||||
|   timeline: "タイムライン" | ||||
|   activity: "アクティビティ" | ||||
|   federation: "連合" | ||||
| _cw: | ||||
|   show: "もっとあるやろ!" | ||||
| _poll: | ||||
| @@ -149,14 +504,27 @@ _poll: | ||||
|   deadlineTime: "時間" | ||||
| _visibility: | ||||
|   publicDescription: "みなのユーザーに公開" | ||||
|   home: "ホーム" | ||||
|   followers: "フォロワー" | ||||
| _profile: | ||||
|   name: "名前" | ||||
|   username: "ユーザー名" | ||||
| _exportOrImport: | ||||
|   allNotes: "全てのノート" | ||||
|   followingList: "フォロー" | ||||
|   muteList: "ミュート" | ||||
|   blockingList: "ブロック" | ||||
|   userLists: "リスト" | ||||
| _timelines: | ||||
|   home: "ホーム" | ||||
| _rooms: | ||||
|   _roomType: | ||||
|     default: "デフォルト" | ||||
|   _furnitures: | ||||
|     monitor: "モニター" | ||||
| _pages: | ||||
|   blocks: | ||||
|     image: "画像" | ||||
|   script: | ||||
|     categories: | ||||
|       list: "リスト" | ||||
| @@ -175,3 +543,19 @@ _pages: | ||||
|         arg1: "リスト" | ||||
|     types: | ||||
|       array: "リスト" | ||||
| _notification: | ||||
|   youWereFollowed: "フォローされたで" | ||||
|   youWereInvitedToGroup: "グループに招待されとるで" | ||||
|   _types: | ||||
|     follow: "フォロー" | ||||
|     mention: "メンション" | ||||
|     renote: "Renote" | ||||
|     quote: "引用" | ||||
|     reaction: "リアクション" | ||||
| _deck: | ||||
|   _columns: | ||||
|     notifications: "通知" | ||||
|     tl: "タイムライン" | ||||
|     antenna: "アンテナ" | ||||
|     list: "リスト" | ||||
|     mentions: "あんた宛て" | ||||
|   | ||||
							
								
								
									
										95
									
								
								locales/kab-KAB.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										95
									
								
								locales/kab-KAB.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,95 @@ | ||||
| --- | ||||
| _lang_: "Taqbaylit" | ||||
| monthAndDay: "{day}/{month}" | ||||
| search: "Nadi" | ||||
| notifications: "Ilɣuyen" | ||||
| username: "Isem n umseqdac" | ||||
| password: "Awal uffir" | ||||
| ok: "IH" | ||||
| settings: "Iɣewwaṛen" | ||||
| profile: "Amaɣnu" | ||||
| save: "Sekles" | ||||
| delete: "Kkes" | ||||
| addToList: "Rnu ɣer tebdart" | ||||
| reply: "Err" | ||||
| loadMore: "Wali ugar" | ||||
| youGotNewFollower: "Yeṭṭafaṛ-ik·em-id" | ||||
| mention: "Bder" | ||||
| import: "Kter" | ||||
| export: "Sifeḍ" | ||||
| files: "Ifuyla" | ||||
| download: "Sider" | ||||
| lists: "Tibdarin" | ||||
| noLists: "Ulac ɣur-k·m ula d yiwet n tabdart" | ||||
| following: "Ig ṭṭafaṛ" | ||||
| followers: "Imeḍfaṛen" | ||||
| followsYou: "Yeṭṭafaṛ-ik·em-id" | ||||
| createList: "Snulfu-d tabdart" | ||||
| enterListName: "Isem n tebdart" | ||||
| follow: "Ḍfeṛ" | ||||
| you: "Kečči·mmi" | ||||
| selectList: "Fren tabdart" | ||||
| youHaveNoLists: "Ulac ɣur-k·m ula d yiwet n tabdart" | ||||
| remove: "Kkes" | ||||
| userList: "Tibdarin" | ||||
| uiLanguage: "Tutlayt n wegrudem" | ||||
| smtpUser: "Isem n umseqdac" | ||||
| smtpPass: "Awal uffir" | ||||
| _mfm: | ||||
|   mention: "Bder" | ||||
|   search: "Nadi" | ||||
| _theme: | ||||
|   keys: | ||||
|     mention: "Bder" | ||||
| _sfx: | ||||
|   notification: "Ilɣuyen" | ||||
| _widgets: | ||||
|   notifications: "Ilɣuyen" | ||||
| _cw: | ||||
|   show: "Wali ugar" | ||||
| _visibility: | ||||
|   followers: "Imeḍfaṛen" | ||||
| _profile: | ||||
|   username: "Isem n umseqdac" | ||||
| _exportOrImport: | ||||
|   followingList: "Ig ṭṭafaṛ" | ||||
|   muteList: "Sgugem" | ||||
|   blockingList: "Seḥbes" | ||||
|   userLists: "Tibdarin" | ||||
| _pages: | ||||
|   contents: "Agbur" | ||||
|   font: "Tasefsit" | ||||
|   fontSerif: "Serif" | ||||
|   fontSansSerif: "Sans Serif" | ||||
|   eyeCatchingImageRemove: "Kkes tugna i d-ijebden" | ||||
|   selectType: "Fren anaw" | ||||
|   contentBlocks: "Agbur" | ||||
|   inputBlocks: "Anekcum" | ||||
|   specialBlocks: "Uzzig" | ||||
|   script: | ||||
|     categories: | ||||
|       list: "Tibdarin" | ||||
|     blocks: | ||||
|       _join: | ||||
|         arg1: "Tibdarin" | ||||
|       _randomPick: | ||||
|         arg1: "Tibdarin" | ||||
|       _dailyRandomPick: | ||||
|         arg1: "Tibdarin" | ||||
|       _seedRandomPick: | ||||
|         arg2: "Tibdarin" | ||||
|       _pick: | ||||
|         arg1: "Tibdarin" | ||||
|       _listLen: | ||||
|         arg1: "Tibdarin" | ||||
|     types: | ||||
|       array: "Tibdarin" | ||||
| _notification: | ||||
|   youWereFollowed: "Yeṭṭafaṛ-ik·em-id" | ||||
|   _types: | ||||
|     follow: "Ig ṭṭafaṛ" | ||||
|     mention: "Bder" | ||||
| _deck: | ||||
|   _columns: | ||||
|     notifications: "Ilɣuyen" | ||||
|     list: "Tibdarin" | ||||
| @@ -54,6 +54,10 @@ driveFileDeleteConfirm: "\"{name}\" ಕಡತವನ್ನು ಅಳಿಸಲು | ||||
| unfollowConfirm: "{name}ಅನ್ನು ಹಿಂಬಾಲಿಸದಿರುವುದೇ?" | ||||
| instances: "ನಿದರ್ಶನ" | ||||
| remove: "ಅಳಿಸು" | ||||
| smtpUser: "ಬಳಕೆಹೆಸರು" | ||||
| smtpPass: "ಗುಪ್ತಪದ" | ||||
| _mfm: | ||||
|   search: "ಹುಡುಕು" | ||||
| _sfx: | ||||
|   notification: "ಅಧಿಸೂಚನೆಗಳು" | ||||
| _widgets: | ||||
| @@ -63,3 +67,10 @@ _cw: | ||||
|   show: "ಇನ್ನಷ್ಟು ನೋಡು" | ||||
| _profile: | ||||
|   username: "ಬಳಕೆಹೆಸರು" | ||||
| _notification: | ||||
|   youWereFollowed: "ಹಿಂಬಾಲಿಸಿದರು" | ||||
| _deck: | ||||
|   _columns: | ||||
|     notifications: "ಅಧಿಸೂಚನೆಗಳು" | ||||
|     tl: "ಸಮಯಸಾಲು" | ||||
|     mentions: "ಹೆಸರಿಸಿದ" | ||||
|   | ||||
| @@ -16,6 +16,9 @@ noNotes: "노트가 없습니다" | ||||
| noNotifications: "표시할 알림이 없습니다" | ||||
| instance: "인스턴스" | ||||
| settings: "설정" | ||||
| basicSettings: "기본 설정" | ||||
| otherSettings: "기타 설정" | ||||
| openInWindow: "창으로 열기" | ||||
| profile: "프로필" | ||||
| timeline: "타임라인" | ||||
| noAccountDescription: "자기소개가 없습니다" | ||||
| @@ -40,11 +43,13 @@ deleteAndEditConfirm: "이 노트를 삭제한 뒤 다시 편집하시겠습니 | ||||
| addToList: "리스트에 추가" | ||||
| sendMessage: "메시지 보내기" | ||||
| copyUsername: "유저명 복사" | ||||
| searchUser: "사용자 검색" | ||||
| reply: "답글" | ||||
| loadMore: "더 보기" | ||||
| youGotNewFollower: "새로운 팔로워가 있습니다" | ||||
| receiveFollowRequest: "새로운 팔로우 요청이 있습니다" | ||||
| followRequestAccepted: "팔로우가 수락되었습니다" | ||||
| mention: "멘션" | ||||
| mentions: "받은 멘션" | ||||
| directNotes: "다이렉트 노트" | ||||
| importAndExport: "가져오기와 내보내기" | ||||
| @@ -65,8 +70,11 @@ followers: "팔로워" | ||||
| followsYou: "당신을 팔로우합니다" | ||||
| createList: "리스트 만들기" | ||||
| manageLists: "리스트 관리" | ||||
| error: "오류가 발생했습니다" | ||||
| error: "오류" | ||||
| somethingHappened: "오류가 발생했습니다" | ||||
| retry: "다시 시도" | ||||
| pageLoadError: "페이지를 불러오지 못했습니다." | ||||
| pageLoadErrorDescription: "네트워크 연결 또는 브라우저 캐시로 인해 발생했을 가능성이 높습니다. 캐시를 삭제하거나, 잠시 후 다시 시도해 주세요." | ||||
| enterListName: "리스트 이름을 입력" | ||||
| privacy: "프라이버시" | ||||
| makeFollowManuallyApprove: "팔로우를 수동으로 승인" | ||||
| @@ -103,7 +111,12 @@ unblockConfirm: "이 계정의 차단을 해제하시겠습니까?" | ||||
| suspendConfirm: "이 계정을 정지하시겠습니까?" | ||||
| unsuspendConfirm: "이 계정의 정지를 해제하시겠습니까?" | ||||
| selectList: "리스트 선택" | ||||
| selectAntenna: "안테나 선택" | ||||
| selectWidget: "위젯 선택" | ||||
| editWidgets: "위젯 편집" | ||||
| editWidgetsExit: "편집 종료" | ||||
| customEmojis: "커스텀 이모지" | ||||
| emoji: "이모지" | ||||
| emojiName: "이모지 이름" | ||||
| emojiUrl: "이모지 URL" | ||||
| addEmoji: "이모지 추가" | ||||
| @@ -111,7 +124,9 @@ settingGuide: "추천 설정" | ||||
| cacheRemoteFiles: "리모트 파일을 캐시" | ||||
| cacheRemoteFilesDescription: "이 설정을 해지하면 리모트 파일을 캐시하지 않고 해당 파일을 직접 링크하게 됩니다. 그에 따라 서버의 저장 공간을 절약할 수 있지만, 썸네일이 생성되지 않기 때문에 통신량이 증가합니다." | ||||
| flagAsBot: "나는 봇입니다" | ||||
| flagAsBotDescription: "이 계정을 자동화된 수단으로 운용할 경우에 활성화해 주세요. 이 플래그를 활성화하면, 다른 봇이 이를 참고하여 봇 끼리의 무한 연쇄 반응을 회피하거나, 이 계정의 시스템 상에서의 취급이 Bot 운영에 최적화되는 등의 변화가 생깁니다." | ||||
| flagAsCat: "나는 고양이다냥" | ||||
| flagAsCatDescription: "이 계정이 고양이라면 활성화 해주세요." | ||||
| autoAcceptFollowed: "팔로우 중인 유저로부터의 팔로우 요청을 자동 수락" | ||||
| addAcount: "계정 추가" | ||||
| loginFailed: "로그인에 실패했습니다" | ||||
| @@ -173,7 +188,6 @@ processing: "처리중" | ||||
| preview: "미리보기" | ||||
| default: "기본값" | ||||
| noCustomEmojis: "이모지가 없습니다" | ||||
| customEmojisOfRemote: "다른 인스턴스들의 이모지" | ||||
| noJobs: "작업이 없습니다" | ||||
| federating: "연합 중" | ||||
| blocked: "차단됨" | ||||
| @@ -202,6 +216,8 @@ imageUrl: "이미지 URL" | ||||
| remove: "삭제" | ||||
| removed: "삭제하였습니다" | ||||
| removeAreYouSure: "\"{x}\" 을(를) 삭제하시겠습니까?" | ||||
| deleteAreYouSure: "\"{x}\" 을(를) 삭제하시겠습니까?" | ||||
| resetAreYouSure: "초기화 하시겠습니까?" | ||||
| saved: "저장하였습니다" | ||||
| messaging: "대화" | ||||
| upload: "업로드" | ||||
| @@ -260,6 +276,7 @@ rename: "이름 변경" | ||||
| avatar: "아바타" | ||||
| banner: "배너" | ||||
| nsfw: "열람주의" | ||||
| whenServerDisconnected: "서버와의 접속이 끊겼을 때" | ||||
| disconnectedFromServer: "서버와의 연결이 끊어졌습니다" | ||||
| reload: "새로고침" | ||||
| doNothing: "무시하기" | ||||
| @@ -300,6 +317,9 @@ bannerUrl: "배너 이미지 URL" | ||||
| basicInfo: "기본 정보" | ||||
| pinnedUsers: "고정된 유저" | ||||
| pinnedUsersDescription: "\"발견하기\" 페이지 등에 고정하고 싶은 유저를 한 줄에 한 명씩 적습니다." | ||||
| pinnedPages: "고정한 페이지" | ||||
| pinnedPagesDescription: "인스턴스의 대문에 고정하고 싶은 페이지의 경로를 한 줄에 하나씩 적습니다." | ||||
| pinnedNotes: "고정해놓은 노트" | ||||
| hcaptcha: "hCaptcha" | ||||
| enableHcaptcha: "hCaptcha 활성화" | ||||
| hcaptchaSiteKey: "사이트 키" | ||||
| @@ -340,13 +360,6 @@ popularTags: "인기 태그" | ||||
| userList: "리스트" | ||||
| about: "정보" | ||||
| aboutMisskey: "Misskey에 대하여" | ||||
| aboutMisskeyText: "Misskey는 syuilo에 의해서 2014년부터 개발되어 온 오픈소스 소프트웨어 입니다." | ||||
| misskeyMembers: "현재는 아래 멤버들에 의해 개발 및 유지보수 되고 있습니다:" | ||||
| misskeySource: "소스코드는 여기에 공개되어 있습니다:" | ||||
| misskeyTranslation: "Misskey의 번역을 함께해 주시길 부탁드립니다:" | ||||
| misskeyDonate: "Misskey에 기부하심으로써 개발에 도움을 주실 수 있습니다:" | ||||
| morePatrons: "이 외에도 다른 많은 분들이 도움을 주시고 계십니다. 감사합니다🥰" | ||||
| patrons: "후원자들" | ||||
| administrator: "관리자" | ||||
| token: "토큰" | ||||
| twoStepAuthentication: "2단계 인증" | ||||
| @@ -360,9 +373,6 @@ unregister: "등록 해제" | ||||
| passwordLessLogin: "비밀번호 없이 로그인" | ||||
| resetPassword: "비밀번호 재설정" | ||||
| newPasswordIs: "새로운 비밀번호는 \"{password}\" 입니다" | ||||
| autoReloadWhenDisconnected: "서버와의 연결이 끊기면 자동 새로고침" | ||||
| autoNoteWatch: "노트를 자동으로 지켜보기" | ||||
| autoNoteWatchDescription: "리액션하거나 답글을 남긴 다른 유저의 노트에 대한 알림을 받습니다." | ||||
| reduceUiAnimation: "UI의 애니메이션을 줄이기" | ||||
| share: "공유" | ||||
| notFound: "찾을 수 없습니다" | ||||
| @@ -400,6 +410,7 @@ noMessagesYet: "아직 대화가 없습니다" | ||||
| newMessageExists: "새 메시지가 있습니다" | ||||
| onlyOneFileCanBeAttached: "메시지에 첨부할 수 있는 파일은 하나까지입니다" | ||||
| signinRequired: "로그인 해주세요" | ||||
| invitations: "초대" | ||||
| invitationCode: "초대 코드" | ||||
| checking: "확인하는 중입니다" | ||||
| available: "사용 가능합니다" | ||||
| @@ -423,6 +434,7 @@ useOsNativeEmojis: "OS 기본 이모지를 사용" | ||||
| youHaveNoGroups: "그룹이 없습니다" | ||||
| joinOrCreateGroup: "다른 그룹의 초대를 받거나, 직접 새 그룹을 만들어 보세요." | ||||
| noHistory: "기록이 없습니다" | ||||
| signinHistory: "로그인 기록" | ||||
| disableAnimatedMfm: "움직임이 있는 MFM을 비활성화" | ||||
| doing: "잠시만요" | ||||
| category: "카테고리" | ||||
| @@ -430,7 +442,7 @@ tags: "태그" | ||||
| docSource: "이 문서의 소스" | ||||
| createAccount: "계정 만들기" | ||||
| existingAcount: "기존 계정" | ||||
| regenerate: "다시 생성" | ||||
| regenerate: "재생성" | ||||
| fontSize: "글자 크기" | ||||
| noFollowRequests: "처리되지 않은 팔로우 요청이 없습니다" | ||||
| openImageInNewTab: "새 탭에서 이미지 열기" | ||||
| @@ -440,8 +452,7 @@ remote: "리모트" | ||||
| total: "합계" | ||||
| weekOverWeekChanges: "지난주보다" | ||||
| dayOverDayChanges: "어제보다" | ||||
| accessibility: "접근성" | ||||
| clinetSettings: "클라이언트 설정" | ||||
| clientSettings: "클라이언트 설정" | ||||
| accountSettings: "계정 설정" | ||||
| promotion: "프로모션" | ||||
| promote: "프로모션하기" | ||||
| @@ -464,6 +475,7 @@ objectStorageUseSSL: "SSL 사용" | ||||
| objectStorageUseSSLDesc: "API 호출시 HTTPS 를 사용하지 않는 경우 OFF 로 설정해 주세요" | ||||
| objectStorageUseProxy: "연결에 프록시를 사용" | ||||
| objectStorageUseProxyDesc: "오브젝트 스토리지 API 호출시 프록시를 사용하지 않는 경우 OFF 로 설정해 주세요" | ||||
| objectStorageSetPublicRead: "업로드할 때 'public-read'를 설정하기" | ||||
| serverLogs: "서버 로그" | ||||
| deleteAll: "모두 삭제" | ||||
| showFixedPostForm: "타임라인 상단에 글 작성란을 표시" | ||||
| @@ -471,7 +483,10 @@ newNoteRecived: "새 노트가 있습니다" | ||||
| sounds: "소리" | ||||
| listen: "듣기" | ||||
| none: "없음" | ||||
| showInPage: "페이지로 보기" | ||||
| popout: "새 창으로 열기" | ||||
| volume: "음량" | ||||
| masterVolume: "마스터 볼륨" | ||||
| details: "자세히" | ||||
| chooseEmoji: "이모지 선택" | ||||
| unableToProcess: "작업을 완료할 수 없습니다" | ||||
| @@ -506,6 +521,176 @@ relays: "릴레이" | ||||
| addRelay: "릴레이 추가" | ||||
| inboxUrl: "Inbox 주소" | ||||
| addedRelays: "추가된 릴레이" | ||||
| serviceworkerInfo: "푸시 알림을 수행하려면 활성화해야 합니다." | ||||
| deletedNote: "삭제된 노트" | ||||
| invisibleNote: "비공개 노트" | ||||
| enableInfiniteScroll: "자동으로 좀 더 보기" | ||||
| visibility: "공개 범위" | ||||
| poll: "투표" | ||||
| useCw: "내용 숨기기" | ||||
| enablePlayer: "플레이어 열기" | ||||
| disablePlayer: "플레이어 닫기" | ||||
| expandTweet: "트윗 확장하기" | ||||
| themeEditor: "테마 에디터" | ||||
| description: "설명" | ||||
| author: "작성자" | ||||
| leaveConfirm: "저장하지 않은 변경사항이 있습니다. 취소하시겠습니까?" | ||||
| manage: "관리" | ||||
| plugins: "플러그인" | ||||
| pluginInstallWarn: "신뢰할 수 없는 플러그인은 설치하지 마십시오." | ||||
| deck: "덱" | ||||
| undeck: "덱 해제" | ||||
| width: "폭" | ||||
| height: "높이" | ||||
| large: "크게" | ||||
| medium: "보통" | ||||
| small: "작게" | ||||
| generateAccessToken: "액세스 토큰 생성" | ||||
| permission: "권한" | ||||
| enableAll: "전체 선택" | ||||
| disableAll: "전체 해제" | ||||
| tokenRequested: "계정 접근 허용" | ||||
| pluginTokenRequestedDescription: "이 플러그인은 여기서 설정한 권한을 사용할 수 있게 됩니다." | ||||
| notificationType: "알림 유형" | ||||
| edit: "편집" | ||||
| useStarForReactionFallback: "알 수 없는 리액션 이모지 대신 ★ 사용" | ||||
| emailConfig: "메일 서버 설정" | ||||
| emailConfigInfo: "가입 시 메일 주소 확인이나 비밀번호 초기화 시에 사용합니다." | ||||
| smtpConfig: "SMTP 서버 설정" | ||||
| smtpHost: "호스트" | ||||
| smtpPort: "포트" | ||||
| smtpUser: "유저명" | ||||
| smtpPass: "비밀번호" | ||||
| emptyToDisableSmtpAuth: "SMTP 인증을 사용하지 않으려면 공란으로 비워둡니다." | ||||
| smtpSecure: "SMTP 연결에 Implicit SSL/TTS 사용" | ||||
| smtpSecureInfo: "STARTTLS 사용 시에는 해제합니다." | ||||
| testEmail: "이메일 전송 테스트" | ||||
| wordMute: "단어 뮤트" | ||||
| makeActive: "활성화" | ||||
| display: "표시" | ||||
| copy: "복사" | ||||
| overview: "요약" | ||||
| logs: "로그" | ||||
| delayed: "지연" | ||||
| database: "데이터베이스" | ||||
| channel: "채널" | ||||
| create: "생성" | ||||
| notificationSetting: "알림 설정" | ||||
| notificationSettingDesc: "표시할 알림의 종류를 선택해 주세요." | ||||
| useGlobalSettingDesc: "활성화하면 계정의 알림 설정이 적용되니다. 비활성화하면 개별적으로 설정할 수 있게 됩니다." | ||||
| other: "기타" | ||||
| regenerateLoginToken: "로그인 토큰을 재생성" | ||||
| regenerateLoginTokenDescription: "로그인할 때 사용되는 내부 토큰을 재생성합니다. 일반적으로 이 작업을 실행할 필요는 없습니다. 이 기능을 사용하면 이 계정으로 로그인한 모든 기기에서 로그아웃됩니다." | ||||
| setMultipleBySeparatingWithSpace: "공백으로 구분하여 여러 개 설정할 수 있습니다." | ||||
| fileIdOrUrl: "파일 ID 또는 URL" | ||||
| chatOpenBehavior: "대화를 열 때의 동작" | ||||
| behavior: "동작" | ||||
| sample: "예시" | ||||
| abuseReports: "신고" | ||||
| reportAbuse: "신고" | ||||
| reportAbuseOf: "{name}을 신고하기" | ||||
| fillAbuseReportDescription: "신고하려는 이유를 자세히 알려주세요. 특정 게시물을 신고할 때에는 게시물의 URL도 포함해 주세요." | ||||
| abuseReported: "신고를 보냈습니다. 신고해 주셔서 감사합니다." | ||||
| send: "전송" | ||||
| openInNewTab: "새 탭에서 열기" | ||||
| random: "랜덤" | ||||
| system: "시스템" | ||||
| switchUi: "UI 전환" | ||||
| desktop: "데스크탑" | ||||
| clip: "클립" | ||||
| createNew: "새로 만들기" | ||||
| optional: "옵션" | ||||
| createNewClip: "새 클립 만들기" | ||||
| public: "공개" | ||||
| manageAccessTokens: "액세스 토큰 관리" | ||||
| yes: "예" | ||||
| no: "아니오" | ||||
| driveUsage: "드라이브 사용량" | ||||
| noCrawle: "검색엔진의 인덱싱 거부" | ||||
| noCrawleDescription: "검색엔진에 사용자 페이지, 노트, 페이지 등의 콘텐츠를 인덱싱되지 않게 합니다." | ||||
| lockedAccountInfo: "팔로우를 승인으로 승인받더라도 노트의 공개 범위를 '팔로워'로 하지 않는 한 누구나 당신의 노트를 볼 수 있습니다." | ||||
| alwaysMarkSensitive: "미디어를 항상 열람 주의로 설정" | ||||
| emailVerified: "메일 주소가 확인되었습니다." | ||||
| clips: "클립" | ||||
| _nsfw: | ||||
|   ignore: "열람 주의 미디어 항상 표시" | ||||
| _mfm: | ||||
|   cheatSheet: "MFM 도움말" | ||||
|   intro: "MFM는 Misskey의 다양한 곳에서 사용할 수 있는 전용 마크업 언어입니다. 여기에서는 MFM에서 사용할 수 있는 구문을 확인할 수 있습니다." | ||||
|   mention: "멘션" | ||||
|   mentionDescription: "골뱅이표(@) 뒤에 사용자명을 넣어 특정 유저를 나타낼 수 있습니다." | ||||
|   hashtag: "해시태그" | ||||
|   hashtagDescription: "샵 또는 우물정자(#)를 앞에 붙여서 해시태그를 나타낼 수 있습니다." | ||||
|   url: "URL" | ||||
|   urlDescription: "URL을 나타낼 수 있습니다." | ||||
|   link: "링크" | ||||
|   boldDescription: "문자를 굵게 강조합니다." | ||||
|   smallDescription: "내용을 작고 연하게 보이게 합니다." | ||||
|   center: "가운데 정렬" | ||||
|   centerDescription: "내용을 가운데 정렬로 보이게 합니다." | ||||
|   inlineCode: "코드(인라인)" | ||||
|   blockCode: "코드(블록)" | ||||
|   inlineMath: "수식(인라인)" | ||||
|   inlineMathDescription: "수식(KaTeX)를 인라인으로 보이게 합니다." | ||||
|   blockMath: "수식(블록)" | ||||
|   blockMathDescription: "여러 줄의 수식(KaTeX)를 블록으로 보이게 합니다." | ||||
|   quote: "인용" | ||||
|   emoji: "커스텀 이모지" | ||||
|   emojiDescription: "커스텀 이모지의 이름을 쌍점(:)으로 감싸서 커스텀 이모지를 사용합니다." | ||||
|   search: "검색" | ||||
|   searchDescription: "주어진 키워드가 입력된 검색창을 보이게 합니다." | ||||
|   flip: "플립" | ||||
|   flipDescription: "내용을 상하 또는 좌우로 반전시킵니다." | ||||
|   jump: "애니메이션(점프)" | ||||
| _reversi: | ||||
|   reversi: "리버시" | ||||
|   gameSettings: "대국 설정" | ||||
|   chooseBoard: "보드 선택" | ||||
|   blackOrWhite: "선공/후공" | ||||
|   blackIs: "{name}님이 흑(선공)" | ||||
|   rules: "규칙" | ||||
|   botSettings: "Bot 설정" | ||||
|   thisGameIsStartedSoon: "잠시 후에 대국이 시작됩니다" | ||||
|   waitingForOther: "상대의 준비가 완료될 때까지 기다리고 있습니다" | ||||
|   waitingForMe: "당신의 준비 완료를 기다리고 있습니다" | ||||
|   ready: "준비 완료" | ||||
|   myTurn: "당신의 차례입니다" | ||||
|   turnOf: "{name}님의 차례입니다" | ||||
|   pastTurnOf: "{name}님의 차례" | ||||
|   surrender: "기권" | ||||
|   surrendered: "기권에 의해" | ||||
|   drawn: "무승부" | ||||
|   won: "{name}님의 승리" | ||||
|   black: "흑" | ||||
|   white: "백" | ||||
|   total: "합계" | ||||
|   turnCount: "{count}턴 째" | ||||
|   myGames: "내 대국" | ||||
|   allGames: "모두의 대국" | ||||
|   ended: "종료" | ||||
|   playing: "지금 대국 중" | ||||
|   isLlotheo: "돌이 적은 사람이 승리 (llotheo)" | ||||
|   loopedMap: "루프 지도" | ||||
|   canPutEverywhere: "어디에나 놓을 수 있음" | ||||
| _instanceTicker: | ||||
|   none: "보이지 않음" | ||||
|   remote: "리모트 유저에게만 보이기" | ||||
|   always: "항상 보이기" | ||||
| _channel: | ||||
|   create: "채널 생성" | ||||
|   setBanner: "배너 설정" | ||||
|   removeBanner: "배너 삭제" | ||||
|   featured: "트렌드" | ||||
|   following: "팔로잉" | ||||
|   usersCount: "{n}명 참여 중" | ||||
|   notesCount: "{n}노트" | ||||
| _sidebar: | ||||
|   icon: "아이콘" | ||||
|   hide: "숨기기" | ||||
| _wordMute: | ||||
|   muteWords: "뮤트할 단어" | ||||
|   muteWordsDescription: "공백으로 구분하는 경우 AND, 줄바꿈으로 구분하는 경우 OR로 지정됩니다。" | ||||
|   mutedNotes: "뮤트된 노트" | ||||
| _theme: | ||||
|   explore: "테마 찾아보기" | ||||
|   install: "테마 설치" | ||||
| @@ -514,6 +699,25 @@ _theme: | ||||
|   installed: "{name} 테마가 설치되었습니다" | ||||
|   alreadyInstalled: "이미 설치된 테마입니다" | ||||
|   invalid: "테마 형식이 올바르지 않습니다" | ||||
|   make: "테마 만들기" | ||||
|   base: "베이스" | ||||
|   addConstant: "상수 추가" | ||||
|   constant: "상수" | ||||
|   defaultValue: "기본값" | ||||
|   color: "색" | ||||
|   refProp: "프로퍼티를 참조" | ||||
|   refConst: "상수를 참조" | ||||
|   key: "키" | ||||
|   func: "함수" | ||||
|   funcKind: "함수 종류" | ||||
|   argument: "매개변수" | ||||
|   importInfo: "여기에 테마 코드를 붙여 넣어 에디터로 불러올 수 있습니다." | ||||
|   keys: | ||||
|     link: "링크" | ||||
|     hashtag: "해시태그" | ||||
|     mention: "멘션" | ||||
|     renote: "Renote" | ||||
|     divider: "구분선" | ||||
| _sfx: | ||||
|   note: "새 노트" | ||||
|   noteMy: "내 노트" | ||||
| @@ -627,12 +831,15 @@ _widgets: | ||||
|   rss: "RSS 리더" | ||||
|   activity: "활동" | ||||
|   photos: "사진" | ||||
|   digitalClock: "디지털 시계" | ||||
|   federation: "연합" | ||||
|   postForm: "글 입력란" | ||||
|   button: "버튼" | ||||
| _cw: | ||||
|   hide: "숨기기" | ||||
|   show: "더 보기" | ||||
|   chars: "{count} 문자" | ||||
|   files: "{count} 파일" | ||||
|   poll: "투표" | ||||
| _poll: | ||||
|   noOnlyOneChoice: "투표 항목이 최소 2개 필요합니다" | ||||
|   choiceN: "선택지 {n}" | ||||
| @@ -665,6 +872,7 @@ _visibility: | ||||
|   specified: "다이렉트" | ||||
|   specifiedDescription: "지정한 유저에게만 공개" | ||||
|   localOnly: "로컬에만" | ||||
|   localOnlyDescription: "리모트 유저에게 보이지 않기" | ||||
| _postForm: | ||||
|   replyPlaceholder: "이 노트에 답글..." | ||||
|   quotePlaceholder: "이 노트를 인용..." | ||||
| @@ -680,7 +888,6 @@ _profile: | ||||
|   username: "유저명" | ||||
|   description: "자기소개" | ||||
|   youCanIncludeHashtags: "해시 태그를 포함할 수 있습니다." | ||||
|   metadata: "추가 정보" | ||||
|   metadataLabel: "라벨" | ||||
|   metadataContent: "내용" | ||||
| _exportOrImport: | ||||
| @@ -780,6 +987,8 @@ _rooms: | ||||
|     cup-noodle: "컵라면" | ||||
|     holo-display: "홀로그램" | ||||
|     energy-drink: "에너지 드링크" | ||||
|     doll-ai: "아이쨩 인형" | ||||
|     banknote: "지폐뭉치" | ||||
| _pages: | ||||
|   newPage: "페이지 만들기" | ||||
|   editPage: "페이지 수정" | ||||
| @@ -798,6 +1007,7 @@ _pages: | ||||
|   my: "내 페이지" | ||||
|   liked: "좋아요한 페이지" | ||||
|   inspector: "인스펙터" | ||||
|   contents: "콘텐츠" | ||||
|   content: "페이지 블록" | ||||
|   variables: "변수" | ||||
|   title: "제목" | ||||
| @@ -851,6 +1061,8 @@ _pages: | ||||
|       id: "캔버스 ID" | ||||
|       width: "폭" | ||||
|       height: "높이" | ||||
|     _note: | ||||
|       detailed: "세부 정보 보기" | ||||
|     switch: "스위치" | ||||
|     _switch: | ||||
|       name: "변수명" | ||||
| @@ -1065,3 +1277,38 @@ _relayStatus: | ||||
|   requesting: "대기 중" | ||||
|   accepted: "승인됨" | ||||
|   rejected: "거절됨" | ||||
| _notification: | ||||
|   fileUploaded: "파일이 업로드되었습니다" | ||||
|   youGotMention: "{name}님이 멘션함" | ||||
|   youGotReply: "{name}님이 답글함" | ||||
|   youGotQuote: "{name}님이 인용함" | ||||
|   youRenoted: "{name}님이 Renote" | ||||
|   youGotPoll: "{name}님이 투표함" | ||||
|   youWereFollowed: "새로운 팔로워가 있습니다" | ||||
|   youReceivedFollowRequest: "새로운 팔로우 요청이 있습니다" | ||||
|   yourFollowRequestAccepted: "팔로우 요청이 수락되었습니다" | ||||
|   youWereInvitedToGroup: "그룹에 초대되었습니다" | ||||
|   _types: | ||||
|     follow: "팔로잉" | ||||
|     mention: "멘션" | ||||
|     renote: "Renote" | ||||
|     quote: "인용" | ||||
|     reaction: "리액션" | ||||
| _deck: | ||||
|   alwaysShowMainColumn: "메인 칼럼 항상 표시" | ||||
|   columnAlign: "칼럼 정렬" | ||||
|   addColumn: "칼럼 추가" | ||||
|   swapLeft: "왼쪽으로 이동" | ||||
|   swapRight: "오른쪽으로 이동" | ||||
|   swapUp: "위로 이동" | ||||
|   swapDown: "아래로 이동" | ||||
|   stackLeft: "왼쪽에 쌓기" | ||||
|   popRight: "오른쪽으로 빼기" | ||||
|   _columns: | ||||
|     widgets: "위젯" | ||||
|     notifications: "알림" | ||||
|     tl: "타임라인" | ||||
|     antenna: "안테나" | ||||
|     list: "리스트" | ||||
|     mentions: "받은 멘션" | ||||
|     direct: "다이렉트" | ||||
|   | ||||
| @@ -1,2 +1,23 @@ | ||||
| --- | ||||
| _lang_: "język polski" | ||||
| search: "Szukaj" | ||||
| notifications: "Powiadomienia" | ||||
| username: "Nazwa użytkownika" | ||||
| password: "Hasło" | ||||
| ok: "OK" | ||||
| gotIt: "Rozumiem!" | ||||
| cancel: "Anuluj" | ||||
| enterUsername: "Wprowadź nazwę użytkownika" | ||||
| smtpUser: "Nazwa użytkownika" | ||||
| smtpPass: "Hasło" | ||||
| _mfm: | ||||
|   search: "Szukaj" | ||||
| _sfx: | ||||
|   notification: "Powiadomienia" | ||||
| _widgets: | ||||
|   notifications: "Powiadomienia" | ||||
| _profile: | ||||
|   username: "Nazwa użytkownika" | ||||
| _deck: | ||||
|   _columns: | ||||
|     notifications: "Powiadomienia" | ||||
|   | ||||
							
								
								
									
										1472
									
								
								locales/ru-RU.yml
									
									
									
									
									
								
							
							
						
						
									
										1472
									
								
								locales/ru-RU.yml
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										5
									
								
								locales/ug-CN.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								locales/ug-CN.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | ||||
| --- | ||||
| _lang_: "ياپونچە" | ||||
| search: "ئىزدەش" | ||||
| _mfm: | ||||
|   search: "ئىزدەش" | ||||
							
								
								
									
										1285
									
								
								locales/uk-UA.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1285
									
								
								locales/uk-UA.yml
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,6 +1,6 @@ | ||||
| --- | ||||
| _lang_: "中文(简体)" | ||||
| introMisskey: "欢迎!Misskey是一个开源的分散型SNS服务。\n通过「帖子」来分享现在发生的事情吧!📡\n「反应」功能,可以让你快速的对大家的「帖子」来表达感情👍\n一起来探索新的世界吧!🚀" | ||||
| introMisskey: "欢迎!Misskey是一个开源的、去中心化的“微博客”服务。\n通过编写「帖文」来和大家分享你的以及你周围的事情吧!📡\n通过「回应」功能,可以让你快速地对大家的帖文表达反馈👍\n来探索新的世界吧!🚀" | ||||
| monthAndDay: "{month}月 {day}日" | ||||
| search: "搜索" | ||||
| notifications: "通知" | ||||
| @@ -11,11 +11,14 @@ ok: "OK" | ||||
| gotIt: "我明白了" | ||||
| cancel: "取消" | ||||
| enterUsername: "输入用户名" | ||||
| renotedBy: "由 {user} 转贴" | ||||
| noNotes: "没有投稿" | ||||
| renotedBy: "{user} 转发了" | ||||
| noNotes: "没有帖文" | ||||
| noNotifications: "无通知" | ||||
| instance: "实例" | ||||
| settings: "设置" | ||||
| basicSettings: "基本设置" | ||||
| otherSettings: "其他设置" | ||||
| openInWindow: "在新窗口中打开" | ||||
| profile: "个人资料" | ||||
| timeline: "时间线" | ||||
| noAccountDescription: "这个人很懒,没有写自我介绍" | ||||
| @@ -30,23 +33,28 @@ addUser: "添加用户" | ||||
| favorite: "收藏" | ||||
| favorites: "收藏" | ||||
| unfavorite: "取消收藏" | ||||
| favorited: "已加入收藏夹。" | ||||
| alreadyFavorited: "收藏夹中已存在。" | ||||
| cantFavorite: "无法添加到收藏夹。" | ||||
| pin: "置顶" | ||||
| unpin: "取消置顶" | ||||
| copyContent: "复制内容" | ||||
| copyLink: "复制链接" | ||||
| delete: "删除" | ||||
| deleteAndEdit: "删除和编辑" | ||||
| deleteAndEditConfirm: "要删除此帖并再次编辑吗?对此帖的所有回应,转推和回复也将被删除。" | ||||
| deleteAndEdit: "删除并编辑" | ||||
| deleteAndEditConfirm: "要删除此帖并再次编辑吗?对此帖的所有回应、转发和回复也将被删除。" | ||||
| addToList: "添加至列表" | ||||
| sendMessage: "发送" | ||||
| copyUsername: "复制用户名" | ||||
| searchUser: "搜索用户" | ||||
| reply: "回复" | ||||
| loadMore: "查看更多" | ||||
| youGotNewFollower: "你有新的关注者" | ||||
| receiveFollowRequest: "收到关注请求" | ||||
| followRequestAccepted: "同意关注请求" | ||||
| receiveFollowRequest: "您收到了关注请求" | ||||
| followRequestAccepted: "您的关注请求被通过了" | ||||
| mention: "提及" | ||||
| mentions: "提及" | ||||
| directNotes: "指定用户可见" | ||||
| directNotes: "私信" | ||||
| importAndExport: "导入和导出" | ||||
| import: "导入" | ||||
| export: "导出" | ||||
| @@ -65,8 +73,11 @@ followers: "关注者" | ||||
| followsYou: "关注了你" | ||||
| createList: "创建列表" | ||||
| manageLists: "管理列表" | ||||
| error: "有点小问题" | ||||
| error: "错误" | ||||
| somethingHappened: "出现了问题" | ||||
| retry: "重试" | ||||
| pageLoadError: "页面加载失败。" | ||||
| pageLoadErrorDescription: "这通常是由于网络或浏览器缓存的原因。请清除缓存或等待片刻后重试。" | ||||
| enterListName: "输入列表名称" | ||||
| privacy: "隐私" | ||||
| makeFollowManuallyApprove: "关注者请求需要批准" | ||||
| @@ -76,17 +87,21 @@ followRequest: "关注申请" | ||||
| followRequests: "关注申请" | ||||
| unfollow: "取消关注" | ||||
| followRequestPending: "发送关注申请" | ||||
| enterEmoji: "输入Emoji" | ||||
| enterEmoji: "输入表情符号" | ||||
| renote: "转发" | ||||
| unrenote: "取消转发" | ||||
| renoted: "已转发。" | ||||
| cantRenote: "该帖子无法转发。" | ||||
| cantReRenote: "转发无法被再次转发。" | ||||
| quote: "引用" | ||||
| pinnedNote: "已置顶的帖子" | ||||
| you: "您" | ||||
| clickToShow: "点击以显示" | ||||
| sensitive: "阅读注意" | ||||
| add: "添加" | ||||
| reaction: "反应" | ||||
| reactionSettingDescription: "选择您想要固定在反应选择器中的反应。" | ||||
| reaction: "回应" | ||||
| reactionSettingDescription: "选择您想要置顶的回应。" | ||||
| reactionSettingDescription2: "拖动重新排序,单击删除,点击 + 添加。" | ||||
| rememberNoteVisibility: "记录公开范围" | ||||
| attachCancel: "删除附件" | ||||
| markAsSensitive: "阅读注意" | ||||
| @@ -103,15 +118,22 @@ unblockConfirm: "确定要解除屏蔽吗?" | ||||
| suspendConfirm: "要冻结吗?" | ||||
| unsuspendConfirm: "要解除冻结吗?" | ||||
| selectList: "选择列表" | ||||
| customEmojis: "自定义Emoji" | ||||
| emojiName: "Emoji 名称" | ||||
| emojiUrl: "emoji 地址" | ||||
| addEmoji: "添加Emoji" | ||||
| selectAntenna: "天线选择" | ||||
| selectWidget: "选择小工具" | ||||
| editWidgets: "编辑小工具" | ||||
| editWidgetsExit: "完成编辑" | ||||
| customEmojis: "自定义表情符号" | ||||
| emoji: "表情符号" | ||||
| emojiName: "表情符号名称" | ||||
| emojiUrl: "表情符号地址" | ||||
| addEmoji: "添加表情符号" | ||||
| settingGuide: "推荐配置" | ||||
| cacheRemoteFiles: "远程文件缓存" | ||||
| cacheRemoteFilesDescription: "当禁用此设定时远程文件将直接从远程实例载入。禁用后会减小储存空间需求,但是会增加流量,因为缩略图不会被生成。" | ||||
| flagAsBot: "这个账户是Bot" | ||||
| flagAsBotDescription: "如果此帐户由程序控制,请启用此项。启用后,此标志可以帮助其他开发人员防止机器人之间产生无限互动的行为,并让Misskey的内部系统将此帐户识别为机器人。" | ||||
| flagAsCat: "这个账户是Cat" | ||||
| flagAsCatDescription: "如果您想表明此帐户是一只猫,请打开此标志。" | ||||
| autoAcceptFollowed: "自动允许关注" | ||||
| addAcount: "添加账户" | ||||
| loginFailed: "登录失败" | ||||
| @@ -151,7 +173,7 @@ jobQueue: "作业队列" | ||||
| cpuAndMemory: "CPU使用量" | ||||
| network: "网络" | ||||
| disk: "存储" | ||||
| instanceInfo: "实例情报" | ||||
| instanceInfo: "实例信息" | ||||
| statistics: "统计" | ||||
| clearQueue: "清除队列" | ||||
| clearQueueConfirmTitle: "确定清除队列?" | ||||
| @@ -172,8 +194,7 @@ done: "完成" | ||||
| processing: "处理中" | ||||
| preview: "预览" | ||||
| default: "默认" | ||||
| noCustomEmojis: "无自定义Emoji" | ||||
| customEmojisOfRemote: "远程Emoji" | ||||
| noCustomEmojis: "没有自定义表情符号" | ||||
| noJobs: "没有任务" | ||||
| federating: "联合中" | ||||
| blocked: "已拦截" | ||||
| @@ -202,6 +223,8 @@ imageUrl: "图片URL" | ||||
| remove: "删除" | ||||
| removed: "已删除" | ||||
| removeAreYouSure: "要删掉「{x}」吗?" | ||||
| deleteAreYouSure: "要删掉「{x}」吗?" | ||||
| resetAreYouSure: "恢复默认设置?" | ||||
| saved: "已保存" | ||||
| messaging: "聊天" | ||||
| upload: "上传" | ||||
| @@ -260,6 +283,7 @@ rename: "重命名" | ||||
| avatar: "头像" | ||||
| banner: "Banner" | ||||
| nsfw: "阅读注意" | ||||
| whenServerDisconnected: "与服务器连接中断时" | ||||
| disconnectedFromServer: "已从服务器断开连接" | ||||
| reload: "重新加载" | ||||
| doNothing: "什么都不做" | ||||
| @@ -281,7 +305,7 @@ dayX: "{day}日" | ||||
| monthX: "{month}月" | ||||
| yearX: "{year}年" | ||||
| pages: "页面" | ||||
| integration: "连携" | ||||
| integration: "关联" | ||||
| connectSerice: "已连接" | ||||
| disconnectSerice: "断开连接" | ||||
| enableLocalTimeline: "启用本地时间线功能" | ||||
| @@ -300,6 +324,10 @@ bannerUrl: "Banner URL" | ||||
| basicInfo: "基本信息" | ||||
| pinnedUsers: "置顶用户" | ||||
| pinnedUsersDescription: "在「发现」页面中使用换行标记想要置顶的用户。" | ||||
| pinnedPages: "固定页面" | ||||
| pinnedPagesDescription: "输入您要固定到实例首页的页面路径,以换行符分隔。" | ||||
| pinnedClipId: "置顶的片段ID" | ||||
| pinnedNotes: "已置顶的帖子" | ||||
| hcaptcha: "hCaptcha" | ||||
| enableHcaptcha: "启用 hCaptcha" | ||||
| hcaptchaSiteKey: "网站密钥" | ||||
| @@ -340,13 +368,6 @@ popularTags: "热门标签" | ||||
| userList: "列表" | ||||
| about: "关于" | ||||
| aboutMisskey: "关于 Misskey" | ||||
| aboutMisskeyText: "Misskey是由syuilo于2014年开发的开放源代码软件。" | ||||
| misskeyMembers: "现在由以下成员进行开发和维护:" | ||||
| misskeySource: "源代码在这里公开:" | ||||
| misskeyTranslation: "与我们一同进行Misskey的翻译工作:" | ||||
| misskeyDonate: "可以向 Misskey 进行捐款以支持开发:" | ||||
| morePatrons: "还有很多其他的人也在支持我们,非常感谢🥰" | ||||
| patrons: "支持者" | ||||
| administrator: "管理员" | ||||
| token: "令牌" | ||||
| twoStepAuthentication: "两步验证" | ||||
| @@ -354,15 +375,12 @@ moderator: "版主" | ||||
| nUsersMentioned: "{n} 被提到" | ||||
| securityKey: "安全密钥" | ||||
| securityKeyName: "密钥名称" | ||||
| registerSecurityKey: "注册安全密钥" | ||||
| registerSecurityKey: "注册硬件安全密钥" | ||||
| lastUsed: "最后使用:" | ||||
| unregister: "删除账户" | ||||
| passwordLessLogin: "无密码登录" | ||||
| resetPassword: "重置密码" | ||||
| newPasswordIs: "新的密码是「{password}」" | ||||
| autoReloadWhenDisconnected: "断开连接时自动重新加载" | ||||
| autoNoteWatch: "自动关注帖子" | ||||
| autoNoteWatchDescription: "让您能够收到关于「反应」和回复其他用户的帖子的通知。" | ||||
| reduceUiAnimation: "减少UI动画" | ||||
| share: "分享" | ||||
| notFound: "未找到" | ||||
| @@ -400,6 +418,7 @@ noMessagesYet: "现在没有新的聊天" | ||||
| newMessageExists: "新信息" | ||||
| onlyOneFileCanBeAttached: "只能添加一个附件" | ||||
| signinRequired: "请先登录" | ||||
| invitations: "邀请" | ||||
| invitationCode: "邀请码" | ||||
| checking: "正在确认" | ||||
| available: "可用" | ||||
| @@ -419,10 +438,11 @@ or: "或者" | ||||
| uiLanguage: "显示语言" | ||||
| groupInvited: "群组招待" | ||||
| aboutX: "关于 {x}" | ||||
| useOsNativeEmojis: "使用OS原生Emoji" | ||||
| useOsNativeEmojis: "使用OS原生表情符号" | ||||
| youHaveNoGroups: "没有群组" | ||||
| joinOrCreateGroup: "请加入一个现有的群组,或者创建新群组。" | ||||
| noHistory: "没有历史记录" | ||||
| signinHistory: "登录历史" | ||||
| disableAnimatedMfm: "禁用MFM动画" | ||||
| doing: "正在进行" | ||||
| category: "类别" | ||||
| @@ -440,8 +460,8 @@ remote: "远程" | ||||
| total: "总计" | ||||
| weekOverWeekChanges: "与前一周相比" | ||||
| dayOverDayChanges: "与前一日相比" | ||||
| accessibility: "辅助功能" | ||||
| clinetSettings: "客户端设置" | ||||
| appearance: "外观" | ||||
| clientSettings: "客户端设置" | ||||
| accountSettings: "账户设置" | ||||
| promotion: "推广" | ||||
| promote: "推广" | ||||
| @@ -451,19 +471,20 @@ showFeaturedNotesInTimeline: "在时间线上显示热门推荐" | ||||
| objectStorage: "对象存储" | ||||
| useObjectStorage: "使用对象存储" | ||||
| objectStorageBaseUrl: "基本网址" | ||||
| objectStorageBaseUrlDesc: "供参考的URL。如果使用CDN或Proxy,则其URL为S3:\"https://<bucket>.s3.amazonaws.com\"、GCS等:\"https://storage-googleapis.proxy.ustclug.org/<bucket>\"。" | ||||
| objectStorageBaseUrlDesc: "URL前缀,用于构造URL到对象(媒体)的引用,如果您使用的是CDN或反向代理,请指定其URL,否则请根据您使用的服务指定可公开访问的地址。例如“https://<bucket>.s3.amazonaws.com”用于AWS S3,“https://storage.googleapis.com/<bucket>”用于GCS" | ||||
| objectStorageBucket: "存储桶" | ||||
| objectStorageBucketDesc: "请指定使用的对象存储服务的存储桶名称。" | ||||
| objectStoragePrefix: "前缀" | ||||
| objectStoragePrefixDesc: "文件将存储在此前缀的目录下。" | ||||
| objectStorageEndpoint: "端点" | ||||
| objectStorageEndpointDesc: "S3默认情况下为空,否则请为每个服务指定端点。 指定为“<host>”或“<host>:<port>”。" | ||||
| objectStorageEndpointDesc: "如果你希望使用AWS S3请留空。否则请根据你使用的服务来进行设置,指定端点形式为“<host>”或“<host>:<port>”。" | ||||
| objectStorageRegion: "可用区" | ||||
| objectStorageRegionDesc: "指定一个可用区,例如“xx-east-1”。 如果您的对象存储服务没有可用区概念,请将其留空或填写“us-east-1”。" | ||||
| objectStorageUseSSL: "使用SSL" | ||||
| objectStorageUseSSLDesc: "如果不使用https进行API连接,请关闭。" | ||||
| objectStorageUseProxy: "使用代理" | ||||
| objectStorageUseProxyDesc: "如果您不使用代理进行API连接,请将其关闭。" | ||||
| objectStorageSetPublicRead: "上传时设置为public-read" | ||||
| serverLogs: "服务器日志" | ||||
| deleteAll: "删除全部" | ||||
| showFixedPostForm: "在时间线顶部显示帖子表单" | ||||
| @@ -471,7 +492,10 @@ newNoteRecived: "有新的帖子" | ||||
| sounds: "声音" | ||||
| listen: "听" | ||||
| none: "空" | ||||
| showInPage: "在页面中显示" | ||||
| popout: "弹窗" | ||||
| volume: "音量" | ||||
| masterVolume: "主音量" | ||||
| details: "详情" | ||||
| chooseEmoji: "选择表情符号" | ||||
| unableToProcess: "操作无法完成" | ||||
| @@ -486,8 +510,8 @@ state: "状态" | ||||
| sort: "排序" | ||||
| ascendingOrder: "升序" | ||||
| descendingOrder: "降序" | ||||
| scratchpad: "暂存器" | ||||
| scratchpadDescription: "暂存器为AiScript提供了实验环境。您可以编写代码以与Misskey交互,运行它并查看结果。" | ||||
| scratchpad: "便签本" | ||||
| scratchpadDescription: "便签本为AiScript提供了实验环境。您可以编写代码以与Misskey交互,运行它并查看结果。" | ||||
| output: "输出" | ||||
| script: "脚本" | ||||
| disablePagesScript: "禁用页面脚本" | ||||
| @@ -506,14 +530,344 @@ relays: "中继" | ||||
| addRelay: "添加中继" | ||||
| inboxUrl: "Inbox URL" | ||||
| addedRelays: "已添加的中继" | ||||
| serviceworkerInfo: "您需要启用推送通知" | ||||
| deletedNote: "已删除的帖子" | ||||
| invisibleNote: "隐藏的帖子" | ||||
| enableInfiniteScroll: "启用自动滚动页面模式" | ||||
| visibility: "可见性" | ||||
| poll: "调查问卷" | ||||
| useCw: "隐藏内容" | ||||
| enablePlayer: "打开播放器" | ||||
| disablePlayer: "关闭播放器" | ||||
| expandTweet: "展开贴文" | ||||
| themeEditor: "主题编辑器" | ||||
| description: "描述" | ||||
| author: "作者" | ||||
| leaveConfirm: "存在未保存的更改。要放弃更改吗?" | ||||
| manage: "管理" | ||||
| plugins: "插件" | ||||
| pluginInstallWarn: "请不要安装不明来源的插件" | ||||
| deck: "Deck" | ||||
| undeck: "取消Deck" | ||||
| useBlurEffectForModal: "模态框使用模糊效果" | ||||
| useFullReactionPicker: "使用全功能的回应工具栏" | ||||
| width: "宽度" | ||||
| height: "高度" | ||||
| large: "大" | ||||
| medium: "中" | ||||
| small: "小" | ||||
| generateAccessToken: "生成访问令牌" | ||||
| permission: "权限" | ||||
| enableAll: "启用全部" | ||||
| disableAll: "禁用全部" | ||||
| tokenRequested: "允许访问账户" | ||||
| pluginTokenRequestedDescription: "此插件将能够拥有此处设置的权限" | ||||
| notificationType: "通知类型" | ||||
| edit: "编辑" | ||||
| useStarForReactionFallback: "如果回应的是未知表情符号,则使用★作为代替" | ||||
| emailConfig: "邮件服务器设置" | ||||
| enableEmail: "启用发送邮件功能" | ||||
| emailConfigInfo: "用于确认电子邮件和密码重置" | ||||
| email: "邮箱" | ||||
| emailAddress: "电子邮件地址" | ||||
| smtpConfig: "SMTP服务器设置" | ||||
| smtpHost: "主机名" | ||||
| smtpPort: "端口" | ||||
| smtpUser: "用户名" | ||||
| smtpPass: "密码" | ||||
| emptyToDisableSmtpAuth: "用户名和密码留空可以禁用SMTP验证" | ||||
| smtpSecure: "在 SMTP 连接中使用隐式 SSL / TLS" | ||||
| smtpSecureInfo: "使用STARTTLS时关闭。" | ||||
| testEmail: "邮件发送测试" | ||||
| wordMute: "文字屏蔽" | ||||
| userSaysSomething: "{name}说了什么" | ||||
| makeActive: "激活" | ||||
| display: "显示" | ||||
| copy: "复制" | ||||
| metrics: "指标" | ||||
| overview: "概述" | ||||
| logs: "日志" | ||||
| delayed: "延迟" | ||||
| database: "数据库" | ||||
| channel: "频道" | ||||
| create: "创建" | ||||
| notificationSetting: "通知设置" | ||||
| notificationSettingDesc: "选择要显示的通知类型。" | ||||
| useGlobalSetting: "使用全局设置" | ||||
| useGlobalSettingDesc: "启用时,将使用帐户通知设置。关闭时,则可以单独设置。" | ||||
| other: "其他" | ||||
| regenerateLoginToken: "重新生成登录令牌" | ||||
| regenerateLoginTokenDescription: "重新生成用于登录的内部令牌。通常您不需要这样做。重新生成后,您将在所有设备上登出。" | ||||
| setMultipleBySeparatingWithSpace: "您可以使用空格分隔多个项目。" | ||||
| fileIdOrUrl: "文件ID或者URL" | ||||
| chatOpenBehavior: "聊天窗口打开时的行为" | ||||
| behavior: "行为" | ||||
| sample: "示例" | ||||
| abuseReports: "举报" | ||||
| reportAbuse: "举报" | ||||
| reportAbuseOf: "举报{name}" | ||||
| fillAbuseReportDescription: "请填写举报的详细原因。如果有对方发的帖子,请同时填写URL地址。" | ||||
| abuseReported: "内容已发送。感谢您的报告。" | ||||
| send: "发送" | ||||
| abuseMarkAsResolved: "处理完毕" | ||||
| openInNewTab: "在新标签页中打开" | ||||
| openInSideView: "在侧边栏中打开" | ||||
| defaultNavigationBehaviour: "默认导航" | ||||
| editTheseSettingsMayBreakAccount: "编辑这些设置可以会损坏您的账号" | ||||
| instanceTicker: "帖子的实例信息" | ||||
| waitingFor: "等待{x}" | ||||
| random: "随机" | ||||
| system: "系统" | ||||
| switchUi: "切换界面" | ||||
| desktop: "桌面" | ||||
| clip: "片段" | ||||
| createNew: "新建" | ||||
| optional: "可选" | ||||
| createNewClip: "新建片段" | ||||
| public: "公开" | ||||
| i18nInfo: "Misskey已经被志愿者们翻译到了各种语言。如果你也有兴趣,可以通过{link}帮助翻译。" | ||||
| manageAccessTokens: "管理 Access Tokens" | ||||
| accountInfo: "帐户信息" | ||||
| notesCount: "贴文数量" | ||||
| repliesCount: "回复数量" | ||||
| renotesCount: "转贴数量" | ||||
| repliedCount: "回复数" | ||||
| renotedCount: "转发数" | ||||
| followingCount: "正在关注数量" | ||||
| followersCount: "关注者数量" | ||||
| sentReactionsCount: "发送反应数" | ||||
| receivedReactionsCount: "收到反应数" | ||||
| pollVotesCount: "发起投票数" | ||||
| pollVotedCount: "已投票数" | ||||
| yes: "确定" | ||||
| no: "取消" | ||||
| driveFilesCount: "磁盘文件数" | ||||
| driveUsage: "磁盘空间用量" | ||||
| noCrawle: "拒绝搜索器的索引" | ||||
| noCrawleDescription: "要求搜索引擎不要收录(索引)您的用户页面,帖子,页面等。" | ||||
| lockedAccountInfo: "即使通过了关注请求,只要您不将帖子可见范围设置成“关注者”,任何人都可以看到您的帖子。" | ||||
| alwaysMarkSensitive: "浏览默认媒体文件时请谨慎" | ||||
| loadRawImages: "添加附件图像的缩略图时使用原始图像质量" | ||||
| disableShowingAnimatedImages: "不播放动画" | ||||
| verificationEmailSent: "已发送确认电子邮件。请访问电子邮件中的链接以完成设置。" | ||||
| notSet: "未设置" | ||||
| emailVerified: "电子邮件地址已验证" | ||||
| noteFavoritesCount: "收藏的帖子数" | ||||
| pageLikesCount: "页面点赞次数" | ||||
| pageLikedCount: "页面被点赞次数" | ||||
| reversiCount: "黑白棋对战次数" | ||||
| contact: "联系人" | ||||
| useSystemFont: "使用系统默认字体" | ||||
| clips: "片段" | ||||
| experimentalFeatures: "实验性功能" | ||||
| developer: "开发者" | ||||
| makeExplorable: "使账号可见。" | ||||
| makeExplorableDescription: "关闭时,账号不会显示在\"发现\"中。" | ||||
| showGapBetweenNotesInTimeline: "时间线上的帖子分开显示。" | ||||
| duplicate: "复制" | ||||
| left: "左" | ||||
| center: "中央" | ||||
| wide: "宽" | ||||
| narrow: "窄" | ||||
| reloadToApplySetting: "页面刷新后设置才会生效。是否现在刷新页面?" | ||||
| _aboutMisskey: | ||||
|   about: "Misskey是由syuilo于2014年开发的开源软件。" | ||||
|   contributors: "主要贡献者" | ||||
|   allContributors: "全体贡献者" | ||||
|   source: "源代码" | ||||
|   translation: "翻译Misskey" | ||||
|   donate: "赞助Misskey" | ||||
|   morePatrons: "还有很多其他的人也在支持我们,非常感谢🥰" | ||||
|   patrons: "支持者" | ||||
| _nsfw: | ||||
|   respect: "隐藏NSFW内容" | ||||
|   ignore: "不隐藏NSFW内容" | ||||
|   force: "总是隐藏内容" | ||||
| _mfm: | ||||
|   cheatSheet: "MFM代码速查表" | ||||
|   intro: "MFM是一种在Misskey中的各个位置使用的专用标记语言。在这里您可以看到MFM中可用的语法列表。" | ||||
|   dummy: "通过Misskey扩展Fediverse的世界" | ||||
|   mention: "提及" | ||||
|   mentionDescription: "可以使用 @+用户名 来指示特定用户" | ||||
|   hashtag: "话题标签" | ||||
|   hashtagDescription: "可以使用井号+文字来表示话题标签。" | ||||
|   url: "URL" | ||||
|   urlDescription: "可以表示URL地址。" | ||||
|   link: "链接" | ||||
|   linkDescription: "可以将部分文字和URL关联起来。" | ||||
|   bold: "粗体" | ||||
|   boldDescription: "可以将文字显示为粗体来表示强调。" | ||||
|   small: "缩小" | ||||
|   smallDescription: "可以使内容文字变小、变淡。" | ||||
|   center: "居中" | ||||
|   centerDescription: "可以将内容居中显示。" | ||||
|   inlineCode: "代码(内嵌)" | ||||
|   inlineCodeDescription: "将文字中的程序代码语法高亮显示。" | ||||
|   blockCode: "代码(块)" | ||||
|   blockCodeDescription: "语法高亮显示整块程序代码。" | ||||
|   inlineMath: "数学公式(内嵌)" | ||||
|   inlineMathDescription: "显示内嵌的KaTex公式。" | ||||
|   blockMath: "数学公式(块)" | ||||
|   blockMathDescription: "显示整块的多行KaTex数学公式。" | ||||
|   quote: "引用" | ||||
|   quoteDescription: "可以用来表示引用的内容。" | ||||
|   emoji: "自定义表情符号" | ||||
|   emojiDescription: "可以将自定义表情符号使用冒号括起来,就可以显示自定义表情符号了。" | ||||
|   search: "搜索" | ||||
|   searchDescription: "显示含有搜索内容示例的搜索框。" | ||||
|   flip: "翻转" | ||||
|   flipDescription: "将内容上下或左右翻转。" | ||||
|   jelly: "动画(果冻)" | ||||
|   jellyDescription: "显示果冻一样的动画效果。" | ||||
|   tada: "动画(锵锵)" | ||||
|   tadaDescription: "显示\"锵锵!\"的动画效果。" | ||||
|   jump: "动画(跳动)" | ||||
|   jumpDescription: "显示跳动的动画效果。" | ||||
|   bounce: "动画(弹性)" | ||||
|   bounceDescription: "显示弹性一样的动画效果。" | ||||
|   shake: "动画(摇晃)" | ||||
|   shakeDescription: "显示摇晃的动画效果。" | ||||
|   twitch: "动画(颤抖)" | ||||
|   twitchDescription: "显示强烈颤抖的动画效果。" | ||||
|   spin: "动画(回转)" | ||||
|   spinDescription: "显示回转的动画效果。" | ||||
| _reversi: | ||||
|   reversi: "黑白棋" | ||||
|   gameSettings: "对局设置" | ||||
|   chooseBoard: "棋盘选择" | ||||
|   blackOrWhite: "先手/后手" | ||||
|   blackIs: "{name}执黑(先走)" | ||||
|   rules: "规则" | ||||
|   botSettings: "机器人设置" | ||||
|   thisGameIsStartedSoon: "对局在几秒后开始" | ||||
|   waitingForOther: "等待对手准备" | ||||
|   waitingForMe: "等待您的准备" | ||||
|   waitingBoth: "请准备" | ||||
|   ready: "准备就绪" | ||||
|   cancelReady: "重新准备" | ||||
|   opponentTurn: "对手的会合" | ||||
|   myTurn: "您的回合" | ||||
|   turnOf: "{name}的回合" | ||||
|   pastTurnOf: "{name}的回合" | ||||
|   surrender: "认输 " | ||||
|   surrendered: "对手认输" | ||||
|   drawn: "平局" | ||||
|   won: "{name}获胜" | ||||
|   black: "黑" | ||||
|   white: "白" | ||||
|   total: "总计" | ||||
|   turnCount: "{count}回合" | ||||
|   myGames: "我的对局" | ||||
|   allGames: "所有对局" | ||||
|   ended: "结束" | ||||
|   playing: "对局中" | ||||
|   isLlotheo: "棋子较少一方获胜(LLoTheO规则)" | ||||
|   loopedMap: "循环棋盘" | ||||
|   canPutEverywhere: "可以下在任意位置" | ||||
| _instanceTicker: | ||||
|   none: "不显示" | ||||
|   remote: "显示给远程用户" | ||||
|   always: "始终显示" | ||||
| _serverDisconnectedBehavior: | ||||
|   reload: "自动重载" | ||||
|   dialog: "对话框警告" | ||||
|   quiet: "安静警告" | ||||
| _channel: | ||||
|   create: "创建频道" | ||||
|   edit: "编辑频道" | ||||
|   setBanner: "设置横幅" | ||||
|   removeBanner: "删除横幅" | ||||
|   featured: "热点" | ||||
|   owned: "管理中" | ||||
|   following: "正在关注" | ||||
|   usersCount: "有{n}人参与" | ||||
|   notesCount: "有{n}个帖子" | ||||
| _sidebar: | ||||
|   full: "全部" | ||||
|   icon: "图标" | ||||
|   hide: "隐藏" | ||||
| _wordMute: | ||||
|   muteWords: "禁用词" | ||||
|   muteWordsDescription: "使用空格分隔表示AND逻辑,使用换行符分隔表示OR逻辑。" | ||||
|   muteWordsDescription2: "将关键字用斜线括起来表示正则表达式。" | ||||
|   softDescription: "隐藏时间线中指定条件的帖文。" | ||||
|   hardDescription: "防止将具有指定条件的帖文添加到时间线。 即使您更改条件,未添加的帖文也会被排除在外。" | ||||
|   soft: "软屏蔽" | ||||
|   hard: "硬屏蔽" | ||||
|   mutedNotes: "被屏蔽的帖文" | ||||
| _theme: | ||||
|   explore: "寻找主题" | ||||
|   install: "安装主题" | ||||
|   manage: "主题管理" | ||||
|   code: "主题代码" | ||||
|   installed: "{name} 已安装" | ||||
|   installedThemes: "已安装的主题" | ||||
|   builtinThemes: "标准主题" | ||||
|   alreadyInstalled: "此主题已经安装" | ||||
|   invalid: "主题格式错误" | ||||
|   make: "制作主题" | ||||
|   base: "基于" | ||||
|   addConstant: "添加常量" | ||||
|   constant: "常量" | ||||
|   defaultValue: "默认值" | ||||
|   color: "颜色" | ||||
|   refProp: "查看属性" | ||||
|   refConst: "查看常量" | ||||
|   key: "主要" | ||||
|   func: "函数" | ||||
|   funcKind: "功能类型" | ||||
|   argument: "参数" | ||||
|   basedProp: "基于的属性名称" | ||||
|   alpha: "不透明度" | ||||
|   darken: "暗色" | ||||
|   lighten: "亮色" | ||||
|   inputConstantName: "请输入常量名称" | ||||
|   importInfo: "您可以在此处粘贴主题代码,将其导入到编辑器中" | ||||
|   deleteConstantConfirm: "确定要删除常量{const}吗?" | ||||
|   keys: | ||||
|     accent: "强调色" | ||||
|     bg: "背景" | ||||
|     fg: "文本" | ||||
|     focus: "聚焦" | ||||
|     indicator: "标记" | ||||
|     panel: "面板" | ||||
|     shadow: "阴影" | ||||
|     header: "顶栏" | ||||
|     navBg: "侧边栏背景" | ||||
|     navFg: "侧栏文本" | ||||
|     navHoverFg: "侧栏文本(悬停)" | ||||
|     navActive: "侧栏文本(活动)" | ||||
|     navIndicator: "侧栏标记" | ||||
|     link: "链接" | ||||
|     hashtag: "话题标签" | ||||
|     mention: "提及" | ||||
|     mentionMe: "提及" | ||||
|     renote: "转发" | ||||
|     modalBg: "模态框背景" | ||||
|     divider: "分割线" | ||||
|     scrollbarHandle: "滚动条" | ||||
|     scrollbarHandleHover: "滚动条(悬停)" | ||||
|     dateLabelFg: "日期标签文字" | ||||
|     infoBg: "信息背景" | ||||
|     infoFg: "信息文本" | ||||
|     infoWarnBg: "警告背景" | ||||
|     infoWarnFg: "警告文本" | ||||
|     cwBg: "CW 按钮背景" | ||||
|     cwFg: "CW 按钮文本" | ||||
|     cwHoverBg: "CW 按钮背景(悬停)" | ||||
|     toastBg: "吐司提示背景" | ||||
|     toastFg: "吐司提示文本" | ||||
|     buttonBg: "按钮背景" | ||||
|     buttonHoverBg: "按钮背景(悬停)" | ||||
|     inputBorder: "输入框边框" | ||||
|     listItemHoverBg: "下拉列表项目背景(悬停)" | ||||
|     driveFolderBg: "驱动器文件夹背景" | ||||
|     wallpaperOverlay: "壁纸叠加层" | ||||
|     badge: "徽章" | ||||
|     messageBg: "聊天背景" | ||||
|     accentDarken: "强调色(暗)" | ||||
|     accentLighten: "强调色(亮)" | ||||
|     fgHighlighted: "高亮显示文本" | ||||
| _sfx: | ||||
|   note: "帖子" | ||||
|   noteMy: "我的帖子" | ||||
| @@ -521,6 +875,9 @@ _sfx: | ||||
|   chat: "聊天" | ||||
|   chatBg: "聊天背景" | ||||
|   antenna: "天线接收" | ||||
|   channel: "频道通知" | ||||
|   reversiPutBlack: "黑白棋:黑方下子时" | ||||
|   reversiPutWhite: "黑白棋:白方下子时" | ||||
| _ago: | ||||
|   unknown: "未知" | ||||
|   future: "未来" | ||||
| @@ -542,7 +899,7 @@ _tutorial: | ||||
|   step1_1: "欢迎!" | ||||
|   step1_2: "这个页面叫做「时间线」,它会按照时间顺序显示所有你「关注」的人所发的「帖子」。" | ||||
|   step1_3: "如果你并没有发布任何帖子,也没有关注其他的人,你的时间线页面应当什么都没有显示。" | ||||
|   step2_1: "在你想发布一些帖子之前,让我们先进行一下个人资料设置。" | ||||
|   step2_1: "在您想要发帖或关注其他人之前,请先设置一下个人资料吧。" | ||||
|   step2_2: "如果别人能够更加的了解你,关注你的概率也会得到提升。" | ||||
|   step3_1: "已经设置完个人资料了吗?" | ||||
|   step3_2: "那么接下来,试着写一些什么东西来发布吧。你可以通过点击屏幕上的铅笔图标来打开投稿页面。" | ||||
| @@ -555,9 +912,9 @@ _tutorial: | ||||
|   step5_3: "要关注其他用户,请单击他的头像,然后在他的个人资料上按下“关注”按钮。" | ||||
|   step5_4: "如果用户的名称旁边有锁定图标,则该用户需要手动批准您的关注请求。" | ||||
|   step6_1: "现在,您将可以在时间线上看到其他用户的帖子。" | ||||
|   step6_2: "您还可以在其他人的帖子上进行「反应」,以快速做出简单回复。" | ||||
|   step6_3: "在他人的贴子上按下「+」图标,即可选择想要的表情来进行「反应」。" | ||||
|   step7_1: "对Misskey基本操作的简单介绍,到此结束了。 辛苦了!" | ||||
|   step6_2: "您还可以在其他人的帖子上进行「回应」,以快速做出简单回复。" | ||||
|   step6_3: "在他人的贴子上按下「+」图标,即可选择想要的表情来进行「回应」。" | ||||
|   step7_1: "对Misskey基本操作的简单介绍,就到此结束了。 辛苦了!" | ||||
|   step7_2: "如果你想了解更多有关Misskey的信息,请参见{help}。" | ||||
|   step7_3: "接下来,享受Misskey带来的乐趣吧🚀" | ||||
| _2fa: | ||||
| @@ -568,7 +925,7 @@ _2fa: | ||||
|   step2: "然后,扫描屏幕上显示的二维码。" | ||||
|   step3: "输入您的应用提供的动态口令以完成设置。" | ||||
|   step4: "从现在开始,任何登录操作都将要求您提供动态口令。" | ||||
|   securityKeyInfo: "您可以设置使用支持FIDO2的硬件安全密钥、指纹或设备上的PIN来保护您的登录过程。" | ||||
|   securityKeyInfo: "您可以设置使用支持FIDO2的硬件安全密钥、设备上的指纹或PIN来保护您的登录过程。" | ||||
| _permissions: | ||||
|   "read:account": "查看账户信息" | ||||
|   "write:account": "更改帐户信息" | ||||
| @@ -596,6 +953,8 @@ _permissions: | ||||
|   "write:page-likes": "操作喜欢的页面" | ||||
|   "read:user-groups": "查看用户组" | ||||
|   "write:user-groups": "操作用户组" | ||||
|   "read:channels": "查看频道" | ||||
|   "write:channels": "管理频道" | ||||
| _auth: | ||||
|   shareAccess: "您要授权允许“{name}”访问您的帐户吗?" | ||||
|   shareAccessAsk: "您确定要授权此应用程序访问您的帐户吗?" | ||||
| @@ -627,12 +986,16 @@ _widgets: | ||||
|   rss: "RSS阅读器" | ||||
|   activity: "活动" | ||||
|   photos: "照片" | ||||
|   digitalClock: "数字时钟" | ||||
|   federation: "联邦宇宙" | ||||
|   postForm: "投稿窗口" | ||||
|   slideshow: "幻灯片展示" | ||||
|   button: "按钮" | ||||
| _cw: | ||||
|   hide: "隐藏" | ||||
|   show: "查看更多" | ||||
|   chars: "{count}个字符" | ||||
|   files: "{count} 个文件" | ||||
|   poll: "投票" | ||||
| _poll: | ||||
|   noOnlyOneChoice: "需要至少两个选项" | ||||
|   choiceN: "选择{n}" | ||||
| @@ -665,9 +1028,11 @@ _visibility: | ||||
|   specified: "指定用户" | ||||
|   specifiedDescription: "仅发送至指定用户" | ||||
|   localOnly: "仅限本地" | ||||
|   localOnlyDescription: "对远程用户不可见" | ||||
| _postForm: | ||||
|   replyPlaceholder: "回复这个帖子..." | ||||
|   quotePlaceholder: "引用这个帖子..." | ||||
|   channelPlaceholder: "发布到频道…" | ||||
|   _placeholders: | ||||
|     a: "现在如何?" | ||||
|     b: "发生了什么?" | ||||
| @@ -680,9 +1045,13 @@ _profile: | ||||
|   username: "用户名" | ||||
|   description: "个人简介" | ||||
|   youCanIncludeHashtags: "您可以包含一个哈希标签。" | ||||
|   metadata: "额外信息" | ||||
|   metadata: "附加信息" | ||||
|   metadataEdit: "附加信息编辑" | ||||
|   metadataDescription: "最多可以在个人资料中以表格形式显示四条其他信息。" | ||||
|   metadataLabel: "标签" | ||||
|   metadataContent: "内容" | ||||
|   changeAvatar: "修改头像" | ||||
|   changeBanner: "修改横幅" | ||||
| _exportOrImport: | ||||
|   allNotes: "所有帖子" | ||||
|   followingList: "关注中" | ||||
| @@ -781,6 +1150,7 @@ _rooms: | ||||
|     holo-display: "全息显示器" | ||||
|     energy-drink: "能量饮料" | ||||
|     doll-ai: "小蓝的玩偶" | ||||
|     banknote: "钞票" | ||||
| _pages: | ||||
|   newPage: "创建页面" | ||||
|   editPage: "编辑页面" | ||||
| @@ -788,6 +1158,7 @@ _pages: | ||||
|   created: "页面已创建" | ||||
|   updated: "页面已更新" | ||||
|   deleted: "该页面已被删除" | ||||
|   pageSetting: "页面设置" | ||||
|   nameAlreadyExists: "该页面URL已存在" | ||||
|   invalidNameTitle: "无效的页面URL" | ||||
|   invalidNameText: "请确认该项不为空" | ||||
| @@ -798,7 +1169,9 @@ _pages: | ||||
|   unlike: "取消赞" | ||||
|   my: "我的页面" | ||||
|   liked: "喜欢的页面" | ||||
|   featured: "热门" | ||||
|   inspector: "检查器" | ||||
|   contents: "内容" | ||||
|   content: "页面内容" | ||||
|   variables: "变量" | ||||
|   title: "标题" | ||||
| @@ -852,6 +1225,11 @@ _pages: | ||||
|       id: "画布ID" | ||||
|       width: "宽度" | ||||
|       height: "高度" | ||||
|     note: "嵌入的帖子" | ||||
|     _note: | ||||
|       id: "帖子ID" | ||||
|       idDescription: "您也可以通过粘贴帖子的URL来进行设置。" | ||||
|       detailed: "显示详细信息" | ||||
|     switch: "开关" | ||||
|     _switch: | ||||
|       name: "变量名" | ||||
| @@ -1066,3 +1444,50 @@ _relayStatus: | ||||
|   requesting: "待批准" | ||||
|   accepted: "已批准" | ||||
|   rejected: "已拒绝" | ||||
| _notification: | ||||
|   fileUploaded: "文件已上传" | ||||
|   youGotMention: "来自{name}的提及" | ||||
|   youGotReply: "来自{name}的回复" | ||||
|   youGotQuote: "来自{name}的引用" | ||||
|   youRenoted: "来自{name}的转发" | ||||
|   youGotPoll: "来自{name}的投票" | ||||
|   youGotMessagingMessageFromUser: "来自{name}的聊天" | ||||
|   youGotMessagingMessageFromGroup: "来自{name}的群聊" | ||||
|   youWereFollowed: "关注了你。" | ||||
|   youReceivedFollowRequest: "您有新的关注请求" | ||||
|   yourFollowRequestAccepted: "您的关注请求已通过" | ||||
|   youWereInvitedToGroup: "您有新的群组邀请" | ||||
|   _types: | ||||
|     all: "全部" | ||||
|     follow: "关注中" | ||||
|     mention: "提及" | ||||
|     reply: "回复" | ||||
|     renote: "转发" | ||||
|     quote: "引用" | ||||
|     reaction: "回应" | ||||
|     pollVote: "问卷调查已投票" | ||||
|     receiveFollowRequest: "收到关注请求" | ||||
|     followRequestAccepted: "关注请求已接受" | ||||
|     groupInvited: "加入群组邀请" | ||||
|     app: "关联应用的通知" | ||||
| _deck: | ||||
|   alwaysShowMainColumn: "总是显示主列" | ||||
|   columnAlign: "列对齐" | ||||
|   columnMargin: "列间距" | ||||
|   columnHeaderHeight: "列标题高度" | ||||
|   addColumn: "添加列" | ||||
|   swapLeft: "向左移动" | ||||
|   swapRight: "向右移动" | ||||
|   swapUp: "向上移动" | ||||
|   swapDown: "向下移动" | ||||
|   stackLeft: "向左折叠" | ||||
|   popRight: "向右弹出" | ||||
|   _columns: | ||||
|     main: "主列" | ||||
|     widgets: "小工具" | ||||
|     notifications: "通知" | ||||
|     tl: "时间线" | ||||
|     antenna: "天线" | ||||
|     list: "列表" | ||||
|     mentions: "提及" | ||||
|     direct: "指定用户" | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										14
									
								
								migration/1595075960584-blurhash.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								migration/1595075960584-blurhash.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class blurhash1595075960584 implements MigrationInterface { | ||||
|     name = 'blurhash1595075960584' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "drive_file" ADD "blurhash" character varying(128)`); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "drive_file" DROP COLUMN "blurhash"`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										20
									
								
								migration/1595077605646-blurhash-for-avatar-banner.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								migration/1595077605646-blurhash-for-avatar-banner.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class blurhashForAvatarBanner1595077605646 implements MigrationInterface { | ||||
|     name = 'blurhashForAvatarBanner1595077605646' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "user" DROP COLUMN "avatarColor"`); | ||||
|         await queryRunner.query(`ALTER TABLE "user" DROP COLUMN "bannerColor"`); | ||||
|         await queryRunner.query(`ALTER TABLE "user" ADD "avatarBlurhash" character varying(128)`); | ||||
|         await queryRunner.query(`ALTER TABLE "user" ADD "bannerBlurhash" character varying(128)`); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "user" DROP COLUMN "bannerBlurhash"`); | ||||
|         await queryRunner.query(`ALTER TABLE "user" DROP COLUMN "avatarBlurhash"`); | ||||
|         await queryRunner.query(`ALTER TABLE "user" ADD "bannerColor" character varying(32)`); | ||||
|         await queryRunner.query(`ALTER TABLE "user" ADD "avatarColor" character varying(32)`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										14
									
								
								migration/1595676934834-instance-icon-url.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								migration/1595676934834-instance-icon-url.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class instanceIconUrl1595676934834 implements MigrationInterface { | ||||
|     name = 'instanceIconUrl1595676934834' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "instance" ADD "iconUrl" character varying(256) DEFAULT null`); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "iconUrl"`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										30
									
								
								migration/1595771249699-word-mute.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								migration/1595771249699-word-mute.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class wordMute1595771249699 implements MigrationInterface { | ||||
|     name = 'wordMute1595771249699' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`CREATE TABLE "muted_note" ("id" character varying(32) NOT NULL, "noteId" character varying(32) NOT NULL, "userId" character varying(32) NOT NULL, CONSTRAINT "PK_897e2eff1c0b9b64e55ca1418a4" PRIMARY KEY ("id"))`); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_70ab9786313d78e4201d81cdb8" ON "muted_note" ("noteId") `); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_d8e07aa18c2d64e86201601aec" ON "muted_note" ("userId") `); | ||||
|         await queryRunner.query(`CREATE UNIQUE INDEX "IDX_a8c6bfd637d3f1d67a27c48e27" ON "muted_note" ("noteId", "userId") `); | ||||
|         await queryRunner.query(`ALTER TABLE "user_profile" ADD "enableWordMute" boolean NOT NULL DEFAULT false`); | ||||
|         await queryRunner.query(`ALTER TABLE "user_profile" ADD "mutedWords" jsonb NOT NULL DEFAULT '[]'`); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_3befe6f999c86aff06eb0257b4" ON "user_profile" ("enableWordMute") `); | ||||
|         await queryRunner.query(`ALTER TABLE "muted_note" ADD CONSTRAINT "FK_70ab9786313d78e4201d81cdb89" FOREIGN KEY ("noteId") REFERENCES "note"("id") ON DELETE CASCADE ON UPDATE NO ACTION`); | ||||
|         await queryRunner.query(`ALTER TABLE "muted_note" ADD CONSTRAINT "FK_d8e07aa18c2d64e86201601aec1" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "muted_note" DROP CONSTRAINT "FK_d8e07aa18c2d64e86201601aec1"`); | ||||
|         await queryRunner.query(`ALTER TABLE "muted_note" DROP CONSTRAINT "FK_70ab9786313d78e4201d81cdb89"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_3befe6f999c86aff06eb0257b4"`); | ||||
|         await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "mutedWords"`); | ||||
|         await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "enableWordMute"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_a8c6bfd637d3f1d67a27c48e27"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_d8e07aa18c2d64e86201601aec"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_70ab9786313d78e4201d81cdb8"`); | ||||
|         await queryRunner.query(`DROP TABLE "muted_note"`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										18
									
								
								migration/1595782306083-word-mute2.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								migration/1595782306083-word-mute2.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class wordMute21595782306083 implements MigrationInterface { | ||||
|     name = 'wordMute21595782306083' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`CREATE TYPE "muted_note_reason_enum" AS ENUM('word', 'manual', 'spam', 'other')`); | ||||
|         await queryRunner.query(`ALTER TABLE "muted_note" ADD "reason" "muted_note_reason_enum" NOT NULL`); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_636e977ff90b23676fb5624b25" ON "muted_note" ("reason") `); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`DROP INDEX "IDX_636e977ff90b23676fb5624b25"`); | ||||
|         await queryRunner.query(`ALTER TABLE "muted_note" DROP COLUMN "reason"`); | ||||
|         await queryRunner.query(`DROP TYPE "muted_note_reason_enum"`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										58
									
								
								migration/1596548170836-channel.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								migration/1596548170836-channel.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,58 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class channel1596548170836 implements MigrationInterface { | ||||
|     name = 'channel1596548170836' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`CREATE TABLE "channel" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "lastNotedAt" TIMESTAMP WITH TIME ZONE, "userId" character varying(32) NOT NULL, "name" character varying(128) NOT NULL, "description" character varying(2048), "bannerId" character varying(32), "notesCount" integer NOT NULL DEFAULT 0, "usersCount" integer NOT NULL DEFAULT 0, CONSTRAINT "PK_590f33ee6ee7d76437acf362e39" PRIMARY KEY ("id"))`); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_71cb7b435b7c0d4843317e7e16" ON "channel" ("createdAt") `); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_29ef80c6f13bcea998447fce43" ON "channel" ("lastNotedAt") `); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_823bae55bd81b3be6e05cff438" ON "channel" ("userId") `); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_0f58c11241e649d2a638a8de94" ON "channel" ("notesCount") `); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_094b86cd36bb805d1aa1e8cc9a" ON "channel" ("usersCount") `); | ||||
|         await queryRunner.query(`CREATE TABLE "channel_following" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "followeeId" character varying(32) NOT NULL, "followerId" character varying(32) NOT NULL, CONSTRAINT "PK_8b104be7f7415113f2a02cd5bdd" PRIMARY KEY ("id"))`); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_11e71f2511589dcc8a4d3214f9" ON "channel_following" ("createdAt") `); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_0e43068c3f92cab197c3d3cd86" ON "channel_following" ("followeeId") `); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_6d8084ec9496e7334a4602707e" ON "channel_following" ("followerId") `); | ||||
|         await queryRunner.query(`CREATE UNIQUE INDEX "IDX_2e230dd45a10e671d781d99f3e" ON "channel_following" ("followerId", "followeeId") `); | ||||
|         await queryRunner.query(`CREATE TABLE "channel_note_pining" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "channelId" character varying(32) NOT NULL, "noteId" character varying(32) NOT NULL, CONSTRAINT "PK_44f7474496bcf2e4b741681146d" PRIMARY KEY ("id"))`); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_8125f950afd3093acb10d2db8a" ON "channel_note_pining" ("channelId") `); | ||||
|         await queryRunner.query(`CREATE UNIQUE INDEX "IDX_f36fed37d6d4cdcc68c803cd9c" ON "channel_note_pining" ("channelId", "noteId") `); | ||||
|         await queryRunner.query(`ALTER TABLE "note" ADD "channelId" character varying(32) DEFAULT null`); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_f22169eb10657bded6d875ac8f" ON "note" ("channelId") `); | ||||
|         await queryRunner.query(`ALTER TABLE "channel" ADD CONSTRAINT "FK_823bae55bd81b3be6e05cff4383" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE SET NULL ON UPDATE NO ACTION`); | ||||
|         await queryRunner.query(`ALTER TABLE "channel" ADD CONSTRAINT "FK_999da2bcc7efadbfe0e92d3bc19" FOREIGN KEY ("bannerId") REFERENCES "drive_file"("id") ON DELETE SET NULL ON UPDATE NO ACTION`); | ||||
|         await queryRunner.query(`ALTER TABLE "note" ADD CONSTRAINT "FK_f22169eb10657bded6d875ac8f9" FOREIGN KEY ("channelId") REFERENCES "channel"("id") ON DELETE CASCADE ON UPDATE NO ACTION`); | ||||
|         await queryRunner.query(`ALTER TABLE "channel_following" ADD CONSTRAINT "FK_0e43068c3f92cab197c3d3cd86e" FOREIGN KEY ("followeeId") REFERENCES "channel"("id") ON DELETE CASCADE ON UPDATE NO ACTION`); | ||||
|         await queryRunner.query(`ALTER TABLE "channel_following" ADD CONSTRAINT "FK_6d8084ec9496e7334a4602707e1" FOREIGN KEY ("followerId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`); | ||||
|         await queryRunner.query(`ALTER TABLE "channel_note_pining" ADD CONSTRAINT "FK_8125f950afd3093acb10d2db8a8" FOREIGN KEY ("channelId") REFERENCES "channel"("id") ON DELETE CASCADE ON UPDATE NO ACTION`); | ||||
|         await queryRunner.query(`ALTER TABLE "channel_note_pining" ADD CONSTRAINT "FK_10b19ef67d297ea9de325cd4502" FOREIGN KEY ("noteId") REFERENCES "note"("id") ON DELETE CASCADE ON UPDATE NO ACTION`); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "channel_note_pining" DROP CONSTRAINT "FK_10b19ef67d297ea9de325cd4502"`); | ||||
|         await queryRunner.query(`ALTER TABLE "channel_note_pining" DROP CONSTRAINT "FK_8125f950afd3093acb10d2db8a8"`); | ||||
|         await queryRunner.query(`ALTER TABLE "channel_following" DROP CONSTRAINT "FK_6d8084ec9496e7334a4602707e1"`); | ||||
|         await queryRunner.query(`ALTER TABLE "channel_following" DROP CONSTRAINT "FK_0e43068c3f92cab197c3d3cd86e"`); | ||||
|         await queryRunner.query(`ALTER TABLE "note" DROP CONSTRAINT "FK_f22169eb10657bded6d875ac8f9"`); | ||||
|         await queryRunner.query(`ALTER TABLE "channel" DROP CONSTRAINT "FK_999da2bcc7efadbfe0e92d3bc19"`); | ||||
|         await queryRunner.query(`ALTER TABLE "channel" DROP CONSTRAINT "FK_823bae55bd81b3be6e05cff4383"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_f22169eb10657bded6d875ac8f"`); | ||||
|         await queryRunner.query(`ALTER TABLE "note" DROP COLUMN "channelId"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_f36fed37d6d4cdcc68c803cd9c"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_8125f950afd3093acb10d2db8a"`); | ||||
|         await queryRunner.query(`DROP TABLE "channel_note_pining"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_2e230dd45a10e671d781d99f3e"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_6d8084ec9496e7334a4602707e"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_0e43068c3f92cab197c3d3cd86"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_11e71f2511589dcc8a4d3214f9"`); | ||||
|         await queryRunner.query(`DROP TABLE "channel_following"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_094b86cd36bb805d1aa1e8cc9a"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_0f58c11241e649d2a638a8de94"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_823bae55bd81b3be6e05cff438"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_29ef80c6f13bcea998447fce43"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_71cb7b435b7c0d4843317e7e16"`); | ||||
|         await queryRunner.query(`DROP TABLE "channel"`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										14
									
								
								migration/1596786425167-channel2.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								migration/1596786425167-channel2.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class channel21596786425167 implements MigrationInterface { | ||||
|     name = 'channel21596786425167' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "channel_following" ADD "readCursor" TIMESTAMP WITH TIME ZONE NOT NULL`); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "channel_following" DROP COLUMN "readCursor"`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										14
									
								
								migration/1597230137744-objectStorageSetPublicRead.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								migration/1597230137744-objectStorageSetPublicRead.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class objectStorageSetPublicRead1597230137744 implements MigrationInterface { | ||||
|     name = 'objectStorageSetPublicRead1597230137744' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "objectStorageSetPublicRead" boolean NOT NULL DEFAULT false`); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStorageSetPublicRead"`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										16
									
								
								migration/1597236229720-IncludingNotificationTypes.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								migration/1597236229720-IncludingNotificationTypes.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class IncludingNotificationTypes1597236229720 implements MigrationInterface { | ||||
|     name = 'IncludingNotificationTypes1597236229720' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`CREATE TYPE "user_profile_includingnotificationtypes_enum" AS ENUM('follow', 'mention', 'reply', 'renote', 'quote', 'reaction', 'pollVote', 'receiveFollowRequest', 'followRequestAccepted', 'groupInvited', 'app')`); | ||||
|         await queryRunner.query(`ALTER TABLE "user_profile" ADD "includingNotificationTypes" "user_profile_includingnotificationtypes_enum" array`); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "includingNotificationTypes"`); | ||||
|         await queryRunner.query(`DROP TYPE "user_profile_includingnotificationtypes_enum"`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										14
									
								
								migration/1597385880794-add-sensitive-index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								migration/1597385880794-add-sensitive-index.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class addSensitiveIndex1597385880794 implements MigrationInterface { | ||||
|     name = 'addSensitiveIndex1597385880794' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_a7eba67f8b3fa27271e85d2e26" ON "drive_file" ("isSensitive") `); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`DROP INDEX "IDX_a7eba67f8b3fa27271e85d2e26"`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										27
									
								
								migration/1597459042300-channel-unread.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								migration/1597459042300-channel-unread.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class channelUnread1597459042300 implements MigrationInterface { | ||||
|     name = 'channelUnread1597459042300' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
| 				await queryRunner.query(`TRUNCATE TABLE "note_unread"`, undefined); | ||||
|         await queryRunner.query(`ALTER TABLE "channel_following" DROP COLUMN "readCursor"`); | ||||
|         await queryRunner.query(`ALTER TABLE "note_unread" ADD "isMentioned" boolean NOT NULL`); | ||||
|         await queryRunner.query(`ALTER TABLE "note_unread" ADD "noteChannelId" character varying(32)`); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_25b1dd384bec391b07b74b861c" ON "note_unread" ("isMentioned") `); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_89a29c9237b8c3b6b3cbb4cb30" ON "note_unread" ("isSpecified") `); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_29e8c1d579af54d4232939f994" ON "note_unread" ("noteUserId") `); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_6a57f051d82c6d4036c141e107" ON "note_unread" ("noteChannelId") `); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`DROP INDEX "IDX_6a57f051d82c6d4036c141e107"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_29e8c1d579af54d4232939f994"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_89a29c9237b8c3b6b3cbb4cb30"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_25b1dd384bec391b07b74b861c"`); | ||||
|         await queryRunner.query(`ALTER TABLE "note_unread" DROP COLUMN "noteChannelId"`); | ||||
|         await queryRunner.query(`ALTER TABLE "note_unread" DROP COLUMN "isMentioned"`); | ||||
|         await queryRunner.query(`ALTER TABLE "channel_following" ADD "readCursor" TIMESTAMP WITH TIME ZONE NOT NULL`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										16
									
								
								migration/1597893996136-ChannelNoteIdDescIndex.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								migration/1597893996136-ChannelNoteIdDescIndex.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class ChannelNoteIdDescIndex1597893996136 implements MigrationInterface { | ||||
|     name = 'ChannelNoteIdDescIndex1597893996136' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
| 				await queryRunner.query(`DROP INDEX "IDX_f22169eb10657bded6d875ac8f"`); | ||||
| 				await queryRunner.query(`CREATE INDEX "IDX_note_on_channelId_and_id_desc" ON "note" ("channelId", "id" desc)`); | ||||
| 		} | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
| 				await queryRunner.query(`DROP INDEX "IDX_note_on_channelId_and_id_desc"`); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_f22169eb10657bded6d875ac8f" ON "note" ("channelId") `); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										20
									
								
								migration/1600353287890-mutingNotificationTypes.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								migration/1600353287890-mutingNotificationTypes.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class mutingNotificationTypes1600353287890 implements MigrationInterface { | ||||
|     name = 'mutingNotificationTypes1600353287890' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "includingNotificationTypes"`); | ||||
|         await queryRunner.query(`DROP TYPE "public"."user_profile_includingnotificationtypes_enum"`); | ||||
|         await queryRunner.query(`CREATE TYPE "user_profile_mutingnotificationtypes_enum" AS ENUM('follow', 'mention', 'reply', 'renote', 'quote', 'reaction', 'pollVote', 'receiveFollowRequest', 'followRequestAccepted', 'groupInvited', 'app')`); | ||||
|         await queryRunner.query(`ALTER TABLE "user_profile" ADD "mutingNotificationTypes" "user_profile_mutingnotificationtypes_enum" array NOT NULL DEFAULT '{}'`); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "mutingNotificationTypes"`); | ||||
|         await queryRunner.query(`DROP TYPE "user_profile_mutingnotificationtypes_enum"`); | ||||
|         await queryRunner.query(`CREATE TYPE "public"."user_profile_includingnotificationtypes_enum" AS ENUM('follow', 'mention', 'reply', 'renote', 'quote', 'reaction', 'pollVote', 'receiveFollowRequest', 'followRequestAccepted', 'groupInvited', 'app')`); | ||||
|         await queryRunner.query(`ALTER TABLE "user_profile" ADD "includingNotificationTypes" "user_profile_includingnotificationtypes_enum" array`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										32
									
								
								migration/1603094348345-refine-abuse-user-report.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								migration/1603094348345-refine-abuse-user-report.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class refineAbuseUserReport1603094348345 implements MigrationInterface { | ||||
|     name = 'refineAbuseUserReport1603094348345' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" DROP CONSTRAINT "FK_d049123c413e68ca52abe734203"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_d049123c413e68ca52abe73420"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_5cd442c3b2e74fdd99dae20243"`); | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" RENAME COLUMN "userId" TO "targetUserId"`); | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" ADD "assigneeId" character varying(32)`); | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" ADD "resolved" boolean NOT NULL DEFAULT false`); | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" DROP COLUMN "comment"`); | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" ADD "comment" character varying(2048) NOT NULL DEFAULT '{}'::varchar[]`); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_2b15aaf4a0dc5be3499af7ab6a" ON "abuse_user_report" ("resolved") `); | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" ADD CONSTRAINT "FK_08b883dd5fdd6f9c4c1572b36de" FOREIGN KEY ("assigneeId") REFERENCES "user"("id") ON DELETE SET NULL ON UPDATE NO ACTION`); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" DROP CONSTRAINT "FK_08b883dd5fdd6f9c4c1572b36de"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_2b15aaf4a0dc5be3499af7ab6a"`); | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" DROP COLUMN "comment"`); | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" ADD "comment" character varying(512) NOT NULL DEFAULT '{}'::varchar[]`); | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" DROP COLUMN "resolved"`); | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" DROP COLUMN "assigneeId"`); | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" RENAME COLUMN "targetUserId" TO "userId"`); | ||||
|         await queryRunner.query(`CREATE UNIQUE INDEX "IDX_5cd442c3b2e74fdd99dae20243" ON "abuse_user_report" ("userId", "reporterId") `); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_d049123c413e68ca52abe73420" ON "abuse_user_report" ("userId") `); | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" ADD CONSTRAINT "FK_d049123c413e68ca52abe734203" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										20
									
								
								migration/1603095701770-refine-abuse-user-report2.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								migration/1603095701770-refine-abuse-user-report2.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class refineAbuseUserReport21603095701770 implements MigrationInterface { | ||||
|     name = 'refineAbuseUserReport21603095701770' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" ADD "targetUserHost" character varying(128)`); | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" ADD "reporterHost" character varying(128)`); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_4ebbf7f93cdc10e8d1ef2fc6cd" ON "abuse_user_report" ("targetUserHost") `); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_f8d8b93740ad12c4ce8213a199" ON "abuse_user_report" ("reporterHost") `); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`DROP INDEX "IDX_f8d8b93740ad12c4ce8213a199"`); | ||||
|         await queryRunner.query(`DROP INDEX "IDX_4ebbf7f93cdc10e8d1ef2fc6cd"`); | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" DROP COLUMN "reporterHost"`); | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" DROP COLUMN "targetUserHost"`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										14
									
								
								migration/1603776877564-instance-theme-color.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								migration/1603776877564-instance-theme-color.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class instanceThemeColor1603776877564 implements MigrationInterface { | ||||
|     name = 'instanceThemeColor1603776877564' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "instance" ADD "themeColor" character varying(64) DEFAULT null`); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "themeColor"`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										14
									
								
								migration/1603781553011-instance-favicon.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								migration/1603781553011-instance-favicon.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class instanceFavicon1603781553011 implements MigrationInterface { | ||||
|     name = 'instanceFavicon1603781553011' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "instance" ADD "faviconUrl" character varying(256) DEFAULT null`); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "faviconUrl"`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										14
									
								
								migration/1604821689616-delete-auto-watch.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								migration/1604821689616-delete-auto-watch.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class deleteAutoWatch1604821689616 implements MigrationInterface { | ||||
|     name = 'deleteAutoWatch1604821689616' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "autoWatch"`); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "user_profile" ADD "autoWatch" boolean NOT NULL DEFAULT false`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										15
									
								
								migration/1605408848373-clip-description.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								migration/1605408848373-clip-description.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class clipDescription1605408848373 implements MigrationInterface { | ||||
|     name = 'clipDescription1605408848373' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "clip" ADD "description" character varying(2048) DEFAULT null`); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|  | ||||
|         await queryRunner.query(`ALTER TABLE "clip" DROP COLUMN "description"`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										434
									
								
								migration/1605408971051-comments.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										434
									
								
								migration/1605408971051-comments.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,434 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class comments1605408971051 implements MigrationInterface { | ||||
|     name = 'comments1605408971051' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "log"."createdAt" IS 'The created date of the Log.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_folder"."createdAt" IS 'The created date of the DriveFolder.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_folder"."name" IS 'The name of the DriveFolder.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_folder"."userId" IS 'The owner ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_folder"."parentId" IS 'The parent folder ID. If null, it means the DriveFolder is located in root.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."createdAt" IS 'The created date of the DriveFile.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."userId" IS 'The owner ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."userHost" IS 'The host of owner. It will be null if the user in local.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."md5" IS 'The MD5 hash of the DriveFile.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."name" IS 'The file name of the DriveFile.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."type" IS 'The content type (MIME) of the DriveFile.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."size" IS 'The file size (bytes) of the DriveFile.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."comment" IS 'The comment of the DriveFile.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."blurhash" IS 'The BlurHash string.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."properties" IS 'The any properties of the DriveFile. For example, it includes image width/height.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."url" IS 'The URL of the DriveFile.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."thumbnailUrl" IS 'The URL of the thumbnail of the DriveFile.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."webpublicUrl" IS 'The URL of the webpublic of the DriveFile.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."uri" IS 'The URI of the DriveFile. it will be null when the DriveFile is local.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."folderId" IS 'The parent folder ID. If null, it means the DriveFile is located in root.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."isSensitive" IS 'Whether the DriveFile is NSFW.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."isLink" IS 'Whether the DriveFile is direct link to remote server.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."createdAt" IS 'The created date of the User.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."updatedAt" IS 'The updated date of the User.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."username" IS 'The username of the User.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."usernameLower" IS 'The username (lowercased) of the User.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."name" IS 'The name of the User.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."followersCount" IS 'The count of followers.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."followingCount" IS 'The count of following.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."notesCount" IS 'The count of notes.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."avatarId" IS 'The ID of avatar DriveFile.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."bannerId" IS 'The ID of banner DriveFile.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."isSuspended" IS 'Whether the User is suspended.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."isSilenced" IS 'Whether the User is silenced.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."isLocked" IS 'Whether the User is locked.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."isBot" IS 'Whether the User is a bot.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."isCat" IS 'Whether the User is a cat.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."isAdmin" IS 'Whether the User is the admin.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."isModerator" IS 'Whether the User is a moderator.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."host" IS 'The host of the User. It will be null if the origin of the user is local.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."inbox" IS 'The inbox URL of the User. It will be null if the origin of the user is local.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."sharedInbox" IS 'The sharedInbox URL of the User. It will be null if the origin of the user is local.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."featured" IS 'The featured URL of the User. It will be null if the origin of the user is local.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."uri" IS 'The URI of the User. It will be null if the origin of the user is local.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."token" IS 'The native access token of the User. It will be null if the origin of the user is local.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "app"."createdAt" IS 'The created date of the App.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "app"."userId" IS 'The owner ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "app"."secret" IS 'The secret key of the App.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "app"."name" IS 'The name of the App.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "app"."description" IS 'The description of the App.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "app"."permission" IS 'The permission of the App.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "app"."callbackUrl" IS 'The callbackUrl of the App.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "access_token"."createdAt" IS 'The created date of the AccessToken.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "access_token"."lastUsedAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "access_token"."session" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "access_token"."appId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "access_token"."name" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "access_token"."description" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "access_token"."iconUrl" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel"."createdAt" IS 'The created date of the Channel.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel"."userId" IS 'The owner ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel"."name" IS 'The name of the Channel.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel"."description" IS 'The description of the Channel.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel"."bannerId" IS 'The ID of banner Channel.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel"."notesCount" IS 'The count of notes.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel"."usersCount" IS 'The count of users.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."createdAt" IS 'The created date of the Note.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."replyId" IS 'The ID of reply target.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."renoteId" IS 'The ID of renote target.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."userId" IS 'The ID of author.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."uri" IS 'The URI of a note. it will be null when the note is local.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."url" IS 'The human readable url of a note. it will be null when the note is local.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."channelId" IS 'The ID of source channel.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."userHost" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."replyUserId" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."replyUserHost" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."renoteUserId" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."renoteUserHost" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "poll_vote"."createdAt" IS 'The created date of the PollVote.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note_reaction"."createdAt" IS 'The created date of the NoteReaction.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note_watching"."createdAt" IS 'The created date of the NoteWatching.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note_watching"."userId" IS 'The watcher ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note_watching"."noteId" IS 'The target Note ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note_watching"."noteUserId" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note_unread"."noteUserId" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note_unread"."noteChannelId" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "follow_request"."createdAt" IS 'The created date of the FollowRequest.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followeeId" IS 'The followee user ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followerId" IS 'The follower user ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "follow_request"."requestId" IS 'id of Follow Activity.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followerHost" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followerInbox" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followerSharedInbox" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followeeHost" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followeeInbox" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followeeSharedInbox" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_group"."createdAt" IS 'The created date of the UserGroup.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_group"."userId" IS 'The ID of owner.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_group_invitation"."createdAt" IS 'The created date of the UserGroupInvitation.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_group_invitation"."userId" IS 'The user ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_group_invitation"."userGroupId" IS 'The group ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "notification"."createdAt" IS 'The created date of the Notification.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "notification"."notifieeId" IS 'The ID of recipient user of the Notification.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "notification"."isRead" IS 'Whether the Notification is read.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "meta"."localDriveCapacityMb" IS 'Drive capacity of a local user (MB)'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "meta"."remoteDriveCapacityMb" IS 'Drive capacity of a remote user (MB)'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "meta"."maxNoteTextLength" IS 'Max allowed note text length in characters'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "following"."createdAt" IS 'The created date of the Following.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "following"."followeeId" IS 'The followee user ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "following"."followerId" IS 'The follower user ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "following"."followerHost" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "following"."followerInbox" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "following"."followerSharedInbox" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "following"."followeeHost" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "following"."followeeInbox" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "following"."followeeSharedInbox" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."caughtAt" IS 'The caught date of the Instance.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."host" IS 'The host of the Instance.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."usersCount" IS 'The count of the users of the Instance.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."notesCount" IS 'The count of the notes of the Instance.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."softwareName" IS 'The software of the Instance.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."softwareVersion" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."openRegistrations" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."name" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."description" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."maintainerName" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."maintainerEmail" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."iconUrl" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."faviconUrl" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."themeColor" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "muting"."createdAt" IS 'The created date of the Muting.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "muting"."muteeId" IS 'The mutee user ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "muting"."muterId" IS 'The muter user ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "blocking"."createdAt" IS 'The created date of the Blocking.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "blocking"."blockeeId" IS 'The blockee user ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "blocking"."blockerId" IS 'The blocker user ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_list"."createdAt" IS 'The created date of the UserList.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_list"."userId" IS 'The owner ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_list"."name" IS 'The name of the UserList.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_list_joining"."createdAt" IS 'The created date of the UserListJoining.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_list_joining"."userId" IS 'The user ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_list_joining"."userListId" IS 'The list ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_group_joining"."createdAt" IS 'The created date of the UserGroupJoining.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_group_joining"."userId" IS 'The user ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_group_joining"."userGroupId" IS 'The group ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note_favorite"."createdAt" IS 'The created date of the NoteFavorite.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "abuse_user_report"."createdAt" IS 'The created date of the AbuseUserReport.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "abuse_user_report"."targetUserHost" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "abuse_user_report"."reporterHost" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "messaging_message"."createdAt" IS 'The created date of the MessagingMessage.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "messaging_message"."userId" IS 'The sender user ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "messaging_message"."groupId" IS 'The recipient group ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "signin"."createdAt" IS 'The created date of the Signin.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "auth_session"."createdAt" IS 'The created date of the AuthSession.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "reversi_game"."createdAt" IS 'The created date of the ReversiGame.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "reversi_game"."startedAt" IS 'The started date of the ReversiGame.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "reversi_game"."form1" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "reversi_game"."form2" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "reversi_matching"."createdAt" IS 'The created date of the ReversiMatching.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_note_pining"."createdAt" IS 'The created date of the UserNotePinings.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "poll"."noteId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "poll"."noteVisibility" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "poll"."userId" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "poll"."userHost" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_keypair"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_publickey"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "page"."createdAt" IS 'The created date of the Page.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "page"."updatedAt" IS 'The updated date of the Page.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "page"."userId" IS 'The ID of author.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."location" IS 'The location of the User.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."birthday" IS 'The birthday (YYYY-MM-DD) of the User.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."description" IS 'The description (bio) of the User.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."url" IS 'Remote URL of the user.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."email" IS 'The email address of the User.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."password" IS 'The password hash of the User. It will be null if the origin of the user is local.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."clientData" IS 'The client-specific data of the User.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."room" IS 'The room data of the User.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."userHost" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_security_key"."id" IS 'Variable-length id given to navigator.credentials.get()'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_security_key"."publicKey" IS 'Variable-length public key used to verify attestations (hex-encoded).'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_security_key"."lastUsed" IS 'The date of the last time the UserSecurityKey was successfully validated.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_security_key"."name" IS 'User-defined name for this key'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "attestation_challenge"."challenge" IS 'Hex-encoded sha256 hash of the challenge.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "attestation_challenge"."createdAt" IS 'The date challenge was created for expiry purposes.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "attestation_challenge"."registrationChallenge" IS 'Indicates that the challenge is only for registration purposes if true to prevent the challenge for being used as authentication.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "moderation_log"."createdAt" IS 'The created date of the ModerationLog.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "announcement"."createdAt" IS 'The created date of the Announcement.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "announcement"."updatedAt" IS 'The updated date of the Announcement.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "announcement_read"."createdAt" IS 'The created date of the AnnouncementRead.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "clip"."createdAt" IS 'The created date of the Clip.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "clip"."userId" IS 'The owner ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "clip"."name" IS 'The name of the Clip.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "clip"."description" IS 'The description of the Clip.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "clip_note"."noteId" IS 'The note ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "clip_note"."clipId" IS 'The clip ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "antenna"."createdAt" IS 'The created date of the Antenna.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "antenna"."userId" IS 'The owner ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "antenna"."name" IS 'The name of the Antenna.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "antenna_note"."noteId" IS 'The note ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "antenna_note"."antennaId" IS 'The antenna ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "promo_note"."noteId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "promo_note"."userId" IS '[Denormalized]'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "promo_read"."createdAt" IS 'The created date of the PromoRead.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "muted_note"."noteId" IS 'The note ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "muted_note"."userId" IS 'The user ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "muted_note"."reason" IS 'The reason of the MutedNote.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel_following"."createdAt" IS 'The created date of the ChannelFollowing.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel_following"."followeeId" IS 'The followee channel ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel_following"."followerId" IS 'The follower user ID.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel_note_pining"."createdAt" IS 'The created date of the ChannelNotePining.'`); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel_note_pining"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel_following"."followerId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel_following"."followeeId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel_following"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "muted_note"."reason" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "muted_note"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "muted_note"."noteId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "promo_read"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "promo_note"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "promo_note"."noteId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "antenna_note"."antennaId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "antenna_note"."noteId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "antenna"."name" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "antenna"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "antenna"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "clip_note"."clipId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "clip_note"."noteId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "clip"."description" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "clip"."name" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "clip"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "clip"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "announcement_read"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "announcement"."updatedAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "announcement"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "moderation_log"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "attestation_challenge"."registrationChallenge" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "attestation_challenge"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "attestation_challenge"."challenge" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_security_key"."name" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_security_key"."lastUsed" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_security_key"."publicKey" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_security_key"."id" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."userHost" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."room" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."clientData" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."password" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."email" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."url" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."description" IS 'The description (bio) of the User.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."birthday" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."location" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "page"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "page"."updatedAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "page"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_publickey"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_keypair"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "poll"."userHost" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "poll"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "poll"."noteVisibility" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "poll"."noteId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_note_pining"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "reversi_matching"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "reversi_game"."form2" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "reversi_game"."form1" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "reversi_game"."startedAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "reversi_game"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "auth_session"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "signin"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "messaging_message"."groupId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "messaging_message"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "messaging_message"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "abuse_user_report"."reporterHost" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "abuse_user_report"."targetUserHost" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "abuse_user_report"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note_favorite"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_group_joining"."userGroupId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_group_joining"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_group_joining"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_list_joining"."userListId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_list_joining"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_list_joining"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_list"."name" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_list"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_list"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "blocking"."blockerId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "blocking"."blockeeId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "blocking"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "muting"."muterId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "muting"."muteeId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "muting"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."themeColor" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."faviconUrl" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."iconUrl" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."maintainerEmail" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."maintainerName" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."description" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."name" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."openRegistrations" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."softwareVersion" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."softwareName" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."notesCount" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."usersCount" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."host" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "instance"."caughtAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "following"."followeeSharedInbox" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "following"."followeeInbox" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "following"."followeeHost" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "following"."followerSharedInbox" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "following"."followerInbox" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "following"."followerHost" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "following"."followerId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "following"."followeeId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "following"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "meta"."maxNoteTextLength" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "meta"."remoteDriveCapacityMb" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "meta"."localDriveCapacityMb" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "notification"."isRead" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "notification"."notifieeId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "notification"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_group_invitation"."userGroupId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_group_invitation"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_group_invitation"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_group"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_group"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followeeSharedInbox" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followeeInbox" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followeeHost" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followerSharedInbox" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followerInbox" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followerHost" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "follow_request"."requestId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followerId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followeeId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "follow_request"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note_unread"."noteChannelId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note_unread"."noteUserId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note_watching"."noteUserId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note_watching"."noteId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note_watching"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note_watching"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note_reaction"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "poll_vote"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."renoteUserHost" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."renoteUserId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."replyUserHost" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."replyUserId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."userHost" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."channelId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."url" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."uri" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."renoteId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."replyId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "note"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel"."usersCount" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel"."notesCount" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel"."bannerId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel"."description" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel"."name" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "channel"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "access_token"."iconUrl" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "access_token"."description" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "access_token"."name" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "access_token"."appId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "access_token"."session" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "access_token"."lastUsedAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "access_token"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "app"."callbackUrl" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "app"."permission" IS 'The permission of the App.'`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "app"."description" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "app"."name" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "app"."secret" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "app"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "app"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."token" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."uri" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."featured" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."sharedInbox" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."inbox" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."host" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."isModerator" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."isAdmin" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."isCat" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."isBot" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."isLocked" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."isSilenced" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."isSuspended" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."bannerId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."avatarId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."notesCount" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."followingCount" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."followersCount" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."name" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."usernameLower" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."username" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."updatedAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."isLink" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."isSensitive" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."folderId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."uri" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."webpublicUrl" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."thumbnailUrl" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."url" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."properties" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."blurhash" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."comment" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."size" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."type" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."name" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."md5" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."userHost" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_file"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_folder"."parentId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_folder"."userId" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_folder"."name" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "drive_folder"."createdAt" IS NULL`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "log"."createdAt" IS NULL`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										14
									
								
								migration/1605585339718-instance-pinned-pages.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								migration/1605585339718-instance-pinned-pages.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class instancePinnedPages1605585339718 implements MigrationInterface { | ||||
|     name = 'instancePinnedPages1605585339718' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "pinnedPages" character varying(512) array NOT NULL DEFAULT '{"/featured", "/channels", "/explore", "/pages", "/about-misskey"}'::varchar[]`); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "pinnedPages"`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										16
									
								
								migration/1605965516823-instance-images.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								migration/1605965516823-instance-images.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class instanceImages1605965516823 implements MigrationInterface { | ||||
|     name = 'instanceImages1605965516823' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "backgroundImageUrl" character varying(512)`); | ||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "logoImageUrl" character varying(512)`); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "logoImageUrl"`); | ||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "backgroundImageUrl"`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										16
									
								
								migration/1606191203881-no-crawle.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								migration/1606191203881-no-crawle.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class noCrawle1606191203881 implements MigrationInterface { | ||||
|     name = 'noCrawle1606191203881' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "user_profile" ADD "noCrawle" boolean NOT NULL DEFAULT false`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."noCrawle" IS 'Whether reject index by crawler.'`); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user_profile"."noCrawle" IS 'Whether reject index by crawler.'`); | ||||
|         await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "noCrawle"`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										14
									
								
								migration/1607151207216-instance-pinned-clip.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								migration/1607151207216-instance-pinned-clip.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class instancePinnedClip1607151207216 implements MigrationInterface { | ||||
|     name = 'instancePinnedClip1607151207216' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "pinnedClipId" character varying(32)`); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "pinnedClipId"`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										18
									
								
								migration/1607353487793-isExplorable.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								migration/1607353487793-isExplorable.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | ||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | ||||
|  | ||||
| export class isExplorable1607353487793 implements MigrationInterface { | ||||
|     name = 'isExplorable1607353487793' | ||||
|  | ||||
|     public async up(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`ALTER TABLE "user" ADD "isExplorable" boolean NOT NULL DEFAULT true`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."isExplorable" IS 'Whether the User is explorable.'`); | ||||
|         await queryRunner.query(`CREATE INDEX "IDX_d5a1b83c7cab66f167e6888188" ON "user" ("isExplorable") `); | ||||
|     } | ||||
|  | ||||
|     public async down(queryRunner: QueryRunner): Promise<void> { | ||||
|         await queryRunner.query(`DROP INDEX "IDX_d5a1b83c7cab66f167e6888188"`); | ||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."isExplorable" IS 'Whether the User is explorable.'`); | ||||
|         await queryRunner.query(`ALTER TABLE "user" DROP COLUMN "isExplorable"`); | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										242
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										242
									
								
								package.json
									
									
									
									
									
								
							| @@ -1,7 +1,7 @@ | ||||
| { | ||||
| 	"name": "misskey", | ||||
| 	"author": "syuilo <syuilotan@yahoo.co.jp>", | ||||
| 	"version": "12.38.0", | ||||
| 	"version": "12.64.1", | ||||
| 	"codename": "indigo", | ||||
| 	"repository": { | ||||
| 		"type": "git", | ||||
| @@ -30,40 +30,39 @@ | ||||
| 	"resolutions": { | ||||
| 		"chokidar": "^3.3.1", | ||||
| 		"constantinople": "^4.0.1", | ||||
| 		"core-js": "^3.6.5", | ||||
| 		"lodash": "^4.17.15", | ||||
| 		"mocha": "^7.1.1" | ||||
| 		"gulp/gulp-cli/yargs/yargs-parser": "5.0.0-security.0", | ||||
| 		"jsonld/rdf-canonize/node-forge": "0.10.0", | ||||
| 		"lodash": "^4.17.20" | ||||
| 	}, | ||||
| 	"dependencies": { | ||||
| 		"@babel/plugin-transform-runtime": "7.9.6", | ||||
| 		"@elastic/elasticsearch": "7.7.1", | ||||
| 		"@fortawesome/fontawesome-svg-core": "1.2.28", | ||||
| 		"@fortawesome/free-brands-svg-icons": "5.13.0", | ||||
| 		"@fortawesome/free-regular-svg-icons": "5.13.0", | ||||
| 		"@fortawesome/free-solid-svg-icons": "5.13.0", | ||||
| 		"@fortawesome/vue-fontawesome": "0.1.9", | ||||
| 		"@juggle/resize-observer": "3.1.3", | ||||
| 		"@koa/cors": "3.0.0", | ||||
| 		"@koa/multer": "2.0.2", | ||||
| 		"@koa/router": "8.0.8", | ||||
| 		"@babel/plugin-transform-runtime": "7.12.1", | ||||
| 		"@elastic/elasticsearch": "7.10.0", | ||||
| 		"@fortawesome/fontawesome-svg-core": "1.2.32", | ||||
| 		"@fortawesome/free-brands-svg-icons": "5.15.1", | ||||
| 		"@fortawesome/free-regular-svg-icons": "5.15.1", | ||||
| 		"@fortawesome/free-solid-svg-icons": "5.15.1", | ||||
| 		"@fortawesome/vue-fontawesome": "3.0.0-3", | ||||
| 		"@koa/cors": "3.1.0", | ||||
| 		"@koa/multer": "3.0.0", | ||||
| 		"@koa/router": "9.0.1", | ||||
| 		"@sinonjs/fake-timers": "6.0.1", | ||||
| 		"@syuilo/aiscript": "0.6.1", | ||||
| 		"@syuilo/aiscript": "0.11.1", | ||||
| 		"@types/bcryptjs": "2.4.2", | ||||
| 		"@types/bull": "3.13.0", | ||||
| 		"@types/cbor": "5.0.0", | ||||
| 		"@types/bull": "3.14.4", | ||||
| 		"@types/cbor": "5.0.1", | ||||
| 		"@types/dateformat": "3.0.1", | ||||
| 		"@types/double-ended-queue": "2.1.1", | ||||
| 		"@types/escape-regexp": "0.0.0", | ||||
| 		"@types/glob": "7.1.1", | ||||
| 		"@types/glob": "7.1.3", | ||||
| 		"@types/gulp": "4.0.6", | ||||
| 		"@types/gulp-rename": "0.0.33", | ||||
| 		"@types/gulp-replace": "0.0.31", | ||||
| 		"@types/is-url": "1.2.28", | ||||
| 		"@types/js-yaml": "3.12.4", | ||||
| 		"@types/jsdom": "16.2.3", | ||||
| 		"@types/js-yaml": "3.12.5", | ||||
| 		"@types/jsdom": "16.2.5", | ||||
| 		"@types/jsonld": "1.5.1", | ||||
| 		"@types/katex": "0.11.0", | ||||
| 		"@types/koa": "2.11.3", | ||||
| 		"@types/koa": "2.11.6", | ||||
| 		"@types/koa-bodyparser": "4.3.0", | ||||
| 		"@types/koa-cors": "0.0.0", | ||||
| 		"@types/koa-favicon": "2.0.19", | ||||
| @@ -71,203 +70,198 @@ | ||||
| 		"@types/koa-mount": "4.0.0", | ||||
| 		"@types/koa-send": "4.1.2", | ||||
| 		"@types/koa-views": "2.0.4", | ||||
| 		"@types/koa__cors": "3.0.1", | ||||
| 		"@types/koa__multer": "2.0.1", | ||||
| 		"@types/koa__cors": "3.0.2", | ||||
| 		"@types/koa__multer": "2.0.2", | ||||
| 		"@types/koa__router": "8.0.2", | ||||
| 		"@types/markdown-it": "10.0.1", | ||||
| 		"@types/markdown-it": "10.0.3", | ||||
| 		"@types/matter-js": "0.14.8", | ||||
| 		"@types/mocha": "7.0.2", | ||||
| 		"@types/node": "14.0.1", | ||||
| 		"@types/node": "14.14.13", | ||||
| 		"@types/node-fetch": "2.5.7", | ||||
| 		"@types/nodemailer": "6.4.0", | ||||
| 		"@types/nprogress": "0.2.0", | ||||
| 		"@types/oauth": "0.9.1", | ||||
| 		"@types/parse5": "5.0.3", | ||||
| 		"@types/parsimmon": "1.10.2", | ||||
| 		"@types/parsimmon": "1.10.6", | ||||
| 		"@types/portscanner": "2.1.0", | ||||
| 		"@types/pug": "2.0.4", | ||||
| 		"@types/qrcode": "1.3.4", | ||||
| 		"@types/qrcode": "1.3.5", | ||||
| 		"@types/random-seed": "0.3.3", | ||||
| 		"@types/ratelimiter": "2.1.28", | ||||
| 		"@types/redis": "2.8.21", | ||||
| 		"@types/rename": "1.0.1", | ||||
| 		"@types/ratelimiter": "3.4.0", | ||||
| 		"@types/redis": "2.8.28", | ||||
| 		"@types/rename": "1.0.2", | ||||
| 		"@types/request-stats": "3.0.0", | ||||
| 		"@types/rimraf": "3.0.0", | ||||
| 		"@types/seedrandom": "2.4.28", | ||||
| 		"@types/sharp": "0.25.0", | ||||
| 		"@types/sharp": "0.26.1", | ||||
| 		"@types/sinonjs__fake-timers": "6.0.1", | ||||
| 		"@types/speakeasy": "2.0.5", | ||||
| 		"@types/tinycolor2": "1.4.2", | ||||
| 		"@types/tmp": "0.2.0", | ||||
| 		"@types/uuid": "7.0.3", | ||||
| 		"@types/uuid": "8.3.0", | ||||
| 		"@types/web-push": "3.3.0", | ||||
| 		"@types/webpack": "4.41.13", | ||||
| 		"@types/webpack": "4.41.25", | ||||
| 		"@types/webpack-stream": "3.2.11", | ||||
| 		"@types/websocket": "1.0.0", | ||||
| 		"@types/ws": "7.2.4", | ||||
| 		"@typescript-eslint/parser": "2.33.0", | ||||
| 		"@types/websocket": "1.0.1", | ||||
| 		"@types/ws": "7.4.0", | ||||
| 		"@typescript-eslint/parser": "4.10.0", | ||||
| 		"@vue/compiler-sfc": "3.0.3", | ||||
| 		"abort-controller": "3.0.0", | ||||
| 		"apexcharts": "3.19.0", | ||||
| 		"apexcharts": "3.22.3", | ||||
| 		"autobind-decorator": "2.4.0", | ||||
| 		"autosize": "4.0.2", | ||||
| 		"autwh": "0.1.0", | ||||
| 		"aws-sdk": "2.678.0", | ||||
| 		"aws-sdk": "2.809.0", | ||||
| 		"bcryptjs": "2.4.3", | ||||
| 		"bull": "3.14.0", | ||||
| 		"blurhash": "1.1.3", | ||||
| 		"bull": "3.20.0", | ||||
| 		"cafy": "15.2.1", | ||||
| 		"cbor": "5.0.2", | ||||
| 		"chalk": "4.0.0", | ||||
| 		"chart.js": "2.9.3", | ||||
| 		"cli-highlight": "2.1.4", | ||||
| 		"cbor": "5.1.0", | ||||
| 		"chalk": "4.1.0", | ||||
| 		"chart.js": "2.9.4", | ||||
| 		"cli-highlight": "2.1.9", | ||||
| 		"commander": "4.1.1", | ||||
| 		"content-disposition": "0.5.3", | ||||
| 		"core-js": "3.6.5", | ||||
| 		"core-js": "3.8.1", | ||||
| 		"crc-32": "1.2.0", | ||||
| 		"css-loader": "3.5.3", | ||||
| 		"css-loader": "5.0.1", | ||||
| 		"cssnano": "4.1.10", | ||||
| 		"dateformat": "3.0.3", | ||||
| 		"dateformat": "4.3.1", | ||||
| 		"deep-entries": "3.1.0", | ||||
| 		"diskusage": "1.1.3", | ||||
| 		"double-ended-queue": "2.1.0-0", | ||||
| 		"escape-regexp": "0.0.1", | ||||
| 		"eslint": "6.8.0", | ||||
| 		"eslint-plugin-vue": "6.2.2", | ||||
| 		"eventemitter3": "4.0.4", | ||||
| 		"feed": "4.1.0", | ||||
| 		"eslint": "7.16.0", | ||||
| 		"eslint-plugin-vue": "7.3.0", | ||||
| 		"eventemitter3": "4.0.7", | ||||
| 		"feed": "4.2.1", | ||||
| 		"fibers": "5.0.0", | ||||
| 		"file-type": "14.4.0", | ||||
| 		"file-type": "16.0.1", | ||||
| 		"fluent-ffmpeg": "2.1.2", | ||||
| 		"glob": "7.1.6", | ||||
| 		"got": "11.8.1", | ||||
| 		"gulp": "4.0.2", | ||||
| 		"gulp-clean-css": "4.3.0", | ||||
| 		"gulp-dart-sass": "1.0.2", | ||||
| 		"gulp-cssnano": "2.1.3", | ||||
| 		"gulp-rename": "2.0.0", | ||||
| 		"gulp-replace": "1.0.0", | ||||
| 		"gulp-sourcemaps": "2.6.5", | ||||
| 		"gulp-terser": "1.2.0", | ||||
| 		"gulp-terser": "2.0.0", | ||||
| 		"gulp-tslint": "8.1.4", | ||||
| 		"gulp-typescript": "6.0.0-alpha.1", | ||||
| 		"hard-source-webpack-plugin": "0.13.1", | ||||
| 		"hcaptcha": "0.0.1", | ||||
| 		"hcaptcha": "0.0.2", | ||||
| 		"html-minifier": "4.0.0", | ||||
| 		"http-proxy-agent": "4.0.1", | ||||
| 		"http-signature": "1.3.4", | ||||
| 		"http-signature": "1.3.5", | ||||
| 		"https-proxy-agent": "5.0.0", | ||||
| 		"insert-text-at-cursor": "0.3.0", | ||||
| 		"is-root": "2.1.0", | ||||
| 		"is-svg": "4.2.1", | ||||
| 		"js-yaml": "3.13.1", | ||||
| 		"jsdom": "16.2.2", | ||||
| 		"js-yaml": "3.14.0", | ||||
| 		"jsdom": "16.4.0", | ||||
| 		"json5": "2.1.3", | ||||
| 		"json5-loader": "4.0.0", | ||||
| 		"jsonld": "3.1.0", | ||||
| 		"jsrsasign": "8.0.15", | ||||
| 		"katex": "0.11.1", | ||||
| 		"koa": "2.11.0", | ||||
| 		"json5-loader": "4.0.1", | ||||
| 		"jsonld": "3.2.0", | ||||
| 		"jsrsasign": "8.0.20", | ||||
| 		"katex": "0.12.0", | ||||
| 		"koa": "2.13.0", | ||||
| 		"koa-bodyparser": "4.3.0", | ||||
| 		"koa-favicon": "2.1.0", | ||||
| 		"koa-json-body": "5.3.0", | ||||
| 		"koa-logger": "3.2.1", | ||||
| 		"koa-mount": "4.0.0", | ||||
| 		"koa-send": "5.0.0", | ||||
| 		"koa-send": "5.0.1", | ||||
| 		"koa-slow": "2.1.0", | ||||
| 		"koa-views": "6.2.2", | ||||
| 		"koa-views": "6.3.1", | ||||
| 		"langmap": "0.0.16", | ||||
| 		"lookup-dns-cache": "2.1.0", | ||||
| 		"markdown-it": "10.0.0", | ||||
| 		"markdown-it-anchor": "5.3.0", | ||||
| 		"mocha": "7.1.2", | ||||
| 		"markdown-it": "11.0.1", | ||||
| 		"markdown-it-anchor": "6.0.1", | ||||
| 		"matter-js": "0.14.2", | ||||
| 		"mocha": "8.2.1", | ||||
| 		"moji": "0.5.1", | ||||
| 		"ms": "2.1.2", | ||||
| 		"ms": "2.1.3", | ||||
| 		"multer": "1.4.2", | ||||
| 		"nested-property": "2.0.0", | ||||
| 		"node-fetch": "2.6.0", | ||||
| 		"nodemailer": "6.4.6", | ||||
| 		"nprogress": "0.2.0", | ||||
| 		"nested-property": "4.0.0", | ||||
| 		"node-fetch": "2.6.1", | ||||
| 		"nodemailer": "6.4.17", | ||||
| 		"object-assign-deep": "0.4.0", | ||||
| 		"os-utils": "0.0.14", | ||||
| 		"parse5": "6.0.0", | ||||
| 		"parsimmon": "1.13.0", | ||||
| 		"pg": "8.2.1", | ||||
| 		"portal-vue": "2.1.7", | ||||
| 		"p-cancelable": "2.0.0", | ||||
| 		"parse5": "6.0.1", | ||||
| 		"parsimmon": "1.16.0", | ||||
| 		"pg": "8.5.1", | ||||
| 		"portscanner": "2.2.0", | ||||
| 		"postcss-loader": "3.0.0", | ||||
| 		"prismjs": "1.20.0", | ||||
| 		"probe-image-size": "5.0.0", | ||||
| 		"postcss": "8.2.1", | ||||
| 		"postcss-loader": "4.1.0", | ||||
| 		"prismjs": "1.22.0", | ||||
| 		"probe-image-size": "6.0.0", | ||||
| 		"promise-limit": "2.7.0", | ||||
| 		"promise-sequential": "1.1.1", | ||||
| 		"pug": "2.0.4", | ||||
| 		"punycode": "2.1.1", | ||||
| 		"pureimage": "0.2.1", | ||||
| 		"pureimage": "0.2.5", | ||||
| 		"qrcode": "1.4.4", | ||||
| 		"random-seed": "0.3.0", | ||||
| 		"randomcolor": "0.5.4", | ||||
| 		"ratelimiter": "3.4.1", | ||||
| 		"recaptcha-promise": "0.1.3", | ||||
| 		"re2": "1.15.8", | ||||
| 		"recaptcha-promise": "1.0.0", | ||||
| 		"reconnecting-websocket": "4.4.0", | ||||
| 		"redis": "3.0.2", | ||||
| 		"redis-lock": "0.1.4", | ||||
| 		"reflect-metadata": "0.1.13", | ||||
| 		"regenerator-runtime": "0.13.5", | ||||
| 		"regenerator-runtime": "0.13.7", | ||||
| 		"rename": "1.0.4", | ||||
| 		"request-stats": "3.0.0", | ||||
| 		"require-all": "3.0.0", | ||||
| 		"rimraf": "3.0.2", | ||||
| 		"rndstr": "1.0.0", | ||||
| 		"s-age": "1.1.2", | ||||
| 		"sass": "1.26.5", | ||||
| 		"sass-loader": "8.0.2", | ||||
| 		"sass": "1.29.0", | ||||
| 		"sass-loader": "10.1.0", | ||||
| 		"seedrandom": "3.0.5", | ||||
| 		"sharp": "0.25.2", | ||||
| 		"sharp": "0.26.2", | ||||
| 		"speakeasy": "2.0.0", | ||||
| 		"stringz": "2.1.0", | ||||
| 		"style-loader": "1.2.1", | ||||
| 		"summaly": "2.3.1", | ||||
| 		"style-loader": "2.0.0", | ||||
| 		"summaly": "2.4.0", | ||||
| 		"syslog-pro": "1.0.0", | ||||
| 		"systeminformation": "4.26.1", | ||||
| 		"systeminformation": "4.31.1", | ||||
| 		"syuilo-password-strength": "0.0.1", | ||||
| 		"textarea-caret": "3.1.0", | ||||
| 		"three": "0.116.1", | ||||
| 		"tinycolor2": "1.4.1", | ||||
| 		"three": "0.117.1", | ||||
| 		"tinycolor2": "1.4.2", | ||||
| 		"tmp": "0.2.1", | ||||
| 		"ts-loader": "7.0.4", | ||||
| 		"ts-node": "8.10.1", | ||||
| 		"tslint": "6.1.2", | ||||
| 		"ts-loader": "8.0.11", | ||||
| 		"ts-node": "9.1.0", | ||||
| 		"tslint": "6.1.3", | ||||
| 		"tslint-sonarts": "1.9.0", | ||||
| 		"typeorm": "0.2.24", | ||||
| 		"typescript": "3.9.2", | ||||
| 		"typeorm": "0.2.29", | ||||
| 		"typescript": "4.1.2", | ||||
| 		"ulid": "2.3.0", | ||||
| 		"url-loader": "4.1.0", | ||||
| 		"uuid": "8.0.0", | ||||
| 		"v-animate-css": "0.0.3", | ||||
| 		"url-loader": "4.1.1", | ||||
| 		"uuid": "8.3.2", | ||||
| 		"v-debounce": "0.1.2", | ||||
| 		"vue": "2.6.11", | ||||
| 		"vanilla-tilt": "1.7.0", | ||||
| 		"vue": "3.0.3", | ||||
| 		"vue-color": "2.7.1", | ||||
| 		"vue-content-loading": "1.6.0", | ||||
| 		"vue-cropperjs": "4.1.0", | ||||
| 		"vue-i18n": "8.17.6", | ||||
| 		"vue-json-pretty": "1.6.3", | ||||
| 		"vue-loader": "15.9.2", | ||||
| 		"vue-marquee-text-component": "1.1.1", | ||||
| 		"vue-meta": "2.3.3", | ||||
| 		"vue-prism-component": "1.2.0", | ||||
| 		"vue-prism-editor": "0.6.1", | ||||
| 		"vue-router": "3.1.6", | ||||
| 		"vue-json-pretty": "1.7.1", | ||||
| 		"vue-loader": "16.0.0", | ||||
| 		"vue-prism-editor": "2.0.0-alpha.2", | ||||
| 		"vue-router": "4.0.1", | ||||
| 		"vue-style-loader": "4.1.2", | ||||
| 		"vue-svg-inline-loader-corejs3": "1.5.0", | ||||
| 		"vue-template-compiler": "2.6.11", | ||||
| 		"vuedraggable": "2.23.2", | ||||
| 		"vuex": "3.4.0", | ||||
| 		"vuex-persistedstate": "3.0.1", | ||||
| 		"vuedraggable": "4.0.1", | ||||
| 		"web-push": "3.4.4", | ||||
| 		"webpack": "5.0.0-beta.16", | ||||
| 		"webpack-cli": "3.3.11", | ||||
| 		"websocket": "1.0.31", | ||||
| 		"ws": "7.3.0", | ||||
| 		"webpack": "5.10.1", | ||||
| 		"webpack-cli": "4.2.0", | ||||
| 		"websocket": "1.0.33", | ||||
| 		"ws": "7.4.1", | ||||
| 		"xev": "2.0.1" | ||||
| 	}, | ||||
| 	"devDependencies": { | ||||
| 		"@types/chai": "4.2.11", | ||||
| 		"@types/fluent-ffmpeg": "2.1.14", | ||||
| 		"@types/chai": "4.2.14", | ||||
| 		"@types/fluent-ffmpeg": "2.1.16", | ||||
| 		"chai": "4.2.0", | ||||
| 		"cross-env": "7.0.2" | ||||
| 		"cross-env": "7.0.3" | ||||
| 	} | ||||
| } | ||||
|   | ||||
							
								
								
									
										21
									
								
								src/@types/nested-property.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										21
									
								
								src/@types/nested-property.d.ts
									
									
									
									
										vendored
									
									
								
							| @@ -1,21 +0,0 @@ | ||||
| type Obj = { [key: string]: any }; | ||||
|  | ||||
| declare module 'nested-property' { | ||||
| 	interface IHasNestedPropertyOptions { | ||||
| 		own?: boolean; | ||||
| 	} | ||||
|  | ||||
| 	interface IIsInNestedPropertyOptions { | ||||
| 		validPath?: boolean; | ||||
| 	} | ||||
|  | ||||
| 	export function set<T>(object: T, property: string, value: any): T; | ||||
|  | ||||
| 	export function get(object: Obj, property: string): any; | ||||
|  | ||||
| 	export function has(object: Obj, property: string, options?: IHasNestedPropertyOptions): boolean; | ||||
|  | ||||
| 	export function hasOwn(object: Obj, property: string, options?: IHasNestedPropertyOptions): boolean; | ||||
|  | ||||
| 	export function isIn(object: Obj, property: string, objectInPath: Obj, options?: IIsInNestedPropertyOptions): boolean; | ||||
| } | ||||
							
								
								
									
										12
									
								
								src/client/.eslintrc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								src/client/.eslintrc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | ||||
| { | ||||
| 	"globals": { | ||||
| 		"_DEV_": false, | ||||
| 		"_LANGS_": false, | ||||
| 		"_VERSION_": false, | ||||
| 		"_ENV_": false, | ||||
| 		"_PERF_PREFIX_": false, | ||||
| 		"_DATA_TRANSFER_DRIVE_FILE_": false, | ||||
| 		"_DATA_TRANSFER_DRIVE_FOLDER_": false, | ||||
| 		"_DATA_TRANSFER_DECK_COLUMN_": false | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										8
									
								
								src/client/@types/global.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								src/client/@types/global.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| declare const _LANGS_: string[][]; | ||||
| declare const _VERSION_: string; | ||||
| declare const _ENV_: string; | ||||
| declare const _DEV_: boolean; | ||||
| declare const _PERF_PREFIX_: string; | ||||
| declare const _DATA_TRANSFER_DRIVE_FILE_: string; | ||||
| declare const _DATA_TRANSFER_DRIVE_FOLDER_: string; | ||||
| declare const _DATA_TRANSFER_DECK_COLUMN_: string; | ||||
							
								
								
									
										5
									
								
								src/client/@types/vue.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								src/client/@types/vue.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | ||||
| declare module '*.vue' { | ||||
| 	import type { DefineComponent } from 'vue'; | ||||
| 	const component: DefineComponent<{}, {}, any>; | ||||
| 	export default component; | ||||
| } | ||||
							
								
								
									
										86
									
								
								src/client/account.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										86
									
								
								src/client/account.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,86 @@ | ||||
| import { reactive } from 'vue'; | ||||
| import { apiUrl } from '@/config'; | ||||
| import { waiting } from '@/os'; | ||||
|  | ||||
| // TODO: 他のタブと永続化されたstateを同期 | ||||
|  | ||||
| type Account = { | ||||
| 	id: string; | ||||
| 	token: string; | ||||
| 	clientData: Record<string, any>; | ||||
| }; | ||||
|  | ||||
| const data = localStorage.getItem('account'); | ||||
|  | ||||
| // TODO: 外部からはreadonlyに | ||||
| export const $i = data ? reactive(JSON.parse(data) as Account) : null; | ||||
|  | ||||
| export function signout() { | ||||
| 	localStorage.removeItem('account'); | ||||
| 	document.cookie = `igi=; path=/`; | ||||
| 	location.href = '/'; | ||||
| } | ||||
|  | ||||
| export function getAccounts() { | ||||
| 	const accountsData = localStorage.getItem('accounts'); | ||||
| 	const accounts: { id: Account['id'], token: Account['token'] }[] = accountsData ? JSON.parse(accountsData) : []; | ||||
| 	return accounts; | ||||
| } | ||||
|  | ||||
| export function addAccount(id: Account['id'], token: Account['token']) { | ||||
| 	const accounts = getAccounts(); | ||||
| 	if (!accounts.some(x => x.id === id)) { | ||||
| 		localStorage.setItem('accounts', JSON.stringify(accounts.concat([{ id, token }]))); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| function fetchAccount(token): Promise<Account> { | ||||
| 	return new Promise((done, fail) => { | ||||
| 		// Fetch user | ||||
| 		fetch(`${apiUrl}/i`, { | ||||
| 			method: 'POST', | ||||
| 			body: JSON.stringify({ | ||||
| 				i: token | ||||
| 			}) | ||||
| 		}) | ||||
| 		.then(res => { | ||||
| 			// When failed to authenticate user | ||||
| 			if (res.status !== 200 && res.status < 500) { | ||||
| 				return signout(); | ||||
| 			} | ||||
|  | ||||
| 			// Parse response | ||||
| 			res.json().then(i => { | ||||
| 				i.token = token; | ||||
| 				done(i); | ||||
| 			}); | ||||
| 		}) | ||||
| 		.catch(fail); | ||||
| 	}); | ||||
| } | ||||
|  | ||||
| export function updateAccount(data) { | ||||
| 	for (const [key, value] of Object.entries(data)) { | ||||
| 		$i[key] = value; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| export function refreshAccount() { | ||||
| 	fetchAccount($i.token).then(updateAccount); | ||||
| } | ||||
|  | ||||
| export async function login(token: Account['token']) { | ||||
| 	waiting(); | ||||
| 	if (_DEV_) console.log('logging as token ', token); | ||||
| 	const me = await fetchAccount(token); | ||||
| 	localStorage.setItem('account', JSON.stringify(me)); | ||||
| 	addAccount(me.id, token); | ||||
| 	location.reload(); | ||||
| } | ||||
|  | ||||
| // このファイルに書きたくないけどここに書かないと何故かVeturが認識しない | ||||
| declare module '@vue/runtime-core' { | ||||
| 	interface ComponentCustomProperties { | ||||
| 		$i: typeof $i; | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										1145
									
								
								src/client/app.vue
									
									
									
									
									
								
							
							
						
						
									
										1145
									
								
								src/client/app.vue
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								src/client/assets/sounds/noizenecio/kick_gaba2.mp3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/client/assets/sounds/noizenecio/kick_gaba2.mp3
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								src/client/assets/sounds/syuilo/kick.mp3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/client/assets/sounds/syuilo/kick.mp3
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								src/client/assets/sounds/syuilo/pirori-square-wet.mp3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/client/assets/sounds/syuilo/pirori-square-wet.mp3
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								src/client/assets/sounds/syuilo/pirori-wet.mp3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/client/assets/sounds/syuilo/pirori-wet.mp3
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								src/client/assets/sounds/syuilo/pirori.mp3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/client/assets/sounds/syuilo/pirori.mp3
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								src/client/assets/sounds/syuilo/reverved.mp3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/client/assets/sounds/syuilo/reverved.mp3
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								src/client/assets/sounds/syuilo/ryukyu.mp3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/client/assets/sounds/syuilo/ryukyu.mp3
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								src/client/assets/sounds/syuilo/snare.mp3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/client/assets/sounds/syuilo/snare.mp3
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								src/client/assets/sounds/syuilo/square-pico.mp3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/client/assets/sounds/syuilo/square-pico.mp3
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										85
									
								
								src/client/components/abuse-report-window.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										85
									
								
								src/client/components/abuse-report-window.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,85 @@ | ||||
| <template> | ||||
| <XWindow ref="window" :initial-width="400" :initial-height="500" :can-resize="true" @closed="$emit('closed')"> | ||||
| 	<template #header> | ||||
| 		<Fa :icon="faExclamationCircle" style="margin-right: 0.5em;"/> | ||||
| 		<I18n :src="$ts.reportAbuseOf" tag="span"> | ||||
| 			<template #name> | ||||
| 				<b><MkAcct :user="user"/></b> | ||||
| 			</template> | ||||
| 		</I18n> | ||||
| 	</template> | ||||
| 	<div class="dpvffvvy"> | ||||
| 		<div class="_section"> | ||||
| 			<div class="_content"> | ||||
| 				<MkTextarea v-model:value="comment"> | ||||
| 					<span>{{ $ts.details }}</span> | ||||
| 					<template #desc>{{ $ts.fillAbuseReportDescription }}</template> | ||||
| 				</MkTextarea> | ||||
| 			</div> | ||||
| 		</div> | ||||
| 		<div class="_section"> | ||||
| 			<div class="_content"> | ||||
| 				<MkButton @click="send" primary full :disabled="comment.length === 0">{{ $ts.send }}</MkButton> | ||||
| 			</div> | ||||
| 		</div> | ||||
| 	</div> | ||||
| </XWindow> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import { defineComponent, markRaw } from 'vue'; | ||||
| import { faExclamationCircle } from '@fortawesome/free-solid-svg-icons'; | ||||
| import XWindow from '@/components/ui/window.vue'; | ||||
| import MkTextarea from '@/components/ui/textarea.vue'; | ||||
| import MkButton from '@/components/ui/button.vue'; | ||||
| import * as os from '@/os'; | ||||
|  | ||||
| export default defineComponent({ | ||||
| 	components: { | ||||
| 		XWindow, | ||||
| 		MkTextarea, | ||||
| 		MkButton, | ||||
| 	}, | ||||
|  | ||||
| 	props: { | ||||
| 		user: { | ||||
| 			type: Object, | ||||
| 			required: true, | ||||
| 		}, | ||||
| 		initialComment: { | ||||
| 			type: String, | ||||
| 			required: false, | ||||
| 		}, | ||||
| 	}, | ||||
|  | ||||
| 	emits: ['closed'], | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			comment: this.initialComment || '', | ||||
| 			faExclamationCircle, | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		send() { | ||||
| 			os.apiWithDialog('users/report-abuse', { | ||||
| 				userId: this.user.id, | ||||
| 				comment: this.comment, | ||||
| 			}, undefined, res => { | ||||
| 				os.dialog({ | ||||
| 					type: 'success', | ||||
| 					text: this.$ts.abuseReported | ||||
| 				}); | ||||
| 				this.$refs.window.close(); | ||||
| 			}); | ||||
| 		} | ||||
| 	}, | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="scss" scoped> | ||||
| .dpvffvvy { | ||||
| 	--section-padding: 16px; | ||||
| } | ||||
| </style> | ||||
| @@ -34,10 +34,11 @@ | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { defineComponent } from 'vue'; | ||||
| import * as tinycolor from 'tinycolor2'; | ||||
| import * as os from '@/os'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| export default defineComponent({ | ||||
| 	data() { | ||||
| 		return { | ||||
| 			now: new Date(), | ||||
| @@ -115,19 +116,9 @@ export default Vue.extend({ | ||||
| 			} | ||||
| 		}; | ||||
| 		update(); | ||||
|  | ||||
| 		this.$store.subscribe((mutation, state) => { | ||||
| 			if (mutation.type !== 'device/set') return; | ||||
|  | ||||
| 			if (mutation?.payload?.key !== 'theme') return; | ||||
|  | ||||
| 			setTimeout(() => { | ||||
| 				this.computedStyle = getComputedStyle(document.documentElement); | ||||
| 			}, 250); | ||||
| 		}); | ||||
| 	}, | ||||
|  | ||||
| 	beforeDestroy() { | ||||
| 	beforeUnmount() { | ||||
| 		this.enabled = false; | ||||
| 	}, | ||||
|  | ||||
|   | ||||
| @@ -1,14 +1,14 @@ | ||||
| <template> | ||||
| <div class="swhvrteh" @contextmenu.prevent="() => {}"> | ||||
| <div class="swhvrteh _popup _shadow" @contextmenu.prevent="() => {}"> | ||||
| 	<ol class="users" ref="suggests" v-if="type === 'user'"> | ||||
| 		<li v-for="user in users" @click="complete(type, user)" @keydown="onKeydown" tabindex="-1" class="user"> | ||||
| 			<img class="avatar" :src="user.avatarUrl"/> | ||||
| 			<span class="name"> | ||||
| 				<mk-user-name :user="user" :key="user.id"/> | ||||
| 				<MkUserName :user="user" :key="user.id"/> | ||||
| 			</span> | ||||
| 			<span class="username">@{{ user | acct }}</span> | ||||
| 			<span class="username">@{{ acct(user) }}</span> | ||||
| 		</li> | ||||
| 		<li @click="chooseUser()" @keydown="onKeydown" tabindex="-1" class="choose">{{ $t('selectUser') }}</li> | ||||
| 		<li @click="chooseUser()" @keydown="onKeydown" tabindex="-1" class="choose">{{ $ts.selectUser }}</li> | ||||
| 	</ol> | ||||
| 	<ol class="hashtags" ref="suggests" v-if="hashtags.length > 0"> | ||||
| 		<li v-for="hashtag in hashtags" @click="complete(type, hashtag)" @keydown="onKeydown" tabindex="-1"> | ||||
| @@ -17,8 +17,8 @@ | ||||
| 	</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" v-if="emoji.isCustomEmoji"><img :src="$store.state.device.disableShowingAnimatedImages ? getStaticImageUrl(emoji.url) : emoji.url" :alt="emoji.emoji"/></span> | ||||
| 			<span class="emoji" v-else-if="!useOsNativeEmojis"><img :src="emoji.url" :alt="emoji.emoji"/></span> | ||||
| 			<span class="emoji" v-if="emoji.isCustomEmoji"><img :src="$store.state.disableShowingAnimatedImages ? getStaticImageUrl(emoji.url) : emoji.url" :alt="emoji.emoji"/></span> | ||||
| 			<span class="emoji" v-else-if="!$store.state.useOsNativeEmojis"><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.aliasOf">({{ emoji.aliasOf }})</span> | ||||
| @@ -28,12 +28,13 @@ | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { defineComponent, markRaw } from 'vue'; | ||||
| import { emojilist } from '../../misc/emojilist'; | ||||
| import contains from '../scripts/contains'; | ||||
| import contains from '@/scripts/contains'; | ||||
| import { twemojiSvgBase } from '../../misc/twemoji-base'; | ||||
| import { getStaticImageUrl } from '../scripts/get-static-image-url'; | ||||
| import MkUserSelect from './user-select.vue'; | ||||
| import { getStaticImageUrl } from '@/scripts/get-static-image-url'; | ||||
| import { acct } from '@/filters/user'; | ||||
| import * as os from '@/os'; | ||||
|  | ||||
| type EmojiDef = { | ||||
| 	emoji: string; | ||||
| @@ -74,7 +75,7 @@ for (const x of lib) { | ||||
|  | ||||
| emjdb.sort((a, b) => a.name.length - b.name.length); | ||||
|  | ||||
| export default Vue.extend({ | ||||
| export default defineComponent({ | ||||
| 	props: { | ||||
| 		type: { | ||||
| 			type: String, | ||||
| @@ -91,11 +92,6 @@ export default Vue.extend({ | ||||
| 			required: true, | ||||
| 		}, | ||||
|  | ||||
| 		complete: { | ||||
| 			type: Function, | ||||
| 			required: true, | ||||
| 		}, | ||||
|  | ||||
| 		close: { | ||||
| 			type: Function, | ||||
| 			required: true, | ||||
| @@ -110,8 +106,15 @@ export default Vue.extend({ | ||||
| 			type: Number, | ||||
| 			required: true, | ||||
| 		}, | ||||
|  | ||||
| 		showing: { | ||||
| 			type: Boolean, | ||||
| 			required: true | ||||
| 		}, | ||||
| 	}, | ||||
|  | ||||
| 	emits: ['done', 'closed'], | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			getStaticImageUrl, | ||||
| @@ -119,31 +122,30 @@ export default Vue.extend({ | ||||
| 			users: [], | ||||
| 			hashtags: [], | ||||
| 			emojis: [], | ||||
| 			items: [], | ||||
| 			select: -1, | ||||
| 			emojilist, | ||||
| 			emojiDb: [] as EmojiDef[] | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	computed: { | ||||
| 		items(): HTMLCollection { | ||||
| 			return (this.$refs.suggests as Element).children; | ||||
| 		}, | ||||
|  | ||||
| 		useOsNativeEmojis(): boolean { | ||||
| 			return this.$store.state.device.useOsNativeEmojis; | ||||
| 	watch: { | ||||
| 		showing() { | ||||
| 			if (!this.showing) { | ||||
| 				this.$emit('closed'); | ||||
| 			} | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	updated() { | ||||
| 		this.setPosition(); | ||||
| 		this.items = (this.$refs.suggests as Element | undefined)?.children || []; | ||||
| 	}, | ||||
|  | ||||
| 	mounted() { | ||||
| 		this.setPosition(); | ||||
|  | ||||
| 		//#region Construct Emoji DB | ||||
| 		const customEmojis = this.$store.state.instance.meta.emojis; | ||||
| 		const customEmojis = this.$instance.emojis; | ||||
| 		const emojiDefinitions: EmojiDef[] = []; | ||||
|  | ||||
| 		for (const x of customEmojis) { | ||||
| @@ -169,7 +171,7 @@ export default Vue.extend({ | ||||
|  | ||||
| 		emojiDefinitions.sort((a, b) => a.name.length - b.name.length); | ||||
|  | ||||
| 		this.emojiDb = emojiDefinitions.concat(emjdb); | ||||
| 		this.emojiDb = markRaw(emojiDefinitions.concat(emjdb)); | ||||
| 		//#endregion | ||||
|  | ||||
| 		this.textarea.addEventListener('keydown', this.onKeydown); | ||||
| @@ -189,7 +191,7 @@ export default Vue.extend({ | ||||
| 		}); | ||||
| 	}, | ||||
|  | ||||
| 	beforeDestroy() { | ||||
| 	beforeUnmount() { | ||||
| 		this.textarea.removeEventListener('keydown', this.onKeydown); | ||||
|  | ||||
| 		for (const el of Array.from(document.querySelectorAll('body *'))) { | ||||
| @@ -198,6 +200,11 @@ export default Vue.extend({ | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		complete(type, value) { | ||||
| 			this.$emit('done', { type, value }); | ||||
| 			this.$emit('closed'); | ||||
| 		}, | ||||
|  | ||||
| 		setPosition() { | ||||
| 			if (this.x + this.$el.offsetWidth > window.innerWidth) { | ||||
| 				this.$el.style.left = (window.innerWidth - this.$el.offsetWidth) + 'px'; | ||||
| @@ -236,8 +243,8 @@ export default Vue.extend({ | ||||
| 					this.users = users; | ||||
| 					this.fetching = false; | ||||
| 				} else { | ||||
| 					this.$root.api('users/search', { | ||||
| 						query: this.q, | ||||
| 					os.api('users/search-by-username-and-host', { | ||||
| 						username: this.q, | ||||
| 						limit: 10, | ||||
| 						detail: false | ||||
| 					}).then(users => { | ||||
| @@ -260,7 +267,7 @@ export default Vue.extend({ | ||||
| 						this.hashtags = hashtags; | ||||
| 						this.fetching = false; | ||||
| 					} else { | ||||
| 						this.$root.api('hashtags/search', { | ||||
| 						os.api('hashtags/search', { | ||||
| 							query: this.q, | ||||
| 							limit: 30 | ||||
| 						}).then(hashtags => { | ||||
| @@ -355,6 +362,7 @@ export default Vue.extend({ | ||||
|  | ||||
| 		selectNext() { | ||||
| 			if (++this.select >= this.items.length) this.select = 0; | ||||
| 			if (this.items.length === 0) this.select = -1; | ||||
| 			this.applySelect(); | ||||
| 		}, | ||||
|  | ||||
| @@ -368,20 +376,21 @@ export default Vue.extend({ | ||||
| 				el.removeAttribute('data-selected'); | ||||
| 			} | ||||
|  | ||||
| 			this.items[this.select].setAttribute('data-selected', 'true'); | ||||
| 			(this.items[this.select] as any).focus(); | ||||
| 			if (this.select !== -1) { | ||||
| 				this.items[this.select].setAttribute('data-selected', 'true'); | ||||
| 				(this.items[this.select] as any).focus(); | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
| 		chooseUser() { | ||||
| 			this.close(); | ||||
| 			const vm = this.$root.new(MkUserSelect, {}); | ||||
| 			vm.$once('selected', user => { | ||||
| 			os.selectUser().then(user => { | ||||
| 				this.complete('user', user); | ||||
| 			}); | ||||
| 			vm.$once('closed', () => { | ||||
| 				this.textarea.focus(); | ||||
| 			}); | ||||
| 		} | ||||
| 		}, | ||||
|  | ||||
| 		acct | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
| @@ -393,9 +402,6 @@ export default Vue.extend({ | ||||
| 	max-width: 100%; | ||||
| 	margin-top: calc(1em + 8px); | ||||
| 	overflow: hidden; | ||||
| 	background: var(--panel); | ||||
| 	border: solid 1px rgba(#000, 0.1); | ||||
| 	border-radius: 4px; | ||||
| 	transition: top 0.1s ease, left 0.1s ease; | ||||
|  | ||||
| 	> ol { | ||||
| @@ -426,7 +432,7 @@ export default Vue.extend({ | ||||
| 			} | ||||
|  | ||||
| 			&:hover { | ||||
| 				background: var(--yrnqrguo); | ||||
| 				background: var(--X3); | ||||
| 			} | ||||
|  | ||||
| 			&[data-selected='true'] { | ||||
|   | ||||
| @@ -1,116 +0,0 @@ | ||||
| <template> | ||||
| <span class="eiwwqkts" :class="{ cat }" :title="user | acct" v-if="disableLink && !disablePreview" v-user-preview="user.id" @click="onClick"> | ||||
| 	<span class="inner" :style="icon"></span> | ||||
| </span> | ||||
| <span class="eiwwqkts" :class="{ cat }" :title="user | acct" v-else-if="disableLink && disablePreview" @click="onClick"> | ||||
| 	<span class="inner" :style="icon"></span> | ||||
| </span> | ||||
| <router-link class="eiwwqkts" :class="{ cat }" :to="user | userPage" :title="user | acct" :target="target" v-else-if="!disableLink && !disablePreview" v-user-preview="user.id"> | ||||
| 	<span class="inner" :style="icon"></span> | ||||
| </router-link> | ||||
| <router-link class="eiwwqkts" :class="{ cat }" :to="user | userPage" :title="user | acct" :target="target" v-else-if="!disableLink && disablePreview"> | ||||
| 	<span class="inner" :style="icon"></span> | ||||
| </router-link> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { getStaticImageUrl } from '../scripts/get-static-image-url'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: { | ||||
| 		user: { | ||||
| 			type: Object, | ||||
| 			required: true | ||||
| 		}, | ||||
| 		target: { | ||||
| 			required: false, | ||||
| 			default: null | ||||
| 		}, | ||||
| 		disableLink: { | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		}, | ||||
| 		disablePreview: { | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		} | ||||
| 	}, | ||||
| 	computed: { | ||||
| 		cat(): boolean { | ||||
| 			return this.user.isCat; | ||||
| 		}, | ||||
| 		url(): string { | ||||
| 			return this.$store.state.device.disableShowingAnimatedImages | ||||
| 				? getStaticImageUrl(this.user.avatarUrl) | ||||
| 				: this.user.avatarUrl; | ||||
| 		}, | ||||
| 		icon(): any { | ||||
| 			return { | ||||
| 				backgroundColor: this.user.avatarColor, | ||||
| 				backgroundImage: `url(${this.url})`, | ||||
| 			}; | ||||
| 		} | ||||
| 	}, | ||||
| 	watch: { | ||||
| 		'user.avatarColor'() { | ||||
| 			this.$el.style.color = this.user.avatarColor; | ||||
| 		} | ||||
| 	}, | ||||
| 	mounted() { | ||||
| 		if (this.user.avatarColor) { | ||||
| 			this.$el.style.color = this.user.avatarColor; | ||||
| 		} | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		onClick(e) { | ||||
| 			this.$emit('click', e); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="scss" scoped> | ||||
| .eiwwqkts { | ||||
| 	position: relative; | ||||
| 	display: inline-block; | ||||
| 	vertical-align: bottom; | ||||
| 	flex-shrink: 0; | ||||
| 	border-radius: 100%; | ||||
| 	line-height: 16px; | ||||
|  | ||||
| 	&.cat { | ||||
| 		&:before, &:after { | ||||
| 			background: #df548f; | ||||
| 			border: solid 4px currentColor; | ||||
| 			box-sizing: border-box; | ||||
| 			content: ''; | ||||
| 			display: inline-block; | ||||
| 			height: 50%; | ||||
| 			width: 50%; | ||||
| 		} | ||||
|  | ||||
| 		&:before { | ||||
| 			border-radius: 0 75% 75%; | ||||
| 			transform: rotate(37.5deg) skew(30deg); | ||||
| 		} | ||||
|  | ||||
| 		&:after { | ||||
| 			border-radius: 75% 0 75% 75%; | ||||
| 			transform: rotate(-37.5deg) skew(-30deg); | ||||
| 		} | ||||
| 	} | ||||
| 	 | ||||
| 	.inner { | ||||
| 		background-position: center center; | ||||
| 		background-size: cover; | ||||
| 		bottom: 0; | ||||
| 		left: 0; | ||||
| 		position: absolute; | ||||
| 		right: 0; | ||||
| 		top: 0; | ||||
| 		border-radius: 100%; | ||||
| 		z-index: 1; | ||||
| 	} | ||||
| } | ||||
| </style> | ||||
| @@ -1,15 +1,16 @@ | ||||
| <template> | ||||
| <div> | ||||
| 	<div v-for="user in us" :key="user.id" style="display:inline-block;width:32px;height:32px;margin-right:8px;"> | ||||
| 		<mk-avatar :user="user" style="width:32px;height:32px;"/> | ||||
| 		<MkAvatar :user="user" style="width:32px;height:32px;"/> | ||||
| 	</div> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { defineComponent } from 'vue'; | ||||
| import * as os from '@/os'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| export default defineComponent({ | ||||
| 	props: { | ||||
| 		userIds: { | ||||
| 			required: true | ||||
| @@ -21,7 +22,7 @@ export default Vue.extend({ | ||||
| 		}; | ||||
| 	}, | ||||
| 	async created() { | ||||
| 		this.us = await this.$root.api('users/show', { | ||||
| 		this.us = await os.api('users/show', { | ||||
| 			userIds: this.userIds | ||||
| 		}); | ||||
| 	} | ||||
|   | ||||
| @@ -1,13 +1,12 @@ | ||||
| <template> | ||||
| <div> | ||||
| 	<span v-if="!available">{{ $t('waiting') }}<mk-ellipsis/></span> | ||||
| 	<span v-if="!available">{{ $ts.waiting }}<MkEllipsis/></span> | ||||
| 	<div ref="captcha"></div> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import i18n from '../i18n'; | ||||
| import { defineComponent } from 'vue'; | ||||
|  | ||||
| type Captcha = { | ||||
| 	render(container: string | Node, options: { | ||||
| @@ -30,8 +29,7 @@ declare global { | ||||
| 	} | ||||
| } | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n, | ||||
| export default defineComponent({ | ||||
| 	props: { | ||||
| 		provider: { | ||||
| 			type: String, | ||||
| @@ -90,7 +88,7 @@ export default Vue.extend({ | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	beforeDestroy() { | ||||
| 	beforeUnmount() { | ||||
| 		this.reset(); | ||||
| 	}, | ||||
|  | ||||
| @@ -102,7 +100,7 @@ export default Vue.extend({ | ||||
| 			if (this.captcha.render && this.$refs.captcha instanceof Element) { | ||||
| 				this.captcha.render(this.$refs.captcha, { | ||||
| 					sitekey: this.sitekey, | ||||
| 					theme: this.$store.state.device.darkMode ? 'dark' : 'light', | ||||
| 					theme: this.$store.state.darkMode ? 'dark' : 'light', | ||||
| 					callback: this.callback, | ||||
| 					'expired-callback': this.callback, | ||||
| 					'error-callback': this.callback, | ||||
| @@ -112,7 +110,7 @@ export default Vue.extend({ | ||||
| 			} | ||||
| 		}, | ||||
| 		callback(response?: string) { | ||||
| 			this.$emit('input', typeof response == 'string' ? response : null); | ||||
| 			this.$emit('update:value', typeof response == 'string' ? response : null); | ||||
| 		}, | ||||
| 	}, | ||||
| }); | ||||
|   | ||||
							
								
								
									
										142
									
								
								src/client/components/channel-follow-button.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										142
									
								
								src/client/components/channel-follow-button.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,142 @@ | ||||
| <template> | ||||
| <button class="hdcaacmi _button" | ||||
| 	:class="{ wait, active: isFollowing, full }" | ||||
| 	@click="onClick" | ||||
| 	:disabled="wait" | ||||
| > | ||||
| 	<template v-if="!wait"> | ||||
| 		<template v-if="isFollowing"> | ||||
| 			<span v-if="full">{{ $ts.unfollow }}</span><Fa :icon="faMinus"/> | ||||
| 		</template> | ||||
| 		<template v-else> | ||||
| 			<span v-if="full">{{ $ts.follow }}</span><Fa :icon="faPlus"/> | ||||
| 		</template> | ||||
| 	</template> | ||||
| 	<template v-else> | ||||
| 		<span v-if="full">{{ $ts.processing }}</span><Fa :icon="faSpinner" pulse fixed-width/> | ||||
| 	</template> | ||||
| </button> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import { defineComponent } from 'vue'; | ||||
| import { faSpinner, faPlus, faMinus, } from '@fortawesome/free-solid-svg-icons'; | ||||
| import * as os from '@/os'; | ||||
|  | ||||
| export default defineComponent({ | ||||
| 	props: { | ||||
| 		channel: { | ||||
| 			type: Object, | ||||
| 			required: true | ||||
| 		}, | ||||
| 		full: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false, | ||||
| 		}, | ||||
| 	}, | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			isFollowing: this.channel.isFollowing, | ||||
| 			wait: false, | ||||
| 			faSpinner, faPlus, faMinus, | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		async onClick() { | ||||
| 			this.wait = true; | ||||
|  | ||||
| 			try { | ||||
| 				if (this.isFollowing) { | ||||
| 					await os.api('channels/unfollow', { | ||||
| 						channelId: this.channel.id | ||||
| 					}); | ||||
| 					this.isFollowing = false; | ||||
| 				} else { | ||||
| 					await os.api('channels/follow', { | ||||
| 						channelId: this.channel.id | ||||
| 					}); | ||||
| 					this.isFollowing = true; | ||||
| 				} | ||||
| 			} catch (e) { | ||||
| 				console.error(e); | ||||
| 			} finally { | ||||
| 				this.wait = false; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="scss" scoped> | ||||
| .hdcaacmi { | ||||
| 	position: relative; | ||||
| 	display: inline-block; | ||||
| 	font-weight: bold; | ||||
| 	color: var(--accent); | ||||
| 	background: transparent; | ||||
| 	border: solid 1px var(--accent); | ||||
| 	padding: 0; | ||||
| 	height: 31px; | ||||
| 	font-size: 16px; | ||||
| 	border-radius: 32px; | ||||
| 	background: #fff; | ||||
|  | ||||
| 	&.full { | ||||
| 		padding: 0 8px 0 12px; | ||||
| 		font-size: 14px; | ||||
| 	} | ||||
|  | ||||
| 	&:not(.full) { | ||||
| 		width: 31px; | ||||
| 	} | ||||
|  | ||||
| 	&:focus { | ||||
| 		&:after { | ||||
| 			content: ""; | ||||
| 			pointer-events: none; | ||||
| 			position: absolute; | ||||
| 			top: -5px; | ||||
| 			right: -5px; | ||||
| 			bottom: -5px; | ||||
| 			left: -5px; | ||||
| 			border: 2px solid var(--focus); | ||||
| 			border-radius: 32px; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	&:hover { | ||||
| 		//background: mix($primary, #fff, 20); | ||||
| 	} | ||||
|  | ||||
| 	&:active { | ||||
| 		//background: mix($primary, #fff, 40); | ||||
| 	} | ||||
|  | ||||
| 	&.active { | ||||
| 		color: #fff; | ||||
| 		background: var(--accent); | ||||
|  | ||||
| 		&:hover { | ||||
| 			background: var(--accentLighten); | ||||
| 			border-color: var(--accentLighten); | ||||
| 		} | ||||
|  | ||||
| 		&:active { | ||||
| 			background: var(--accentDarken); | ||||
| 			border-color: var(--accentDarken); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	&.wait { | ||||
| 		cursor: wait !important; | ||||
| 		opacity: 0.7; | ||||
| 	} | ||||
|  | ||||
| 	> span { | ||||
| 		margin-right: 6px; | ||||
| 	} | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										167
									
								
								src/client/components/channel-preview.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										167
									
								
								src/client/components/channel-preview.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,167 @@ | ||||
| <template> | ||||
| <MkA :to="`/channels/${channel.id}`" class="eftoefju _panel" tabindex="-1"> | ||||
| 	<div class="banner" :style="bannerStyle"> | ||||
| 		<div class="fade"></div> | ||||
| 		<div class="name"><Fa :icon="faSatelliteDish"/> {{ channel.name }}</div> | ||||
| 		<div class="status"> | ||||
| 			<div> | ||||
| 				<Fa :icon="faUsers" fixed-width/> | ||||
| 				<I18n :src="$ts._channel.usersCount" tag="span" style="margin-left: 4px;"> | ||||
| 					<template #n> | ||||
| 						<b>{{ channel.usersCount }}</b> | ||||
| 					</template> | ||||
| 				</I18n> | ||||
| 			</div> | ||||
| 			<div> | ||||
| 				<Fa :icon="faPencilAlt" fixed-width/> | ||||
| 				<I18n :src="$ts._channel.notesCount" tag="span" style="margin-left: 4px;"> | ||||
| 					<template #n> | ||||
| 						<b>{{ channel.notesCount }}</b> | ||||
| 					</template> | ||||
| 				</I18n> | ||||
| 			</div> | ||||
| 		</div> | ||||
| 	</div> | ||||
| 	<article v-if="channel.description"> | ||||
| 		<p :title="channel.description">{{ channel.description.length > 85 ? channel.description.slice(0, 85) + '…' : channel.description }}</p> | ||||
| 	</article> | ||||
| 	<footer> | ||||
| 		<span v-if="channel.lastNotedAt"> | ||||
| 			{{ $ts.updatedAt }}: <MkTime :time="channel.lastNotedAt"/> | ||||
| 		</span> | ||||
| 	</footer> | ||||
| </MkA> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import { defineComponent } from 'vue'; | ||||
| import { faSatelliteDish, faUsers, faPencilAlt } from '@fortawesome/free-solid-svg-icons'; | ||||
|  | ||||
| export default defineComponent({ | ||||
| 	props: { | ||||
| 		channel: { | ||||
| 			type: Object, | ||||
| 			required: true | ||||
| 		}, | ||||
| 	}, | ||||
|  | ||||
| 	computed: { | ||||
| 		bannerStyle() { | ||||
| 			if (this.channel.bannerUrl) { | ||||
| 				return { backgroundImage: `url(${this.channel.bannerUrl})` }; | ||||
| 			} else { | ||||
| 				return { backgroundColor: '#4c5e6d' }; | ||||
| 			} | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			faSatelliteDish, faUsers, faPencilAlt, | ||||
| 		}; | ||||
| 	}, | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="scss" scoped> | ||||
| .eftoefju { | ||||
| 	display: block; | ||||
| 	overflow: hidden; | ||||
| 	width: 100%; | ||||
|  | ||||
| 	&:hover { | ||||
| 		text-decoration: none; | ||||
| 	} | ||||
|  | ||||
| 	> .banner { | ||||
| 		position: relative; | ||||
| 		width: 100%; | ||||
| 		height: 200px; | ||||
| 		background-position: center; | ||||
| 		background-size: cover; | ||||
|  | ||||
| 		> .fade { | ||||
| 			position: absolute; | ||||
| 			bottom: 0; | ||||
| 			left: 0; | ||||
| 			width: 100%; | ||||
| 			height: 64px; | ||||
| 			background: linear-gradient(0deg, var(--panel), var(--X15)); | ||||
| 		} | ||||
|  | ||||
| 		> .name { | ||||
| 			position: absolute; | ||||
| 			top: 16px; | ||||
| 			left: 16px; | ||||
| 			padding: 12px 16px; | ||||
| 			background: rgba(0, 0, 0, 0.7); | ||||
| 			color: #fff; | ||||
| 			font-size: 1.2em; | ||||
| 		} | ||||
|  | ||||
| 		> .status { | ||||
| 			position: absolute; | ||||
| 			z-index: 1; | ||||
| 			bottom: 16px; | ||||
| 			right: 16px; | ||||
| 			padding: 8px 12px; | ||||
| 			font-size: 80%; | ||||
| 			background: rgba(0, 0, 0, 0.7); | ||||
| 			border-radius: 6px; | ||||
| 			color: #fff; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	> article { | ||||
| 		padding: 16px; | ||||
|  | ||||
| 		> p { | ||||
| 			margin: 0; | ||||
| 			font-size: 1em; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	> footer { | ||||
| 		padding: 12px 16px; | ||||
| 		border-top: solid 1px var(--divider); | ||||
|  | ||||
| 		> span { | ||||
| 			opacity: 0.7; | ||||
| 			font-size: 0.9em; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	@media (max-width: 550px) { | ||||
| 		font-size: 0.9em; | ||||
|  | ||||
| 		> .banner { | ||||
| 			height: 80px; | ||||
|  | ||||
| 			> .status { | ||||
| 				display: none; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		> article { | ||||
| 			padding: 12px; | ||||
| 		} | ||||
|  | ||||
| 		> footer { | ||||
| 			display: none; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	@media (max-width: 500px) { | ||||
| 		font-size: 0.8em; | ||||
|  | ||||
| 		> .banner { | ||||
| 			height: 70px; | ||||
| 		} | ||||
|  | ||||
| 		> article { | ||||
| 			padding: 8px; | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| </style> | ||||
| @@ -1,16 +1,14 @@ | ||||
| <template> | ||||
| <x-prism :inline="inline" :language="prismLang">{{ code }}</x-prism> | ||||
| <code v-if="inline" v-html="html" :class="`language-${prismLang}`"></code> | ||||
| <pre v-else :class="`language-${prismLang}`"><code v-html="html" :class="`language-${prismLang}`"></code></pre> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { defineComponent } from 'vue'; | ||||
| import 'prismjs'; | ||||
| import 'prismjs/themes/prism-okaidia.css'; | ||||
| import XPrism from 'vue-prism-component'; | ||||
| export default Vue.extend({ | ||||
| 	components: { | ||||
| 		XPrism | ||||
| 	}, | ||||
|  | ||||
| export default defineComponent({ | ||||
| 	props: { | ||||
| 		code: { | ||||
| 			type: String, | ||||
| @@ -28,6 +26,9 @@ export default Vue.extend({ | ||||
| 	computed: { | ||||
| 		prismLang() { | ||||
| 			return Prism.languages[this.lang] ? this.lang : 'js'; | ||||
| 		}, | ||||
| 		html() { | ||||
| 			return Prism.highlight(this.code, Prism.languages[this.prismLang], this.prismLang); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
|   | ||||
| @@ -1,12 +1,13 @@ | ||||
| <template> | ||||
| <x-code :code="code" :lang="lang" :inline="inline"/> | ||||
| <XCode :code="code" :lang="lang" :inline="inline"/> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| export default Vue.extend({ | ||||
| import { defineComponent, defineAsyncComponent } from 'vue'; | ||||
|  | ||||
| export default defineComponent({ | ||||
| 	components: { | ||||
| 		XCode: () => import('./code-core.vue').then(m => m.default) | ||||
| 		XCode: defineAsyncComponent(() => import('./code-core.vue')) | ||||
| 	}, | ||||
| 	props: { | ||||
| 		code: { | ||||
|   | ||||
| @@ -1,19 +1,16 @@ | ||||
| <template> | ||||
| <button class="nrvgflfuaxwgkxoynpnumyookecqrrvh _button" @click="toggle"> | ||||
| 	<b>{{ value ? this.$t('_cw.hide') : this.$t('_cw.show') }}</b> | ||||
| 	<span v-if="!value">{{ this.label }}</span> | ||||
| <button class="nrvgflfu _button" @click="toggle"> | ||||
| 	<b>{{ value ? $ts._cw.hide : $ts._cw.show }}</b> | ||||
| 	<span v-if="!value">{{ label }}</span> | ||||
| </button> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import i18n from '../i18n'; | ||||
| import { defineComponent } from 'vue'; | ||||
| import { length } from 'stringz'; | ||||
| import { concat } from '../../prelude/array'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n, | ||||
|  | ||||
| export default defineComponent({ | ||||
| 	props: { | ||||
| 		value: { | ||||
| 			type: Boolean, | ||||
| @@ -30,7 +27,7 @@ export default Vue.extend({ | ||||
| 			return concat([ | ||||
| 				this.note.text ? [this.$t('_cw.chars', { count: length(this.note.text) })] : [], | ||||
| 				this.note.files && this.note.files.length !== 0 ? [this.$t('_cw.files', { count: this.note.files.length }) ] : [], | ||||
| 				this.note.poll != null ? [this.$t('_cw.poll')] : [] | ||||
| 				this.note.poll != null ? [this.$ts.poll] : [] | ||||
| 			] as string[][]).join(' / '); | ||||
| 		} | ||||
| 	}, | ||||
| @@ -39,14 +36,14 @@ export default Vue.extend({ | ||||
| 		length, | ||||
|  | ||||
| 		toggle() { | ||||
| 			this.$emit('input', !this.value); | ||||
| 			this.$emit('update:value', !this.value); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="scss" scoped> | ||||
| .nrvgflfuaxwgkxoynpnumyookecqrrvh { | ||||
| .nrvgflfu { | ||||
| 	display: inline-block; | ||||
| 	padding: 4px 8px; | ||||
| 	font-size: 0.7em; | ||||
|   | ||||
| @@ -1,25 +1,9 @@ | ||||
| <template> | ||||
| <component :is="$store.state.device.animation ? 'transition-group' : 'div'" class="sqadhkmv" name="list" tag="div" :data-direction="direction" :data-reversed="reversed ? 'true' : 'false'"> | ||||
| 	<template v-for="(item, i) in items"> | ||||
| 		<slot :item="item"></slot> | ||||
| 		<div class="separator" v-if="showDate(i, item)" :key="item.id + '_date'"> | ||||
| 			<p class="date"> | ||||
| 				<span><fa class="icon" :icon="faAngleUp"/>{{ getDateText(item.createdAt) }}</span> | ||||
| 				<span>{{ getDateText(items[i + 1].createdAt) }}<fa class="icon" :icon="faAngleDown"/></span> | ||||
| 			</p> | ||||
| 		</div> | ||||
| 	</template> | ||||
| </component> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { defineComponent, h, TransitionGroup } from 'vue'; | ||||
| import { faAngleUp, faAngleDown } from '@fortawesome/free-solid-svg-icons'; | ||||
| import i18n from '../i18n'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n, | ||||
| import { FontAwesomeIcon } from '@fortawesome/vue-fontawesome'; | ||||
|  | ||||
| export default defineComponent({ | ||||
| 	props: { | ||||
| 		items: { | ||||
| 			type: Array, | ||||
| @@ -37,41 +21,81 @@ export default Vue.extend({ | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			faAngleUp, faAngleDown | ||||
| 		}; | ||||
| 	methods: { | ||||
| 		focus() { | ||||
| 			this.$slots.default[0].elm.focus(); | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		getDateText(time: string) { | ||||
| 	render() { | ||||
| 		const getDateText = (time: string) => { | ||||
| 			const date = new Date(time).getDate(); | ||||
| 			const month = new Date(time).getMonth() + 1; | ||||
| 			return this.$t('monthAndDay', { | ||||
| 				month: month.toString(), | ||||
| 				day: date.toString() | ||||
| 			}); | ||||
| 		}, | ||||
| 		} | ||||
|  | ||||
| 		showDate(i, item) { | ||||
| 			return ( | ||||
| 		return h(this.$store.state.animation ? TransitionGroup : 'div', this.$store.state.animation ? { | ||||
| 			class: 'sqadhkmv _list_', | ||||
| 			name: 'list', | ||||
| 			tag: 'div', | ||||
| 			'data-direction': this.direction, | ||||
| 			'data-reversed': this.reversed ? 'true' : 'false', | ||||
| 		} : { | ||||
| 			class: 'sqadhkmv _list_', | ||||
| 		}, this.items.map((item, i) => { | ||||
| 			const el = this.$slots.default({ | ||||
| 				item: item | ||||
| 			})[0]; | ||||
| 			el.key = item.id; | ||||
|  | ||||
| 			if ( | ||||
| 				i != this.items.length - 1 && | ||||
| 				new Date(item.createdAt).getDate() != new Date(this.items[i + 1].createdAt).getDate() && | ||||
| 				!item._prId_ && | ||||
| 				!this.items[i + 1]._prId_ && | ||||
| 				!item._featuredId_ && | ||||
| 				!this.items[i + 1]._featuredId_); | ||||
| 		}, | ||||
| 				!this.items[i + 1]._featuredId_ | ||||
| 			) { | ||||
| 				const separator = h('div', { | ||||
| 					class: 'separator', | ||||
| 					key: item.id + ':separator', | ||||
| 				}, h('p', { | ||||
| 					class: 'date' | ||||
| 				}, [ | ||||
| 					h('span', [ | ||||
| 						h(FontAwesomeIcon, { | ||||
| 							class: 'icon', | ||||
| 							icon: faAngleUp, | ||||
| 						}), | ||||
| 						getDateText(item.createdAt) | ||||
| 					]), | ||||
| 					h('span', [ | ||||
| 						getDateText(this.items[i + 1].createdAt), | ||||
| 						h(FontAwesomeIcon, { | ||||
| 							class: 'icon', | ||||
| 							icon: faAngleDown, | ||||
| 						}) | ||||
| 					]) | ||||
| 				])); | ||||
|  | ||||
| 		focus() { | ||||
| 			this.$slots.default[0].elm.focus(); | ||||
| 		} | ||||
| 	} | ||||
| 				return [el, separator]; | ||||
| 			} else { | ||||
| 				return el; | ||||
| 			} | ||||
| 		})); | ||||
| 	}, | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="scss"> | ||||
| .sqadhkmv { | ||||
| 	> *:not(:last-child) { | ||||
| 		margin-bottom: var(--margin); | ||||
| 	} | ||||
|  | ||||
| 	> .list-move { | ||||
| 		transition: transform 0.7s cubic-bezier(0.23, 1, 0.32, 1); | ||||
| 	} | ||||
| @@ -81,14 +105,14 @@ export default Vue.extend({ | ||||
| 	} | ||||
|  | ||||
| 	&[data-direction="up"] { | ||||
| 		> .list-enter { | ||||
| 		> .list-enter-from { | ||||
| 			opacity: 0; | ||||
| 			transform: translateY(64px); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	&[data-direction="down"] { | ||||
| 		> .list-enter { | ||||
| 		> .list-enter-from { | ||||
| 			opacity: 0; | ||||
| 			transform: translateY(-64px); | ||||
| 		} | ||||
| @@ -96,7 +120,7 @@ export default Vue.extend({ | ||||
| } | ||||
| </style> | ||||
|  | ||||
| <style lang="scss" scoped> | ||||
| <style lang="scss"> | ||||
| .sqadhkmv { | ||||
| 	> .separator { | ||||
| 		text-align: center; | ||||
|   | ||||
| @@ -1,72 +1,56 @@ | ||||
| <template> | ||||
| <div class="mk-dialog" :class="{ iconOnly }"> | ||||
| 	<transition :name="$store.state.device.animation ? 'bg-fade' : ''" appear> | ||||
| 		<div class="bg" ref="bg" @click="onBgClick" v-if="show"></div> | ||||
| 	</transition> | ||||
| 	<transition :name="$store.state.device.animation ? 'dialog' : ''" appear @after-leave="() => { destroyDom(); }"> | ||||
| 		<div class="main" ref="main" v-if="show"> | ||||
| 			<template v-if="type == 'signin'"> | ||||
| 				<mk-signin/> | ||||
| <MkModal ref="modal" @click="done(true)" @closed="$emit('closed')"> | ||||
| 	<div class="mk-dialog"> | ||||
| 		<div class="icon" v-if="icon"> | ||||
| 			<Fa :icon="icon"/> | ||||
| 		</div> | ||||
| 		<div class="icon" v-else-if="!input && !select" :class="type"> | ||||
| 			<Fa :icon="faCheck" v-if="type === 'success'"/> | ||||
| 			<Fa :icon="faTimesCircle" v-if="type === 'error'"/> | ||||
| 			<Fa :icon="faExclamationTriangle" v-if="type === 'warning'"/> | ||||
| 			<Fa :icon="faInfoCircle" v-if="type === 'info'"/> | ||||
| 			<Fa :icon="faQuestionCircle" v-if="type === 'question'"/> | ||||
| 			<Fa :icon="faSpinner" pulse v-if="type === 'waiting'"/> | ||||
| 		</div> | ||||
| 		<header v-if="title"><Mfm :text="title"/></header> | ||||
| 		<div class="body" v-if="text"><Mfm :text="text"/></div> | ||||
| 		<MkInput v-if="input" v-model:value="inputValue" autofocus :type="input.type || 'text'" :placeholder="input.placeholder" @keydown="onInputKeydown"></MkInput> | ||||
| 		<MkSelect v-if="select" v-model:value="selectedValue" autofocus> | ||||
| 			<template v-if="select.items"> | ||||
| 				<option v-for="item in select.items" :value="item.value">{{ item.text }}</option> | ||||
| 			</template> | ||||
| 			<template v-else> | ||||
| 				<div class="icon" v-if="icon"> | ||||
| 					<fa :icon="icon"/> | ||||
| 				</div> | ||||
| 				<div class="icon" v-else-if="!input && !select && !user" :class="type"> | ||||
| 					<fa :icon="faCheck" v-if="type === 'success'"/> | ||||
| 					<fa :icon="faTimesCircle" v-if="type === 'error'"/> | ||||
| 					<fa :icon="faExclamationTriangle" v-if="type === 'warning'"/> | ||||
| 					<fa :icon="faInfoCircle" v-if="type === 'info'"/> | ||||
| 					<fa :icon="faQuestionCircle" v-if="type === 'question'"/> | ||||
| 					<fa :icon="faSpinner" pulse v-if="type === 'waiting'"/> | ||||
| 				</div> | ||||
| 				<header v-if="title" v-html="title"></header> | ||||
| 				<header v-if="title == null && user">{{ $t('enterUsername') }}</header> | ||||
| 				<div class="body" v-if="text" v-html="text"></div> | ||||
| 				<mk-input v-if="input" v-model="inputValue" autofocus :type="input.type || 'text'" :placeholder="input.placeholder" @keydown="onInputKeydown"></mk-input> | ||||
| 				<mk-input v-if="user" v-model="userInputValue" autofocus @keydown="onInputKeydown"><template #prefix>@</template></mk-input> | ||||
| 				<mk-select v-if="select" v-model="selectedValue" autofocus> | ||||
| 					<template v-if="select.items"> | ||||
| 						<option v-for="item in select.items" :value="item.value">{{ item.text }}</option> | ||||
| 					</template> | ||||
| 					<template v-else> | ||||
| 						<optgroup v-for="groupedItem in select.groupedItems" :label="groupedItem.label"> | ||||
| 							<option v-for="item in groupedItem.items" :value="item.value">{{ item.text }}</option> | ||||
| 						</optgroup> | ||||
| 					</template> | ||||
| 				</mk-select> | ||||
| 				<div class="buttons" v-if="!iconOnly && (showOkButton || showCancelButton) && !actions"> | ||||
| 					<mk-button inline @click="ok" v-if="showOkButton" primary :autofocus="!input && !select && !user" :disabled="!canOk">{{ (showCancelButton || input || select || user) ? $t('ok') : $t('gotIt') }}</mk-button> | ||||
| 					<mk-button inline @click="cancel" v-if="showCancelButton || input || select || user">{{ $t('cancel') }}</mk-button> | ||||
| 				</div> | ||||
| 				<div class="buttons" v-if="actions"> | ||||
| 					<mk-button v-for="action in actions" inline @click="() => { action.callback(); close(); }" :primary="action.primary" :key="action.text">{{ action.text }}</mk-button> | ||||
| 				</div> | ||||
| 				<optgroup v-for="groupedItem in select.groupedItems" :label="groupedItem.label"> | ||||
| 					<option v-for="item in groupedItem.items" :value="item.value">{{ item.text }}</option> | ||||
| 				</optgroup> | ||||
| 			</template> | ||||
| 		</MkSelect> | ||||
| 		<div class="buttons" v-if="(showOkButton || showCancelButton) && !actions"> | ||||
| 			<MkButton inline @click="ok" v-if="showOkButton" primary :autofocus="!input && !select">{{ (showCancelButton || input || select) ? $ts.ok : $ts.gotIt }}</MkButton> | ||||
| 			<MkButton inline @click="cancel" v-if="showCancelButton || input || select">{{ $ts.cancel }}</MkButton> | ||||
| 		</div> | ||||
| 	</transition> | ||||
| </div> | ||||
| 		<div class="buttons" v-if="actions"> | ||||
| 			<MkButton v-for="action in actions" inline @click="() => { action.callback(); close(); }" :primary="action.primary" :key="action.text">{{ action.text }}</MkButton> | ||||
| 		</div> | ||||
| 	</div> | ||||
| </MkModal> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { defineComponent } from 'vue'; | ||||
| import { faSpinner, faInfoCircle, faExclamationTriangle, faCheck } from '@fortawesome/free-solid-svg-icons'; | ||||
| import { faTimesCircle, faQuestionCircle } from '@fortawesome/free-regular-svg-icons'; | ||||
| import MkButton from './ui/button.vue'; | ||||
| import MkInput from './ui/input.vue'; | ||||
| import MkSelect from './ui/select.vue'; | ||||
| import MkSignin from './signin.vue'; | ||||
| import parseAcct from '../../misc/acct/parse'; | ||||
| import i18n from '../i18n'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n, | ||||
| import MkModal from '@/components/ui/modal.vue'; | ||||
| import MkButton from '@/components/ui/button.vue'; | ||||
| import MkInput from '@/components/ui/input.vue'; | ||||
| import MkSelect from '@/components/ui/select.vue'; | ||||
|  | ||||
| export default defineComponent({ | ||||
| 	components: { | ||||
| 		MkModal, | ||||
| 		MkButton, | ||||
| 		MkInput, | ||||
| 		MkSelect, | ||||
| 		MkSignin, | ||||
| 	}, | ||||
|  | ||||
| 	props: { | ||||
| @@ -89,9 +73,6 @@ export default Vue.extend({ | ||||
| 		select: { | ||||
| 			required: false | ||||
| 		}, | ||||
| 		user: { | ||||
| 			required: false | ||||
| 		}, | ||||
| 		icon: { | ||||
| 			required: false | ||||
| 		}, | ||||
| @@ -110,87 +91,44 @@ export default Vue.extend({ | ||||
| 			type: Boolean, | ||||
| 			default: true | ||||
| 		}, | ||||
| 		iconOnly: { | ||||
| 			type: Boolean, | ||||
| 			default: false | ||||
| 		}, | ||||
| 		autoClose: { | ||||
| 			type: Boolean, | ||||
| 			default: false | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	emits: ['done', 'closed'], | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			show: true, | ||||
| 			inputValue: this.input && this.input.default ? this.input.default : null, | ||||
| 			userInputValue: null, | ||||
| 			selectedValue: this.select ? this.select.default ? this.select.default : this.select.items ? this.select.items[0].value : this.select.groupedItems[0].items[0].value : null, | ||||
| 			canOk: true, | ||||
| 			faTimesCircle, faQuestionCircle, faSpinner, faInfoCircle, faExclamationTriangle, faCheck | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	watch: { | ||||
| 		userInputValue() { | ||||
| 			if (this.user) { | ||||
| 				this.$root.api('users/show', parseAcct(this.userInputValue)).then(u => { | ||||
| 					this.canOk = u != null; | ||||
| 				}).catch(() => { | ||||
| 					this.canOk = false; | ||||
| 				}); | ||||
| 			} | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	mounted() { | ||||
| 		if (this.user) this.canOk = false; | ||||
|  | ||||
| 		if (this.autoClose) { | ||||
| 			setTimeout(() => { | ||||
| 				this.close(); | ||||
| 			}, 1000); | ||||
| 		} | ||||
|  | ||||
| 		document.addEventListener('keydown', this.onKeydown); | ||||
| 	}, | ||||
|  | ||||
| 	beforeDestroy() { | ||||
| 	beforeUnmount() { | ||||
| 		document.removeEventListener('keydown', this.onKeydown); | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		done(canceled, result?) { | ||||
| 			this.$emit('done', { canceled, result }); | ||||
| 			this.$refs.modal.close(); | ||||
| 		}, | ||||
|  | ||||
| 		async ok() { | ||||
| 			if (!this.canOk) return; | ||||
| 			if (!this.showOkButton) return; | ||||
|  | ||||
| 			if (this.user) { | ||||
| 				const user = await this.$root.api('users/show', parseAcct(this.userInputValue)); | ||||
| 				if (user) { | ||||
| 					this.$emit('ok', user); | ||||
| 					this.close(); | ||||
| 				} | ||||
| 			} else { | ||||
| 				const result = | ||||
| 					this.input ? this.inputValue : | ||||
| 					this.select ? this.selectedValue : | ||||
| 					true; | ||||
| 				this.$emit('ok', result); | ||||
| 				this.close(); | ||||
| 			} | ||||
| 			const result = | ||||
| 				this.input ? this.inputValue : | ||||
| 				this.select ? this.selectedValue : | ||||
| 				true; | ||||
| 			this.done(false, result); | ||||
| 		}, | ||||
|  | ||||
| 		cancel() { | ||||
| 			this.$emit('cancel'); | ||||
| 			this.close(); | ||||
| 		}, | ||||
|  | ||||
| 		close() { | ||||
| 			if (!this.show) return; | ||||
| 			this.show = false; | ||||
| 			this.$el.style.pointerEvents = 'none'; | ||||
| 			(this.$refs.bg as any).style.pointerEvents = 'none'; | ||||
| 			(this.$refs.main as any).style.pointerEvents = 'none'; | ||||
| 			this.done(true); | ||||
| 		}, | ||||
|  | ||||
| 		onBgClick() { | ||||
| @@ -217,105 +155,60 @@ export default Vue.extend({ | ||||
| </script> | ||||
|  | ||||
| <style lang="scss" scoped> | ||||
| .dialog-enter-active, .dialog-leave-active { | ||||
| 	transition: opacity 0.3s, transform 0.3s !important; | ||||
| } | ||||
| .dialog-enter, .dialog-leave-to { | ||||
| 	opacity: 0; | ||||
| 	transform: scale(0.9); | ||||
| } | ||||
|  | ||||
| .bg-fade-enter-active, .bg-fade-leave-active { | ||||
| 	transition: opacity 0.3s !important; | ||||
| } | ||||
| .bg-fade-enter, .bg-fade-leave-to { | ||||
| 	opacity: 0; | ||||
| } | ||||
|  | ||||
| .mk-dialog { | ||||
| 	display: flex; | ||||
| 	align-items: center; | ||||
| 	justify-content: center; | ||||
| 	position: fixed; | ||||
| 	z-index: 30000; | ||||
| 	top: 0; | ||||
| 	left: 0; | ||||
| 	width: 100%; | ||||
| 	height: 100%; | ||||
| 	position: relative; | ||||
| 	padding: 32px; | ||||
| 	min-width: 320px; | ||||
| 	max-width: 480px; | ||||
| 	box-sizing: border-box; | ||||
| 	text-align: center; | ||||
| 	background: var(--panel); | ||||
| 	border-radius: var(--radius); | ||||
|  | ||||
| 	&.iconOnly > .main { | ||||
| 		min-width: 0; | ||||
| 		width: initial; | ||||
| 	} | ||||
| 	> .icon { | ||||
| 		font-size: 32px; | ||||
|  | ||||
| 	> .bg { | ||||
| 		display: block; | ||||
| 		position: fixed; | ||||
| 		top: 0; | ||||
| 		left: 0; | ||||
| 		width: 100%; | ||||
| 		height: 100%; | ||||
| 		background: rgba(0,0,0,0.7); | ||||
| 	} | ||||
|  | ||||
| 	> .main { | ||||
| 		display: block; | ||||
| 		position: fixed; | ||||
| 		margin: auto; | ||||
| 		padding: 32px; | ||||
| 		min-width: 320px; | ||||
| 		max-width: 480px; | ||||
| 		box-sizing: border-box; | ||||
| 		width: calc(100% - 32px); | ||||
| 		text-align: center; | ||||
| 		background: var(--panel); | ||||
| 		border-radius: var(--radius); | ||||
|  | ||||
| 		> .icon { | ||||
| 			font-size: 32px; | ||||
|  | ||||
| 			&.success { | ||||
| 				color: var(--accent); | ||||
| 			} | ||||
|  | ||||
| 			&.error { | ||||
| 				color: #ec4137; | ||||
| 			} | ||||
|  | ||||
| 			&.warning { | ||||
| 				color: #ecb637; | ||||
| 			} | ||||
|  | ||||
| 			> * { | ||||
| 				display: block; | ||||
| 				margin: 0 auto; | ||||
| 			} | ||||
|  | ||||
| 			& + header { | ||||
| 				margin-top: 16px; | ||||
| 			} | ||||
| 		&.success { | ||||
| 			color: var(--success); | ||||
| 		} | ||||
|  | ||||
| 		> header { | ||||
| 			margin: 0 0 8px 0; | ||||
| 			font-weight: bold; | ||||
| 			font-size: 20px; | ||||
|  | ||||
| 			& + .body { | ||||
| 				margin-top: 8px; | ||||
| 			} | ||||
| 		&.error { | ||||
| 			color: var(--error); | ||||
| 		} | ||||
|  | ||||
| 		> .body { | ||||
| 			margin: 16px 0 0 0; | ||||
| 		&.warning { | ||||
| 			color: var(--warn); | ||||
| 		} | ||||
|  | ||||
| 		> .buttons { | ||||
| 		> * { | ||||
| 			display: block; | ||||
| 			margin: 0 auto; | ||||
| 		} | ||||
|  | ||||
| 		& + header { | ||||
| 			margin-top: 16px; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 			> * { | ||||
| 				margin: 0 8px; | ||||
| 			} | ||||
| 	> header { | ||||
| 		margin: 0 0 8px 0; | ||||
| 		font-weight: bold; | ||||
| 		font-size: 20px; | ||||
|  | ||||
| 		& + .body { | ||||
| 			margin-top: 8px; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	> .body { | ||||
| 		margin: 16px 0 0 0; | ||||
| 	} | ||||
|  | ||||
| 	> .buttons { | ||||
| 		margin-top: 16px; | ||||
|  | ||||
| 		> * { | ||||
| 			margin: 0 8px; | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|   | ||||
| @@ -1,41 +1,20 @@ | ||||
| <template> | ||||
| <div class="zdjebgpv" :class="{ detail }" ref="thumbnail" :style="`background-color: ${ background }`"> | ||||
| 	<img | ||||
| 		:src="file.url" | ||||
| 		:alt="file.name" | ||||
| 		:title="file.name" | ||||
| 		@load="onThumbnailLoaded" | ||||
| 		v-if="detail && is === 'image'"/> | ||||
| 	<video | ||||
| 		:src="file.url" | ||||
| 		ref="volumectrl" | ||||
| 		preload="metadata" | ||||
| 		controls | ||||
| 		v-else-if="detail && is === 'video'"/> | ||||
| 	<img :src="file.thumbnailUrl" @load="onThumbnailLoaded" :style="`object-fit: ${ fit }`" v-else-if="isThumbnailAvailable"/> | ||||
| 	<fa :icon="faFileImage" class="icon" v-else-if="is === 'image'"/> | ||||
| 	<fa :icon="faFileVideo" class="icon" v-else-if="is === 'video'"/> | ||||
|  | ||||
| 	<audio | ||||
| 		:src="file.url" | ||||
| 		ref="volumectrl" | ||||
| 		preload="metadata" | ||||
| 		controls | ||||
| 		v-else-if="detail && is === 'audio'"/> | ||||
| 	<fa :icon="faMusic" class="icon" v-else-if="is === 'audio' || is === 'midi'"/> | ||||
|  | ||||
| 	<fa :icon="faFileCsv" class="icon" v-else-if="is === 'csv'"/> | ||||
| 	<fa :icon="faFilePdf" class="icon" v-else-if="is === 'pdf'"/> | ||||
| 	<fa :icon="faFileAlt" class="icon" v-else-if="is === 'textfile'"/> | ||||
| 	<fa :icon="faFileArchive" class="icon" v-else-if="is === 'archive'"/> | ||||
| 	<fa :icon="faFile" class="icon" v-else/> | ||||
|  | ||||
| 	<fa :icon="faFilm" class="icon-sub" v-if="!detail && isThumbnailAvailable && is === 'video'"/> | ||||
| <div class="zdjebgpv" ref="thumbnail"> | ||||
| 	<ImgWithBlurhash v-if="isThumbnailAvailable" :hash="file.blurhash" :src="file.thumbnailUrl" :alt="file.name" :title="file.name" :style="`object-fit: ${ fit }`"/> | ||||
| 	<Fa :icon="faFileImage" class="icon" v-else-if="is === 'image'"/> | ||||
| 	<Fa :icon="faFileVideo" class="icon" v-else-if="is === 'video'"/> | ||||
| 	<Fa :icon="faMusic" class="icon" v-else-if="is === 'audio' || is === 'midi'"/> | ||||
| 	<Fa :icon="faFileCsv" class="icon" v-else-if="is === 'csv'"/> | ||||
| 	<Fa :icon="faFilePdf" class="icon" v-else-if="is === 'pdf'"/> | ||||
| 	<Fa :icon="faFileAlt" class="icon" v-else-if="is === 'textfile'"/> | ||||
| 	<Fa :icon="faFileArchive" class="icon" v-else-if="is === 'archive'"/> | ||||
| 	<Fa :icon="faFile" class="icon" v-else/> | ||||
| 	<Fa :icon="faFilm" class="icon-sub" v-if="isThumbnailAvailable && is === 'video'"/> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { defineComponent } from 'vue'; | ||||
| import { | ||||
| 	faFile, | ||||
| 	faFileAlt, | ||||
| @@ -47,8 +26,13 @@ import { | ||||
| 	faFileArchive, | ||||
| 	faFilm | ||||
| 	} from '@fortawesome/free-solid-svg-icons'; | ||||
| import ImgWithBlurhash from './img-with-blurhash.vue'; | ||||
| import { ColdDeviceStorage } from '@/store'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| export default defineComponent({ | ||||
| 	components: { | ||||
| 		ImgWithBlurhash | ||||
| 	}, | ||||
| 	props: { | ||||
| 		file: { | ||||
| 			type: Object, | ||||
| @@ -59,11 +43,6 @@ export default Vue.extend({ | ||||
| 			required: false, | ||||
| 			default: 'cover' | ||||
| 		}, | ||||
| 		detail: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		} | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| @@ -108,23 +87,15 @@ export default Vue.extend({ | ||||
| 				? (this.is === 'image' || this.is === 'video') | ||||
| 				: false; | ||||
| 		}, | ||||
| 		background(): string { | ||||
| 			return this.file.properties.avgColor || 'transparent'; | ||||
| 		} | ||||
| 	}, | ||||
| 	mounted() { | ||||
| 		const audioTag = this.$refs.volumectrl as HTMLAudioElement; | ||||
| 		if (audioTag) audioTag.volume = this.$store.state.device.mediaVolume; | ||||
| 		if (audioTag) audioTag.volume = ColdDeviceStorage.get('mediaVolume'); | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		onThumbnailLoaded() { | ||||
| 			if (this.file.properties.avgColor) { | ||||
| 				this.$refs.thumbnail.style.backgroundColor = 'transparent'; | ||||
| 			} | ||||
| 		}, | ||||
| 		volumechange() { | ||||
| 			const audioTag = this.$refs.volumectrl as HTMLAudioElement; | ||||
| 			this.$store.commit('device/set', { key: 'mediaVolume', value: audioTag.volume }); | ||||
| 			ColdDeviceStorage.set('mediaVolume', audioTag.volume); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| @@ -132,14 +103,8 @@ export default Vue.extend({ | ||||
|  | ||||
| <style lang="scss" scoped> | ||||
| .zdjebgpv { | ||||
| 	display: flex; | ||||
| 	position: relative; | ||||
|  | ||||
| 	> img, | ||||
| 	> .icon { | ||||
| 		pointer-events: none; | ||||
| 	} | ||||
|  | ||||
| 	> .icon-sub { | ||||
| 		position: absolute; | ||||
| 		width: 30%; | ||||
| @@ -153,37 +118,10 @@ export default Vue.extend({ | ||||
| 		margin: auto; | ||||
| 	} | ||||
|  | ||||
| 	&:not(.detail) { | ||||
| 		> img { | ||||
| 			height: 100%; | ||||
| 			width: 100%; | ||||
| 			object-fit: cover; | ||||
| 		} | ||||
|  | ||||
| 		> .icon { | ||||
| 			height: 65%; | ||||
| 			width: 65%; | ||||
| 		} | ||||
|  | ||||
| 		> video, | ||||
| 		> audio { | ||||
| 			width: 100%; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	&.detail { | ||||
| 		> .icon { | ||||
| 			height: 100px; | ||||
| 			width: 100px; | ||||
| 			margin: 16px; | ||||
| 		} | ||||
|  | ||||
| 		> *:not(.icon) { | ||||
| 			max-height: 300px; | ||||
| 			max-width: 100%; | ||||
| 			height: 100%; | ||||
| 			object-fit: contain; | ||||
| 		} | ||||
| 	> .icon { | ||||
| 		pointer-events: none; | ||||
| 		height: 65%; | ||||
| 		width: 65%; | ||||
| 	} | ||||
| } | ||||
| </style> | ||||
|   | ||||
							
								
								
									
										70
									
								
								src/client/components/drive-select-dialog.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								src/client/components/drive-select-dialog.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,70 @@ | ||||
| <template> | ||||
| <XModalWindow ref="dialog" | ||||
| 	:width="800" | ||||
| 	:height="500" | ||||
| 	:with-ok-button="true" | ||||
| 	:ok-button-disabled="(type === 'file') && (selected.length === 0)" | ||||
| 	@click="cancel()" | ||||
| 	@close="cancel()" | ||||
| 	@ok="ok()" | ||||
| 	@closed="$emit('closed')" | ||||
| > | ||||
| 	<template #header> | ||||
| 		{{ multiple ? ((type === 'file') ? $ts.selectFiles : $ts.selectFolders) : ((type === 'file') ? $ts.selectFile : $ts.selectFolder) }} | ||||
| 		<span v-if="selected.length > 0" style="margin-left: 8px; opacity: 0.5;">({{ number(selected.length) }})</span> | ||||
| 	</template> | ||||
| 	<XDrive :multiple="multiple" @changeSelection="onChangeSelection" @selected="ok()" :select="type"/> | ||||
| </XModalWindow> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import { defineComponent } from 'vue'; | ||||
| import XDrive from './drive.vue'; | ||||
| import XModalWindow from '@/components/ui/modal-window.vue'; | ||||
| import number from '@/filters/number'; | ||||
|  | ||||
| export default defineComponent({ | ||||
| 	components: { | ||||
| 		XDrive, | ||||
| 		XModalWindow, | ||||
| 	}, | ||||
|  | ||||
| 	props: { | ||||
| 		type: { | ||||
| 			type: String, | ||||
| 			required: false, | ||||
| 			default: 'file' | ||||
| 		}, | ||||
| 		multiple: { | ||||
| 			type: Boolean, | ||||
| 			default: false | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	emits: ['done', 'closed'], | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			selected: [] | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		ok() { | ||||
| 			this.$emit('done', this.selected); | ||||
| 			this.$refs.dialog.close(); | ||||
| 		}, | ||||
|  | ||||
| 		cancel() { | ||||
| 			this.$emit('done'); | ||||
| 			this.$refs.dialog.close(); | ||||
| 		}, | ||||
|  | ||||
| 		onChangeSelection(xs) { | ||||
| 			this.selected = xs; | ||||
| 		}, | ||||
|  | ||||
| 		number | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
| @@ -1,56 +1,44 @@ | ||||
| <template> | ||||
| <x-window ref="window" :width="800" :height="500" @closed="() => { $emit('closed'); destroyDom(); }" :with-ok-button="true" :ok-button-disabled="(type === 'file') && (selected.length === 0)" @ok="ok()"> | ||||
| <XWindow ref="window" | ||||
| 	:initial-width="800" | ||||
| 	:initial-height="500" | ||||
| 	:can-resize="true" | ||||
| 	@closed="$emit('closed')" | ||||
| > | ||||
| 	<template #header> | ||||
| 		{{ multiple ? ((type === 'file') ? $t('selectFiles') : $t('selectFolders')) : ((type === 'file') ? $t('selectFile') : $t('selectFolder')) }} | ||||
| 		<span v-if="selected.length > 0" style="margin-left: 8px; opacity: 0.5;">({{ selected.length | number }})</span> | ||||
| 		{{ $ts.drive }} | ||||
| 	</template> | ||||
| 	<div> | ||||
| 		<x-drive :multiple="multiple" @change-selection="onChangeSelection" :select="type"/> | ||||
| 	</div> | ||||
| </x-window> | ||||
| 	<XDrive :initial-folder="initialFolder"/> | ||||
| </XWindow> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import i18n from '../i18n'; | ||||
| import { defineComponent } from 'vue'; | ||||
| import XDrive from './drive.vue'; | ||||
| import XWindow from './window.vue'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n, | ||||
| import XWindow from '@/components/ui/window.vue'; | ||||
|  | ||||
| export default defineComponent({ | ||||
| 	components: { | ||||
| 		XDrive, | ||||
| 		XWindow, | ||||
| 	}, | ||||
|  | ||||
| 	props: { | ||||
| 		type: { | ||||
| 			type: String, | ||||
| 			required: false, | ||||
| 			default: 'file'  | ||||
| 		initialFolder: { | ||||
| 			type: Object, | ||||
| 			required: false | ||||
| 		}, | ||||
| 		multiple: { | ||||
| 			type: Boolean, | ||||
| 			default: false | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	emits: ['closed'], | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			selected: [] | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		ok() { | ||||
| 			this.$emit('selected', this.selected); | ||||
| 			this.$refs.window.close(); | ||||
| 		}, | ||||
|  | ||||
| 		onChangeSelection(xs) { | ||||
| 			this.selected = xs; | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|   | ||||
| @@ -1,26 +1,27 @@ | ||||
| <template> | ||||
| <div class="ncvczrfv" | ||||
| 	:data-is-selected="isSelected" | ||||
| 	:class="{ isSelected }" | ||||
| 	@click="onClick" | ||||
| 	@contextmenu.stop="onContextmenu" | ||||
| 	draggable="true" | ||||
| 	@dragstart="onDragstart" | ||||
| 	@dragend="onDragend" | ||||
| 	:title="title" | ||||
| > | ||||
| 	<div class="label" v-if="$store.state.i.avatarId == file.id"> | ||||
| 	<div class="label" v-if="$i.avatarId == file.id"> | ||||
| 		<img src="/assets/label.svg"/> | ||||
| 		<p>{{ $t('avatar') }}</p> | ||||
| 		<p>{{ $ts.avatar }}</p> | ||||
| 	</div> | ||||
| 	<div class="label" v-if="$store.state.i.bannerId == file.id"> | ||||
| 	<div class="label" v-if="$i.bannerId == file.id"> | ||||
| 		<img src="/assets/label.svg"/> | ||||
| 		<p>{{ $t('banner') }}</p> | ||||
| 		<p>{{ $ts.banner }}</p> | ||||
| 	</div> | ||||
| 	<div class="label red" v-if="file.isSensitive"> | ||||
| 		<img src="/assets/label-red.svg"/> | ||||
| 		<p>{{ $t('nsfw') }}</p> | ||||
| 		<p>{{ $ts.nsfw }}</p> | ||||
| 	</div> | ||||
|  | ||||
| 	<x-file-thumbnail class="thumbnail" :file="file" fit="contain"/> | ||||
| 	<MkDriveFileThumbnail class="thumbnail" :file="file" fit="contain"/> | ||||
|  | ||||
| 	<p class="name"> | ||||
| 		<span>{{ file.name.lastIndexOf('.') != -1 ? file.name.substr(0, file.name.lastIndexOf('.')) : file.name }}</span> | ||||
| @@ -30,20 +31,17 @@ | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { defineComponent } from 'vue'; | ||||
| import { faEye, faEyeSlash } from '@fortawesome/free-regular-svg-icons'; | ||||
| import i18n from '../i18n'; | ||||
| import copyToClipboard from '../scripts/copy-to-clipboard'; | ||||
| //import updateAvatar from '../api/update-avatar'; | ||||
| //import updateBanner from '../api/update-banner'; | ||||
| import XFileThumbnail from './drive-file-thumbnail.vue'; | ||||
| import { faDownload, faLink, faICursor, faTrashAlt } from '@fortawesome/free-solid-svg-icons'; | ||||
| import copyToClipboard from '@/scripts/copy-to-clipboard'; | ||||
| import MkDriveFileThumbnail from './drive-file-thumbnail.vue'; | ||||
| import bytes from '../filters/bytes'; | ||||
| import * as os from '@/os'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n, | ||||
|  | ||||
| export default defineComponent({ | ||||
| 	components: { | ||||
| 		XFileThumbnail | ||||
| 		MkDriveFileThumbnail | ||||
| 	}, | ||||
|  | ||||
| 	props: { | ||||
| @@ -63,6 +61,8 @@ export default Vue.extend({ | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	emits: ['chosen'], | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			isDragging: false | ||||
| @@ -75,48 +75,54 @@ export default Vue.extend({ | ||||
| 			return this.$parent; | ||||
| 		}, | ||||
| 		title(): string { | ||||
| 			return `${this.file.name}\n${this.file.type} ${Vue.filter('bytes')(this.file.size)}`; | ||||
| 			return `${this.file.name}\n${this.file.type} ${bytes(this.file.size)}`; | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		getMenu() { | ||||
| 			return [{ | ||||
| 				text: this.$ts.rename, | ||||
| 				icon: faICursor, | ||||
| 				action: this.rename | ||||
| 			}, { | ||||
| 				text: this.file.isSensitive ? this.$ts.unmarkAsSensitive : this.$ts.markAsSensitive, | ||||
| 				icon: this.file.isSensitive ? faEye : faEyeSlash, | ||||
| 				action: this.toggleSensitive | ||||
| 			}, null, { | ||||
| 				text: this.$ts.copyUrl, | ||||
| 				icon: faLink, | ||||
| 				action: this.copyUrl | ||||
| 			}, { | ||||
| 				type: 'a', | ||||
| 				href: this.file.url, | ||||
| 				target: '_blank', | ||||
| 				text: this.$ts.download, | ||||
| 				icon: faDownload, | ||||
| 				download: this.file.name | ||||
| 			}, null, { | ||||
| 				text: this.$ts.delete, | ||||
| 				icon: faTrashAlt, | ||||
| 				danger: true, | ||||
| 				action: this.deleteFile | ||||
| 			}]; | ||||
| 		}, | ||||
|  | ||||
| 		onClick(ev) { | ||||
| 			if (this.selectMode) { | ||||
| 				this.$emit('chosen', this.file); | ||||
| 			} else { | ||||
| 				this.$root.menu({ | ||||
| 					items: [{ | ||||
| 						text: this.$t('rename'), | ||||
| 						icon: faICursor, | ||||
| 						action: this.rename | ||||
| 					}, { | ||||
| 						text: this.file.isSensitive ? this.$t('unmarkAsSensitive') : this.$t('markAsSensitive'), | ||||
| 						icon: this.file.isSensitive ? faEye : faEyeSlash, | ||||
| 						action: this.toggleSensitive | ||||
| 					}, null, { | ||||
| 						text: this.$t('copyUrl'), | ||||
| 						icon: faLink, | ||||
| 						action: this.copyUrl | ||||
| 					}, { | ||||
| 						type: 'a', | ||||
| 						href: this.file.url, | ||||
| 						target: '_blank', | ||||
| 						text: this.$t('download'), | ||||
| 						icon: faDownload, | ||||
| 						download: this.file.name | ||||
| 					}, null, { | ||||
| 						text: this.$t('delete'), | ||||
| 						icon: faTrashAlt, | ||||
| 						action: this.deleteFile | ||||
| 					}], | ||||
| 					source: ev.currentTarget || ev.target, | ||||
| 				}); | ||||
| 				os.modalMenu(this.getMenu(), ev.currentTarget || ev.target); | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
| 		onContextmenu(e) { | ||||
| 			os.contextMenu(this.getMenu(), e); | ||||
| 		}, | ||||
|  | ||||
| 		onDragstart(e) { | ||||
| 			e.dataTransfer.effectAllowed = 'move'; | ||||
| 			e.dataTransfer.setData('mk_drive_file', JSON.stringify(this.file)); | ||||
| 			e.dataTransfer.setData(_DATA_TRANSFER_DRIVE_FILE_, JSON.stringify(this.file)); | ||||
| 			this.isDragging = true; | ||||
|  | ||||
| 			// 親ブラウザに対して、ドラッグが開始されたフラグを立てる | ||||
| @@ -129,28 +135,17 @@ export default Vue.extend({ | ||||
| 			this.browser.isDragSource = false; | ||||
| 		}, | ||||
|  | ||||
| 		onThumbnailLoaded() { | ||||
| 			if (this.file.properties.avgColor) { | ||||
| 				anime({ | ||||
| 					targets: this.$refs.thumbnail, | ||||
| 					backgroundColor: 'transparent', // TODO fade | ||||
| 					duration: 100, | ||||
| 					easing: 'linear' | ||||
| 				}); | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
| 		rename() { | ||||
| 			this.$root.dialog({ | ||||
| 				title: this.$t('renameFile'), | ||||
| 			os.dialog({ | ||||
| 				title: this.$ts.renameFile, | ||||
| 				input: { | ||||
| 					placeholder: this.$t('inputNewFileName'), | ||||
| 					placeholder: this.$ts.inputNewFileName, | ||||
| 					default: this.file.name, | ||||
| 					allowEmpty: false | ||||
| 				} | ||||
| 			}).then(({ canceled, result: name }) => { | ||||
| 				if (canceled) return; | ||||
| 				this.$root.api('drive/files/update', { | ||||
| 				os.api('drive/files/update', { | ||||
| 					fileId: this.file.id, | ||||
| 					name: name | ||||
| 				}); | ||||
| @@ -158,7 +153,7 @@ export default Vue.extend({ | ||||
| 		}, | ||||
|  | ||||
| 		toggleSensitive() { | ||||
| 			this.$root.api('drive/files/update', { | ||||
| 			os.api('drive/files/update', { | ||||
| 				fileId: this.file.id, | ||||
| 				isSensitive: !this.file.isSensitive | ||||
| 			}); | ||||
| @@ -166,18 +161,15 @@ export default Vue.extend({ | ||||
|  | ||||
| 		copyUrl() { | ||||
| 			copyToClipboard(this.file.url); | ||||
| 			this.$root.dialog({ | ||||
| 				type: 'success', | ||||
| 				iconOnly: true, autoClose: true | ||||
| 			}); | ||||
| 			os.success(); | ||||
| 		}, | ||||
|  | ||||
| 		setAsAvatar() { | ||||
| 			updateAvatar(this.$root)(this.file); | ||||
| 			os.updateAvatar(this.file); | ||||
| 		}, | ||||
|  | ||||
| 		setAsBanner() { | ||||
| 			updateBanner(this.$root)(this.file); | ||||
| 			os.updateBanner(this.file); | ||||
| 		}, | ||||
|  | ||||
| 		addApp() { | ||||
| @@ -185,17 +177,19 @@ export default Vue.extend({ | ||||
| 		}, | ||||
|  | ||||
| 		async deleteFile() { | ||||
| 			const { canceled } = await this.$root.dialog({ | ||||
| 			const { canceled } = await os.dialog({ | ||||
| 				type: 'warning', | ||||
| 				text: this.$t('driveFileDeleteConfirm', { name: this.file.name }), | ||||
| 				showCancelButton: true | ||||
| 			}); | ||||
| 			if (canceled) return; | ||||
|  | ||||
| 			this.$root.api('drive/files/delete', { | ||||
| 			os.api('drive/files/delete', { | ||||
| 				fileId: this.file.id | ||||
| 			}); | ||||
| 		} | ||||
| 		}, | ||||
|  | ||||
| 		bytes | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
| @@ -211,6 +205,10 @@ export default Vue.extend({ | ||||
| 		cursor: pointer; | ||||
| 	} | ||||
|  | ||||
| 	> * { | ||||
| 		pointer-events: none; | ||||
| 	} | ||||
|  | ||||
| 	&:hover { | ||||
| 		background: rgba(#000, 0.05); | ||||
|  | ||||
| @@ -247,7 +245,7 @@ export default Vue.extend({ | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	&[data-is-selected] { | ||||
| 	&.isSelected { | ||||
| 		background: var(--accent); | ||||
|  | ||||
| 		&:hover { | ||||
| @@ -335,7 +333,6 @@ export default Vue.extend({ | ||||
| 		width: 128px; | ||||
| 		height: 128px; | ||||
| 		margin: auto; | ||||
| 		color: var(--driveFileIcon); | ||||
| 	} | ||||
|  | ||||
| 	> .name { | ||||
|   | ||||
| @@ -1,7 +1,8 @@ | ||||
| <template> | ||||
| <div class="rghtznwe" | ||||
| 	:data-draghover="draghover" | ||||
| 	:class="{ draghover }" | ||||
| 	@click="onClick" | ||||
| 	@contextmenu.stop="onContextmenu" | ||||
| 	@mouseover="onMouseover" | ||||
| 	@mouseout="onMouseout" | ||||
| 	@dragover.prevent.stop="onDragover" | ||||
| @@ -14,25 +15,24 @@ | ||||
| 	:title="title" | ||||
| > | ||||
| 	<p class="name"> | ||||
| 		<template v-if="hover"><fa :icon="faFolderOpen" fixed-width/></template> | ||||
| 		<template v-if="!hover"><fa :icon="faFolder" fixed-width/></template> | ||||
| 		<template v-if="hover"><Fa :icon="faFolderOpen" fixed-width/></template> | ||||
| 		<template v-if="!hover"><Fa :icon="faFolder" fixed-width/></template> | ||||
| 		{{ folder.name }} | ||||
| 	</p> | ||||
| 	<p class="upload" v-if="$store.state.settings.uploadFolder == folder.id"> | ||||
| 		{{ $t('uploadFolder') }} | ||||
| 	<p class="upload" v-if="$store.state.uploadFolder == folder.id"> | ||||
| 		{{ $ts.uploadFolder }} | ||||
| 	</p> | ||||
| 	<button v-if="selectMode" class="checkbox _button" :class="{ checked: isSelected }" @click.prevent.stop="checkboxClicked"></button> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { faFolder, faFolderOpen } from '@fortawesome/free-regular-svg-icons'; | ||||
| import i18n from '../i18n'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n, | ||||
| import { defineComponent } from 'vue'; | ||||
| import { faFolder, faFolderOpen, faTrashAlt, faWindowRestore } from '@fortawesome/free-regular-svg-icons'; | ||||
| import * as os from '@/os'; | ||||
| import { faICursor } from '@fortawesome/free-solid-svg-icons'; | ||||
|  | ||||
| export default defineComponent({ | ||||
| 	props: { | ||||
| 		folder: { | ||||
| 			type: Object, | ||||
| @@ -50,6 +50,8 @@ export default Vue.extend({ | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	emits: ['chosen'], | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			hover: false, | ||||
| @@ -94,8 +96,8 @@ export default Vue.extend({ | ||||
| 			} | ||||
|  | ||||
| 			const isFile = e.dataTransfer.items[0].kind == 'file'; | ||||
| 			const isDriveFile = e.dataTransfer.types[0] == 'mk_drive_file'; | ||||
| 			const isDriveFolder = e.dataTransfer.types[0] == 'mk_drive_folder'; | ||||
| 			const isDriveFile = e.dataTransfer.types[0] == _DATA_TRANSFER_DRIVE_FILE_; | ||||
| 			const isDriveFolder = e.dataTransfer.types[0] == _DATA_TRANSFER_DRIVE_FOLDER_; | ||||
|  | ||||
| 			if (isFile || isDriveFile || isDriveFolder) { | ||||
| 				e.dataTransfer.dropEffect = e.dataTransfer.effectAllowed == 'all' ? 'copy' : 'move'; | ||||
| @@ -124,11 +126,11 @@ export default Vue.extend({ | ||||
| 			} | ||||
|  | ||||
| 			//#region ドライブのファイル | ||||
| 			const driveFile = e.dataTransfer.getData('mk_drive_file'); | ||||
| 			const driveFile = e.dataTransfer.getData(_DATA_TRANSFER_DRIVE_FILE_); | ||||
| 			if (driveFile != null && driveFile != '') { | ||||
| 				const file = JSON.parse(driveFile); | ||||
| 				this.browser.removeFile(file.id); | ||||
| 				this.$root.api('drive/files/update', { | ||||
| 				os.api('drive/files/update', { | ||||
| 					fileId: file.id, | ||||
| 					folderId: this.folder.id | ||||
| 				}); | ||||
| @@ -136,7 +138,7 @@ export default Vue.extend({ | ||||
| 			//#endregion | ||||
|  | ||||
| 			//#region ドライブのフォルダ | ||||
| 			const driveFolder = e.dataTransfer.getData('mk_drive_folder'); | ||||
| 			const driveFolder = e.dataTransfer.getData(_DATA_TRANSFER_DRIVE_FOLDER_); | ||||
| 			if (driveFolder != null && driveFolder != '') { | ||||
| 				const folder = JSON.parse(driveFolder); | ||||
|  | ||||
| @@ -144,7 +146,7 @@ export default Vue.extend({ | ||||
| 				if (folder.id == this.folder.id) return; | ||||
|  | ||||
| 				this.browser.removeFolder(folder.id); | ||||
| 				this.$root.api('drive/folders/update', { | ||||
| 				os.api('drive/folders/update', { | ||||
| 					folderId: folder.id, | ||||
| 					parentId: this.folder.id | ||||
| 				}).then(() => { | ||||
| @@ -152,15 +154,15 @@ export default Vue.extend({ | ||||
| 				}).catch(err => { | ||||
| 					switch (err) { | ||||
| 						case 'detected-circular-definition': | ||||
| 							this.$root.dialog({ | ||||
| 								title: this.$t('unableToProcess'), | ||||
| 								text: this.$t('circularReferenceFolder') | ||||
| 							os.dialog({ | ||||
| 								title: this.$ts.unableToProcess, | ||||
| 								text: this.$ts.circularReferenceFolder | ||||
| 							}); | ||||
| 							break; | ||||
| 						default: | ||||
| 							this.$root.dialog({ | ||||
| 							os.dialog({ | ||||
| 								type: 'error', | ||||
| 								text: this.$t('error') | ||||
| 								text: this.$ts.somethingHappened | ||||
| 							}); | ||||
| 					} | ||||
| 				}); | ||||
| @@ -170,7 +172,7 @@ export default Vue.extend({ | ||||
|  | ||||
| 		onDragstart(e) { | ||||
| 			e.dataTransfer.effectAllowed = 'move'; | ||||
| 			e.dataTransfer.setData('mk_drive_folder', JSON.stringify(this.folder)); | ||||
| 			e.dataTransfer.setData(_DATA_TRANSFER_DRIVE_FOLDER_, JSON.stringify(this.folder)); | ||||
| 			this.isDragging = true; | ||||
|  | ||||
| 			// 親ブラウザに対して、ドラッグが開始されたフラグを立てる | ||||
| @@ -192,15 +194,15 @@ export default Vue.extend({ | ||||
| 		}, | ||||
|  | ||||
| 		rename() { | ||||
| 			this.$root.dialog({ | ||||
| 				title: this.$t('renameFolder'), | ||||
| 			os.dialog({ | ||||
| 				title: this.$ts.renameFolder, | ||||
| 				input: { | ||||
| 					placeholder: this.$t('inputNewFolderName'), | ||||
| 					placeholder: this.$ts.inputNewFolderName, | ||||
| 					default: this.folder.name | ||||
| 				} | ||||
| 			}).then(({ canceled, result: name }) => { | ||||
| 				if (canceled) return; | ||||
| 				this.$root.api('drive/folders/update', { | ||||
| 				os.api('drive/folders/update', { | ||||
| 					folderId: this.folder.id, | ||||
| 					name: name | ||||
| 				}); | ||||
| @@ -208,38 +210,54 @@ export default Vue.extend({ | ||||
| 		}, | ||||
|  | ||||
| 		deleteFolder() { | ||||
| 			this.$root.api('drive/folders/delete', { | ||||
| 			os.api('drive/folders/delete', { | ||||
| 				folderId: this.folder.id | ||||
| 			}).then(() => { | ||||
| 				if (this.$store.state.settings.uploadFolder === this.folder.id) { | ||||
| 					this.$store.dispatch('settings/set', { | ||||
| 						key: 'uploadFolder', | ||||
| 						value: null | ||||
| 					}); | ||||
| 				if (this.$store.state.uploadFolder === this.folder.id) { | ||||
| 					this.$store.set('uploadFolder', null); | ||||
| 				} | ||||
| 			}).catch(err => { | ||||
| 				switch(err.id) { | ||||
| 					case 'b0fc8a17-963c-405d-bfbc-859a487295e1': | ||||
| 						this.$root.dialog({ | ||||
| 						os.dialog({ | ||||
| 							type: 'error', | ||||
| 							title: this.$t('unableToDelete'), | ||||
| 							text: this.$t('hasChildFilesOrFolders') | ||||
| 							title: this.$ts.unableToDelete, | ||||
| 							text: this.$ts.hasChildFilesOrFolders | ||||
| 						}); | ||||
| 						break; | ||||
| 					default: | ||||
| 						this.$root.dialog({ | ||||
| 						os.dialog({ | ||||
| 							type: 'error', | ||||
| 							text: this.$t('unableToDelete') | ||||
| 							text: this.$ts.unableToDelete | ||||
| 						}); | ||||
| 				} | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		setAsUploadFolder() { | ||||
| 			this.$store.dispatch('settings/set', { | ||||
| 				key: 'uploadFolder', | ||||
| 				value: this.folder.id | ||||
| 			}); | ||||
| 			this.$store.set('uploadFolder', this.folder.id); | ||||
| 		}, | ||||
|  | ||||
| 		onContextmenu(e) { | ||||
| 			os.contextMenu([{ | ||||
| 				text: this.$ts.openInWindow, | ||||
| 				icon: faWindowRestore, | ||||
| 				action: () => { | ||||
| 					os.popup(import('./drive-window.vue'), { | ||||
| 						initialFolder: this.folder | ||||
| 					}, { | ||||
| 					}, 'closed'); | ||||
| 				} | ||||
| 			}, null, { | ||||
| 				text: this.$ts.rename, | ||||
| 				icon: faICursor, | ||||
| 				action: this.rename | ||||
| 			}, null, { | ||||
| 				text: this.$ts.delete, | ||||
| 				icon: faTrashAlt, | ||||
| 				danger: true, | ||||
| 				action: this.deleteFolder | ||||
| 			}], e); | ||||
| 		}, | ||||
| 	} | ||||
| }); | ||||
| @@ -275,7 +293,7 @@ export default Vue.extend({ | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	&[data-draghover] { | ||||
| 	&.draghover { | ||||
| 		&:after { | ||||
| 			content: ""; | ||||
| 			pointer-events: none; | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user