Compare commits
	
		
			899 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 3b974428fc | ||
|   | 580191fb17 | ||
|   | be0cb88b6c | ||
|   | 95c4e4497e | ||
|   | 2ec445f83e | ||
|   | 51b915428e | ||
|   | 1395cf89ce | ||
|   | 2a8f984db7 | ||
|   | decf2d396f | ||
|   | f7964da899 | ||
|   | c8607ff7b6 | ||
|   | e9f8897fe2 | ||
|   | e0b107a3a0 | ||
|   | 1d3e6a7197 | ||
|   | 1c93fcb1c4 | ||
|   | e3389e7899 | ||
|   | 454632d785 | ||
|   | c9bca7dc85 | ||
|   | 710ba526fa | ||
|   | aa47b6732d | ||
|   | 20f83420ca | ||
|   | d09a68ef11 | ||
|   | b545be5799 | ||
|   | 4fc377584f | ||
|   | a5f09c90dd | ||
|   | d059d7f972 | ||
|   | c03e2dfbc0 | ||
|   | 45c5e7b967 | ||
|   | c81a94ff75 | ||
|   | acc6f54557 | ||
|   | 8025b121af | ||
|   | 78ec06bda3 | ||
|   | 6ef83d9c59 | ||
|   | fca4ceef21 | ||
|   | 00f979f0e6 | ||
|   | 556677be7a | ||
|   | 624fd093f2 | ||
|   | 2ee438dece | ||
|   | 534de24406 | ||
|   | e88ce1746d | ||
|   | b8aad35009 | ||
|   | 47bd485a39 | ||
|   | ad869d7469 | ||
|   | d15cce5337 | ||
|   | 37daff6d61 | ||
|   | 5417e40f59 | ||
|   | 0fed33bfdb | ||
|   | 5dddc75d09 | ||
|   | 081578c604 | ||
|   | 6c47bf5b76 | ||
|   | 9e85291cd3 | ||
|   | 7f77517fc8 | ||
|   | b2f288dcac | ||
|   | 52b59e9d7b | ||
|   | 80c74b1fa7 | ||
|   | 91811ea500 | ||
|   | 57150fd910 | ||
|   | cddbbdf5d0 | ||
|   | 423dc2349b | ||
|   | 0556a2a2da | ||
|   | 65d943e42a | ||
|   | 3bcb344ecb | ||
|   | 82d721d60b | ||
|   | 48dc56e834 | ||
|   | 2c33bd6e31 | ||
|   | b6524616bc | ||
|   | 7e2b70f912 | ||
|   | 4f071a66b6 | ||
|   | 39f2303429 | ||
|   | cacf072027 | ||
|   | 6ab1fdfe1a | ||
|   | 6e5c93f926 | ||
|   | 1670737075 | ||
|   | fee235c4e4 | ||
|   | 7a39d489f2 | ||
|   | 7c634218d1 | ||
|   | 2704c5be73 | ||
|   | 489b51ba9f | ||
|   | 21807c29f1 | ||
|   | 3bc62fe3eb | ||
|   | ba0e3c4a5f | ||
|   | 9ec1fb5e37 | ||
|   | d708409462 | ||
|   | 07d05d4f86 | ||
|   | bbdb2ebb40 | ||
|   | f7908ba098 | ||
|   | f2fda3075e | ||
|   | 1338a68979 | ||
|   | e7da505fb3 | ||
|   | 5a9228372f | ||
|   | c4a6ba9097 | ||
|   | d5871b408b | ||
|   | 7b3338e373 | ||
|   | d18ee12d2f | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | ca9cc97940 | ||
|   | a70070ac7d | ||
|   | 069d99b320 | ||
|   | 37d350dcad | ||
|   | 8653e09b59 | ||
|   | 7cd2d59576 | ||
|   | a0839de38f | ||
|   | b7c5c71c6f | ||
|   | adab0adbdd | ||
|   | 2faa58928f | ||
|   | ffb80efe21 | ||
|   | 6f959218ef | ||
|   | be1125dcb9 | ||
|   | 9ab34c2301 | ||
|   | 0166d81d9e | ||
|   | 0b26efbd2f | ||
|   | 2cbaedf946 | ||
|   | b66924fbe8 | ||
|   | 8c91148954 | ||
|   | be0eff3dda | ||
|   | 85903ac9c6 | ||
|   | dbdd778dc7 | ||
|   | fc50dfd8d5 | ||
|   | f444e132ee | ||
|   | 68f562c323 | ||
|   | 820ea69613 | ||
|   | 6f4b3853a1 | ||
|   | a706ad0e80 | ||
|   | 820116affc | ||
|   | 52650342be | ||
|   | 85ddabdc65 | ||
|   | 0730cc4fa4 | ||
|   | 17b6ab0ef0 | ||
|   | 4e208b85bb | ||
|   | 00f8b29f6d | ||
|   | 9cf0fcadb1 | ||
|   | c595efeead | ||
|   | b56c6793a1 | ||
|   | ebceffba1e | ||
|   | 3ae42d9b85 | ||
|   | 796237b3c6 | ||
|   | cb7a97ee4c | ||
|   | 0cf758b6d1 | ||
|   | d28fca320e | ||
|   | 8bd17703c3 | ||
|   | a78eebc43f | ||
|   | 79fb5246df | ||
|   | 458b8c78dc | ||
|   | 64e0cbd6fc | ||
|   | 7fe937026b | ||
|   | 656cec65b9 | ||
|   | 8045bbff1c | ||
|   | c1a7a21746 | ||
|   | f3ee63fcbe | ||
|   | 7645c212a3 | ||
|   | 8b38e2ea58 | ||
|   | c9eb6a8919 | ||
|   | 9a41fd4734 | ||
|   | 70d96ee076 | ||
|   | 3b6fb3959b | ||
|   | 484d705320 | ||
|   | 786031be66 | ||
|   | bc0027ce43 | ||
|   | 3e7c6d9bdc | ||
|   | 5463e3e55e | ||
|   | 84a880086e | ||
|   | 89419b7136 | ||
|   | 9106ec74f7 | ||
|   | ebf9a0921d | ||
|   | c237f49016 | ||
|   | 709290d2da | ||
|   | eb3180f3b6 | ||
|   | 681997509c | ||
|   | 79ff5888fd | ||
|   | 9ee9cf8d81 | ||
|   | ee3c0f6f18 | ||
|   | 9dd463bff4 | ||
|   | df297d0031 | ||
|   | d18d1cb958 | ||
|   | 5bc0570888 | ||
|   | 8b43d75eaf | ||
|   | 89b37bd73d | ||
|   | 69f246ce7f | ||
|   | 6a97f0b7f6 | ||
|   | d885b872f3 | ||
|   | 125849673a | ||
|   | 30c53e9ee0 | ||
|   | 981fb9e8f3 | ||
|   | 9fac22d880 | ||
|   | b8f034064a | ||
|   | 6068227434 | ||
|   | 69cda49c88 | ||
|   | 039d821d20 | ||
|   | 44d93bc408 | ||
|   | cfa76ac6f9 | ||
|   | 0ec2d16522 | ||
|   | 6bcac1fe14 | ||
|   | bc9427d000 | ||
|   | 07c043361e | ||
|   | e676a9a501 | ||
|   | 09e654c6d2 | ||
|   | 549cb1ba87 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | c633827e5e | ||
|   | 08142ead67 | ||
|   | 638d81b66e | ||
|   | 4c83c2f64d | ||
|   | bf56f90fdc | ||
|   | d8412aad7a | ||
|   | c136741710 | ||
|   | 4fe8454da0 | ||
|   | 3f2161dadd | ||
|   | 3db516aa1a | ||
|   | 367bbbe605 | ||
|   | 5b70ff561c | ||
|   | 4486527e5d | ||
|   | 147e23d332 | ||
|   | ee20e6950e | ||
|   | 1d217154ef | ||
|   | 27d304a1ab | ||
|   | 1d1a373ca8 | ||
|   | bca3c6f8bf | ||
|   | d83d661535 | ||
|   | e16906afc3 | ||
|   | a6dc0f3684 | ||
|   | 6120474548 | ||
|   | 121dd86299 | ||
|   | 5251d9f668 | ||
|   | 7ae3f569de | ||
|   | 142ebead59 | ||
|   | e196086c64 | ||
|   | 8c6ed98505 | ||
|   | 98a2953c9c | ||
|   | 61d224695b | ||
|   | 6967def6c8 | ||
|   | 393c6aa79a | ||
|   | fc05540404 | ||
|   | 1c589c7c18 | ||
|   | 284df27435 | ||
|   | 68c0600a5c | ||
|   | b8163bd0e1 | ||
|   | 8c25b9dfad | ||
|   | bf34f67583 | ||
|   | 0c63f410d6 | ||
|   | 069077ace4 | ||
|   | 5be947ea4d | ||
|   | b41ffa75b7 | ||
|   | cd80e02ebf | ||
|   | dffcefb81f | ||
|   | 48df08d4dc | ||
|   | 4de9a08e55 | ||
|   | 3f46b5259b | ||
|   | 2faa8ea97c | ||
|   | 514690cf18 | ||
|   | f4f78c1898 | ||
|   | 2d24befb15 | ||
|   | 184d88838c | ||
|   | 4490503d59 | ||
|   | 99750435ae | ||
|   | fae920e578 | ||
|   | 0243b6d13b | ||
|   | 12bc725d68 | ||
|   | b1a7b781ec | ||
|   | 7e1cad3e12 | ||
|   | fd3f4c37a0 | ||
|   | 3acd2e0f0c | ||
|   | b1b5a795c8 | ||
|   | 197e2c8377 | ||
|   | fb8b0c291d | ||
|   | 706d47ec32 | ||
|   | 4eab2b3654 | ||
|   | 0a78f560e0 | ||
|   | f6f79fb388 | ||
|   | 34235d4d44 | ||
|   | 21842ec190 | ||
|   | 026e1cc7e7 | ||
|   | c65f4eebaf | ||
|   | 17baf8770a | ||
|   | 01f60edb17 | ||
|   | 15b11e59f4 | ||
|   | a2db4db963 | ||
|   | e87b9cc019 | ||
|   | 54cb94db1d | ||
|   | 1de8e1eeb1 | ||
|   | 1d8fb65959 | ||
|   | 28482627f7 | ||
|   | 4ee7df887d | ||
|   | b040571fa8 | ||
|   | fbd5e4bab8 | ||
|   | 498bdd1cd0 | ||
|   | 102cca8971 | ||
|   | e710ad4c5f | ||
|   | f64f6fd603 | ||
|   | 5995020c64 | ||
|   | 2dc86ec1ac | ||
|   | d50bcbdb23 | ||
|   | 19afd0ba61 | ||
|   | 7a787fa95c | ||
|   | 4e85eb90cb | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | d4474b953e | ||
|   | 0aaf3d7bd7 | ||
|   | 02bb2423af | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | e9b25f17af | ||
|   | 96671c5c7e | ||
|   | 4fc786f062 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 51c0cca4ff | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | bd344628f6 | ||
|   | 48deb35d4b | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | f9792f0d5c | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 0157033104 | ||
|   | 596f92cfcc | ||
|   | b2dedf7f98 | ||
|   | 34393ef89f | ||
|   | 7e11cd3b99 | ||
|   | dd1622296d | ||
|   | 77cb59a6ac | ||
|   | a2b60e38a3 | ||
|   | f0570bf111 | ||
|   | b980164318 | ||
|   | 3e7ff586a5 | ||
|   | 923bbcbf6b | ||
|   | 8cc85931d6 | ||
|   | b25522a091 | ||
|   | 97ae7e9ef4 | ||
|   | d25bd65722 | ||
|   | f4f98c25f7 | ||
|   | 336607568f | ||
|   | e2843a5ce4 | ||
|   | 702875a78e | ||
|   | 0fa8c6afd2 | ||
|   | 96571866a3 | ||
|   | f72b00bec7 | ||
|   | 1e7b5a0a98 | ||
|   | 9f09afc824 | ||
|   | 93b599dc8e | ||
|   | 1c722494de | ||
|   | a464c8d1d0 | ||
|   | 51362e9a52 | ||
|   | 3c086fe8c7 | ||
|   | f3b1248bd8 | ||
|   | 4e529ee7d0 | ||
|   | a2b975a493 | ||
|   | 13055d1496 | ||
|   | 78b5af4e4f | ||
|   | 008432e156 | ||
|   | d3d50b2f79 | ||
|   | eefeb4c268 | ||
|   | 86d4f1981c | ||
|   | 7a8e97972c | ||
|   | 3555213155 | ||
|   | 5d3d8dffd6 | ||
|   | dea8688c9d | ||
|   | a235869cfa | ||
|   | a8434b3bc5 | ||
|   | f110b2b320 | ||
|   | 0543cffe00 | ||
|   | 0383cbe43f | ||
|   | 9dd1203583 | ||
|   | 4eeeaffdee | ||
|   | 6f73f3d7a1 | ||
|   | aa9cd211dd | ||
|   | 3cdf4f01f8 | ||
|   | d0f84643d8 | ||
|   | 89707ad436 | ||
|   | 163d81c1b0 | ||
|   | 81a7213583 | ||
|   | 8f92a07d68 | ||
|   | 31b30e3dd2 | ||
|   | 0a1ac12d97 | ||
|   | e800104ac4 | ||
|   | 05cb94eb77 | ||
|   | 51499e04e0 | ||
|   | 0c993ef851 | ||
|   | b27fced30d | ||
|   | 2b7da9d98c | ||
|   | cd66f86f08 | ||
|   | a2e7cab573 | ||
|   | f81f7d51c5 | ||
|   | 7fb640e38f | ||
|   | c7561be15f | ||
|   | 741c81bca9 | ||
|   | 1e38528716 | ||
|   | 58b3be438a | ||
|   | 4522568749 | ||
|   | 719f9c8c02 | ||
|   | fe891da886 | ||
|   | 95b6684cfd | ||
|   | 66836836ab | ||
|   | 0db48c778f | ||
|   | 13a2f9373c | ||
|   | ae4d504392 | ||
|   | 85d240625d | ||
|   | db646b0ad9 | ||
|   | 2570d50957 | ||
|   | 7faecaadcf | ||
|   | dcbcb18081 | ||
|   | f1a61a268e | ||
|   | d7636355a1 | ||
|   | ed2993b3f2 | ||
|   | 1368c9d182 | ||
|   | c5e3c07c16 | ||
|   | f8395166af | ||
|   | dc8f4c8d6a | ||
|   | ed4860dfd9 | ||
|   | 5b0bf98b3c | ||
|   | adffac1000 | ||
|   | 3a1672b061 | ||
|   | e7658be6cd | ||
|   | 63533ad9c8 | ||
|   | 34b431fa1d | ||
|   | 958802dbe0 | ||
|   | 8681259597 | ||
|   | f3d76c06db | ||
|   | 3f32a9bfff | ||
|   | c497149765 | ||
|   | 9159613f2f | ||
|   | 70e95a5cdb | ||
|   | b0f82749aa | ||
|   | 20c0690352 | ||
|   | 006ecec443 | ||
|   | effcf0a609 | ||
|   | 3852d0b2c3 | ||
|   | ec67590dbe | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 65d0dbb7d8 | ||
|   | f8af57dffb | ||
|   | 2b058be3aa | ||
|   | 67efd30553 | ||
|   | 8d1fdc5aa4 | ||
|   | d033103163 | ||
|   | 53dff28a21 | ||
|   | 53c37036ee | ||
|   | 133c879a3a | ||
|   | a105faeaae | ||
|   | 13404310a7 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 2373b114bf | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 5bfc6b6547 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 8026a609bb | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 10db61a0d2 | ||
|   | 40520f3997 | ||
|   | c1d59716d1 | ||
|   | d8698743a1 | ||
|   | ade5055bc3 | ||
|   | 6e343d50f1 | ||
|   | ce3f735654 | ||
|   | 9b5e623130 | ||
|   | f0b0c5b540 | ||
|   | dd2207d430 | ||
|   | ffd6ac2434 | ||
|   | 27f93cc112 | ||
|   | 7ee88a69ec | ||
|   | 227798300f | ||
|   | 2ab8a5bc0a | ||
|   | c222b9ae94 | ||
|   | 53a0f3c794 | ||
|   | 9ff349c548 | ||
|   | 37a360efd9 | ||
|   | 3a850823a9 | ||
|   | 4da53b7382 | ||
|   | cb6f94735f | ||
|   | c073a20969 | ||
|   | 6dc8a385ee | ||
|   | f299c050b8 | ||
|   | eed540a51c | ||
|   | 5db72c4d71 | ||
|   | fc0bbfa759 | ||
|   | 6d63c81dd5 | ||
|   | bea42924cb | ||
|   | b48ef68c12 | ||
|   | 65109d140b | ||
|   | 0935bd4bd4 | ||
|   | 45bee7cc2f | ||
|   | 1c86a4bc26 | ||
|   | b385cf2a9f | ||
|   | 40d3dc454d | ||
|   | 8e92848495 | ||
|   | 2d94a22a30 | ||
|   | 7a5a091c25 | ||
|   | 2baf810c71 | ||
|   | d1ecef13ef | ||
|   | 495fa553ad | ||
|   | 854e649ea6 | ||
|   | c047324b42 | ||
|   | daac865c72 | ||
|   | 63d059b8d1 | ||
|   | e3075a0dc7 | ||
|   | 6b6e597b95 | ||
|   | eb0eadad5e | ||
|   | f600fee16d | ||
|   | 7b88c54aa6 | ||
|   | 623dd57cc3 | ||
|   | f6edd33adb | ||
|   | ac20d73222 | ||
|   | c59374d79d | ||
|   | 0d478046de | ||
|   | f3479d1b98 | ||
|   | 2fdecb8a38 | ||
|   | a95c3ee557 | ||
|   | 67c439c70a | ||
|   | b96037cffa | ||
|   | ebd8d34552 | ||
|   | a653d9a83e | ||
|   | 07d6894c42 | ||
|   | 03588b3fd6 | ||
|   | 2e83440e70 | ||
|   | 2633873fcc | ||
|   | 5f33713f53 | ||
|   | fe84c5010c | ||
|   | 7f39df0713 | ||
|   | 928d359dd2 | ||
|   | 184eb00133 | ||
|   | e264a49b08 | ||
|   | 8caf853c80 | ||
|   | b451c04787 | ||
|   | 1653977392 | ||
|   | a0d9def98a | ||
|   | 92701e5cec | ||
|   | 0b6b6a4f2f | ||
|   | 3a2dc95850 | ||
|   | 163cf49f16 | ||
|   | 37fc3103f6 | ||
|   | b7bd1ff69f | ||
|   | dc36134f10 | ||
|   | fea8821091 | ||
|   | 33faf40aca | ||
|   | 4410f8d7f7 | ||
|   | 3e6029e69d | ||
|   | 96c7707e6c | ||
|   | d8e545db3c | ||
|   | a9a6ba0aed | ||
|   | a898c6ceab | ||
|   | 0205c5c2d7 | ||
|   | f8074ab74b | ||
|   | f15c491d5f | ||
|   | c38a32dee9 | ||
|   | 4f5abed70d | ||
|   | c9ac9923df | ||
|   | bb14895fd8 | ||
|   | 6f92d601ec | ||
|   | 345143b0c1 | ||
|   | dc80d5d376 | ||
|   | d3544f9637 | ||
|   | 864b6ad1bd | ||
|   | c58027e521 | ||
|   | 10fb399588 | ||
|   | 10f466c895 | ||
|   | 32068b4bcc | ||
|   | 381f2b7fdf | ||
|   | 1c3c733c6b | ||
|   | 8bc5febe66 | ||
|   | 20335e23f9 | ||
|   | 9dbc9115c9 | ||
|   | fe707f88a4 | ||
|   | 9b23ebd4a3 | ||
|   | bea450cc2c | ||
|   | e80709f7aa | ||
| ![imgbot[bot]](/assets/img/avatar_default.png)  | cb71f92f42 | ||
|   | 2ca5348560 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | c8e98fdf8e | ||
|   | 0bfa041026 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 33bf474a1e | ||
|   | 53c559c001 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 1c99ef454b | ||
|   | cf4cecd4df | ||
|   | 6a8835b923 | ||
|   | f2b1cf92e1 | ||
|   | 6b79618e74 | ||
|   | 3db414add4 | ||
|   | 9ef641b403 | ||
|   | 6fa7819a44 | ||
|   | 59a1b9adbe | ||
|   | 3fbc7094f6 | ||
|   | 56c6227bc2 | ||
|   | ee82f99f5a | ||
|   | 72d9a46156 | ||
|   | 683a85ecc0 | ||
|   | 89047fd66d | ||
|   | 789de130a2 | ||
|   | 46c026ce70 | ||
|   | 82290f6e4e | ||
|   | 8729525f95 | ||
|   | df0115ffe8 | ||
|   | 0275b4fc9e | ||
|   | 9982fd71ba | ||
|   | 081060b7db | ||
|   | 0de64f1fc7 | ||
|   | f0508c0a90 | ||
|   | b51ae1dfaa | ||
|   | 6e7233d41b | ||
|   | 8ca27a4480 | ||
|   | 418041a56e | ||
|   | 17d20f5a18 | ||
|   | 77d2d84e05 | ||
|   | 3bde4285eb | ||
|   | 15efbfb244 | ||
|   | 55a57db958 | ||
|   | 91f624c900 | ||
|   | d753489e49 | ||
|   | 36dd7c82db | ||
|   | b00db74216 | ||
|   | cf9f85eb2a | ||
|   | bfa8414289 | ||
|   | 58dc9c9544 | ||
|   | ba95ce18a8 | ||
|   | ac10c40f31 | ||
|   | de8b40c80f | ||
|   | 60fe69728d | ||
|   | 557607e842 | ||
|   | 40ac9de728 | ||
|   | a725cd1946 | ||
|   | b648706756 | ||
|   | 20f2e9fc6d | ||
|   | 858ced0a53 | ||
|   | c9ca8f777f | ||
|   | 0d0be31527 | ||
|   | 96305a088c | ||
|   | 22e30b44b9 | ||
|   | 48d0e2fa5f | ||
|   | 0489291815 | ||
|   | 7a412500e1 | ||
|   | dffaa72a88 | ||
|   | 152d61f906 | ||
|   | b44ded5fc9 | ||
|   | 99d77cc843 | ||
|   | bc385eec2d | ||
|   | 2c6b9403b3 | ||
|   | 89cdc59fe5 | ||
|   | 3e04e1ccea | ||
|   | 25f491a65f | ||
|   | 7fdde157e0 | ||
|   | 27f30a449a | ||
|   | dc66a0cd66 | ||
|   | f302ecd1e2 | ||
|   | 1afc2a227a | ||
|   | ab594d1dfe | ||
|   | 647d32f506 | ||
|   | 1bc109b42c | ||
|   | 6e02e2a6b3 | ||
|   | 3372baad6c | ||
|   | e9b3e3877a | ||
|   | c84c5fbae7 | ||
|   | 2e7ab91f48 | ||
|   | 92c41c003a | ||
|   | 53688cdcdc | ||
|   | 70f864ea8b | ||
|   | 5dd94e551a | ||
|   | afc1ed9897 | ||
|   | df7562f98d | ||
|   | 1c7e799164 | ||
|   | 107a3f99f4 | ||
|   | 7e3cf4b4ad | ||
|   | afdb23ff57 | ||
|   | 0ce64f8c33 | ||
|   | 2cd6ccb85c | ||
|   | 3dcf5374c2 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 1c7d5f3f64 | ||
|   | bb0cb0a866 | ||
|   | 362dc29057 | ||
|   | 8af0218e4c | ||
|   | 09af9968b5 | ||
|   | 7d0b819c5a | ||
|   | 4bbb7eded3 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 72ea9e5522 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 743e5d947d | ||
|   | f257853906 | ||
|   | 32983d3829 | ||
|   | bdef33e88d | ||
|   | a4a4194586 | ||
|   | e36c538dc0 | ||
|   | 982a218bf2 | ||
|   | f7aeca4c7c | ||
|   | 4b81bc864f | ||
|   | a52cc62c04 | ||
|   | 81f69bff9e | ||
|   | d9b2aa1880 | ||
|   | 3bddd986a0 | ||
|   | d00712d817 | ||
|   | d756fdbebf | ||
|   | b2f2c74605 | ||
|   | 1407cd71b5 | ||
|   | 3dd3a7238d | ||
|   | afc834ae4b | ||
|   | 357f190ce3 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | ab92762320 | ||
|   | 04942c8477 | ||
|   | 9c60f51e0d | ||
|   | 956ae2ac46 | ||
|   | f2ed813337 | ||
|   | 7d9a7d1a3c | ||
|   | 2f67b6fb47 | ||
|   | 7444dde93e | ||
|   | e62fad7bc6 | ||
|   | 2c6bad2501 | ||
|   | 6952bb2eca | ||
|   | 610972dbde | ||
|   | 926049055a | ||
|   | db5f6b60df | ||
|   | 7be7b9d9fd | ||
|   | 366855c4cc | ||
|   | e950beeeab | ||
|   | 5515b39f6c | ||
|   | f5d0599e4d | ||
|   | 8fd7914f0f | ||
|   | 24ef98eb01 | ||
|   | b3dd6cf001 | ||
|   | 6d4b474cb1 | ||
|   | 0a8876a3ae | ||
|   | 9a83a48331 | ||
|   | 7ed50b90bd | ||
|   | b6fd5d7282 | ||
|   | 33243e7176 | ||
|   | e8439679a5 | ||
|   | 06124dbbd5 | ||
|   | 857940f402 | ||
|   | bcb04924ff | ||
|   | 2b6aeb9ebc | ||
|   | 648e4538fb | ||
|   | cd4b3777da | ||
|   | 4acf506b7e | ||
|   | 543ca348bc | ||
|   | 03375412f1 | ||
|   | 0c7a9b6827 | ||
|   | c54bc3c176 | ||
|   | 90973bedf4 | ||
|   | 757f70162e | ||
|   | 3047410b35 | ||
|   | 9d0d4c5eae | ||
|   | cab5b4d601 | ||
|   | 517b6e25d9 | ||
|   | 94d394c29e | ||
|   | a52099d175 | ||
|   | f1cb7b862d | ||
|   | 0863e5d379 | ||
|   | 55dcd25df1 | ||
|   | f3155ea180 | ||
|   | 2c5162671c | ||
|   | fc8aeb5a66 | ||
|   | 995cf503eb | ||
|   | 0e49c11a4c | ||
|   | 0367c37b0a | ||
|   | e0b9fe5e5d | ||
|   | a4726e683b | ||
|   | 3b10e93efe | ||
|   | 02b07c1b5b | ||
|   | 5e54751bd4 | ||
|   | 34f1dc238d | ||
|   | 3c0f4bdf35 | ||
|   | a68d370ad0 | ||
|   | debb27ed30 | ||
|   | 97fbb857fb | ||
|   | 93f13ffc8e | ||
|   | 4d9dc93d46 | ||
|   | 22cd4c5d16 | ||
|   | 6883994b22 | ||
|   | 852a312753 | ||
|   | afea0baaa8 | ||
|   | 2c477660a0 | ||
|   | 16a1cd3c9d | ||
|   | db23dd2e01 | ||
|   | eaa1ded5ba | ||
|   | 393e14196a | ||
|   | 8b005307ea | ||
|   | c915ac0e72 | ||
|   | 1752bb896e | ||
|   | 9c8fa026f3 | ||
|   | e93db6324a | ||
|   | a10708bffa | ||
|   | e65a7a142f | ||
|   | 72e0b2d470 | ||
|   | 43fb0f36a7 | ||
|   | cf3533221b | ||
|   | de522ebe14 | ||
|   | 2ace891dde | ||
|   | e212d9f991 | ||
|   | 739f3f84d0 | ||
|   | 5e206c86be | ||
|   | 1ab37011ea | ||
|   | b6e02f63cd | ||
|   | 60e10d4efa | ||
|   | 95ba7e43b1 | ||
|   | 9e5a2e5b17 | ||
|   | dbbc416095 | ||
|   | a479ad357c | ||
|   | b1c12abb7c | ||
|   | 17d1a1d7bd | ||
|   | ba50156a83 | ||
|   | eb83ab41c0 | ||
|   | 4e6a917dab | ||
|   | 8c4f0d4589 | ||
|   | 3f7738204e | ||
|   | e251a9b9fe | ||
|   | 01d43b9683 | ||
|   | 4d4a0c89a8 | ||
|   | 0a5524e9c8 | ||
|   | c8fb5746b3 | ||
|   | bbcc132978 | ||
|   | d3e4f84285 | ||
|   | 62c470cf75 | ||
|   | 8ab31d3765 | ||
|   | 55fe1cf0a8 | ||
|   | 00cff51ff7 | ||
|   | d6bc4a7aa1 | ||
|   | 4e57d12aea | ||
|   | 4a2d99c43f | ||
|   | 217c27df86 | ||
|   | e6dcd438b4 | ||
|   | de2b0224d6 | ||
|   | 3f8a72eb88 | ||
|   | 0387176e8c | ||
|   | aa34e332f4 | ||
|   | d13999d689 | ||
|   | 22c4e92728 | ||
|   | df8128c0b1 | ||
|   | ec534a3704 | ||
|   | 366d4cd3e2 | ||
|   | 4841926df1 | ||
|   | f2f7bdc5a9 | ||
|   | fd811eb325 | ||
|   | 915d352505 | ||
|   | 1d1024c57a | ||
|   | 73df6e0347 | ||
|   | e6d62c5a7b | ||
|   | 470e48c0a5 | ||
|   | 9235f72a2e | ||
|   | 9fe6da79b2 | ||
|   | 1858437eb1 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | c3ba0dcd32 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 70f4b13089 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | cc57a4b671 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 6902700458 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | b772041547 | ||
|   | 79174c1a19 | ||
|   | 898850027a | ||
|   | 0d272b1fb0 | ||
|   | 7993a9eb90 | ||
|   | 42d419970d | ||
|   | ad49268d8b | ||
|   | 76c345396a | ||
|   | 5690ef1ebc | ||
|   | 5616404b4d | ||
|   | f92137f6c2 | ||
|   | ca3373ba4e | ||
|   | 4e6115b414 | ||
|   | ddf47051c9 | ||
|   | d45478510c | ||
|   | 2641f89349 | ||
|   | 9d46d03c37 | ||
|   | 25b6de88a9 | ||
|   | a24046e46a | ||
|   | 7e803ff9a9 | ||
|   | 246cead2b1 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 214f7f06bb | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 6878f73a9f | ||
|   | 336b45b6f7 | ||
|   | 2a0b62d26d | ||
|   | 653ec0cbb0 | ||
|   | 120ab3f0a3 | ||
|   | 8bcbbbc1a3 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 13a75abc91 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | eace740c63 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | cb3a54de00 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 5fbc77795d | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | ce4feae731 | ||
|   | 08f00d4990 | ||
|   | 6951f7e74a | ||
|   | 2b4d63b1bb | ||
|   | 8cbb961493 | ||
|   | 64c795938d | ||
|   | 67df681a48 | ||
|   | 9285bcf8bb | ||
|   | b9b23a4b54 | ||
|   | 2f6371b085 | ||
|   | 2a5c3475a7 | ||
|   | 8a2698a5db | ||
|   | f6919a171a | ||
|   | 82ebf67456 | ||
|   | a60c8b2ee8 | ||
|   | 0a2b8ccfb6 | ||
|   | 698094b787 | ||
|   | b57e111ea8 | ||
|   | aa6bf2b54e | ||
|   | 454910d295 | ||
|   | d44e620769 | ||
|   | ac14adfd3e | ||
|   | 928d30ee1e | ||
|   | 3dd9b0f347 | ||
|   | c57dd083c5 | ||
|   | 2a1d6c5406 | ||
|   | 112e9f69bd | ||
|   | d50e537888 | ||
|   | 86d14d30fa | ||
|   | 710d3689d3 | ||
|   | 3fee011369 | ||
|   | 7cd4b8ba4f | ||
|   | 31132de18b | ||
|   | c6cb271f6f | ||
|   | b7c4afd20c | ||
|   | 70395d200a | ||
|   | 562a5f66fc | ||
|   | b2f8003602 | ||
|   | b7b36973f7 | ||
|   | f7d5f597f3 | ||
|   | 79c7712241 | ||
|   | 8f5f3985f4 | ||
|   | af00464f5b | ||
|   | f522b3df91 | ||
|   | e9ec4a3b84 | 
							
								
								
									
										3
									
								
								.autogen/check_pr.jq
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,3 @@ | ||||
| .[] | ||||
| .head | ||||
| .label | ||||
							
								
								
									
										2
									
								
								.autogen/next_url.jq
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,2 @@ | ||||
| .links | ||||
| .next | ||||
							
								
								
									
										39
									
								
								.autogen/patreon.jq
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,39 @@ | ||||
| ( | ||||
|   .data | | ||||
|   map( | ||||
|     select( | ||||
|       .relationships | ||||
|       .currently_entitled_tiers | ||||
|       .data[] | ||||
|     ) | ||||
|   ) | | ||||
|   map( | ||||
|     .relationships | ||||
|     .user | ||||
|     .data | ||||
|     .id | ||||
|   ) | ||||
| ) as $data | | ||||
| .included | | ||||
| map( | ||||
|   select( | ||||
|     .id as $id | | ||||
|     $data | | ||||
|     contains( | ||||
|       [ | ||||
|         $id | ||||
|       ] | ||||
|     ) | ||||
|   ) | ||||
| ) | | ||||
| map( | ||||
|   .attributes | | ||||
|   [ | ||||
|     .full_name, | ||||
|     .thumb_url, | ||||
|     .url | ||||
|   ] | | ||||
|   @tsv | ||||
| ) | | ||||
| .[] | | ||||
| @text | ||||
| @@ -5,7 +5,7 @@ | ||||
| # __MISSKEY_HEAD=acid-chicken:patch-autogen | ||||
| # __MISSKEY_REPO=syuilo/misskey | ||||
| # __MISSKEY_BRANCH=develop | ||||
| test "$(curl -LSs -w '\n' -- "https://api.github.com/repos/$REPO/pulls?access_token=$__MISSKEY_GITHUB_TOKEN" | jq -r '.[].head.label' | grep $__MISSKEY_HEAD)" && exit 1 | ||||
| test "$(curl -LSs -w '\n' -- "https://api.github.com/repos/$REPO/pulls?access_token=$__MISSKEY_GITHUB_TOKEN" | jq -r -f check_pr.jq | grep $__MISSKEY_HEAD)" && exit 1 | ||||
| cd "$(dirname $0)/.." && \ | ||||
| touch null.cache && \ | ||||
| rm *.cache && \ | ||||
| @@ -30,7 +30,7 @@ while : | ||||
|   touch patreon.cache && \ | ||||
|   rm patreon.cache && \ | ||||
|   cat patreon.raw.cache | \ | ||||
|   jq -r '(.data|map(select(.relationships.currently_entitled_tiers.data[]))|map(.relationships.user.data.id))as$data|.included|map(select(.id as$id|$data|contains([$id])))|map(.attributes|[.full_name,.thumb_url,.url]|@tsv)|.[]|@text' >> patreon.cache && \ | ||||
|   jq -r -f patreon.jq >> patreon.cache && \ | ||||
|   echo '<table><tr>' >> patreon.md.cache && \ | ||||
|   cat patreon.cache | \ | ||||
|   awk -F'\t' '{print $2,$1}' | \ | ||||
| @@ -43,7 +43,7 @@ while : | ||||
|   xargs -I% echo '<td><a href="%</a></td>' >> patreon.md.cache && \ | ||||
|   echo '</tr></table>' >> patreon.md.cache || \ | ||||
|   exit 1 | ||||
|   new_url="$(cat patreon.raw.cache | jq -r '.links.next')" | ||||
|   new_url="$(cat patreon.raw.cache | jq -r -f next_url.jq)" | ||||
|   test "$new_url" = 'null' && \ | ||||
|   break || \ | ||||
|   URL="$url" | ||||
| @@ -108,22 +108,5 @@ autoAdmin: true | ||||
| #  port: 9200 | ||||
| #  pass: null | ||||
|  | ||||
| # ServiceWorker | ||||
| #sw: | ||||
| #  # Public key of VAPID | ||||
| #  public_key: example-sw-public-key | ||||
| # | ||||
| #  # Private key of VAPID | ||||
| #  private_key: example-sw-private-key | ||||
|  | ||||
| # Clustering | ||||
| #clusterLimit: 1 | ||||
|  | ||||
| # Summaly proxy | ||||
| #summalyProxy: "http://example.com" | ||||
|  | ||||
| # User recommendation | ||||
| #user_recommendation: | ||||
| #  external: true | ||||
| #  engine: http://vinayaka.distsn.org/cgi-bin/vinayaka-user-match-misskey-api.cgi?{{host}}+{{user}}+{{limit}}+{{offset}} | ||||
| #  timeout: 300000 | ||||
|   | ||||
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -17,3 +17,4 @@ api-docs.json | ||||
| /mongo | ||||
| /elasticsearch | ||||
| *.code-workspace | ||||
| yarn.lock | ||||
|   | ||||
							
								
								
									
										70
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						| @@ -1,9 +1,75 @@ | ||||
| ChangeLog | ||||
| ========= | ||||
|  | ||||
| 破壊的変更のみ記載。 | ||||
| 10.66.1 | ||||
| ------- | ||||
| * ActivityPubのsharedInboxに関して修正 | ||||
| * MFMでのカッコの判定を改善 | ||||
| * バグ修正 | ||||
|  | ||||
| This document describes breaking changes only. | ||||
| 10.66.0 | ||||
| ------- | ||||
| * ユーザーごとのRSSフィードを提供するように | ||||
| * リストのユーザーがすべて表示できない問題を修正 | ||||
| * デザインの調整 | ||||
| * パフォーマンスの改善 | ||||
|  | ||||
| 10.65.0 | ||||
| ------- | ||||
| * 検索で投稿やユーザーのURLを入力した際にそれをフェッチして表示するように | ||||
| * リストのリネームと削除をできるように | ||||
| * リストからユーザーを削除できるように | ||||
| * リモートの絵文字を更新するように | ||||
| * ActivityPubのための絵文字エンドポイントを実装 | ||||
| * 管理者がドライブのファイルのNSFWを設定できるように | ||||
| * ServiceWorkerの設定を管理者ページで行えるように | ||||
| * メンションの判定を改善 | ||||
| * リモートの投稿を引用した際にオリジナルのURLを挿入するように | ||||
| * クライアントのパフォーマンス改善 | ||||
| * CWの内容がタブタイトルに表示されるのを修正 | ||||
| * アカウントを作成したときにログイン状態にならない問題を修正 | ||||
| * 時計の針にテーマカラーが適用されていなかったのを修正 | ||||
| * 一部の日時の表示が日本語で表示されていたのを修正 | ||||
| * プロフィールの写真欄に画像以外のファイルが含まれる問題を修正 | ||||
| * メンションが含まれる投稿に返信する際、フォームに予めそれらのメンションがセットされた状態にならない問題を修正 | ||||
| * デッキのTLにUIの動きを減らすオプションが適用されていなかったのを修正 | ||||
| * ログイン画面のタイムラインに隠した投稿が表示される問題を修正 | ||||
| * サジェストが複数開いてしまう問題を修正 | ||||
| * APから来たタグに登録時の長さ制限が適用されていなかったのを修正 | ||||
|  | ||||
| 10.64.2 | ||||
| ------- | ||||
| * UIの動きを減らすオプションが一部のアニメーションに適用されなかったのを修正 | ||||
|  | ||||
| 10.64.1 | ||||
| ------- | ||||
| * レートリミットの調整 | ||||
| * アニメーションの調整 | ||||
|  | ||||
| 10.64.0 | ||||
| ------- | ||||
| * いくつかのアニメーションを追加 | ||||
| * OGP向けにインスタンスのバナー画像を提供するように | ||||
| * 管理者ページでドライブのファイルを表示できるように | ||||
| * ユーザビリティの強化 | ||||
| * バグ修正 | ||||
|  | ||||
| 10.63.1 | ||||
| ------- | ||||
| * メンションの表示を改善 | ||||
| * バグ修正 | ||||
|  | ||||
| 10.63.0 | ||||
| ------- | ||||
| * ActivityPubのユーザーフィールドをユーザーページに表示 | ||||
| * 404ページの実装 | ||||
| * パフォーマンスの向上 | ||||
| * バグ修正 | ||||
|  | ||||
| 10.62.2 | ||||
| ------- | ||||
| * バグ修正 | ||||
| * ユーザビリティの向上 | ||||
|  | ||||
| 10.0.0 | ||||
| ------ | ||||
|   | ||||
| @@ -25,3 +25,16 @@ Misskey uses [vue-i18n](https://github.com/kazupon/vue-i18n). | ||||
| ## Continuous integration | ||||
| Misskey uses CircleCI for automated test. | ||||
| Configuration files are located in `/.circleci`. | ||||
|  | ||||
| ## Glossary | ||||
| ### AP | ||||
| Stands for _**A**ctivity**P**ub_. | ||||
|  | ||||
| ### MFM | ||||
| Stands for _**M**isskey **F**lavored **M**arkdown_. | ||||
|  | ||||
| ### Mk | ||||
| Stands for _**M**iss**k**ey_. | ||||
|  | ||||
| ### SW | ||||
| Stands for _**S**ervice**W**orker_. | ||||
|   | ||||
							
								
								
									
										12
									
								
								Dockerfile
									
									
									
									
									
								
							
							
						
						| @@ -8,18 +8,20 @@ WORKDIR /misskey | ||||
|  | ||||
| FROM base AS builder | ||||
|  | ||||
| RUN unlink /usr/bin/free | ||||
| RUN apk add --no-cache \ | ||||
|     gcc \ | ||||
|     g++ \ | ||||
|     libc-dev \ | ||||
|     python \ | ||||
|     autoconf \ | ||||
|     automake \ | ||||
|     file \ | ||||
|     g++ \ | ||||
|     gcc \ | ||||
|     libc-dev \ | ||||
|     libtool \ | ||||
|     make \ | ||||
|     nasm \ | ||||
|     pkgconfig \ | ||||
|     libtool \ | ||||
|     procps \ | ||||
|     python \ | ||||
|     zlib-dev | ||||
| RUN npm i -g node-gyp | ||||
|  | ||||
|   | ||||
							
								
								
									
										13
									
								
								PULL_REQUEST_TEMPLATE.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,13 @@ | ||||
| # Summary | ||||
|  | ||||
| <!-- | ||||
|   - | ||||
|   - * Please describe your changes here * | ||||
|   - | ||||
|   - If you are going to resolve some issue, please add this context. | ||||
|   - Resolve #ISSUE_NUMBER | ||||
|   - | ||||
|   - If you are going to fix some bug issue, please add this context. | ||||
|   - Fix #ISSUE_NUMBER | ||||
|   - | ||||
|   --> | ||||
							
								
								
									
										34
									
								
								README.md
									
									
									
									
									
								
							
							
						
						| @@ -3,9 +3,9 @@ | ||||
| [](https://misskey.xyz/) | ||||
| ================================================================ | ||||
|  | ||||
| [](https://circleci.com/gh/syuilo/misskey) | ||||
| [![][dependencies-badge]][dependencies-link] | ||||
| [](http://makeapullrequest.com) | ||||
| [](https://circleci.com/gh/syuilo/misskey) | ||||
| [](https://david-dm.org/syuilo/misskey) | ||||
| [](http://makeapullrequest.com) | ||||
|  | ||||
| **Sophisticated microblogging platform, evolving forever.** | ||||
|  | ||||
| @@ -73,46 +73,52 @@ Please see [Contribution guide](./CONTRIBUTING.md). | ||||
| ---------------------------------------------------------------- | ||||
| <!-- PATREON_START --> | ||||
| <table><tr> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12190916/fb7fa7983c14425f890369535b1506a4/1?token-time=2145916800&token-hash=Zeh1u6l_Vmgoy8A1eT1Sltea-_SZSq8t8uOWDRZRh94%3D" alt="weep"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/13376668/71f3cf87ec6c4393a44b1b9df5ee3d12/1?token-time=2145916800&token-hash=7pSmWqgMfMSJHVIEcNsuuQoKeU3TRluew5p0EGTzWA4%3D" alt="Arctic"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12731202/0995c46cdcb54153ab5f073f5869b70a/1?token-time=2145916800&token-hash=Yd60FK_SWfQO56SeiJpy1tDHOnCV4xdEywQe8gn5_Wo%3D" alt="negao"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12913507/f7181eacafe8469a93033d85f5969c29/2?token-time=2145916800&token-hash=mgPdX9TqZxEg4TTPuc477dxhIgYk9246qafjWZEqZ7g%3D" alt="Melilot"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12999811/5f349fafcce44dd1824a8b1ebbec4564/3?token-time=2145916800&token-hash=ybYtxfpte1b-rGg6Zecpys2ZdZDtwR_UNJHQjt-3eoU%3D" alt="Xeltica"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/3384329/8b713330cb27404ea6e9fac50ff96efe/1?token-time=2145916800&token-hash=0eu4-m1gTWA9PhptVZt6rdKcusqcD7RB87rJT23VVFI%3D" alt="べすれい"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12021162/963128bb8d14476dbd8407943db8f31a/1?token-time=2145916800&token-hash=GgJ_NmUB6_nnRNLVGUWjV-WX91On7BOu59LKncYV9fE%3D" alt="gutfuckllc"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/11357794/923ce94cd8c44ba788ee931907881839/1?token-time=2145916800&token-hash=I8lJVM8LeW6TSo5W6uIIRZ42cw83zp1wK_FsbzY0mcQ%3D" alt="mydarkstar"></td> | ||||
| <td><img src="https://c8.patreon.com/2/100/12718187" alt="Peter G."></td> | ||||
| </tr><tr> | ||||
| <td><a href="https://www.patreon.com/weepjp">weep</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=13376668">Arctic</a></td> | ||||
| <td><a href="https://www.patreon.com/negao">negao</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=12913507">Melilot</a></td> | ||||
| <td><a href="https://www.patreon.com/Xeltica">Xeltica</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=3384329">べすれい</a></td> | ||||
| <td><a href="https://www.patreon.com/gutfuckllc">gutfuckllc</a></td> | ||||
| <td><a href="https://www.patreon.com/mydarkstar">mydarkstar</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=12718187">Peter G.</a></td> | ||||
| </tr></table> | ||||
| <table><tr> | ||||
| <td><img src="https://c8.patreon.com/2/100/12718187" alt="Peter G."></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/13039004/509d0c412eb14ae08d6a812a3054f7d6/1?token-time=2145916800&token-hash=zwSu01tOtn5xTUucDZHuPsCxF2HBEMVs9ROJKTlEV_o%3D" alt="nemu"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/5881381/6235ca5d3fb04c8e95ef5b4ff2abcc18/3?token-time=2145916800&token-hash=qsdn0-e6yLaLI6hUX9JAkyTR6a5UdnSp7T1foniBvGQ%3D" alt="YUKIMOCHI"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/8241184/39e18850e87a449e9c9a71acb3310ebd/2?token-time=2145916800&token-hash=iUXOQzRyJDv3PJxwS7Mjwg1459dzh2trOq6NFtXu_OM%3D" alt="Acid Chicken"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/13034746/c711c7f58e204ecfbc2fd646bc8a4eee/1?token-time=2145916800&token-hash=UERBN4OyP7Nh5XwwdDg0N0IE5cD6_qUQMO81Z5Wizso%3D" alt="Hiratake"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/10789744/97175095d8f04c0f86225ff47cb98d40/1?token-time=2145916800&token-hash=P4BIzCX2I1CkEP66ottfhsC8Wr6BUSamjA-vq3pLqFI%3D" alt="Naoki Hirayama"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/4503830/ccf2cc867ea64de0b524bb2e24b9a1cb/1?token-time=2145916800&token-hash=S1zP0QyLU52Dqq6dtc9qNYyWfW86XrYHiR4NMbeOrnA%3D" alt="dansup"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/619786/32cf01444db24e578cd1982c197f6fc6/1?token-time=2145916800&token-hash=tB1e_r8RlZ5sFL0KV_e8dugapxatNBRK1Z3h67TO1g8%3D" alt="Gargron"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/5731881/4b6038e6cda34c04b83a5fcce3806a93/1?token-time=2145916800&token-hash=VZUtwrjQa8Jml4twCjHYQQZ64wHEY4oIlGl7Kc-VYUQ%3D" alt="Nokotaro Takeda"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12531784/93a45137841849329ba692da92ac7c60/1?token-time=2145916800&token-hash=tMosUojzUYJCH_3t--tvYA-SMCyrS__hzSndyaRSnbo%3D" alt="Takashi Shibuya"></td> | ||||
| </tr><tr> | ||||
| <td><a href="https://www.patreon.com/user?u=12718187">Peter G.</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=13039004">nemu</a></td> | ||||
| <td><a href="https://www.patreon.com/yukimochi">YUKIMOCHI</a></td> | ||||
| <td><a href="https://www.patreon.com/acid_chicken">Acid Chicken</a></td> | ||||
| <td><a href="https://www.patreon.com/hiratake">Hiratake</a></td> | ||||
| <td><a href="https://www.patreon.com/spinlock">Naoki Hirayama</a></td> | ||||
| <td><a href="https://www.patreon.com/dansup">dansup</a></td> | ||||
| </tr></table> | ||||
| <table><tr> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/619786/32cf01444db24e578cd1982c197f6fc6/1?token-time=2145916800&token-hash=tB1e_r8RlZ5sFL0KV_e8dugapxatNBRK1Z3h67TO1g8%3D" alt="Gargron"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/5731881/4b6038e6cda34c04b83a5fcce3806a93/1?token-time=2145916800&token-hash=VZUtwrjQa8Jml4twCjHYQQZ64wHEY4oIlGl7Kc-VYUQ%3D" alt="Nokotaro Takeda"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJoIjoxMDAsInciOjEwMH0%3D/patreon-media/p/user/12531784/93a45137841849329ba692da92ac7c60/1?token-time=2145916800&token-hash=tMosUojzUYJCH_3t--tvYA-SMCyrS__hzSndyaRSnbo%3D" alt="Takashi Shibuya"></td> | ||||
| </tr><tr> | ||||
| <td><a href="https://www.patreon.com/mastodon">Gargron</a></td> | ||||
| <td><a href="https://www.patreon.com/takenoko">Nokotaro Takeda</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=12531784">Takashi Shibuya</a></td> | ||||
| </tr></table> | ||||
| <table><tr> | ||||
| </tr><tr> | ||||
| </tr></table> | ||||
|  | ||||
| **Last updated:** Wed, 31 Oct 2018 23:21:06 UTC | ||||
| **Last updated:** Sun, 16 Dec 2018 18:32:06 UTC | ||||
| <!-- PATREON_END --> | ||||
|  | ||||
| :four_leaf_clover: Copyright | ||||
| @@ -124,9 +130,7 @@ Misskey is an open-source software licensed under the [GNU AGPLv3](LICENSE). | ||||
| [![][agpl-3.0-badge]][AGPL-3.0] | ||||
|  | ||||
| [agpl-3.0]:           https://www.gnu.org/licenses/agpl-3.0.en.html | ||||
| [agpl-3.0-badge]:     https://img.shields.io/badge/license-AGPL--3.0-444444.svg?style=flat-square | ||||
| [dependencies-link]:  https://david-dm.org/syuilo/misskey | ||||
| [dependencies-badge]: https://img.shields.io/david/syuilo/misskey.svg?style=flat-square | ||||
| [agpl-3.0-badge]:     https://img.shields.io/badge/license-AGPL--3.0-444444.svg?style=for-the-badge | ||||
|  | ||||
| [backer-url]: #backers | ||||
| [backer-badge]: https://opencollective.com/misskey/backers/badge.svg | ||||
|   | ||||
| Before Width: | Height: | Size: 110 KiB After Width: | Height: | Size: 94 KiB | 
| Before Width: | Height: | Size: 344 KiB After Width: | Height: | Size: 317 KiB | 
| Before Width: | Height: | Size: 125 KiB After Width: | Height: | Size: 95 KiB | 
| Before Width: | Height: | Size: 256 KiB After Width: | Height: | Size: 200 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/ai.png
									
									
									
									
									
								
							
							
						
						| Before Width: | Height: | Size: 243 KiB After Width: | Height: | Size: 235 KiB | 
| Before Width: | Height: | Size: 2.5 KiB After Width: | Height: | Size: 2.5 KiB | 
| Before Width: | Height: | Size: 264 KiB After Width: | Height: | Size: 6.8 KiB | 
| Before Width: | Height: | Size: 3.9 KiB After Width: | Height: | Size: 3.9 KiB | 
| @@ -1,108 +1,17 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||
| <!-- Created with Inkscape (http://www.inkscape.org/) --> | ||||
| 
 | ||||
| <svg | ||||
|    xmlns:dc="http://purl.org/dc/elements/1.1/" | ||||
|    xmlns:cc="http://creativecommons.org/ns#" | ||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" | ||||
|    xmlns:svg="http://www.w3.org/2000/svg" | ||||
|    xmlns="http://www.w3.org/2000/svg" | ||||
|    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" | ||||
|    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" | ||||
|    width="512" | ||||
|    height="512" | ||||
|    viewBox="0 0 135.46667 135.46667" | ||||
|    version="1.1" | ||||
|    id="svg8" | ||||
|    inkscape:version="0.92.1 r15371" | ||||
|    sodipodi:docname="favicon.svg" | ||||
|    inkscape:export-filename="C:\Users\syuilo\projects\misskey\assets\favicon\16.png" | ||||
|    inkscape:export-xdpi="3" | ||||
|    inkscape:export-ydpi="3"> | ||||
|    version="1.1" | ||||
|    viewBox="0 0 135.46667 135.46667" | ||||
|    height="512" | ||||
|    width="512"> | ||||
|   <defs | ||||
|      id="defs2"> | ||||
|     <inkscape:path-effect | ||||
|        effect="simplify" | ||||
|        id="path-effect5115" | ||||
|        is_visible="true" | ||||
|        steps="1" | ||||
|        threshold="0.000408163" | ||||
|        smooth_angles="360" | ||||
|        helper_size="0" | ||||
|        simplify_individual_paths="false" | ||||
|        simplify_just_coalesce="false" | ||||
|        simplifyindividualpaths="false" | ||||
|        simplifyJustCoalesce="false" /> | ||||
|     <inkscape:path-effect | ||||
|        effect="simplify" | ||||
|        id="path-effect5111" | ||||
|        is_visible="true" | ||||
|        steps="1" | ||||
|        threshold="0.000408163" | ||||
|        smooth_angles="360" | ||||
|        helper_size="0" | ||||
|        simplify_individual_paths="false" | ||||
|        simplify_just_coalesce="false" | ||||
|        simplifyindividualpaths="false" | ||||
|        simplifyJustCoalesce="false" /> | ||||
|     <inkscape:path-effect | ||||
|        effect="simplify" | ||||
|        id="path-effect5104" | ||||
|        is_visible="true" | ||||
|        steps="1" | ||||
|        threshold="0.000408163" | ||||
|        smooth_angles="360" | ||||
|        helper_size="0" | ||||
|        simplify_individual_paths="false" | ||||
|        simplify_just_coalesce="false" | ||||
|        simplifyindividualpaths="false" | ||||
|        simplifyJustCoalesce="false" /> | ||||
|   </defs> | ||||
|   <sodipodi:namedview | ||||
|      id="base" | ||||
|      pagecolor="#ffffff" | ||||
|      bordercolor="#666666" | ||||
|      borderopacity="1.0" | ||||
|      inkscape:pageopacity="0.0" | ||||
|      inkscape:pageshadow="2" | ||||
|      inkscape:zoom="1.4142136" | ||||
|      inkscape:cx="15.466544" | ||||
|      inkscape:cy="235.92965" | ||||
|      inkscape:document-units="px" | ||||
|      inkscape:current-layer="g4502" | ||||
|      showgrid="true" | ||||
|      units="px" | ||||
|      inkscape:snap-bbox="true" | ||||
|      inkscape:bbox-nodes="true" | ||||
|      inkscape:snap-bbox-edge-midpoints="false" | ||||
|      inkscape:snap-smooth-nodes="true" | ||||
|      inkscape:snap-center="true" | ||||
|      inkscape:snap-page="true" | ||||
|      inkscape:window-width="1920" | ||||
|      inkscape:window-height="1027" | ||||
|      inkscape:window-x="-8" | ||||
|      inkscape:window-y="1072" | ||||
|      inkscape:window-maximized="1" | ||||
|      inkscape:snap-object-midpoints="true" | ||||
|      inkscape:snap-midpoints="true" | ||||
|      inkscape:object-paths="true" | ||||
|      fit-margin-top="0" | ||||
|      fit-margin-left="0" | ||||
|      fit-margin-right="0" | ||||
|      fit-margin-bottom="0" | ||||
|      objecttolerance="1" | ||||
|      guidetolerance="1" | ||||
|      inkscape:snap-nodes="false" | ||||
|      inkscape:snap-others="false"> | ||||
|     <inkscape:grid | ||||
|        type="xygrid" | ||||
|        id="grid4504" | ||||
|        spacingx="4.2333334" | ||||
|        spacingy="4.2333334" | ||||
|        empcolor="#ff3fff" | ||||
|        empopacity="0.25098039" | ||||
|        empspacing="4" /> | ||||
|   </sodipodi:namedview> | ||||
|      id="defs2" /> | ||||
|   <metadata | ||||
|      id="metadata5"> | ||||
|     <rdf:RDF> | ||||
| @@ -116,32 +25,27 @@ | ||||
|     </rdf:RDF> | ||||
|   </metadata> | ||||
|   <g | ||||
|      inkscape:label="レイヤー 1" | ||||
|      inkscape:groupmode="layer" | ||||
|      id="layer1" | ||||
|      transform="translate(-30.809093,-111.78601)"> | ||||
|      style="fill:#2fa3bc;fill-opacity:1" | ||||
|      transform="translate(-30.809093,-111.78601)" | ||||
|      id="layer1"> | ||||
|     <g | ||||
|        id="g4502" | ||||
|        transform="matrix(1.096096,0,0,1.096096,-2.960633,-44.023579)"> | ||||
|        style="fill:#2fa3bc;fill-opacity:1" | ||||
|        transform="matrix(1.096096,0,0,1.096096,-2.960633,-44.023579)" | ||||
|        id="g4502"> | ||||
|       <g | ||||
|          style="fill:#2fa1bb;fill-opacity:1" | ||||
|          id="g5125"> | ||||
|          id="g5125" | ||||
|          transform="translate(-1.3333333e-6,-1.3439941e-6)" | ||||
|          style="fill:#2fa3bc;fill-opacity:1"> | ||||
|         <g | ||||
|            transform="matrix(0.91391326,0,0,0.91391326,7.9719907,17.595761)" | ||||
|            aria-label="Mi" | ||||
|            style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:141.03404236px;line-height:476.69509888px;font-family:'OTADESIGN Rounded';-inkscape-font-specification:'OTADESIGN Rounded';letter-spacing:0px;word-spacing:0px;fill:#2fa3bc;fill-opacity:1;stroke:none;stroke-width:0.28950602px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" | ||||
|            id="text4489" | ||||
|            style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:141.03404236px;line-height:476.69509888px;font-family:'OTADESIGN Rounded';-inkscape-font-specification:'OTADESIGN Rounded';letter-spacing:0px;word-spacing:0px;fill:#2fa1bb;fill-opacity:1;stroke:none;stroke-width:0.28950602px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" | ||||
|            aria-label="Mi"> | ||||
|            transform="matrix(0.91391326,0,0,0.91391326,7.9719907,17.595761)"> | ||||
|           <path | ||||
|              sodipodi:nodetypes="zccssscssccscczzzccsccsscscsccz" | ||||
|              inkscape:connector-curvature="0" | ||||
|              id="path5210" | ||||
|              style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-family:'OTADESIGN Rounded';-inkscape-font-specification:'OTADESIGN Rounded';fill:#2fa1bb;fill-opacity:1;stroke-width:0.28950602px" | ||||
|              d="m 75.196381,231.17126 c -5.855419,0.0202 -10.885068,-3.50766 -13.2572,-7.61584 -1.266603,-1.79454 -3.772419,-2.43291 -3.807919,0 v 11.2332 c 0,4.51309 -1.645397,8.41504 -4.936191,11.70583 -3.196772,3.19677 -7.098714,4.79516 -11.705826,4.79516 -4.513089,0 -8.415031,-1.59839 -11.705825,-4.79516 -3.196772,-3.29079 -4.795158,-7.19274 -4.795158,-11.70583 v -61.7729 c 0,-3.47884 0.987238,-6.6286 2.961715,-9.44928 2.068499,-2.91471 4.701135,-4.9362 7.897906,-6.06447 1.786431,-0.65816 3.666885,-0.98724 5.641362,-0.98724 5.077225,0 9.308247,1.97448 12.693064,5.92343 1.786431,1.97448 2.820681,3.00873 3.102749,3.10275 0,0 13.408119,16.21319 13.78421,16.49526 0.376091,0.28206 1.480789,2.43848 4.127113,2.43848 2.646324,0 3.89218,-2.15642 4.26827,-2.43848 0.376091,-0.28207 13.784088,-16.49526 13.784088,-16.49526 0.09402,0.094 1.081261,-0.94022 2.961715,-3.10275 3.478837,-3.94895 7.756866,-5.92343 12.834096,-5.92343 1.88045,0 3.76091,0.32908 5.64136,0.98724 3.19677,1.12827 5.7824,3.14976 7.75688,6.06447 2.06849,2.82068 3.10274,5.97044 3.10274,9.44928 v 61.7729 c 0,4.51309 -1.6454,8.41504 -4.93619,11.70583 -3.19677,3.19677 -7.09871,4.79516 -11.70582,4.79516 -4.51309,0 -8.41504,-1.59839 -11.705828,-4.79516 -3.196772,-3.29079 -4.795158,-7.19274 -4.795158,-11.70583 v -11.2332 c -0.277898,-3.06563 -2.987588,-1.13379 -3.948953,0 -2.538613,4.70114 -7.401781,7.59567 -13.2572,7.61584 z" /> | ||||
|           <path | ||||
|              inkscape:connector-curvature="0" | ||||
|              id="path5212" | ||||
|              style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-family:'OTADESIGN Rounded';-inkscape-font-specification:'OTADESIGN Rounded';fill:#2fa1bb;fill-opacity:1;stroke-width:0.28950602px" | ||||
|              d="m 145.83461,185.00361 q -5.92343,0 -10.15445,-4.08999 -4.08999,-4.23102 -4.08999,-10.15445 0,-5.92343 4.08999,-10.01342 4.23102,-4.23102 10.15445,-4.23102 5.92343,0 10.15445,4.23102 4.23102,4.08999 4.23102,10.01342 0,5.92343 -4.23102,10.15445 -4.23102,4.08999 -10.15445,4.08999 z m 0.14103,2.82068 q 5.92343,0 10.01342,4.23102 4.23102,4.23102 4.23102,10.15445 v 34.83541 q 0,5.92343 -4.23102,10.15445 -4.08999,4.08999 -10.01342,4.08999 -5.92343,0 -10.15445,-4.08999 -4.23102,-4.23102 -4.23102,-10.15445 v -34.83541 q 0,-5.92343 4.23102,-10.15445 4.23102,-4.23102 10.15445,-4.23102 z" /> | ||||
|              transform="matrix(0.26412464,0,0,0.26412464,24.988264,136.28626)" | ||||
|              d="m 62.474609,76.585938 c -7.47555,0 -14.595784,1.246427 -21.359375,3.738281 C 29.011968,84.595952 19.044417,92.249798 11.212891,103.28516 3.7373405,113.96451 0,125.88934 0,139.06055 v 233.8789 c 0,17.08697 6.0510264,31.85913 18.154297,44.31836 12.459246,12.10327 27.233346,18.15625 44.320312,18.15625 17.442947,0 32.215089,-6.05298 44.318361,-18.15625 12.45925,-12.45923 18.68945,-27.23139 18.68945,-44.31836 V 330.4082 c 0.13441,-9.21122 9.6225,-6.79429 14.41797,0 8.98111,15.55395 28.02226,28.91242 50.19141,28.83594 22.16915,-0.0764 40.58194,-11.03699 50.19336,-28.83594 3.63981,-4.29263 13.89902,-11.60675 14.95117,0 v 42.53125 c 0,17.08697 6.05102,31.85913 18.15429,44.31836 12.45923,12.10327 27.23335,18.15625 44.32032,18.15625 17.44294,0 32.21509,-6.05298 44.31836,-18.15625 12.45923,-12.45923 18.68945,-27.23139 18.68945,-44.31836 v -233.8789 c 0,-13.17121 -3.9146,-25.09604 -11.74609,-35.77539 -7.47557,-11.035362 -17.26588,-18.689208 -29.36914,-22.960941 -7.11956,-2.491854 -14.23982,-3.738281 -21.35938,-3.738281 -19.22286,0 -35.41865,7.476649 -48.58984,22.427734 l -63.40235,74.199218 c -1.42391,1.06791 -6.14093,9.23242 -16.16015,9.23242 -10.01923,0 -14.20109,-8.16451 -15.625,-9.23242 L 110.53125,99.013672 C 97.716024,84.062587 81.697447,76.585938 62.474609,76.585938 Z m 395.060551,0 c -14.9511,-10e-7 -27.76596,5.340179 -38.44532,16.019531 -10.32338,10.323381 -15.48437,22.961011 -15.48437,37.912111 0,14.9511 5.16099,27.76596 15.48437,38.44531 10.67936,10.32338 23.49422,15.48633 38.44532,15.48633 14.95109,0 27.76596,-5.16295 38.44531,-15.48633 C 506.65982,158.28354 512,145.46868 512,130.51758 512,115.56648 506.65982,102.92885 495.98047,92.605469 485.30112,81.926117 472.48625,76.585938 457.53516,76.585938 Z m 0.5332,118.541012 c -14.9511,0 -27.76596,5.34018 -38.44531,16.01953 -10.67936,10.67936 -16.01758,23.49422 -16.01758,38.44532 v 131.89062 c 0,14.9511 5.33822,27.76596 16.01758,38.44531 10.67935,10.32339 23.49421,15.48633 38.44531,15.48633 14.9511,0 27.58873,-5.16294 37.91211,-15.48633 C 506.65982,409.24838 512,396.43352 512,381.48242 V 249.5918 c 0,-14.9511 -5.34018,-27.76596 -16.01953,-38.44532 -10.32338,-10.67935 -22.96101,-16.01953 -37.91211,-16.01953 z" | ||||
|              style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-family:'OTADESIGN Rounded';-inkscape-font-specification:'OTADESIGN Rounded';fill:#2fa3bc;fill-opacity:1;stroke-width:1.09609616px" /> | ||||
|         </g> | ||||
|       </g> | ||||
|     </g> | ||||
|   | ||||
| Before Width: | Height: | Size: 6.9 KiB After Width: | Height: | Size: 4.1 KiB | 
| Before Width: | Height: | Size: 2.5 KiB After Width: | Height: | Size: 1.5 KiB | 
| Before Width: | Height: | Size: 446 B After Width: | Height: | Size: 430 B | 
| Before Width: | Height: | Size: 3.8 KiB After Width: | Height: | Size: 2.0 KiB | 
| Before Width: | Height: | Size: 2.5 KiB After Width: | Height: | Size: 2.5 KiB | 
| Before Width: | Height: | Size: 774 B After Width: | Height: | Size: 671 B | 
| Before Width: | Height: | Size: 1.2 KiB After Width: | Height: | Size: 1015 B | 
							
								
								
									
										129
									
								
								assets/mi.svg
									
									
									
									
									
								
							
							
						
						| @@ -1,108 +1,17 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||
| <!-- Created with Inkscape (http://www.inkscape.org/) --> | ||||
| 
 | ||||
| <svg | ||||
|    xmlns:dc="http://purl.org/dc/elements/1.1/" | ||||
|    xmlns:cc="http://creativecommons.org/ns#" | ||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" | ||||
|    xmlns:svg="http://www.w3.org/2000/svg" | ||||
|    xmlns="http://www.w3.org/2000/svg" | ||||
|    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" | ||||
|    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" | ||||
|    width="512" | ||||
|    height="512" | ||||
|    viewBox="0 0 135.46667 135.46667" | ||||
|    version="1.1" | ||||
|    id="svg8" | ||||
|    inkscape:version="0.92.1 r15371" | ||||
|    sodipodi:docname="mi.svg" | ||||
|    inkscape:export-filename="C:\Users\syuilo\projects\misskey\assets\favicon\32.png" | ||||
|    inkscape:export-xdpi="6" | ||||
|    inkscape:export-ydpi="6"> | ||||
|    version="1.1" | ||||
|    viewBox="0 0 135.46667 135.46667" | ||||
|    height="512" | ||||
|    width="512"> | ||||
|   <defs | ||||
|      id="defs2"> | ||||
|     <inkscape:path-effect | ||||
|        effect="simplify" | ||||
|        id="path-effect5115" | ||||
|        is_visible="true" | ||||
|        steps="1" | ||||
|        threshold="0.000408163" | ||||
|        smooth_angles="360" | ||||
|        helper_size="0" | ||||
|        simplify_individual_paths="false" | ||||
|        simplify_just_coalesce="false" | ||||
|        simplifyindividualpaths="false" | ||||
|        simplifyJustCoalesce="false" /> | ||||
|     <inkscape:path-effect | ||||
|        effect="simplify" | ||||
|        id="path-effect5111" | ||||
|        is_visible="true" | ||||
|        steps="1" | ||||
|        threshold="0.000408163" | ||||
|        smooth_angles="360" | ||||
|        helper_size="0" | ||||
|        simplify_individual_paths="false" | ||||
|        simplify_just_coalesce="false" | ||||
|        simplifyindividualpaths="false" | ||||
|        simplifyJustCoalesce="false" /> | ||||
|     <inkscape:path-effect | ||||
|        effect="simplify" | ||||
|        id="path-effect5104" | ||||
|        is_visible="true" | ||||
|        steps="1" | ||||
|        threshold="0.000408163" | ||||
|        smooth_angles="360" | ||||
|        helper_size="0" | ||||
|        simplify_individual_paths="false" | ||||
|        simplify_just_coalesce="false" | ||||
|        simplifyindividualpaths="false" | ||||
|        simplifyJustCoalesce="false" /> | ||||
|   </defs> | ||||
|   <sodipodi:namedview | ||||
|      id="base" | ||||
|      pagecolor="#ffffff" | ||||
|      bordercolor="#666666" | ||||
|      borderopacity="1.0" | ||||
|      inkscape:pageopacity="0.0" | ||||
|      inkscape:pageshadow="2" | ||||
|      inkscape:zoom="1.4142136" | ||||
|      inkscape:cx="232.39583" | ||||
|      inkscape:cy="251.50613" | ||||
|      inkscape:document-units="px" | ||||
|      inkscape:current-layer="g4502" | ||||
|      showgrid="true" | ||||
|      units="px" | ||||
|      inkscape:snap-bbox="true" | ||||
|      inkscape:bbox-nodes="true" | ||||
|      inkscape:snap-bbox-edge-midpoints="false" | ||||
|      inkscape:snap-smooth-nodes="true" | ||||
|      inkscape:snap-center="true" | ||||
|      inkscape:snap-page="true" | ||||
|      inkscape:window-width="1920" | ||||
|      inkscape:window-height="1027" | ||||
|      inkscape:window-x="-8" | ||||
|      inkscape:window-y="1072" | ||||
|      inkscape:window-maximized="1" | ||||
|      inkscape:snap-object-midpoints="true" | ||||
|      inkscape:snap-midpoints="true" | ||||
|      inkscape:object-paths="true" | ||||
|      fit-margin-top="0" | ||||
|      fit-margin-left="0" | ||||
|      fit-margin-right="0" | ||||
|      fit-margin-bottom="0" | ||||
|      objecttolerance="1" | ||||
|      guidetolerance="1" | ||||
|      inkscape:snap-nodes="false" | ||||
|      inkscape:snap-others="false"> | ||||
|     <inkscape:grid | ||||
|        type="xygrid" | ||||
|        id="grid4504" | ||||
|        spacingx="4.2333334" | ||||
|        spacingy="4.2333334" | ||||
|        empcolor="#ff3fff" | ||||
|        empopacity="0.25098039" | ||||
|        empspacing="4" /> | ||||
|   </sodipodi:namedview> | ||||
|      id="defs2" /> | ||||
|   <metadata | ||||
|      id="metadata5"> | ||||
|     <rdf:RDF> | ||||
| @@ -111,32 +20,30 @@ | ||||
|         <dc:format>image/svg+xml</dc:format> | ||||
|         <dc:type | ||||
|            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> | ||||
|         <dc:title /> | ||||
|         <dc:title></dc:title> | ||||
|       </cc:Work> | ||||
|     </rdf:RDF> | ||||
|   </metadata> | ||||
|   <g | ||||
|      inkscape:label="レイヤー 1" | ||||
|      inkscape:groupmode="layer" | ||||
|      id="layer1" | ||||
|      transform="translate(-30.809093,-111.78601)"> | ||||
|      transform="translate(-30.809093,-111.78601)" | ||||
|      id="layer1"> | ||||
|     <g | ||||
|        id="g4502" | ||||
|        transform="matrix(1.096096,0,0,1.096096,-2.960633,-44.023579)"> | ||||
|        transform="matrix(1.096096,0,0,1.096096,-2.960633,-44.023579)" | ||||
|        id="g4502"> | ||||
|       <g | ||||
|          style="fill:#000000;fill-opacity:1" | ||||
|          id="g5125" | ||||
|          transform="translate(-1.3333333e-6,-1.3439941e-6)" | ||||
|          id="g5125"> | ||||
|          style="fill:#000000;fill-opacity:1"> | ||||
|         <g | ||||
|            transform="matrix(0.91391326,0,0,0.91391326,7.9719907,17.595761)" | ||||
|            id="text4489" | ||||
|            aria-label="Mi" | ||||
|            style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:141.03404236px;line-height:476.69509888px;font-family:'OTADESIGN Rounded';-inkscape-font-specification:'OTADESIGN Rounded';letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.28950602px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" | ||||
|            aria-label="Mi"> | ||||
|            id="text4489" | ||||
|            transform="matrix(0.91391326,0,0,0.91391326,7.9719907,17.595761)"> | ||||
|           <path | ||||
|              style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-family:'OTADESIGN Rounded';-inkscape-font-specification:'OTADESIGN Rounded';fill:#000000;fill-opacity:1;stroke-width:1.09609616px" | ||||
|              d="M 62.474609 76.585938 C 54.999059 76.585938 47.878825 77.832365 41.115234 80.324219 C 29.011968 84.595952 19.044417 92.249798 11.212891 103.28516 C 3.7373405 113.96451 0 125.88934 0 139.06055 L 0 372.93945 C 0 390.02642 6.0510264 404.79858 18.154297 417.25781 C 30.613543 429.36108 45.387643 435.41406 62.474609 435.41406 C 79.917556 435.41406 94.689698 429.36108 106.79297 417.25781 C 119.25222 404.79858 125.48242 390.02642 125.48242 372.93945 L 125.48242 330.4082 C 125.61683 321.19698 135.10492 323.61391 139.90039 330.4082 C 148.8815 345.96215 167.92265 359.32062 190.0918 359.24414 C 212.26095 359.16778 230.67374 348.20715 240.28516 330.4082 C 243.92497 326.11557 254.18418 318.80145 255.23633 330.4082 L 255.23633 372.93945 C 255.23633 390.02642 261.28735 404.79858 273.39062 417.25781 C 285.84985 429.36108 300.62397 435.41406 317.71094 435.41406 C 335.15388 435.41406 349.92603 429.36108 362.0293 417.25781 C 374.48853 404.79858 380.71875 390.02642 380.71875 372.93945 L 380.71875 139.06055 C 380.71875 125.88934 376.80415 113.96451 368.97266 103.28516 C 361.49709 92.249798 351.70678 84.595952 339.60352 80.324219 C 332.48396 77.832365 325.3637 76.585938 318.24414 76.585938 C 299.02128 76.585938 282.82549 84.062587 269.6543 99.013672 C 262.53473 107.20121 258.79542 111.11761 258.43945 110.76172 C 258.43945 110.76172 207.67587 172.14495 206.25195 173.21289 C 204.82804 174.2808 200.11102 182.44531 190.0918 182.44531 C 180.07257 182.44531 175.89071 174.2808 174.4668 173.21289 C 173.04288 172.14495 122.2793 110.76172 122.2793 110.76172 C 121.21136 110.40575 117.29484 106.48923 110.53125 99.013672 C 97.716024 84.062587 81.697447 76.585938 62.474609 76.585938 z M 457.53516 76.585938 C 442.58406 76.585937 429.7692 81.926117 419.08984 92.605469 C 408.76646 102.92885 403.60547 115.56648 403.60547 130.51758 C 403.60547 145.46868 408.76646 158.28354 419.08984 168.96289 C 429.7692 179.28627 442.58406 184.44922 457.53516 184.44922 C 472.48625 184.44922 485.30112 179.28627 495.98047 168.96289 C 506.65982 158.28354 512 145.46868 512 130.51758 C 512 115.56648 506.65982 102.92885 495.98047 92.605469 C 485.30112 81.926117 472.48625 76.585938 457.53516 76.585938 z M 458.06836 195.12695 C 443.11726 195.12695 430.3024 200.46713 419.62305 211.14648 C 408.94369 221.82584 403.60547 234.6407 403.60547 249.5918 L 403.60547 381.48242 C 403.60547 396.43352 408.94369 409.24838 419.62305 419.92773 C 430.3024 430.25112 443.11726 435.41406 458.06836 435.41406 C 473.01946 435.41406 485.65709 430.25112 495.98047 419.92773 C 506.65982 409.24838 512 396.43352 512 381.48242 L 512 249.5918 C 512 234.6407 506.65982 221.82584 495.98047 211.14648 C 485.65709 200.46713 473.01946 195.12695 458.06836 195.12695 z " | ||||
|              id="path5210" | ||||
|              transform="matrix(0.26412464,0,0,0.26412464,24.988264,136.28626)" | ||||
|              id="path5210" /> | ||||
|              d="m 62.474609,76.585938 c -7.47555,0 -14.595784,1.246427 -21.359375,3.738281 C 29.011968,84.595952 19.044417,92.249798 11.212891,103.28516 3.7373405,113.96451 0,125.88934 0,139.06055 v 233.8789 c 0,17.08697 6.0510264,31.85913 18.154297,44.31836 12.459246,12.10327 27.233346,18.15625 44.320312,18.15625 17.442947,0 32.215089,-6.05298 44.318361,-18.15625 12.45925,-12.45923 18.68945,-27.23139 18.68945,-44.31836 V 330.4082 c 0.13441,-9.21122 9.6225,-6.79429 14.41797,0 8.98111,15.55395 28.02226,28.91242 50.19141,28.83594 22.16915,-0.0764 40.58194,-11.03699 50.19336,-28.83594 3.63981,-4.29263 13.89902,-11.60675 14.95117,0 v 42.53125 c 0,17.08697 6.05102,31.85913 18.15429,44.31836 12.45923,12.10327 27.23335,18.15625 44.32032,18.15625 17.44294,0 32.21509,-6.05298 44.31836,-18.15625 12.45923,-12.45923 18.68945,-27.23139 18.68945,-44.31836 v -233.8789 c 0,-13.17121 -3.9146,-25.09604 -11.74609,-35.77539 -7.47557,-11.035362 -17.26588,-18.689208 -29.36914,-22.960941 -7.11956,-2.491854 -14.23982,-3.738281 -21.35938,-3.738281 -19.22286,0 -35.41865,7.476649 -48.58984,22.427734 l -63.40235,74.199218 c -1.42391,1.06791 -6.14093,9.23242 -16.16015,9.23242 -10.01923,0 -14.20109,-8.16451 -15.625,-9.23242 L 110.53125,99.013672 C 97.716024,84.062587 81.697447,76.585938 62.474609,76.585938 Z m 395.060551,0 c -14.9511,-10e-7 -27.76596,5.340179 -38.44532,16.019531 -10.32338,10.323381 -15.48437,22.961011 -15.48437,37.912111 0,14.9511 5.16099,27.76596 15.48437,38.44531 10.67936,10.32338 23.49422,15.48633 38.44532,15.48633 14.95109,0 27.76596,-5.16295 38.44531,-15.48633 C 506.65982,158.28354 512,145.46868 512,130.51758 512,115.56648 506.65982,102.92885 495.98047,92.605469 485.30112,81.926117 472.48625,76.585938 457.53516,76.585938 Z m 0.5332,118.541012 c -14.9511,0 -27.76596,5.34018 -38.44531,16.01953 -10.67936,10.67936 -16.01758,23.49422 -16.01758,38.44532 v 131.89062 c 0,14.9511 5.33822,27.76596 16.01758,38.44531 10.67935,10.32339 23.49421,15.48633 38.44531,15.48633 14.9511,0 27.58873,-5.16294 37.91211,-15.48633 C 506.65982,409.24838 512,396.43352 512,381.48242 V 249.5918 c 0,-14.9511 -5.34018,-27.76596 -16.01953,-38.44532 -10.32338,-10.67935 -22.96101,-16.01953 -37.91211,-16.01953 z" | ||||
|              style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-family:'OTADESIGN Rounded';-inkscape-font-specification:'OTADESIGN Rounded';fill:#000000;fill-opacity:1;stroke-width:1.09609616px" /> | ||||
|         </g> | ||||
|       </g> | ||||
|     </g> | ||||
|   | ||||
| Before Width: | Height: | Size: 7.3 KiB After Width: | Height: | Size: 4.1 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/title.png
									
									
									
									
									
								
							
							
						
						| Before Width: | Height: | Size: 3.8 KiB After Width: | Height: | Size: 3.8 KiB | 
| @@ -1,29 +0,0 @@ | ||||
| const mongo = require('mongodb'); | ||||
| const bcrypt = require('bcryptjs'); | ||||
| const User = require('../built/models/user').default; | ||||
|  | ||||
| const args = process.argv.slice(2); | ||||
|  | ||||
| const user = args[0]; | ||||
|  | ||||
| const q = user.startsWith('@') ? { | ||||
| 	username: user.split('@')[1], | ||||
| 	host: user.split('@')[2] || null | ||||
| } : { _id: new mongo.ObjectID(user) }; | ||||
|  | ||||
| console.log(`Resetting password for ${user}...`); | ||||
|  | ||||
| const passwd = 'yo'; | ||||
|  | ||||
| // Generate hash of password | ||||
| const hash = bcrypt.hashSync(passwd); | ||||
|  | ||||
| User.update(q, { | ||||
| 	$set: { | ||||
| 		password: hash | ||||
| 	} | ||||
| }).then(() => { | ||||
| 	console.log(`Password of ${user} is now '${passwd}'`); | ||||
| }, e => { | ||||
| 	console.error(e); | ||||
| }); | ||||
| @@ -1,23 +0,0 @@ | ||||
| const mongo = require('mongodb'); | ||||
| const User = require('../built/models/user').default; | ||||
|  | ||||
| const args = process.argv.slice(2); | ||||
|  | ||||
| const user = args[0]; | ||||
|  | ||||
| const q = user.startsWith('@') ? { | ||||
| 	username: user.split('@')[1], | ||||
| 	host: user.split('@')[2] || null | ||||
| } : { _id: new mongo.ObjectID(user) }; | ||||
|  | ||||
| console.log(`Suspending ${user}...`); | ||||
|  | ||||
| User.update(q, { | ||||
| 	$set: { | ||||
| 		isSuspended: true | ||||
| 	} | ||||
| }).then(() => { | ||||
| 	console.log(`Suspended ${user}`); | ||||
| }, e => { | ||||
| 	console.error(e); | ||||
| }); | ||||
							
								
								
									
										70
									
								
								docs/examples/misskey.nginx
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,70 @@ | ||||
| # Sample nginx configuration for Misskey | ||||
| # | ||||
| # 1. Replace example.tld to your domain | ||||
| # 2. Copy to /etc/nginx/sites-available/ and then symlink from /etc/nginx/sites-ebabled/ | ||||
| #    or copy to /etc/nginx/conf.d/ | ||||
|  | ||||
| # For WebSocket | ||||
| map $http_upgrade $connection_upgrade { | ||||
|     default upgrade; | ||||
|     ''      close; | ||||
| } | ||||
|  | ||||
| proxy_cache_path /tmp/nginx_cache levels=1:2 keys_zone=cache1:16m max_size=1g inactive=720m use_temp_path=off; | ||||
|  | ||||
| server { | ||||
|     listen 80; | ||||
|     listen [::]:80; | ||||
|     server_name example.tld; | ||||
|  | ||||
|     # For SSL domain validation | ||||
|     root /var/www/html; | ||||
|     location /.well-known/acme-challenge/ { allow all; } | ||||
|     location /.well-known/pki-validation/ { allow all; } | ||||
|     location / { return 301 https://$server_name$request_uri; } | ||||
| } | ||||
|  | ||||
| server { | ||||
|     listen 443 http2; | ||||
|     listen [::]:443 http2; | ||||
|     server_name example.tld; | ||||
|     ssl on; | ||||
| 		ssl_session_cache shared:ssl_session_cache:10m; | ||||
|  | ||||
|     # To use Let's Encrypt certificate | ||||
|     ssl_certificate     /etc/letsencrypt/live/example.tld/fullchain.pem; | ||||
|     ssl_certificate_key /etc/letsencrypt/live/example.tld/privkey.pem; | ||||
|  | ||||
|     # To use Debian/Ubuntu's self-signed certificate (For testing or before issuing a certificate) | ||||
|     #ssl_certificate     /etc/ssl/certs/ssl-cert-snakeoil.pem; | ||||
|     #ssl_certificate_key /etc/ssl/private/ssl-cert-snakeoil.key; | ||||
|  | ||||
|     # SSL protocol settings | ||||
|     ssl_protocols TLSv1 TLSv1.2; | ||||
|     ssl_ciphers ECDHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-SHA384:ECDHE-RSA-AES128-SHA256:ECDHE-RSA-AES256-SHA:ECDHE-RSA-AES128-SHA:AES128-SHA; | ||||
|     ssl_prefer_server_ciphers on; | ||||
|  | ||||
|     # Change to your upload limit | ||||
|     client_max_body_size 80m; | ||||
|  | ||||
|     # Proxy to Node | ||||
|     location / { | ||||
|         proxy_pass http://127.0.0.1:3000; | ||||
|         proxy_set_header Host $host; | ||||
|         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_http_version 1.1; | ||||
|         proxy_redirect off; | ||||
|  | ||||
|         # For WebSocket | ||||
|         proxy_set_header Upgrade $http_upgrade; | ||||
|         proxy_set_header Connection $connection_upgrade; | ||||
|  | ||||
|         # Cache settings | ||||
|         proxy_cache cache1; | ||||
|         proxy_cache_lock on; | ||||
|         proxy_cache_use_stale updating; | ||||
|         add_header X-Cache $upstream_cache_status; | ||||
|     } | ||||
| } | ||||
| @@ -8,28 +8,11 @@ coming soon | ||||
| node cli/mark-admin (User-ID or Username) | ||||
| ``` | ||||
|  | ||||
| ## Mark as 'verified' user | ||||
| ``` shell | ||||
| node cli/mark-verified (User-ID or Username) | ||||
| ``` | ||||
|  | ||||
| ## Suspend users | ||||
| ``` shell | ||||
| node cli/suspend (User-ID or Username) | ||||
| ``` | ||||
| e.g. | ||||
| ``` shell | ||||
| # Use id | ||||
| node cli/suspend 57d01a501fdf2d07be417afe | ||||
| # By id | ||||
| node cli/mark-admin 57d01a501fdf2d07be417afe | ||||
|  | ||||
| # Use username | ||||
| # By username | ||||
| node cli/suspend @syuilo | ||||
|  | ||||
| # Use username (remote) | ||||
| node cli/suspend @syuilo@misskey.xyz | ||||
| ``` | ||||
|  | ||||
| ## Reset password | ||||
| ``` shell | ||||
| node cli/reset-password (User-ID or Username) | ||||
| ``` | ||||
|   | ||||
| @@ -8,28 +8,11 @@ coming soon | ||||
| node cli/mark-admin (ユーザーID または ユーザー名) | ||||
| ``` | ||||
|  | ||||
| ## 'verified'ユーザーを設定する | ||||
| ``` shell | ||||
| node cli/mark-verified (ユーザーID または ユーザー名) | ||||
| ``` | ||||
|  | ||||
| ## ユーザーを凍結する | ||||
| ``` shell | ||||
| node cli/suspend (ユーザーID または ユーザー名) | ||||
| ``` | ||||
| 例: | ||||
| ``` shell | ||||
| # ユーザーID | ||||
| node cli/suspend 57d01a501fdf2d07be417afe | ||||
| node cli/mark-admin 57d01a501fdf2d07be417afe | ||||
|  | ||||
| # ユーザー名 | ||||
| node cli/suspend @syuilo | ||||
|  | ||||
| # ユーザー名 (リモート) | ||||
| node cli/suspend @syuilo@misskey.xyz | ||||
| ``` | ||||
|  | ||||
| ## ユーザーのパスワードをリセットする | ||||
| ``` shell | ||||
| node cli/reset-password (ユーザーID または ユーザー名) | ||||
| node cli/mark-admin @syuilo | ||||
| ``` | ||||
|   | ||||
| @@ -47,16 +47,6 @@ As root: | ||||
| 4. `git checkout $(git tag -l | grep -v 'rc[0-9]*$' | sort -V | tail -n 1)` Checkout to the [latest release](https://github.com/syuilo/misskey/releases/latest) | ||||
| 5. `npm install` Install misskey dependencies. | ||||
|  | ||||
| *(optional)* Generate VAPID keys | ||||
| ---------------------------------------------------------------- | ||||
| If you want to enable ServiceWorker, you need to generate VAPID keys: | ||||
| Unless you have set your global node_modules location elsewhere, you need to run this as root. | ||||
|  | ||||
| ``` shell | ||||
| npm install web-push -g | ||||
| web-push generate-vapid-keys | ||||
| ``` | ||||
|  | ||||
| *5.* Configure Misskey | ||||
| ---------------------------------------------------------------- | ||||
| 1. `cp .config/example.yml .config/default.yml` Copy the `.config/example.yml` and rename it to `default.yml`. | ||||
|   | ||||
| @@ -47,16 +47,6 @@ En mode root : | ||||
| 4. `git checkout $(git tag -l | grep -v 'rc[0-9]*$' | sort -V | tail -n 1)` Télécharge la [version la plus récente](https://github.com/syuilo/misskey/releases/latest) | ||||
| 5. `npm install` Installez les dépendances de misskey. | ||||
|  | ||||
| *(optionnel)* Génération des clés VAPID | ||||
| ---------------------------------------------------------------- | ||||
| Si vous désirez activer ServiceWorker, vous devez générer les clés VAPID : | ||||
| Unless you have set your global node_modules location elsewhere, vous devez lancer ceci en mode root. | ||||
|  | ||||
| ``` shell | ||||
| npm install web-push -g | ||||
| web-push generate-vapid-keys | ||||
| ``` | ||||
|  | ||||
| *5.* Création du fichier de configuration | ||||
| ---------------------------------------------------------------- | ||||
| 1. `cp .config/example.yml .config/default.yml` Copiez le fichier `.config/example.yml` et renommez-le `default.yml`. | ||||
|   | ||||
| @@ -53,15 +53,6 @@ adduser --disabled-password --disabled-login misskey | ||||
| 4. `git checkout $(git tag -l | grep -v 'rc[0-9]*$' | sort -V | tail -n 1)` [最新のリリース](https://github.com/syuilo/misskey/releases/latest)を確認 | ||||
| 5. `npm install` Misskeyの依存パッケージをインストール | ||||
|  | ||||
| *(オプション)* VAPIDキーペアの生成 | ||||
| ---------------------------------------------------------------- | ||||
| ServiceWorkerを有効にする場合、VAPIDキーペアを生成する必要があります: | ||||
|  | ||||
| ``` shell | ||||
| npm install web-push -g | ||||
| web-push generate-vapid-keys | ||||
| ``` | ||||
|  | ||||
| *5.* 設定ファイルを作成する | ||||
| ---------------------------------------------------------------- | ||||
| 1. `cp .config/example.yml .config/default.yml` `.config/example.yml`をコピーし名前を`default.yml`にする。 | ||||
|   | ||||
							
								
								
									
										52
									
								
								gulpfile.ts
									
									
									
									
									
								
							
							
						
						| @@ -11,14 +11,12 @@ import tslint from 'gulp-tslint'; | ||||
| const cssnano = require('gulp-cssnano'); | ||||
| const stylus = require('gulp-stylus'); | ||||
| import * as uglifyComposer from 'gulp-uglify/composer'; | ||||
| import pug = require('gulp-pug'); | ||||
| import * as rimraf from 'rimraf'; | ||||
| import chalk from 'chalk'; | ||||
| const imagemin = require('gulp-imagemin'); | ||||
| import * as rename from 'gulp-rename'; | ||||
| import * as mocha from 'gulp-mocha'; | ||||
| import * as replace from 'gulp-replace'; | ||||
| import * as htmlmin from 'gulp-htmlmin'; | ||||
| const uglifyes = require('uglify-es'); | ||||
|  | ||||
| const locales = require('./locales'); | ||||
| @@ -34,8 +32,6 @@ if (isDebug) { | ||||
| 	console.warn(chalk.yellow.bold('         built script will not be compressed.')); | ||||
| } | ||||
|  | ||||
| const constants = require('./src/const.json'); | ||||
|  | ||||
| gulp.task('build', [ | ||||
| 	'build:ts', | ||||
| 	'build:copy', | ||||
| @@ -109,7 +105,7 @@ gulp.task('default', ['build']); | ||||
| gulp.task('build:client', [ | ||||
| 	'build:ts', | ||||
| 	'build:client:script', | ||||
| 	'build:client:pug', | ||||
| 	'build:client:styles', | ||||
| 	'copy:client' | ||||
| ]); | ||||
|  | ||||
| @@ -148,52 +144,6 @@ gulp.task('copy:client', [ | ||||
| 			.pipe(gulp.dest('./built/client/assets/')) | ||||
| ); | ||||
|  | ||||
| gulp.task('build:client:pug', [ | ||||
| 	'copy:client', | ||||
| 	'build:client:script', | ||||
| 	'build:client:styles' | ||||
| ], () => | ||||
| 		gulp.src('./src/client/app/base.pug') | ||||
| 			.pipe(pug({ | ||||
| 				locals: { | ||||
| 					themeColor: constants.themeColor | ||||
| 				} | ||||
| 			})) | ||||
| 			.pipe(htmlmin({ | ||||
| 				// 真理値属性の簡略化 e.g. | ||||
| 				// <input value="foo" readonly="readonly"> to | ||||
| 				// <input value="foo" readonly> | ||||
| 				collapseBooleanAttributes: true, | ||||
|  | ||||
| 				// テキストの一部かもしれない空白も削除する e.g. | ||||
| 				// <div> <p>    foo </p>    </div> to | ||||
| 				// <div><p>foo</p></div> | ||||
| 				collapseWhitespace: true, | ||||
|  | ||||
| 				// タグ間の改行を保持する | ||||
| 				preserveLineBreaks: true, | ||||
|  | ||||
| 				// (できる場合は)属性のクォーテーション削除する e.g. | ||||
| 				// <p class="foo-bar" id="moo" title="blah blah">foo</p> to | ||||
| 				// <p class=foo-bar id=moo title="blah blah">foo</p> | ||||
| 				removeAttributeQuotes: true, | ||||
|  | ||||
| 				// 省略可能なタグを省略する e.g. | ||||
| 				// <html><p>yo</p></html> ro | ||||
| 				// <p>yo</p> | ||||
| 				removeOptionalTags: true, | ||||
|  | ||||
| 				// 属性の値がデフォルトと同じなら省略する e.g. | ||||
| 				// <input type="text"> to | ||||
| 				// <input> | ||||
| 				removeRedundantAttributes: true, | ||||
|  | ||||
| 				// CSSも圧縮する | ||||
| 				minifyCSS: true | ||||
| 			})) | ||||
| 			.pipe(gulp.dest('./built/client/app/')) | ||||
| ); | ||||
|  | ||||
| gulp.task('locales', () => | ||||
| 	gulp.src('./locales/*.yml') | ||||
| 		.pipe(yaml({ schema: 'DEFAULT_SAFE_SCHEMA' })) | ||||
|   | ||||
| @@ -26,6 +26,7 @@ common: | ||||
|   close: "閉じる" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   load-more: "もっと読み込む" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   got-it: "わかった" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
| @@ -109,9 +110,10 @@ common: | ||||
|   my-token-regenerated: "あなたのトークンが更新されたのでサインアウトします。" | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   use-white-black-reversi-stones: "リバーシに白黒の石を使う" | ||||
|   verified-user: "公式アカウント" | ||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   show-full-acct: "ユーザー名のホストを省略しない" | ||||
| @@ -157,12 +159,12 @@ common: | ||||
|     polls: "アンケート" | ||||
|     post-form: "投稿フォーム" | ||||
|     server: "サーバー情報" | ||||
|     donation: "寄付のお願い" | ||||
|     nav: "ナビゲーション" | ||||
|     tips: "ヒント" | ||||
|     hashtags: "ハッシュタグ" | ||||
|   dev: "アプリの作成に失敗しました。再度お試しください。" | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
|   you: "あなた" | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{name}</i>があなたのアカウントにアクセスすることを許可しますか?" | ||||
|   permission-ask: "このアプリは次の権限を要求しています:" | ||||
| @@ -295,6 +297,8 @@ common/views/components/theme.vue: | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "隠す" | ||||
|   show: "もっと見る" | ||||
|   chars: "{count}文字" | ||||
|   files: "{count}ファイル" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "ユーザーを探す" | ||||
|   you: "あなた" | ||||
| @@ -399,13 +403,11 @@ common/views/components/stream-indicator.vue: | ||||
|   connecting: "接続中" | ||||
|   reconnecting: "再接続中" | ||||
|   connected: "接続完了" | ||||
| common/views/components/twitter-setting.vue: | ||||
|   description: "お使いのTwitterアカウントをお使いのMisskeyアカウントに接続しておくと、プロフィールでTwitterアカウント情報が表示されるようになったり、Twitterを用いた便利なサインインを利用できるようになります。" | ||||
|   connected-to: "次のTwitterアカウントに接続されています" | ||||
|   detail: "詳細..." | ||||
|   reconnect: "再接続する" | ||||
|   connect: "Twitterと接続する" | ||||
| common/views/components/integration-settings.vue: | ||||
|   title: "サービス連携" | ||||
|   connect: "接続する" | ||||
|   disconnect: "切断する" | ||||
|   connected-to: "次のアカウントに接続されています" | ||||
| common/views/components/github-setting.vue: | ||||
|   description: "お使いのGitHubアカウントをお使いのMisskeyアカウントに接続しておくと、プロフィールでGitHubアカウント情報が表示されるようになったり、GitHubを用いた便利なサインインを利用できるようになります。" | ||||
|   connected-to: "次のGitHubアカウントに接続されています" | ||||
| @@ -438,12 +440,20 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/components/language-settings.vue: | ||||
|   title: "表示言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語を指定" | ||||
|   info: "変更はページの再度読み込み後に反映されます。" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   language: "言語" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
| @@ -457,6 +467,10 @@ common/views/components/profile-editor.vue: | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
|   email: "メール設定" | ||||
|   email-address: "メールアドレス" | ||||
|   email-verified: "メールアドレスが確認されました" | ||||
|   email-not-verified: "メールアドレスが確認されていません。メールボックスをご確認ください。" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "確認中" | ||||
|   no-broadcasts: "お知らせはありません" | ||||
| @@ -469,9 +483,6 @@ common/views/widgets/calendar.vue: | ||||
|   today: "今日:" | ||||
|   this-month: "今月:" | ||||
|   this-year: "今年:" | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "寄付のお願い" | ||||
|   text: "Misskeyの運営にはドメイン、サーバー等のコストが掛かります。Misskeyは広告を掲載したりしないため、収入を皆様からの寄付に頼っています。もしご興味があれば、{}までご連絡ください。ご協力ありがとうございます。" | ||||
| common/views/widgets/photo-stream.vue: | ||||
|   title: "フォトストリーム" | ||||
|   no-photos: "写真はありません" | ||||
| @@ -512,6 +523,8 @@ common/views/widgets/tips.vue: | ||||
|   tips-line23: "まゆかわいいよまゆ" | ||||
|   tips-line24: "Misskeyは2014年にサービスを開始しました" | ||||
|   tips-line25: "対応ブラウザではMisskeyを開いていなくても通知を受け取れます" | ||||
| common/views/pages/404.vue: | ||||
|   page-not-found: "ページが見つかりませんでした" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   following: "フォロー中" | ||||
| @@ -731,6 +744,8 @@ desktop/views/components/settings.vue: | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   web-search-engine: "ウェブ検索エンジン" | ||||
|   web-search-engine-desc: "例: https://www.google.com/?#q={{query}}" | ||||
|   auto-popout: "ウィンドウの自動ポップアウト" | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   advanced: "詳細設定" | ||||
| @@ -750,7 +765,6 @@ desktop/views/components/settings.vue: | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   timeline: "タイムライン" | ||||
| @@ -759,20 +773,21 @@ desktop/views/components/settings.vue: | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   remain-deleted-note: "削除された投稿を表示し続ける" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align: "デッキのカラムの配置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   deck-column-align-flexible: "フレキシブル" | ||||
|   deck-column-width: "デッキのカラムの幅" | ||||
|   deck-column-width-narrow: "狭" | ||||
|   deck-column-width-narrower: "やや狭" | ||||
|   deck-column-width-normal: "普通" | ||||
|   deck-column-width-wider: "やや広" | ||||
|   deck-column-width-wide: "広" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||
|   volume: "ボリューム" | ||||
|   test: "テスト" | ||||
|   language: "言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語を指定" | ||||
|   language-desc: "変更はページの再度読み込み後に反映されます。" | ||||
|   cache: "キャッシュ" | ||||
|   clean-cache: "クリーンアップ" | ||||
|   cache-warn: "クリーンアップを行うと、ブラウザに記憶されたアカウント情報のキャッシュ、書きかけの投稿・返信・メッセージ、およびその他のデータ(設定情報含む)が削除されます。クリーンアップを行った後はページを再度読み込みする必要があります。" | ||||
| @@ -862,11 +877,17 @@ common/views/components/password-settings.vue: | ||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||
|   not-match: "新しいパスワードが一致しません" | ||||
|   changed: "パスワードを変更しました" | ||||
|   failed: "パスワード変更に失敗しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   media-count: "{}つのメディア" | ||||
|   poll: "アンケート" | ||||
| desktop/views/components/settings.tags.vue: | ||||
|   title: "タグ" | ||||
|   query: "クエリ (省略可)" | ||||
|   add: "追加" | ||||
|   save: "保存" | ||||
| desktop/views/components/taskmanager.vue: | ||||
|   title: "タスクマネージャ" | ||||
| desktop/views/components/timeline.vue: | ||||
| @@ -949,6 +970,7 @@ admin/views/instance.vue: | ||||
|   instance-description: "インスタンスの紹介" | ||||
|   host: "ホスト" | ||||
|   banner-url: "バナー画像URL" | ||||
|   error-image-url: "エラー画像URL" | ||||
|   languages: "インスタンスの対象言語" | ||||
|   languages-desc: "スペースで区切って複数設定できます。" | ||||
|   maintainer-config: "管理者情報" | ||||
| @@ -966,17 +988,17 @@ admin/views/instance.vue: | ||||
|   recaptcha-site-key: "reCAPTCHA site key" | ||||
|   recaptcha-secret-key: "reCAPTCHA secret key" | ||||
|   twitter-integration-config: "Twitter連携の設定" | ||||
|   twitter-integration-info: "コールバックURLは /api/tw/cb に設定します。" | ||||
|   twitter-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-twitter-integration: "Twitter連携を有効にする" | ||||
|   twitter-integration-consumer-key: "Consumer key" | ||||
|   twitter-integration-consumer-secret: "Consumer secret" | ||||
|   github-integration-config: "GitHub連携の設定" | ||||
|   github-integration-info: "コールバックURLは /api/gh/cb に設定します。" | ||||
|   github-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-github-integration: "GitHub連携を有効にする" | ||||
|   github-integration-client-id: "Client ID" | ||||
|   github-integration-client-secret: "Client Secret" | ||||
|   discord-integration-config: "Discord連携の設定" | ||||
|   discord-integration-info: "コールバックURLは /api/dc/cb に設定します。" | ||||
|   discord-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-discord-integration: "Discord連携を有効にする" | ||||
|   discord-integration-client-id: "Client ID" | ||||
|   discord-integration-client-secret: "Client Secret" | ||||
| @@ -991,6 +1013,22 @@ admin/views/instance.vue: | ||||
|   invite: "招待" | ||||
|   save: "保存" | ||||
|   saved: "保存しました" | ||||
|   user-recommendation-config: "おすすめユーザー" | ||||
|   enable-external-user-recommendation: "外部ユーザーレコメンデーションを有効にする" | ||||
|   external-user-recommendation-engine: "エンジン" | ||||
|   external-user-recommendation-engine-desc: "例: https://vinayaka.distsn.org/cgi-bin/vinayaka-user-match-misskey-api.cgi?{{host}}+{{user}}+{{limit}}+{{offset}}" | ||||
|   external-user-recommendation-timeout: "タイムアウト" | ||||
|   external-user-recommendation-timeout-desc: "ミリ秒単位 (例: 300000)" | ||||
|   email-config: "メールサーバーの設定" | ||||
|   email-config-info: "メールアドレス確認やパスワードリセットの際に使われます。" | ||||
|   enable-email: "メール配信を有効にする" | ||||
|   email: "メールアドレス" | ||||
|   smtp-secure: "SMTP接続に暗黙的なSSL/TLSを使用する" | ||||
|   smtp-secure-info: "STARTTLS使用時はオフにします。" | ||||
|   smtp-host: "SMTPホスト" | ||||
|   smtp-port: "SMTPポート" | ||||
|   smtp-user: "SMTPユーザー" | ||||
|   smtp-pass: "SMTPパスワード" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
| @@ -1016,19 +1054,50 @@ admin/views/charts.vue: | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| admin/views/drive.vue: | ||||
|   sort: | ||||
|     title: "ソート" | ||||
|     createdAtAsc: "アップロード日時が古い順" | ||||
|     createdAtDesc: "アップロード日時が新しい順" | ||||
|     sizeAsc: "サイズが小さい順" | ||||
|     sizeDesc: "サイズが大きい順" | ||||
|   origin: | ||||
|     title: "オリジン" | ||||
|     combined: "ローカル+リモート" | ||||
|     local: "ローカル" | ||||
|     remote: "リモート" | ||||
|   delete: "削除" | ||||
|   deleted: "削除しました" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   operation: "操作" | ||||
|   username-or-userid: "ユーザー名またはユーザーID" | ||||
|   user-not-found: "ユーザーが見つかりません" | ||||
|   lookup: "照会" | ||||
|   reset-password: "パスワードをリセット" | ||||
|   password-updated: "パスワードは現在「{password}」です" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|   users: | ||||
|     title: "ユーザー" | ||||
|     sort: | ||||
|       title: "ソート" | ||||
|       createdAtAsc: "登録日時が古い順" | ||||
|       createdAtDesc: "登録日時が新しい順" | ||||
|       updatedAtAsc: "更新日時が古い順" | ||||
|       updatedAtDesc: "更新日時が新しい順" | ||||
|     origin: | ||||
|       title: "オリジン" | ||||
|       combined: "ローカル+リモート" | ||||
|       local: "ローカル" | ||||
|       remote: "リモート" | ||||
|     createdAt: "登録日時" | ||||
|     updatedAt: "更新日時" | ||||
| admin/views/moderators.vue: | ||||
|   add-moderator: | ||||
|     title: "モデレーターの登録" | ||||
| @@ -1321,11 +1390,6 @@ mobile/views/pages/selectdrive.vue: | ||||
|   select-file: "ファイルを選択" | ||||
| mobile/views/pages/settings.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   lang: "言語" | ||||
|   lang-tip: "変更はページの再読み込み後に反映されます。" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語を指定" | ||||
|   design: "デザインと表示" | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
| @@ -1348,21 +1412,11 @@ mobile/views/pages/settings.vue: | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   web-search-engine: "ウェブ検索エンジン" | ||||
|   web-search-engine-desc: "例: https://www.google.com/?#q={{query}}" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   load-raw-images: "添付された画像を高画質で表示する" | ||||
|   load-remote-media: "リモートサーバーのメディアを表示する" | ||||
|   twitter: "Twitter連携" | ||||
|   twitter-connect: "Twitterアカウントに接続する" | ||||
|   twitter-reconnect: "再接続する" | ||||
|   twitter-disconnect: "切断する" | ||||
|   github: "GitHub連携" | ||||
|   github-connect: "GitHubアカウントに接続する" | ||||
|   github-reconnect: "再接続する" | ||||
|   github-disconnect: "切断する" | ||||
|   discord: "Discord連携" | ||||
|   discord-connect: "Discordアカウントに接続する" | ||||
|   discord-reconnect: "再接続する" | ||||
|   discord-disconnect: "切断する" | ||||
|   update: "Misskey Update" | ||||
|   version: "バージョン:" | ||||
|   latest-version: "最新のバージョン:" | ||||
| @@ -1392,6 +1446,9 @@ mobile/views/pages/user.vue: | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
|   years-old: "{age}歳" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "最近の投稿" | ||||
|   images: "画像" | ||||
|   | ||||
| @@ -26,6 +26,7 @@ common: | ||||
|   close: "Schließen" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   load-more: "もっと読み込む" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   got-it: "Verstanden!" | ||||
|   customization-tips: | ||||
|     title: "Anpassung-Tipps" | ||||
| @@ -109,9 +110,10 @@ common: | ||||
|   my-token-regenerated: "Dein Token wurde generiert. Du wirst jetzt abgemeldet." | ||||
|   i-like-sushi: "Ich bevorzuge Sushi anstelle von Pudding" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   use-white-black-reversi-stones: "リバーシに白黒の石を使う" | ||||
|   verified-user: "Verifizierter Benutzer" | ||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   show-full-acct: "ユーザー名のホストを省略しない" | ||||
| @@ -157,12 +159,12 @@ common: | ||||
|     polls: "Umfrage" | ||||
|     post-form: "Beitragsform" | ||||
|     server: "Server-Info" | ||||
|     donation: "Spenden" | ||||
|     nav: "Navigation" | ||||
|     tips: "Tipps" | ||||
|     hashtags: "Hashtags" | ||||
|   dev: "Fehler beim Erstellen der Applikation. Bitte versuche es erneut." | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
|   you: "あなた" | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{name}</i>があなたのアカウントにアクセスすることを許可しますか?" | ||||
|   permission-ask: "このアプリは次の権限を要求しています:" | ||||
| @@ -295,6 +297,8 @@ common/views/components/theme.vue: | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "隠す" | ||||
|   show: "もっと見る" | ||||
|   chars: "{count}文字" | ||||
|   files: "{count}ファイル" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "Einen Nutzer suchen" | ||||
|   you: "Du" | ||||
| @@ -399,13 +403,11 @@ common/views/components/stream-indicator.vue: | ||||
|   connecting: "Verbindung wird hergestellt" | ||||
|   reconnecting: "Erneut verbinden" | ||||
|   connected: "Verbindung hergestellt" | ||||
| common/views/components/twitter-setting.vue: | ||||
|   description: "Wenn du deinen Twitter-Account mit deinem Misskey-Account verbindest, siehst du deine Twitter Account-Informationen auf deinem Profil und du kannst dich mit Twitter einloggen." | ||||
|   connected-to: "Du bist mit diesem Twitter-Account verbunden" | ||||
|   detail: "Mehr..." | ||||
|   reconnect: "Erneut verbinden" | ||||
|   connect: "Mit Twitter verbinden" | ||||
|   disconnect: "Trennen" | ||||
| common/views/components/integration-settings.vue: | ||||
|   title: "サービス連携" | ||||
|   connect: "接続する" | ||||
|   disconnect: "切断する" | ||||
|   connected-to: "次のアカウントに接続されています" | ||||
| common/views/components/github-setting.vue: | ||||
|   description: "お使いのGitHubアカウントをお使いのMisskeyアカウントに接続しておくと、プロフィールでGitHubアカウント情報が表示されるようになったり、GitHubを用いた便利なサインインを利用できるようになります。" | ||||
|   connected-to: "次のGitHubアカウントに接続されています" | ||||
| @@ -438,12 +440,20 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/components/language-settings.vue: | ||||
|   title: "表示言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語を指定" | ||||
|   info: "変更はページの再度読み込み後に反映されます。" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   language: "言語" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
| @@ -457,6 +467,10 @@ common/views/components/profile-editor.vue: | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
|   email: "メール設定" | ||||
|   email-address: "メールアドレス" | ||||
|   email-verified: "メールアドレスが確認されました" | ||||
|   email-not-verified: "メールアドレスが確認されていません。メールボックスをご確認ください。" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "Laden" | ||||
|   no-broadcasts: "Keine Broadcasts" | ||||
| @@ -469,9 +483,6 @@ common/views/widgets/calendar.vue: | ||||
|   today: "今日:" | ||||
|   this-month: "今月:" | ||||
|   this-year: "今年:" | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "Spende" | ||||
|   text: "Um Misskey am Laufen zu halten geben wir Geld für Domain, Server usw. aus. Wir bekommen dafür kein Geld und würden uns freuen, wenn du spenden würdest. Wenn du interessiert bist, dann kontaktiere {}. Danke für deine Unterstützung!" | ||||
| common/views/widgets/photo-stream.vue: | ||||
|   title: "Fotostream" | ||||
|   no-photos: "Keine Fotos" | ||||
| @@ -512,6 +523,8 @@ common/views/widgets/tips.vue: | ||||
|   tips-line23: "まゆかわいいよまゆ" | ||||
|   tips-line24: "Misskeyは2014年にサービスを開始しました" | ||||
|   tips-line25: "対応ブラウザではMisskeyを開いていなくても通知を受け取れます" | ||||
| common/views/pages/404.vue: | ||||
|   page-not-found: "ページが見つかりませんでした" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   following: "フォロー中" | ||||
| @@ -731,6 +744,8 @@ desktop/views/components/settings.vue: | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   web-search-engine: "ウェブ検索エンジン" | ||||
|   web-search-engine-desc: "例: https://www.google.com/?#q={{query}}" | ||||
|   auto-popout: "Automatische Pop-out Fenster" | ||||
|   auto-popout-desc: "Pop-out ein offenes Fenster wenn möglich. Diese Einstellung wird im Browser gespeichert." | ||||
|   advanced: "Erweiterte Einstellungen" | ||||
| @@ -750,7 +765,6 @@ desktop/views/components/settings.vue: | ||||
|   circle-icons: "Kreisförmige Icons" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "Zeige Antworten" | ||||
|   timeline: "タイムライン" | ||||
| @@ -759,20 +773,21 @@ desktop/views/components/settings.vue: | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "Karte anzeigen" | ||||
|   remain-deleted-note: "削除された投稿を表示し続ける" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align: "デッキのカラムの配置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   deck-column-align-flexible: "フレキシブル" | ||||
|   deck-column-width: "デッキのカラムの幅" | ||||
|   deck-column-width-narrow: "狭" | ||||
|   deck-column-width-narrower: "やや狭" | ||||
|   deck-column-width-normal: "普通" | ||||
|   deck-column-width-wider: "やや広" | ||||
|   deck-column-width-wide: "広" | ||||
|   sound: "Ton" | ||||
|   enable-sounds: "Ton aktivieren" | ||||
|   enable-sounds-desc: "Spiel einen Ton ab beim Erhalten eines Beitrags bzw. einer Nachricht. Diese Einstellung wird im Browser gespeichert." | ||||
|   volume: "Lautstärke" | ||||
|   test: "Test" | ||||
|   language: "Sprache" | ||||
|   pick-language: "Sprache auswählen" | ||||
|   recommended: "Empfohlen" | ||||
|   auto: "Automatisch" | ||||
|   specify-language: "Sprache auswählen" | ||||
|   language-desc: "変更はページの再度読み込み後に反映されます。" | ||||
|   cache: "キャッシュ" | ||||
|   clean-cache: "クリーンアップ" | ||||
|   cache-warn: "Der Cache deines Benutzerkontos (Info, Beiträge, Antworten, Direktnachrichten, Einstellungen), die lokal im Browser gespeichert sind werden gelöscht.\nDu musst die Seite aktualisieren nachdem du aufgeräumt hast." | ||||
| @@ -862,11 +877,17 @@ common/views/components/password-settings.vue: | ||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||
|   not-match: "新しいパスワードが一致しません" | ||||
|   changed: "パスワードを変更しました" | ||||
|   failed: "パスワード変更に失敗しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   media-count: "{}つのメディア" | ||||
|   poll: "アンケート" | ||||
| desktop/views/components/settings.tags.vue: | ||||
|   title: "タグ" | ||||
|   query: "クエリ (省略可)" | ||||
|   add: "追加" | ||||
|   save: "保存" | ||||
| desktop/views/components/taskmanager.vue: | ||||
|   title: "Taskmanager" | ||||
| desktop/views/components/timeline.vue: | ||||
| @@ -949,6 +970,7 @@ admin/views/instance.vue: | ||||
|   instance-description: "インスタンスの紹介" | ||||
|   host: "ホスト" | ||||
|   banner-url: "バナー画像URL" | ||||
|   error-image-url: "エラー画像URL" | ||||
|   languages: "インスタンスの対象言語" | ||||
|   languages-desc: "スペースで区切って複数設定できます。" | ||||
|   maintainer-config: "管理者情報" | ||||
| @@ -966,17 +988,17 @@ admin/views/instance.vue: | ||||
|   recaptcha-site-key: "reCAPTCHA site key" | ||||
|   recaptcha-secret-key: "reCAPTCHA secret key" | ||||
|   twitter-integration-config: "Twitter連携の設定" | ||||
|   twitter-integration-info: "コールバックURLは /api/tw/cb に設定します。" | ||||
|   twitter-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-twitter-integration: "Twitter連携を有効にする" | ||||
|   twitter-integration-consumer-key: "Consumer key" | ||||
|   twitter-integration-consumer-secret: "Consumer secret" | ||||
|   github-integration-config: "GitHub連携の設定" | ||||
|   github-integration-info: "コールバックURLは /api/gh/cb に設定します。" | ||||
|   github-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-github-integration: "GitHub連携を有効にする" | ||||
|   github-integration-client-id: "Client ID" | ||||
|   github-integration-client-secret: "Client Secret" | ||||
|   discord-integration-config: "Discord連携の設定" | ||||
|   discord-integration-info: "コールバックURLは /api/dc/cb に設定します。" | ||||
|   discord-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-discord-integration: "Discord連携を有効にする" | ||||
|   discord-integration-client-id: "Client ID" | ||||
|   discord-integration-client-secret: "Client Secret" | ||||
| @@ -991,6 +1013,22 @@ admin/views/instance.vue: | ||||
|   invite: "招待" | ||||
|   save: "保存" | ||||
|   saved: "保存しました" | ||||
|   user-recommendation-config: "おすすめユーザー" | ||||
|   enable-external-user-recommendation: "外部ユーザーレコメンデーションを有効にする" | ||||
|   external-user-recommendation-engine: "エンジン" | ||||
|   external-user-recommendation-engine-desc: "例: https://vinayaka.distsn.org/cgi-bin/vinayaka-user-match-misskey-api.cgi?{{host}}+{{user}}+{{limit}}+{{offset}}" | ||||
|   external-user-recommendation-timeout: "タイムアウト" | ||||
|   external-user-recommendation-timeout-desc: "ミリ秒単位 (例: 300000)" | ||||
|   email-config: "メールサーバーの設定" | ||||
|   email-config-info: "メールアドレス確認やパスワードリセットの際に使われます。" | ||||
|   enable-email: "メール配信を有効にする" | ||||
|   email: "メールアドレス" | ||||
|   smtp-secure: "SMTP接続に暗黙的なSSL/TLSを使用する" | ||||
|   smtp-secure-info: "STARTTLS使用時はオフにします。" | ||||
|   smtp-host: "SMTPホスト" | ||||
|   smtp-port: "SMTPポート" | ||||
|   smtp-user: "SMTPユーザー" | ||||
|   smtp-pass: "SMTPパスワード" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
| @@ -1016,19 +1054,50 @@ admin/views/charts.vue: | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| admin/views/drive.vue: | ||||
|   sort: | ||||
|     title: "ソート" | ||||
|     createdAtAsc: "アップロード日時が古い順" | ||||
|     createdAtDesc: "アップロード日時が新しい順" | ||||
|     sizeAsc: "サイズが小さい順" | ||||
|     sizeDesc: "サイズが大きい順" | ||||
|   origin: | ||||
|     title: "オリジン" | ||||
|     combined: "ローカル+リモート" | ||||
|     local: "ローカル" | ||||
|     remote: "リモート" | ||||
|   delete: "削除" | ||||
|   deleted: "削除しました" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   operation: "操作" | ||||
|   username-or-userid: "ユーザー名またはユーザーID" | ||||
|   user-not-found: "ユーザーが見つかりません" | ||||
|   lookup: "照会" | ||||
|   reset-password: "パスワードをリセット" | ||||
|   password-updated: "パスワードは現在「{password}」です" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|   users: | ||||
|     title: "ユーザー" | ||||
|     sort: | ||||
|       title: "ソート" | ||||
|       createdAtAsc: "登録日時が古い順" | ||||
|       createdAtDesc: "登録日時が新しい順" | ||||
|       updatedAtAsc: "更新日時が古い順" | ||||
|       updatedAtDesc: "更新日時が新しい順" | ||||
|     origin: | ||||
|       title: "オリジン" | ||||
|       combined: "ローカル+リモート" | ||||
|       local: "ローカル" | ||||
|       remote: "リモート" | ||||
|     createdAt: "登録日時" | ||||
|     updatedAt: "更新日時" | ||||
| admin/views/moderators.vue: | ||||
|   add-moderator: | ||||
|     title: "モデレーターの登録" | ||||
| @@ -1321,11 +1390,6 @@ mobile/views/pages/selectdrive.vue: | ||||
|   select-file: "ファイルを選択" | ||||
| mobile/views/pages/settings.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   lang: "言語" | ||||
|   lang-tip: "変更はページの再読み込み後に反映されます。" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "Sprache auswählen" | ||||
|   design: "デザインと表示" | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
| @@ -1348,21 +1412,11 @@ mobile/views/pages/settings.vue: | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   web-search-engine: "ウェブ検索エンジン" | ||||
|   web-search-engine-desc: "例: https://www.google.com/?#q={{query}}" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   load-raw-images: "添付された画像を高画質で表示する" | ||||
|   load-remote-media: "リモートサーバーのメディアを表示する" | ||||
|   twitter: "Twitter連携" | ||||
|   twitter-connect: "Twitterアカウントに接続する" | ||||
|   twitter-reconnect: "再接続する" | ||||
|   twitter-disconnect: "切断する" | ||||
|   github: "GitHub連携" | ||||
|   github-connect: "GitHubアカウントに接続する" | ||||
|   github-reconnect: "再接続する" | ||||
|   github-disconnect: "切断する" | ||||
|   discord: "Discord連携" | ||||
|   discord-connect: "Discordアカウントに接続する" | ||||
|   discord-reconnect: "再接続する" | ||||
|   discord-disconnect: "切断する" | ||||
|   update: "Misskey Update" | ||||
|   version: "バージョン:" | ||||
|   latest-version: "Neuste Version:" | ||||
| @@ -1392,6 +1446,9 @@ mobile/views/pages/user.vue: | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
|   years-old: "{age}歳" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "最近の投稿" | ||||
|   images: "画像" | ||||
|   | ||||
| @@ -26,6 +26,7 @@ common: | ||||
|   close: "Close" | ||||
|   do-not-copy-paste: "Please do not enter or paste the code here. Account may be compromised." | ||||
|   load-more: "Load more" | ||||
|   enter-password: "Please enter the Password" | ||||
|   got-it: "Got it!" | ||||
|   customization-tips: | ||||
|     title: "Customization tips" | ||||
| @@ -90,9 +91,9 @@ common: | ||||
|     specified: "Direct" | ||||
|     specified-desc: "Post to specified users only" | ||||
|     private: "Private" | ||||
|     local-public: "Local (Public)" | ||||
|     local-home: "Local (Home)" | ||||
|     local-followers: "Local (Followers)" | ||||
|     local-public: "Public (Only local)" | ||||
|     local-home: "Home (Only local)" | ||||
|     local-followers: "Followers (Only local)" | ||||
|   note-placeholders: | ||||
|     a: "What are you doing?" | ||||
|     b: "What's happening?" | ||||
| @@ -109,9 +110,10 @@ common: | ||||
|   my-token-regenerated: "Your token has been regenerated, so you will be signed out." | ||||
|   i-like-sushi: "I prefer sushi rather than pudding" | ||||
|   show-reversi-board-labels: "Show row and column labels in Reversi" | ||||
|   use-contrast-reversi-stones: "Make the stone color clear in reversi" | ||||
|   use-white-black-reversi-stones: "Use white-black stone in reversi" | ||||
|   verified-user: "Verified account" | ||||
|   disable-animated-mfm: "Disable animated texts in a post" | ||||
|   suggest-recent-hashtags: "Suggest recently used hashtags within the post composition area" | ||||
|   always-show-nsfw: "Always show NSFW contents" | ||||
|   always-mark-nsfw: "Always mark posts with media attachments as NSFW" | ||||
|   show-full-acct: "Do not omit the hostname from the username" | ||||
| @@ -119,7 +121,7 @@ common: | ||||
|   reduce-motion: "Reduce motion in UI" | ||||
|   this-setting-is-this-device-only: "Only for this device" | ||||
|   use-os-default-emojis: "Use the OS default Emojis" | ||||
|   do-not-use-in-production: 'As this is for development, do not use this in production.' | ||||
|   do-not-use-in-production: 'This is a development build. Do not use in production.' | ||||
|   is-remote-user: "This user information is copied." | ||||
|   is-remote-post: "This post information is a copy." | ||||
|   view-on-remote: "View it on remote" | ||||
| @@ -157,12 +159,12 @@ common: | ||||
|     polls: "Polls" | ||||
|     post-form: "Post form" | ||||
|     server: "Server info" | ||||
|     donation: "Request for donations" | ||||
|     nav: "Navigation" | ||||
|     tips: "Tips" | ||||
|     hashtags: "Hashtags" | ||||
|   dev: "Failed to create the application. Please try again." | ||||
|   ai-chan-kawaii: "Ai-chan kawaii!" | ||||
|   you: "You" | ||||
| auth/views/form.vue: | ||||
|   share-access: "Would you allow <i>{name}</i> to access your account?" | ||||
|   permission-ask: "This application requires the following permissions:" | ||||
| @@ -208,7 +210,7 @@ common/views/components/games/reversi/reversi.index.vue: | ||||
|   invitations: "You’ve got an invitation!" | ||||
|   my-games: "My game" | ||||
|   all-games: "All games" | ||||
|   enter-username: "Enter a username" | ||||
|   enter-username: "Please enter username" | ||||
|   game-state: | ||||
|     ended: "Finished" | ||||
|     playing: "In Progress" | ||||
| @@ -219,7 +221,7 @@ common/views/components/games/reversi/reversi.room.vue: | ||||
|   black-or-white: "Black/White" | ||||
|   black-is: "Black is {}" | ||||
|   rules: "Rules" | ||||
|   is-llotheo: "The lesser side wins" | ||||
|   is-llotheo: "The lesser one wins(Llotheo)" | ||||
|   looped-map: "Looped map" | ||||
|   can-put-everywhere: "Can put everywhere" | ||||
|   settings-of-the-bot: "Bot settings" | ||||
| @@ -267,7 +269,7 @@ common/views/components/theme.vue: | ||||
|   install: "Install" | ||||
|   installed: "\"{}\" has been installed" | ||||
|   create-a-theme: "Create a theme" | ||||
|   save-created-theme: "Save a theme" | ||||
|   save-created-theme: "Save theme" | ||||
|   primary-color: "Primary color" | ||||
|   secondary-color: "Secondary color" | ||||
|   text-color: "Text color" | ||||
| @@ -295,6 +297,8 @@ common/views/components/theme.vue: | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "Hide" | ||||
|   show: "See more" | ||||
|   chars: "{count} chars" | ||||
|   files: "{count} files" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "Find a user" | ||||
|   you: "You" | ||||
| @@ -366,8 +370,8 @@ common/views/components/signin.vue: | ||||
|   signin: "Sign in" | ||||
|   or: "Or" | ||||
|   signin-with-twitter: "Log in with Twitter" | ||||
|   signin-with-github: "Log in with GitHub" | ||||
|   signin-with-discord: "Login with Discord" | ||||
|   signin-with-github: "Sign in with GitHub" | ||||
|   signin-with-discord: "Sign in with Discord" | ||||
|   login-failed: "Log in failed. Make sure you have entered your correct username and password." | ||||
| common/views/components/signup.vue: | ||||
|   invitation-code: "Invitation code" | ||||
| @@ -399,13 +403,11 @@ common/views/components/stream-indicator.vue: | ||||
|   connecting: "Connecting" | ||||
|   reconnecting: "Reconnecting" | ||||
|   connected: "Connected" | ||||
| common/views/components/twitter-setting.vue: | ||||
|   description: "Once you connect your Twitter account to your Misskey account, you will be able to see information about your Twitter account on your profile, and you will be able to sign-in using Twitter." | ||||
|   connected-to: "You are connected to this Twitter account" | ||||
|   detail: "Details..." | ||||
|   reconnect: "Reconnect" | ||||
|   connect: "Link your Twitter account" | ||||
| common/views/components/integration-settings.vue: | ||||
|   title: "Service cooperation" | ||||
|   connect: "Connect" | ||||
|   disconnect: "Disconnect" | ||||
|   connected-to: "You are connected to next account" | ||||
| common/views/components/github-setting.vue: | ||||
|   description: "Once you connect your GitHub account to your Misskey account, you will be able to see information about your GitHub account on your profile, and you will be able to sign-in via GitHub." | ||||
|   connected-to: "You are connected to this GitHub account" | ||||
| @@ -433,32 +435,44 @@ common/views/components/visibility-chooser.vue: | ||||
|   private: "Private" | ||||
|   local-public: "Local (Public)" | ||||
|   local-public-desc: "Do not publish to remote" | ||||
|   local-home: "Local (Home)" | ||||
|   local-followers: "Local (Followers)" | ||||
|   local-home: "Home (Only local)" | ||||
|   local-followers: "Followers (Only local)" | ||||
| common/views/components/trends.vue: | ||||
|   count: "{} users mentioned" | ||||
|   empty: "No popular hashtag trends" | ||||
| common/views/components/language-settings.vue: | ||||
|   title: "Display Language" | ||||
|   pick-language: "Select a language" | ||||
|   recommended: "Recommended" | ||||
|   auto: "Auto" | ||||
|   specify-language: "Specify language" | ||||
|   info: "You need to reload the page for the changes to take effect." | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "Profile" | ||||
|   name: "Name" | ||||
|   account: "Account" | ||||
|   location: "Location" | ||||
|   description: "About me" | ||||
|   language: "Language" | ||||
|   birthday: "Birthday" | ||||
|   avatar: "Avatar" | ||||
|   avatar: "Icon" | ||||
|   banner: "Banner" | ||||
|   is-cat: "This account is a Cat" | ||||
|   is-bot: "This account is a Bot" | ||||
|   is-locked: "Follower requests require approval" | ||||
|   careful-bot: "Follower requests from bots require approval" | ||||
|   advanced: "Advanced" | ||||
|   advanced: "Other" | ||||
|   privacy: "Privacy" | ||||
|   save: "Update profile" | ||||
|   save: "Save" | ||||
|   saved: "Profile updated successfully" | ||||
|   uploading: "Uploading" | ||||
|   upload-failed: "Failed to upload" | ||||
|   email: "Email settings" | ||||
|   email-address: "Email Address" | ||||
|   email-verified: "Your email has been verified." | ||||
|   email-not-verified: "Email address is not confirmed. Please check your inbox." | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "Fetching" | ||||
|   fetching: "Checking" | ||||
|   no-broadcasts: "No announcements" | ||||
|   have-a-nice-day: "Have a nice day!" | ||||
|   next: "Next" | ||||
| @@ -469,9 +483,6 @@ common/views/widgets/calendar.vue: | ||||
|   today: "Today: " | ||||
|   this-month: "This month: " | ||||
|   this-year: "This year: " | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "Request for donations" | ||||
|   text: "To keep Misskey up and running, there have to happen some expense for the domain name, the server and so on. Since our policy is not to display any advertisements, we count on your donations. If you're interested in helping, contact {}. Thank you for your contribution!" | ||||
| common/views/widgets/photo-stream.vue: | ||||
|   title: "Photo stream" | ||||
|   no-photos: "No photos" | ||||
| @@ -512,6 +523,8 @@ common/views/widgets/tips.vue: | ||||
|   tips-line23: "Mayu is so cute with its eyebrows." | ||||
|   tips-line24: "Misskey has been running since 2014." | ||||
|   tips-line25: "In a browser compatible with notification features, you can receive notifications in case Misskey is not open" | ||||
| common/views/pages/404.vue: | ||||
|   page-not-found: "Page not found" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "Signed in as {}" | ||||
|   following: "Following" | ||||
| @@ -731,6 +744,8 @@ desktop/views/components/settings.vue: | ||||
|   note-visibility: "Post visibility" | ||||
|   default-note-visibility: "Default visibility" | ||||
|   remember-note-visibility: "Remember post visibility" | ||||
|   web-search-engine: "Web search engine" | ||||
|   web-search-engine-desc: "Example: https://www.google.com/?#q={{query}}" | ||||
|   auto-popout: "Auto pop-out window" | ||||
|   auto-popout-desc: "If it's possible, pop-out display will be used instead of opening a new window. This setting is stored in your browser." | ||||
|   advanced: "Advanced settings" | ||||
| @@ -750,7 +765,6 @@ desktop/views/components/settings.vue: | ||||
|   circle-icons: "Use circle icons" | ||||
|   contrasted-acct: "Add contrast to username" | ||||
|   post-form-on-timeline: "Display post form at the top of the timeline" | ||||
|   suggest-recent-hashtags: "Show recent popular hashtags on the post form" | ||||
|   show-clock-on-header: "Show clock on upper-right" | ||||
|   show-reply-target: "Display reply target" | ||||
|   timeline: "Timeline" | ||||
| @@ -762,17 +776,18 @@ desktop/views/components/settings.vue: | ||||
|   deck-column-align: "Deck column alignment" | ||||
|   deck-column-align-center: "Center" | ||||
|   deck-column-align-left: "Left" | ||||
|   deck-column-align-flexible: "Flexible" | ||||
|   deck-column-width: "Column width of the deck" | ||||
|   deck-column-width-narrow: "narrow" | ||||
|   deck-column-width-narrower: "somewhat narrow" | ||||
|   deck-column-width-normal: "Normal" | ||||
|   deck-column-width-wider: "somewhat wide" | ||||
|   deck-column-width-wide: "wide" | ||||
|   sound: "Sound" | ||||
|   enable-sounds: "Enable sound" | ||||
|   enable-sounds-desc: "Play a sound when you receive a post/message. This setting is stored in the browser." | ||||
|   volume: "Volume" | ||||
|   test: "Test" | ||||
|   language: "Language" | ||||
|   pick-language: "Select a language" | ||||
|   recommended: "Recommended" | ||||
|   auto: "Automatic" | ||||
|   specify-language: "Specify language" | ||||
|   language-desc: "You need to reload the page for the changes to take effect." | ||||
|   cache: "Cache" | ||||
|   clean-cache: "Clear cache" | ||||
|   cache-warn: "The cache of account info/posts/replies/messages/settings stored in the browser will be deleted. You need to reload the page after cleaning up." | ||||
| @@ -862,11 +877,17 @@ common/views/components/password-settings.vue: | ||||
|   enter-new-password-again: "Enter the new password again" | ||||
|   not-match: "The new passwords do not match" | ||||
|   changed: "Password changed" | ||||
|   failed: "Failed to change password" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "This post is private" | ||||
|   deleted: "This post has been deleted" | ||||
|   media-count: "{} media attached" | ||||
|   poll: "Poll" | ||||
| desktop/views/components/settings.tags.vue: | ||||
|   title: "Tags" | ||||
|   query: "Query (optional)" | ||||
|   add: "Add" | ||||
|   save: "Save" | ||||
| desktop/views/components/taskmanager.vue: | ||||
|   title: "Task Manager" | ||||
| desktop/views/components/timeline.vue: | ||||
| @@ -949,6 +970,7 @@ admin/views/instance.vue: | ||||
|   instance-description: "Instance description" | ||||
|   host: "Host" | ||||
|   banner-url: "Banner image URL" | ||||
|   error-image-url: "Error image URL" | ||||
|   languages: "Language of this instance" | ||||
|   languages-desc: "You can add more than one, separated by spaces." | ||||
|   maintainer-config: "Administrator information" | ||||
| @@ -966,17 +988,17 @@ admin/views/instance.vue: | ||||
|   recaptcha-site-key: "reCAPTCHA site key" | ||||
|   recaptcha-secret-key: "reCAPTCHA secret key" | ||||
|   twitter-integration-config: "Settings of connecting to Twitter" | ||||
|   twitter-integration-info: "The callback URL is set on /api/tw/cb." | ||||
|   twitter-integration-info: "The callback URL is set on {url}." | ||||
|   enable-twitter-integration: "Enable connection to Twitter" | ||||
|   twitter-integration-consumer-key: "Consumer key" | ||||
|   twitter-integration-consumer-secret: "Consumer Secret" | ||||
|   github-integration-config: "Setting of connecting to GitHub" | ||||
|   github-integration-info: "The callback URL is set on /api/gh/cb." | ||||
|   github-integration-info: "The callback URL is set on {url}." | ||||
|   enable-github-integration: "Enable connection to GitHub" | ||||
|   github-integration-client-id: "Client ID" | ||||
|   github-integration-client-secret: "Client Secret" | ||||
|   discord-integration-config: "Setting of Discord Integration" | ||||
|   discord-integration-info: "The callback URL is set on /api/dc/cb." | ||||
|   discord-integration-info: "The callback URL is set on {url}." | ||||
|   enable-discord-integration: "Enable Discord connection" | ||||
|   discord-integration-client-id: "Client ID" | ||||
|   discord-integration-client-secret: "Client Secret" | ||||
| @@ -991,6 +1013,22 @@ admin/views/instance.vue: | ||||
|   invite: "Invite" | ||||
|   save: "Save" | ||||
|   saved: "Saved" | ||||
|   user-recommendation-config: "Recommended users" | ||||
|   enable-external-user-recommendation: "Enable to external user recommendation" | ||||
|   external-user-recommendation-engine: "Engine" | ||||
|   external-user-recommendation-engine-desc: "Example : https://vinayaka.distsn.org/cgi-bin/vinayaka-user-match-misskey-api.cgi?{{host}}+{{user}}+{{limit}}+{{offset}}" | ||||
|   external-user-recommendation-timeout: "Timeout" | ||||
|   external-user-recommendation-timeout-desc: "Number of milliseconds (ex. 300,000)" | ||||
|   email-config: "Email server settings" | ||||
|   email-config-info: "Used to confirm email and password reset etc." | ||||
|   enable-email: "Enable email delivery" | ||||
|   email: "Email Address" | ||||
|   smtp-secure: "Use implicit SSL/TLS in the SMTP connection" | ||||
|   smtp-secure-info: "Turn off STARTTLS when used that." | ||||
|   smtp-host: "SMTP Host" | ||||
|   smtp-port: "SMTP Port" | ||||
|   smtp-user: "SMTP User" | ||||
|   smtp-pass: "SMTP Password" | ||||
| admin/views/charts.vue: | ||||
|   title: "Chart" | ||||
|   per-day: "per Day" | ||||
| @@ -1016,19 +1054,50 @@ admin/views/charts.vue: | ||||
|     network-requests: "Requests" | ||||
|     network-time: "Response time" | ||||
|     network-usage: "Traffic" | ||||
| admin/views/drive.vue: | ||||
|   sort: | ||||
|     title: "Sort" | ||||
|     createdAtAsc: "アップロード日時が古い順" | ||||
|     createdAtDesc: "アップロード日時が新しい順" | ||||
|     sizeAsc: "サイズが小さい順" | ||||
|     sizeDesc: "サイズが大きい順" | ||||
|   origin: | ||||
|     title: "Origin" | ||||
|     combined: "Local + Remote" | ||||
|     local: "Local" | ||||
|     remote: "Remote" | ||||
|   delete: "Delete" | ||||
|   deleted: "Deleted successfully" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "Suspend a user" | ||||
|   operation: "Operations" | ||||
|   username-or-userid: "Username or user ID" | ||||
|   user-not-found: "User not found" | ||||
|   lookup: "Look up" | ||||
|   reset-password: "Reset password" | ||||
|   password-updated: "The password is now \"{password}\"" | ||||
|   suspend: "Suspend" | ||||
|   suspended: "Successfully suspended." | ||||
|   unsuspend-user: "Unsuspend users" | ||||
|   unsuspend: "Unsuspend" | ||||
|   unsuspended: "The user has successfully unsuspended." | ||||
|   verify-user: "User account verification settings" | ||||
|   verify: "Verify account" | ||||
|   verified: "The account is now being verified" | ||||
|   unverify-user: "User account unverification settings" | ||||
|   unverify: "Unverify account" | ||||
|   unverified: "The account is now being unverified" | ||||
|   users: | ||||
|     title: "Users" | ||||
|     sort: | ||||
|       title: "Sort" | ||||
|       createdAtAsc: "Date Registered (Ascending)" | ||||
|       createdAtDesc: "Date Registered (Descending)" | ||||
|       updatedAtAsc: "Last Updated (Ascending)" | ||||
|       updatedAtDesc: "Last Updated (Descending)" | ||||
|     origin: | ||||
|       title: "Origin" | ||||
|       combined: "Local + Remote" | ||||
|       local: "Local" | ||||
|       remote: "Remote" | ||||
|     createdAt: "Created at" | ||||
|     updatedAt: "Updated at" | ||||
| admin/views/moderators.vue: | ||||
|   add-moderator: | ||||
|     title: "Register Moderator" | ||||
| @@ -1051,7 +1120,7 @@ admin/views/emoji.vue: | ||||
|     remove: "Remove" | ||||
|   updated: "Updated" | ||||
|   remove-emoji: | ||||
|     are-you-sure: "Delete \"%1$s\"?" | ||||
|     are-you-sure: "Delete \"$1\"?" | ||||
|     removed: "Deleted" | ||||
| admin/views/announcements.vue: | ||||
|   announcements: "Announcements" | ||||
| @@ -1062,7 +1131,7 @@ admin/views/announcements.vue: | ||||
|   text: "Content" | ||||
|   saved: "Saved" | ||||
|   _remove: | ||||
|     are-you-sure: "Delete \"%1$s\"?" | ||||
|     are-you-sure: "Delete \"$1\"?" | ||||
|     removed: "Deleted" | ||||
| admin/views/hashtags.vue: | ||||
|   hided-tags: "Hidden Tags" | ||||
| @@ -1321,11 +1390,6 @@ mobile/views/pages/selectdrive.vue: | ||||
|   select-file: "Choose files" | ||||
| mobile/views/pages/settings.vue: | ||||
|   signed-in-as: "Signed in as {}" | ||||
|   lang: "Language" | ||||
|   lang-tip: "You will need to reload the page for the changes to take effect." | ||||
|   recommended: "Recommended" | ||||
|   auto: "Auto" | ||||
|   specify-language: "Select your language" | ||||
|   design: "Design and display" | ||||
|   dark-mode: "Dark Mode" | ||||
|   i-am-under-limited-internet: "I'm in limited bandwidth" | ||||
| @@ -1348,21 +1412,11 @@ mobile/views/pages/settings.vue: | ||||
|   note-visibility: "Post visibility" | ||||
|   default-note-visibility: "Default visibility" | ||||
|   remember-note-visibility: "Remember post visibility" | ||||
|   web-search-engine: "Web search engine" | ||||
|   web-search-engine-desc: "Example: https://www.google.com/?#q={{query}}" | ||||
|   disable-via-mobile: "Don't mark the post as 'from mobile'" | ||||
|   load-raw-images: "Show attached images in original quality" | ||||
|   load-remote-media: "Show media from a remote server" | ||||
|   twitter: "Twitter integration" | ||||
|   twitter-connect: "Connect to your Twitter account" | ||||
|   twitter-reconnect: "Reconnect" | ||||
|   twitter-disconnect: "Disconnect" | ||||
|   github: "GitHub Integration" | ||||
|   github-connect: "Connect to your GitHub account" | ||||
|   github-reconnect: "Reconnect" | ||||
|   github-disconnect: "Disconnect" | ||||
|   discord: "Discord Integration" | ||||
|   discord-connect: "Connect to your Discord account" | ||||
|   discord-reconnect: "Reconnect" | ||||
|   discord-disconnect: "Disconnect" | ||||
|   update: "Misskey Update" | ||||
|   version: "Current version:" | ||||
|   latest-version: "Latest version:" | ||||
| @@ -1392,6 +1446,9 @@ mobile/views/pages/user.vue: | ||||
|   block: "Block" | ||||
|   unblock: "Unblock" | ||||
|   years-old: "{age} years old" | ||||
|   push-to-list: "Add to list" | ||||
|   select-list: "Select a list" | ||||
|   list-pushed: "Successfully added {user} to {list}." | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "Recent notes" | ||||
|   images: "Images" | ||||
|   | ||||
| @@ -26,6 +26,7 @@ common: | ||||
|   close: "Cerrar" | ||||
|   do-not-copy-paste: "Por favor no copies código aquí. Tu cuenta puede resultar comprometida." | ||||
|   load-more: "もっと読み込む" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   got-it: "¡Listo!" | ||||
|   customization-tips: | ||||
|     title: "Consejos de personalización" | ||||
| @@ -109,9 +110,10 @@ common: | ||||
|   my-token-regenerated: "Tu token se ha regenerado vas a ser desconectado." | ||||
|   i-like-sushi: "Prefiero sushi a pudín" | ||||
|   show-reversi-board-labels: "Mostrar etiquetas de filas y columnas en Reversi" | ||||
|   use-contrast-reversi-stones: "Hacer el color de la piedra claro en Reversi" | ||||
|   use-white-black-reversi-stones: "リバーシに白黒の石を使う" | ||||
|   verified-user: "Cuenta verificada" | ||||
|   disable-animated-mfm: "Desactivar texto animado en una publicación" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   show-full-acct: "ユーザー名のホストを省略しない" | ||||
| @@ -157,12 +159,12 @@ common: | ||||
|     polls: "Encuestas" | ||||
|     post-form: "Formulario" | ||||
|     server: "Información del servidor" | ||||
|     donation: "Donaciones" | ||||
|     nav: "Navegación" | ||||
|     tips: "Consejos" | ||||
|     hashtags: "Etiquetas" | ||||
|   dev: "アプリの作成に失敗しました。再度お試しください。" | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
|   you: "あなた" | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{name}</i>があなたのアカウントにアクセスすることを許可しますか?" | ||||
|   permission-ask: "La aplicación requiere los siguientes permisos:" | ||||
| @@ -295,6 +297,8 @@ common/views/components/theme.vue: | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "隠す" | ||||
|   show: "もっと見る" | ||||
|   chars: "{count}文字" | ||||
|   files: "{count}ファイル" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "Encuentra un usuario" | ||||
|   you: "Tu" | ||||
| @@ -399,13 +403,11 @@ common/views/components/stream-indicator.vue: | ||||
|   connecting: "Conectando" | ||||
|   reconnecting: "Reconectando" | ||||
|   connected: "Conectado" | ||||
| common/views/components/twitter-setting.vue: | ||||
|   description: "Si comectas tu cuenta de Twitter con tu cuenta de Misskey podrás ver la información de tu cuemta de Twitter en tu perfil y además podrás entrar usando Twitter." | ||||
|   connected-to: "Estas comectado con las siguientes cuentas de Twitter" | ||||
|   detail: "Detalles..." | ||||
|   reconnect: "Conectar de nuevo" | ||||
|   connect: "Conectate usando Twitter" | ||||
|   disconnect: "Desconectado" | ||||
| common/views/components/integration-settings.vue: | ||||
|   title: "サービス連携" | ||||
|   connect: "接続する" | ||||
|   disconnect: "切断する" | ||||
|   connected-to: "次のアカウントに接続されています" | ||||
| common/views/components/github-setting.vue: | ||||
|   description: "お使いのGitHubアカウントをお使いのMisskeyアカウントに接続しておくと、プロフィールでGitHubアカウント情報が表示されるようになったり、GitHubを用いた便利なサインインを利用できるようになります。" | ||||
|   connected-to: "次のGitHubアカウントに接続されています" | ||||
| @@ -438,12 +440,20 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/components/language-settings.vue: | ||||
|   title: "表示言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語を指定" | ||||
|   info: "変更はページの再度読み込み後に反映されます。" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   language: "言語" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
| @@ -457,6 +467,10 @@ common/views/components/profile-editor.vue: | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
|   email: "メール設定" | ||||
|   email-address: "メールアドレス" | ||||
|   email-verified: "メールアドレスが確認されました" | ||||
|   email-not-verified: "メールアドレスが確認されていません。メールボックスをご確認ください。" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "Recuperando" | ||||
|   no-broadcasts: "Sin emisión" | ||||
| @@ -469,9 +483,6 @@ common/views/widgets/calendar.vue: | ||||
|   today: "Hoy:" | ||||
|   this-month: "Este mes:" | ||||
|   this-year: "Este año:" | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "Donaciones" | ||||
|   text: "Para mantener Misskey funcionando tenemos que pagar por el dominio, los costos de hospedaje y otros costos. Como no recibimos dinero de publicidad, contamos con el apoyo de todos ustedes. Si estás interesado en ayudar, contacta a {}. ¡Muchas gracias por tu contribución!" | ||||
| common/views/widgets/photo-stream.vue: | ||||
|   title: "Galería de fotos" | ||||
|   no-photos: "No hay fotos." | ||||
| @@ -512,6 +523,8 @@ common/views/widgets/tips.vue: | ||||
|   tips-line23: "Mayu is tan bonito con sus cejas." | ||||
|   tips-line24: "Misskey inició en 2014." | ||||
|   tips-line25: "Puedes recibir notificaciones incluso si Misskey no está abierto en un navegador compatible." | ||||
| common/views/pages/404.vue: | ||||
|   page-not-found: "ページが見つかりませんでした" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "Autenticado como {}" | ||||
|   following: "Siguiendo" | ||||
| @@ -731,6 +744,8 @@ desktop/views/components/settings.vue: | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   web-search-engine: "ウェブ検索エンジン" | ||||
|   web-search-engine-desc: "例: https://www.google.com/?#q={{query}}" | ||||
|   auto-popout: "Ventana emergente automática" | ||||
|   auto-popout-desc: "Muestra una ventana emergente si es posible. Esta configuración depende del navegador." | ||||
|   advanced: "Configuración avanzada" | ||||
| @@ -750,7 +765,6 @@ desktop/views/components/settings.vue: | ||||
|   circle-icons: "Usar iconos circulares" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   post-form-on-timeline: "Mostrar el formulario de las entradas encima de la línea de tiempo" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   timeline: "タイムライン" | ||||
| @@ -759,20 +773,21 @@ desktop/views/components/settings.vue: | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   remain-deleted-note: "削除された投稿を表示し続ける" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align: "デッキのカラムの配置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   deck-column-align-flexible: "フレキシブル" | ||||
|   deck-column-width: "デッキのカラムの幅" | ||||
|   deck-column-width-narrow: "狭" | ||||
|   deck-column-width-narrower: "やや狭" | ||||
|   deck-column-width-normal: "普通" | ||||
|   deck-column-width-wider: "やや広" | ||||
|   deck-column-width-wide: "広" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||
|   volume: "ボリューム" | ||||
|   test: "テスト" | ||||
|   language: "言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語を指定" | ||||
|   language-desc: "変更はページの再度読み込み後に反映されます。" | ||||
|   cache: "キャッシュ" | ||||
|   clean-cache: "クリーンアップ" | ||||
|   cache-warn: "クリーンアップを行うと、ブラウザに記憶されたアカウント情報のキャッシュ、書きかけの投稿・返信・メッセージ、およびその他のデータ(設定情報含む)が削除されます。クリーンアップを行った後はページを再度読み込みする必要があります。" | ||||
| @@ -862,11 +877,17 @@ common/views/components/password-settings.vue: | ||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||
|   not-match: "新しいパスワードが一致しません" | ||||
|   changed: "パスワードを変更しました" | ||||
|   failed: "パスワード変更に失敗しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   media-count: "{}つのメディア" | ||||
|   poll: "アンケート" | ||||
| desktop/views/components/settings.tags.vue: | ||||
|   title: "タグ" | ||||
|   query: "クエリ (省略可)" | ||||
|   add: "追加" | ||||
|   save: "保存" | ||||
| desktop/views/components/taskmanager.vue: | ||||
|   title: "タスクマネージャ" | ||||
| desktop/views/components/timeline.vue: | ||||
| @@ -949,6 +970,7 @@ admin/views/instance.vue: | ||||
|   instance-description: "インスタンスの紹介" | ||||
|   host: "ホスト" | ||||
|   banner-url: "バナー画像URL" | ||||
|   error-image-url: "エラー画像URL" | ||||
|   languages: "インスタンスの対象言語" | ||||
|   languages-desc: "スペースで区切って複数設定できます。" | ||||
|   maintainer-config: "管理者情報" | ||||
| @@ -966,17 +988,17 @@ admin/views/instance.vue: | ||||
|   recaptcha-site-key: "reCAPTCHA site key" | ||||
|   recaptcha-secret-key: "reCAPTCHA secret key" | ||||
|   twitter-integration-config: "Twitter連携の設定" | ||||
|   twitter-integration-info: "コールバックURLは /api/tw/cb に設定します。" | ||||
|   twitter-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-twitter-integration: "Twitter連携を有効にする" | ||||
|   twitter-integration-consumer-key: "Consumer key" | ||||
|   twitter-integration-consumer-secret: "Consumer secret" | ||||
|   github-integration-config: "GitHub連携の設定" | ||||
|   github-integration-info: "コールバックURLは /api/gh/cb に設定します。" | ||||
|   github-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-github-integration: "GitHub連携を有効にする" | ||||
|   github-integration-client-id: "Client ID" | ||||
|   github-integration-client-secret: "Client Secret" | ||||
|   discord-integration-config: "Discord連携の設定" | ||||
|   discord-integration-info: "コールバックURLは /api/dc/cb に設定します。" | ||||
|   discord-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-discord-integration: "Discord連携を有効にする" | ||||
|   discord-integration-client-id: "Client ID" | ||||
|   discord-integration-client-secret: "Client Secret" | ||||
| @@ -991,6 +1013,22 @@ admin/views/instance.vue: | ||||
|   invite: "招待" | ||||
|   save: "保存" | ||||
|   saved: "保存しました" | ||||
|   user-recommendation-config: "おすすめユーザー" | ||||
|   enable-external-user-recommendation: "外部ユーザーレコメンデーションを有効にする" | ||||
|   external-user-recommendation-engine: "エンジン" | ||||
|   external-user-recommendation-engine-desc: "例: https://vinayaka.distsn.org/cgi-bin/vinayaka-user-match-misskey-api.cgi?{{host}}+{{user}}+{{limit}}+{{offset}}" | ||||
|   external-user-recommendation-timeout: "タイムアウト" | ||||
|   external-user-recommendation-timeout-desc: "ミリ秒単位 (例: 300000)" | ||||
|   email-config: "メールサーバーの設定" | ||||
|   email-config-info: "メールアドレス確認やパスワードリセットの際に使われます。" | ||||
|   enable-email: "メール配信を有効にする" | ||||
|   email: "メールアドレス" | ||||
|   smtp-secure: "SMTP接続に暗黙的なSSL/TLSを使用する" | ||||
|   smtp-secure-info: "STARTTLS使用時はオフにします。" | ||||
|   smtp-host: "SMTPホスト" | ||||
|   smtp-port: "SMTPポート" | ||||
|   smtp-user: "SMTPユーザー" | ||||
|   smtp-pass: "SMTPパスワード" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
| @@ -1016,19 +1054,50 @@ admin/views/charts.vue: | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| admin/views/drive.vue: | ||||
|   sort: | ||||
|     title: "ソート" | ||||
|     createdAtAsc: "アップロード日時が古い順" | ||||
|     createdAtDesc: "アップロード日時が新しい順" | ||||
|     sizeAsc: "サイズが小さい順" | ||||
|     sizeDesc: "サイズが大きい順" | ||||
|   origin: | ||||
|     title: "オリジン" | ||||
|     combined: "ローカル+リモート" | ||||
|     local: "ローカル" | ||||
|     remote: "リモート" | ||||
|   delete: "削除" | ||||
|   deleted: "削除しました" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   operation: "操作" | ||||
|   username-or-userid: "ユーザー名またはユーザーID" | ||||
|   user-not-found: "ユーザーが見つかりません" | ||||
|   lookup: "照会" | ||||
|   reset-password: "パスワードをリセット" | ||||
|   password-updated: "パスワードは現在「{password}」です" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|   users: | ||||
|     title: "ユーザー" | ||||
|     sort: | ||||
|       title: "ソート" | ||||
|       createdAtAsc: "登録日時が古い順" | ||||
|       createdAtDesc: "登録日時が新しい順" | ||||
|       updatedAtAsc: "更新日時が古い順" | ||||
|       updatedAtDesc: "更新日時が新しい順" | ||||
|     origin: | ||||
|       title: "オリジン" | ||||
|       combined: "ローカル+リモート" | ||||
|       local: "ローカル" | ||||
|       remote: "リモート" | ||||
|     createdAt: "登録日時" | ||||
|     updatedAt: "更新日時" | ||||
| admin/views/moderators.vue: | ||||
|   add-moderator: | ||||
|     title: "モデレーターの登録" | ||||
| @@ -1321,11 +1390,6 @@ mobile/views/pages/selectdrive.vue: | ||||
|   select-file: "ファイルを選択" | ||||
| mobile/views/pages/settings.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   lang: "言語" | ||||
|   lang-tip: "変更はページの再読み込み後に反映されます。" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語を指定" | ||||
|   design: "デザインと表示" | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
| @@ -1348,21 +1412,11 @@ mobile/views/pages/settings.vue: | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   web-search-engine: "ウェブ検索エンジン" | ||||
|   web-search-engine-desc: "例: https://www.google.com/?#q={{query}}" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   load-raw-images: "添付された画像を高画質で表示する" | ||||
|   load-remote-media: "リモートサーバーのメディアを表示する" | ||||
|   twitter: "Twitter連携" | ||||
|   twitter-connect: "Twitterアカウントに接続する" | ||||
|   twitter-reconnect: "再接続する" | ||||
|   twitter-disconnect: "切断する" | ||||
|   github: "GitHub連携" | ||||
|   github-connect: "GitHubアカウントに接続する" | ||||
|   github-reconnect: "再接続する" | ||||
|   github-disconnect: "切断する" | ||||
|   discord: "Discord連携" | ||||
|   discord-connect: "Discordアカウントに接続する" | ||||
|   discord-reconnect: "再接続する" | ||||
|   discord-disconnect: "切断する" | ||||
|   update: "Misskey Update" | ||||
|   version: "バージョン:" | ||||
|   latest-version: "最新のバージョン:" | ||||
| @@ -1392,6 +1446,9 @@ mobile/views/pages/user.vue: | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
|   years-old: "{age}歳" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "最近の投稿" | ||||
|   images: "画像" | ||||
|   | ||||
| @@ -18,7 +18,7 @@ common: | ||||
|     ui-desc: "どのようなUIが使いやすいかは人それぞれです。だから、Misskeyは自由度の高いUIを持っています。レイアウトやデザインを調整したり、カスタマイズ可能な様々なウィジェットを配置したりして、自分だけのホームを作ってください。" | ||||
|     drive: "Drive" | ||||
|     drive-desc: "以前投稿したことのある画像をまた投稿したくなったことはありませんか?もしくは、アップロードしたファイルをフォルダ分けして整理したくなったことはありませんか?Misskeyの根幹に組み込まれたドライブ機能によってそれらが解決します。ファイルの共有も簡単です。" | ||||
|     outro: "他にもMisskeyにしかない機能はまだまだあるので、ぜひあなた自身の目で確かめてください。Misskeyは分散型SNSなので、このインスタンスが気に入らなければ他のインスタンスを試すこともできます。それでは、GLHF!" | ||||
|     outro: "Découvrez vous-même les fonctionnalités de Misskey. Étant donné que Misskey est un réseaux social fédéré, vous pouvez essayer d’autres instances afin de trouver vos ami·e·s si la présente instance ne vous correspond pas. Bonne chance et amusez-vous bien !" | ||||
|   adblock: | ||||
|     detected: "Veuillez désactiver votre bloqueur de publicités" | ||||
|     warning: "<strong>Misskey n’utilise pas de publicités</strong>, mais quelques options peuvent être non disponibles ou fonctionneraient mal si un bloqueur de publicités est activé." | ||||
| @@ -26,6 +26,7 @@ common: | ||||
|   close: "Fermer" | ||||
|   do-not-copy-paste: "Veuillez ne pas entrer ou coller le code ici. Le compte peut être compromis." | ||||
|   load-more: "Charger plus" | ||||
|   enter-password: "Veuillez entrer le mot de passe" | ||||
|   got-it: "J’ai compris !" | ||||
|   customization-tips: | ||||
|     title: "Conseils de personnalisation" | ||||
| @@ -46,11 +47,11 @@ common: | ||||
|     seconds_ago: "Il y a {} seconde·s" | ||||
|     minutes_ago: "Il y a {} min" | ||||
|     hours_ago: "Il y a {} h" | ||||
|     days_ago: "Il y a {} jours" | ||||
|     weeks_ago: "Il y a {} semaines·s" | ||||
|     days_ago: "Il y a {} j" | ||||
|     weeks_ago: "Il y a {} semaines" | ||||
|     months_ago: "Il y a {} mois" | ||||
|     years_ago: "Il y a {} an·s" | ||||
|   month-and-day: "{day}/{month}" | ||||
|   month-and-day: "{day}-{month}" | ||||
|   trash: "Corbeille" | ||||
|   drive: "Drive" | ||||
|   messaging: "Conversations" | ||||
| @@ -109,9 +110,10 @@ common: | ||||
|   my-token-regenerated: "Votre jeton vient d’être généré, vous allez maintenant être déconnecté." | ||||
|   i-like-sushi: "Je préfère les sushis plutôt que le pudding" | ||||
|   show-reversi-board-labels: "Afficher les étiquettes des lignes et colonnes dans Reversi" | ||||
|   use-contrast-reversi-stones: "Icône avec contraste sur Reversi" | ||||
|   use-white-black-reversi-stones: "Jouer avec des pions noirs et blancs sur Reversi" | ||||
|   verified-user: "Compte vérifié" | ||||
|   disable-animated-mfm: "Désactiver les textes animés dans les publications" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "Toujours afficher les contenus sensibles" | ||||
|   always-mark-nsfw: "Toujours marquer les notes ayant des attachements comme sensibles" | ||||
|   show-full-acct: "Afficher l’adresse complète de l’utilisateur" | ||||
| @@ -123,7 +125,7 @@ common: | ||||
|   is-remote-user: "Ces informations appartiennent à un·e utilisateur·rice distant·e." | ||||
|   is-remote-post: "Ceci est une publication distante." | ||||
|   view-on-remote: " Consulter le profil complet" | ||||
|   renoted-by: "{user}がRenote" | ||||
|   renoted-by: "Renoté par {user}" | ||||
|   error: | ||||
|     title: 'Une erreur est survenue' | ||||
|     retry: 'Réessayer' | ||||
| @@ -157,12 +159,12 @@ common: | ||||
|     polls: "Sondages" | ||||
|     post-form: "Champs de publication" | ||||
|     server: "Info sur le serveur" | ||||
|     donation: "Dons" | ||||
|     nav: "Navigation" | ||||
|     tips: "Conseils" | ||||
|     hashtags: "Hashtags" | ||||
|   dev: "Échec lors de la création de l’application. Veuillez réessayer." | ||||
|   ai-chan-kawaii: "Ai-Chan est mignonne !" | ||||
|   you: "Vous" | ||||
| auth/views/form.vue: | ||||
|   share-access: "Désirez-vous autoriser <i>{name}</i> à avoir accès à votre compte ?" | ||||
|   permission-ask: "Cette application nécessite les autorisations suivantes :" | ||||
| @@ -295,6 +297,8 @@ common/views/components/theme.vue: | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "Masquer" | ||||
|   show: "Voir plus" | ||||
|   chars: "{count} caractères" | ||||
|   files: "{count} fichiers" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "Trouver un·e utilisateur·trice" | ||||
|   you: "Vous" | ||||
| @@ -399,13 +403,11 @@ common/views/components/stream-indicator.vue: | ||||
|   connecting: "Connexion en cours" | ||||
|   reconnecting: "Reconnexion en cours" | ||||
|   connected: "Connecté" | ||||
| common/views/components/twitter-setting.vue: | ||||
|   description: "Si vous liez votre compte Twitter à votre compte Misskey, vous verrez ensuite votre compte Twitter s'afficher sur votre profil, vous aurez aussi la possibilité de vous connecter à Misskey en utilisant votre compte Twitter." | ||||
|   connected-to: "Vous êtes connecté à ce compte Twitter" | ||||
|   detail: "Détails…" | ||||
|   reconnect: "Reconnexion" | ||||
|   connect: "Lier votre compte Twitter" | ||||
|   disconnect: "Déconnexion" | ||||
| common/views/components/integration-settings.vue: | ||||
|   title: "Intégrations" | ||||
|   connect: "Connecter" | ||||
|   disconnect: "Déconnecter" | ||||
|   connected-to: "Vous êtes connectés aux services suivants" | ||||
| common/views/components/github-setting.vue: | ||||
|   description: "Si vous liez votre compte GitHub à votre compte Misskey, vous verrez votre compte GitHub s’afficher sur votre profil, vous aurez également la possibilité de vous connecter à Misskey en utilisant ce dernier." | ||||
|   connected-to: "Vous êtes connecté à votre compte GitHub" | ||||
| @@ -432,18 +434,26 @@ common/views/components/visibility-chooser.vue: | ||||
|   specified-desc: "Publier uniquement aux utilisateurs·rices mentionné·e·s" | ||||
|   private: "Privé" | ||||
|   local-public: "Local (Public)" | ||||
|   local-public-desc: "リモートへは公開しない" | ||||
|   local-public-desc: "Ne pas publier pour les distants" | ||||
|   local-home: "Accueil (local uniquement)" | ||||
|   local-followers: "Local (Abonnés)" | ||||
| common/views/components/trends.vue: | ||||
|   count: "{} utilisateurs·rices mentionnés·es" | ||||
|   empty: "Aucune tendance" | ||||
| common/views/components/language-settings.vue: | ||||
|   title: "Langue " | ||||
|   pick-language: "Sélectionner une langue" | ||||
|   recommended: "Recommandé" | ||||
|   auto: "Automatique" | ||||
|   specify-language: "Spécifier la langue" | ||||
|   info: "Le rechargement de la page est requis afin d'appliquer les modifications." | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "Profil" | ||||
|   name: "Nom" | ||||
|   account: "Compte" | ||||
|   location: "Lieu" | ||||
|   description: "À propos de moi" | ||||
|   language: "Langue" | ||||
|   birthday: "Date de naissance" | ||||
|   avatar: "Avatar" | ||||
|   banner: "Bannière" | ||||
| @@ -457,6 +467,10 @@ common/views/components/profile-editor.vue: | ||||
|   saved: "Profil mis à jour avec succès" | ||||
|   uploading: "En cours d'envoi …" | ||||
|   upload-failed: "Échec de l'envoi" | ||||
|   email: "Paramètres de messagerie" | ||||
|   email-address: "Adresse de courrier électronique" | ||||
|   email-verified: "L’adresse du courrier électronique a été vérifiée." | ||||
|   email-not-verified: "Adresse de courriel n’est pas confirmée. Veuillez vérifier votre boite de réception." | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "Récupération" | ||||
|   no-broadcasts: "Aucune annonce" | ||||
| @@ -464,14 +478,11 @@ common/views/widgets/broadcast.vue: | ||||
|   next: "Suivant" | ||||
| common/views/widgets/calendar.vue: | ||||
|   year: "Année {}" | ||||
|   month: "Mois {}" | ||||
|   month: "{}," | ||||
|   day: "{}" | ||||
|   today: "Aujourd’hui :" | ||||
|   this-month: "Ce mois-ci :" | ||||
|   this-year: "Cette année :" | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "Faire un don" | ||||
|   text: "Les frais pour faire fonctionner Misskey sortent directement de notre poche. Nous ne recevons pas d'argent issu de la publicité, si vous pouvez nous faire des dons, on vous serait éternellement reconnaissants. Si vous êtes intéressé·es veuillez contacter {}. Merci pour votre contribution !" | ||||
| common/views/widgets/photo-stream.vue: | ||||
|   title: "Flux de photos" | ||||
|   no-photos: "Pas de photo" | ||||
| @@ -504,7 +515,7 @@ common/views/widgets/tips.vue: | ||||
|   tips-line10: "タイムマシンウィジェットを利用すると、簡単に過去のタイムラインに遡れます" | ||||
|   tips-line11: "Vous pouvez épingler des notes sur votre page en cliquant sur « … »" | ||||
|   tips-line13: "Tous les fichiers attachés à cette publication sont sauvegardés dans le Drive" | ||||
|   tips-line14: "ホームのカスタマイズ中、ウィジェットを右クリックしてデザインを変更できます" | ||||
|   tips-line14: "Lorsque vous personnalisez la disposition de votre page d’accueil, vous pouvez effectuer un clique droit sur un widget pour changer son apparence." | ||||
|   tips-line17: "Vous pouvez mettre un texte en surbrillance en le mettant entre ** **" | ||||
|   tips-line19: "Plusieurs fenêtres peuvent être détachées en dehors du navigateur." | ||||
|   tips-line20: "Pourcentage sur le widget calendrier qui indique le pourcentage de temps passé" | ||||
| @@ -512,6 +523,8 @@ common/views/widgets/tips.vue: | ||||
|   tips-line23: "Mayu est mignonne avec ses sourcils." | ||||
|   tips-line24: "Misskey est fonctionnel depuis 2014" | ||||
|   tips-line25: "Vous pouvez recevoir les notifications de Misskey dans un navigateur web compatible" | ||||
| common/views/pages/404.vue: | ||||
|   page-not-found: "La page demandée est introuvable !" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "Connecté·e en tant que {}" | ||||
|   following: "Suit" | ||||
| @@ -540,7 +553,7 @@ desktop/views/components/activity.vue: | ||||
|   title: "Activité" | ||||
|   toggle: "Afficher les vues" | ||||
| desktop/views/components/calendar.vue: | ||||
|   title: "{month} / {year}" | ||||
|   title: "{month} - {year}" | ||||
|   prev: "Mois précédent" | ||||
|   next: "Mois suivant" | ||||
|   go: "Cliquez pour naviguer" | ||||
| @@ -731,6 +744,8 @@ desktop/views/components/settings.vue: | ||||
|   note-visibility: "Visibilité de la publication" | ||||
|   default-note-visibility: "Visibilité par défaut" | ||||
|   remember-note-visibility: "Se souvenir du mode de visibilité de la publication" | ||||
|   web-search-engine: "Moteur de recherche Web" | ||||
|   web-search-engine-desc: "Exemple : https://www.google.com/?#q={{query}}" | ||||
|   auto-popout: "Fenêtre contextuelle automatique" | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   advanced: "Paramètres avancés" | ||||
| @@ -750,7 +765,6 @@ desktop/views/components/settings.vue: | ||||
|   circle-icons: "Utiliser des icônes circulaires" | ||||
|   contrasted-acct: "Nom d’utilisateur contrasté" | ||||
|   post-form-on-timeline: "Afficher le formulaire en haut du fil" | ||||
|   suggest-recent-hashtags: "Afficher les hashtags populaires dans le champs de saisie" | ||||
|   show-clock-on-header: "Afficher l'horloge à droite sur le coté supérieur" | ||||
|   show-reply-target: "Afficher les réponses" | ||||
|   timeline: "Chronologie" | ||||
| @@ -762,17 +776,18 @@ desktop/views/components/settings.vue: | ||||
|   deck-column-align: "Alignement des colonnes du Deck" | ||||
|   deck-column-align-center: "Centrer" | ||||
|   deck-column-align-left: "À gauche" | ||||
|   deck-column-align-flexible: "Flexibles" | ||||
|   deck-column-width: "Largeur des colonnes du Deck" | ||||
|   deck-column-width-narrow: "Étroite" | ||||
|   deck-column-width-narrower: "Légèrement étroite" | ||||
|   deck-column-width-normal: "Normale" | ||||
|   deck-column-width-wider: "Légèrement large" | ||||
|   deck-column-width-wide: "Large" | ||||
|   sound: "Son" | ||||
|   enable-sounds: "Activer le son" | ||||
|   enable-sounds-desc: "Jouer un son lorsque vous recevez un message. Ce paramètre est sauvegardé dans le navigateur." | ||||
|   volume: "Volume" | ||||
|   test: "Test" | ||||
|   language: "Langue" | ||||
|   pick-language: "Sélectionner une langue" | ||||
|   recommended: "Recommandé" | ||||
|   auto: "Automatique" | ||||
|   specify-language: "Spécifier la langue" | ||||
|   language-desc: "Le rechargement de la page est requis afin d'appliquer les modifications." | ||||
|   cache: "Cache" | ||||
|   clean-cache: "Nettoyage" | ||||
|   cache-warn: "Le nettoyage du cache du compte supprime les informations stockées dans le navigateur comme les messages, les réponses ainsi que d’autres données (y compris les paramètres de configuration). Après le nettoyage, vous devez recharger la page." | ||||
| @@ -862,11 +877,17 @@ common/views/components/password-settings.vue: | ||||
|   enter-new-password-again: "Entrez à nouveau le nouveau mot de passe" | ||||
|   not-match: "Les nouveaux mots de passe ne sont pas identiques" | ||||
|   changed: "Mot de passe modifié avec succès" | ||||
|   failed: "Échec lors de la modification du mot de passe" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "cette publication est privée" | ||||
|   deleted: "cette publication a été supprimée" | ||||
|   media-count: "{} médias attachés" | ||||
|   poll: "Sondage" | ||||
| desktop/views/components/settings.tags.vue: | ||||
|   title: "Étiquettes" | ||||
|   query: "Requête (optionnelle)" | ||||
|   add: "Ajouter" | ||||
|   save: "Enregistrer" | ||||
| desktop/views/components/taskmanager.vue: | ||||
|   title: "Gestionnaire de tâches" | ||||
| desktop/views/components/timeline.vue: | ||||
| @@ -949,6 +970,7 @@ admin/views/instance.vue: | ||||
|   instance-description: "Description de l’instance" | ||||
|   host: "Hôte" | ||||
|   banner-url: "Url de l’image de la bannière" | ||||
|   error-image-url: "URL de l’image d’erreur" | ||||
|   languages: "Langue de l’instance" | ||||
|   languages-desc: "Vous pouvez en définir plus d’une, séparées par des espaces." | ||||
|   maintainer-config: "Informations de l’administrateur" | ||||
| @@ -966,17 +988,17 @@ admin/views/instance.vue: | ||||
|   recaptcha-site-key: "Clé reCAPTCHA du site" | ||||
|   recaptcha-secret-key: "Clé secrète reCAPTCHA" | ||||
|   twitter-integration-config: "Paramètres de connexion à Twitter" | ||||
|   twitter-integration-info: "L’URL callback est définit sur /api/tw/cb" | ||||
|   twitter-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-twitter-integration: "Activer la connection à Twitter" | ||||
|   twitter-integration-consumer-key: "Clé du consommateur" | ||||
|   twitter-integration-consumer-secret: "Secret du consommateur" | ||||
|   github-integration-config: "Paramètres d’authentification GitHub" | ||||
|   github-integration-info: "L’URL callback est définit sur /api/gh/cb" | ||||
|   github-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-github-integration: "Activer l’authentification avec Github" | ||||
|   github-integration-client-id: "ID client" | ||||
|   github-integration-client-secret: "Secret client" | ||||
|   discord-integration-config: "Paramètres d’authentification Discord" | ||||
|   discord-integration-info: "L’URL callback est définit sur /api/dc/cb" | ||||
|   discord-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-discord-integration: "Activer l’authentification avec Discord" | ||||
|   discord-integration-client-id: "ID client" | ||||
|   discord-integration-client-secret: "Secret client" | ||||
| @@ -991,6 +1013,22 @@ admin/views/instance.vue: | ||||
|   invite: "Inviter" | ||||
|   save: "Sauvegarder" | ||||
|   saved: "Enregistré" | ||||
|   user-recommendation-config: "Utilisateur·rice·s" | ||||
|   enable-external-user-recommendation: "Activer la recommandation des utilisateur·trice·s distant·e·s" | ||||
|   external-user-recommendation-engine: "Moteur" | ||||
|   external-user-recommendation-engine-desc: "Exemple : https://vinayaka.distsn.org/cgi-bin/vinayaka-user-match-misskey-api.cgi?{{host}}+{{user}}+{{limit}}+{{offset}}" | ||||
|   external-user-recommendation-timeout: "Délai d’expiration" | ||||
|   external-user-recommendation-timeout-desc: "En millisecondes (par exemple : 300000)" | ||||
|   email-config: "Paramètres du serveur de messagerie" | ||||
|   email-config-info: "Utilisé pour confirmer votre adresse de courrier électronique et la réinitialisation de votre mot de passe." | ||||
|   enable-email: "Activation de la distribution du courrier" | ||||
|   email: "Adresse de courrier électronique" | ||||
|   smtp-secure: "Utiliser SSL/TLS implicitement dans la connexion SMTP" | ||||
|   smtp-secure-info: "Désactiver STARTTLS lorsque celui-ci est utilisé." | ||||
|   smtp-host: "Hôte SMTP" | ||||
|   smtp-port: "Port SMTP" | ||||
|   smtp-user: "Utilisateur SMTP" | ||||
|   smtp-pass: "Mot de passe SMTP" | ||||
| admin/views/charts.vue: | ||||
|   title: "Graph" | ||||
|   per-day: "par jour" | ||||
| @@ -1016,19 +1054,50 @@ admin/views/charts.vue: | ||||
|     network-requests: "Requêtes" | ||||
|     network-time: "Temps de réponse" | ||||
|     network-usage: "Traffic" | ||||
| admin/views/drive.vue: | ||||
|   sort: | ||||
|     title: "Tri" | ||||
|     createdAtAsc: "アップロード日時が古い順" | ||||
|     createdAtDesc: "アップロード日時が新しい順" | ||||
|     sizeAsc: "Taille - Ascendant" | ||||
|     sizeDesc: "Taille - Volumineux en premier" | ||||
|   origin: | ||||
|     title: "Origine" | ||||
|     combined: "Locaux et distants combinés" | ||||
|     local: "Local" | ||||
|     remote: "Distant" | ||||
|   delete: "Supprimer" | ||||
|   deleted: "Supprimé" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "Suspendre un·e utilisateur·rice" | ||||
|   operation: "Actions" | ||||
|   username-or-userid: "Nom d’utilisateur·rice ou ID utilisateur" | ||||
|   user-not-found: "Utilisateur·rice non trouvé·e" | ||||
|   lookup: "Recherche" | ||||
|   reset-password: "Réinitialiser mot de passe" | ||||
|   password-updated: "Le mot de passe est « {password} »" | ||||
|   suspend: "Suspendre" | ||||
|   suspended: "Suspendu·e avec succès." | ||||
|   unsuspend-user: "Lever la suspension d’utilisateur·rice·s" | ||||
|   unsuspend: "Suspension levée" | ||||
|   unsuspended: "La suspension de l’utilisateur·rice a été levée avec succès" | ||||
|   verify-user: "Paramètres de vérification du compte utilisateur" | ||||
|   verify: "Vérification du compte" | ||||
|   verified: "Le compte a été vérifié" | ||||
|   unverify-user: "Paramètres de non-vérification du compte utilisateur" | ||||
|   unverify: "Ôter la vérification du compte" | ||||
|   unverified: "Ce compte n'est plus vérifié" | ||||
|   users: | ||||
|     title: "Utilisateur·rice·s" | ||||
|     sort: | ||||
|       title: "Trier par" | ||||
|       createdAtAsc: "Date d’inscription (Ascendant)" | ||||
|       createdAtDesc: "Date d’inscription (Descendant)" | ||||
|       updatedAtAsc: "Mis à jour récemment (Ascendant)" | ||||
|       updatedAtDesc: "Mis à jour récemment (descendant)" | ||||
|     origin: | ||||
|       title: "Origine" | ||||
|       combined: "Locaux + distants" | ||||
|       local: "Locaux" | ||||
|       remote: "Distants" | ||||
|     createdAt: "Créé le" | ||||
|     updatedAt: "Mis à jour le" | ||||
| admin/views/moderators.vue: | ||||
|   add-moderator: | ||||
|     title: "Ajout d’un modérateur" | ||||
| @@ -1134,7 +1203,7 @@ desktop/views/pages/user/user.header.vue: | ||||
|   years-old: "{age} ans" | ||||
|   year: "/" | ||||
|   month: "/" | ||||
|   day: "/" | ||||
|   day: "-" | ||||
| desktop/views/pages/user/user.timeline.vue: | ||||
|   default: "Publications" | ||||
|   with-replies: "Publications et réponses" | ||||
| @@ -1265,7 +1334,7 @@ mobile/views/components/ui.nav.vue: | ||||
|   admin: "Admin" | ||||
|   about: "À propos de Misskey" | ||||
| mobile/views/components/user-timeline.vue: | ||||
|   no-notes: "Cette utilisateur semble n'avoir rien poster pour le moment" | ||||
|   no-notes: "Il semble que cet·te utilisateur·rice n’a rien publié pour le moment." | ||||
|   no-notes-with-media: "Aucune notes avec des médias" | ||||
| mobile/views/components/users-list.vue: | ||||
|   all: "Tout" | ||||
| @@ -1294,7 +1363,7 @@ mobile/views/pages/welcome.vue: | ||||
|   signup: "S'enregistrer" | ||||
| mobile/views/pages/widgets.vue: | ||||
|   dashboard: "Tableau de bord" | ||||
|   widgets-hints: "ウィジェットを追加/削除したり並べ替えたりできます。ウィジェットを移動するには「三」をドラッグします。ウィジェットを削除するには「x」をタップします。いくつかのウィジェットはタップすることで表示を変更できます。" | ||||
|   widgets-hints: "Vous pouvez ajouter, supprimer et réaranger les widgets. Faites glisser « 三 » pour déplacer le widget. Appuyez sur « x » pour supprimer le widget. Certains widgets peuvent changer d’apparence en cliquant dessus." | ||||
|   add-widget: "Ajouter" | ||||
|   customization-tips: "Conseils de personnalisation" | ||||
| mobile/views/pages/widgets/activity.vue: | ||||
| @@ -1321,11 +1390,6 @@ mobile/views/pages/selectdrive.vue: | ||||
|   select-file: "Choisissez un fichier" | ||||
| mobile/views/pages/settings.vue: | ||||
|   signed-in-as: "Connecté·e en tant que {}" | ||||
|   lang: "Langue" | ||||
|   lang-tip: "Le rechargement de la page est requis afin d'appliquer les modifications." | ||||
|   recommended: "Recommandé" | ||||
|   auto: "Automatique" | ||||
|   specify-language: "Sélectionnez votre langue" | ||||
|   design: "Affichage et design" | ||||
|   dark-mode: "Mode nuit" | ||||
|   i-am-under-limited-internet: "J'ai un accès Internet limité" | ||||
| @@ -1348,21 +1412,11 @@ mobile/views/pages/settings.vue: | ||||
|   note-visibility: "Visibilité de la publication" | ||||
|   default-note-visibility: "Visibilité par défaut" | ||||
|   remember-note-visibility: "Se souvenir du mode de visibilité de la publication" | ||||
|   web-search-engine: "Moteur de recherche Web" | ||||
|   web-search-engine-desc: "Exemple : https://www.google.com/?#q={{query}}" | ||||
|   disable-via-mobile: "Ne pas mentionner que ma publication provient d'un 'périphérique mobile'" | ||||
|   load-raw-images: "Afficher les photos jointes en haute qualité" | ||||
|   load-remote-media: "Afficher les médias sur le serveur distant" | ||||
|   twitter: "Intégration à Twitter" | ||||
|   twitter-connect: "Se connecter à votre compte Twitter" | ||||
|   twitter-reconnect: "Reconnecter" | ||||
|   twitter-disconnect: "Déconnexion" | ||||
|   github: "Avec GitHub" | ||||
|   github-connect: "Se connecter à votre compte GitHub" | ||||
|   github-reconnect: "Reconnecter" | ||||
|   github-disconnect: "Déconnecter" | ||||
|   discord: "Intégration avec Discord" | ||||
|   discord-connect: "Connecter votre compte Discord" | ||||
|   discord-reconnect: "Reconnecter" | ||||
|   discord-disconnect: "Déconnecter" | ||||
|   update: "Mise à jour de Misskey" | ||||
|   version: "Version :" | ||||
|   latest-version: "Dernière version :" | ||||
| @@ -1392,6 +1446,9 @@ mobile/views/pages/user.vue: | ||||
|   block: "Bloquer" | ||||
|   unblock: "Débloquer" | ||||
|   years-old: "{age} ans" | ||||
|   push-to-list: "Ajouter à la liste" | ||||
|   select-list: "Sélectionnez une liste" | ||||
|   list-pushed: "Vous avez ajouté {user} à la liste {list} avec succès." | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "Notes récentes" | ||||
|   images: "Images" | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
| const fs = require('fs'); | ||||
| const yaml = require('js-yaml'); | ||||
|  | ||||
| const langs = ['de-DE', 'en-US', 'fr-FR', 'ja-JP', 'ja-KS', 'pl-PL', 'es-ES', 'nl-NL', 'zh-CN']; | ||||
| const langs = ['de-DE', 'en-US', 'fr-FR', 'ja-JP', 'ja-KS', 'pl-PL', 'es-ES', 'nl-NL', 'zh-CN', 'ko-KR']; | ||||
|  | ||||
| const loadLocale = lang => yaml.safeLoad(fs.readFileSync(`${__dirname}/${lang}.yml`, 'utf-8')); | ||||
| const locales = langs.map(lang => ({ [lang]: loadLocale(lang) })); | ||||
|   | ||||
| @@ -26,6 +26,7 @@ common: | ||||
|   close: "閉じる" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   load-more: "もっと読み込む" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   got-it: "わかった" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
| @@ -109,9 +110,10 @@ common: | ||||
|   my-token-regenerated: "あなたのトークンが更新されたのでサインアウトします。" | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   use-white-black-reversi-stones: "リバーシに白黒の石を使う" | ||||
|   verified-user: "公式アカウント" | ||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   show-full-acct: "ユーザー名のホストを省略しない" | ||||
| @@ -157,12 +159,12 @@ common: | ||||
|     polls: "アンケート" | ||||
|     post-form: "投稿フォーム" | ||||
|     server: "サーバー情報" | ||||
|     donation: "寄付のお願い" | ||||
|     nav: "ナビゲーション" | ||||
|     tips: "ヒント" | ||||
|     hashtags: "ハッシュタグ" | ||||
|   dev: "アプリの作成に失敗しました。再度お試しください。" | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
|   you: "あなた" | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{name}</i>があなたのアカウントにアクセスすることを許可しますか?" | ||||
|   permission-ask: "このアプリは次の権限を要求しています:" | ||||
| @@ -295,6 +297,8 @@ common/views/components/theme.vue: | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "隠す" | ||||
|   show: "もっと見る" | ||||
|   chars: "{count}文字" | ||||
|   files: "{count}ファイル" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "ユーザーを探す" | ||||
|   you: "あなた" | ||||
| @@ -399,13 +403,11 @@ common/views/components/stream-indicator.vue: | ||||
|   connecting: "接続中" | ||||
|   reconnecting: "再接続中" | ||||
|   connected: "接続完了" | ||||
| common/views/components/twitter-setting.vue: | ||||
|   description: "お使いのTwitterアカウントをお使いのMisskeyアカウントに接続しておくと、プロフィールでTwitterアカウント情報が表示されるようになったり、Twitterを用いた便利なサインインを利用できるようになります。" | ||||
|   connected-to: "次のTwitterアカウントに接続されています" | ||||
|   detail: "詳細..." | ||||
|   reconnect: "再接続する" | ||||
|   connect: "Twitterと接続する" | ||||
| common/views/components/integration-settings.vue: | ||||
|   title: "サービス連携" | ||||
|   connect: "接続する" | ||||
|   disconnect: "切断する" | ||||
|   connected-to: "次のアカウントに接続されています" | ||||
| common/views/components/github-setting.vue: | ||||
|   description: "お使いのGitHubアカウントをお使いのMisskeyアカウントに接続しておくと、プロフィールでGitHubアカウント情報が表示されるようになったり、GitHubを用いた便利なサインインを利用できるようになります。" | ||||
|   connected-to: "次のGitHubアカウントに接続されています" | ||||
| @@ -438,12 +440,20 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/components/language-settings.vue: | ||||
|   title: "表示言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語を指定" | ||||
|   info: "変更はページの再度読み込み後に反映されます。" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   language: "言語" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
| @@ -457,6 +467,10 @@ common/views/components/profile-editor.vue: | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
|   email: "メール設定" | ||||
|   email-address: "メールアドレス" | ||||
|   email-verified: "メールアドレスが確認されました" | ||||
|   email-not-verified: "メールアドレスが確認されていません。メールボックスをご確認ください。" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "確認中" | ||||
|   no-broadcasts: "お知らせはありません" | ||||
| @@ -469,9 +483,6 @@ common/views/widgets/calendar.vue: | ||||
|   today: "今日:" | ||||
|   this-month: "今月:" | ||||
|   this-year: "今年:" | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "寄付のお願い" | ||||
|   text: "Misskeyの運営にはドメイン、サーバー等のコストが掛かります。Misskeyは広告を掲載したりしないため、収入を皆様からの寄付に頼っています。もしご興味があれば、{}までご連絡ください。ご協力ありがとうございます。" | ||||
| common/views/widgets/photo-stream.vue: | ||||
|   title: "フォトストリーム" | ||||
|   no-photos: "写真はありません" | ||||
| @@ -512,6 +523,8 @@ common/views/widgets/tips.vue: | ||||
|   tips-line23: "まゆかわいいよまゆ" | ||||
|   tips-line24: "Misskeyは2014年にサービスを開始しました" | ||||
|   tips-line25: "対応ブラウザではMisskeyを開いていなくても通知を受け取れます" | ||||
| common/views/pages/404.vue: | ||||
|   page-not-found: "ページが見つかりませんでした" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   following: "フォロー中" | ||||
| @@ -731,6 +744,8 @@ desktop/views/components/settings.vue: | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   web-search-engine: "ウェブ検索エンジン" | ||||
|   web-search-engine-desc: "例: https://www.google.com/?#q={{query}}" | ||||
|   auto-popout: "ウィンドウの自動ポップアウト" | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   advanced: "詳細設定" | ||||
| @@ -750,7 +765,6 @@ desktop/views/components/settings.vue: | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   timeline: "タイムライン" | ||||
| @@ -759,20 +773,21 @@ desktop/views/components/settings.vue: | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   remain-deleted-note: "削除された投稿を表示し続ける" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align: "デッキのカラムの配置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   deck-column-align-flexible: "フレキシブル" | ||||
|   deck-column-width: "デッキのカラムの幅" | ||||
|   deck-column-width-narrow: "狭" | ||||
|   deck-column-width-narrower: "やや狭" | ||||
|   deck-column-width-normal: "普通" | ||||
|   deck-column-width-wider: "やや広" | ||||
|   deck-column-width-wide: "広" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||
|   volume: "ボリューム" | ||||
|   test: "テスト" | ||||
|   language: "言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語を指定" | ||||
|   language-desc: "変更はページの再度読み込み後に反映されます。" | ||||
|   cache: "キャッシュ" | ||||
|   clean-cache: "クリーンアップ" | ||||
|   cache-warn: "クリーンアップを行うと、ブラウザに記憶されたアカウント情報のキャッシュ、書きかけの投稿・返信・メッセージ、およびその他のデータ(設定情報含む)が削除されます。クリーンアップを行った後はページを再度読み込みする必要があります。" | ||||
| @@ -862,11 +877,17 @@ common/views/components/password-settings.vue: | ||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||
|   not-match: "新しいパスワードが一致しません" | ||||
|   changed: "パスワードを変更しました" | ||||
|   failed: "パスワード変更に失敗しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   media-count: "{}つのメディア" | ||||
|   poll: "アンケート" | ||||
| desktop/views/components/settings.tags.vue: | ||||
|   title: "タグ" | ||||
|   query: "クエリ (省略可)" | ||||
|   add: "追加" | ||||
|   save: "保存" | ||||
| desktop/views/components/taskmanager.vue: | ||||
|   title: "タスクマネージャ" | ||||
| desktop/views/components/timeline.vue: | ||||
| @@ -949,6 +970,7 @@ admin/views/instance.vue: | ||||
|   instance-description: "インスタンスの紹介" | ||||
|   host: "ホスト" | ||||
|   banner-url: "バナー画像URL" | ||||
|   error-image-url: "エラー画像URL" | ||||
|   languages: "インスタンスの対象言語" | ||||
|   languages-desc: "スペースで区切って複数設定できます。" | ||||
|   maintainer-config: "管理者情報" | ||||
| @@ -966,17 +988,17 @@ admin/views/instance.vue: | ||||
|   recaptcha-site-key: "reCAPTCHA site key" | ||||
|   recaptcha-secret-key: "reCAPTCHA secret key" | ||||
|   twitter-integration-config: "Twitter連携の設定" | ||||
|   twitter-integration-info: "コールバックURLは /api/tw/cb に設定します。" | ||||
|   twitter-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-twitter-integration: "Twitter連携を有効にする" | ||||
|   twitter-integration-consumer-key: "Consumer key" | ||||
|   twitter-integration-consumer-secret: "Consumer secret" | ||||
|   github-integration-config: "GitHub連携の設定" | ||||
|   github-integration-info: "コールバックURLは /api/gh/cb に設定します。" | ||||
|   github-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-github-integration: "GitHub連携を有効にする" | ||||
|   github-integration-client-id: "Client ID" | ||||
|   github-integration-client-secret: "Client Secret" | ||||
|   discord-integration-config: "Discord連携の設定" | ||||
|   discord-integration-info: "コールバックURLは /api/dc/cb に設定します。" | ||||
|   discord-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-discord-integration: "Discord連携を有効にする" | ||||
|   discord-integration-client-id: "Client ID" | ||||
|   discord-integration-client-secret: "Client Secret" | ||||
| @@ -991,6 +1013,22 @@ admin/views/instance.vue: | ||||
|   invite: "招待" | ||||
|   save: "保存" | ||||
|   saved: "保存しました" | ||||
|   user-recommendation-config: "おすすめユーザー" | ||||
|   enable-external-user-recommendation: "外部ユーザーレコメンデーションを有効にする" | ||||
|   external-user-recommendation-engine: "エンジン" | ||||
|   external-user-recommendation-engine-desc: "例: https://vinayaka.distsn.org/cgi-bin/vinayaka-user-match-misskey-api.cgi?{{host}}+{{user}}+{{limit}}+{{offset}}" | ||||
|   external-user-recommendation-timeout: "タイムアウト" | ||||
|   external-user-recommendation-timeout-desc: "ミリ秒単位 (例: 300000)" | ||||
|   email-config: "メールサーバーの設定" | ||||
|   email-config-info: "メールアドレス確認やパスワードリセットの際に使われます。" | ||||
|   enable-email: "メール配信を有効にする" | ||||
|   email: "メールアドレス" | ||||
|   smtp-secure: "SMTP接続に暗黙的なSSL/TLSを使用する" | ||||
|   smtp-secure-info: "STARTTLS使用時はオフにします。" | ||||
|   smtp-host: "SMTPホスト" | ||||
|   smtp-port: "SMTPポート" | ||||
|   smtp-user: "SMTPユーザー" | ||||
|   smtp-pass: "SMTPパスワード" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
| @@ -1016,19 +1054,50 @@ admin/views/charts.vue: | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| admin/views/drive.vue: | ||||
|   sort: | ||||
|     title: "ソート" | ||||
|     createdAtAsc: "アップロード日時が古い順" | ||||
|     createdAtDesc: "アップロード日時が新しい順" | ||||
|     sizeAsc: "サイズが小さい順" | ||||
|     sizeDesc: "サイズが大きい順" | ||||
|   origin: | ||||
|     title: "オリジン" | ||||
|     combined: "ローカル+リモート" | ||||
|     local: "ローカル" | ||||
|     remote: "リモート" | ||||
|   delete: "削除" | ||||
|   deleted: "削除しました" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   operation: "操作" | ||||
|   username-or-userid: "ユーザー名またはユーザーID" | ||||
|   user-not-found: "ユーザーが見つかりません" | ||||
|   lookup: "照会" | ||||
|   reset-password: "パスワードをリセット" | ||||
|   password-updated: "パスワードは現在「{password}」です" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|   users: | ||||
|     title: "ユーザー" | ||||
|     sort: | ||||
|       title: "ソート" | ||||
|       createdAtAsc: "登録日時が古い順" | ||||
|       createdAtDesc: "登録日時が新しい順" | ||||
|       updatedAtAsc: "更新日時が古い順" | ||||
|       updatedAtDesc: "更新日時が新しい順" | ||||
|     origin: | ||||
|       title: "オリジン" | ||||
|       combined: "ローカル+リモート" | ||||
|       local: "ローカル" | ||||
|       remote: "リモート" | ||||
|     createdAt: "登録日時" | ||||
|     updatedAt: "更新日時" | ||||
| admin/views/moderators.vue: | ||||
|   add-moderator: | ||||
|     title: "モデレーターの登録" | ||||
| @@ -1321,11 +1390,6 @@ mobile/views/pages/selectdrive.vue: | ||||
|   select-file: "ファイルを選択" | ||||
| mobile/views/pages/settings.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   lang: "言語" | ||||
|   lang-tip: "変更はページの再読み込み後に反映されます。" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語を指定" | ||||
|   design: "デザインと表示" | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
| @@ -1348,21 +1412,11 @@ mobile/views/pages/settings.vue: | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   web-search-engine: "ウェブ検索エンジン" | ||||
|   web-search-engine-desc: "例: https://www.google.com/?#q={{query}}" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   load-raw-images: "添付された画像を高画質で表示する" | ||||
|   load-remote-media: "リモートサーバーのメディアを表示する" | ||||
|   twitter: "Twitter連携" | ||||
|   twitter-connect: "Twitterアカウントに接続する" | ||||
|   twitter-reconnect: "再接続する" | ||||
|   twitter-disconnect: "切断する" | ||||
|   github: "GitHub連携" | ||||
|   github-connect: "GitHubアカウントに接続する" | ||||
|   github-reconnect: "再接続する" | ||||
|   github-disconnect: "切断する" | ||||
|   discord: "Discord連携" | ||||
|   discord-connect: "Discordアカウントに接続する" | ||||
|   discord-reconnect: "再接続する" | ||||
|   discord-disconnect: "切断する" | ||||
|   update: "Misskey Update" | ||||
|   version: "バージョン:" | ||||
|   latest-version: "最新のバージョン:" | ||||
| @@ -1392,6 +1446,9 @@ mobile/views/pages/user.vue: | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
|   years-old: "{age}歳" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "最近の投稿" | ||||
|   images: "画像" | ||||
|   | ||||
| @@ -26,6 +26,7 @@ common: | ||||
|   close: "閉じる" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   load-more: "もっと読み込む" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|  | ||||
|   got-it: "わかった" | ||||
|   customization-tips: | ||||
| @@ -117,9 +118,10 @@ common: | ||||
|   my-token-regenerated: "あなたのトークンが更新されたのでサインアウトします。" | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   use-white-black-reversi-stones: "リバーシに白黒の石を使う" | ||||
|   verified-user: "公式アカウント" | ||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   show-full-acct: "ユーザー名のホストを省略しない" | ||||
| @@ -170,13 +172,13 @@ common: | ||||
|     polls: "アンケート" | ||||
|     post-form: "投稿フォーム" | ||||
|     server: "サーバー情報" | ||||
|     donation: "寄付のお願い" | ||||
|     nav: "ナビゲーション" | ||||
|     tips: "ヒント" | ||||
|     hashtags: "ハッシュタグ" | ||||
|  | ||||
|   dev: "アプリの作成に失敗しました。再度お試しください。" | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
|   you: "あなた" | ||||
|  | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{name}</i>があなたのアカウントにアクセスすることを許可しますか?" | ||||
| @@ -320,6 +322,8 @@ common/views/components/theme.vue: | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "隠す" | ||||
|   show: "もっと見る" | ||||
|   chars: "{count}文字" | ||||
|   files: "{count}ファイル" | ||||
|  | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "ユーザーを探す" | ||||
| @@ -439,13 +443,11 @@ common/views/components/stream-indicator.vue: | ||||
|   reconnecting: "再接続中" | ||||
|   connected: "接続完了" | ||||
|  | ||||
| common/views/components/twitter-setting.vue: | ||||
|   description: "お使いのTwitterアカウントをお使いのMisskeyアカウントに接続しておくと、プロフィールでTwitterアカウント情報が表示されるようになったり、Twitterを用いた便利なサインインを利用できるようになります。" | ||||
|   connected-to: "次のTwitterアカウントに接続されています" | ||||
|   detail: "詳細..." | ||||
|   reconnect: "再接続する" | ||||
|   connect: "Twitterと接続する" | ||||
| common/views/components/integration-settings.vue: | ||||
|   title: "サービス連携" | ||||
|   connect: "接続する" | ||||
|   disconnect: "切断する" | ||||
|   connected-to: "次のアカウントに接続されています" | ||||
|  | ||||
| common/views/components/github-setting.vue: | ||||
|   description: "お使いのGitHubアカウントをお使いのMisskeyアカウントに接続しておくと、プロフィールでGitHubアカウント情報が表示されるようになったり、GitHubを用いた便利なサインインを利用できるようになります。" | ||||
| @@ -484,12 +486,21 @@ common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
|  | ||||
| common/views/components/language-settings.vue: | ||||
|   title: "表示言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語を指定" | ||||
|   info: "変更はページの再度読み込み後に反映されます。" | ||||
|  | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   language: "言語" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
| @@ -503,6 +514,18 @@ common/views/components/profile-editor.vue: | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
|   email: "メール設定" | ||||
|   email-address: "メールアドレス" | ||||
|   email-verified: "メールアドレスが確認されました" | ||||
|   email-not-verified: "メールアドレスが確認されていません。メールボックスをご確認ください。" | ||||
|  | ||||
| common/views/components/user-list-editor.vue: | ||||
|   users: "ユーザー" | ||||
|   rename: "リスト名を変更" | ||||
|   delete: "リストを削除" | ||||
|   remove-user: "このリストから削除" | ||||
|   delete-are-you-sure: "リスト「$1」を削除しますか?" | ||||
|   deleted: "削除しました" | ||||
|  | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "確認中" | ||||
| @@ -518,10 +541,6 @@ common/views/widgets/calendar.vue: | ||||
|   this-month: "今月:" | ||||
|   this-year: "今年:" | ||||
|  | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "寄付のお願い" | ||||
|   text: "Misskeyの運営にはドメイン、サーバー等のコストが掛かります。Misskeyは広告を掲載したりしないため、収入を皆様からの寄付に頼っています。もしご興味があれば、{}までご連絡ください。ご協力ありがとうございます。" | ||||
|  | ||||
| common/views/widgets/photo-stream.vue: | ||||
|   title: "フォトストリーム" | ||||
|   no-photos: "写真はありません" | ||||
| @@ -569,6 +588,9 @@ common/views/widgets/tips.vue: | ||||
|   tips-line24: "Misskeyは2014年にサービスを開始しました" | ||||
|   tips-line25: "対応ブラウザではMisskeyを開いていなくても通知を受け取れます" | ||||
|  | ||||
| common/views/pages/404.vue: | ||||
|   page-not-found: "ページが見つかりませんでした" | ||||
|  | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   following: "フォロー中" | ||||
| @@ -824,6 +846,8 @@ desktop/views/components/settings.vue: | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   web-search-engine: "ウェブ検索エンジン" | ||||
|   web-search-engine-desc: "例: https://www.google.com/?#q={{query}}" | ||||
|   auto-popout: "ウィンドウの自動ポップアウト" | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   advanced: "詳細設定" | ||||
| @@ -844,7 +868,6 @@ desktop/views/components/settings.vue: | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   timeline: "タイムライン" | ||||
| @@ -853,9 +876,16 @@ desktop/views/components/settings.vue: | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   remain-deleted-note: "削除された投稿を表示し続ける" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align: "デッキのカラムの配置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   deck-column-align-flexible: "フレキシブル" | ||||
|   deck-column-width: "デッキのカラムの幅" | ||||
|   deck-column-width-narrow: "狭" | ||||
|   deck-column-width-narrower: "やや狭" | ||||
|   deck-column-width-normal: "普通" | ||||
|   deck-column-width-wider: "やや広" | ||||
|   deck-column-width-wide: "広" | ||||
|  | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
| @@ -863,13 +893,6 @@ desktop/views/components/settings.vue: | ||||
|   volume: "ボリューム" | ||||
|   test: "テスト" | ||||
|  | ||||
|   language: "言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語を指定" | ||||
|   language-desc: "変更はページの再度読み込み後に反映されます。" | ||||
|  | ||||
|   cache: "キャッシュ" | ||||
|   clean-cache: "クリーンアップ" | ||||
|   cache-warn: "クリーンアップを行うと、ブラウザに記憶されたアカウント情報のキャッシュ、書きかけの投稿・返信・メッセージ、およびその他のデータ(設定情報含む)が削除されます。クリーンアップを行った後はページを再度読み込みする必要があります。" | ||||
| @@ -970,6 +993,7 @@ common/views/components/password-settings.vue: | ||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||
|   not-match: "新しいパスワードが一致しません" | ||||
|   changed: "パスワードを変更しました" | ||||
|   failed: "パスワード変更に失敗しました" | ||||
|  | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
| @@ -977,6 +1001,12 @@ desktop/views/components/sub-note-content.vue: | ||||
|   media-count: "{}つのメディア" | ||||
|   poll: "アンケート" | ||||
|  | ||||
| desktop/views/components/settings.tags.vue: | ||||
|   title: "タグ" | ||||
|   query: "クエリ (省略可)" | ||||
|   add: "追加" | ||||
|   save: "保存" | ||||
|  | ||||
| desktop/views/components/taskmanager.vue: | ||||
|   title: "タスクマネージャ" | ||||
|  | ||||
| @@ -1075,6 +1105,7 @@ admin/views/instance.vue: | ||||
|   instance-description: "インスタンスの紹介" | ||||
|   host: "ホスト" | ||||
|   banner-url: "バナー画像URL" | ||||
|   error-image-url: "エラー画像URL" | ||||
|   languages: "インスタンスの対象言語" | ||||
|   languages-desc: "スペースで区切って複数設定できます。" | ||||
|   maintainer-config: "管理者情報" | ||||
| @@ -1092,17 +1123,17 @@ admin/views/instance.vue: | ||||
|   recaptcha-site-key: "reCAPTCHA site key" | ||||
|   recaptcha-secret-key: "reCAPTCHA secret key" | ||||
|   twitter-integration-config: "Twitter連携の設定" | ||||
|   twitter-integration-info: "コールバックURLは /api/tw/cb に設定します。" | ||||
|   twitter-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-twitter-integration: "Twitter連携を有効にする" | ||||
|   twitter-integration-consumer-key: "Consumer key" | ||||
|   twitter-integration-consumer-secret: "Consumer secret" | ||||
|   github-integration-config: "GitHub連携の設定" | ||||
|   github-integration-info: "コールバックURLは /api/gh/cb に設定します。" | ||||
|   github-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-github-integration: "GitHub連携を有効にする" | ||||
|   github-integration-client-id: "Client ID" | ||||
|   github-integration-client-secret: "Client Secret" | ||||
|   discord-integration-config: "Discord連携の設定" | ||||
|   discord-integration-info: "コールバックURLは /api/dc/cb に設定します。" | ||||
|   discord-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-discord-integration: "Discord連携を有効にする" | ||||
|   discord-integration-client-id: "Client ID" | ||||
|   discord-integration-client-secret: "Client Secret" | ||||
| @@ -1117,6 +1148,28 @@ admin/views/instance.vue: | ||||
|   invite: "招待" | ||||
|   save: "保存" | ||||
|   saved: "保存しました" | ||||
|   user-recommendation-config: "おすすめユーザー" | ||||
|   enable-external-user-recommendation: "外部ユーザーレコメンデーションを有効にする" | ||||
|   external-user-recommendation-engine: "エンジン" | ||||
|   external-user-recommendation-engine-desc: "例: https://vinayaka.distsn.org/cgi-bin/vinayaka-user-match-misskey-api.cgi?{{host}}+{{user}}+{{limit}}+{{offset}}" | ||||
|   external-user-recommendation-timeout: "タイムアウト" | ||||
|   external-user-recommendation-timeout-desc: "ミリ秒単位 (例: 300000)" | ||||
|   email-config: "メールサーバーの設定" | ||||
|   email-config-info: "メールアドレス確認やパスワードリセットの際に使われます。" | ||||
|   enable-email: "メール配信を有効にする" | ||||
|   email: "メールアドレス" | ||||
|   smtp-secure: "SMTP接続に暗黙的なSSL/TLSを使用する" | ||||
|   smtp-secure-info: "STARTTLS使用時はオフにします。" | ||||
|   smtp-host: "SMTPホスト" | ||||
|   smtp-port: "SMTPポート" | ||||
|   smtp-user: "SMTPユーザー" | ||||
|   smtp-pass: "SMTPパスワード" | ||||
|   serviceworker-config: "ServiceWorker" | ||||
|   enable-serviceworker: "ServiceWorkerを有効にする" | ||||
|   serviceworker-info: "プッシュ通知を行うには有効する必要があります。" | ||||
|   vapid-publickey: "VAPID公開鍵" | ||||
|   vapid-privatekey: "VAPID秘密鍵" | ||||
|   vapid-info: "ServiceWorkerを有効にする場合、VAPIDキーペアを生成する必要があります。シェルで次のようにします:" | ||||
|  | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
| @@ -1144,19 +1197,53 @@ admin/views/charts.vue: | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
|  | ||||
| admin/views/drive.vue: | ||||
|   sort: | ||||
|     title: "ソート" | ||||
|     createdAtAsc: "アップロード日時が古い順" | ||||
|     createdAtDesc: "アップロード日時が新しい順" | ||||
|     sizeAsc: "サイズが小さい順" | ||||
|     sizeDesc: "サイズが大きい順" | ||||
|   origin: | ||||
|     title: "オリジン" | ||||
|     combined: "ローカル+リモート" | ||||
|     local: "ローカル" | ||||
|     remote: "リモート" | ||||
|   delete: "削除" | ||||
|   deleted: "削除しました" | ||||
|   mark-as-sensitive: "閲覧注意に設定" | ||||
|   unmark-as-sensitive: "閲覧注意を解除" | ||||
|  | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   operation: "操作" | ||||
|   username-or-userid: "ユーザー名またはユーザーID" | ||||
|   user-not-found: "ユーザーが見つかりません" | ||||
|   lookup: "照会" | ||||
|   reset-password: "パスワードをリセット" | ||||
|   password-updated: "パスワードは現在「{password}」です" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|   users: | ||||
|     title: "ユーザー" | ||||
|     sort: | ||||
|       title: "ソート" | ||||
|       createdAtAsc: "登録日時が古い順" | ||||
|       createdAtDesc: "登録日時が新しい順" | ||||
|       updatedAtAsc: "更新日時が古い順" | ||||
|       updatedAtDesc: "更新日時が新しい順" | ||||
|     origin: | ||||
|       title: "オリジン" | ||||
|       combined: "ローカル+リモート" | ||||
|       local: "ローカル" | ||||
|       remote: "リモート" | ||||
|     createdAt: "登録日時" | ||||
|     updatedAt: "更新日時" | ||||
|  | ||||
| admin/views/moderators.vue: | ||||
|   add-moderator: | ||||
| @@ -1514,11 +1601,6 @@ mobile/views/pages/selectdrive.vue: | ||||
|  | ||||
| mobile/views/pages/settings.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   lang: "言語" | ||||
|   lang-tip: "変更はページの再読み込み後に反映されます。" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語を指定" | ||||
|   design: "デザインと表示" | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
| @@ -1541,21 +1623,11 @@ mobile/views/pages/settings.vue: | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   web-search-engine: "ウェブ検索エンジン" | ||||
|   web-search-engine-desc: "例: https://www.google.com/?#q={{query}}" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   load-raw-images: "添付された画像を高画質で表示する" | ||||
|   load-remote-media: "リモートサーバーのメディアを表示する" | ||||
|   twitter: "Twitter連携" | ||||
|   twitter-connect: "Twitterアカウントに接続する" | ||||
|   twitter-reconnect: "再接続する" | ||||
|   twitter-disconnect: "切断する" | ||||
|   github: "GitHub連携" | ||||
|   github-connect: "GitHubアカウントに接続する" | ||||
|   github-reconnect: "再接続する" | ||||
|   github-disconnect: "切断する" | ||||
|   discord: "Discord連携" | ||||
|   discord-connect: "Discordアカウントに接続する" | ||||
|   discord-reconnect: "再接続する" | ||||
|   discord-disconnect: "切断する" | ||||
|   update: "Misskey Update" | ||||
|   version: "バージョン:" | ||||
|   latest-version: "最新のバージョン:" | ||||
| @@ -1586,6 +1658,9 @@ mobile/views/pages/user.vue: | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
|   years-old: "{age}歳" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
|  | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "最近の投稿" | ||||
|   | ||||
| @@ -25,11 +25,12 @@ common: | ||||
|   application-authorization: "アプリの連携" | ||||
|   close: "さいなら" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりせんといてください。アカウントが不正利用されるかも分からん。知らんけど。" | ||||
|   load-more: "もっと読み込む" | ||||
|   load-more: "もっとあらへんのか!" | ||||
|   enter-password: "パスワードを入れてや" | ||||
|   got-it: "ほい" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
|     paragraph: "<p>ホームのカスタマイズでは、ウィジェットを追加/削除したり、ドラッグ&ドロップして並べ替えたりすることができます。</p><p>一部のウィジェットは、<strong><strong>右</strong>クリック</strong>することで表示を変更することができます。</p><p>ウィジェットを削除するには、ヘッダーの<strong>「ゴミ箱」</strong>と書かれたエリアにウィジェットをドラッグ&ドロップします。</p><p>カスタマイズを終了するには、右上の「完了」をクリックします。</p>" | ||||
|     paragraph: "<p>ホームのカスタマイズは、ウィジェットを増やしたりほかしたり、ドラッグ&ドロップして並び替えたりしていじれるで。</p><p>一部ウィジェットは<strong><strong>右</strong>クリック</strong>で表示もいじれるんや。</p><p>ほかしたいときはヘッダーの<strong>「ゴミ箱」</strong>にほうりこんでら。</p><p>「完了」押したらお終いやで。</p>" | ||||
|     gotit: "Got it!" | ||||
|   notification: | ||||
|     file-uploaded: "ファイルがアップロードされたで" | ||||
| @@ -90,9 +91,9 @@ common: | ||||
|     specified: "ダイレクト" | ||||
|     specified-desc: "今から言うユーザー以外に見せんとってや" | ||||
|     private: "非公開" | ||||
|     local-public: "公開 (ローカルのみ)" | ||||
|     local-home: "ホーム (ローカルのみ)" | ||||
|     local-followers: "フォロワー (ローカルのみ)" | ||||
|     local-public: "公開 (ローカルだけ)" | ||||
|     local-home: "ホーム (ローカルだけ)" | ||||
|     local-followers: "フォロワー (ローカルだけ)" | ||||
|   note-placeholders: | ||||
|     a: "今なにしてん?" | ||||
|     b: "何かあったんか?" | ||||
| @@ -109,16 +110,17 @@ common: | ||||
|   my-token-regenerated: "あんさんのトークンが更新されたらしいわ。すまんがとりあえずサインアウトすんで。" | ||||
|   i-like-sushi: "寿司(のほうがプリンよりむしろ)ウマい、タコ焼きはあらへんけど。" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示や!" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストをつけんで!" | ||||
|   use-white-black-reversi-stones: "リバーシに白黒の石を使う" | ||||
|   verified-user: "アメちゃん付きアカウント" | ||||
|   disable-animated-mfm: "投稿内のちょろちょろ動いてんのを止める" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "閲覧注意?見せたらあかん?そんなん知らんわ、見せろや!" | ||||
|   always-mark-nsfw: "わからんからとりあえずメディアは見せたらあかん" | ||||
|   show-full-acct: "ユーザー名のホストも出したる" | ||||
|   show-via: "viaを表示する" | ||||
|   show-via: "viaを見せる" | ||||
|   reduce-motion: "UI、動き過ぎや、静かにしてや" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   use-os-default-emojis: "OS標準の絵文字を使用" | ||||
|   use-os-default-emojis: "OSにもとから入っとる絵文字使う" | ||||
|   do-not-use-in-production: '開発ビルドや。本番環境で使わんといて!知らんで!' | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
| @@ -131,9 +133,9 @@ common: | ||||
|     drawn: "おあいこ" | ||||
|     my-turn: "あんさんのターンや" | ||||
|     opponent-turn: "相手のターンや" | ||||
|     turn-of: "{name}のターンです" | ||||
|     turn-of: "{name}のターンや" | ||||
|     past-turn-of: "{name}のターン" | ||||
|     won: "{name}の勝ち" | ||||
|     won: "{name}の勝ちやで!" | ||||
|     black: "黒" | ||||
|     white: "白" | ||||
|     total: "合計" | ||||
| @@ -157,14 +159,14 @@ common: | ||||
|     polls: "アンケート" | ||||
|     post-form: "投稿フォーム" | ||||
|     server: "サーバー情報" | ||||
|     donation: "寄付のお願い" | ||||
|     nav: "ナビゲーション" | ||||
|     tips: "ヒント" | ||||
|     hashtags: "ハッシュタグ" | ||||
|   dev: "アプリの作成あかんかったわ。もっぺんやってみて。" | ||||
|   ai-chan-kawaii: "藍ちゃめっさべっぴんさんや" | ||||
|   you: "あなた" | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{name}</i>があなたのアカウントにアクセスすることを許可しますか?" | ||||
|   share-access: "あんたのアカウントに<i>{name}</i>がアクセスしようとしてるで?ええか?" | ||||
|   permission-ask: "このアプリは次の権限を要求してんで:" | ||||
|   account-read: "アカウントの情報を見させてもらうで。" | ||||
|   account-write: "アカウントの情報を操作させてもらうで。" | ||||
| @@ -295,6 +297,8 @@ common/views/components/theme.vue: | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "もうええわ" | ||||
|   show: "見たいやろ?" | ||||
|   chars: "{count}文字" | ||||
|   files: "{count}ファイル" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "ユーザーを探す" | ||||
|   you: "あんさん" | ||||
| @@ -352,7 +356,7 @@ common/views/components/emoji-picker.vue: | ||||
|   custom-emoji: "カスタム絵文字" | ||||
|   people: "人" | ||||
|   animals-and-nature: "動物&自然" | ||||
|   food-and-drink: "食べ物&飲み物" | ||||
|   food-and-drink: "食いもん&飲みもん" | ||||
|   activity: "アクティビティ" | ||||
|   travel-and-places: "場所" | ||||
|   objects: "物" | ||||
| @@ -399,27 +403,25 @@ common/views/components/stream-indicator.vue: | ||||
|   connecting: "つないどるで" | ||||
|   reconnecting: "つなぎ直すで" | ||||
|   connected: "つないだわ" | ||||
| common/views/components/twitter-setting.vue: | ||||
|   description: "あんさんがつことるTwitterアカウントをMisskeyアカウントに接続しとくと、あんさんのプロフィールにTwitterアカウント情報が表示されるようになったり、Twitterをつこた便利なサインインが使えるようになったりすんで。" | ||||
|   connected-to: "次のTwitterアカウントに接続されとるで" | ||||
|   detail: "詳細..." | ||||
|   reconnect: "つなぎ直す" | ||||
|   connect: "Twitterと接続する" | ||||
|   disconnect: "さいならする" | ||||
| common/views/components/integration-settings.vue: | ||||
|   title: "サービス連携" | ||||
|   connect: "つなげる" | ||||
|   disconnect: "接続をほかす" | ||||
|   connected-to: "このアカウントと繋がっとるで" | ||||
| common/views/components/github-setting.vue: | ||||
|   description: "お使いのGitHubアカウントをお使いのMisskeyアカウントに接続しておくと、プロフィールでGitHubアカウント情報が表示されるようになったり、GitHubを用いた便利なサインインを利用できるようになります。" | ||||
|   connected-to: "次のGitHubアカウントに接続されています" | ||||
|   detail: "詳細..." | ||||
|   reconnect: "再接続する" | ||||
|   description: "あんたがつことるTwitterアカウントをMisskeyアカウントに接続しとくと、あんさんのプロフィールにTwitterアカウント情報が表示されるようになったり、Twitterを使うた便利なサインインが使えるようになったりすんで。" | ||||
|   connected-to: "次のGitHubアカウントに接続されとるで" | ||||
|   detail: "くわしく..." | ||||
|   reconnect: "つなぎ直す" | ||||
|   connect: "GitHubと接続する" | ||||
|   disconnect: "切断する" | ||||
|   disconnect: "接続をほかす" | ||||
| common/views/components/discord-setting.vue: | ||||
|   description: "お使いのDiscordアカウントをお使いのMisskeyアカウントに接続しておくと、プロフィールでDiscordアカウント情報が表示されるようになったり、Discordを用いた便利なサインインを利用できるようになります。" | ||||
|   connected-to: "次のDiscordアカウントに接続されています" | ||||
|   detail: "詳細..." | ||||
|   reconnect: "再接続する" | ||||
|   description: "あんたがつことるDiscordアカウントをMisskeyアカウントに接続しとくと、あんさんのプロフィールにDiscordアカウント情報が表示されるようになったり、Discordを使うた便利なサインインが使えるようになったりすんで。" | ||||
|   connected-to: "次のDiscordアカウントに接続されとるで" | ||||
|   detail: "くわしく..." | ||||
|   reconnect: "つなぎ直す" | ||||
|   connect: "Discordと接続する" | ||||
|   disconnect: "切断する" | ||||
|   disconnect: "接続をほかす" | ||||
| common/views/components/uploader.vue: | ||||
|   waiting: "待っとる" | ||||
| common/views/components/visibility-chooser.vue: | ||||
| @@ -431,19 +433,27 @@ common/views/components/visibility-chooser.vue: | ||||
|   specified: "ダイレクト" | ||||
|   specified-desc: "今から言うユーザー以外に見せんとってや" | ||||
|   private: "非公開" | ||||
|   local-public: "公開 (ローカルのみ)" | ||||
|   local-public-desc: "リモートへは公開しない" | ||||
|   local-home: "ホーム (ローカルのみ)" | ||||
|   local-followers: "フォロワー (ローカルのみ)" | ||||
|   local-public: "公開 (ローカルだけ)" | ||||
|   local-public-desc: "リモートには見せへん" | ||||
|   local-home: "ホーム (ローカルだけ)" | ||||
|   local-followers: "フォロワー (ローカルだけ)" | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "流行は自分で作るんや" | ||||
| common/views/components/language-settings.vue: | ||||
|   title: "表示言語" | ||||
|   pick-language: "言語選んでや" | ||||
|   recommended: "これええで" | ||||
|   auto: "勝手にやる" | ||||
|   specify-language: "言語選びや" | ||||
|   info: "ページもっぺん読み込んだら反映したるで。" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   language: "言語" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
| @@ -457,6 +467,10 @@ common/views/components/profile-editor.vue: | ||||
|   saved: "プロフィールを保存したで" | ||||
|   uploading: "アップロードしとります" | ||||
|   upload-failed: "これアップロードでけへんわ" | ||||
|   email: "メール設定" | ||||
|   email-address: "メールアドレス" | ||||
|   email-verified: "このメールアドレスOKや!" | ||||
|   email-not-verified: "メールアドレスが確認されとらん。メールボックスもっぺん見てくれへん?" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "見てみるわ…" | ||||
|   no-broadcasts: "お知らせはあらへんで" | ||||
| @@ -469,9 +483,6 @@ common/views/widgets/calendar.vue: | ||||
|   today: "今日:" | ||||
|   this-month: "今月:" | ||||
|   this-year: "今年:" | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "寄付のお願い" | ||||
|   text: "Misskeyの運営にはドメイン、サーバー等のコストが掛かるんや。Misskeyは広告を掲載したりせんから、収入を皆様からの寄付に頼ってますねん。もし興味があるなら、{}までご連絡よろしゅう頼んます。ご協力おおきに。" | ||||
| common/views/widgets/photo-stream.vue: | ||||
|   title: "フォトストリーム" | ||||
|   no-photos: "写真はあらへんで" | ||||
| @@ -512,6 +523,8 @@ common/views/widgets/tips.vue: | ||||
|   tips-line23: "ウチのタコちゃんかわええやろ…今の突っ込むところや!" | ||||
|   tips-line24: "Misskeyは2014年にサービスを開始したんよ" | ||||
|   tips-line25: "対応ブラウザやったらMisskeyを開いとらんでも通知を受け取れんで" | ||||
| common/views/pages/404.vue: | ||||
|   page-not-found: "ページが見つかりませんでした" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   following: "フォローしとる" | ||||
| @@ -540,7 +553,7 @@ desktop/views/components/activity.vue: | ||||
|   title: "アクティビティ" | ||||
|   toggle: "表示変える" | ||||
| desktop/views/components/calendar.vue: | ||||
|   title: "{year}年 {month}月" | ||||
|   title: "{year}年 {month} 月" | ||||
|   prev: "前の月" | ||||
|   next: "次の月" | ||||
|   go: "クリックしてタイムリープ" | ||||
| @@ -682,7 +695,7 @@ desktop/views/components/post-form.vue: | ||||
|   create-poll: "アンケートを作成" | ||||
|   text-remain: "残り{}文字" | ||||
|   recent-tags: "最近のタグ" | ||||
|   local-only-message: "この投稿はローカルにのみ公開されます" | ||||
|   local-only-message: "この投稿はローカルだけ公開されるで" | ||||
|   click-to-tagging: "クリックでタグ付け" | ||||
|   visibility: "公開範囲" | ||||
|   geolocation-alert: "あんさんのつことる端末は位置情報に対応しとらんみたいやわ、知らんけど。" | ||||
| @@ -731,6 +744,8 @@ desktop/views/components/settings.vue: | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "もとからの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲おぼえといて" | ||||
|   web-search-engine: "ウェブ検索エンジン" | ||||
|   web-search-engine-desc: "例: https://www.google.com/?#q?{{query}}" | ||||
|   auto-popout: "ウィンドウの自動ポップアウト" | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトすんで。この設定はブラウザに記憶されんで。" | ||||
|   advanced: "もっと設定" | ||||
| @@ -750,7 +765,6 @@ desktop/views/components/settings.vue: | ||||
|   circle-icons: "アイコンもタコ焼きも丸いやんな?" | ||||
|   contrasted-acct: "ユーザー名ようわからんし見やすしといて" | ||||
|   post-form-on-timeline: "タイムラインの上の方で投稿できるようにせえへん?" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示すんで" | ||||
|   show-clock-on-header: "右上をカリヨン広場にする(時計表示)" | ||||
|   show-reply-target: "どこにリプライするんや見せて" | ||||
|   timeline: "タイムライン" | ||||
| @@ -758,21 +772,22 @@ desktop/views/components/settings.vue: | ||||
|   show-renoted-my-notes: "わしのRenoteもタイムライン載せてくれや" | ||||
|   show-local-renotes: "ローカル投稿のRenoteも見たいんや" | ||||
|   show-maps: "地図勝手にバァーって開いてくれ" | ||||
|   remain-deleted-note: "削除された投稿を表示し続ける" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   remain-deleted-note: "削除された投稿も表示しっぱなしにする" | ||||
|   deck-column-align: "デッキのカラムの配置" | ||||
|   deck-column-align-center: "真ん中" | ||||
|   deck-column-align-left: "左" | ||||
|   deck-column-align-flexible: "フレキシブル" | ||||
|   deck-column-width: "デッキのカラムの幅" | ||||
|   deck-column-width-narrow: "狭" | ||||
|   deck-column-width-narrower: "やや狭" | ||||
|   deck-column-width-normal: "普通" | ||||
|   deck-column-width-wider: "やや広" | ||||
|   deck-column-width-wide: "広" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンド鳴らす" | ||||
|   enable-sounds-desc: "投稿やメッセージもろたとき、音鳴らしたるわ。大丈夫や、この設定はブラウザが覚えてくれとる。" | ||||
|   volume: "ボリューム" | ||||
|   test: "テスト" | ||||
|   language: "言語" | ||||
|   pick-language: "言語選んでや" | ||||
|   recommended: "おすすめ" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語選んでくれ" | ||||
|   language-desc: "変更はページの再度読み込み後に反映されんで。" | ||||
|   cache: "キャッシュ" | ||||
|   clean-cache: "お掃除" | ||||
|   cache-warn: "お掃除するとな、ブラウザが覚えてくれとるアカウントのあれこれや書きかけの投稿・返信・メッセージや設定情報なんかのデータが全部飛んでいくんや。これやったらページ再読込しといてな。" | ||||
| @@ -835,7 +850,7 @@ common/views/components/api-settings.vue: | ||||
|     title: 'APIコンソール' | ||||
|     endpoint: 'エンドポイント' | ||||
|     parameter: 'パラメータ' | ||||
|     credential-info: "「i」パラメータは自動で付与されます。" | ||||
|     credential-info: "「i」パラメータは勝手に付くで。" | ||||
|     send: '送る' | ||||
|     sending: '応答待っとる' | ||||
|     response: 'こんなん返ってきたわ' | ||||
| @@ -852,8 +867,8 @@ common/views/components/mute-and-block.vue: | ||||
|   no-muted-users: "ミュートしとるユーザーはおらんで" | ||||
|   no-blocked-users: "ブロックしとるユーザーはおらんで" | ||||
|   word-mute: "ワードミュート" | ||||
|   muted-words: "ミュートされたキーワード" | ||||
|   muted-words-description: "スペースで区切るとAND指定になり、改行で区切るとOR指定になります" | ||||
|   muted-words: "ミュートしとるキーワード" | ||||
|   muted-words-description: "スペースで区切るとAND指定で、改行で区切るとOR指定や" | ||||
|   save: "保存" | ||||
| common/views/components/password-settings.vue: | ||||
|   reset: "パスワード変える" | ||||
| @@ -862,11 +877,17 @@ common/views/components/password-settings.vue: | ||||
|   enter-new-password-again: "もっぺん入れてや" | ||||
|   not-match: "パスワードがおうとらん" | ||||
|   changed: "パスワード変えたわ" | ||||
|   failed: "パスワード変更に失敗しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は見せられへんわ" | ||||
|   deleted: "この投稿なんか無くなってもうたわ" | ||||
|   media-count: "{}つのメディア" | ||||
|   poll: "アンケート" | ||||
| desktop/views/components/settings.tags.vue: | ||||
|   title: "タグ" | ||||
|   query: "クエリ (省略可)" | ||||
|   add: "追加" | ||||
|   save: "保存" | ||||
| desktop/views/components/taskmanager.vue: | ||||
|   title: "タスクマネージャ" | ||||
| desktop/views/components/timeline.vue: | ||||
| @@ -949,48 +970,65 @@ admin/views/instance.vue: | ||||
|   instance-description: "インスタンスの紹介" | ||||
|   host: "ホスト" | ||||
|   banner-url: "バナー画像URL" | ||||
|   error-image-url: "エラー画像URL" | ||||
|   languages: "インスタンスの対象言語" | ||||
|   languages-desc: "スペースで区切って複数設定できます。" | ||||
|   languages-desc: "スペースで区切って複数設定できるで。" | ||||
|   maintainer-config: "管理者情報" | ||||
|   maintainer-name: "管理者名" | ||||
|   maintainer-email: "管理者の連絡先" | ||||
|   drive-config: "ドライブの設定" | ||||
|   cache-remote-files: "リモートのファイルをキャッシュする" | ||||
|   cache-remote-files-desc: "この設定を無効にすると、リモートファイルをキャッシュせず直リンクするようになります。そのためサーバーのストレージを節約できますが、プライバシー設定で直リンクを無効にしているユーザーにはファイルが見えなくなったり、サムネイルが生成されないので通信量が増加します。通常はこの設定をオンにしておくことをおすすめします。" | ||||
|   cache-remote-files-desc: "この設定を無効にすると、リモートファイルをこっちで保管せずに直接リンク張るようになるで。サーバーのストレージは軽くやろうけど、プライバシー設定で直リンクを向こうにしとるユーザーはファイルが見れへんし、サムネイルが無いから通信量が増えたりするから、普通はオンにしといてな。" | ||||
|   local-drive-capacity-mb: "ローカルユーザーひとりあたりのドライブ容量" | ||||
|   remote-drive-capacity-mb: "リモートユーザーひとりあたりのドライブ容量" | ||||
|   mb: "メガバイト単位" | ||||
|   recaptcha-config: "reCAPTCHAの設定" | ||||
|   recaptcha-info: "reCAPTCHAを有効にする場合、reCAPTCHAトークンを取得する必要があります。https://www.google.com/recaptcha/intro/ にアクセスしてトークンを取得してください。" | ||||
|   recaptcha-info: "reCAPTCHAを有効にするにはreCAPTCHAトークンが要るで。https://www.google.com/recaptcha/intro/ にアクセスしてトークンを取得してな。" | ||||
|   enable-recaptcha: "reCAPTCHAを有効にする" | ||||
|   recaptcha-site-key: "reCAPTCHA site key" | ||||
|   recaptcha-secret-key: "reCAPTCHA secret key" | ||||
|   twitter-integration-config: "Twitter連携の設定" | ||||
|   twitter-integration-info: "コールバックURLは /api/tw/cb に設定します。" | ||||
|   twitter-integration-info: "コールバックURLは {url} に設定してや。" | ||||
|   enable-twitter-integration: "Twitter連携を有効にする" | ||||
|   twitter-integration-consumer-key: "Consumer key" | ||||
|   twitter-integration-consumer-secret: "Consumer secret" | ||||
|   github-integration-config: "GitHub連携の設定" | ||||
|   github-integration-info: "コールバックURLは /api/gh/cb に設定します。" | ||||
|   enable-github-integration: "GitHub連携を有効にする" | ||||
|   github-integration-info: "コールバックURLは {url} に設定してや。" | ||||
|   enable-github-integration: "GitHub連携を使えるようにする" | ||||
|   github-integration-client-id: "Client ID" | ||||
|   github-integration-client-secret: "Client Secret" | ||||
|   discord-integration-config: "Discord連携の設定" | ||||
|   discord-integration-info: "コールバックURLは /api/dc/cb に設定します。" | ||||
|   discord-integration-info: "コールバックURLは {url} に設定してや。" | ||||
|   enable-discord-integration: "Discord連携を有効にする" | ||||
|   discord-integration-client-id: "Client ID" | ||||
|   discord-integration-client-secret: "Client Secret" | ||||
|   proxy-account-config: "プロキシアカウントの設定" | ||||
|   proxy-account-info: "プロキシアカウントは、特定の条件下でユーザーのリモートフォローを代行するアカウントです。例えば、ユーザーがリモートユーザーをリストに入れたとき、リストに入れられたユーザーを誰もフォローしていないとアクティビティがサーバーに配達されないため、代わりにプロキシアカウントがフォローするようにします。" | ||||
|   proxy-account-info: "プロキシアカウントは、代わりにフォローしてくれるアカウントや。例えば、551に豚まんが無いときやったり、ユーザーがリモートユーザーをアカウントに入れたとき、リストに入れられたユーザーが誰からもフォローされてないと寂しいやん。寂しいし、アクティビティも配達されへんから、プロキシアカウントがフォローしてくれるで。ええやつやん…" | ||||
|   proxy-account-username: "プロキシアカウントのユーザー名" | ||||
|   proxy-account-username-desc: "プロキシとして使用するアカウントのユーザー名を指定してください。" | ||||
|   proxy-account-warn: "アカウントは自動で作られないため、そのユーザー名のアカウントを予め作成しておく必要があります。" | ||||
|   proxy-account-username-desc: "プロキシとして使用するアカウントのユーザー名を指定してや" | ||||
|   proxy-account-warn: "アカウント作るんはあんたがやってや。あんたのおかんもMisskeyもやってくれへんで。" | ||||
|   max-note-text-length: "投稿の最大文字数" | ||||
|   disable-registration: "ユーザー登録の受付を停止する" | ||||
|   disable-local-timeline: "ローカルタイムラインを無効にする" | ||||
|   invite: "招待" | ||||
|   disable-registration: "ユーザー登録の受付を止める" | ||||
|   disable-local-timeline: "ローカルタイムラインを使えんようにする" | ||||
|   invite: "来てや" | ||||
|   save: "保存" | ||||
|   saved: "保存しました" | ||||
|   saved: "保存したで!" | ||||
|   user-recommendation-config: "このユーザーええで" | ||||
|   enable-external-user-recommendation: "外部ユーザーレコメンデーションを使えるようにする" | ||||
|   external-user-recommendation-engine: "エンジン" | ||||
|   external-user-recommendation-engine-desc: "例: https://vinayaka.distsn.org/cgi-bin/vinayaka-user-match-misskey-api.cgi?{{host}}+{{user}}+{{limit}}+{{offset}}" | ||||
|   external-user-recommendation-timeout: "タイムアウト" | ||||
|   external-user-recommendation-timeout-desc: "ミリ秒単位 (例: 300000)" | ||||
|   email-config: "メールサーバーの設定" | ||||
|   email-config-info: "メールアドレス確認やパスワードリセットの際に使うで。" | ||||
|   enable-email: "メール配信を有効にする" | ||||
|   email: "メールアドレス" | ||||
|   smtp-secure: "SMTP接続に暗黙的なSSL/TLSを使用する" | ||||
|   smtp-secure-info: "STARTTLS使用時はオフにします。" | ||||
|   smtp-host: "SMTPホスト" | ||||
|   smtp-port: "SMTPポート" | ||||
|   smtp-user: "SMTPユーザー" | ||||
|   smtp-pass: "SMTPパスワード" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
| @@ -1016,19 +1054,50 @@ admin/views/charts.vue: | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| admin/views/drive.vue: | ||||
|   sort: | ||||
|     title: "ソート" | ||||
|     createdAtAsc: "アップロード日時が古い順" | ||||
|     createdAtDesc: "アップロード日時が新しい順" | ||||
|     sizeAsc: "サイズが小さい順" | ||||
|     sizeDesc: "サイズが大きい順" | ||||
|   origin: | ||||
|     title: "オリジン" | ||||
|     combined: "ローカル+リモート" | ||||
|     local: "ローカル" | ||||
|     remote: "リモート" | ||||
|   delete: "削除" | ||||
|   deleted: "削除しました" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   operation: "操作" | ||||
|   username-or-userid: "ユーザー名またはユーザーID" | ||||
|   user-not-found: "ユーザーが見つからへん!" | ||||
|   lookup: "照会" | ||||
|   reset-password: "パスワードをリセット" | ||||
|   password-updated: "パスワードは現在「{password} 」やで" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|   users: | ||||
|     title: "ユーザー" | ||||
|     sort: | ||||
|       title: "ソート" | ||||
|       createdAtAsc: "登録日時が古い順" | ||||
|       createdAtDesc: "登録日時が新しい順" | ||||
|       updatedAtAsc: "更新日時が古い順" | ||||
|       updatedAtDesc: "更新日時が新しい順" | ||||
|     origin: | ||||
|       title: "オリジン" | ||||
|       combined: "ローカル+リモート" | ||||
|       local: "ローカル" | ||||
|       remote: "リモート" | ||||
|     createdAt: "登録日時" | ||||
|     updatedAt: "更新日時" | ||||
| admin/views/moderators.vue: | ||||
|   add-moderator: | ||||
|     title: "モデレーターの登録" | ||||
| @@ -1122,8 +1191,8 @@ desktop/views/pages/user/user.profile.vue: | ||||
|   muted: "ミュートしとるで" | ||||
|   unmute: "ミュート解除" | ||||
|   block: "ブロックする" | ||||
|   unblock: "ブロック解除" | ||||
|   block-confirm: "このユーザーをブロックしますか?" | ||||
|   unblock: "ブロックやめたる" | ||||
|   block-confirm: "このユーザーをブロックしてええか?" | ||||
|   push-to-a-list: "リストに追加" | ||||
|   list-pushed: "{user}を{list}に追加したで。" | ||||
| desktop/views/pages/user/user.header.vue: | ||||
| @@ -1199,11 +1268,11 @@ mobile/views/components/media-video.vue: | ||||
|   sensitive: "ちょっと見せられへんわ" | ||||
|   click-to-show: "押してみ、見せたるわ" | ||||
| common/views/components/follow-button.vue: | ||||
|   following: "フォロー中" | ||||
|   following: "フォローしとる" | ||||
|   follow: "フォロー" | ||||
|   request-pending: "フォロー許可待ち" | ||||
|   follow-processing: "フォロー処理中" | ||||
|   follow-request: "フォロー申請" | ||||
|   request-pending: "フォロー許してくれるん待っとる" | ||||
|   follow-processing: "今フォロー処理やっとる‥" | ||||
|   follow-request: "フォローさせてや!言うてみる" | ||||
| mobile/views/components/friends-maker.vue: | ||||
|   title: "おもろそうやな" | ||||
|   empty: "おすすめのユーザーはおらん。" | ||||
| @@ -1289,7 +1358,7 @@ mobile/views/pages/home.vue: | ||||
|   mentions: "あんた宛て" | ||||
|   messages: "メッセージ" | ||||
| mobile/views/pages/tag.vue: | ||||
|   no-posts-found: "ハッシュタグ「{q}」が付けられた投稿は見つかりませんでした。" | ||||
|   no-posts-found: "ハッシュタグ「{q}」が付けられた投稿はあらへんかった。" | ||||
| mobile/views/pages/welcome.vue: | ||||
|   signup: "新規登録" | ||||
| mobile/views/pages/widgets.vue: | ||||
| @@ -1316,16 +1385,11 @@ mobile/views/pages/games/reversi.vue: | ||||
|   reversi: "リバーシ" | ||||
| mobile/views/pages/search.vue: | ||||
|   search: "探す" | ||||
|   not-found: "「{q}」に関する投稿は見つかりませんでした。" | ||||
|   not-found: "ワイは「{q}」なんて投稿知らんわ、無いんちゃう?知らんけど。" | ||||
| mobile/views/pages/selectdrive.vue: | ||||
|   select-file: "ファイル選んでや" | ||||
| mobile/views/pages/settings.vue: | ||||
|   signed-in-as: "あんたは橋の下で拾った{}や!" | ||||
|   lang: "言語" | ||||
|   lang-tip: "ページもっぺん読み込んだら反映したるで。" | ||||
|   recommended: "これええで" | ||||
|   auto: "勝手にやる" | ||||
|   specify-language: "言語選びや" | ||||
|   design: "見た感じ" | ||||
|   dark-mode: "ナイトゲームや!" | ||||
|   i-am-under-limited-internet: "電波と阪神がザコいんや" | ||||
| @@ -1348,21 +1412,11 @@ mobile/views/pages/settings.vue: | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "もとからの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲おぼえといて" | ||||
|   web-search-engine: "ウェブ検索エンジン" | ||||
|   web-search-engine-desc: "例: https://www.google.com/?#q?{{query}}" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグなんて要らんわ" | ||||
|   load-raw-images: "添付された画像もべっぴんさんのままにしといてな" | ||||
|   load-remote-media: "東京とか、リモートサーバーのメディアも見せてや" | ||||
|   twitter: "鳥さんとも連携や!" | ||||
|   twitter-connect: "鳥さん邪魔すんで" | ||||
|   twitter-reconnect: "もっぺん繋ぎ直すで" | ||||
|   twitter-disconnect: "邪魔するんやったら帰って" | ||||
|   github: "GitHub連携" | ||||
|   github-connect: "GitHubアカウントに接続する" | ||||
|   github-reconnect: "再接続する" | ||||
|   github-disconnect: "切断する" | ||||
|   discord: "Discord連携" | ||||
|   discord-connect: "Discordアカウントに接続する" | ||||
|   discord-reconnect: "再接続する" | ||||
|   discord-disconnect: "切断する" | ||||
|   update: "あんたのMisskeyいつのや?" | ||||
|   version: "バージョン:" | ||||
|   latest-version: "いっちゃん新しいやつ:" | ||||
| @@ -1388,10 +1442,13 @@ mobile/views/pages/user.vue: | ||||
|   media: "メディア" | ||||
|   is-suspended: "このユーザーはあかんわ。凍結されとる。" | ||||
|   mute: "ミュート" | ||||
|   unmute: "ミュート解除" | ||||
|   unmute: "ミュートやめたる" | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロックやめたる" | ||||
|   years-old: "{age}歳" | ||||
|   push-to-list: "リストに入れたる" | ||||
|   select-list: "リスト選んでや" | ||||
|   list-pushed: "{user}を{list}に追加したで" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "最近儲かりまっか?" | ||||
|   images: "画像" | ||||
| @@ -1416,21 +1473,21 @@ deck: | ||||
|   hybrid: "ソーシャル" | ||||
|   hashtag: "ハッシュタグ" | ||||
|   global: "グローバル" | ||||
|   mentions: "あなた宛て" | ||||
|   mentions: "あんた宛て" | ||||
|   direct: "ダイレクト投稿" | ||||
|   notifications: "通知" | ||||
|   list: "リスト" | ||||
|   swap-left: "左に移動" | ||||
|   swap-right: "右に移動" | ||||
|   swap-up: "上に移動" | ||||
|   swap-down: "下に移動" | ||||
|   remove: "カラムを削除" | ||||
|   add-column: "カラムを追加" | ||||
|   rename: "名前を変更" | ||||
|   stack-left: "左に重ねる" | ||||
|   pop-right: "右に出す" | ||||
|   swap-left: "左に移動や!" | ||||
|   swap-right: "右に移動や!" | ||||
|   swap-up: "上に移動や!" | ||||
|   swap-down: "下に移動や!" | ||||
|   remove: "カラムにさいなら" | ||||
|   add-column: "カラム増やす" | ||||
|   rename: "名前を変えるで" | ||||
|   stack-left: "左に重ねんで!" | ||||
|   pop-right: "右に出すで!" | ||||
| deck/deck.tl-column.vue: | ||||
|   is-media-only: "メディア投稿のみ" | ||||
|   is-media-only: "メディア投稿だけや" | ||||
|   is-media-view: "メディアビュー" | ||||
|   edit: "オプション" | ||||
| deck/deck.user-column.vue: | ||||
| @@ -1440,8 +1497,8 @@ deck/deck.user-column.vue: | ||||
|   images: "画像" | ||||
|   activity: "アクティビティ" | ||||
|   timeline: "タイムライン" | ||||
|   pinned-notes: "ピン留めされた投稿" | ||||
|   push-to-a-list: "リストに追加" | ||||
|   pinned-notes: "ピン留めしはった投稿" | ||||
|   push-to-a-list: "リストに入れたる" | ||||
| docs: | ||||
|   edit-this-page-on-github: "間違いや改善点を見つけましたか?" | ||||
|   edit-this-page-on-github-link: "このページをGitHubで編集" | ||||
|   | ||||
							
								
								
									
										2349
									
								
								locales/ko-KR.yml
									
									
									
									
									
								
							
							
						
						| @@ -26,6 +26,7 @@ common: | ||||
|   close: "閉じる" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   load-more: "もっと読み込む" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   got-it: "わかった" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
| @@ -109,9 +110,10 @@ common: | ||||
|   my-token-regenerated: "Je sleutel is gegenereerd; je wordt nu uitgelogd." | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   use-white-black-reversi-stones: "リバーシに白黒の石を使う" | ||||
|   verified-user: "公式アカウント" | ||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   show-full-acct: "ユーザー名のホストを省略しない" | ||||
| @@ -157,12 +159,12 @@ common: | ||||
|     polls: "アンケート" | ||||
|     post-form: "投稿フォーム" | ||||
|     server: "サーバー情報" | ||||
|     donation: "寄付のお願い" | ||||
|     nav: "ナビゲーション" | ||||
|     tips: "ヒント" | ||||
|     hashtags: "ハッシュタグ" | ||||
|   dev: "アプリの作成に失敗しました。再度お試しください。" | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
|   you: "あなた" | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{name}</i>があなたのアカウントにアクセスすることを許可しますか?" | ||||
|   permission-ask: "このアプリは次の権限を要求しています:" | ||||
| @@ -295,6 +297,8 @@ common/views/components/theme.vue: | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "隠す" | ||||
|   show: "もっと見る" | ||||
|   chars: "{count}文字" | ||||
|   files: "{count}ファイル" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "Gebruiker zoeken" | ||||
|   you: "Jij" | ||||
| @@ -399,13 +403,11 @@ common/views/components/stream-indicator.vue: | ||||
|   connecting: "Bezig met verbinden" | ||||
|   reconnecting: "Bezig met herverbinden" | ||||
|   connected: "Verbonden" | ||||
| common/views/components/twitter-setting.vue: | ||||
|   description: "Als je je Twitter-account verbindt met je Misskey-account, dan kun je je Twitter-accountinformatie terugzien op je profiel en kun je inloggen met Twitter." | ||||
|   connected-to: "Je bent verbonden met dit Twitter-account" | ||||
|   detail: "Details..." | ||||
|   reconnect: "Opnieuw verbinden" | ||||
|   connect: "Koppel je Twitter-account" | ||||
|   disconnect: "Verbinding verbreken" | ||||
| common/views/components/integration-settings.vue: | ||||
|   title: "サービス連携" | ||||
|   connect: "接続する" | ||||
|   disconnect: "切断する" | ||||
|   connected-to: "次のアカウントに接続されています" | ||||
| common/views/components/github-setting.vue: | ||||
|   description: "お使いのGitHubアカウントをお使いのMisskeyアカウントに接続しておくと、プロフィールでGitHubアカウント情報が表示されるようになったり、GitHubを用いた便利なサインインを利用できるようになります。" | ||||
|   connected-to: "次のGitHubアカウントに接続されています" | ||||
| @@ -438,12 +440,20 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/components/language-settings.vue: | ||||
|   title: "表示言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語を指定" | ||||
|   info: "変更はページの再度読み込み後に反映されます。" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   language: "言語" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
| @@ -457,6 +467,10 @@ common/views/components/profile-editor.vue: | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
|   email: "メール設定" | ||||
|   email-address: "メールアドレス" | ||||
|   email-verified: "メールアドレスが確認されました" | ||||
|   email-not-verified: "メールアドレスが確認されていません。メールボックスをご確認ください。" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "Bezig met ophalen" | ||||
|   no-broadcasts: "Geen uitzendingen" | ||||
| @@ -469,9 +483,6 @@ common/views/widgets/calendar.vue: | ||||
|   today: "今日:" | ||||
|   this-month: "今月:" | ||||
|   this-year: "今年:" | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "Donatie" | ||||
|   text: "Om Misskey draaiende te houden, geven we geld uit aan onze domeinnaam, servers, enz. We maken hier geen winst op, dus we zouden het fijn vinden als je een donatie wilt doen. Neem in dat geval contact op via {}. Bedankt voor je bijdrage!" | ||||
| common/views/widgets/photo-stream.vue: | ||||
|   title: "Fotostream" | ||||
|   no-photos: "Geen foto's" | ||||
| @@ -512,6 +523,8 @@ common/views/widgets/tips.vue: | ||||
|   tips-line23: "まゆかわいいよまゆ" | ||||
|   tips-line24: "Misskeyは2014年にサービスを開始しました" | ||||
|   tips-line25: "対応ブラウザではMisskeyを開いていなくても通知を受け取れます" | ||||
| common/views/pages/404.vue: | ||||
|   page-not-found: "ページが見つかりませんでした" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   following: "フォロー中" | ||||
| @@ -731,6 +744,8 @@ desktop/views/components/settings.vue: | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   web-search-engine: "ウェブ検索エンジン" | ||||
|   web-search-engine-desc: "例: https://www.google.com/?#q={{query}}" | ||||
|   auto-popout: "Venster automatisch uitvouwen" | ||||
|   auto-popout-desc: "Venster uitvouwen, indien mogelijk. Deze instelling wordt opgeslagen in je browser." | ||||
|   advanced: "Geavanceerde instellingen" | ||||
| @@ -750,7 +765,6 @@ desktop/views/components/settings.vue: | ||||
|   circle-icons: "Ronde pictogrammen gebruiken" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   post-form-on-timeline: "Berichtformulier boven de tijdlijn tonen" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "Antwoord-knop tonen" | ||||
|   timeline: "タイムライン" | ||||
| @@ -759,20 +773,21 @@ desktop/views/components/settings.vue: | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "Kaart tonen" | ||||
|   remain-deleted-note: "削除された投稿を表示し続ける" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align: "デッキのカラムの配置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   deck-column-align-flexible: "フレキシブル" | ||||
|   deck-column-width: "デッキのカラムの幅" | ||||
|   deck-column-width-narrow: "狭" | ||||
|   deck-column-width-narrower: "やや狭" | ||||
|   deck-column-width-normal: "普通" | ||||
|   deck-column-width-wider: "やや広" | ||||
|   deck-column-width-wide: "広" | ||||
|   sound: "Geluid" | ||||
|   enable-sounds: "Geluid inschakelen" | ||||
|   enable-sounds-desc: "Een geluid afspelen bij het ontvangen van een bericht. Deze instelling wordt opgeslagen in je browser." | ||||
|   volume: "Volume" | ||||
|   test: "Testen" | ||||
|   language: "Taal" | ||||
|   pick-language: "Selecteer een taal" | ||||
|   recommended: "Aanbevolen" | ||||
|   auto: "Automatisch" | ||||
|   specify-language: "Taal opgeven" | ||||
|   language-desc: "Je moet de pagina herladen om de wijzigingen toe te passen." | ||||
|   cache: "Cache" | ||||
|   clean-cache: "Opschonen" | ||||
|   cache-warn: "De cache van je accountinformatie/berichten/antwoorden/instellingen wordt verwijderd. Je moet de pagina herladen na het opschonen." | ||||
| @@ -862,11 +877,17 @@ common/views/components/password-settings.vue: | ||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||
|   not-match: "新しいパスワードが一致しません" | ||||
|   changed: "パスワードを変更しました" | ||||
|   failed: "パスワード変更に失敗しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   media-count: "{}つのメディア" | ||||
|   poll: "Peilingen" | ||||
| desktop/views/components/settings.tags.vue: | ||||
|   title: "タグ" | ||||
|   query: "クエリ (省略可)" | ||||
|   add: "追加" | ||||
|   save: "保存" | ||||
| desktop/views/components/taskmanager.vue: | ||||
|   title: "Taakbeheer" | ||||
| desktop/views/components/timeline.vue: | ||||
| @@ -949,6 +970,7 @@ admin/views/instance.vue: | ||||
|   instance-description: "インスタンスの紹介" | ||||
|   host: "ホスト" | ||||
|   banner-url: "バナー画像URL" | ||||
|   error-image-url: "エラー画像URL" | ||||
|   languages: "インスタンスの対象言語" | ||||
|   languages-desc: "スペースで区切って複数設定できます。" | ||||
|   maintainer-config: "管理者情報" | ||||
| @@ -966,17 +988,17 @@ admin/views/instance.vue: | ||||
|   recaptcha-site-key: "reCAPTCHA site key" | ||||
|   recaptcha-secret-key: "reCAPTCHA secret key" | ||||
|   twitter-integration-config: "Twitter連携の設定" | ||||
|   twitter-integration-info: "コールバックURLは /api/tw/cb に設定します。" | ||||
|   twitter-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-twitter-integration: "Twitter連携を有効にする" | ||||
|   twitter-integration-consumer-key: "Consumer key" | ||||
|   twitter-integration-consumer-secret: "Consumer secret" | ||||
|   github-integration-config: "GitHub連携の設定" | ||||
|   github-integration-info: "コールバックURLは /api/gh/cb に設定します。" | ||||
|   github-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-github-integration: "GitHub連携を有効にする" | ||||
|   github-integration-client-id: "Client ID" | ||||
|   github-integration-client-secret: "Client Secret" | ||||
|   discord-integration-config: "Discord連携の設定" | ||||
|   discord-integration-info: "コールバックURLは /api/dc/cb に設定します。" | ||||
|   discord-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-discord-integration: "Discord連携を有効にする" | ||||
|   discord-integration-client-id: "Client ID" | ||||
|   discord-integration-client-secret: "Client Secret" | ||||
| @@ -991,6 +1013,22 @@ admin/views/instance.vue: | ||||
|   invite: "招待" | ||||
|   save: "保存" | ||||
|   saved: "保存しました" | ||||
|   user-recommendation-config: "おすすめユーザー" | ||||
|   enable-external-user-recommendation: "外部ユーザーレコメンデーションを有効にする" | ||||
|   external-user-recommendation-engine: "エンジン" | ||||
|   external-user-recommendation-engine-desc: "例: https://vinayaka.distsn.org/cgi-bin/vinayaka-user-match-misskey-api.cgi?{{host}}+{{user}}+{{limit}}+{{offset}}" | ||||
|   external-user-recommendation-timeout: "タイムアウト" | ||||
|   external-user-recommendation-timeout-desc: "ミリ秒単位 (例: 300000)" | ||||
|   email-config: "メールサーバーの設定" | ||||
|   email-config-info: "メールアドレス確認やパスワードリセットの際に使われます。" | ||||
|   enable-email: "メール配信を有効にする" | ||||
|   email: "メールアドレス" | ||||
|   smtp-secure: "SMTP接続に暗黙的なSSL/TLSを使用する" | ||||
|   smtp-secure-info: "STARTTLS使用時はオフにします。" | ||||
|   smtp-host: "SMTPホスト" | ||||
|   smtp-port: "SMTPポート" | ||||
|   smtp-user: "SMTPユーザー" | ||||
|   smtp-pass: "SMTPパスワード" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
| @@ -1016,19 +1054,50 @@ admin/views/charts.vue: | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| admin/views/drive.vue: | ||||
|   sort: | ||||
|     title: "ソート" | ||||
|     createdAtAsc: "アップロード日時が古い順" | ||||
|     createdAtDesc: "アップロード日時が新しい順" | ||||
|     sizeAsc: "サイズが小さい順" | ||||
|     sizeDesc: "サイズが大きい順" | ||||
|   origin: | ||||
|     title: "オリジン" | ||||
|     combined: "ローカル+リモート" | ||||
|     local: "ローカル" | ||||
|     remote: "リモート" | ||||
|   delete: "削除" | ||||
|   deleted: "削除しました" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   operation: "操作" | ||||
|   username-or-userid: "ユーザー名またはユーザーID" | ||||
|   user-not-found: "ユーザーが見つかりません" | ||||
|   lookup: "照会" | ||||
|   reset-password: "パスワードをリセット" | ||||
|   password-updated: "パスワードは現在「{password}」です" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|   users: | ||||
|     title: "ユーザー" | ||||
|     sort: | ||||
|       title: "ソート" | ||||
|       createdAtAsc: "登録日時が古い順" | ||||
|       createdAtDesc: "登録日時が新しい順" | ||||
|       updatedAtAsc: "更新日時が古い順" | ||||
|       updatedAtDesc: "更新日時が新しい順" | ||||
|     origin: | ||||
|       title: "オリジン" | ||||
|       combined: "ローカル+リモート" | ||||
|       local: "ローカル" | ||||
|       remote: "リモート" | ||||
|     createdAt: "登録日時" | ||||
|     updatedAt: "更新日時" | ||||
| admin/views/moderators.vue: | ||||
|   add-moderator: | ||||
|     title: "モデレーターの登録" | ||||
| @@ -1321,11 +1390,6 @@ mobile/views/pages/selectdrive.vue: | ||||
|   select-file: "Kies een bestand" | ||||
| mobile/views/pages/settings.vue: | ||||
|   signed-in-as: "Ingelogd als {}" | ||||
|   lang: "Taal" | ||||
|   lang-tip: "Je moet de pagina herladen om de wijzigingen toe te passen." | ||||
|   recommended: "Aanbevolen" | ||||
|   auto: "Automatisch" | ||||
|   specify-language: "Taal opgeven" | ||||
|   design: "Ontwerp en weergave" | ||||
|   dark-mode: "Donkere modus" | ||||
|   i-am-under-limited-internet: "Ik heb beperkt internet" | ||||
| @@ -1348,21 +1412,11 @@ mobile/views/pages/settings.vue: | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   web-search-engine: "ウェブ検索エンジン" | ||||
|   web-search-engine-desc: "例: https://www.google.com/?#q={{query}}" | ||||
|   disable-via-mobile: "Zonder 'mobiele berichten'" | ||||
|   load-raw-images: "添付された画像を高画質で表示する" | ||||
|   load-remote-media: "リモートサーバーのメディアを表示する" | ||||
|   twitter: "Twitter-integratie" | ||||
|   twitter-connect: "Mijn Twitter-account verbinden" | ||||
|   twitter-reconnect: "Opnieuw verbinden" | ||||
|   twitter-disconnect: "Verbinding verbreken" | ||||
|   github: "GitHub連携" | ||||
|   github-connect: "GitHubアカウントに接続する" | ||||
|   github-reconnect: "再接続する" | ||||
|   github-disconnect: "切断する" | ||||
|   discord: "Discord連携" | ||||
|   discord-connect: "Discordアカウントに接続する" | ||||
|   discord-reconnect: "再接続する" | ||||
|   discord-disconnect: "切断する" | ||||
|   update: "Misskey-update" | ||||
|   version: "Huidige versie:" | ||||
|   latest-version: "Nieuwste versie:" | ||||
| @@ -1392,6 +1446,9 @@ mobile/views/pages/user.vue: | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
|   years-old: "{age}歳" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "Recente notities" | ||||
|   images: "Afbeeldingen" | ||||
|   | ||||
| @@ -26,6 +26,7 @@ common: | ||||
|   close: "Lukk" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   load-more: "もっと読み込む" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   got-it: "Skjønner!" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
| @@ -109,9 +110,10 @@ common: | ||||
|   my-token-regenerated: "Ditt synbol har blitt generert. Du vil nå bli utlogget." | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   use-white-black-reversi-stones: "リバーシに白黒の石を使う" | ||||
|   verified-user: "公式アカウント" | ||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   show-full-acct: "ユーザー名のホストを省略しない" | ||||
| @@ -157,12 +159,12 @@ common: | ||||
|     polls: "アンケート" | ||||
|     post-form: "投稿フォーム" | ||||
|     server: "サーバー情報" | ||||
|     donation: "寄付のお願い" | ||||
|     nav: "ナビゲーション" | ||||
|     tips: "Tips" | ||||
|     hashtags: "ハッシュタグ" | ||||
|   dev: "アプリの作成に失敗しました。再度お試しください。" | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
|   you: "あなた" | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{name}</i>があなたのアカウントにアクセスすることを許可しますか?" | ||||
|   permission-ask: "このアプリは次の権限を要求しています:" | ||||
| @@ -295,6 +297,8 @@ common/views/components/theme.vue: | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "Skjul" | ||||
|   show: "もっと見る" | ||||
|   chars: "{count}文字" | ||||
|   files: "{count}ファイル" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "ユーザーを探す" | ||||
|   you: "Du" | ||||
| @@ -399,13 +403,11 @@ common/views/components/stream-indicator.vue: | ||||
|   connecting: "Tilkobler" | ||||
|   reconnecting: "Kobler til på nytt" | ||||
|   connected: "Tilkoblet" | ||||
| common/views/components/twitter-setting.vue: | ||||
|   description: "お使いのTwitterアカウントをお使いのMisskeyアカウントに接続しておくと、プロフィールでTwitterアカウント情報が表示されるようになったり、Twitterを用いた便利なサインインを利用できるようになります。" | ||||
|   connected-to: "次のTwitterアカウントに接続されています" | ||||
|   detail: "Detaljer..." | ||||
|   reconnect: "Koble til på nytt" | ||||
|   connect: "Twitterと接続する" | ||||
|   disconnect: "Koble fra" | ||||
| common/views/components/integration-settings.vue: | ||||
|   title: "サービス連携" | ||||
|   connect: "接続する" | ||||
|   disconnect: "切断する" | ||||
|   connected-to: "次のアカウントに接続されています" | ||||
| common/views/components/github-setting.vue: | ||||
|   description: "お使いのGitHubアカウントをお使いのMisskeyアカウントに接続しておくと、プロフィールでGitHubアカウント情報が表示されるようになったり、GitHubを用いた便利なサインインを利用できるようになります。" | ||||
|   connected-to: "次のGitHubアカウントに接続されています" | ||||
| @@ -438,12 +440,20 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/components/language-settings.vue: | ||||
|   title: "表示言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語を指定" | ||||
|   info: "変更はページの再度読み込み後に反映されます。" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   language: "言語" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
| @@ -457,6 +467,10 @@ common/views/components/profile-editor.vue: | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
|   email: "メール設定" | ||||
|   email-address: "メールアドレス" | ||||
|   email-verified: "メールアドレスが確認されました" | ||||
|   email-not-verified: "メールアドレスが確認されていません。メールボックスをご確認ください。" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "Henter" | ||||
|   no-broadcasts: "お知らせはありません" | ||||
| @@ -469,9 +483,6 @@ common/views/widgets/calendar.vue: | ||||
|   today: "I dag:" | ||||
|   this-month: "Denne måneden:" | ||||
|   this-year: "Dette året:" | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "寄付のお願い" | ||||
|   text: "Misskeyの運営にはドメイン、サーバー等のコストが掛かります。Misskeyは広告を掲載したりしないため、収入を皆様からの寄付に頼っています。もしご興味があれば、{}までご連絡ください。ご協力ありがとうございます。" | ||||
| common/views/widgets/photo-stream.vue: | ||||
|   title: "フォトストリーム" | ||||
|   no-photos: "写真はありません" | ||||
| @@ -512,6 +523,8 @@ common/views/widgets/tips.vue: | ||||
|   tips-line23: "まゆかわいいよまゆ" | ||||
|   tips-line24: "Misskeyは2014年にサービスを開始しました" | ||||
|   tips-line25: "対応ブラウザではMisskeyを開いていなくても通知を受け取れます" | ||||
| common/views/pages/404.vue: | ||||
|   page-not-found: "ページが見つかりませんでした" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   following: "フォロー中" | ||||
| @@ -731,6 +744,8 @@ desktop/views/components/settings.vue: | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   web-search-engine: "ウェブ検索エンジン" | ||||
|   web-search-engine-desc: "例: https://www.google.com/?#q={{query}}" | ||||
|   auto-popout: "ウィンドウの自動ポップアウト" | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   advanced: "Avanserte innstillinger" | ||||
| @@ -750,7 +765,6 @@ desktop/views/components/settings.vue: | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   timeline: "タイムライン" | ||||
| @@ -759,20 +773,21 @@ desktop/views/components/settings.vue: | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   remain-deleted-note: "削除された投稿を表示し続ける" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align: "デッキのカラムの配置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   deck-column-align-flexible: "フレキシブル" | ||||
|   deck-column-width: "デッキのカラムの幅" | ||||
|   deck-column-width-narrow: "狭" | ||||
|   deck-column-width-narrower: "やや狭" | ||||
|   deck-column-width-normal: "普通" | ||||
|   deck-column-width-wider: "やや広" | ||||
|   deck-column-width-wide: "広" | ||||
|   sound: "Lyd" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||
|   volume: "Volum" | ||||
|   test: "Test" | ||||
|   language: "Språk" | ||||
|   pick-language: "Velg språk" | ||||
|   recommended: "Anbefalt" | ||||
|   auto: "Automatisk" | ||||
|   specify-language: "Angi språk" | ||||
|   language-desc: "変更はページの再度読み込み後に反映されます。" | ||||
|   cache: "Hurtiglager" | ||||
|   clean-cache: "クリーンアップ" | ||||
|   cache-warn: "クリーンアップを行うと、ブラウザに記憶されたアカウント情報のキャッシュ、書きかけの投稿・返信・メッセージ、およびその他のデータ(設定情報含む)が削除されます。クリーンアップを行った後はページを再度読み込みする必要があります。" | ||||
| @@ -862,11 +877,17 @@ common/views/components/password-settings.vue: | ||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||
|   not-match: "新しいパスワードが一致しません" | ||||
|   changed: "パスワードを変更しました" | ||||
|   failed: "パスワード変更に失敗しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   media-count: "{}つのメディア" | ||||
|   poll: "アンケート" | ||||
| desktop/views/components/settings.tags.vue: | ||||
|   title: "タグ" | ||||
|   query: "クエリ (省略可)" | ||||
|   add: "追加" | ||||
|   save: "保存" | ||||
| desktop/views/components/taskmanager.vue: | ||||
|   title: "タスクマネージャ" | ||||
| desktop/views/components/timeline.vue: | ||||
| @@ -949,6 +970,7 @@ admin/views/instance.vue: | ||||
|   instance-description: "インスタンスの紹介" | ||||
|   host: "ホスト" | ||||
|   banner-url: "バナー画像URL" | ||||
|   error-image-url: "エラー画像URL" | ||||
|   languages: "インスタンスの対象言語" | ||||
|   languages-desc: "スペースで区切って複数設定できます。" | ||||
|   maintainer-config: "管理者情報" | ||||
| @@ -966,17 +988,17 @@ admin/views/instance.vue: | ||||
|   recaptcha-site-key: "reCAPTCHA site key" | ||||
|   recaptcha-secret-key: "reCAPTCHA secret key" | ||||
|   twitter-integration-config: "Twitter連携の設定" | ||||
|   twitter-integration-info: "コールバックURLは /api/tw/cb に設定します。" | ||||
|   twitter-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-twitter-integration: "Twitter連携を有効にする" | ||||
|   twitter-integration-consumer-key: "Consumer key" | ||||
|   twitter-integration-consumer-secret: "Consumer secret" | ||||
|   github-integration-config: "GitHub連携の設定" | ||||
|   github-integration-info: "コールバックURLは /api/gh/cb に設定します。" | ||||
|   github-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-github-integration: "GitHub連携を有効にする" | ||||
|   github-integration-client-id: "Client ID" | ||||
|   github-integration-client-secret: "Client Secret" | ||||
|   discord-integration-config: "Discord連携の設定" | ||||
|   discord-integration-info: "コールバックURLは /api/dc/cb に設定します。" | ||||
|   discord-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-discord-integration: "Discord連携を有効にする" | ||||
|   discord-integration-client-id: "Client ID" | ||||
|   discord-integration-client-secret: "Client Secret" | ||||
| @@ -991,6 +1013,22 @@ admin/views/instance.vue: | ||||
|   invite: "招待" | ||||
|   save: "保存" | ||||
|   saved: "保存しました" | ||||
|   user-recommendation-config: "おすすめユーザー" | ||||
|   enable-external-user-recommendation: "外部ユーザーレコメンデーションを有効にする" | ||||
|   external-user-recommendation-engine: "エンジン" | ||||
|   external-user-recommendation-engine-desc: "例: https://vinayaka.distsn.org/cgi-bin/vinayaka-user-match-misskey-api.cgi?{{host}}+{{user}}+{{limit}}+{{offset}}" | ||||
|   external-user-recommendation-timeout: "タイムアウト" | ||||
|   external-user-recommendation-timeout-desc: "ミリ秒単位 (例: 300000)" | ||||
|   email-config: "メールサーバーの設定" | ||||
|   email-config-info: "メールアドレス確認やパスワードリセットの際に使われます。" | ||||
|   enable-email: "メール配信を有効にする" | ||||
|   email: "メールアドレス" | ||||
|   smtp-secure: "SMTP接続に暗黙的なSSL/TLSを使用する" | ||||
|   smtp-secure-info: "STARTTLS使用時はオフにします。" | ||||
|   smtp-host: "SMTPホスト" | ||||
|   smtp-port: "SMTPポート" | ||||
|   smtp-user: "SMTPユーザー" | ||||
|   smtp-pass: "SMTPパスワード" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
| @@ -1016,19 +1054,50 @@ admin/views/charts.vue: | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| admin/views/drive.vue: | ||||
|   sort: | ||||
|     title: "ソート" | ||||
|     createdAtAsc: "アップロード日時が古い順" | ||||
|     createdAtDesc: "アップロード日時が新しい順" | ||||
|     sizeAsc: "サイズが小さい順" | ||||
|     sizeDesc: "サイズが大きい順" | ||||
|   origin: | ||||
|     title: "オリジン" | ||||
|     combined: "ローカル+リモート" | ||||
|     local: "ローカル" | ||||
|     remote: "リモート" | ||||
|   delete: "削除" | ||||
|   deleted: "削除しました" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   operation: "操作" | ||||
|   username-or-userid: "ユーザー名またはユーザーID" | ||||
|   user-not-found: "ユーザーが見つかりません" | ||||
|   lookup: "照会" | ||||
|   reset-password: "パスワードをリセット" | ||||
|   password-updated: "パスワードは現在「{password}」です" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|   users: | ||||
|     title: "ユーザー" | ||||
|     sort: | ||||
|       title: "ソート" | ||||
|       createdAtAsc: "登録日時が古い順" | ||||
|       createdAtDesc: "登録日時が新しい順" | ||||
|       updatedAtAsc: "更新日時が古い順" | ||||
|       updatedAtDesc: "更新日時が新しい順" | ||||
|     origin: | ||||
|       title: "オリジン" | ||||
|       combined: "ローカル+リモート" | ||||
|       local: "ローカル" | ||||
|       remote: "リモート" | ||||
|     createdAt: "登録日時" | ||||
|     updatedAt: "更新日時" | ||||
| admin/views/moderators.vue: | ||||
|   add-moderator: | ||||
|     title: "モデレーターの登録" | ||||
| @@ -1321,11 +1390,6 @@ mobile/views/pages/selectdrive.vue: | ||||
|   select-file: "ファイルを選択" | ||||
| mobile/views/pages/settings.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   lang: "Språk" | ||||
|   lang-tip: "変更はページの再読み込み後に反映されます。" | ||||
|   recommended: "Anbefalt" | ||||
|   auto: "Automatisk" | ||||
|   specify-language: "Angi språk" | ||||
|   design: "デザインと表示" | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
| @@ -1348,21 +1412,11 @@ mobile/views/pages/settings.vue: | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   web-search-engine: "ウェブ検索エンジン" | ||||
|   web-search-engine-desc: "例: https://www.google.com/?#q={{query}}" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   load-raw-images: "添付された画像を高画質で表示する" | ||||
|   load-remote-media: "リモートサーバーのメディアを表示する" | ||||
|   twitter: "Twitter連携" | ||||
|   twitter-connect: "Twitterアカウントに接続する" | ||||
|   twitter-reconnect: "Koble til på nytt" | ||||
|   twitter-disconnect: "Koble fra" | ||||
|   github: "GitHub連携" | ||||
|   github-connect: "GitHubアカウントに接続する" | ||||
|   github-reconnect: "再接続する" | ||||
|   github-disconnect: "切断する" | ||||
|   discord: "Discord連携" | ||||
|   discord-connect: "Discordアカウントに接続する" | ||||
|   discord-reconnect: "再接続する" | ||||
|   discord-disconnect: "切断する" | ||||
|   update: "Misskey Update" | ||||
|   version: "バージョン:" | ||||
|   latest-version: "最新のバージョン:" | ||||
| @@ -1392,6 +1446,9 @@ mobile/views/pages/user.vue: | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
|   years-old: "{age}歳" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "Nylige innlegg" | ||||
|   images: "Bilder" | ||||
|   | ||||
| @@ -26,6 +26,7 @@ common: | ||||
|   close: "Fechar" | ||||
|   do-not-copy-paste: "Por favor, não digite ou copie o código aqui. A conta pode ser comprometida." | ||||
|   load-more: "もっと読み込む" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   got-it: "Entendi!" | ||||
|   customization-tips: | ||||
|     title: "Dicas de personalização" | ||||
| @@ -109,9 +110,10 @@ common: | ||||
|   my-token-regenerated: "Seu token foi recriado, portanto você foi deslogado." | ||||
|   i-like-sushi: "Eu prefiro sushi a pudim" | ||||
|   show-reversi-board-labels: "Mostrar etiquetas de colunas e linhas no Reversi" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   use-white-black-reversi-stones: "リバーシに白黒の石を使う" | ||||
|   verified-user: "Conta verificada" | ||||
|   disable-animated-mfm: "Desativar texto animado nas publicações" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   show-full-acct: "ユーザー名のホストを省略しない" | ||||
| @@ -157,12 +159,12 @@ common: | ||||
|     polls: "Enquetes" | ||||
|     post-form: "Formulário de publicação" | ||||
|     server: "Informações do servidor" | ||||
|     donation: "Doações" | ||||
|     nav: "Navegação" | ||||
|     tips: "Dicas" | ||||
|     hashtags: "Hashtags" | ||||
|   dev: "アプリの作成に失敗しました。再度お試しください。" | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
|   you: "あなた" | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{name}</i>があなたのアカウントにアクセスすることを許可しますか?" | ||||
|   permission-ask: "Este aplicativo precisa das seguintes permissões:" | ||||
| @@ -295,6 +297,8 @@ common/views/components/theme.vue: | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "隠す" | ||||
|   show: "もっと見る" | ||||
|   chars: "{count}文字" | ||||
|   files: "{count}ファイル" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "ユーザーを探す" | ||||
|   you: "Você" | ||||
| @@ -399,13 +403,11 @@ common/views/components/stream-indicator.vue: | ||||
|   connecting: "接続中" | ||||
|   reconnecting: "再接続中" | ||||
|   connected: "接続完了" | ||||
| common/views/components/twitter-setting.vue: | ||||
|   description: "お使いのTwitterアカウントをお使いのMisskeyアカウントに接続しておくと、プロフィールでTwitterアカウント情報が表示されるようになったり、Twitterを用いた便利なサインインを利用できるようになります。" | ||||
|   connected-to: "次のTwitterアカウントに接続されています" | ||||
|   detail: "詳細..." | ||||
|   reconnect: "再接続する" | ||||
|   connect: "Twitterと接続する" | ||||
| common/views/components/integration-settings.vue: | ||||
|   title: "サービス連携" | ||||
|   connect: "接続する" | ||||
|   disconnect: "切断する" | ||||
|   connected-to: "次のアカウントに接続されています" | ||||
| common/views/components/github-setting.vue: | ||||
|   description: "お使いのGitHubアカウントをお使いのMisskeyアカウントに接続しておくと、プロフィールでGitHubアカウント情報が表示されるようになったり、GitHubを用いた便利なサインインを利用できるようになります。" | ||||
|   connected-to: "次のGitHubアカウントに接続されています" | ||||
| @@ -438,12 +440,20 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/components/language-settings.vue: | ||||
|   title: "表示言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語を指定" | ||||
|   info: "変更はページの再度読み込み後に反映されます。" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   language: "言語" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
| @@ -457,6 +467,10 @@ common/views/components/profile-editor.vue: | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
|   email: "メール設定" | ||||
|   email-address: "メールアドレス" | ||||
|   email-verified: "メールアドレスが確認されました" | ||||
|   email-not-verified: "メールアドレスが確認されていません。メールボックスをご確認ください。" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "確認中" | ||||
|   no-broadcasts: "お知らせはありません" | ||||
| @@ -469,9 +483,6 @@ common/views/widgets/calendar.vue: | ||||
|   today: "今日:" | ||||
|   this-month: "今月:" | ||||
|   this-year: "今年:" | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "寄付のお願い" | ||||
|   text: "Misskeyの運営にはドメイン、サーバー等のコストが掛かります。Misskeyは広告を掲載したりしないため、収入を皆様からの寄付に頼っています。もしご興味があれば、{}までご連絡ください。ご協力ありがとうございます。" | ||||
| common/views/widgets/photo-stream.vue: | ||||
|   title: "フォトストリーム" | ||||
|   no-photos: "写真はありません" | ||||
| @@ -512,6 +523,8 @@ common/views/widgets/tips.vue: | ||||
|   tips-line23: "まゆかわいいよまゆ" | ||||
|   tips-line24: "Misskeyは2014年にサービスを開始しました" | ||||
|   tips-line25: "対応ブラウザではMisskeyを開いていなくても通知を受け取れます" | ||||
| common/views/pages/404.vue: | ||||
|   page-not-found: "ページが見つかりませんでした" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   following: "フォロー中" | ||||
| @@ -731,6 +744,8 @@ desktop/views/components/settings.vue: | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   web-search-engine: "ウェブ検索エンジン" | ||||
|   web-search-engine-desc: "例: https://www.google.com/?#q={{query}}" | ||||
|   auto-popout: "ウィンドウの自動ポップアウト" | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   advanced: "詳細設定" | ||||
| @@ -750,7 +765,6 @@ desktop/views/components/settings.vue: | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   timeline: "タイムライン" | ||||
| @@ -759,20 +773,21 @@ desktop/views/components/settings.vue: | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   remain-deleted-note: "削除された投稿を表示し続ける" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align: "デッキのカラムの配置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   deck-column-align-flexible: "フレキシブル" | ||||
|   deck-column-width: "デッキのカラムの幅" | ||||
|   deck-column-width-narrow: "狭" | ||||
|   deck-column-width-narrower: "やや狭" | ||||
|   deck-column-width-normal: "普通" | ||||
|   deck-column-width-wider: "やや広" | ||||
|   deck-column-width-wide: "広" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||
|   volume: "ボリューム" | ||||
|   test: "テスト" | ||||
|   language: "言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語を指定" | ||||
|   language-desc: "変更はページの再度読み込み後に反映されます。" | ||||
|   cache: "キャッシュ" | ||||
|   clean-cache: "クリーンアップ" | ||||
|   cache-warn: "クリーンアップを行うと、ブラウザに記憶されたアカウント情報のキャッシュ、書きかけの投稿・返信・メッセージ、およびその他のデータ(設定情報含む)が削除されます。クリーンアップを行った後はページを再度読み込みする必要があります。" | ||||
| @@ -862,11 +877,17 @@ common/views/components/password-settings.vue: | ||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||
|   not-match: "新しいパスワードが一致しません" | ||||
|   changed: "パスワードを変更しました" | ||||
|   failed: "パスワード変更に失敗しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   media-count: "{}つのメディア" | ||||
|   poll: "アンケート" | ||||
| desktop/views/components/settings.tags.vue: | ||||
|   title: "タグ" | ||||
|   query: "クエリ (省略可)" | ||||
|   add: "追加" | ||||
|   save: "保存" | ||||
| desktop/views/components/taskmanager.vue: | ||||
|   title: "タスクマネージャ" | ||||
| desktop/views/components/timeline.vue: | ||||
| @@ -949,6 +970,7 @@ admin/views/instance.vue: | ||||
|   instance-description: "インスタンスの紹介" | ||||
|   host: "ホスト" | ||||
|   banner-url: "バナー画像URL" | ||||
|   error-image-url: "エラー画像URL" | ||||
|   languages: "インスタンスの対象言語" | ||||
|   languages-desc: "スペースで区切って複数設定できます。" | ||||
|   maintainer-config: "管理者情報" | ||||
| @@ -966,17 +988,17 @@ admin/views/instance.vue: | ||||
|   recaptcha-site-key: "reCAPTCHA site key" | ||||
|   recaptcha-secret-key: "reCAPTCHA secret key" | ||||
|   twitter-integration-config: "Twitter連携の設定" | ||||
|   twitter-integration-info: "コールバックURLは /api/tw/cb に設定します。" | ||||
|   twitter-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-twitter-integration: "Twitter連携を有効にする" | ||||
|   twitter-integration-consumer-key: "Consumer key" | ||||
|   twitter-integration-consumer-secret: "Consumer secret" | ||||
|   github-integration-config: "GitHub連携の設定" | ||||
|   github-integration-info: "コールバックURLは /api/gh/cb に設定します。" | ||||
|   github-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-github-integration: "GitHub連携を有効にする" | ||||
|   github-integration-client-id: "Client ID" | ||||
|   github-integration-client-secret: "Client Secret" | ||||
|   discord-integration-config: "Discord連携の設定" | ||||
|   discord-integration-info: "コールバックURLは /api/dc/cb に設定します。" | ||||
|   discord-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-discord-integration: "Discord連携を有効にする" | ||||
|   discord-integration-client-id: "Client ID" | ||||
|   discord-integration-client-secret: "Client Secret" | ||||
| @@ -991,6 +1013,22 @@ admin/views/instance.vue: | ||||
|   invite: "招待" | ||||
|   save: "保存" | ||||
|   saved: "保存しました" | ||||
|   user-recommendation-config: "おすすめユーザー" | ||||
|   enable-external-user-recommendation: "外部ユーザーレコメンデーションを有効にする" | ||||
|   external-user-recommendation-engine: "エンジン" | ||||
|   external-user-recommendation-engine-desc: "例: https://vinayaka.distsn.org/cgi-bin/vinayaka-user-match-misskey-api.cgi?{{host}}+{{user}}+{{limit}}+{{offset}}" | ||||
|   external-user-recommendation-timeout: "タイムアウト" | ||||
|   external-user-recommendation-timeout-desc: "ミリ秒単位 (例: 300000)" | ||||
|   email-config: "メールサーバーの設定" | ||||
|   email-config-info: "メールアドレス確認やパスワードリセットの際に使われます。" | ||||
|   enable-email: "メール配信を有効にする" | ||||
|   email: "メールアドレス" | ||||
|   smtp-secure: "SMTP接続に暗黙的なSSL/TLSを使用する" | ||||
|   smtp-secure-info: "STARTTLS使用時はオフにします。" | ||||
|   smtp-host: "SMTPホスト" | ||||
|   smtp-port: "SMTPポート" | ||||
|   smtp-user: "SMTPユーザー" | ||||
|   smtp-pass: "SMTPパスワード" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
| @@ -1016,19 +1054,50 @@ admin/views/charts.vue: | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| admin/views/drive.vue: | ||||
|   sort: | ||||
|     title: "ソート" | ||||
|     createdAtAsc: "アップロード日時が古い順" | ||||
|     createdAtDesc: "アップロード日時が新しい順" | ||||
|     sizeAsc: "サイズが小さい順" | ||||
|     sizeDesc: "サイズが大きい順" | ||||
|   origin: | ||||
|     title: "オリジン" | ||||
|     combined: "ローカル+リモート" | ||||
|     local: "ローカル" | ||||
|     remote: "リモート" | ||||
|   delete: "削除" | ||||
|   deleted: "削除しました" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   operation: "操作" | ||||
|   username-or-userid: "ユーザー名またはユーザーID" | ||||
|   user-not-found: "ユーザーが見つかりません" | ||||
|   lookup: "照会" | ||||
|   reset-password: "パスワードをリセット" | ||||
|   password-updated: "パスワードは現在「{password}」です" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|   users: | ||||
|     title: "ユーザー" | ||||
|     sort: | ||||
|       title: "ソート" | ||||
|       createdAtAsc: "登録日時が古い順" | ||||
|       createdAtDesc: "登録日時が新しい順" | ||||
|       updatedAtAsc: "更新日時が古い順" | ||||
|       updatedAtDesc: "更新日時が新しい順" | ||||
|     origin: | ||||
|       title: "オリジン" | ||||
|       combined: "ローカル+リモート" | ||||
|       local: "ローカル" | ||||
|       remote: "リモート" | ||||
|     createdAt: "登録日時" | ||||
|     updatedAt: "更新日時" | ||||
| admin/views/moderators.vue: | ||||
|   add-moderator: | ||||
|     title: "モデレーターの登録" | ||||
| @@ -1321,11 +1390,6 @@ mobile/views/pages/selectdrive.vue: | ||||
|   select-file: "ファイルを選択" | ||||
| mobile/views/pages/settings.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   lang: "言語" | ||||
|   lang-tip: "変更はページの再読み込み後に反映されます。" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語を指定" | ||||
|   design: "デザインと表示" | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
| @@ -1348,21 +1412,11 @@ mobile/views/pages/settings.vue: | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   web-search-engine: "ウェブ検索エンジン" | ||||
|   web-search-engine-desc: "例: https://www.google.com/?#q={{query}}" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   load-raw-images: "添付された画像を高画質で表示する" | ||||
|   load-remote-media: "リモートサーバーのメディアを表示する" | ||||
|   twitter: "Twitter連携" | ||||
|   twitter-connect: "Conectar à sua conta no Twitter" | ||||
|   twitter-reconnect: "Reconectar" | ||||
|   twitter-disconnect: "Desconectar" | ||||
|   github: "GitHub連携" | ||||
|   github-connect: "GitHubアカウントに接続する" | ||||
|   github-reconnect: "再接続する" | ||||
|   github-disconnect: "切断する" | ||||
|   discord: "Discord連携" | ||||
|   discord-connect: "Discordアカウントに接続する" | ||||
|   discord-reconnect: "再接続する" | ||||
|   discord-disconnect: "切断する" | ||||
|   update: "Atualizar Misskey" | ||||
|   version: "Versão atual;" | ||||
|   latest-version: "Última versão:" | ||||
| @@ -1392,6 +1446,9 @@ mobile/views/pages/user.vue: | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
|   years-old: "{age}歳" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "Notas recentes" | ||||
|   images: "Imagens" | ||||
|   | ||||
| @@ -7,61 +7,62 @@ common: | ||||
|   about-title: "Мы — ⭐ fediverse" | ||||
|   about: "Спасибо, что нашли Misskey. Misskey — это <b>децентрализованная платформа для микроблоггинга</b> родом с планеты Земля. Поскольку она существует внутри Fediverse (вселенной различных социальных платформ), она связана с другими платформами. Отдохните от шума большого города — и познакомьтесь с новым интернетом." | ||||
|   intro: | ||||
|     title: "Misskeyって?" | ||||
|     about: "Misskeyはオープンソースの<b>分散型マイクロブログSNS</b>です。リッチで高度にカスタマイズできるUI、投稿へのリアクション、ファイルを一元管理できるドライブなど、先進的な機能を揃えています。また、Fediverseと呼ばれるネットワークに接続できるため、他のSNSともやり取りできます。例えば、あなたが何か投稿すると、その投稿はMisskeyだけでなく他のSNSにも伝わります。ちょうどある惑星から他の惑星に電波を発信している様子をイメージしてください。" | ||||
|     features: "特徴" | ||||
|     rich-contents: "投稿" | ||||
|     rich-contents-desc: "自分の考え、話題の出来事、皆と共有したいことについて発信してください。必要であれば、様々な構文を使って投稿を装飾したり、好きな画像、動画などのファイルやアンケートを添付することもできます。" | ||||
|     reaction: "リアクション" | ||||
|     reaction-desc: "あなたの気持ちを伝える最も簡単な方法です。Misskeyは、他のユーザーの投稿に様々なリアクションを付けることができます。いちどMisskeyのリアクション機能を体験してしまうと、もう「いいね」の概念しか存在しないSNSには戻れなくなるかもしれません。" | ||||
|     ui: "インターフェース" | ||||
|     ui-desc: "どのようなUIが使いやすいかは人それぞれです。だから、Misskeyは自由度の高いUIを持っています。レイアウトやデザインを調整したり、カスタマイズ可能な様々なウィジェットを配置したりして、自分だけのホームを作ってください。" | ||||
|     drive: "ドライブ" | ||||
|     drive-desc: "以前投稿したことのある画像をまた投稿したくなったことはありませんか?もしくは、アップロードしたファイルをフォルダ分けして整理したくなったことはありませんか?Misskeyの根幹に組み込まれたドライブ機能によってそれらが解決します。ファイルの共有も簡単です。" | ||||
|     outro: "他にもMisskeyにしかない機能はまだまだあるので、ぜひあなた自身の目で確かめてください。Misskeyは分散型SNSなので、このインスタンスが気に入らなければ他のインスタンスを試すこともできます。それでは、GLHF!" | ||||
|     title: "Что такое Misskey?" | ||||
|     about: "Misskey - это <b>децентрализованный сервис микроблогинга</b> с открытым исходным кодом. Он имеет такие функции, как: навороченный, полностью настраиваемый пользовательский интерфейс, множество реакций на посты, бесплатное хранилище файлов с интегрированной системой управления и ещё куча передовых фишек. А ещё сетевая система под названием “Fediverse” позволяет нам общаться с пользователями других социальных сетей. Например, если ты что-нибудь запостишь, то твой пост будет отослан не только в Misskey, но ещё и mastodon. Просто представь, что планета посылает микроволны на другую планету для коммуникации." | ||||
|     features: "Особенности" | ||||
|     rich-contents: "Посты" | ||||
|     rich-contents-desc: "Просто выложи свою идею, актуальные темы и всё, что тебе хочется показать миру. Ты можешь декорировать свои слова, прикреплять свои любимые картинки, отправлять файлы с фильмами и создать голосование - это те вещи, которые ты можешь сделать с помощью Misskey!" | ||||
|     reaction: "Реакции" | ||||
|     reaction-desc: "Самый лёгкий способ выразить свои эмоции. Misskey позволяет добавлять различные виды реакций к постам других людей. Эмоциональный опыт из Misskey никогда не появится в других социальных сетях, позволяющих только жать “лайки”." | ||||
|     ui: "Интерфейс" | ||||
|     ui-desc: "Нет такого интерфейса, понравившегося всем. Поэтому у Misskey имеется пользовательский интерфейс, широко настраиваемый под ваши вкусы. Создай себе уникальную домашнюю страницу редактируя, подстраивая оформление ленты и размещая виджеты, которые тоже можно кастомизировать." | ||||
|     drive: "Хранилище файлов" | ||||
|     drive-desc: "Хотите запостить картинку, которую уже отправляли ранее? Хочется сортировать, переименовать и создать папку для ваших выложенных файлов? Тогда Misskey Drive - это лучшее решение для вас. Очень лёгкий способ делиться своими файлами онлайн." | ||||
|     outro: "Попробуйте будущие, уникальные для Misskey функции своими глазами! Если чувствуете, что это не в вашем вкусе, то попробуйте другие инстанции, ведь Misskey - это децентрализованная социальная сеть, так что ты можешь с лёгкостью найти себе товарищей. И наконец, GLHF!" | ||||
|   adblock: | ||||
|     detected: "広告ブロッカーを無効にしてください" | ||||
|     warning: "<strong>Misskeyは広告を掲載していません</strong>が、広告をブロックする機能が有効だと一部の機能が利用できなかったり、不具合が発生する場合があります。" | ||||
|   application-authorization: "アプリの連携" | ||||
|   close: "閉じる" | ||||
|   do-not-copy-paste: "ここにコードを入力したり張り付けたりしないでください。アカウントが不正利用される可能性があります。" | ||||
|   load-more: "もっと読み込む" | ||||
|     detected: "Пожалуйста, отключите блокировщик рекламы." | ||||
|     warning: "Некоторые функции перестанут быть доступными или будут работать неправильно, если включена блокировка рекламы. <strong>В Misskey нет рекламы</strong>." | ||||
|   application-authorization: "Авторизация приложений" | ||||
|   close: "Закрыть" | ||||
|   do-not-copy-paste: "Пожалуйста, не вводите и не вставляйте сюда код. Аккаунту может угрожать опасность." | ||||
|   load-more: "Загрузить больше" | ||||
|   enter-password: "パスワードを入力してください" | ||||
|   got-it: "わかった" | ||||
|   customization-tips: | ||||
|     title: "カスタマイズのヒント" | ||||
|     paragraph: "<p>ホームのカスタマイズでは、ウィジェットを追加/削除したり、ドラッグ&ドロップして並べ替えたりすることができます。</p><p>一部のウィジェットは、<strong><strong>右</strong>クリック</strong>することで表示を変更することができます。</p><p>ウィジェットを削除するには、ヘッダーの<strong>「ゴミ箱」</strong>と書かれたエリアにウィジェットをドラッグ&ドロップします。</p><p>カスタマイズを終了するには、右上の「完了」をクリックします。</p>" | ||||
|     gotit: "Got it!" | ||||
|   notification: | ||||
|     file-uploaded: "ファイルがアップロードされました" | ||||
|     message-from: "{}さんからメッセージ:" | ||||
|     reversi-invited: "対局への招待があります" | ||||
|     reversi-invited-by: "{}さんから" | ||||
|     file-uploaded: "Файл отправлен!" | ||||
|     message-from: "Сообщение от {}:" | ||||
|     reversi-invited: "Приглашён в игру" | ||||
|     reversi-invited-by: "Был приглашён {}:" | ||||
|     notified-by: "{}さんから" | ||||
|     reply-from: "{}さんから返信:" | ||||
|     quoted-by: "{}さんが引用:" | ||||
|     reply-from: "Ответ от {}:" | ||||
|     quoted-by: "Цитировано {}:" | ||||
|   time: | ||||
|     unknown: "なぞのじかん" | ||||
|     future: "未来" | ||||
|     just_now: "たった今" | ||||
|     seconds_ago: "{}秒前" | ||||
|     minutes_ago: "{}分前" | ||||
|     hours_ago: "{}時間前" | ||||
|     days_ago: "{}日前" | ||||
|     weeks_ago: "{}週間前" | ||||
|     months_ago: "{}ヶ月前" | ||||
|     years_ago: "{}年前" | ||||
|   month-and-day: "{month}月 {day}日" | ||||
|   trash: "ゴミ箱" | ||||
|   drive: "ドライブ" | ||||
|   messaging: "トーク" | ||||
|     unknown: "неизвестно" | ||||
|     future: "сейчас" | ||||
|     just_now: "сейчас" | ||||
|     seconds_ago: "{} секунд назад" | ||||
|     minutes_ago: "{} минут назад" | ||||
|     hours_ago: "{} часов назад" | ||||
|     days_ago: "{} дней назад" | ||||
|     weeks_ago: "{} недель назад" | ||||
|     months_ago: "{} месяцев назад" | ||||
|     years_ago: "{} лет назад" | ||||
|   month-and-day: "{day}.{month}" | ||||
|   trash: "Мусорное ведро" | ||||
|   drive: "Drive" | ||||
|   messaging: "Чат" | ||||
|   weekday-short: | ||||
|     sunday: "日" | ||||
|     monday: "月" | ||||
|     tuesday: "火" | ||||
|     wednesday: "水" | ||||
|     thursday: "木" | ||||
|     friday: "金" | ||||
|     saturday: "土" | ||||
|     sunday: "Вс" | ||||
|     monday: "Пн" | ||||
|     tuesday: "Вт" | ||||
|     wednesday: "Ср" | ||||
|     thursday: "Чт" | ||||
|     friday: "Пт" | ||||
|     saturday: "Сб" | ||||
|   weekday: | ||||
|     sunday: "日曜日" | ||||
|     monday: "月曜日" | ||||
| @@ -109,62 +110,63 @@ common: | ||||
|   my-token-regenerated: "あなたのトークンが更新されたのでサインアウトします。" | ||||
|   i-like-sushi: "私は(プリンよりむしろ)寿司が好き" | ||||
|   show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" | ||||
|   use-contrast-reversi-stones: "リバーシのアイコンにコントラストを付ける" | ||||
|   use-white-black-reversi-stones: "リバーシに白黒の石を使う" | ||||
|   verified-user: "公式アカウント" | ||||
|   disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" | ||||
|   always-show-nsfw: "常に閲覧注意のメディアを表示する" | ||||
|   always-mark-nsfw: "常にメディアを閲覧注意として投稿" | ||||
|   disable-animated-mfm: "Отключить анимированный текст в постах" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "Всегда показывать NSFW контент" | ||||
|   always-mark-nsfw: "Всегда помечать посты с медиафайлами как NSFW" | ||||
|   show-full-acct: "ユーザー名のホストを省略しない" | ||||
|   show-via: "viaを表示する" | ||||
|   reduce-motion: "UIの動きを減らす" | ||||
|   this-setting-is-this-device-only: "このデバイスのみ" | ||||
|   use-os-default-emojis: "OS標準の絵文字を使用" | ||||
|   do-not-use-in-production: 'これは開発ビルドです。本番環境で使用しないでください。' | ||||
|   show-via: "показать через" | ||||
|   reduce-motion: "Уменьшить движение в интерфейсе" | ||||
|   this-setting-is-this-device-only: "Только для этого устройства" | ||||
|   use-os-default-emojis: "Использовать стандартные Emoji из ОС" | ||||
|   do-not-use-in-production: 'Эта сборка для разработчиков. Не используйте в продакшне.' | ||||
|   is-remote-user: "このユーザー情報はコピーです。" | ||||
|   is-remote-post: "この投稿情報はコピーです。" | ||||
|   view-on-remote: "正確な情報を見る" | ||||
|   renoted-by: "{user}がRenote" | ||||
|   error: | ||||
|     title: '問題が発生しました' | ||||
|     retry: 'やり直す' | ||||
|     title: 'Что-то пошло не так :(' | ||||
|     retry: 'Повторить' | ||||
|   reversi: | ||||
|     drawn: "引き分け" | ||||
|     my-turn: "あなたのターンです" | ||||
|     opponent-turn: "相手のターンです" | ||||
|     turn-of: "{name}のターンです" | ||||
|     past-turn-of: "{name}のターン" | ||||
|     won: "{name}の勝ち" | ||||
|     black: "黒" | ||||
|     white: "白" | ||||
|     total: "合計" | ||||
|     this-turn: "{count}ターン目" | ||||
|     drawn: "Ничья" | ||||
|     my-turn: "Ваш ход" | ||||
|     opponent-turn: "Ход оппонента" | ||||
|     turn-of: "Ход {name}" | ||||
|     past-turn-of: "Ход {name}" | ||||
|     won: "{name} победил" | ||||
|     black: "Чёрный" | ||||
|     white: "Белый" | ||||
|     total: "Всего" | ||||
|     this-turn: "Ход {count}" | ||||
|   widgets: | ||||
|     analog-clock: "アナログ時計" | ||||
|     profile: "プロフィール" | ||||
|     calendar: "カレンダー" | ||||
|     timemachine: "カレンダー(タイムマシン)" | ||||
|     activity: "アクティビティ" | ||||
|     rss: "RSSリーダー" | ||||
|     memo: "付箋" | ||||
|     trends: "トレンド" | ||||
|     photo-stream: "フォトストリーム" | ||||
|     analog-clock: "Аналоговые часы" | ||||
|     profile: "Профиль" | ||||
|     calendar: "Календарь" | ||||
|     timemachine: "Календарь (машина времени)" | ||||
|     activity: "Активность" | ||||
|     rss: "Ридер RSS" | ||||
|     memo: "Заметка" | ||||
|     trends: "Популярное" | ||||
|     photo-stream: "Фотопоток" | ||||
|     posts-monitor: "投稿チャート" | ||||
|     slideshow: "スライドショー" | ||||
|     version: "バージョン" | ||||
|     slideshow: "Слайдшоу" | ||||
|     version: "Версия" | ||||
|     broadcast: "ブロードキャスト" | ||||
|     notifications: "通知" | ||||
|     users: "おすすめユーザー" | ||||
|     polls: "アンケート" | ||||
|     notifications: "Уведомления" | ||||
|     users: "Рекомендованные пользователи" | ||||
|     polls: "Голосования" | ||||
|     post-form: "投稿フォーム" | ||||
|     server: "サーバー情報" | ||||
|     donation: "寄付のお願い" | ||||
|     server: "Информация о сервере" | ||||
|     nav: "ナビゲーション" | ||||
|     tips: "ヒント" | ||||
|     hashtags: "ハッシュタグ" | ||||
|   dev: "アプリの作成に失敗しました。再度お試しください。" | ||||
|   ai-chan-kawaii: "藍ちゃかわいい" | ||||
|     hashtags: "Хэштеги" | ||||
|   dev: "Не удалось создать приложение. Пожалуйста, попробуйте ещё раз." | ||||
|   ai-chan-kawaii: "Ai-chan kawaii!" | ||||
|   you: "あなた" | ||||
| auth/views/form.vue: | ||||
|   share-access: "<i>{name}</i>があなたのアカウントにアクセスすることを許可しますか?" | ||||
|   share-access: "Вы разрешаете <i>{name}</i> получить доступ к вашему аккаунту?" | ||||
|   permission-ask: "このアプリは次の権限を要求しています:" | ||||
|   account-read: "アカウントの情報を見る。" | ||||
|   account-write: "アカウントの情報を操作する。" | ||||
| @@ -210,28 +212,28 @@ common/views/components/games/reversi/reversi.index.vue: | ||||
|   all-games: "みんなの対局" | ||||
|   enter-username: "ユーザー名を入力してください" | ||||
|   game-state: | ||||
|     ended: "終了" | ||||
|     playing: "進行中" | ||||
|     ended: "Завершено" | ||||
|     playing: "В процессе" | ||||
| common/views/components/games/reversi/reversi.room.vue: | ||||
|   settings-of-the-game: "ゲームの設定" | ||||
|   settings-of-the-game: "Настройки игры" | ||||
|   choose-map: "マップを選択" | ||||
|   random: "ランダム" | ||||
|   black-or-white: "先手/後手" | ||||
|   black-is: "{}が黒" | ||||
|   rules: "ルール" | ||||
|   random: "Случайно" | ||||
|   black-or-white: "Чёрные/Белые" | ||||
|   black-is: "{} ходит чёрными" | ||||
|   rules: "Правила" | ||||
|   is-llotheo: "石の少ない方が勝ち(ロセオ)" | ||||
|   looped-map: "ループマップ" | ||||
|   can-put-everywhere: "どこでも置けるモード" | ||||
|   settings-of-the-bot: "Botの設定" | ||||
|   this-game-is-started-soon: "ゲームは数秒後に開始されます" | ||||
|   waiting-for-other: "相手の準備が完了するのを待っています" | ||||
|   settings-of-the-bot: "Настройки бота" | ||||
|   this-game-is-started-soon: "Игра вот-вот начнётся" | ||||
|   waiting-for-other: "Ожидание оппонента" | ||||
|   waiting-for-me: "あなたの準備が完了するのを待っています" | ||||
|   waiting-for-both: "準備中" | ||||
|   cancel: "キャンセル" | ||||
|   ready: "準備完了" | ||||
|   cancel: "Отмена" | ||||
|   ready: "Готов" | ||||
|   cancel-ready: "準備続行" | ||||
| common/views/components/connect-failed.vue: | ||||
|   title: "サーバーに接続できません" | ||||
|   title: "Невозможно подключиться к серверу" | ||||
|   description: "インターネット回線に問題があるか、サーバーがダウンまたはメンテナンスしている可能性があります。しばらくしてから{再度お試し}ください。" | ||||
|   thanks: "いつもMisskeyをご利用いただきありがとうございます。" | ||||
|   troubleshoot: "トラブルシュート" | ||||
| @@ -295,6 +297,8 @@ common/views/components/theme.vue: | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "隠す" | ||||
|   show: "もっと見る" | ||||
|   chars: "{count}文字" | ||||
|   files: "{count}ファイル" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "ユーザーを探す" | ||||
|   you: "あなた" | ||||
| @@ -399,13 +403,11 @@ common/views/components/stream-indicator.vue: | ||||
|   connecting: "接続中" | ||||
|   reconnecting: "再接続中" | ||||
|   connected: "接続完了" | ||||
| common/views/components/twitter-setting.vue: | ||||
|   description: "お使いのTwitterアカウントをお使いのMisskeyアカウントに接続しておくと、プロフィールでTwitterアカウント情報が表示されるようになったり、Twitterを用いた便利なサインインを利用できるようになります。" | ||||
|   connected-to: "次のTwitterアカウントに接続されています" | ||||
|   detail: "詳細..." | ||||
|   reconnect: "再接続する" | ||||
|   connect: "Twitterと接続する" | ||||
| common/views/components/integration-settings.vue: | ||||
|   title: "サービス連携" | ||||
|   connect: "接続する" | ||||
|   disconnect: "切断する" | ||||
|   connected-to: "次のアカウントに接続されています" | ||||
| common/views/components/github-setting.vue: | ||||
|   description: "お使いのGitHubアカウントをお使いのMisskeyアカウントに接続しておくと、プロフィールでGitHubアカウント情報が表示されるようになったり、GitHubを用いた便利なサインインを利用できるようになります。" | ||||
|   connected-to: "次のGitHubアカウントに接続されています" | ||||
| @@ -438,12 +440,20 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{}人が投稿" | ||||
|   empty: "トレンドなし" | ||||
| common/views/components/language-settings.vue: | ||||
|   title: "表示言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語を指定" | ||||
|   info: "変更はページの再度読み込み後に反映されます。" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "プロフィール" | ||||
|   name: "名前" | ||||
|   account: "アカウント" | ||||
|   location: "場所" | ||||
|   description: "自己紹介" | ||||
|   language: "言語" | ||||
|   birthday: "誕生日" | ||||
|   avatar: "アイコン" | ||||
|   banner: "バナー" | ||||
| @@ -457,6 +467,10 @@ common/views/components/profile-editor.vue: | ||||
|   saved: "プロフィールを保存しました" | ||||
|   uploading: "アップロード中" | ||||
|   upload-failed: "アップロードに失敗しました" | ||||
|   email: "メール設定" | ||||
|   email-address: "メールアドレス" | ||||
|   email-verified: "メールアドレスが確認されました" | ||||
|   email-not-verified: "メールアドレスが確認されていません。メールボックスをご確認ください。" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "確認中" | ||||
|   no-broadcasts: "お知らせはありません" | ||||
| @@ -469,9 +483,6 @@ common/views/widgets/calendar.vue: | ||||
|   today: "今日:" | ||||
|   this-month: "今月:" | ||||
|   this-year: "今年:" | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "寄付のお願い" | ||||
|   text: "Misskeyの運営にはドメイン、サーバー等のコストが掛かります。Misskeyは広告を掲載したりしないため、収入を皆様からの寄付に頼っています。もしご興味があれば、{}までご連絡ください。ご協力ありがとうございます。" | ||||
| common/views/widgets/photo-stream.vue: | ||||
|   title: "フォトストリーム" | ||||
|   no-photos: "写真はありません" | ||||
| @@ -512,6 +523,8 @@ common/views/widgets/tips.vue: | ||||
|   tips-line23: "まゆかわいいよまゆ" | ||||
|   tips-line24: "Misskeyは2014年にサービスを開始しました" | ||||
|   tips-line25: "対応ブラウザではMisskeyを開いていなくても通知を受け取れます" | ||||
| common/views/pages/404.vue: | ||||
|   page-not-found: "ページが見つかりませんでした" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   following: "フォロー中" | ||||
| @@ -731,6 +744,8 @@ desktop/views/components/settings.vue: | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   web-search-engine: "ウェブ検索エンジン" | ||||
|   web-search-engine-desc: "例: https://www.google.com/?#q={{query}}" | ||||
|   auto-popout: "ウィンドウの自動ポップアウト" | ||||
|   auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトします。この設定はブラウザに記憶されます。" | ||||
|   advanced: "詳細設定" | ||||
| @@ -750,7 +765,6 @@ desktop/views/components/settings.vue: | ||||
|   circle-icons: "円形のアイコンを使用" | ||||
|   contrasted-acct: "ユーザー名にコントラストを付ける" | ||||
|   post-form-on-timeline: "タイムライン上部に投稿フォームを表示する" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   show-clock-on-header: "右上に時計を表示する" | ||||
|   show-reply-target: "リプライ先を表示する" | ||||
|   timeline: "タイムライン" | ||||
| @@ -759,20 +773,21 @@ desktop/views/components/settings.vue: | ||||
|   show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示する" | ||||
|   show-maps: "マップの自動展開" | ||||
|   remain-deleted-note: "削除された投稿を表示し続ける" | ||||
|   deck-column-align: "デッキのカラムの位置" | ||||
|   deck-column-align: "デッキのカラムの配置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   deck-column-align-flexible: "フレキシブル" | ||||
|   deck-column-width: "デッキのカラムの幅" | ||||
|   deck-column-width-narrow: "狭" | ||||
|   deck-column-width-narrower: "やや狭" | ||||
|   deck-column-width-normal: "普通" | ||||
|   deck-column-width-wider: "やや広" | ||||
|   deck-column-width-wide: "広" | ||||
|   sound: "サウンド" | ||||
|   enable-sounds: "サウンドを有効にする" | ||||
|   enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生します。この設定はブラウザに記憶されます。" | ||||
|   volume: "ボリューム" | ||||
|   test: "テスト" | ||||
|   language: "言語" | ||||
|   pick-language: "言語を選択" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語を指定" | ||||
|   language-desc: "変更はページの再度読み込み後に反映されます。" | ||||
|   cache: "キャッシュ" | ||||
|   clean-cache: "クリーンアップ" | ||||
|   cache-warn: "クリーンアップを行うと、ブラウザに記憶されたアカウント情報のキャッシュ、書きかけの投稿・返信・メッセージ、およびその他のデータ(設定情報含む)が削除されます。クリーンアップを行った後はページを再度読み込みする必要があります。" | ||||
| @@ -862,11 +877,17 @@ common/views/components/password-settings.vue: | ||||
|   enter-new-password-again: "もう一度新しいパスワードを入力してください" | ||||
|   not-match: "新しいパスワードが一致しません" | ||||
|   changed: "パスワードを変更しました" | ||||
|   failed: "パスワード変更に失敗しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "この投稿は非公開です" | ||||
|   deleted: "この投稿は削除されました" | ||||
|   media-count: "{}つのメディア" | ||||
|   poll: "アンケート" | ||||
| desktop/views/components/settings.tags.vue: | ||||
|   title: "タグ" | ||||
|   query: "クエリ (省略可)" | ||||
|   add: "追加" | ||||
|   save: "保存" | ||||
| desktop/views/components/taskmanager.vue: | ||||
|   title: "タスクマネージャ" | ||||
| desktop/views/components/timeline.vue: | ||||
| @@ -949,6 +970,7 @@ admin/views/instance.vue: | ||||
|   instance-description: "インスタンスの紹介" | ||||
|   host: "ホスト" | ||||
|   banner-url: "バナー画像URL" | ||||
|   error-image-url: "エラー画像URL" | ||||
|   languages: "インスタンスの対象言語" | ||||
|   languages-desc: "スペースで区切って複数設定できます。" | ||||
|   maintainer-config: "管理者情報" | ||||
| @@ -966,17 +988,17 @@ admin/views/instance.vue: | ||||
|   recaptcha-site-key: "reCAPTCHA site key" | ||||
|   recaptcha-secret-key: "reCAPTCHA secret key" | ||||
|   twitter-integration-config: "Twitter連携の設定" | ||||
|   twitter-integration-info: "コールバックURLは /api/tw/cb に設定します。" | ||||
|   twitter-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-twitter-integration: "Twitter連携を有効にする" | ||||
|   twitter-integration-consumer-key: "Consumer key" | ||||
|   twitter-integration-consumer-secret: "Consumer secret" | ||||
|   github-integration-config: "GitHub連携の設定" | ||||
|   github-integration-info: "コールバックURLは /api/gh/cb に設定します。" | ||||
|   github-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-github-integration: "GitHub連携を有効にする" | ||||
|   github-integration-client-id: "Client ID" | ||||
|   github-integration-client-secret: "Client Secret" | ||||
|   discord-integration-config: "Discord連携の設定" | ||||
|   discord-integration-info: "コールバックURLは /api/dc/cb に設定します。" | ||||
|   discord-integration-info: "コールバックURLは {url} に設定します。" | ||||
|   enable-discord-integration: "Discord連携を有効にする" | ||||
|   discord-integration-client-id: "Client ID" | ||||
|   discord-integration-client-secret: "Client Secret" | ||||
| @@ -991,6 +1013,22 @@ admin/views/instance.vue: | ||||
|   invite: "招待" | ||||
|   save: "保存" | ||||
|   saved: "保存しました" | ||||
|   user-recommendation-config: "おすすめユーザー" | ||||
|   enable-external-user-recommendation: "外部ユーザーレコメンデーションを有効にする" | ||||
|   external-user-recommendation-engine: "エンジン" | ||||
|   external-user-recommendation-engine-desc: "例: https://vinayaka.distsn.org/cgi-bin/vinayaka-user-match-misskey-api.cgi?{{host}}+{{user}}+{{limit}}+{{offset}}" | ||||
|   external-user-recommendation-timeout: "タイムアウト" | ||||
|   external-user-recommendation-timeout-desc: "ミリ秒単位 (例: 300000)" | ||||
|   email-config: "メールサーバーの設定" | ||||
|   email-config-info: "メールアドレス確認やパスワードリセットの際に使われます。" | ||||
|   enable-email: "メール配信を有効にする" | ||||
|   email: "メールアドレス" | ||||
|   smtp-secure: "SMTP接続に暗黙的なSSL/TLSを使用する" | ||||
|   smtp-secure-info: "STARTTLS使用時はオフにします。" | ||||
|   smtp-host: "SMTPホスト" | ||||
|   smtp-port: "SMTPポート" | ||||
|   smtp-user: "SMTPユーザー" | ||||
|   smtp-pass: "SMTPパスワード" | ||||
| admin/views/charts.vue: | ||||
|   title: "チャート" | ||||
|   per-day: "1日ごと" | ||||
| @@ -1016,19 +1054,50 @@ admin/views/charts.vue: | ||||
|     network-requests: "リクエスト" | ||||
|     network-time: "応答時間" | ||||
|     network-usage: "通信量" | ||||
| admin/views/drive.vue: | ||||
|   sort: | ||||
|     title: "ソート" | ||||
|     createdAtAsc: "アップロード日時が古い順" | ||||
|     createdAtDesc: "アップロード日時が新しい順" | ||||
|     sizeAsc: "サイズが小さい順" | ||||
|     sizeDesc: "サイズが大きい順" | ||||
|   origin: | ||||
|     title: "オリジン" | ||||
|     combined: "ローカル+リモート" | ||||
|     local: "ローカル" | ||||
|     remote: "リモート" | ||||
|   delete: "削除" | ||||
|   deleted: "削除しました" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "ユーザーの凍結" | ||||
|   operation: "操作" | ||||
|   username-or-userid: "ユーザー名またはユーザーID" | ||||
|   user-not-found: "ユーザーが見つかりません" | ||||
|   lookup: "照会" | ||||
|   reset-password: "パスワードをリセット" | ||||
|   password-updated: "パスワードは現在「{password}」です" | ||||
|   suspend: "凍結" | ||||
|   suspended: "凍結しました" | ||||
|   unsuspend-user: "ユーザーの凍結の解除" | ||||
|   unsuspend: "凍結の解除" | ||||
|   unsuspended: "凍結を解除しました" | ||||
|   verify-user: "ユーザーの公式アカウント設定" | ||||
|   verify: "公式アカウントにする" | ||||
|   verified: "公式アカウントにしました" | ||||
|   unverify-user: "ユーザーの公式アカウント解除" | ||||
|   unverify: "公式アカウントを解除する" | ||||
|   unverified: "公式アカウントを解除しました" | ||||
|   users: | ||||
|     title: "ユーザー" | ||||
|     sort: | ||||
|       title: "ソート" | ||||
|       createdAtAsc: "登録日時が古い順" | ||||
|       createdAtDesc: "登録日時が新しい順" | ||||
|       updatedAtAsc: "更新日時が古い順" | ||||
|       updatedAtDesc: "更新日時が新しい順" | ||||
|     origin: | ||||
|       title: "オリジン" | ||||
|       combined: "ローカル+リモート" | ||||
|       local: "ローカル" | ||||
|       remote: "リモート" | ||||
|     createdAt: "登録日時" | ||||
|     updatedAt: "更新日時" | ||||
| admin/views/moderators.vue: | ||||
|   add-moderator: | ||||
|     title: "モデレーターの登録" | ||||
| @@ -1321,11 +1390,6 @@ mobile/views/pages/selectdrive.vue: | ||||
|   select-file: "ファイルを選択" | ||||
| mobile/views/pages/settings.vue: | ||||
|   signed-in-as: "{}としてサインイン中" | ||||
|   lang: "言語" | ||||
|   lang-tip: "変更はページの再読み込み後に反映されます。" | ||||
|   recommended: "推奨" | ||||
|   auto: "自動" | ||||
|   specify-language: "言語を指定" | ||||
|   design: "デザインと表示" | ||||
|   dark-mode: "ダークモード" | ||||
|   i-am-under-limited-internet: "私は通信を制限されている" | ||||
| @@ -1348,21 +1412,11 @@ mobile/views/pages/settings.vue: | ||||
|   note-visibility: "投稿の公開範囲" | ||||
|   default-note-visibility: "デフォルトの公開範囲" | ||||
|   remember-note-visibility: "投稿の公開範囲を記憶する" | ||||
|   web-search-engine: "ウェブ検索エンジン" | ||||
|   web-search-engine-desc: "例: https://www.google.com/?#q={{query}}" | ||||
|   disable-via-mobile: "「モバイルからの投稿」フラグを付けない" | ||||
|   load-raw-images: "添付された画像を高画質で表示する" | ||||
|   load-remote-media: "リモートサーバーのメディアを表示する" | ||||
|   twitter: "Twitter連携" | ||||
|   twitter-connect: "Twitterアカウントに接続する" | ||||
|   twitter-reconnect: "再接続する" | ||||
|   twitter-disconnect: "切断する" | ||||
|   github: "GitHub連携" | ||||
|   github-connect: "GitHubアカウントに接続する" | ||||
|   github-reconnect: "再接続する" | ||||
|   github-disconnect: "切断する" | ||||
|   discord: "Discord連携" | ||||
|   discord-connect: "Discordアカウントに接続する" | ||||
|   discord-reconnect: "再接続する" | ||||
|   discord-disconnect: "切断する" | ||||
|   update: "Misskey Update" | ||||
|   version: "バージョン:" | ||||
|   latest-version: "最新のバージョン:" | ||||
| @@ -1392,6 +1446,9 @@ mobile/views/pages/user.vue: | ||||
|   block: "ブロック" | ||||
|   unblock: "ブロック解除" | ||||
|   years-old: "{age}歳" | ||||
|   push-to-list: "リストに追加" | ||||
|   select-list: "リストを選択してください" | ||||
|   list-pushed: "{user}を{list}に追加しました" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "最近の投稿" | ||||
|   images: "画像" | ||||
|   | ||||
| @@ -26,6 +26,7 @@ common: | ||||
|   close: "关闭" | ||||
|   do-not-copy-paste: "请不要在这里输入或粘贴代码。您帐户可能会受到损害。" | ||||
|   load-more: "加载更多" | ||||
|   enter-password: "请输入您的密码" | ||||
|   got-it: "没问题" | ||||
|   customization-tips: | ||||
|     title: "客制化提示" | ||||
| @@ -109,9 +110,10 @@ common: | ||||
|   my-token-regenerated: "您的 Token 已被重置, 您将自动登出。" | ||||
|   i-like-sushi: "相比于布丁来说, 我更喜欢寿司。" | ||||
|   show-reversi-board-labels: "在 Reversi 中显示行和列表签" | ||||
|   use-contrast-reversi-stones: "Make the stone color clear in Reversi" | ||||
|   use-white-black-reversi-stones: "リバーシに白黒の石を使う" | ||||
|   verified-user: "认证用户" | ||||
|   disable-animated-mfm: "在帖子中禁用动画文本" | ||||
|   suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示する" | ||||
|   always-show-nsfw: "总是显示 NSFW 的内容" | ||||
|   always-mark-nsfw: "总是用 NSFW 来标记附件" | ||||
|   show-full-acct: "不要从用户名中忽略主机名" | ||||
| @@ -157,12 +159,12 @@ common: | ||||
|     polls: "投票" | ||||
|     post-form: "投稿形式" | ||||
|     server: "服务器信息" | ||||
|     donation: "捐助" | ||||
|     nav: "导航" | ||||
|     tips: "提示" | ||||
|     hashtags: "标签" | ||||
|   dev: "构建应用程序失败,请再试一次。" | ||||
|   ai-chan-kawaii: "Ai-chan kawaii!" | ||||
|   you: "あなた" | ||||
| auth/views/form.vue: | ||||
|   share-access: "您要允许<i>{name}</i>来访问您的账户吗?" | ||||
|   permission-ask: "这个应用程序需要以下权限:" | ||||
| @@ -295,6 +297,8 @@ common/views/components/theme.vue: | ||||
| common/views/components/cw-button.vue: | ||||
|   hide: "隐藏" | ||||
|   show: "查看更多" | ||||
|   chars: "{count}文字" | ||||
|   files: "{count}ファイル" | ||||
| common/views/components/messaging.vue: | ||||
|   search-user: "查找用户" | ||||
|   you: "您" | ||||
| @@ -399,13 +403,11 @@ common/views/components/stream-indicator.vue: | ||||
|   connecting: "连接中" | ||||
|   reconnecting: "重新连接中" | ||||
|   connected: "已连接" | ||||
| common/views/components/twitter-setting.vue: | ||||
|   description: "当您用Twitter连接Misskey账户后,您将能够看到有关您自己的信息,并且您将能够使用Twitter登录。" | ||||
|   connected-to: "此账户已连接Twitter" | ||||
|   detail: "详细信息..." | ||||
|   reconnect: "重新连接" | ||||
|   connect: "连接您的推特账户" | ||||
|   disconnect: "未连接" | ||||
| common/views/components/integration-settings.vue: | ||||
|   title: "サービス連携" | ||||
|   connect: "接続する" | ||||
|   disconnect: "切断する" | ||||
|   connected-to: "次のアカウントに接続されています" | ||||
| common/views/components/github-setting.vue: | ||||
|   description: "当您用GitHub连接Misskey账户后,您将能够看到有关您自己的信息,并且您将能够使用GitHub登录。" | ||||
|   connected-to: "此账户已连接GitHub" | ||||
| @@ -438,12 +440,20 @@ common/views/components/visibility-chooser.vue: | ||||
| common/views/components/trends.vue: | ||||
|   count: "{} 被提到" | ||||
|   empty: "没有流行的标签" | ||||
| common/views/components/language-settings.vue: | ||||
|   title: "显示语言" | ||||
|   pick-language: "选择一个语言" | ||||
|   recommended: "推荐" | ||||
|   auto: "自动" | ||||
|   specify-language: "指定语言" | ||||
|   info: "你需要刷新这个页面来应用更改。" | ||||
| common/views/components/profile-editor.vue: | ||||
|   title: "简况" | ||||
|   name: "名称" | ||||
|   account: "账户" | ||||
|   location: "位置" | ||||
|   description: "关于我" | ||||
|   language: "言語" | ||||
|   birthday: "生日" | ||||
|   avatar: "头像" | ||||
|   banner: "背景" | ||||
| @@ -457,6 +467,10 @@ common/views/components/profile-editor.vue: | ||||
|   saved: "更新配置文件成功" | ||||
|   uploading: "正在上传" | ||||
|   upload-failed: "上传失败" | ||||
|   email: "邮件设置" | ||||
|   email-address: "电子邮件地址" | ||||
|   email-verified: "电子邮件地址已验证" | ||||
|   email-not-verified: "电子邮件地址还没有验证哦, 请检查一下收信箱吧~" | ||||
| common/views/widgets/broadcast.vue: | ||||
|   fetching: "确认中" | ||||
|   no-broadcasts: "没有公告" | ||||
| @@ -469,9 +483,6 @@ common/views/widgets/calendar.vue: | ||||
|   today: "今天:" | ||||
|   this-month: "本月:" | ||||
|   this-year: "今年:" | ||||
| common/views/widgets/donation.vue: | ||||
|   title: "请求捐助" | ||||
|   text: "为了保持 Misskey 持续运行, 这会对域名,服务器等产生一些费用。 如果您有兴趣提供捐助,请联系{}。感谢您的贡献!" | ||||
| common/views/widgets/photo-stream.vue: | ||||
|   title: "图片轮播" | ||||
|   no-photos: "没有图片" | ||||
| @@ -512,6 +523,8 @@ common/views/widgets/tips.vue: | ||||
|   tips-line23: "Mayu的眉毛非常可爱。" | ||||
|   tips-line24: "Misskey自2014年开始运营。" | ||||
|   tips-line25: "在与通知功能兼容的浏览器中,您可以在Misskey未打开的情况下接收通知" | ||||
| common/views/pages/404.vue: | ||||
|   page-not-found: "ページが見つかりませんでした" | ||||
| common/views/pages/follow.vue: | ||||
|   signed-in-as: "用 {}登录" | ||||
|   following: "正在关注" | ||||
| @@ -731,6 +744,8 @@ desktop/views/components/settings.vue: | ||||
|   note-visibility: "帖子可见性" | ||||
|   default-note-visibility: "默认可见性" | ||||
|   remember-note-visibility: "记住帖子可见性" | ||||
|   web-search-engine: "搜索引擎" | ||||
|   web-search-engine-desc: "例如: https://www.google.com/?#q={{query}}" | ||||
|   auto-popout: "自动弹出窗口" | ||||
|   auto-popout-desc: "如果可用,将使用弹出显示而不是打开新窗口。 此设置存储在浏览器中。" | ||||
|   advanced: "更多设置" | ||||
| @@ -750,7 +765,6 @@ desktop/views/components/settings.vue: | ||||
|   circle-icons: "使用圆形图标" | ||||
|   contrasted-acct: "增加用户名的对比度" | ||||
|   post-form-on-timeline: "在时间线顶部显示帖子表单" | ||||
|   suggest-recent-hashtags: "在帖子表单上显示最近流行的主题标签" | ||||
|   show-clock-on-header: "在右上角显示时钟" | ||||
|   show-reply-target: "显示回复目标" | ||||
|   timeline: "时间线" | ||||
| @@ -759,20 +773,21 @@ desktop/views/components/settings.vue: | ||||
|   show-local-renotes: "在时间线中显示Local Renote(s)" | ||||
|   show-maps: "显示地图以显示位置" | ||||
|   remain-deleted-note: "继续显示已删除的帖子" | ||||
|   deck-column-align: "甲板柱的位置" | ||||
|   deck-column-align: "デッキのカラムの配置" | ||||
|   deck-column-align-center: "中央" | ||||
|   deck-column-align-left: "左" | ||||
|   deck-column-align-flexible: "フレキシブル" | ||||
|   deck-column-width: "デッキのカラムの幅" | ||||
|   deck-column-width-narrow: "狭" | ||||
|   deck-column-width-narrower: "やや狭" | ||||
|   deck-column-width-normal: "普通" | ||||
|   deck-column-width-wider: "やや広" | ||||
|   deck-column-width-wide: "広" | ||||
|   sound: "声音" | ||||
|   enable-sounds: "开启声音" | ||||
|   enable-sounds-desc: "收到帖子/留言时播放声音。 此设置将被存储在浏览器中。" | ||||
|   volume: "音量" | ||||
|   test: "测试" | ||||
|   language: "语言" | ||||
|   pick-language: "选择一个语言" | ||||
|   recommended: "推荐" | ||||
|   auto: "自动" | ||||
|   specify-language: "指定语言" | ||||
|   language-desc: "你需要刷新这个页面来应用更改。" | ||||
|   cache: "缓存" | ||||
|   clean-cache: "清除缓存" | ||||
|   cache-warn: "将删除存储在浏览器中的帐户信息/帖子/回复/消息/设置的缓存。 清理完毕后需要刷新页面。" | ||||
| @@ -862,11 +877,17 @@ common/views/components/password-settings.vue: | ||||
|   enter-new-password-again: "请再次输入新密码" | ||||
|   not-match: "新密码不匹配" | ||||
|   changed: "密码已更改" | ||||
|   failed: "パスワード変更に失敗しました" | ||||
| desktop/views/components/sub-note-content.vue: | ||||
|   private: "这个帖子是私密的" | ||||
|   deleted: "帖子已删除" | ||||
|   media-count: "附加{}媒体" | ||||
|   poll: "投票" | ||||
| desktop/views/components/settings.tags.vue: | ||||
|   title: "タグ" | ||||
|   query: "クエリ (省略可)" | ||||
|   add: "追加" | ||||
|   save: "保存" | ||||
| desktop/views/components/taskmanager.vue: | ||||
|   title: "任务管理器" | ||||
| desktop/views/components/timeline.vue: | ||||
| @@ -949,6 +970,7 @@ admin/views/instance.vue: | ||||
|   instance-description: "实例介绍" | ||||
|   host: "主机名" | ||||
|   banner-url: "背景图片地址" | ||||
|   error-image-url: "エラー画像URL" | ||||
|   languages: "实例语言" | ||||
|   languages-desc: "您可以添加多个,以空格分隔。" | ||||
|   maintainer-config: "管理员信息" | ||||
| @@ -966,17 +988,17 @@ admin/views/instance.vue: | ||||
|   recaptcha-site-key: "reCAPTCHA site key" | ||||
|   recaptcha-secret-key: "reCAPTCHA secret key" | ||||
|   twitter-integration-config: "连接到Twitter的设置" | ||||
|   twitter-integration-info: "回调 URL 设置为 /api/tw/cb" | ||||
|   twitter-integration-info: "设置返回的URL{url}。" | ||||
|   enable-twitter-integration: "启用连接到Twitter" | ||||
|   twitter-integration-consumer-key: "Consumer key" | ||||
|   twitter-integration-consumer-secret: "Consumer Secret" | ||||
|   github-integration-config: "连接到GitHub设置" | ||||
|   github-integration-info: "回调 URL 设置为 /api/gh/cb" | ||||
|   github-integration-info: "设置返回的URL{url}。" | ||||
|   enable-github-integration: "启用连接到GitHub" | ||||
|   github-integration-client-id: "Client ID" | ||||
|   github-integration-client-secret: "Client Secret" | ||||
|   discord-integration-config: "设置 Discord Integration" | ||||
|   discord-integration-info: "回调 URL 设置为 /api/dc/cb" | ||||
|   discord-integration-info: "设置返回的URL{url}。" | ||||
|   enable-discord-integration: "启用 Discord 连接" | ||||
|   discord-integration-client-id: "Client ID" | ||||
|   discord-integration-client-secret: "Client Secret" | ||||
| @@ -991,6 +1013,22 @@ admin/views/instance.vue: | ||||
|   invite: "邀请" | ||||
|   save: "保存" | ||||
|   saved: "保存完毕" | ||||
|   user-recommendation-config: "推荐用户" | ||||
|   enable-external-user-recommendation: "启用外部用户推荐" | ||||
|   external-user-recommendation-engine: "引擎" | ||||
|   external-user-recommendation-engine-desc: "例如: https://vinayaka.distsn.org/cgi-bin/vinayaka-user-match-misskey-api.cgi?{{host}}+{{user}}+{{limit}}+{{offset}}" | ||||
|   external-user-recommendation-timeout: "超时" | ||||
|   external-user-recommendation-timeout-desc: "单位为毫秒 (例如:300000)" | ||||
|   email-config: "电子邮件服务器设置" | ||||
|   email-config-info: "用于确认电子邮件和密码重置等。" | ||||
|   enable-email: "启用电子邮件送递" | ||||
|   email: "电子邮件地址" | ||||
|   smtp-secure: "在 SMTP 连接中使用隐式 SSL / TLS" | ||||
|   smtp-secure-info: "使用时关闭 STARTTLS。" | ||||
|   smtp-host: "SMTP 服务器地址 (主机名)" | ||||
|   smtp-port: "SMTP 端口" | ||||
|   smtp-user: "SMTP 用户名" | ||||
|   smtp-pass: "SMTP 密码" | ||||
| admin/views/charts.vue: | ||||
|   title: "历史记录" | ||||
|   per-day: "每天" | ||||
| @@ -1016,19 +1054,50 @@ admin/views/charts.vue: | ||||
|     network-requests: "请求" | ||||
|     network-time: "响应时间" | ||||
|     network-usage: "网络流量" | ||||
| admin/views/drive.vue: | ||||
|   sort: | ||||
|     title: "ソート" | ||||
|     createdAtAsc: "アップロード日時が古い順" | ||||
|     createdAtDesc: "アップロード日時が新しい順" | ||||
|     sizeAsc: "サイズが小さい順" | ||||
|     sizeDesc: "サイズが大きい順" | ||||
|   origin: | ||||
|     title: "オリジン" | ||||
|     combined: "ローカル+リモート" | ||||
|     local: "ローカル" | ||||
|     remote: "リモート" | ||||
|   delete: "削除" | ||||
|   deleted: "削除しました" | ||||
| admin/views/users.vue: | ||||
|   suspend-user: "冻结用户" | ||||
|   operation: "操作" | ||||
|   username-or-userid: "用户名或用户ID" | ||||
|   user-not-found: "用户不存在" | ||||
|   lookup: "订阅" | ||||
|   reset-password: "密码重置" | ||||
|   password-updated: "密码为「{password}」" | ||||
|   suspend: "被冻结" | ||||
|   suspended: "成功冻结用户" | ||||
|   unsuspend-user: "解除用户冻结" | ||||
|   unsuspend: "已解除冻结" | ||||
|   unsuspended: "已成功解除用户冻结" | ||||
|   verify-user: "用户账户认证设置" | ||||
|   verify: "认证用户" | ||||
|   verified: "此账户已被认证" | ||||
|   unverify-user: "用户账号解除认证设置" | ||||
|   unverify: "解除账户认证" | ||||
|   unverified: "该帐户未经认证" | ||||
|   users: | ||||
|     title: "用户" | ||||
|     sort: | ||||
|       title: "排序" | ||||
|       createdAtAsc: "注册时间从旧到新" | ||||
|       createdAtDesc: "注册时间从新到旧" | ||||
|       updatedAtAsc: "更新时间从旧到新" | ||||
|       updatedAtDesc: "更新时间从新到旧" | ||||
|     origin: | ||||
|       title: "源自" | ||||
|       combined: "本地+远程" | ||||
|       local: "本地" | ||||
|       remote: "远程" | ||||
|     createdAt: "注册日期" | ||||
|     updatedAt: "最后更新" | ||||
| admin/views/moderators.vue: | ||||
|   add-moderator: | ||||
|     title: "注册版主" | ||||
| @@ -1321,11 +1390,6 @@ mobile/views/pages/selectdrive.vue: | ||||
|   select-file: "选择文件" | ||||
| mobile/views/pages/settings.vue: | ||||
|   signed-in-as: "以{}登录" | ||||
|   lang: "语言" | ||||
|   lang-tip: "你需要刷新这个页面来应用更改。" | ||||
|   recommended: "推荐" | ||||
|   auto: "自动" | ||||
|   specify-language: "选择语言" | ||||
|   design: "设计与展示" | ||||
|   dark-mode: "夜间模式" | ||||
|   i-am-under-limited-internet: "我的带宽有限" | ||||
| @@ -1348,21 +1412,11 @@ mobile/views/pages/settings.vue: | ||||
|   note-visibility: "帖子可见性" | ||||
|   default-note-visibility: "默认可见性" | ||||
|   remember-note-visibility: "记住帖子可见性" | ||||
|   web-search-engine: "搜索引擎" | ||||
|   web-search-engine-desc: "例如: https://www.google.com/?#q={{query}}" | ||||
|   disable-via-mobile: "不要将帖子标记为“来自手机”" | ||||
|   load-raw-images: "以原始质量显示附加图像" | ||||
|   load-remote-media: "显示来自远程服务器的媒体" | ||||
|   twitter: "Twitter integration" | ||||
|   twitter-connect: "连接到您的 Twitter" | ||||
|   twitter-reconnect: "重新连接" | ||||
|   twitter-disconnect: "未连接" | ||||
|   github: "GitHub Integration" | ||||
|   github-connect: "连接到您的 GitHub" | ||||
|   github-reconnect: "重新连接" | ||||
|   github-disconnect: "未连接" | ||||
|   discord: "Discord Integration" | ||||
|   discord-connect: "连接到您的 Discord" | ||||
|   discord-reconnect: "重新连接" | ||||
|   discord-disconnect: "未连接" | ||||
|   update: "更新 Misskey" | ||||
|   version: "当前版本:" | ||||
|   latest-version: "最新版本:" | ||||
| @@ -1392,6 +1446,9 @@ mobile/views/pages/user.vue: | ||||
|   block: "屏蔽" | ||||
|   unblock: "取消屏蔽" | ||||
|   years-old: "{age}岁" | ||||
|   push-to-list: "添加至列表" | ||||
|   select-list: "选择一个列表" | ||||
|   list-pushed: "成功添加{user}到{list}" | ||||
| mobile/views/pages/user/home.vue: | ||||
|   recent-notes: "最近的帖子" | ||||
|   images: "图片" | ||||
|   | ||||
							
								
								
									
										70
									
								
								package.json
									
									
									
									
									
								
							
							
						
						| @@ -1,8 +1,8 @@ | ||||
| { | ||||
| 	"name": "misskey", | ||||
| 	"author": "syuilo <i@syuilo.com>", | ||||
| 	"version": "10.56.1", | ||||
| 	"clientVersion": "2.0.11960", | ||||
| 	"version": "10.66.1", | ||||
| 	"clientVersion": "2.0.12859", | ||||
| 	"codename": "nighthike", | ||||
| 	"main": "./built/index.js", | ||||
| 	"private": true, | ||||
| @@ -34,10 +34,9 @@ | ||||
| 		"@types/debug": "0.0.31", | ||||
| 		"@types/deep-equal": "1.0.1", | ||||
| 		"@types/double-ended-queue": "2.1.0", | ||||
| 		"@types/elasticsearch": "5.0.28", | ||||
| 		"@types/file-type": "5.2.1", | ||||
| 		"@types/elasticsearch": "5.0.29", | ||||
| 		"@types/file-type": "5.2.2", | ||||
| 		"@types/gulp": "3.8.36", | ||||
| 		"@types/gulp-htmlmin": "1.3.32", | ||||
| 		"@types/gulp-mocha": "0.0.32", | ||||
| 		"@types/gulp-rename": "0.0.33", | ||||
| 		"@types/gulp-replace": "0.0.31", | ||||
| @@ -47,14 +46,14 @@ | ||||
| 		"@types/is-url": "1.2.28", | ||||
| 		"@types/js-yaml": "3.11.2", | ||||
| 		"@types/katex": "0.5.0", | ||||
| 		"@types/koa": "2.0.46", | ||||
| 		"@types/koa-bodyparser": "5.0.1", | ||||
| 		"@types/koa": "2.0.47", | ||||
| 		"@types/koa-bodyparser": "5.0.2", | ||||
| 		"@types/koa-compress": "2.0.8", | ||||
| 		"@types/koa-favicon": "2.0.19", | ||||
| 		"@types/koa-logger": "3.1.1", | ||||
| 		"@types/koa-mount": "3.0.1", | ||||
| 		"@types/koa-multer": "1.0.0", | ||||
| 		"@types/koa-router": "7.0.33", | ||||
| 		"@types/koa-router": "7.0.35", | ||||
| 		"@types/koa-send": "4.1.1", | ||||
| 		"@types/koa-views": "2.0.3", | ||||
| 		"@types/koa__cors": "2.2.3", | ||||
| @@ -63,14 +62,15 @@ | ||||
| 		"@types/mocha": "5.2.5", | ||||
| 		"@types/mongodb": "3.1.14", | ||||
| 		"@types/ms": "0.7.30", | ||||
| 		"@types/node": "10.12.2", | ||||
| 		"@types/node": "10.12.10", | ||||
| 		"@types/nodemailer": "4.6.5", | ||||
| 		"@types/oauth": "0.9.1", | ||||
| 		"@types/parsimmon": "1.10.0", | ||||
| 		"@types/portscanner": "2.1.0", | ||||
| 		"@types/pug": "2.0.4", | ||||
| 		"@types/qrcode": "1.3.0", | ||||
| 		"@types/ratelimiter": "2.1.28", | ||||
| 		"@types/redis": "2.8.7", | ||||
| 		"@types/redis": "2.8.8", | ||||
| 		"@types/request": "2.48.1", | ||||
| 		"@types/request-promise-native": "1.0.15", | ||||
| 		"@types/rimraf": "2.0.2", | ||||
| @@ -78,17 +78,17 @@ | ||||
| 		"@types/sharp": "0.21.0", | ||||
| 		"@types/showdown": "1.7.5", | ||||
| 		"@types/speakeasy": "2.0.3", | ||||
| 		"@types/systeminformation": "3.23.0", | ||||
| 		"@types/systeminformation": "3.23.1", | ||||
| 		"@types/tinycolor2": "1.4.1", | ||||
| 		"@types/tmp": "0.0.33", | ||||
| 		"@types/uuid": "3.4.4", | ||||
| 		"@types/webpack": "4.4.19", | ||||
| 		"@types/webpack": "4.4.20", | ||||
| 		"@types/webpack-stream": "3.2.10", | ||||
| 		"@types/websocket": "0.0.40", | ||||
| 		"@types/ws": "6.0.1", | ||||
| 		"animejs": "2.2.0", | ||||
| 		"apexcharts": "2.2.2", | ||||
| 		"autobind-decorator": "2.2.1", | ||||
| 		"apexcharts": "2.4.2", | ||||
| 		"autobind-decorator": "2.4.0", | ||||
| 		"autosize": "4.0.2", | ||||
| 		"autwh": "0.1.0", | ||||
| 		"bcryptjs": "2.4.3", | ||||
| @@ -106,23 +106,22 @@ | ||||
| 		"debug": "4.1.0", | ||||
| 		"deep-equal": "1.0.1", | ||||
| 		"deepcopy": "0.6.3", | ||||
| 		"diskusage": "0.2.5", | ||||
| 		"diskusage": "1.0.0", | ||||
| 		"double-ended-queue": "2.1.0-0", | ||||
| 		"elasticsearch": "15.2.0", | ||||
| 		"emojilib": "2.3.0", | ||||
| 		"emojilib": "2.4.0", | ||||
| 		"escape-regexp": "0.0.1", | ||||
| 		"eslint": "5.8.0", | ||||
| 		"eslint-plugin-vue": "4.7.1", | ||||
| 		"eventemitter3": "3.1.0", | ||||
| 		"feed": "2.0.2", | ||||
| 		"file-loader": "2.0.0", | ||||
| 		"file-type": "10.4.0", | ||||
| 		"file-type": "10.6.0", | ||||
| 		"fuckadblock": "3.2.1", | ||||
| 		"gulp": "3.9.1", | ||||
| 		"gulp-cssnano": "2.1.3", | ||||
| 		"gulp-htmlmin": "5.0.1", | ||||
| 		"gulp-imagemin": "4.1.0", | ||||
| 		"gulp-mocha": "6.0.0", | ||||
| 		"gulp-pug": "4.0.1", | ||||
| 		"gulp-rename": "1.4.0", | ||||
| 		"gulp-replace": "1.0.0", | ||||
| 		"gulp-sourcemaps": "2.6.4", | ||||
| @@ -143,7 +142,7 @@ | ||||
| 		"json5": "2.1.0", | ||||
| 		"json5-loader": "1.0.1", | ||||
| 		"katex": "0.10.0", | ||||
| 		"koa": "2.6.1", | ||||
| 		"koa": "2.6.2", | ||||
| 		"koa-bodyparser": "4.2.1", | ||||
| 		"koa-compress": "3.0.0", | ||||
| 		"koa-favicon": "2.0.1", | ||||
| @@ -155,8 +154,9 @@ | ||||
| 		"koa-send": "5.0.0", | ||||
| 		"koa-slow": "2.1.0", | ||||
| 		"koa-views": "6.1.4", | ||||
| 		"langmap": "0.0.16", | ||||
| 		"loader-utils": "1.1.0", | ||||
| 		"minio": "7.0.1", | ||||
| 		"minio": "7.0.2", | ||||
| 		"mkdirp": "0.5.1", | ||||
| 		"mocha": "5.2.0", | ||||
| 		"moji": "0.5.1", | ||||
| @@ -166,6 +166,7 @@ | ||||
| 		"ms": "2.1.1", | ||||
| 		"nan": "2.11.1", | ||||
| 		"nested-property": "0.0.7", | ||||
| 		"nodemailer": "4.7.0", | ||||
| 		"nprogress": "0.2.0", | ||||
| 		"object-assign-deep": "0.4.0", | ||||
| 		"on-build-webpack": "0.1.0", | ||||
| @@ -201,43 +202,44 @@ | ||||
| 		"stylus": "0.54.5", | ||||
| 		"stylus-loader": "3.0.2", | ||||
| 		"summaly": "2.2.0", | ||||
| 		"systeminformation": "3.47.0", | ||||
| 		"systeminformation": "3.51.3", | ||||
| 		"syuilo-password-strength": "0.0.1", | ||||
| 		"terser-webpack-plugin": "1.1.0", | ||||
| 		"textarea-caret": "3.1.0", | ||||
| 		"tinycolor2": "1.4.1", | ||||
| 		"tmp": "0.0.33", | ||||
| 		"ts-loader": "5.3.0", | ||||
| 		"ts-loader": "5.3.1", | ||||
| 		"ts-node": "7.0.1", | ||||
| 		"tslint": "5.10.0", | ||||
| 		"typescript": "3.1.6", | ||||
| 		"typescript-eslint-parser": "21.0.1", | ||||
| 		"typescript": "3.2.2", | ||||
| 		"typescript-eslint-parser": "21.0.2", | ||||
| 		"uglify-es": "3.3.9", | ||||
| 		"url-loader": "1.1.2", | ||||
| 		"uuid": "3.3.2", | ||||
| 		"v-animate-css": "0.0.2", | ||||
| 		"v-animate-css": "0.0.3", | ||||
| 		"vue": "2.5.17", | ||||
| 		"vue-color": "2.7.0", | ||||
| 		"vue-content-loading": "1.5.3", | ||||
| 		"vue-cropperjs": "2.2.2", | ||||
| 		"vue-i18n": "8.3.1", | ||||
| 		"vue-js-modal": "1.3.26", | ||||
| 		"vue-i18n": "8.3.2", | ||||
| 		"vue-js-modal": "1.3.27", | ||||
| 		"vue-loader": "15.4.2", | ||||
| 		"vue-marquee-text-component": "1.1.0", | ||||
| 		"vue-router": "3.0.1", | ||||
| 		"vue-router": "3.0.2", | ||||
| 		"vue-sequential-entrance": "1.1.3", | ||||
| 		"vue-style-loader": "4.1.2", | ||||
| 		"vue-svg-inline-loader": "1.2.2", | ||||
| 		"vue-svg-inline-loader": "1.2.4", | ||||
| 		"vue-template-compiler": "2.5.17", | ||||
| 		"vuedraggable": "2.16.0", | ||||
| 		"vuedraggable": "2.17.0", | ||||
| 		"vuewordcloud": "18.7.11", | ||||
| 		"vuex": "3.0.1", | ||||
| 		"vuex-persistedstate": "2.5.4", | ||||
| 		"web-push": "3.3.3", | ||||
| 		"webfinger.js": "2.6.6", | ||||
| 		"webpack": "4.25.1", | ||||
| 		"webfinger.js": "2.7.0", | ||||
| 		"webpack": "4.26.1", | ||||
| 		"webpack-cli": "3.1.2", | ||||
| 		"websocket": "1.0.28", | ||||
| 		"ws": "6.1.0", | ||||
| 		"ws": "6.1.2", | ||||
| 		"xev": "2.0.1" | ||||
| 	} | ||||
| } | ||||
|   | ||||
| @@ -61,11 +61,12 @@ export default abstract class Chart<T> { | ||||
|  | ||||
| 	constructor(name: string, grouped = false) { | ||||
| 		this.collection = db.get<Log<T>>(`chart.${name}`); | ||||
| 		if (grouped) { | ||||
| 			this.collection.createIndex({ span: -1, date: -1, group: -1 }, { unique: true }); | ||||
| 		} else { | ||||
| 			this.collection.createIndex({ span: -1, date: -1 }, { unique: true }); | ||||
| 		} | ||||
| 		const keys = { | ||||
| 			span: -1, | ||||
| 			date: -1 | ||||
| 		} as { [key: string]: 1 | -1; }; | ||||
| 		if (grouped) keys.group = -1; | ||||
| 		this.collection.createIndex(keys, { unique: true }); | ||||
| 	} | ||||
|  | ||||
| 	@autobind | ||||
| @@ -73,14 +74,14 @@ export default abstract class Chart<T> { | ||||
| 		const query: Obj = {}; | ||||
|  | ||||
| 		const dive = (x: Obj, path: string) => { | ||||
| 			Object.entries(x).forEach(([k, v]) => { | ||||
| 			for (const [k, v] of Object.entries(x)) { | ||||
| 				const p = path ? `${path}.${k}` : k; | ||||
| 				if (typeof v === 'number') { | ||||
| 					query[p] = v; | ||||
| 				} else { | ||||
| 					dive(v, p); | ||||
| 				} | ||||
| 			}); | ||||
| 			} | ||||
| 		}; | ||||
|  | ||||
| 		dive(x, path); | ||||
| @@ -333,14 +334,14 @@ export default abstract class Chart<T> { | ||||
| 		 * にする | ||||
| 		 */ | ||||
| 		const dive = (x: Obj, path?: string) => { | ||||
| 			Object.entries(x).forEach(([k, v]) => { | ||||
| 			for (const [k, v] of Object.entries(x)) { | ||||
| 				const p = path ? `${path}.${k}` : k; | ||||
| 				if (typeof v == 'object') { | ||||
| 					dive(v, p); | ||||
| 				} else { | ||||
| 					nestedProperty.set(res, p, chart.map(s => nestedProperty.get(s, p))); | ||||
| 				} | ||||
| 			}); | ||||
| 			} | ||||
| 		}; | ||||
|  | ||||
| 		dive(chart[0]); | ||||
|   | ||||
| @@ -9,6 +9,7 @@ import './style.styl'; | ||||
|  | ||||
| import init from '../init'; | ||||
| import Index from './views/index.vue'; | ||||
| import NotFound from '../common/views/pages/404.vue'; | ||||
|  | ||||
| init(launch => { | ||||
| 	document.title = 'Admin'; | ||||
| @@ -19,6 +20,7 @@ init(launch => { | ||||
| 		base: '/admin/', | ||||
| 		routes: [ | ||||
| 			{ path: '/', component: Index }, | ||||
| 			{ path: '*', component: NotFound } | ||||
| 		] | ||||
| 	}); | ||||
|  | ||||
|   | ||||
| @@ -9,7 +9,7 @@ | ||||
| 			<ui-textarea v-model="announcement.text"> | ||||
| 				<span>{{ $t('text') }}</span> | ||||
| 			</ui-textarea> | ||||
| 			<ui-horizon-group> | ||||
| 			<ui-horizon-group class="fit-bottom"> | ||||
| 				<ui-button @click="save()"><fa :icon="['far', 'save']"/> {{ $t('save') }}</ui-button> | ||||
| 				<ui-button @click="remove(i)"><fa :icon="['far', 'trash-alt']"/> {{ $t('remove') }}</ui-button> | ||||
| 			</ui-horizon-group> | ||||
| @@ -48,15 +48,15 @@ export default Vue.extend({ | ||||
| 		}, | ||||
|  | ||||
| 		remove(i) { | ||||
| 			this.$root.alert({ | ||||
| 			this.$root.dialog({ | ||||
| 				type: 'warning', | ||||
| 				text: this.$t('_remove.are-you-sure').replace('$1', this.announcements.find((_, j) => j == i).title), | ||||
| 				showCancelButton: true | ||||
| 			}).then(res => { | ||||
| 				if (!res) return; | ||||
| 			}).then(({ canceled }) => { | ||||
| 				if (canceled) return; | ||||
| 				this.announcements = this.announcements.filter((_, j) => j !== i); | ||||
| 				this.save(true); | ||||
| 				this.$root.alert({ | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					text: this.$t('_remove.removed') | ||||
| 				}); | ||||
| @@ -68,13 +68,13 @@ export default Vue.extend({ | ||||
| 				broadcasts: this.announcements | ||||
| 			}).then(() => { | ||||
| 				if (!silent) { | ||||
| 					this.$root.alert({ | ||||
| 					this.$root.dialog({ | ||||
| 						type: 'success', | ||||
| 						text: this.$t('saved') | ||||
| 					}); | ||||
| 				} | ||||
| 			}).catch(e => { | ||||
| 				this.$root.alert({ | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'error', | ||||
| 					text: e | ||||
| 				}); | ||||
|   | ||||
| @@ -56,7 +56,9 @@ export default Vue.extend({ | ||||
| 		}, | ||||
|  | ||||
| 		onLogs(logs) { | ||||
| 			logs.reverse().forEach(log => this.onLog(log)); | ||||
| 			for (const log of logs.reverse()) { | ||||
| 				this.onLog(log) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
|   | ||||
| @@ -132,7 +132,9 @@ export default Vue.extend({ | ||||
| 		}, | ||||
|  | ||||
| 		onStatsLog(statsLog) { | ||||
| 			statsLog.reverse().forEach(stats => this.onStats(stats)); | ||||
| 			for (const stats of statsLog.reverse()) { | ||||
| 				this.onStats(stats); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
|   | ||||
| @@ -127,12 +127,12 @@ export default Vue.extend({ | ||||
| 		this.$root.api('instances', { | ||||
| 			sort: '+notes' | ||||
| 		}).then(instances => { | ||||
| 			instances.forEach(i => { | ||||
| 			for (const i of instances) { | ||||
| 				i.bg = randomColor({ | ||||
| 					seed: i.host, | ||||
| 					luminosity: 'dark' | ||||
| 				}); | ||||
| 			}); | ||||
| 			} | ||||
| 			this.instances = instances; | ||||
| 		}); | ||||
| 	}, | ||||
|   | ||||
							
								
								
									
										188
									
								
								src/client/app/admin/views/drive.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,188 @@ | ||||
| <template> | ||||
| <div class="pwnqwyet"> | ||||
| 	<ui-card> | ||||
| 		<div slot="title"><fa :icon="faCloud"/> {{ $t('@.drive') }}</div> | ||||
| 		<section class="fit-top"> | ||||
| 			<ui-horizon-group inputs> | ||||
| 				<ui-select v-model="sort"> | ||||
| 					<span slot="label">{{ $t('sort.title') }}</span> | ||||
| 					<option value="-createdAt">{{ $t('sort.createdAtAsc') }}</option> | ||||
| 					<option value="+createdAt">{{ $t('sort.createdAtDesc') }}</option> | ||||
| 					<option value="-size">{{ $t('sort.sizeAsc') }}</option> | ||||
| 					<option value="+size">{{ $t('sort.sizeDesc') }}</option> | ||||
| 				</ui-select> | ||||
| 				<ui-select v-model="origin"> | ||||
| 					<span slot="label">{{ $t('origin.title') }}</span> | ||||
| 					<option value="combined">{{ $t('origin.combined') }}</option> | ||||
| 					<option value="local">{{ $t('origin.local') }}</option> | ||||
| 					<option value="remote">{{ $t('origin.remote') }}</option> | ||||
| 				</ui-select> | ||||
| 			</ui-horizon-group> | ||||
| 			<sequential-entrance animation="entranceFromTop" delay="25"> | ||||
| 				<div class="kidvdlkg" v-for="file in files"> | ||||
| 					<div @click="file._open = !file._open"> | ||||
| 						<div> | ||||
| 							<div class="thumbnail" :style="thumbnail(file)"></div> | ||||
| 						</div> | ||||
| 						<div> | ||||
| 							<header> | ||||
| 								<b>{{ file.name }}</b> | ||||
| 								<span class="username">@{{ file.user | acct }}</span> | ||||
| 							</header> | ||||
| 							<div> | ||||
| 								<div> | ||||
| 									<span style="margin-right:16px;">{{ file.type }}</span> | ||||
| 									<span>{{ file.datasize | bytes }}</span> | ||||
| 								</div> | ||||
| 								<div><mk-time :time="file.createdAt" mode="detail"/></div> | ||||
| 							</div> | ||||
| 						</div> | ||||
| 					</div> | ||||
| 					<div v-show="file._open"> | ||||
| 						<ui-horizon-group> | ||||
| 							<ui-button @click="toggleSensitive(file)" v-if="file.isSensitive"><fa :icon="faEye"/> {{ $t('unmark-as-sensitive') }}</ui-button> | ||||
| 							<ui-button @click="toggleSensitive(file)" v-else><fa :icon="faEyeSlash"/> {{ $t('mark-as-sensitive') }}</ui-button> | ||||
| 							<ui-button @click="del(file)"><fa :icon="faTrashAlt"/> {{ $t('delete') }}</ui-button> | ||||
| 						</ui-horizon-group> | ||||
| 					</div> | ||||
| 				</div> | ||||
| 			</sequential-entrance> | ||||
| 			<ui-button v-if="existMore" @click="fetch">{{ $t('@.load-more') }}</ui-button> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import i18n from '../../i18n'; | ||||
| import { faCloud } from '@fortawesome/free-solid-svg-icons'; | ||||
| import { faTrashAlt, faEye, faEyeSlash } from '@fortawesome/free-regular-svg-icons'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n: i18n('admin/views/drive.vue'), | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			sort: '+createdAt', | ||||
| 			origin: 'combined', | ||||
| 			limit: 10, | ||||
| 			offset: 0, | ||||
| 			files: [], | ||||
| 			existMore: false, | ||||
| 			faCloud, faTrashAlt, faEye, faEyeSlash | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	watch: { | ||||
| 		sort() { | ||||
| 			this.files = []; | ||||
| 			this.offset = 0; | ||||
| 			this.fetch(); | ||||
| 		}, | ||||
|  | ||||
| 		origin() { | ||||
| 			this.files = []; | ||||
| 			this.offset = 0; | ||||
| 			this.fetch(); | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	mounted() { | ||||
| 		this.fetch(); | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		fetch() { | ||||
| 			this.$root.api('admin/drive/files', { | ||||
| 				origin: this.origin, | ||||
| 				sort: this.sort, | ||||
| 				offset: this.offset, | ||||
| 				limit: this.limit + 1 | ||||
| 			}).then(files => { | ||||
| 				if (files.length == this.limit + 1) { | ||||
| 					files.pop(); | ||||
| 					this.existMore = true; | ||||
| 				} else { | ||||
| 					this.existMore = false; | ||||
| 				} | ||||
| 				for (const x of files) { | ||||
| 					x._open = false; | ||||
| 				} | ||||
| 				this.files = this.files.concat(files); | ||||
| 				this.offset += this.limit; | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		thumbnail(file: any): any { | ||||
| 			return { | ||||
| 				'background-color': file.properties.avgColor && file.properties.avgColor.length == 3 ? `rgb(${file.properties.avgColor.join(',')})` : 'transparent', | ||||
| 				'background-image': `url(${file.thumbnailUrl})` | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		async del(file: any) { | ||||
| 			const process = async () => { | ||||
| 				await this.$root.api('drive/files/delete', { fileId: file.id }); | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					text: this.$t('deleted') | ||||
| 				}); | ||||
| 			}; | ||||
|  | ||||
| 			await process().catch(e => { | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'error', | ||||
| 					text: e.toString() | ||||
| 				}); | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		toggleSensitive(file: any) { | ||||
| 			this.$root.api('drive/files/update', { | ||||
| 				fileId: file.id, | ||||
| 				isSensitive: !file.isSensitive | ||||
| 			}); | ||||
|  | ||||
| 			file.isSensitive = !file.isSensitive; | ||||
| 		}, | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .pwnqwyet | ||||
| 	@media (min-width 500px) | ||||
| 		padding 16px | ||||
|  | ||||
| 	.kidvdlkg | ||||
| 		padding 16px 0 | ||||
| 		border-top solid 1px var(--faceDivider) | ||||
|  | ||||
| 		> div:first-child | ||||
| 			display flex | ||||
| 			cursor pointer | ||||
|  | ||||
| 			> div:nth-child(1) | ||||
| 				> .thumbnail | ||||
| 					display block | ||||
| 					width 64px | ||||
| 					height 64px | ||||
| 					background-size cover | ||||
| 					background-position center center | ||||
|  | ||||
| 			> div:nth-child(2) | ||||
| 				flex 1 | ||||
| 				padding-left 16px | ||||
|  | ||||
| 				@media (max-width 500px) | ||||
| 					font-size 14px | ||||
|  | ||||
| 				> header | ||||
| 					word-break break-word | ||||
|  | ||||
| 					> .username | ||||
| 						margin-left 8px | ||||
| 						opacity 0.7 | ||||
|  | ||||
| </style> | ||||
| @@ -24,24 +24,28 @@ | ||||
|  | ||||
| 	<ui-card> | ||||
| 		<div slot="title"><fa :icon="faGrin"/> {{ $t('emojis.title') }}</div> | ||||
| 		<section v-for="emoji in emojis"> | ||||
| 			<img :src="emoji.url" :alt="emoji.name" style="width: 64px;"/> | ||||
| 			<ui-horizon-group inputs> | ||||
| 				<ui-input v-model="emoji.name"> | ||||
| 					<span>{{ $t('add-emoji.name') }}</span> | ||||
| 		<section v-for="emoji in emojis" class="oryfrbft"> | ||||
| 			<div> | ||||
| 				<img :src="emoji.url" :alt="emoji.name" style="width: 64px;"/> | ||||
| 			</div> | ||||
| 			<div> | ||||
| 				<ui-horizon-group> | ||||
| 					<ui-input v-model="emoji.name"> | ||||
| 						<span>{{ $t('add-emoji.name') }}</span> | ||||
| 					</ui-input> | ||||
| 					<ui-input v-model="emoji.aliases"> | ||||
| 						<span>{{ $t('add-emoji.aliases') }}</span> | ||||
| 					</ui-input> | ||||
| 				</ui-horizon-group> | ||||
| 				<ui-input v-model="emoji.url"> | ||||
| 					<i slot="icon"><fa icon="link"/></i> | ||||
| 					<span>{{ $t('add-emoji.url') }}</span> | ||||
| 				</ui-input> | ||||
| 				<ui-input v-model="emoji.aliases"> | ||||
| 					<span>{{ $t('add-emoji.aliases') }}</span> | ||||
| 				</ui-input> | ||||
| 			</ui-horizon-group> | ||||
| 			<ui-input v-model="emoji.url"> | ||||
| 				<i slot="icon"><fa icon="link"/></i> | ||||
| 				<span>{{ $t('add-emoji.url') }}</span> | ||||
| 			</ui-input> | ||||
| 			<ui-horizon-group> | ||||
| 				<ui-button @click="updateEmoji(emoji)"><fa :icon="['far', 'save']"/> {{ $t('emojis.update') }}</ui-button> | ||||
| 				<ui-button @click="removeEmoji(emoji)"><fa :icon="['far', 'trash-alt']"/> {{ $t('emojis.remove') }}</ui-button> | ||||
| 			</ui-horizon-group> | ||||
| 				<ui-horizon-group class="fit-bottom"> | ||||
| 					<ui-button @click="updateEmoji(emoji)"><fa :icon="['far', 'save']"/> {{ $t('emojis.update') }}</ui-button> | ||||
| 					<ui-button @click="removeEmoji(emoji)"><fa :icon="['far', 'trash-alt']"/> {{ $t('emojis.remove') }}</ui-button> | ||||
| 				</ui-horizon-group> | ||||
| 			</div> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
| </div> | ||||
| @@ -75,13 +79,13 @@ export default Vue.extend({ | ||||
| 				url: this.url, | ||||
| 				aliases: this.aliases.split(' ').filter(x => x.length > 0) | ||||
| 			}).then(() => { | ||||
| 				this.$root.alert({ | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					text: this.$t('add-emoji.added') | ||||
| 				}); | ||||
| 				this.fetchEmojis(); | ||||
| 			}).catch(e => { | ||||
| 				this.$root.alert({ | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'error', | ||||
| 					text: e | ||||
| 				}); | ||||
| @@ -91,7 +95,9 @@ export default Vue.extend({ | ||||
| 		fetchEmojis() { | ||||
| 			this.$root.api('admin/emoji/list').then(emojis => { | ||||
| 				emojis.reverse(); | ||||
| 				emojis.forEach(e => e.aliases = (e.aliases || []).join(' ')); | ||||
| 				for (const e of emojis) { | ||||
| 					e.aliases = (e.aliases || []).join(' '); | ||||
| 				} | ||||
| 				this.emojis = emojis; | ||||
| 			}); | ||||
| 		}, | ||||
| @@ -103,12 +109,12 @@ export default Vue.extend({ | ||||
| 				url: emoji.url, | ||||
| 				aliases: emoji.aliases.split(' ').filter(x => x.length > 0) | ||||
| 			}).then(() => { | ||||
| 				this.$root.alert({ | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					text: this.$t('updated') | ||||
| 				}); | ||||
| 			}).catch(e => { | ||||
| 				this.$root.alert({ | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'error', | ||||
| 					text: e | ||||
| 				}); | ||||
| @@ -116,23 +122,23 @@ export default Vue.extend({ | ||||
| 		}, | ||||
|  | ||||
| 		removeEmoji(emoji) { | ||||
| 			this.$root.alert({ | ||||
| 			this.$root.dialog({ | ||||
| 				type: 'warning', | ||||
| 				text: this.$t('remove-emoji.are-you-sure').replace('$1', emoji.name), | ||||
| 				showCancelButton: true | ||||
| 			}).then(res => { | ||||
| 				if (!res) return; | ||||
| 			}).then(({ canceled }) => { | ||||
| 				if (canceled) return; | ||||
|  | ||||
| 				this.$root.api('admin/emoji/remove', { | ||||
| 					id: emoji.id | ||||
| 				}).then(() => { | ||||
| 					this.$root.alert({ | ||||
| 					this.$root.dialog({ | ||||
| 						type: 'success', | ||||
| 						text: this.$t('remove-emoji.removed') | ||||
| 					}); | ||||
| 					this.fetchEmojis(); | ||||
| 				}).catch(e => { | ||||
| 					this.$root.alert({ | ||||
| 					this.$root.dialog({ | ||||
| 						type: 'error', | ||||
| 						text: e | ||||
| 					}); | ||||
| @@ -148,4 +154,21 @@ export default Vue.extend({ | ||||
| 	@media (min-width 500px) | ||||
| 		padding 16px | ||||
|  | ||||
| 	.oryfrbft | ||||
| 		@media (min-width 500px) | ||||
| 			display flex | ||||
|  | ||||
| 		> div:first-child | ||||
| 			@media (max-width 500px) | ||||
| 				padding-bottom 16px | ||||
|  | ||||
| 			> img | ||||
| 				vertical-align bottom | ||||
|  | ||||
| 		> div:last-child | ||||
| 			flex 1 | ||||
|  | ||||
| 			@media (min-width 500px) | ||||
| 				padding-left 16px | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -15,19 +15,18 @@ | ||||
| 		</div> | ||||
| 		<div class="me"> | ||||
| 			<img class="avatar" :src="$store.state.i.avatarUrl" alt="avatar"/> | ||||
| 			<p class="name">{{ $store.state.i | userName }}</p> | ||||
| 			<p class="name"><mk-user-name :user="$store.state.i"/></p> | ||||
| 		</div> | ||||
| 		<ul> | ||||
| 			<li @click="nav('dashboard')" :class="{ active: page == 'dashboard' }"><fa icon="home" fixed-width/>{{ $t('dashboard') }}</li> | ||||
| 			<li @click="nav('instance')" :class="{ active: page == 'instance' }"><fa icon="cog" fixed-width/>{{ $t('instance') }}</li> | ||||
| 			<li @click="nav('moderators')" :class="{ active: page == 'moderators' }"><fa :icon="faHeadset" fixed-width/>{{ $t('moderators') }}</li> | ||||
| 			<li @click="nav('users')" :class="{ active: page == 'users' }"><fa icon="users" fixed-width/>{{ $t('users') }}</li> | ||||
| 			<li @click="nav('drive')" :class="{ active: page == 'drive' }"><fa icon="cloud" fixed-width/>{{ $t('@.drive') }}</li> | ||||
| 			<!-- <li @click="nav('federation')" :class="{ active: page == 'federation' }"><fa :icon="faShareAlt" fixed-width/>{{ $t('federation') }}</li> --> | ||||
| 			<li @click="nav('emoji')" :class="{ active: page == 'emoji' }"><fa :icon="faGrin" fixed-width/>{{ $t('emoji') }}</li> | ||||
| 			<li @click="nav('announcements')" :class="{ active: page == 'announcements' }"><fa icon="broadcast-tower" fixed-width/>{{ $t('announcements') }}</li> | ||||
| 			<li @click="nav('hashtags')" :class="{ active: page == 'hashtags' }"><fa icon="hashtag" fixed-width/>{{ $t('hashtags') }}</li> | ||||
|  | ||||
| 			<!-- <li @click="nav('drive')" :class="{ active: page == 'drive' }"><fa icon="cloud" fixed-width/>{{ $t('@.drive') }}</li> --> | ||||
| 		</ul> | ||||
| 		<div class="back-to-misskey"> | ||||
| 			<a href="/"><fa :icon="faArrowLeft"/> {{ $t('back-to-misskey') }}</a> | ||||
| @@ -45,7 +44,7 @@ | ||||
| 			<div v-if="page == 'emoji'"><x-emoji/></div> | ||||
| 			<div v-if="page == 'announcements'"><x-announcements/></div> | ||||
| 			<div v-if="page == 'hashtags'"><x-hashtags/></div> | ||||
| 			<div v-if="page == 'drive'"></div> | ||||
| 			<div v-if="page == 'drive'"><x-drive/></div> | ||||
| 			<div v-if="page == 'update'"></div> | ||||
| 		</div> | ||||
| 	</main> | ||||
| @@ -63,6 +62,7 @@ import XEmoji from "./emoji.vue"; | ||||
| import XAnnouncements from "./announcements.vue"; | ||||
| import XHashtags from "./hashtags.vue"; | ||||
| import XUsers from "./users.vue"; | ||||
| import XDrive from "./drive.vue"; | ||||
| import { faHeadset, faArrowLeft, faShareAlt } from '@fortawesome/free-solid-svg-icons'; | ||||
| import { faGrin } from '@fortawesome/free-regular-svg-icons'; | ||||
|  | ||||
| @@ -79,7 +79,8 @@ export default Vue.extend({ | ||||
| 		XEmoji, | ||||
| 		XAnnouncements, | ||||
| 		XHashtags, | ||||
| 		XUsers | ||||
| 		XUsers, | ||||
| 		XDrive, | ||||
| 	}, | ||||
| 	provide: { | ||||
| 		isMobile | ||||
|   | ||||
| @@ -7,16 +7,21 @@ | ||||
| 			<ui-input v-model="name">{{ $t('instance-name') }}</ui-input> | ||||
| 			<ui-textarea v-model="description">{{ $t('instance-description') }}</ui-textarea> | ||||
| 			<ui-input v-model="bannerUrl"><i slot="icon"><fa icon="link"/></i>{{ $t('banner-url') }}</ui-input> | ||||
| 			<ui-input v-model="errorImageUrl"><i slot="icon"><fa icon="link"/></i>{{ $t('error-image-url') }}</ui-input> | ||||
| 			<ui-input v-model="languages"><i slot="icon"><fa icon="language"/></i>{{ $t('languages') }}<span slot="desc">{{ $t('languages-desc') }}</span></ui-input> | ||||
| 		</section> | ||||
| 		<section class="fit-bottom"> | ||||
| 			<header><fa :icon="faHeadset"/> {{ $t('maintainer-config') }}</header> | ||||
| 			<ui-input v-model="maintainerName">{{ $t('maintainer-name') }}</ui-input> | ||||
| 			<ui-input v-model="maintainerEmail" type="email"><i slot="icon"><fa :icon="['far', 'envelope']"/></i>{{ $t('maintainer-email') }}</ui-input> | ||||
| 			<ui-input v-model="maintainerEmail" type="email"><i slot="icon"><fa :icon="farEnvelope"/></i>{{ $t('maintainer-email') }}</ui-input> | ||||
| 		</section> | ||||
| 		<section class="fit-top fit-bottom"> | ||||
| 			<ui-input v-model="maxNoteTextLength">{{ $t('max-note-text-length') }}</ui-input> | ||||
| 		</section> | ||||
| 		<section> | ||||
| 			<ui-switch v-model="disableRegistration">{{ $t('disable-registration') }}</ui-switch> | ||||
| 			<ui-switch v-model="disableLocalTimeline">{{ $t('disable-local-timeline') }}</ui-switch> | ||||
| 		</section> | ||||
| 		<section class="fit-bottom"> | ||||
| 			<header><fa icon="cloud"/> {{ $t('drive-config') }}</header> | ||||
| 			<ui-switch v-model="cacheRemoteFiles">{{ $t('cache-remote-files') }}<span slot="desc">{{ $t('cache-remote-files-desc') }}</span></ui-switch> | ||||
| @@ -27,8 +32,10 @@ | ||||
| 			<header><fa :icon="faShieldAlt"/> {{ $t('recaptcha-config') }}</header> | ||||
| 			<ui-switch v-model="enableRecaptcha">{{ $t('enable-recaptcha') }}</ui-switch> | ||||
| 			<ui-info>{{ $t('recaptcha-info') }}</ui-info> | ||||
| 			<ui-input v-model="recaptchaSiteKey" :disabled="!enableRecaptcha"><i slot="icon"><fa icon="key"/></i>{{ $t('recaptcha-site-key') }}</ui-input> | ||||
| 			<ui-input v-model="recaptchaSecretKey" :disabled="!enableRecaptcha"><i slot="icon"><fa icon="key"/></i>{{ $t('recaptcha-secret-key') }}</ui-input> | ||||
| 			<ui-horizon-group inputs> | ||||
| 				<ui-input v-model="recaptchaSiteKey" :disabled="!enableRecaptcha"><i slot="icon"><fa icon="key"/></i>{{ $t('recaptcha-site-key') }}</ui-input> | ||||
| 				<ui-input v-model="recaptchaSecretKey" :disabled="!enableRecaptcha"><i slot="icon"><fa icon="key"/></i>{{ $t('recaptcha-secret-key') }}</ui-input> | ||||
| 			</ui-horizon-group> | ||||
| 		</section> | ||||
| 		<section> | ||||
| 			<header><fa :icon="faGhost"/> {{ $t('proxy-account-config') }}</header> | ||||
| @@ -37,10 +44,37 @@ | ||||
| 			<ui-info warn>{{ $t('proxy-account-warn') }}</ui-info> | ||||
| 		</section> | ||||
| 		<section> | ||||
| 			<ui-switch v-model="disableRegistration">{{ $t('disable-registration') }}</ui-switch> | ||||
| 			<header><fa :icon="farEnvelope"/> {{ $t('email-config') }}</header> | ||||
| 			<ui-switch v-model="enableEmail">{{ $t('enable-email') }}<span slot="desc">{{ $t('email-config-info') }}</span></ui-switch> | ||||
| 			<ui-input v-model="email" type="email" :disabled="!enableEmail">{{ $t('email') }}</ui-input> | ||||
| 			<ui-horizon-group inputs> | ||||
| 				<ui-input v-model="smtpHost" :disabled="!enableEmail">{{ $t('smtp-host') }}</ui-input> | ||||
| 				<ui-input v-model="smtpPort" type="number" :disabled="!enableEmail">{{ $t('smtp-port') }}</ui-input> | ||||
| 			</ui-horizon-group> | ||||
| 			<ui-horizon-group inputs> | ||||
| 				<ui-input v-model="smtpUser" :disabled="!enableEmail">{{ $t('smtp-user') }}</ui-input> | ||||
| 				<ui-input v-model="smtpPass" :disabled="!enableEmail">{{ $t('smtp-pass') }}</ui-input> | ||||
| 			</ui-horizon-group> | ||||
| 			<ui-switch v-model="smtpSecure" :disabled="!enableEmail">{{ $t('smtp-secure') }}<span slot="desc">{{ $t('smtp-secure-info') }}</span></ui-switch> | ||||
| 		</section> | ||||
| 		<section> | ||||
| 			<ui-switch v-model="disableLocalTimeline">{{ $t('disable-local-timeline') }}</ui-switch> | ||||
| 			<header><fa :icon="faBolt"/> {{ $t('serviceworker-config') }}</header> | ||||
| 			<ui-switch v-model="enableServiceWorker">{{ $t('enable-serviceworker') }}<span slot="desc">{{ $t('serviceworker-info') }}</span></ui-switch> | ||||
| 			<ui-info>{{ $t('vapid-info') }}<br><code>npm i web-push -g<br>web-push generate-vapid-keys</code></ui-info> | ||||
| 			<ui-horizon-group inputs class="fit-bottom"> | ||||
| 				<ui-input v-model="swPublicKey" :disabled="!enableServiceWorker"><i slot="icon"><fa icon="key"/></i>{{ $t('vapid-publickey') }}</ui-input> | ||||
| 				<ui-input v-model="swPrivateKey" :disabled="!enableServiceWorker"><i slot="icon"><fa icon="key"/></i>{{ $t('vapid-privatekey') }}</ui-input> | ||||
| 			</ui-horizon-group> | ||||
| 		</section> | ||||
| 		<section> | ||||
| 			<header>summaly Proxy</header> | ||||
| 			<ui-input v-model="summalyProxy">URL</ui-input> | ||||
| 		</section> | ||||
| 		<section> | ||||
| 			<header><fa :icon="faUserPlus"/> {{ $t('user-recommendation-config') }}</header> | ||||
| 			<ui-switch v-model="enableExternalUserRecommendation">{{ $t('enable-external-user-recommendation') }}</ui-switch> | ||||
| 			<ui-input v-model="externalUserRecommendationEngine" :disabled="!enableExternalUserRecommendation">{{ $t('external-user-recommendation-engine') }}<span slot="desc">{{ $t('external-user-recommendation-engine-desc') }}</span></ui-input> | ||||
| 			<ui-input v-model="externalUserRecommendationTimeout" type="number" :disabled="!enableExternalUserRecommendation">{{ $t('external-user-recommendation-timeout') }}<span slot="suffix">ms</span><span slot="desc">{{ $t('external-user-recommendation-timeout-desc') }}</span></ui-input> | ||||
| 		</section> | ||||
| 		<section> | ||||
| 			<ui-button @click="updateMeta">{{ $t('save') }}</ui-button> | ||||
| @@ -59,9 +93,11 @@ | ||||
| 		<div slot="title"><fa :icon="['fab', 'twitter']"/> {{ $t('twitter-integration-config') }}</div> | ||||
| 		<section> | ||||
| 			<ui-switch v-model="enableTwitterIntegration">{{ $t('enable-twitter-integration') }}</ui-switch> | ||||
| 			<ui-info>{{ $t('twitter-integration-info') }}</ui-info> | ||||
| 			<ui-input v-model="twitterConsumerKey" :disabled="!enableTwitterIntegration"><i slot="icon"><fa icon="key"/></i>{{ $t('twitter-integration-consumer-key') }}</ui-input> | ||||
| 			<ui-input v-model="twitterConsumerSecret" :disabled="!enableTwitterIntegration"><i slot="icon"><fa icon="key"/></i>{{ $t('twitter-integration-consumer-secret') }}</ui-input> | ||||
| 			<ui-horizon-group> | ||||
| 				<ui-input v-model="twitterConsumerKey" :disabled="!enableTwitterIntegration"><i slot="icon"><fa icon="key"/></i>{{ $t('twitter-integration-consumer-key') }}</ui-input> | ||||
| 				<ui-input v-model="twitterConsumerSecret" :disabled="!enableTwitterIntegration"><i slot="icon"><fa icon="key"/></i>{{ $t('twitter-integration-consumer-secret') }}</ui-input> | ||||
| 			</ui-horizon-group> | ||||
| 			<ui-info>{{ $t('twitter-integration-info', { url: `${url}/api/tw/cb` }) }}</ui-info> | ||||
| 			<ui-button @click="updateMeta">{{ $t('save') }}</ui-button> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
| @@ -70,9 +106,11 @@ | ||||
| 		<div slot="title"><fa :icon="['fab', 'github']"/> {{ $t('github-integration-config') }}</div> | ||||
| 		<section> | ||||
| 			<ui-switch v-model="enableGithubIntegration">{{ $t('enable-github-integration') }}</ui-switch> | ||||
| 			<ui-info>{{ $t('github-integration-info') }}</ui-info> | ||||
| 			<ui-input v-model="githubClientId" :disabled="!enableGithubIntegration"><i slot="icon"><fa icon="key"/></i>{{ $t('github-integration-client-id') }}</ui-input> | ||||
| 			<ui-input v-model="githubClientSecret" :disabled="!enableGithubIntegration"><i slot="icon"><fa icon="key"/></i>{{ $t('github-integration-client-secret') }}</ui-input> | ||||
| 			<ui-horizon-group> | ||||
| 				<ui-input v-model="githubClientId" :disabled="!enableGithubIntegration"><i slot="icon"><fa icon="key"/></i>{{ $t('github-integration-client-id') }}</ui-input> | ||||
| 				<ui-input v-model="githubClientSecret" :disabled="!enableGithubIntegration"><i slot="icon"><fa icon="key"/></i>{{ $t('github-integration-client-secret') }}</ui-input> | ||||
| 			</ui-horizon-group> | ||||
| 			<ui-info>{{ $t('github-integration-info', { url: `${url}/api/gh/cb` }) }}</ui-info> | ||||
| 			<ui-button @click="updateMeta">{{ $t('save') }}</ui-button> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
| @@ -81,9 +119,11 @@ | ||||
| 		<div slot="title"><fa :icon="['fab', 'discord']"/> {{ $t('discord-integration-config') }}</div> | ||||
| 		<section> | ||||
| 			<ui-switch v-model="enableDiscordIntegration">{{ $t('enable-discord-integration') }}</ui-switch> | ||||
| 			<ui-info>{{ $t('discord-integration-info') }}</ui-info> | ||||
| 			<ui-input v-model="discordClientId" :disabled="!enableDiscordIntegration"><i slot="icon"><fa icon="key"/></i>{{ $t('discord-integration-client-id') }}</ui-input> | ||||
| 			<ui-input v-model="discordClientSecret" :disabled="!enableDiscordIntegration"><i slot="icon"><fa icon="key"/></i>{{ $t('discord-integration-client-secret') }}</ui-input> | ||||
| 			<ui-horizon-group> | ||||
| 				<ui-input v-model="discordClientId" :disabled="!enableDiscordIntegration"><i slot="icon"><fa icon="key"/></i>{{ $t('discord-integration-client-id') }}</ui-input> | ||||
| 				<ui-input v-model="discordClientSecret" :disabled="!enableDiscordIntegration"><i slot="icon"><fa icon="key"/></i>{{ $t('discord-integration-client-secret') }}</ui-input> | ||||
| 			</ui-horizon-group> | ||||
| 			<ui-info>{{ $t('discord-integration-info', { url: `${url}/api/dc/cb` }) }}</ui-info> | ||||
| 			<ui-button @click="updateMeta">{{ $t('save') }}</ui-button> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
| @@ -93,21 +133,24 @@ | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import i18n from '../../i18n'; | ||||
| import { host } from '../../config'; | ||||
| import { url, host } from '../../config'; | ||||
| import { toUnicode } from 'punycode'; | ||||
| import { faHeadset, faShieldAlt, faGhost } from '@fortawesome/free-solid-svg-icons'; | ||||
| import { faHeadset, faShieldAlt, faGhost, faUserPlus, faBolt } from '@fortawesome/free-solid-svg-icons'; | ||||
| import { faEnvelope as farEnvelope } from '@fortawesome/free-regular-svg-icons'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n: i18n('admin/views/instance.vue'), | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			url, | ||||
| 			host: toUnicode(host), | ||||
| 			maintainerName: null, | ||||
| 			maintainerEmail: null, | ||||
| 			disableRegistration: false, | ||||
| 			disableLocalTimeline: false, | ||||
| 			bannerUrl: null, | ||||
| 			errorImageUrl: null, | ||||
| 			name: null, | ||||
| 			description: null, | ||||
| 			languages: null, | ||||
| @@ -129,7 +172,21 @@ export default Vue.extend({ | ||||
| 			discordClientSecret: null, | ||||
| 			proxyAccount: null, | ||||
| 			inviteCode: null, | ||||
| 			faHeadset, faShieldAlt, faGhost | ||||
| 			enableExternalUserRecommendation: false, | ||||
| 			externalUserRecommendationEngine: null, | ||||
| 			externalUserRecommendationTimeout: null, | ||||
| 			summalyProxy: null, | ||||
| 			enableEmail: false, | ||||
| 			email: null, | ||||
| 			smtpSecure: false, | ||||
| 			smtpHost: null, | ||||
| 			smtpPort: null, | ||||
| 			smtpUser: null, | ||||
| 			smtpPass: null, | ||||
| 			enableServiceWorker: false, | ||||
| 			swPublicKey: null, | ||||
| 			swPrivateKey: null, | ||||
| 			faHeadset, faShieldAlt, faGhost, faUserPlus, farEnvelope, faBolt | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| @@ -137,7 +194,10 @@ export default Vue.extend({ | ||||
| 		this.$root.getMeta().then(meta => { | ||||
| 			this.maintainerName = meta.maintainer.name; | ||||
| 			this.maintainerEmail = meta.maintainer.email; | ||||
| 			this.disableRegistration = meta.disableRegistration; | ||||
| 			this.disableLocalTimeline = meta.disableLocalTimeline; | ||||
| 			this.bannerUrl = meta.bannerUrl; | ||||
| 			this.errorImageUrl = meta.errorImageUrl; | ||||
| 			this.name = meta.name; | ||||
| 			this.description = meta.description; | ||||
| 			this.languages = meta.langs.join(' '); | ||||
| @@ -158,6 +218,20 @@ export default Vue.extend({ | ||||
| 			this.enableDiscordIntegration = meta.enableDiscordIntegration; | ||||
| 			this.discordClientId = meta.discordClientId; | ||||
| 			this.discordClientSecret = meta.discordClientSecret; | ||||
| 			this.enableExternalUserRecommendation = meta.enableExternalUserRecommendation; | ||||
| 			this.externalUserRecommendationEngine = meta.externalUserRecommendationEngine; | ||||
| 			this.externalUserRecommendationTimeout = meta.externalUserRecommendationTimeout; | ||||
| 			this.summalyProxy = meta.summalyProxy; | ||||
| 			this.enableEmail = meta.enableEmail; | ||||
| 			this.email = meta.email; | ||||
| 			this.smtpSecure = meta.smtpSecure; | ||||
| 			this.smtpHost = meta.smtpHost; | ||||
| 			this.smtpPort = meta.smtpPort; | ||||
| 			this.smtpUser = meta.smtpUser; | ||||
| 			this.smtpPass = meta.smtpPass; | ||||
| 			this.enableServiceWorker = meta.enableServiceWorker; | ||||
| 			this.swPublicKey = meta.swPublickey; | ||||
| 			this.swPrivateKey = meta.swPrivateKey; | ||||
| 		}); | ||||
| 	}, | ||||
|  | ||||
| @@ -166,7 +240,7 @@ export default Vue.extend({ | ||||
| 			this.$root.api('admin/invite').then(x => { | ||||
| 				this.inviteCode = x.code; | ||||
| 			}).catch(e => { | ||||
| 				this.$root.alert({ | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'error', | ||||
| 					text: e | ||||
| 				}); | ||||
| @@ -180,6 +254,7 @@ export default Vue.extend({ | ||||
| 				disableRegistration: this.disableRegistration, | ||||
| 				disableLocalTimeline: this.disableLocalTimeline, | ||||
| 				bannerUrl: this.bannerUrl, | ||||
| 				errorImageUrl: this.errorImageUrl, | ||||
| 				name: this.name, | ||||
| 				description: this.description, | ||||
| 				langs: this.languages.split(' '), | ||||
| @@ -199,14 +274,28 @@ export default Vue.extend({ | ||||
| 				githubClientSecret: this.githubClientSecret, | ||||
| 				enableDiscordIntegration: this.enableDiscordIntegration, | ||||
| 				discordClientId: this.discordClientId, | ||||
| 				discordClientSecret: this.discordClientSecret | ||||
| 				discordClientSecret: this.discordClientSecret, | ||||
| 				enableExternalUserRecommendation: this.enableExternalUserRecommendation, | ||||
| 				externalUserRecommendationEngine: this.externalUserRecommendationEngine, | ||||
| 				externalUserRecommendationTimeout: parseInt(this.externalUserRecommendationTimeout, 10), | ||||
| 				summalyProxy: this.summalyProxy, | ||||
| 				enableEmail: this.enableEmail, | ||||
| 				email: this.email, | ||||
| 				smtpSecure: this.smtpSecure, | ||||
| 				smtpHost: this.smtpHost, | ||||
| 				smtpPort: parseInt(this.smtpPort, 10), | ||||
| 				smtpUser: this.smtpUser, | ||||
| 				smtpPass: this.smtpPass, | ||||
| 				enableServiceWorker: this.enableServiceWorker, | ||||
| 				swPublicKey: this.swPublicKey, | ||||
| 				swPrivateKey: this.swPrivateKey | ||||
| 			}).then(() => { | ||||
| 				this.$root.alert({ | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					text: this.$t('saved') | ||||
| 				}); | ||||
| 			}).catch(e => { | ||||
| 				this.$root.alert({ | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'error', | ||||
| 					text: e | ||||
| 				}); | ||||
|   | ||||
| @@ -34,14 +34,14 @@ export default Vue.extend({ | ||||
| 			const process = async () => { | ||||
| 				const user = await this.$root.api('users/show', parseAcct(this.username)); | ||||
| 				await this.$root.api('admin/moderators/add', { userId: user.id }); | ||||
| 				this.$root.alert({ | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					text: this.$t('add-moderator.added') | ||||
| 				}); | ||||
| 			}; | ||||
|  | ||||
| 			await process().catch(e => { | ||||
| 				this.$root.alert({ | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'error', | ||||
| 					text: e.toString() | ||||
| 				}); | ||||
|   | ||||
| @@ -1,42 +1,65 @@ | ||||
| <template> | ||||
| <div class="ucnffhbtogqgscfmqcymwmmupoknpfsw"> | ||||
| 	<ui-card> | ||||
| 		<div slot="title">{{ $t('verify-user') }}</div> | ||||
| 		<div slot="title"><fa :icon="faTerminal"/> {{ $t('operation') }}</div> | ||||
| 		<section class="fit-top"> | ||||
| 			<ui-input v-model="verifyUsername" type="text"> | ||||
| 				<span slot="prefix">@</span> | ||||
| 			<ui-input v-model="target" type="text"> | ||||
| 				<span>{{ $t('username-or-userid') }}</span> | ||||
| 			</ui-input> | ||||
| 			<ui-button @click="verifyUser" :disabled="verifying">{{ $t('verify') }}</ui-button> | ||||
| 			<ui-button @click="resetPassword"><fa :icon="faKey"/> {{ $t('reset-password') }}</ui-button> | ||||
| 			<ui-horizon-group> | ||||
| 				<ui-button @click="verifyUser" :disabled="verifying"><fa :icon="faCertificate"/> {{ $t('verify') }}</ui-button> | ||||
| 				<ui-button @click="unverifyUser" :disabled="unverifying">{{ $t('unverify') }}</ui-button> | ||||
| 			</ui-horizon-group> | ||||
| 			<ui-horizon-group> | ||||
| 				<ui-button @click="suspendUser" :disabled="suspending"><fa :icon="faSnowflake"/> {{ $t('suspend') }}</ui-button> | ||||
| 				<ui-button @click="unsuspendUser" :disabled="unsuspending">{{ $t('unsuspend') }}</ui-button> | ||||
| 			</ui-horizon-group> | ||||
| 			<ui-button @click="showUser"><fa :icon="faSearch"/> {{ $t('lookup') }}</ui-button> | ||||
| 			<ui-textarea v-if="user" :value="user | json5" readonly tall style="margin-top:16px;"></ui-textarea> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
|  | ||||
| 	<ui-card> | ||||
| 		<div slot="title">{{ $t('unverify-user') }}</div> | ||||
| 		<div slot="title"><fa :icon="faUsers"/> {{ $t('users.title') }}</div> | ||||
| 		<section class="fit-top"> | ||||
| 			<ui-input v-model="unverifyUsername" type="text"> | ||||
| 				<span slot="prefix">@</span> | ||||
| 			</ui-input> | ||||
| 			<ui-button @click="unverifyUser" :disabled="unverifying">{{ $t('unverify') }}</ui-button> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
|  | ||||
| 	<ui-card> | ||||
| 		<div slot="title">{{ $t('suspend-user') }}</div> | ||||
| 		<section class="fit-top"> | ||||
| 			<ui-input v-model="suspendUsername" type="text"> | ||||
| 				<span slot="prefix">@</span> | ||||
| 			</ui-input> | ||||
| 			<ui-button @click="suspendUser" :disabled="suspending">{{ $t('suspend') }}</ui-button> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
|  | ||||
| 	<ui-card> | ||||
| 		<div slot="title">{{ $t('unsuspend-user') }}</div> | ||||
| 		<section class="fit-top"> | ||||
| 			<ui-input v-model="unsuspendUsername" type="text"> | ||||
| 				<span slot="prefix">@</span> | ||||
| 			</ui-input> | ||||
| 			<ui-button @click="unsuspendUser" :disabled="unsuspending">{{ $t('unsuspend') }}</ui-button> | ||||
| 			<ui-horizon-group inputs> | ||||
| 				<ui-select v-model="sort"> | ||||
| 					<span slot="label">{{ $t('users.sort.title') }}</span> | ||||
| 					<option value="-createdAt">{{ $t('users.sort.createdAtAsc') }}</option> | ||||
| 					<option value="+createdAt">{{ $t('users.sort.createdAtDesc') }}</option> | ||||
| 					<option value="-updatedAt">{{ $t('users.sort.updatedAtAsc') }}</option> | ||||
| 					<option value="+updatedAt">{{ $t('users.sort.updatedAtDesc') }}</option> | ||||
| 				</ui-select> | ||||
| 				<ui-select v-model="origin"> | ||||
| 					<span slot="label">{{ $t('users.origin.title') }}</span> | ||||
| 					<option value="combined">{{ $t('users.origin.combined') }}</option> | ||||
| 					<option value="local">{{ $t('users.origin.local') }}</option> | ||||
| 					<option value="remote">{{ $t('users.origin.remote') }}</option> | ||||
| 				</ui-select> | ||||
| 			</ui-horizon-group> | ||||
| 			<sequential-entrance animation="entranceFromTop" delay="25"> | ||||
| 				<div class="kofvwchc" v-for="user in users"> | ||||
| 					<div> | ||||
| 						<a :href="user | userPage(null, true)"> | ||||
| 							<mk-avatar class="avatar" :user="user" :disable-link="true"/> | ||||
| 						</a> | ||||
| 					</div> | ||||
| 					<div> | ||||
| 						<header> | ||||
| 							<b><mk-user-name :user="user"/></b> | ||||
| 							<span class="username">@{{ user | acct }}</span> | ||||
| 						</header> | ||||
| 						<div> | ||||
| 							<span>{{ $t('users.updatedAt') }}: <mk-time :time="user.updatedAt" mode="detail"/></span> | ||||
| 						</div> | ||||
| 						<div> | ||||
| 							<span>{{ $t('users.createdAt') }}: <mk-time :time="user.createdAt" mode="detail"/></span> | ||||
| 						</div> | ||||
| 					</div> | ||||
| 				</div> | ||||
| 			</sequential-entrance> | ||||
| 			<ui-button v-if="existMore" @click="fetchUsers">{{ $t('@.load-more') }}</ui-button> | ||||
| 		</section> | ||||
| 	</ui-card> | ||||
| </div> | ||||
| @@ -46,38 +69,98 @@ | ||||
| import Vue from 'vue'; | ||||
| import i18n from '../../i18n'; | ||||
| import parseAcct from "../../../../misc/acct/parse"; | ||||
| import { faCertificate, faUsers, faTerminal, faSearch, faKey } from '@fortawesome/free-solid-svg-icons'; | ||||
| import { faSnowflake } from '@fortawesome/free-regular-svg-icons'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n: i18n('admin/views/users.vue'), | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			verifyUsername: null, | ||||
| 			user: null, | ||||
| 			target: null, | ||||
| 			verifying: false, | ||||
| 			unverifyUsername: null, | ||||
| 			unverifying: false, | ||||
| 			suspendUsername: null, | ||||
| 			suspending: false, | ||||
| 			unsuspendUsername: null, | ||||
| 			unsuspending: false | ||||
| 			unsuspending: false, | ||||
| 			sort: '+createdAt', | ||||
| 			origin: 'combined', | ||||
| 			limit: 10, | ||||
| 			offset: 0, | ||||
| 			users: [], | ||||
| 			existMore: false, | ||||
| 			faTerminal, faCertificate, faUsers, faSnowflake, faSearch, faKey | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	watch: { | ||||
| 		sort() { | ||||
| 			this.users = []; | ||||
| 			this.offset = 0; | ||||
| 			this.fetchUsers(); | ||||
| 		}, | ||||
|  | ||||
| 		origin() { | ||||
| 			this.users = []; | ||||
| 			this.offset = 0; | ||||
| 			this.fetchUsers(); | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	mounted() { | ||||
| 		this.fetchUsers(); | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		async fetchUser() { | ||||
| 			try { | ||||
| 				return await this.$root.api('users/show', this.target.startsWith('@') ? parseAcct(this.target) : { userId: this.target }); | ||||
| 			} catch (e) { | ||||
| 				if (e == 'user not found') { | ||||
| 					this.$root.dialog({ | ||||
| 						type: 'error', | ||||
| 						text: this.$t('user-not-found') | ||||
| 					}); | ||||
| 				} else { | ||||
| 					this.$root.dialog({ | ||||
| 						type: 'error', | ||||
| 						text: e.toString() | ||||
| 					}); | ||||
| 				} | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
| 		async showUser() { | ||||
| 			const user = await this.fetchUser(); | ||||
| 			this.$root.api('admin/show-user', { userId: user.id }).then(info => { | ||||
| 				this.user = info; | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		async resetPassword() { | ||||
| 			const user = await this.fetchUser(); | ||||
| 			this.$root.api('admin/reset-password', { userId: user.id }).then(res => { | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					text: this.$t('password-updated', { password: res.password }) | ||||
| 				}); | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		async verifyUser() { | ||||
| 			this.verifying = true; | ||||
|  | ||||
| 			const process = async () => { | ||||
| 				const user = await this.$root.api('users/show', parseAcct(this.verifyUsername)); | ||||
| 				const user = await this.fetchUser(); | ||||
| 				await this.$root.api('admin/verify-user', { userId: user.id }); | ||||
| 				this.$root.alert({ | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					text: this.$t('verified') | ||||
| 				}); | ||||
| 			}; | ||||
|  | ||||
| 			await process().catch(e => { | ||||
| 				this.$root.alert({ | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'error', | ||||
| 					text: e.toString() | ||||
| 				}); | ||||
| @@ -90,16 +173,16 @@ export default Vue.extend({ | ||||
| 			this.unverifying = true; | ||||
|  | ||||
| 			const process = async () => { | ||||
| 				const user = await this.$root.api('users/show', parseAcct(this.unverifyUsername)); | ||||
| 				const user = await this.fetchUser(); | ||||
| 				await this.$root.api('admin/unverify-user', { userId: user.id }); | ||||
| 				this.$root.alert({ | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					text: this.$t('unverified') | ||||
| 				}); | ||||
| 			}; | ||||
|  | ||||
| 			await process().catch(e => { | ||||
| 				this.$root.alert({ | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'error', | ||||
| 					text: e.toString() | ||||
| 				}); | ||||
| @@ -112,16 +195,16 @@ export default Vue.extend({ | ||||
| 			this.suspending = true; | ||||
|  | ||||
| 			const process = async () => { | ||||
| 				const user = await this.$root.api('users/show', parseAcct(this.suspendUsername)); | ||||
| 				const user = await this.fetchUser(); | ||||
| 				await this.$root.api('admin/suspend-user', { userId: user.id }); | ||||
| 				this.$root.alert({ | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					text: this.$t('suspended') | ||||
| 				}); | ||||
| 			}; | ||||
|  | ||||
| 			await process().catch(e => { | ||||
| 				this.$root.alert({ | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'error', | ||||
| 					text: e.toString() | ||||
| 				}); | ||||
| @@ -134,22 +217,40 @@ export default Vue.extend({ | ||||
| 			this.unsuspending = true; | ||||
|  | ||||
| 			const process = async () => { | ||||
| 				const user = await this.$root.api('users/show', parseAcct(this.unsuspendUsername)); | ||||
| 				const user = await this.fetchUser(); | ||||
| 				await this.$root.api('admin/unsuspend-user', { userId: user.id }); | ||||
| 				this.$root.alert({ | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					text: this.$t('unsuspended') | ||||
| 				}); | ||||
| 			}; | ||||
|  | ||||
| 			await process().catch(e => { | ||||
| 				this.$root.alert({ | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'error', | ||||
| 					text: e.toString() | ||||
| 				}); | ||||
| 			}); | ||||
|  | ||||
| 			this.unsuspending = false; | ||||
| 		}, | ||||
|  | ||||
| 		fetchUsers() { | ||||
| 			this.$root.api('users', { | ||||
| 				origin: this.origin, | ||||
| 				sort: this.sort, | ||||
| 				offset: this.offset, | ||||
| 				limit: this.limit + 1 | ||||
| 			}).then(users => { | ||||
| 				if (users.length == this.limit + 1) { | ||||
| 					users.pop(); | ||||
| 					this.existMore = true; | ||||
| 				} else { | ||||
| 					this.existMore = false; | ||||
| 				} | ||||
| 				this.users = this.users.concat(users); | ||||
| 				this.offset += this.limit; | ||||
| 			}); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| @@ -160,4 +261,27 @@ export default Vue.extend({ | ||||
| 	@media (min-width 500px) | ||||
| 		padding 16px | ||||
|  | ||||
| 	.kofvwchc | ||||
| 		display flex | ||||
| 		padding 16px 0 | ||||
| 		border-top solid 1px var(--faceDivider) | ||||
|  | ||||
| 		> div:first-child | ||||
| 			> a | ||||
| 				> .avatar | ||||
| 					width 64px | ||||
| 					height 64px | ||||
|  | ||||
| 		> div:last-child | ||||
| 			flex 1 | ||||
| 			padding-left 16px | ||||
|  | ||||
| 			@media (max-width 500px) | ||||
| 				font-size 14px | ||||
|  | ||||
| 			> header | ||||
| 				> .username | ||||
| 					margin-left 8px | ||||
| 					opacity 0.7 | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -10,3 +10,19 @@ | ||||
| 	opacity: 0; | ||||
| 	transform: scaleY(0); | ||||
| } | ||||
|  | ||||
| .entranceFromTop { | ||||
| 	animation-duration: 0.5s; | ||||
| 	animation-name: entranceFromTop; | ||||
| } | ||||
|  | ||||
| @keyframes entranceFromTop { | ||||
| 	from { | ||||
| 		opacity: 0; | ||||
| 		transform: translateY(-64px); | ||||
| 	} | ||||
| 	to { | ||||
| 		opacity: 1; | ||||
| 		transform: translateY(0); | ||||
| 	} | ||||
| } | ||||
|   | ||||
| @@ -9,6 +9,7 @@ import './style.styl'; | ||||
|  | ||||
| import init from '../init'; | ||||
| import Index from './views/index.vue'; | ||||
| import NotFound from '../common/views/pages/404.vue'; | ||||
|  | ||||
| /** | ||||
|  * init | ||||
| @@ -20,6 +21,7 @@ init(launch => { | ||||
| 		base: '/auth/', | ||||
| 		routes: [ | ||||
| 			{ path: '/:token', component: Index }, | ||||
| 			{ path: '*', component: NotFound } | ||||
| 		] | ||||
| 	}); | ||||
|  | ||||
|   | ||||
| @@ -17,9 +17,9 @@ | ||||
| 	//#region Apply theme | ||||
| 	const theme = localStorage.getItem('theme'); | ||||
| 	if (theme) { | ||||
| 		Object.entries(JSON.parse(theme)).forEach(([k, v]) => { | ||||
| 		for (const [k, v] of Object.entries(JSON.parse(theme))) { | ||||
| 			document.documentElement.style.setProperty(`--${k}`, v.toString()); | ||||
| 		}); | ||||
| 		} | ||||
| 	} | ||||
| 	//#endregion | ||||
|  | ||||
| @@ -160,7 +160,7 @@ | ||||
| 			navigator.serviceWorker.controller.postMessage('clear'); | ||||
|  | ||||
| 			navigator.serviceWorker.getRegistrations().then(registrations => { | ||||
| 				registrations.forEach(registration => registration.unregister()); | ||||
| 				for (const registration of registrations) registration.unregister(); | ||||
| 			}); | ||||
| 		} catch (e) { | ||||
| 			console.error(e); | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| import Vue from 'vue'; | ||||
|  | ||||
| export default function<T extends object>(data: { | ||||
| export default function <T extends object>(data: { | ||||
| 	name: string; | ||||
| 	props?: () => T; | ||||
| }) { | ||||
| @@ -53,11 +53,10 @@ export default function<T extends object>(data: { | ||||
| 			mergeProps() { | ||||
| 				if (data.props) { | ||||
| 					const defaultProps = data.props(); | ||||
| 					Object.keys(defaultProps).forEach(prop => { | ||||
| 						if (!this.props.hasOwnProperty(prop)) { | ||||
| 							Vue.set(this.props, prop, defaultProps[prop]); | ||||
| 						} | ||||
| 					}); | ||||
| 					for (const prop of Object.keys(defaultProps)) { | ||||
| 						if (this.props.hasOwnProperty(prop)) continue; | ||||
| 						Vue.set(this.props, prop, defaultProps[prop]); | ||||
| 					} | ||||
| 				} | ||||
| 			}, | ||||
|  | ||||
|   | ||||
| @@ -28,15 +28,15 @@ const getKeyMap = keymap => Object.entries(keymap).map(([patterns, callback]): a | ||||
| 			shift: false | ||||
| 		} as pattern; | ||||
|  | ||||
| 		part.trim().split('+').forEach(key => { | ||||
| 			key = key.trim().toLowerCase(); | ||||
| 		const keys = part.trim().split('+').map(x => x.trim().toLowerCase()); | ||||
| 		for (const key of keys) { | ||||
| 			switch (key) { | ||||
| 				case 'ctrl': pattern.ctrl = true; break; | ||||
| 				case 'alt': pattern.alt = true; break; | ||||
| 				case 'shift': pattern.shift = true; break; | ||||
| 				default: pattern.which = keyCode(key).map(k => k.toLowerCase()); | ||||
| 			} | ||||
| 		}); | ||||
| 		} | ||||
|  | ||||
| 		return pattern; | ||||
| 	}); | ||||
| @@ -77,11 +77,7 @@ export default { | ||||
| 						const matched = match(e, action.patterns); | ||||
|  | ||||
| 						if (matched) { | ||||
| 							if (el._hotkey_global) { | ||||
| 								if (match(e, targetReservedKeys)) { | ||||
| 									return; | ||||
| 								} | ||||
| 							} | ||||
| 							if (el._hotkey_global && match(e, targetReservedKeys)) return; | ||||
|  | ||||
| 							e.preventDefault(); | ||||
| 							e.stopPropagation(); | ||||
|   | ||||
| @@ -14,19 +14,20 @@ export default async function($root: any, force = false, silent = false) { | ||||
| 				navigator.serviceWorker.controller.postMessage('clear'); | ||||
| 			} | ||||
|  | ||||
| 			navigator.serviceWorker.getRegistrations().then(registrations => { | ||||
| 				registrations.forEach(registration => registration.unregister()); | ||||
| 			}); | ||||
| 			const registrations = await navigator.serviceWorker.getRegistrations(); | ||||
| 			for (const registration of registrations) { | ||||
| 				registration.unregister(); | ||||
| 			} | ||||
| 		} catch (e) { | ||||
| 			console.error(e); | ||||
| 		} | ||||
|  | ||||
| 		if (!silent) { | ||||
| 			$root.alert({ | ||||
| 		/*if (!silent) { | ||||
| 			$root.dialog({ | ||||
| 				title: $root.$t('@.update-available-title'), | ||||
| 				text: $root.$t('@.update-available', { newer, current }) | ||||
| 			}); | ||||
| 		} | ||||
| 		}*/ | ||||
|  | ||||
| 		return newer; | ||||
| 	} else { | ||||
|   | ||||
| @@ -22,7 +22,7 @@ export default function(type, data): Notification { | ||||
|  | ||||
| 		case 'unreadMessagingMessage': | ||||
| 			return { | ||||
| 				title: '%i18n:common.notification.message-from%'.split("{}")[0] + `${getUserName(data.user)}` + '%i18n:common.notification.message-from%'.split("{}")[1] , | ||||
| 				title: '%i18n:common.notification.message-from%'.split('{}')[0] + `${getUserName(data.user)}` + '%i18n:common.notification.message-from%'.split('{}')[1] , | ||||
| 				body: data.text, // TODO: getMessagingMessageSummary(data), | ||||
| 				icon: data.user.avatarUrl | ||||
| 			}; | ||||
| @@ -30,7 +30,7 @@ export default function(type, data): Notification { | ||||
| 		case 'reversiInvited': | ||||
| 			return { | ||||
| 				title: '%i18n:common.notification.reversi-invited%', | ||||
| 				body: '%i18n:common.notification.reversi-invited-by%'.split("{}")[0] + `${getUserName(data.parent)}` + '%i18n:common.notification.reversi-invited-by%'.split("{}")[1], | ||||
| 				body: '%i18n:common.notification.reversi-invited-by%'.split('{}')[0] + `${getUserName(data.parent)}` + '%i18n:common.notification.reversi-invited-by%'.split('{}')[1], | ||||
| 				icon: data.parent.avatarUrl | ||||
| 			}; | ||||
|  | ||||
| @@ -38,21 +38,21 @@ export default function(type, data): Notification { | ||||
| 			switch (data.type) { | ||||
| 				case 'mention': | ||||
| 					return { | ||||
| 						title: '%i18n:common.notification.notified-by%'.split("{}")[0] + `${getUserName(data.user)}:` + '%i18n:common.notification.notified-by%'.split("{}")[1], | ||||
| 						title: '%i18n:common.notification.notified-by%'.split('{}')[0] + `${getUserName(data.user)}:` + '%i18n:common.notification.notified-by%'.split('{}')[1], | ||||
| 						body: getNoteSummary(data), | ||||
| 						icon: data.user.avatarUrl | ||||
| 					}; | ||||
|  | ||||
| 				case 'reply': | ||||
| 					return { | ||||
| 						title: '%i18n:common.notification.reply-from%'.split("{}")[0] + `${getUserName(data.user)}` + '%i18n:common.notification.reply-from%'.split("{}")[1], | ||||
| 						title: '%i18n:common.notification.reply-from%'.split('{}')[0] + `${getUserName(data.user)}` + '%i18n:common.notification.reply-from%'.split('{}')[1], | ||||
| 						body: getNoteSummary(data), | ||||
| 						icon: data.user.avatarUrl | ||||
| 					}; | ||||
|  | ||||
| 				case 'quote': | ||||
| 					return { | ||||
| 						title: '%i18n:common.notification.quoted-by%'.split("{}")[0] + `${getUserName(data.user)}` + '%i18n:common.notification.quoted-by%'.split("{}")[1], | ||||
| 						title: '%i18n:common.notification.quoted-by%'.split('{}')[0] + `${getUserName(data.user)}` + '%i18n:common.notification.quoted-by%'.split('{}')[1], | ||||
| 						body: getNoteSummary(data), | ||||
| 						icon: data.user.avatarUrl | ||||
| 					}; | ||||
|   | ||||
							
								
								
									
										25
									
								
								src/client/app/common/scripts/format-uptime.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,25 @@ | ||||
|  | ||||
| /** | ||||
|  * Format like the uptime command | ||||
|  */ | ||||
| export default function(sec) { | ||||
| 	if (!sec) return sec; | ||||
|  | ||||
| 	const day = Math.floor(sec / 86400); | ||||
| 	const tod = sec % 86400; | ||||
|  | ||||
| 	// Days part in string: 2 days, 1 day, null | ||||
| 	const d = day >= 2 ? `${day} days` : day >= 1 ? `${day} day` : null; | ||||
|  | ||||
| 	// Time part in string: 1 sec, 1 min, 1:01 | ||||
| 	const t | ||||
| 		= tod < 60 ? `${Math.floor(tod)} sec` | ||||
| 		: tod < 3600 ? `${Math.floor(tod / 60)} min` | ||||
| 		: `${Math.floor(tod / 60 / 60)}:${Math.floor((tod / 60) % 60).toString().padStart(2, '0')}`; | ||||
|  | ||||
| 	let str = ''; | ||||
| 	if (d) str += `${d}, `; | ||||
| 	str += t; | ||||
|  | ||||
| 	return str; | ||||
| } | ||||
| @@ -4,7 +4,7 @@ export default ($root: any) => { | ||||
| 	require('fuckadblock'); | ||||
|  | ||||
| 	function adBlockDetected() { | ||||
| 		$root.alert({ | ||||
| 		$root.dialog({ | ||||
| 			title: $root.$t('@.adblock.detected'), | ||||
| 			text: $root.$t('@.adblock.warning') | ||||
| 		}); | ||||
|   | ||||
| @@ -2,7 +2,7 @@ const faces = [ | ||||
| 	'(=^・・^=)', | ||||
| 	'v(\'ω\')v', | ||||
| 	'🐡( \'-\' 🐡 )フグパンチ!!!!', | ||||
| 	'🖕(´・_・`)🖕', | ||||
| 	'✌️(´・_・`)✌️', | ||||
| 	'(。>﹏<。)', | ||||
| 	'(Δ・x・Δ)' | ||||
| ]; | ||||
|   | ||||
| @@ -3,8 +3,8 @@ | ||||
|  | ||||
| export default (data: ArrayBuffer) => { | ||||
| 	//const buf = new Buffer(data); | ||||
| 	//const hash = crypto.createHash("md5"); | ||||
| 	//const hash = crypto.createHash('md5'); | ||||
| 	//hash.update(buf); | ||||
| 	//return hash.digest("hex"); | ||||
| 	//return hash.digest('hex'); | ||||
| 	return ''; | ||||
| }; | ||||
|   | ||||
| @@ -78,9 +78,10 @@ export default (opts: Opts = {}) => ({ | ||||
| 		urls(): string[] { | ||||
| 			if (this.appearNote.text) { | ||||
| 				const ast = parse(this.appearNote.text); | ||||
| 				// TODO: 再帰的にURL要素がないか調べる | ||||
| 				return unique(ast | ||||
| 					.filter(t => (t.type == 'url' || t.type == 'link') && !t.silent) | ||||
| 					.map(t => t.url)); | ||||
| 					.filter(t => ((t.node.type == 'url' || t.node.type == 'link') && t.node.props.url && !t.node.props.silent)) | ||||
| 					.map(t => t.node.props.url)); | ||||
| 			} else { | ||||
| 				return null; | ||||
| 			} | ||||
| @@ -141,7 +142,7 @@ export default (opts: Opts = {}) => ({ | ||||
| 			this.$root.api('notes/favorites/create', { | ||||
| 				noteId: this.appearNote.id | ||||
| 			}).then(() => { | ||||
| 				this.$root.alert({ | ||||
| 				this.$root.dialog({ | ||||
| 					type: 'success', | ||||
| 					splash: true | ||||
| 				}); | ||||
|   | ||||
| @@ -2,27 +2,8 @@ export default function(me, settings, note) { | ||||
| 	const isMyNote = note.userId == me.id; | ||||
| 	const isPureRenote = note.renoteId != null && note.text == null && note.fileIds.length == 0 && note.poll == null; | ||||
|  | ||||
| 	if (settings.showMyRenotes === false) { | ||||
| 		if (isMyNote && isPureRenote) { | ||||
| 			return true; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if (settings.showRenotedMyNotes === false) { | ||||
| 		if (isPureRenote && (note.renote.userId == me.id)) { | ||||
| 			return true; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if (settings.showLocalRenotes === false) { | ||||
| 		if (isPureRenote && (note.renote.user.host == null)) { | ||||
| 			return true; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if (!isMyNote && note.text && settings.mutedWords.some(q => !q.some(word => !note.text.includes(word)))) { | ||||
| 		return true; | ||||
| 	} | ||||
|  | ||||
| 	return false; | ||||
| 	return settings.showMyRenotes === false && isMyNote && isPureRenote || | ||||
| 		settings.showRenotedMyNotes === false && isPureRenote && note.renote.userId == me.id || | ||||
| 		settings.showLocalRenotes === false && isPureRenote && note.renote.user.host == null || | ||||
| 		!isMyNote && note.text && settings.mutedWords.some(q => q.length > 0 && !q.some(word => !note.text.includes(word))); | ||||
| } | ||||
|   | ||||
| @@ -75,12 +75,10 @@ export default class Stream extends EventEmitter { | ||||
|  | ||||
| 		// チャンネル再接続 | ||||
| 		if (isReconnect) { | ||||
| 			this.sharedConnectionPools.forEach(p => { | ||||
| 			for (const p of this.sharedConnectionPools) | ||||
| 				p.connect(); | ||||
| 			}); | ||||
| 			this.nonSharedConnections.forEach(c => { | ||||
| 			for (const c of this.nonSharedConnections) | ||||
| 				c.connect(); | ||||
| 			}); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @@ -113,9 +111,9 @@ export default class Stream extends EventEmitter { | ||||
| 				connections = [this.nonSharedConnections.find(c => c.id === id)]; | ||||
| 			} | ||||
|  | ||||
| 			connections.filter(c => c != null).forEach(c => { | ||||
| 			for (const c of connections.filter(c => c != null)) { | ||||
| 				c.emit(body.type, body.body); | ||||
| 			}); | ||||
| 			} | ||||
| 		} else { | ||||
| 			this.emit(type, body); | ||||
| 		} | ||||
|   | ||||
| @@ -32,7 +32,7 @@ | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import { themeColor } from '../../../config'; | ||||
| import * as tinycolor from 'tinycolor2'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	props: { | ||||
| @@ -75,7 +75,7 @@ export default Vue.extend({ | ||||
| 			return this.dark ? '#fff' : '#777'; | ||||
| 		}, | ||||
| 		hHandColor(): string { | ||||
| 			return themeColor; | ||||
| 			return tinycolor(getComputedStyle(document.documentElement).getPropertyValue('--primary')).toHexString(); | ||||
| 		}, | ||||
|  | ||||
| 		ms(): number { | ||||
|   | ||||
| @@ -50,10 +50,13 @@ export default Vue.extend({ | ||||
|  | ||||
| 	methods: { | ||||
| 		regenerateToken() { | ||||
| 			this.$input({ | ||||
| 			this.$root.dialog({ | ||||
| 				title: this.$t('enter-password'), | ||||
| 				type: 'password' | ||||
| 			}).then(password => { | ||||
| 				input: { | ||||
| 					type: 'password' | ||||
| 				} | ||||
| 			}).then(({ canceled, result: password }) => { | ||||
| 				if (canceled) return; | ||||
| 				this.$root.api('i/regenerate_token', { | ||||
| 					password: password | ||||
| 				}); | ||||
|   | ||||
| @@ -3,7 +3,9 @@ | ||||
| 	<ol class="users" ref="suggests" v-if="users.length > 0"> | ||||
| 		<li v-for="user in users" @click="complete(type, user)" @keydown="onKeydown" tabindex="-1"> | ||||
| 			<img class="avatar" :src="user.avatarUrl" alt=""/> | ||||
| 			<span class="name">{{ user | userName }}</span> | ||||
| 			<span class="name"> | ||||
| 				<mk-user-name :user="user"/> | ||||
| 			</span> | ||||
| 			<span class="username">@{{ user | acct }}</span> | ||||
| 		</li> | ||||
| 	</ol> | ||||
| @@ -42,8 +44,9 @@ const lib = Object.entries(emojilib.lib).filter((x: any) => { | ||||
| }); | ||||
|  | ||||
| const char2file = (char: string) => { | ||||
| 	let codes = [...char].map(x => x.codePointAt(0).toString(16)); | ||||
| 	let codes = Array.from(char).map(x => x.codePointAt(0).toString(16)); | ||||
| 	if (!codes.includes('200d')) codes = codes.filter(x => x != 'fe0f'); | ||||
| 	codes = codes.filter(x => x && x.length); | ||||
| 	return codes.join('-'); | ||||
| }; | ||||
|  | ||||
| @@ -54,18 +57,18 @@ const emjdb: EmojiDef[] = lib.map((x: any) => ({ | ||||
| 	url: `https://twemoji.maxcdn.com/2/svg/${char2file(x[1].char)}.svg` | ||||
| })); | ||||
|  | ||||
| lib.forEach((x: any) => { | ||||
| for (const x of lib as any) { | ||||
| 	if (x[1].keywords) { | ||||
| 		x[1].keywords.forEach(k => { | ||||
| 		for (const k of x[1].keywords) { | ||||
| 			emjdb.push({ | ||||
| 				emoji: x[1].char, | ||||
| 				name: k, | ||||
| 				aliasOf: x[0], | ||||
| 				url: `https://twemoji.maxcdn.com/2/svg/${char2file(x[1].char)}.svg` | ||||
| 			}); | ||||
| 		}); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| } | ||||
|  | ||||
| emjdb.sort((a, b) => a.name.length - b.name.length); | ||||
|  | ||||
| @@ -117,7 +120,7 @@ export default Vue.extend({ | ||||
| 		const customEmojis = (this.$root.getMetaSync() || { emojis: [] }).emojis || []; | ||||
| 		const emojiDefinitions: EmojiDef[] = []; | ||||
|  | ||||
| 		customEmojis.forEach(x => { | ||||
| 		for (const x of customEmojis) { | ||||
| 			emojiDefinitions.push({ | ||||
| 				name: x.name, | ||||
| 				emoji: `:${x.name}:`, | ||||
| @@ -126,7 +129,7 @@ export default Vue.extend({ | ||||
| 			}); | ||||
|  | ||||
| 			if (x.aliases) { | ||||
| 				x.aliases.forEach(alias => { | ||||
| 				for (const alias of x.aliases) { | ||||
| 					emojiDefinitions.push({ | ||||
| 						name: alias, | ||||
| 						aliasOf: x.name, | ||||
| @@ -134,9 +137,9 @@ export default Vue.extend({ | ||||
| 						url: x.url, | ||||
| 						isCustomEmoji: true | ||||
| 					}); | ||||
| 				}); | ||||
| 				} | ||||
| 			} | ||||
| 		}); | ||||
| 		} | ||||
|  | ||||
| 		emojiDefinitions.sort((a, b) => a.name.length - b.name.length); | ||||
|  | ||||
| @@ -145,9 +148,9 @@ export default Vue.extend({ | ||||
|  | ||||
| 		this.textarea.addEventListener('keydown', this.onKeydown); | ||||
|  | ||||
| 		Array.from(document.querySelectorAll('body *')).forEach(el => { | ||||
| 		for (const el of Array.from(document.querySelectorAll('body *'))) { | ||||
| 			el.addEventListener('mousedown', this.onMousedown); | ||||
| 		}); | ||||
| 		} | ||||
|  | ||||
| 		this.$nextTick(() => { | ||||
| 			this.exec(); | ||||
| @@ -163,18 +166,18 @@ export default Vue.extend({ | ||||
| 	beforeDestroy() { | ||||
| 		this.textarea.removeEventListener('keydown', this.onKeydown); | ||||
|  | ||||
| 		Array.from(document.querySelectorAll('body *')).forEach(el => { | ||||
| 		for (const el of Array.from(document.querySelectorAll('body *'))) { | ||||
| 			el.removeEventListener('mousedown', this.onMousedown); | ||||
| 		}); | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		exec() { | ||||
| 			this.select = -1; | ||||
| 			if (this.$refs.suggests) { | ||||
| 				Array.from(this.items).forEach(el => { | ||||
| 				for (const el of Array.from(this.items)) { | ||||
| 					el.removeAttribute('data-selected'); | ||||
| 				}); | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			if (this.type == 'user') { | ||||
| @@ -187,7 +190,8 @@ export default Vue.extend({ | ||||
| 				} else { | ||||
| 					this.$root.api('users/search', { | ||||
| 						query: this.q, | ||||
| 						limit: 30 | ||||
| 						limit: 10, | ||||
| 						detail: false | ||||
| 					}).then(users => { | ||||
| 						this.users = users; | ||||
| 						this.fetching = false; | ||||
| @@ -312,9 +316,9 @@ export default Vue.extend({ | ||||
| 		}, | ||||
|  | ||||
| 		applySelect() { | ||||
| 			Array.from(this.items).forEach(el => { | ||||
| 			for (const el of Array.from(this.items)) { | ||||
| 				el.removeAttribute('data-selected'); | ||||
| 			}); | ||||
| 			} | ||||
|  | ||||
| 			this.items[this.select].setAttribute('data-selected', 'true'); | ||||
| 			(this.items[this.select] as any).focus(); | ||||
|   | ||||
| @@ -1,21 +1,36 @@ | ||||
| <template> | ||||
| <button class="nrvgflfuaxwgkxoynpnumyookecqrrvh" @click="toggle">{{ value ? this.$t('hide') : this.$t('show') }}</button> | ||||
| <button class="nrvgflfuaxwgkxoynpnumyookecqrrvh" @click="toggle"> | ||||
| 	<b>{{ value ? this.$t('hide') : this.$t('show') }}</b> | ||||
| 	<span v-if="!value"> | ||||
| 		<span v-if="note.text">{{ this.$t('chars', { count: length(note.text) }) | number }}</span> | ||||
| 		<span v-if="note.text && note.files && note.files.length > 0"> / </span> | ||||
| 		<span v-if="note.files && note.files.length > 0">{{ this.$t('files', { count: note.files.length }) }}</span> | ||||
| 	</span> | ||||
| </button> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import i18n from '../../../i18n'; | ||||
| import { length } from 'stringz'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n: i18n('common/views/components/cw-button.vue'), | ||||
|  | ||||
| 	props: { | ||||
| 		value: { | ||||
| 			type: Boolean, | ||||
| 			required: true | ||||
| 		}, | ||||
| 		note: { | ||||
| 			type: Object, | ||||
| 			required: true | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		length, | ||||
|  | ||||
| 		toggle() { | ||||
| 			this.$emit('input', !this.value); | ||||
| 		} | ||||
| @@ -37,4 +52,12 @@ export default Vue.extend({ | ||||
| 	&:hover | ||||
| 		background var(--cwButtonHoverBg) | ||||
|  | ||||
| 	> span | ||||
| 		margin-left 4px | ||||
|  | ||||
| 		&:before | ||||
| 			content '(' | ||||
| 		&:after | ||||
| 			content ')' | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -2,12 +2,17 @@ | ||||
| <div class="felqjxyj" :class="{ splash }"> | ||||
| 	<div class="bg" ref="bg" @click="onBgClick"></div> | ||||
| 	<div class="main" ref="main"> | ||||
| 		<div class="icon" :class="type"><fa :icon="icon"/></div> | ||||
| 		<div class="icon" v-if="!input && !select && !user" :class="type"><fa :icon="icon"/></div> | ||||
| 		<header v-if="title" v-html="title"></header> | ||||
| 		<div class="body" v-if="text" v-html="text"></div> | ||||
| 		<ui-horizon-group no-grow class="buttons" v-if="!splash"> | ||||
| 			<ui-button @click="ok" primary autofocus>OK</ui-button> | ||||
| 			<ui-button @click="cancel" v-if="showCancelButton">Cancel</ui-button> | ||||
| 		<ui-input v-if="input" v-model="inputValue" autofocus :type="input.type || 'text'" :placeholder="input.placeholder" @keydown="onInputKeydown"></ui-input> | ||||
| 		<ui-input v-if="user" v-model="userInputValue" autofocus @keydown="onInputKeydown"><span slot="prefix">@</span></ui-input> | ||||
| 		<ui-select v-if="select" v-model="selectedValue"> | ||||
| 			<option v-for="item in select.items" :value="item.value">{{ item.text }}</option> | ||||
| 		</ui-select> | ||||
| 		<ui-horizon-group no-grow class="buttons fit-bottom" v-if="!splash"> | ||||
| 			<ui-button @click="ok" primary :autofocus="!input && !select && !user">OK</ui-button> | ||||
| 			<ui-button @click="cancel" v-if="showCancelButton || input || select || user">Cancel</ui-button> | ||||
| 		</ui-horizon-group> | ||||
| 	</div> | ||||
| </div> | ||||
| @@ -17,6 +22,7 @@ | ||||
| import Vue from 'vue'; | ||||
| import * as anime from 'animejs'; | ||||
| import { faTimesCircle, faQuestionCircle } from '@fortawesome/free-regular-svg-icons'; | ||||
| import parseAcct from "../../../../../misc/acct/parse"; | ||||
| 
 | ||||
| export default Vue.extend({ | ||||
| 	props: { | ||||
| @@ -33,6 +39,15 @@ export default Vue.extend({ | ||||
| 			type: String, | ||||
| 			required: false | ||||
| 		}, | ||||
| 		input: { | ||||
| 			required: false | ||||
| 		}, | ||||
| 		select: { | ||||
| 			required: false | ||||
| 		}, | ||||
| 		user: { | ||||
| 			required: false | ||||
| 		}, | ||||
| 		showCancelButton: { | ||||
| 			type: Boolean, | ||||
| 			default: false | ||||
| @@ -43,6 +58,14 @@ export default Vue.extend({ | ||||
| 		} | ||||
| 	}, | ||||
| 
 | ||||
| 	data() { | ||||
| 		return { | ||||
| 			inputValue: this.input && this.input.default ? this.input.default : null, | ||||
| 			userInputValue: null, | ||||
| 			selectedValue: null | ||||
| 		}; | ||||
| 	}, | ||||
| 
 | ||||
| 	computed: { | ||||
| 		icon(): any { | ||||
| 			switch (this.type) { | ||||
| @@ -82,9 +105,21 @@ export default Vue.extend({ | ||||
| 	}, | ||||
| 
 | ||||
| 	methods: { | ||||
| 		ok() { | ||||
| 			this.$emit('ok'); | ||||
| 			this.close(); | ||||
| 		async ok() { | ||||
| 			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(); | ||||
| 			} | ||||
| 		}, | ||||
| 
 | ||||
| 		cancel() { | ||||
| @@ -114,6 +149,14 @@ export default Vue.extend({ | ||||
| 
 | ||||
| 		onBgClick() { | ||||
| 			this.cancel(); | ||||
| 		}, | ||||
| 
 | ||||
| 		onInputKeydown(e) { | ||||
| 			if (e.which == 13) { // Enter | ||||
| 				e.preventDefault(); | ||||
| 				e.stopPropagation(); | ||||
| 				this.ok(); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| @@ -180,8 +223,11 @@ export default Vue.extend({ | ||||
| 				display block | ||||
| 				margin 0 auto | ||||
| 
 | ||||
| 			& + header | ||||
| 				margin-top 16px | ||||
| 
 | ||||
| 		> header | ||||
| 			margin 16px 0 8px 0 | ||||
| 			margin 0 0 8px 0 | ||||
| 			font-weight bold | ||||
| 			font-size 20px | ||||
| 
 | ||||
| @@ -1,64 +0,0 @@ | ||||
| <template> | ||||
| <div class="mk-discord-setting"> | ||||
| 	<p>{{ $t('description') }}</p> | ||||
| 	<p class="account" v-if="$store.state.i.discord" :title="`Discord ID: ${$store.state.i.discord.id}`">{{ $t('connected-to') }}: <a :href="`https://discordapp.com/users/${$store.state.i.discord.id}`" target="_blank">@{{ $store.state.i.discord.username }}#{{ $store.state.i.discord.discriminator }}</a></p> | ||||
| 	<p> | ||||
| 		<a :href="`${apiUrl}/connect/discord`" target="_blank" @click.prevent="connect">{{ $store.state.i.discord ? this.$t('reconnect') : this.$t('connect') }}</a> | ||||
| 		<span v-if="$store.state.i.discord"> or </span> | ||||
| 		<a :href="`${apiUrl}/disconnect/discord`" target="_blank" v-if="$store.state.i.discord" @click.prevent="disconnect">{{ $t('disconnect') }}</a> | ||||
| 	</p> | ||||
| 	<p class="id" v-if="$store.state.i.discord">Discord ID: {{ $store.state.i.discord.id }}</p> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import i18n from '../../../i18n'; | ||||
| import { apiUrl } from '../../../config'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n: i18n('common/views/components/discord-setting.vue'), | ||||
| 	data() { | ||||
| 		return { | ||||
| 			form: null, | ||||
| 			apiUrl | ||||
| 		}; | ||||
| 	}, | ||||
| 	mounted() { | ||||
| 		this.$watch('$store.state.i', () => { | ||||
| 			if (this.$store.state.i.discord && this.form) | ||||
| 				this.form.close(); | ||||
| 		}, { | ||||
| 			deep: true | ||||
| 		}); | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		connect() { | ||||
| 			this.form = window.open(apiUrl + '/connect/discord', | ||||
| 				'discord_connect_window', | ||||
| 				'height=570, width=520'); | ||||
| 		}, | ||||
|  | ||||
| 		disconnect() { | ||||
| 			window.open(apiUrl + '/disconnect/discord', | ||||
| 				'discord_disconnect_window', | ||||
| 				'height=570, width=520'); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .mk-discord-setting | ||||
| 	.account | ||||
| 		border solid 1px #e1e8ed | ||||
| 		border-radius 4px | ||||
| 		padding 16px | ||||
|  | ||||
| 		a | ||||
| 			font-weight bold | ||||
| 			color inherit | ||||
|  | ||||
| 	.id | ||||
| 		color #8899a6 | ||||
| </style> | ||||
| @@ -114,11 +114,11 @@ export default Vue.extend({ | ||||
| 		}, | ||||
|  | ||||
| 		onScroll(e) { | ||||
| 			const section = this.categories.forEach(x => { | ||||
| 			for (const x of this.categories) { | ||||
| 				const top = e.target.scrollTop; | ||||
| 				const el = this.$refs[x.ref][0]; | ||||
| 				x.isActive = el.offsetTop <= top && el.offsetTop + el.offsetHeight > top; | ||||
| 			}); | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
| 		chosen(emoji) { | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| <template> | ||||
| <img v-if="customEmoji" class="fvgwvorwhxigeolkkrcderjzcawqrscl custom" :src="url" :alt="alt" :title="alt"/> | ||||
| <img v-if="customEmoji" class="fvgwvorwhxigeolkkrcderjzcawqrscl custom" :class="{ normal: normal }" :src="url" :alt="alt" :title="alt"/> | ||||
| <img v-else-if="char && !useOsDefaultEmojis" class="fvgwvorwhxigeolkkrcderjzcawqrscl" :src="url" :alt="alt" :title="alt"/> | ||||
| <span v-else-if="char && useOsDefaultEmojis">{{ char }}</span> | ||||
| <span v-else>:{{ name }}:</span> | ||||
| @@ -20,6 +20,11 @@ export default Vue.extend({ | ||||
| 			type: String, | ||||
| 			required: false | ||||
| 		}, | ||||
| 		normal: { | ||||
| 			type: Boolean, | ||||
| 			required: false, | ||||
| 			default: false | ||||
| 		}, | ||||
| 		customEmojis: { | ||||
| 			required: false, | ||||
| 			default: () => [] | ||||
| @@ -61,8 +66,9 @@ export default Vue.extend({ | ||||
| 		} | ||||
|  | ||||
| 		if (this.char) { | ||||
| 			let codes = [...this.char].map(x => x.codePointAt(0).toString(16)); | ||||
| 			let codes = Array.from(this.char).map(x => x.codePointAt(0).toString(16)); | ||||
| 			if (!codes.includes('200d')) codes = codes.filter(x => x != 'fe0f'); | ||||
| 			codes = codes.filter(x => x && x.length); | ||||
|  | ||||
| 			this.url = `https://twemoji.maxcdn.com/2/svg/${codes.join('-')}.svg`; | ||||
| 		} | ||||
| @@ -83,4 +89,11 @@ export default Vue.extend({ | ||||
| 		&:hover | ||||
| 			transform scale(1.2) | ||||
|  | ||||
| 		&.normal | ||||
| 			height 1.25em | ||||
| 			vertical-align -0.25em | ||||
|  | ||||
| 			&:hover | ||||
| 				transform none | ||||
|  | ||||
| </style> | ||||
|   | ||||
| @@ -48,7 +48,7 @@ export default Vue.extend({ | ||||
| 		iconAndText(): any[] { | ||||
| 			return ( | ||||
| 				(this.hasPendingFollowRequestFromYou && this.user.isLocked) ? ['hourglass-half', this.$t('request-pending')] : | ||||
| 				(this.hasPendingFollowRequestFromYou && !this.user.isLocked) ? ['hourglass-start', this.$t('follow-processing')] : | ||||
| 				(this.hasPendingFollowRequestFromYou && !this.user.isLocked) ? ['spinner', this.$t('follow-processing')] : | ||||
| 				(this.isFollowing) ? ['minus', this.$t('following')] : | ||||
| 				(!this.isFollowing && this.user.isLocked) ? ['plus', this.$t('follow-request')] : | ||||
| 				(!this.isFollowing && !this.user.isLocked) ? ['plus', this.$t('follow')] : | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <template> | ||||
| <div class="xqnhankfuuilcwvhgsopeqncafzsquya"> | ||||
| 	<button class="go-index" v-if="selfNav" @click="goIndex"><fa icon="arrow-left"/></button> | ||||
| 	<header><b><router-link :to="blackUser | userPage">{{ blackUser | userName }}</router-link></b>({{ $t('@.reversi.black') }}) vs <b><router-link :to="whiteUser | userPage">{{ whiteUser | userName }}</router-link></b>({{ $t('@.reversi.white') }})</header> | ||||
| 	<header><b><router-link :to="blackUser | userPage"><mk-user-name :user="blackUser"/></router-link></b>({{ $t('@.reversi.black') }}) vs <b><router-link :to="whiteUser | userPage"><mk-user-name :user="whiteUser"/></router-link></b>({{ $t('@.reversi.white') }})</header> | ||||
|  | ||||
| 	<div style="overflow: hidden; line-height: 28px;"> | ||||
| 		<p class="turn" v-if="!iAmPlayer && !game.isEnded">{{ $t('@.reversi.turn-of', { name: $options.filters.userName(turnUser) }) }}<mk-ellipsis/></p> | ||||
| @@ -10,7 +10,7 @@ | ||||
| 		<p class="turn2" v-if="iAmPlayer && !game.isEnded && isMyTurn" v-animate-css="{ classes: 'tada', iteration: 'infinite' }">{{ $t('@.reversi.my-turn') }}</p> | ||||
| 		<p class="result" v-if="game.isEnded && logPos == logs.length"> | ||||
| 			<template v-if="game.winner"> | ||||
| 				<span>{{ $t('@.reversi.won', { name: $options.filters.userName(game.winner) }) }}</span> | ||||
| 				<misskey-flavored-markdown :text="$t('@.reversi.won', { name: $options.filters.userName(game.winner) })" :shouldBreak="false" :plainText="true" :custom-emojis="game.winner.emojis"/> | ||||
| 				<span v-if="game.surrendered != null"> ({{ $t('surrendered') }})</span> | ||||
| 			</template> | ||||
| 			<template v-else>{{ $t('@.reversi.drawn') }}</template> | ||||
| @@ -30,8 +30,14 @@ | ||||
| 						:class="{ empty: stone == null, none: o.map[i] == 'null', isEnded: game.isEnded, myTurn: !game.isEnded && isMyTurn, can: turnUser ? o.canPut(turnUser.id == blackUser.id, i) : null, prev: o.prevPos == i }" | ||||
| 						@click="set(i)" | ||||
| 						:title="`${String.fromCharCode(65 + o.transformPosToXy(i)[0])}${o.transformPosToXy(i)[1] + 1}`"> | ||||
| 					<img v-if="stone === true" :src="blackUser.avatarUrl" alt="black" :class="{ contrast: $store.state.settings.games.reversi.useContrastStones }"> | ||||
| 					<img v-if="stone === false" :src="whiteUser.avatarUrl" alt="white" :class="{ contrast: $store.state.settings.games.reversi.useContrastStones }"> | ||||
| 					<template v-if="!$store.state.settings.games.reversi.useWhiteBlackStones"> | ||||
| 						<img v-if="stone === true" :src="blackUser.avatarUrl" alt="black"> | ||||
| 						<img v-if="stone === false" :src="whiteUser.avatarUrl" alt="white"> | ||||
| 					</template> | ||||
| 					<template v-if="$store.state.settings.games.reversi.useWhiteBlackStones"> | ||||
| 						<fa v-if="stone === true" :icon="fasCircle"/> | ||||
| 						<fa v-if="stone === false" :icon="farCircle"/> | ||||
| 					</template> | ||||
| 				</div> | ||||
| 			</div> | ||||
| 			<div class="labels-y" v-if="this.$store.state.settings.games.reversi.showBoardLabels"> | ||||
| @@ -50,15 +56,13 @@ | ||||
| 	</div> | ||||
|  | ||||
| 	<div class="player" v-if="game.isEnded"> | ||||
| 		<div> | ||||
| 			<button @click="logPos = 0" :disabled="logPos == 0"><fa icon="angle-double-left"/></button> | ||||
| 			<button @click="logPos--" :disabled="logPos == 0"><fa icon="angle-left"/></button> | ||||
| 		</div> | ||||
| 		<span>{{ logPos }} / {{ logs.length }}</span> | ||||
| 		<div> | ||||
| 			<button @click="logPos++" :disabled="logPos == logs.length"><fa icon="angle-right"/></button> | ||||
| 			<button @click="logPos = logs.length" :disabled="logPos == logs.length"><fa icon="angle-double-right"/></button> | ||||
| 		</div> | ||||
| 		<ui-horizon-group> | ||||
| 			<ui-button @click="logPos = 0" :disabled="logPos == 0"><fa :icon="faAngleDoubleLeft"/></ui-button> | ||||
| 			<ui-button @click="logPos--" :disabled="logPos == 0"><fa :icon="faAngleLeft"/></ui-button> | ||||
| 			<ui-button @click="logPos++" :disabled="logPos == logs.length"><fa :icon="faAngleRight"/></ui-button> | ||||
| 			<ui-button @click="logPos = logs.length" :disabled="logPos == logs.length"><fa :icon="faAngleDoubleRight"/></ui-button> | ||||
| 		</ui-horizon-group> | ||||
| 	</div> | ||||
|  | ||||
| 	<div class="info"> | ||||
| @@ -75,6 +79,9 @@ import i18n from '../../../../../i18n'; | ||||
| import * as CRC32 from 'crc-32'; | ||||
| import Reversi, { Color } from '../../../../../../../games/reversi/core'; | ||||
| import { url } from '../../../../../config'; | ||||
| import { faAngleDoubleLeft, faAngleLeft, faAngleRight, faAngleDoubleRight } from '@fortawesome/free-solid-svg-icons'; | ||||
| import { faCircle as fasCircle } from '@fortawesome/free-solid-svg-icons'; | ||||
| import { faCircle as farCircle } from '@fortawesome/free-regular-svg-icons'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n: i18n('common/views/components/games/reversi/reversi.game.vue'), | ||||
| @@ -99,7 +106,8 @@ export default Vue.extend({ | ||||
| 			o: null as Reversi, | ||||
| 			logs: [], | ||||
| 			logPos: 0, | ||||
| 			pollingClock: null | ||||
| 			pollingClock: null, | ||||
| 			faAngleDoubleLeft, faAngleLeft, faAngleRight, faAngleDoubleRight, fasCircle, farCircle | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| @@ -177,9 +185,9 @@ export default Vue.extend({ | ||||
| 			loopedBoard: this.game.settings.loopedBoard | ||||
| 		}); | ||||
|  | ||||
| 		this.game.logs.forEach(log => { | ||||
| 		for (const log of this.game.logs) { | ||||
| 			this.o.put(log.color, log.pos); | ||||
| 		}); | ||||
| 		} | ||||
|  | ||||
| 		this.logs = this.game.logs; | ||||
| 		this.logPos = this.logs.length; | ||||
| @@ -279,9 +287,9 @@ export default Vue.extend({ | ||||
| 				loopedBoard: this.game.settings.loopedBoard | ||||
| 			}); | ||||
|  | ||||
| 			this.game.logs.forEach(log => { | ||||
| 			for (const log of this.game.logs) { | ||||
| 				this.o.put(log.color, log.pos, true); | ||||
| 			}); | ||||
| 			} | ||||
|  | ||||
| 			this.logs = this.game.logs; | ||||
| 			this.logPos = this.logs.length; | ||||
| @@ -412,17 +420,15 @@ export default Vue.extend({ | ||||
| 					&.none | ||||
| 						border-color transparent !important | ||||
|  | ||||
| 					> img | ||||
| 					> svg | ||||
| 						display block | ||||
| 						width 100% | ||||
| 						height 100% | ||||
|  | ||||
| 						&.contrast | ||||
| 							&[alt="black"] | ||||
| 								filter brightness(.5) | ||||
|  | ||||
| 							&[alt="white"] | ||||
| 								filter brightness(2) | ||||
| 					> img | ||||
| 						display block | ||||
| 						width 100% | ||||
| 						height 100% | ||||
|  | ||||
| 	> .graph | ||||
| 		display grid | ||||
| @@ -449,7 +455,9 @@ export default Vue.extend({ | ||||
| 		padding-bottom 16px | ||||
|  | ||||
| 	> .player | ||||
| 		padding-bottom 32px | ||||
| 		padding 0 16px 32px 16px | ||||
| 		margin 0 auto | ||||
| 		max-width 500px | ||||
|  | ||||
| 		> span | ||||
| 			display inline-block | ||||
|   | ||||
| @@ -19,7 +19,7 @@ | ||||
| 		<h2>{{ $t('invitations') }}</h2> | ||||
| 		<div class="invitation" v-for="i in invitations" tabindex="-1" @click="accept(i)"> | ||||
| 			<mk-avatar class="avatar" :user="i.parent"/> | ||||
| 			<span class="name"><b>{{ i.parent | userName }}</b></span> | ||||
| 			<span class="name"><b><mk-user-name :user="i.parent"/></b></span> | ||||
| 			<span class="username">@{{ i.parent.username }}</span> | ||||
| 			<mk-time :time="i.createdAt"/> | ||||
| 		</div> | ||||
| @@ -29,7 +29,7 @@ | ||||
| 		<a class="game" v-for="g in myGames" tabindex="-1" @click.prevent="go(g)" :href="`/reversi/${g.id}`"> | ||||
| 			<mk-avatar class="avatar" :user="g.user1"/> | ||||
| 			<mk-avatar class="avatar" :user="g.user2"/> | ||||
| 			<span><b>{{ g.user1 | userName }}</b> vs <b>{{ g.user2 | userName }}</b></span> | ||||
| 			<span><b><mk-user-name :user="g.user1"/></b> vs <b><mk-user-name :user="g.user2"/></b></span> | ||||
| 			<span class="state">{{ g.isEnded ? $t('game-state.ended') : $t('game-state.playing') }}</span> | ||||
| 			<mk-time :time="g.createdAt" /> | ||||
| 		</a> | ||||
| @@ -39,7 +39,7 @@ | ||||
| 		<a class="game" v-for="g in games" tabindex="-1" @click.prevent="go(g)" :href="`/reversi/${g.id}`"> | ||||
| 			<mk-avatar class="avatar" :user="g.user1"/> | ||||
| 			<mk-avatar class="avatar" :user="g.user2"/> | ||||
| 			<span><b>{{ g.user1 | userName }}</b> vs <b>{{ g.user2 | userName }}</b></span> | ||||
| 			<span><b><mk-user-name :user="g.user1"/></b> vs <b><mk-user-name :user="g.user2"/></b></span> | ||||
| 			<span class="state">{{ g.isEnded ? $t('game-state.ended') : $t('game-state.playing') }}</span> | ||||
| 			<mk-time :time="g.createdAt" /> | ||||
| 		</a> | ||||
| @@ -99,23 +99,22 @@ export default Vue.extend({ | ||||
| 			this.$emit('go', game); | ||||
| 		}, | ||||
|  | ||||
| 		match() { | ||||
| 			this.$input({ | ||||
| 				title: this.$t('enter-username') | ||||
| 			}).then(username => { | ||||
| 				this.$root.api('users/show', { | ||||
| 					username | ||||
| 				}).then(user => { | ||||
| 					this.$root.api('games/reversi/match', { | ||||
| 						userId: user.id | ||||
| 					}).then(res => { | ||||
| 						if (res == null) { | ||||
| 							this.$emit('matching', user); | ||||
| 						} else { | ||||
| 							this.$emit('go', res); | ||||
| 						} | ||||
| 					}); | ||||
| 				}); | ||||
| 		async match() { | ||||
| 			const { result: user } = await this.$root.dialog({ | ||||
| 				title: this.$t('enter-username'), | ||||
| 				user: { | ||||
| 					local: true | ||||
| 				} | ||||
| 			}); | ||||
| 			if (user == null) return; | ||||
| 			this.$root.api('games/reversi/match', { | ||||
| 				userId: user.id | ||||
| 			}).then(res => { | ||||
| 				if (res == null) { | ||||
| 					this.$emit('matching', user); | ||||
| 				} else { | ||||
| 					this.$emit('go', res); | ||||
| 				} | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <template> | ||||
| <div class="urbixznjwwuukfsckrwzwsqzsxornqij"> | ||||
| 	<header><b>{{ game.user1 | userName }}</b> vs <b>{{ game.user2 | userName }}</b></header> | ||||
| 	<header><b><mk-user-name :user="game.user1"/></b> vs <b><mk-user-name :user="game.user2"/></b></header> | ||||
|  | ||||
| 	<div> | ||||
| 		<p>{{ $t('settings-of-the-game') }}</p> | ||||
| @@ -22,8 +22,8 @@ | ||||
| 					<div v-for="(x, i) in game.settings.map.join('')" | ||||
| 							:data-none="x == ' '" | ||||
| 							@click="onPixelClick(i, x)"> | ||||
| 						<template v-if="x == 'b'"><template v-if="$store.state.device.darkmode"><fa :icon="['far', 'circle']"/></template><template v-else><fa icon="circle"/></template></template> | ||||
| 						<template v-if="x == 'w'"><template v-if="$store.state.device.darkmode"><fa :icon="['far', 'circle']"/></template><template v-else><fa icon="circle"/></template></template> | ||||
| 						<fa v-if="x == 'b'" :icon="fasCircle"/> | ||||
| 						<fa v-if="x == 'w'" :icon="farCircle"/> | ||||
| 					</div> | ||||
| 				</div> | ||||
| 			</div> | ||||
| @@ -36,8 +36,8 @@ | ||||
|  | ||||
| 			<div> | ||||
| 				<form-radio v-model="game.settings.bw" value="random" @change="updateSettings">{{ $t('random') }}</form-radio> | ||||
| 				<form-radio v-model="game.settings.bw" :value="1" @change="updateSettings">{{ this.$t('black-is').split('{}')[0] }}<b>{{ game.user1 | userName }}</b>{{ this.$t('black-is').split('{}')[1] }}</form-radio> | ||||
| 				<form-radio v-model="game.settings.bw" :value="2" @change="updateSettings">{{ this.$t('black-is').split('{}')[0] }}<b>{{ game.user2 | userName }}</b>{{ this.$t('black-is').split('{}')[1] }}</form-radio> | ||||
| 				<form-radio v-model="game.settings.bw" :value="1" @change="updateSettings">{{ this.$t('black-is').split('{}')[0] }}<b><mk-user-name :user="game.user1"/></b>{{ this.$t('black-is').split('{}')[1] }}</form-radio> | ||||
| 				<form-radio v-model="game.settings.bw" :value="2" @change="updateSettings">{{ this.$t('black-is').split('{}')[0] }}<b><mk-user-name :user="game.user2"/></b>{{ this.$t('black-is').split('{}')[1] }}</form-radio> | ||||
| 			</div> | ||||
| 		</div> | ||||
|  | ||||
| @@ -60,7 +60,7 @@ | ||||
|  | ||||
| 			<div> | ||||
| 				<template v-for="item in form"> | ||||
| 					<ui-switch v-if="item.type == 'switch'" v-model="item.value" :key="item.id" :text="item.label" @change="onChangeForm(item)">{{ item.desc || '' }}</ui-switch> | ||||
| 					<ui-switch v-if="item.type == 'switch'" v-model="item.value" :key="item.id" @change="onChangeForm(item)">{{ item.label || item.desc || '' }}</ui-switch> | ||||
|  | ||||
| 					<div class="card" v-if="item.type == 'radio'" :key="item.id"> | ||||
| 						<header> | ||||
| @@ -117,6 +117,8 @@ | ||||
| import Vue from 'vue'; | ||||
| import i18n from '../../../../../i18n'; | ||||
| import * as maps from '../../../../../../../games/reversi/maps'; | ||||
| import { faCircle as fasCircle } from '@fortawesome/free-solid-svg-icons'; | ||||
| import { faCircle as farCircle } from '@fortawesome/free-regular-svg-icons'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n: i18n('common/views/components/games/reversi/reversi.room.vue'), | ||||
| @@ -129,7 +131,8 @@ export default Vue.extend({ | ||||
| 			mapName: maps.eighteight.name, | ||||
| 			maps: maps, | ||||
| 			form: null, | ||||
| 			messages: [] | ||||
| 			messages: [], | ||||
| 			fasCircle, farCircle | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
|   | ||||
| @@ -4,7 +4,7 @@ | ||||
| 		<x-gameroom :game="game" :self-nav="selfNav" @go-index="goIndex"/> | ||||
| 	</div> | ||||
| 	<div class="matching" v-else-if="matching"> | ||||
| 		<h1>{{ this.$t('matching.waiting-for').split('{}')[0] }}<b>{{ matching | userName }}</b>{{ this.$t('matching.waiting-for').split('{}')[1] }}<mk-ellipsis/></h1> | ||||
| 		<h1>{{ this.$t('matching.waiting-for').split('{}')[0] }}<b><mk-user-name :user="matching"/></b>{{ this.$t('matching.waiting-for').split('{}')[1] }}<mk-ellipsis/></h1> | ||||
| 		<div class="cancel"> | ||||
| 			<form-button round @click="cancel">{{ $t('matching.cancel') }}</form-button> | ||||
| 		</div> | ||||
|   | ||||
| @@ -1,64 +0,0 @@ | ||||
| <template> | ||||
| <div class="mk-github-setting"> | ||||
| 	<p>{{ $t('description') }}</p> | ||||
| 	<p class="account" v-if="$store.state.i.github" :title="`GitHub ID: ${$store.state.i.github.id}`">{{ $t('connected-to') }}: <a :href="`https://github.com/${$store.state.i.github.login}`" target="_blank">@{{ $store.state.i.github.login }}</a></p> | ||||
| 	<p> | ||||
| 		<a :href="`${apiUrl}/connect/github`" target="_blank" @click.prevent="connect">{{ $store.state.i.github ? this.$t('reconnect') : this.$t('connect') }}</a> | ||||
| 		<span v-if="$store.state.i.github"> or </span> | ||||
| 		<a :href="`${apiUrl}/disconnect/github`" target="_blank" v-if="$store.state.i.github" @click.prevent="disconnect">{{ $t('disconnect') }}</a> | ||||
| 	</p> | ||||
| 	<p class="id" v-if="$store.state.i.github">GitHub ID: {{ $store.state.i.github.id }}</p> | ||||
| </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import i18n from '../../../i18n'; | ||||
| import { apiUrl } from '../../../config'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n: i18n('common/views/components/github-setting.vue'), | ||||
| 	data() { | ||||
| 		return { | ||||
| 			form: null, | ||||
| 			apiUrl | ||||
| 		}; | ||||
| 	}, | ||||
| 	mounted() { | ||||
| 		this.$watch('$store.state.i', () => { | ||||
| 			if (this.$store.state.i.github && this.form) | ||||
| 				this.form.close(); | ||||
| 		}, { | ||||
| 			deep: true | ||||
| 		}); | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		connect() { | ||||
| 			this.form = window.open(apiUrl + '/connect/github', | ||||
| 				'github_connect_window', | ||||
| 				'height=570, width=520'); | ||||
| 		}, | ||||
|  | ||||
| 		disconnect() { | ||||
| 			window.open(apiUrl + '/disconnect/github', | ||||
| 				'github_disconnect_window', | ||||
| 				'height=570, width=520'); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .mk-github-setting | ||||
| 	.account | ||||
| 		border solid 1px #e1e8ed | ||||
| 		border-radius 4px | ||||
| 		padding 16px | ||||
|  | ||||
| 		a | ||||
| 			font-weight bold | ||||
| 			color inherit | ||||
|  | ||||
| 	.id | ||||
| 		color #8899a6 | ||||
| </style> | ||||
| @@ -22,7 +22,10 @@ export default Vue.extend({ | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		search() { | ||||
| 			window.open(`https://www.google.com/?#q=${this.query}`, '_blank'); | ||||
| 			const engine = this.$store.state.settings.webSearchEngine || | ||||
| 				'https://www.google.com/?#q={{query}}'; | ||||
| 			const url = engine.replace('{{query}}', this.query) | ||||
| 			window.open(url, '_blank'); | ||||
| 		} | ||||
| 	} | ||||
| }); | ||||
|   | ||||
| @@ -1,5 +1,6 @@ | ||||
| import Vue from 'vue'; | ||||
|  | ||||
| import userName from './user-name.vue'; | ||||
| import followButton from './follow-button.vue'; | ||||
| import error from './error.vue'; | ||||
| import noteSkeleton from './note-skeleton.vue'; | ||||
| @@ -44,6 +45,7 @@ import uiInfo from './ui/info.vue'; | ||||
| import formButton from './ui/form/button.vue'; | ||||
| import formRadio from './ui/form/radio.vue'; | ||||
|  | ||||
| Vue.component('mk-user-name', userName); | ||||
| Vue.component('mk-follow-button', followButton); | ||||
| Vue.component('mk-error', error); | ||||
| Vue.component('mk-note-skeleton', noteSkeleton); | ||||
|   | ||||
							
								
								
									
										114
									
								
								src/client/app/common/views/components/integration-settings.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,114 @@ | ||||
| <template> | ||||
| <ui-card v-if="enableTwitterIntegration || enableDiscordIntegration || enableGithubIntegration"> | ||||
| 	<div slot="title"><fa icon="share-alt"/> {{ $t('title') }}</div> | ||||
|  | ||||
| 	<section v-if="enableTwitterIntegration"> | ||||
| 		<header><fa :icon="['fab', 'twitter']"/> Twitter</header> | ||||
| 		<p v-if="$store.state.i.twitter">{{ $t('connected-to') }}: <a :href="`https://twitter.com/${$store.state.i.twitter.screenName}`" target="_blank">@{{ $store.state.i.twitter.screenName }}</a></p> | ||||
| 		<ui-button v-if="$store.state.i.twitter" @click="disconnectTwitter">{{ $t('disconnect') }}</ui-button> | ||||
| 		<ui-button v-else @click="connectTwitter">{{ $t('connect') }}</ui-button> | ||||
| 	</section> | ||||
|  | ||||
| 	<section v-if="enableDiscordIntegration"> | ||||
| 		<header><fa :icon="['fab', 'discord']"/> Discord</header> | ||||
| 		<p v-if="$store.state.i.discord">{{ $t('connected-to') }}: <a :href="`https://discordapp.com/users/${$store.state.i.discord.id}`" target="_blank">@{{ $store.state.i.discord.username }}#{{ $store.state.i.discord.discriminator }}</a></p> | ||||
| 		<ui-button v-if="$store.state.i.discord" @click="disconnectDiscord">{{ $t('disconnect') }}</ui-button> | ||||
| 		<ui-button v-else @click="connectDiscord">{{ $t('connect') }}</ui-button> | ||||
| 	</section> | ||||
|  | ||||
| 	<section v-if="enableGithubIntegration"> | ||||
| 		<header><fa :icon="['fab', 'github']"/> GitHub</header> | ||||
| 		<p v-if="$store.state.i.github">{{ $t('connected-to') }}: <a :href="`https://github.com/${$store.state.i.github.login}`" target="_blank">@{{ $store.state.i.github.login }}</a></p> | ||||
| 		<ui-button v-if="$store.state.i.github" @click="disconnectGithub">{{ $t('disconnect') }}</ui-button> | ||||
| 		<ui-button v-else @click="connectGithub">{{ $t('connect') }}</ui-button> | ||||
| 	</section> | ||||
| </ui-card> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import i18n from '../../../i18n'; | ||||
| import { apiUrl } from '../../../config'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n: i18n('common/views/components/integration-settings.vue'), | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			apiUrl, | ||||
| 			twitterForm: null, | ||||
| 			discordForm: null, | ||||
| 			githubForm: null, | ||||
| 			enableTwitterIntegration: false, | ||||
| 			enableDiscordIntegration: false, | ||||
| 			enableGithubIntegration: false, | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	created() { | ||||
| 		this.$root.getMeta().then(meta => { | ||||
| 			this.enableTwitterIntegration = meta.enableTwitterIntegration; | ||||
| 			this.enableDiscordIntegration = meta.enableDiscordIntegration; | ||||
| 			this.enableGithubIntegration = meta.enableGithubIntegration; | ||||
| 		}); | ||||
| 	}, | ||||
|  | ||||
| 	mounted() { | ||||
| 		document.cookie = `i=${this.$store.state.i.token}`; | ||||
| 		this.$watch('$store.state.i', () => { | ||||
| 			if (this.$store.state.i.twitter) { | ||||
| 				if (this.twitterForm) this.twitterForm.close(); | ||||
| 			} | ||||
| 			if (this.$store.state.i.discord) { | ||||
| 				if (this.discordForm) this.discordForm.close(); | ||||
| 			} | ||||
| 			if (this.$store.state.i.github) { | ||||
| 				if (this.githubForm) this.githubForm.close(); | ||||
| 			} | ||||
| 		}, { | ||||
| 			deep: true | ||||
| 		}); | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 		connectTwitter() { | ||||
| 			this.twitterForm = window.open(apiUrl + '/connect/twitter', | ||||
| 				'twitter_connect_window', | ||||
| 				'height=570, width=520'); | ||||
| 		}, | ||||
|  | ||||
| 		disconnectTwitter() { | ||||
| 			window.open(apiUrl + '/disconnect/twitter', | ||||
| 				'twitter_disconnect_window', | ||||
| 				'height=570, width=520'); | ||||
| 		}, | ||||
|  | ||||
| 		connectDiscord() { | ||||
| 			this.discordForm = window.open(apiUrl + '/connect/discord', | ||||
| 				'discord_connect_window', | ||||
| 				'height=570, width=520'); | ||||
| 		}, | ||||
|  | ||||
| 		disconnectDiscord() { | ||||
| 			window.open(apiUrl + '/disconnect/discord', | ||||
| 				'discord_disconnect_window', | ||||
| 				'height=570, width=520'); | ||||
| 		}, | ||||
|  | ||||
| 		connectGithub() { | ||||
| 			this.githubForm = window.open(apiUrl + '/connect/github', | ||||
| 				'github_connect_window', | ||||
| 				'height=570, width=520'); | ||||
| 		}, | ||||
|  | ||||
| 		disconnectGithub() { | ||||
| 			window.open(apiUrl + '/disconnect/github', | ||||
| 				'github_disconnect_window', | ||||
| 				'height=570, width=520'); | ||||
| 		}, | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| </style> | ||||
							
								
								
									
										54
									
								
								src/client/app/common/views/components/language-settings.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,54 @@ | ||||
| <template> | ||||
| <ui-card> | ||||
| 	<div slot="title"><fa icon="language"/> {{ $t('title') }}</div> | ||||
|  | ||||
| 	<section class="fit-top"> | ||||
| 		<ui-select v-model="lang" :placeholder="$t('pick-language')"> | ||||
| 			<optgroup :label="$t('recommended')"> | ||||
| 				<option value="">{{ $t('auto') }}</option> | ||||
| 			</optgroup> | ||||
|  | ||||
| 			<optgroup :label="$t('specify-language')"> | ||||
| 				<option v-for="x in langs" :value="x[0]" :key="x[0]">{{ x[1] }}</option> | ||||
| 			</optgroup> | ||||
| 		</ui-select> | ||||
| 		<ui-info>Current: <i>{{ currentLanguage }}</i></ui-info> | ||||
| 		<ui-info warn>{{ $t('info') }}</ui-info> | ||||
| 	</section> | ||||
| </ui-card> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import i18n from '../../../i18n'; | ||||
| import { langs } from '../../../config'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n: i18n('common/views/components/language-settings.vue'), | ||||
|  | ||||
| 	data() { | ||||
| 		return { | ||||
| 			langs, | ||||
| 			currentLanguage: 'Unknown', | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	computed: { | ||||
| 		lang: { | ||||
| 			get() { return this.$store.state.device.lang; }, | ||||
| 			set(value) { this.$store.commit('device/set', { key: 'lang', value }); } | ||||
| 		}, | ||||
| 	}, | ||||
|  | ||||
| 	created() { | ||||
| 		try { | ||||
| 			const locale = JSON.parse(localStorage.getItem('locale') || "{}"); | ||||
| 			const localeKey = localStorage.getItem('localeKey'); | ||||
| 			this.currentLanguage = `${locale.meta.lang} (${localeKey})`; | ||||
| 		} catch { } | ||||
| 	}, | ||||
|  | ||||
| 	methods: { | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
							
								
								
									
										70
									
								
								src/client/app/common/views/components/mention.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,70 @@ | ||||
| <template> | ||||
| <router-link class="ldlomzub" :to="`/@${ canonical }`" v-user-preview="canonical"> | ||||
| 	<span class="me" v-if="isMe">{{ $t('@.you') }}</span> | ||||
| 	<span class="main"> | ||||
| 		<span class="username">@{{ username }}</span> | ||||
| 		<span class="host" :class="{ fade: $store.state.settings.contrastedAcct }" v-if="(host != localHost) || $store.state.settings.showFullAcct">@{{ toUnicode(host) }}</span> | ||||
| 	</span> | ||||
| </router-link> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts"> | ||||
| import Vue from 'vue'; | ||||
| import i18n from '../../../i18n'; | ||||
| import { toUnicode } from 'punycode'; | ||||
| import { host as localHost } from '../../../config'; | ||||
|  | ||||
| export default Vue.extend({ | ||||
| 	i18n: i18n(), | ||||
| 	props: { | ||||
| 		username: { | ||||
| 			type: String, | ||||
| 			required: true | ||||
| 		}, | ||||
| 		host: { | ||||
| 			type: String, | ||||
| 			required: true | ||||
| 		} | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| 			localHost | ||||
| 		}; | ||||
| 	}, | ||||
| 	computed: { | ||||
| 		canonical(): string { | ||||
| 			return `@${this.username}@${toUnicode(this.host)}`; | ||||
| 		}, | ||||
| 		isMe(): boolean { | ||||
| 			return this.$store.getters.isSignedIn && this.canonical.toLowerCase() === `@${this.$store.state.i.username}@${toUnicode(localHost)}`.toLowerCase(); | ||||
| 		} | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		toUnicode | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style lang="stylus" scoped> | ||||
| .ldlomzub | ||||
| 	color var(--mfmMention) | ||||
|  | ||||
| 	> .me | ||||
| 		pointer-events none | ||||
| 		user-select none | ||||
| 		padding 0 4px | ||||
| 		background var(--primary) | ||||
| 		border solid 1px var(--primary) | ||||
| 		border-radius 4px 0 0 4px | ||||
| 		color var(--primaryForeground) | ||||
|  | ||||
| 		& + .main | ||||
| 			padding 0 4px | ||||
| 			border solid 1px var(--primary) | ||||
| 			border-radius 0 4px 4px 0 | ||||
|  | ||||
| 	> .main | ||||
| 		> .host.fade | ||||
| 			opacity 0.5 | ||||
|  | ||||
| </style> | ||||
| @@ -1,5 +1,5 @@ | ||||
| <template> | ||||
| <div class="onchrpzrvnoruiaenfcqvccjfuupzzwv"> | ||||
| <div class="onchrpzrvnoruiaenfcqvccjfuupzzwv" :class="{ big: $root.isMobile }"> | ||||
| 	<div class="backdrop" ref="backdrop" @click="close"></div> | ||||
| 	<div class="popover" :class="{ hukidasi }" ref="popover"> | ||||
| 		<template v-for="item, i in items"> | ||||
| @@ -125,6 +125,11 @@ export default Vue.extend({ | ||||
|  | ||||
| 	position initial | ||||
|  | ||||
| 	&.big | ||||
| 		> .popover | ||||
| 			> button | ||||
| 				font-size 15px | ||||
|  | ||||
| 	> .backdrop | ||||
| 		position fixed | ||||
| 		top 0 | ||||
| @@ -180,6 +185,7 @@ export default Vue.extend({ | ||||
| 			padding 8px 16px | ||||
| 			width 100% | ||||
| 			color var(--popupFg) | ||||
| 			white-space nowrap | ||||
|  | ||||
| 			&:hover | ||||
| 				color var(--primaryForeground) | ||||
|   | ||||