Compare commits
	
		
			359 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 929e545514 | ||
|   | 3e7a87f75a | ||
|   | caf40e40fb | ||
|   | b608f63a1a | ||
|   | dc44d9a0a8 | ||
|   | bb926dd301 | ||
|   | 79cb836483 | ||
|   | f1c4e4a10e | ||
|   | 798aedfc0f | ||
|   | 1077c2a637 | ||
|   | cbe689607c | ||
|   | 948b70cb0f | ||
|   | 0263539202 | ||
|   | 52e54cf0dc | ||
|   | 24e7eeca0f | ||
|   | d76345264d | ||
|   | 0eb115bf7e | ||
|   | 30d2a1d8b6 | ||
|   | 857c88e8d6 | ||
|   | ffb9646ce9 | ||
|   | db3724cf33 | ||
|   | 466c083233 | ||
|   | ae2267220b | ||
|   | c92744c3d3 | ||
|   | 35f075b887 | ||
|   | 6cc4edc5e8 | ||
|   | c06091f78a | ||
|   | f85399e355 | ||
|   | 47aaf04481 | ||
|   | 7063a6925f | ||
|   | 3cd04c4b81 | ||
|   | 942c802431 | ||
|   | e6754eb880 | ||
|   | 70d02cf1be | ||
|   | ef646b9576 | ||
|   | ecd541873b | ||
|   | 5d10642e07 | ||
|   | da34acd35f | ||
|   | 0108b8bfe3 | ||
|   | b16c3798a4 | ||
|   | 4b33c42da7 | ||
|   | 961b3177d5 | ||
|   | 7dc85a624e | ||
|   | bfd215542b | ||
|   | d752275730 | ||
|   | be7e389bb5 | ||
|   | f96c60c1a0 | ||
|   | 99234632b2 | ||
|   | 3a7393e1dd | ||
|   | 2d12f8b49e | ||
|   | 3461f0ffc9 | ||
|   | f24f7f14c3 | ||
|   | 917e57d475 | ||
|   | 6b43c5c18c | ||
|   | 7cd7059fbc | ||
|   | 591a5c277c | ||
|   | 164959a0c5 | ||
|   | 47fa7bb22a | ||
|   | 5b250c15f8 | ||
|   | b60f9fbc00 | ||
|   | 8accb78fa9 | ||
|   | 3d7c3c39ff | ||
|   | dd628006ec | ||
|   | 6cec662ec4 | ||
|   | 588b838deb | ||
|   | 05203e2cf0 | ||
|   | 80f8c2de78 | ||
|   | d011aeefc5 | ||
|   | 44627c3b5f | ||
|   | 925a61e4d7 | ||
|   | d8b17daf9d | ||
|   | 5e40930f11 | ||
|   | b6c9ab0c15 | ||
|   | 1a8f41010e | ||
|   | 67f58b5217 | ||
|   | cdef5cd1ad | ||
|   | 2efae80b97 | ||
|   | 1157df1407 | ||
|   | 94ac0a7797 | ||
|   | 35cf05d6ca | ||
|   | 18e1efc7ec | ||
|   | 71ebb068f7 | ||
|   | e9170e630c | ||
|   | 6ae642245e | ||
|   | a34d8549d0 | ||
|   | 52e1df2df3 | ||
|   | d7a5efbd36 | ||
|   | 9f5123d176 | ||
|   | ea7d4d323e | ||
|   | 18da55bd81 | ||
|   | 25424fe62e | ||
|   | c7e60cfd0c | ||
|   | 3e19bcb6cb | ||
|   | 6573c3b522 | ||
|   | 17fff8c665 | ||
|   | fa9f0d9ff9 | ||
|   | 77ccf3b929 | ||
|   | 4b205aee91 | ||
|   | d348e211d4 | ||
|   | 42539575a6 | ||
|   | 8bce241170 | ||
|   | c039665a97 | ||
|   | 92977f303d | ||
|   | 0038f3b244 | ||
|   | 2f1fb9fe2d | ||
|   | 8c6d5408eb | ||
|   | 3f6a55aabd | ||
|   | f37c25d00e | ||
|   | 23821d6fad | ||
|   | c384c4ca6c | ||
|   | 946ba2a8ae | ||
|   | 55b673cc6f | ||
|   | 8043409d38 | ||
|   | 6d145bc4cb | ||
|   | 26b2a4de36 | ||
|   | 99b7f4d26e | ||
|   | f413339e75 | ||
|   | 8a5567796f | ||
|   | 112c68cd0c | ||
|   | 4e5e542fb0 | ||
|   | 7bfc41c6e1 | ||
|   | fec3c70886 | ||
|   | ccf063709e | ||
|   | 9cab2cd940 | ||
|   | 37dc1c9a82 | ||
|   | 3286c93c8f | ||
|   | b918b6383b | ||
|   | 9d8ffe9911 | ||
|   | 24fa788609 | ||
|   | 1edb8cf0e9 | ||
|   | 25da4a6a79 | ||
|   | e1e5283963 | ||
|   | bc074abeba | ||
|   | 70a8dd30e0 | ||
|   | d61a74fb88 | ||
|   | dfa341e1c0 | ||
|   | e825d3be83 | ||
|   | b5c8dc0fe3 | ||
|   | ebb2fe068c | ||
|   | 246693b848 | ||
|   | ec75600e1c | ||
|   | ec7242576e | ||
|   | 83a53c1008 | ||
|   | 878b154604 | ||
|   | 03101f001c | ||
|   | a5bbb6732d | ||
|   | 11349561d6 | ||
|   | 8bb6ed625b | ||
|   | 046c263f13 | ||
|   | 1043020f27 | ||
|   | 17f2e39084 | ||
|   | 4d9e3b9012 | ||
|   | 135ff280b9 | ||
|   | 631091940b | ||
|   | 53d257ef0f | ||
|   | 9e012dbc1a | ||
|   | 7da5eead8a | ||
|   | f984f56459 | ||
|   | 203799871c | ||
|   | ad826bf088 | ||
|   | e81c466d74 | ||
|   | e04d866b20 | ||
|   | d7a042b95d | ||
|   | 5c51185388 | ||
|   | 926266c7af | ||
|   | 1bcf123dd5 | ||
|   | 7c26fbbb2e | ||
|   | 938fcb3e5e | ||
|   | 3553f3be4e | ||
|   | 8c4662e6e5 | ||
|   | e7610b2467 | ||
|   | 79e60afd42 | ||
|   | 3da93e7bf9 | ||
|   | 1700154f00 | ||
|   | 68571d8f57 | ||
|   | 61461b7f59 | ||
|   | c27c3817a9 | ||
|   | 08e1db45a9 | ||
|   | 27c373ddf4 | ||
|   | e62d7bc1ba | ||
|   | 0d680b060e | ||
|   | 0f054aed88 | ||
|   | b4308ecb91 | ||
|   | e68ff28649 | ||
|   | cb946772b4 | ||
|   | f169585a55 | ||
|   | e5fbc68e0e | ||
|   | f32cad2667 | ||
|   | 503f23ad3b | ||
|   | 481b46ac9e | ||
|   | 9c34ef7d74 | ||
|   | 18fbaee9df | ||
|   | 94b59e8b6f | ||
|   | e9c5cd543e | ||
|   | 5e1d17dff2 | ||
|   | 526838c77c | ||
|   | ef6b370d0e | ||
|   | 38896205c8 | ||
|   | 7221684337 | ||
|   | 99e936bf2b | ||
|   | 138fee9b52 | ||
|   | a19c1535e8 | ||
|   | 05ba1d0fd4 | ||
|   | c2b3436770 | ||
|   | a0fd3aef98 | ||
|   | b112341d91 | ||
|   | 0dba5607a8 | ||
|   | 7378c4a9d8 | ||
|   | 89e7ef36dc | ||
|   | 39ed02bc53 | ||
|   | 449dc17df8 | ||
|   | 5cb3d86a1b | ||
|   | a3687dd653 | ||
|   | fbc5b8ceb7 | ||
|   | 4c545fbba5 | ||
|   | 7fda726bbe | ||
|   | e404e5e2de | ||
|   | 930127348a | ||
|   | 3db37e1d52 | ||
|   | b9c4a582ac | ||
|   | a085d9fbd7 | ||
|   | 7f2356ba4b | ||
|   | 7a7f668879 | ||
|   | 69a05aa5de | ||
|   | c0c64a2d5d | ||
|   | 3c3b4eb2af | ||
|   | 1019e0bcfd | ||
|   | faf2c007aa | ||
|   | 43678ac801 | ||
|   | f22d5aa46d | ||
|   | d599c1e740 | ||
|   | 0cc4519fc0 | ||
|   | 0265c85ba3 | ||
|   | 7ec0670748 | ||
|   | d06517265f | ||
|   | a88e486468 | ||
|   | c22ff4c556 | ||
|   | d4c4e30fe4 | ||
|   | 1ec3338d2e | ||
|   | bffcfd92da | ||
|   | f44517f4af | ||
|   | 5087a5af21 | ||
|   | 3a6331693a | ||
|   | 56a28923ca | ||
|   | fb8ed718ce | ||
|   | 45e5d89353 | ||
|   | d3fe02fb3e | ||
|   | 7d2126e2b2 | ||
|   | 1f4ae2f63a | ||
|   | b378066ebf | ||
|   | 2210d1053a | ||
|   | bb6cd258f3 | ||
|   | b5adb02eb8 | ||
|   | 8b702bcfa0 | ||
|   | 3e11011229 | ||
|   | e5ba475147 | ||
|   | 3cd537ecf2 | ||
|   | d7c7bc5d8e | ||
|   | 9191b9e736 | ||
|   | ce340aba7a | ||
|   | 62cc14c93b | ||
|   | a284e8c5eb | ||
|   | 834c6df9eb | ||
|   | c74fe3c6e2 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | ca542f8677 | ||
|   | d6e23b803b | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 8b327fbc82 | ||
|   | 8432c2c9ea | ||
|   | 94fd5485b6 | ||
|   | cd4680b422 | ||
|   | 7e4a800352 | ||
|   | 00bc097abb | ||
|   | 5c3a56b283 | ||
|   | 48ea805999 | ||
|   | 6b753b05d6 | ||
|   | 52d577c7dd | ||
|   | cf757ed01e | ||
|   | 82dd88821c | ||
|   | 0e3e90f94f | ||
|   | 7c3086e9d9 | ||
|   | 202e943d55 | ||
|   | 36bcaaff55 | ||
|   | 967fae142b | ||
|   | 8f41dfec2e | ||
|   | 1f0abef084 | ||
|   | 0e6fbdfa5b | ||
|   | e881e1bfb3 | ||
|   | 9e6cdd6106 | ||
|   | d1efe1d208 | ||
|   | 2f2a8e537d | ||
|   | 82de8b7c50 | ||
|   | fb194b855b | ||
|   | a4a9b8707d | ||
|   | c4c20bee7c | ||
|   | 41b491fa7c | ||
|   | 667d58bad4 | ||
|   | 630464f38d | ||
|   | 8050352ad8 | ||
|   | b6d0d4eb99 | ||
|   | 70b129cc42 | ||
|   | c52b504140 | ||
|   | e987a50e9f | ||
|   | d7e7848c92 | ||
|   | 9bb6dc52b8 | ||
|   | 73df95c42d | ||
|   | f27e4033a6 | ||
|   | e523e54881 | ||
|   | 606e5c0878 | ||
|   | 4b13431a19 | ||
|   | 87c8f9ff95 | ||
|   | 5e61c60f85 | ||
|   | fbc9d5ecba | ||
|   | d381d31e5e | ||
|   | 65e7204ec9 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 0b5e3a93a5 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 23d743bcae | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 3e1596d5fb | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 8a04fc3336 | ||
|   | bffdfea58a | ||
|   | 449ea4b669 | ||
|   | e632806349 | ||
|   | 9cc8b3656a | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | a3fff800d2 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 48d767918f | ||
|   | 4f249159d3 | ||
|   | 0d19c2d42e | ||
|   | e53a40658d | ||
|   | 0389e2c891 | ||
|   | 8aa089178a | ||
|   | d3c8368b0c | ||
|   | ca4f026533 | ||
|   | 7d02b36092 | ||
|   | 9e634360fa | ||
|   | 9cf811b048 | ||
|   | b0d38446d7 | ||
|   | dfe10ac61f | ||
|   | f41c851108 | ||
|   | 522dbb1e13 | ||
|   | bc4315da1e | ||
|   | 1a841b101e | ||
|   | cbcf3b7599 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 4c4b3b8a8a | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | c562d09479 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | ee7bef3395 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 80fa5c2e36 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 7212027937 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 16b5e121cd | ||
|   | a87930542a | ||
|   | e9ba81149d | ||
|   | 7ea207df5d | ||
|   | aaa40e34c3 | ||
|   | 9b010074e1 | ||
|   | 0359db23d9 | ||
|   | 320f5fedfb | ||
|   | 3e2d2e5f6b | ||
|   | b8d9dd15ac | ||
|   | 936fcfb1c7 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | fb60ffd319 | ||
| ![dependabot-preview[bot]](/assets/img/avatar_default.png)  | 8c9f8de6d2 | 
| @@ -1,3 +0,0 @@ | |||||||
| .[] |  | ||||||
| .head |  | ||||||
| .label |  | ||||||
| @@ -1,2 +0,0 @@ | |||||||
| .links |  | ||||||
| .next |  | ||||||
| @@ -1,39 +0,0 @@ | |||||||
| ( |  | ||||||
|   .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 |  | ||||||
| @@ -1,87 +0,0 @@ | |||||||
| #!/usr/bin/env bash |  | ||||||
| # __MISSKEY_BEARER_TOKEN= |  | ||||||
| # __MISSKEY_CAMPAIGN_ID= |  | ||||||
| # __MISSKEY_GITHUB_TOKEN= |  | ||||||
| # __MISSKEY_HEAD=syuilo: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 -f check_pr.jq | grep $__MISSKEY_HEAD)" && exit 1 |  | ||||||
| cd "$(dirname $0)/.." && \ |  | ||||||
| touch null.cache && \ |  | ||||||
| rm *.cache && \ |  | ||||||
| git checkout $__MISSKEY_BRANCH && \ |  | ||||||
| git pull origin $__MISSKEY_BRANCH && \ |  | ||||||
| git pull upstream $__MISSKEY_BRANCH && \ |  | ||||||
| git stash && \ |  | ||||||
| git rebase -f upstream/$__MISSKEY_BRANCH && \ |  | ||||||
| git branch patch-autogen && \ |  | ||||||
| git checkout patch-autogen && \ |  | ||||||
| git reset --hard HEAD || \ |  | ||||||
| exit 1 |  | ||||||
| touch patreon.md.cache && \ |  | ||||||
| rm patreon.md.cache && \ |  | ||||||
| echo '<!-- PATREON_START -->' > patreon.md.cache && \ |  | ||||||
| url="https://www.patreon.com/api/oauth2/v2/campaigns/$__MISSKEY_CAMPAIGN_ID/members?include=currently_entitled_tiers,user&fields%5Btier%5D=title&fields%5Buser%5D=full_name,thumb_url,url,hide_pledges" |  | ||||||
| while : |  | ||||||
|  do |  | ||||||
|   touch patreon.raw.cache && \ |  | ||||||
|   rm patreon.raw.cache && \ |  | ||||||
|   curl -LSs -w '\n' -H "Authorization: Bearer $__MISSKEY_BEARER_TOKEN" -- $url > patreon.raw.cache && \ |  | ||||||
|   touch patreon.cache && \ |  | ||||||
|   rm patreon.cache && \ |  | ||||||
|   cat patreon.raw.cache | \ |  | ||||||
|   jq -r -f patreon.jq >> patreon.cache && \ |  | ||||||
|   echo '<table><tr>' >> patreon.md.cache && \ |  | ||||||
|   cat patreon.cache | \ |  | ||||||
|   awk -F'\t' '{print $2,$1}' | \ |  | ||||||
|   sed -e 's/ /\\" alt=\\"/' | \ |  | ||||||
|   xargs -I% echo '<td><img src="%" width="100"></td>' >> patreon.md.cache && \ |  | ||||||
|   echo '</tr><tr>' >> patreon.md.cache && \ |  | ||||||
|   cat patreon.cache | \ |  | ||||||
|   awk -F'\t' '{print $3,$1}' | \ |  | ||||||
|   sed -e 's/ /\\">/' | \ |  | ||||||
|   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 -f next_url.jq)" |  | ||||||
|   test "$new_url" = 'null' && \ |  | ||||||
|   break || \ |  | ||||||
|   URL="$url" |  | ||||||
| done |  | ||||||
| ignore= && \ |  | ||||||
| echo -e "\n**Last updated:** $(date -uR | sed 's/\+0000/UTC/')\n<!-- PATREON_END -->" >> patreon.md.cache && \ |  | ||||||
| touch README.md && \ |  | ||||||
| touch .autogen/README.md && \ |  | ||||||
| rm .autogen/README.md && \ |  | ||||||
| mv README.md .autogen/README.md && \ |  | ||||||
| cat .autogen/README.md | while IFS= read line; |  | ||||||
|  do |  | ||||||
|   if [[ -z "$ignore" ]] |  | ||||||
|    then |  | ||||||
|     if [[ "$line" = '<!-- PATREON_START -->' ]] |  | ||||||
|      then |  | ||||||
|       ignore='PATREON_INSIDE' |  | ||||||
|      else |  | ||||||
|       echo "$line" >> README.md |  | ||||||
|     fi |  | ||||||
|    else |  | ||||||
|     if [[ "$LINE" = '<!-- PATREON_END -->' ]] |  | ||||||
|      then |  | ||||||
|       ignore= |  | ||||||
|       cat patreon.md.cache >> README.md |  | ||||||
|     fi |  | ||||||
|   fi |  | ||||||
| done |  | ||||||
| cat patreon.md.cache |  | ||||||
| touch null.cache && \ |  | ||||||
| rm *.cache && \ |  | ||||||
| diff .autogen/README.md README.md > diff.cache |  | ||||||
| cat diff.cache && \ |  | ||||||
| test 4 -lt $(cat diff.cache | wc -l) && \ |  | ||||||
| git add README.md && \ |  | ||||||
| git commit -m 'Update README.md [AUTOGEN]' && \ |  | ||||||
| git push -f origin patch-autogen && \ |  | ||||||
| curl -LSs -w '\n' -X POST -d '{"title":"[AUTOMATED] Update README.md","body":"*This pull request was created by a tool.*","head":"'$__MISSKEY_HEAD'","base":"'$__MISSKEY_BRANCH'"}' -- "https://api.github.com/repos/$__MISSKEY_REPO/pulls?access_token=$__MISSKEY_GITHUB_TOKEN" |  | ||||||
| git stash |  | ||||||
| git checkout $__MISSKEY_BRANCH |  | ||||||
| git branch -D patch-autogen |  | ||||||
							
								
								
									
										20
									
								
								.eslintrc
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								.eslintrc
									
									
									
									
									
								
							| @@ -3,29 +3,11 @@ | |||||||
| 		"parser": "@typescript-eslint/parser" | 		"parser": "@typescript-eslint/parser" | ||||||
| 	}, | 	}, | ||||||
| 	"extends": [ | 	"extends": [ | ||||||
| 		"eslint:recommended", | 		"eslint:recommended" | ||||||
| 		"plugin:vue/recommended" |  | ||||||
| 	], | 	], | ||||||
| 	"rules": { | 	"rules": { | ||||||
| 		"vue/require-v-for-key": 0, |  | ||||||
| 		"vue/max-attributes-per-line": 0, |  | ||||||
| 		"vue/html-indent": 0, |  | ||||||
| 		"vue/html-self-closing": 0, |  | ||||||
| 		"vue/no-unused-vars": 0, |  | ||||||
| 		"vue/attributes-order": 0, |  | ||||||
| 		"vue/require-prop-types": 0, |  | ||||||
| 		"vue/require-default-prop": 0, |  | ||||||
| 		"vue/html-closing-bracket-spacing": 0, |  | ||||||
| 		"vue/singleline-html-element-content-newline": 0, |  | ||||||
| 		"vue/no-v-html": 0, |  | ||||||
| 		"no-console": 0, | 		"no-console": 0, | ||||||
| 		"no-unused-vars": 0, | 		"no-unused-vars": 0, | ||||||
| 		"no-empty": 0 | 		"no-empty": 0 | ||||||
| 	}, |  | ||||||
| 	"globals": { |  | ||||||
| 		"ENV": true, |  | ||||||
| 		"VERSION": true, |  | ||||||
| 		"API": true, |  | ||||||
| 		"LANGS": true |  | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										5
									
								
								.github/ISSUE_TEMPLATE/01_bug-report.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								.github/ISSUE_TEMPLATE/01_bug-report.md
									
									
									
									
										vendored
									
									
								
							| @@ -7,6 +7,11 @@ assignees: '' | |||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
|  | <!-- | ||||||
|  | Thanks for reporting! | ||||||
|  | First, in order to avoid duplicate Issues, please search to see if the problem you found has already been reported. | ||||||
|  | --> | ||||||
|  |  | ||||||
| ## 💡 Summary | ## 💡 Summary | ||||||
|  |  | ||||||
| <!-- Tell us what the bug is --> | <!-- Tell us what the bug is --> | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								.github/workflows/nodejs.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/nodejs.yml
									
									
									
									
										vendored
									
									
								
							| @@ -12,7 +12,7 @@ jobs: | |||||||
|  |  | ||||||
|     strategy: |     strategy: | ||||||
|       matrix: |       matrix: | ||||||
|         node-version: [12.x, 14.x, 15.x] |         node-version: [14.x, 16.x] | ||||||
|  |  | ||||||
|     services: |     services: | ||||||
|       postgres: |       postgres: | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
| 	"extension": ["ts","js","cjs","mjs"], | 	"extension": ["ts","js","cjs","mjs"], | ||||||
| 	"require": "ts-node/register", | 	"require": ["ts-node/register", "tsconfig-paths/register"], | ||||||
| 	"slow": 1000, | 	"slow": 1000, | ||||||
| 	"timeout": 30000, | 	"timeout": 30000, | ||||||
| 	"exit": true | 	"exit": true | ||||||
|   | |||||||
| @@ -1 +1 @@ | |||||||
| v14.15.5 | v16.2.0 | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								CHANGELOG.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								CHANGELOG.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | see [releases](https://github.com/misskey-dev/misskey/releases) | ||||||
| @@ -8,7 +8,7 @@ | |||||||
|   - 温度感高めで見てほしいものは責付いてください。 |   - 温度感高めで見てほしいものは責付いてください。 | ||||||
|  |  | ||||||
| ## Issues | ## Issues | ||||||
| Feature suggestions and bug reports are filed in https://github.com/syuilo/misskey/issues . | Feature suggestions and bug reports are filed in https://github.com/misskey-dev/misskey/issues . | ||||||
|  |  | ||||||
| * Please search existing issues to avoid duplication. If your issue is already filed, please add your reaction or comment to the existing one. | * Please search existing issues to avoid duplication. If your issue is already filed, please add your reaction or comment to the existing one. | ||||||
| * If you have multiple independent issues, please submit them separately. | * If you have multiple independent issues, please submit them separately. | ||||||
| @@ -50,7 +50,7 @@ Configuration files are located in [`/.circleci`](/.circleci). | |||||||
| * Your PR should include all source files (e.g. `.png`, `.blend`) of your models (for later editing). | * Your PR should include all source files (e.g. `.png`, `.blend`) of your models (for later editing). | ||||||
| * Your PR must include the glTF binary files (`.glb`) of your models. | * Your PR must include the glTF binary files (`.glb`) of your models. | ||||||
| * Add a locale key `room.furnitures.YOUR_ITEM` at [`/locales/ja-JP.yml`](/locales/ja-JP.yml). | * Add a locale key `room.furnitures.YOUR_ITEM` at [`/locales/ja-JP.yml`](/locales/ja-JP.yml). | ||||||
| * Add a furniture definition at [`/src/client/app/common/scripts/room/furnitures.json5`](/src/client/app/common/scripts/room/furnitures.json5). | * Add a furniture definition at [`src/client/scripts/room/furnitures.json5`](src/client/scripts/room/furnitures.json5). | ||||||
|  |  | ||||||
| If you have no experience on 3D modeling, we suggest to use the free 3DCG software [Blender](https://www.blender.org/). | If you have no experience on 3D modeling, we suggest to use the free 3DCG software [Blender](https://www.blender.org/). | ||||||
| You can find information on glTF 2.0 at [glTF 2.0 — Blender Manual]( https://docs.blender.org/manual/en/dev/addons/io_scene_gltf2.html). | You can find information on glTF 2.0 at [glTF 2.0 — Blender Manual]( https://docs.blender.org/manual/en/dev/addons/io_scene_gltf2.html). | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								COPYING
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								COPYING
									
									
									
									
									
								
							| @@ -6,10 +6,6 @@ And is distributed under The GNU Affero General Public License Version 3, you sh | |||||||
|  |  | ||||||
| Misskey includes several third-party Open-Source softwares. | Misskey includes several third-party Open-Source softwares. | ||||||
|  |  | ||||||
| Unicode emoji regular expressions by Twitter, Inc. |  | ||||||
| License: MIT |  | ||||||
| https://github.com/twitter/twemoji-parser/blob/master/LICENSE.md |  | ||||||
|  |  | ||||||
| Emoji keywords for Unicode 11 and below by Mu-An Chiou | Emoji keywords for Unicode 11 and below by Mu-An Chiou | ||||||
| License: MIT | License: MIT | ||||||
| https://github.com/muan/emojilib/blob/master/LICENSE | https://github.com/muan/emojilib/blob/master/LICENSE | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| FROM node:14.15.5-alpine3.13 AS base | FROM node:16.2.0-alpine3.13 AS base | ||||||
|  |  | ||||||
| ENV NODE_ENV=production | ENV NODE_ENV=production | ||||||
|  |  | ||||||
| @@ -22,7 +22,7 @@ RUN apk add --no-cache \ | |||||||
|     vips-dev \ |     vips-dev \ | ||||||
|     vips |     vips | ||||||
|  |  | ||||||
| COPY package.json yarn.lock ./ | COPY package.json yarn.lock .yarnrc ./ | ||||||
| RUN yarn install | RUN yarn install | ||||||
| COPY . ./ | COPY . ./ | ||||||
| RUN yarn build | RUN yarn build | ||||||
|   | |||||||
							
								
								
									
										16
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								README.md
									
									
									
									
									
								
							| @@ -4,8 +4,8 @@ | |||||||
|  |  | ||||||
| <div align="center"> | <div align="center"> | ||||||
|  |  | ||||||
| [](https://circleci.com/gh/syuilo/misskey) | [](https://circleci.com/gh/misskey-dev/misskey) | ||||||
| [](https://david-dm.org/syuilo/misskey) | [](https://david-dm.org/misskey-dev/misskey) | ||||||
| [](http://makeapullrequest.com) | [](http://makeapullrequest.com) | ||||||
| [](https://github.com/humanetech-community/awesome-humane-tech) | [](https://github.com/humanetech-community/awesome-humane-tech) | ||||||
|  |  | ||||||
| @@ -22,11 +22,16 @@ Why don't you take a short break from the hustle and bustle of the city, and div | |||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
|  | Do you have a question? Or are you experiencing trouble? | ||||||
|  | Visit [our forum](https://forum.misskey.io/)! | ||||||
|  |  | ||||||
|  | --- | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| :sparkles: Features | :sparkles: Features | ||||||
| ---------------------------------------------------------------- | ---------------------------------------------------------------- | ||||||
| <a href="https://xn--931a.moe/"><img src="https://github.com/syuilo/misskey/blob/develop/assets/ai-orig.png?raw=true" align="right" height="320px"/></a> | <a href="https://xn--931a.moe/"><img src="https://github.com/misskey-dev/misskey/blob/develop/assets/ai-orig.png?raw=true" align="right" height="320px"/></a> | ||||||
|  |  | ||||||
| <h3>Posting</h3> | <h3>Posting</h3> | ||||||
| <p> | <p> | ||||||
| @@ -94,6 +99,11 @@ Please see the [Contribution Guide](./CONTRIBUTING.md). | |||||||
|  |  | ||||||
| To receive updates of this repo, follow [@repo@misskey.io](https://misskey.io/@repo) on fediverse. | To receive updates of this repo, follow [@repo@misskey.io](https://misskey.io/@repo) on fediverse. | ||||||
|  |  | ||||||
|  | Related projects | ||||||
|  | ---------------------------------------------------------------- | ||||||
|  | - [misskey.js](https://github.com/misskey-dev/misskey.js) - Misskey SDK for JavaScript | ||||||
|  | - [mfm.js](https://github.com/misskey-dev/mfm.js) - MFM parser | ||||||
|  |  | ||||||
| :heart: Backers | :heart: Backers | ||||||
| ---------------------------------------------------------------- | ---------------------------------------------------------------- | ||||||
| <!-- PATREON_START --> | <!-- PATREON_START --> | ||||||
|   | |||||||
							
								
								
									
										9
									
								
								SECURITY.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								SECURITY.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | |||||||
|  | # Reporting Security Issues | ||||||
|  |  | ||||||
|  | If you discover a security issue in Misskey, please report it by sending an | ||||||
|  | email to [syuilotan@yahoo.co.jp](mailto:syuilotan@yahoo.co.jp). | ||||||
|  |  | ||||||
|  | This will allow us to assess the risk, and make a fix available before we add a | ||||||
|  | bug report to the GitHub repository. | ||||||
|  |  | ||||||
|  | Thanks for helping make Misskey safe for everyone. | ||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| Before Width: | Height: | Size: 35 KiB After Width: | Height: | Size: 38 KiB | 
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								assets/favicon.ico
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								assets/favicon.ico
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 88 KiB | 
| @@ -19,6 +19,6 @@ | |||||||
| 	</head> | 	</head> | ||||||
| 	<body> | 	<body> | ||||||
| 		<redoc spec-url="/api.json" expand-responses="200" expand-single-schema-field="true"></redoc> | 		<redoc spec-url="/api.json" expand-responses="200" expand-single-schema-field="true"></redoc> | ||||||
| 		<script src="https://cdn.jsdelivr.net/npm/redoc@next/bundles/redoc.standalone.js"> </script> | 		<script src="https://cdn.jsdelivr.net/npm/redoc@2.0.0-rc.50/bundles/redoc.standalone.js" integrity="sha256-WJbngBWN9vp6vkEuzeoSj5tE5saW9Hfj6/SinkzhL2s=" crossorigin="anonymous"></script> | ||||||
| 	</body> | 	</body> | ||||||
| </html> | </html> | ||||||
|   | |||||||
| @@ -12,13 +12,13 @@ This guide describes how to install and setup Misskey with Docker. | |||||||
| ---------------------------------------------------------------- | ---------------------------------------------------------------- | ||||||
| 1. Clone Misskey repository's master branch. | 1. Clone Misskey repository's master branch. | ||||||
|  |  | ||||||
| 	`git clone -b master git://github.com/syuilo/misskey.git` | 	`git clone -b master git://github.com/misskey-dev/misskey.git` | ||||||
|  |  | ||||||
| 2. Move to misskey directory. | 2. Move to misskey directory. | ||||||
|  |  | ||||||
| 	`cd misskey` | 	`cd misskey` | ||||||
|  |  | ||||||
| 3. Checkout to the [latest release](https://github.com/syuilo/misskey/releases/latest) tag. | 3. Checkout to the [latest release](https://github.com/misskey-dev/misskey/releases/latest) tag. | ||||||
|  |  | ||||||
| 	`git checkout master` | 	`git checkout master` | ||||||
|  |  | ||||||
|   | |||||||
| @@ -13,13 +13,13 @@ Ce guide explique comment installer et configurer Misskey avec Docker. | |||||||
| ---------------------------------------------------------------- | ---------------------------------------------------------------- | ||||||
| 1. Clone le dépôt de Misskey sur la branche master. | 1. Clone le dépôt de Misskey sur la branche master. | ||||||
|  |  | ||||||
| 	`git clone -b master git://github.com/syuilo/misskey.git` | 	`git clone -b master git://github.com/misskey-dev/misskey.git` | ||||||
|  |  | ||||||
| 2. Naviguez dans le dossier du dépôt. | 2. Naviguez dans le dossier du dépôt. | ||||||
|  |  | ||||||
| 	`cd misskey` | 	`cd misskey` | ||||||
|  |  | ||||||
| 3. Checkout sur le tag de la [dernière version](https://github.com/syuilo/misskey/releases/latest). | 3. Checkout sur le tag de la [dernière version](https://github.com/misskey-dev/misskey/releases/latest). | ||||||
|  |  | ||||||
| 	`git checkout master` | 	`git checkout master` | ||||||
|  |  | ||||||
|   | |||||||
| @@ -12,13 +12,13 @@ Dockerを使ったMisskey構築方法 | |||||||
| ---------------------------------------------------------------- | ---------------------------------------------------------------- | ||||||
| 1. masterブランチからMisskeyレポジトリをクローン | 1. masterブランチからMisskeyレポジトリをクローン | ||||||
|  |  | ||||||
| 	`git clone -b master git://github.com/syuilo/misskey.git` | 	`git clone -b master git://github.com/misskey-dev/misskey.git` | ||||||
|  |  | ||||||
| 2. misskeyディレクトリに移動 | 2. misskeyディレクトリに移動 | ||||||
|  |  | ||||||
| 	`cd misskey` | 	`cd misskey` | ||||||
|  |  | ||||||
| 3. [最新のリリース](https://github.com/syuilo/misskey/releases/latest)を確認 | 3. [最新のリリース](https://github.com/misskey-dev/misskey/releases/latest)を確認 | ||||||
|  |  | ||||||
| 	`git checkout master` | 	`git checkout master` | ||||||
|  |  | ||||||
|   | |||||||
| @@ -12,13 +12,13 @@ Docker 部署指南 | |||||||
| ---------------------------------------------------------------- | ---------------------------------------------------------------- | ||||||
| 1. 克隆 Misskey 项目的 master 分支。 | 1. 克隆 Misskey 项目的 master 分支。 | ||||||
|  |  | ||||||
| 	`git clone -b master git://github.com/syuilo/misskey.git` | 	`git clone -b master git://github.com/misskey-dev/misskey.git` | ||||||
|  |  | ||||||
| 2. 进入 misskey 文件夹。 | 2. 进入 misskey 文件夹。 | ||||||
|  |  | ||||||
| 	`cd misskey` | 	`cd misskey` | ||||||
|  |  | ||||||
| 3. 检查 [最新发布版](https://github.com/syuilo/misskey/releases/latest) 标签。 | 3. 检查 [最新发布版](https://github.com/misskey-dev/misskey/releases/latest) 标签。 | ||||||
|  |  | ||||||
| 	`git checkout master` | 	`git checkout master` | ||||||
|  |  | ||||||
|   | |||||||
| @@ -40,13 +40,13 @@ Please install and setup these softwares: | |||||||
|  |  | ||||||
| 2. Clone the misskey repo from master branch. | 2. Clone the misskey repo from master branch. | ||||||
|  |  | ||||||
| 	`git clone -b master git://github.com/syuilo/misskey.git` | 	`git clone -b master git://github.com/misskey-dev/misskey.git` | ||||||
|  |  | ||||||
| 3. Navigate to misskey directory | 3. Navigate to misskey directory | ||||||
|  |  | ||||||
| 	`cd misskey` | 	`cd misskey` | ||||||
|  |  | ||||||
| 4. Checkout to the [latest release](https://github.com/syuilo/misskey/releases/latest) | 4. Checkout to the [latest release](https://github.com/misskey-dev/misskey/releases/latest) | ||||||
|  |  | ||||||
| 	`git checkout master` | 	`git checkout master` | ||||||
|  |  | ||||||
|   | |||||||
| @@ -41,13 +41,13 @@ Installez les paquets suivants : | |||||||
|  |  | ||||||
| 2. Clonez la branche master du dépôt misskey. | 2. Clonez la branche master du dépôt misskey. | ||||||
|  |  | ||||||
| 	`git clone -b master git://github.com/syuilo/misskey.git` | 	`git clone -b master git://github.com/misskey-dev/misskey.git` | ||||||
|  |  | ||||||
| 3. Accédez au dossier misskey. | 3. Accédez au dossier misskey. | ||||||
|  |  | ||||||
| 	`cd misskey` | 	`cd misskey` | ||||||
|  |  | ||||||
| 4. Checkout sur le tag de la [version la plus récente](https://github.com/syuilo/misskey/releases/latest) | 4. Checkout sur le tag de la [version la plus récente](https://github.com/misskey-dev/misskey/releases/latest) | ||||||
|  |  | ||||||
| 	`git checkout master` | 	`git checkout master` | ||||||
|   |   | ||||||
|   | |||||||
| @@ -42,13 +42,13 @@ adduser --disabled-password --disabled-login misskey | |||||||
|  |  | ||||||
| 2. masterブランチからMisskeyレポジトリをクローン | 2. masterブランチからMisskeyレポジトリをクローン | ||||||
|  |  | ||||||
| 	`git clone -b master git://github.com/syuilo/misskey.git` | 	`git clone -b master git://github.com/misskey-dev/misskey.git` | ||||||
|  |  | ||||||
| 3. misskeyディレクトリに移動 | 3. misskeyディレクトリに移動 | ||||||
|  |  | ||||||
| 	`cd misskey` | 	`cd misskey` | ||||||
|  |  | ||||||
| 4. [最新のリリース](https://github.com/syuilo/misskey/releases/latest)を確認 | 4. [最新のリリース](https://github.com/misskey-dev/misskey/releases/latest)を確認 | ||||||
|  |  | ||||||
| 	`git checkout master` | 	`git checkout master` | ||||||
|  |  | ||||||
|   | |||||||
| @@ -40,13 +40,13 @@ adduser --disabled-password --disabled-login misskey | |||||||
|  |  | ||||||
| 2. 克隆 Misskey 项目的 master 分支。 | 2. 克隆 Misskey 项目的 master 分支。 | ||||||
|  |  | ||||||
| 	`git clone -b master git://github.com/syuilo/misskey.git` | 	`git clone -b master git://github.com/misskey-dev/misskey.git` | ||||||
|  |  | ||||||
| 3. 进入 misskey 文件夹。 | 3. 进入 misskey 文件夹。 | ||||||
|  |  | ||||||
| 	`cd misskey` | 	`cd misskey` | ||||||
|  |  | ||||||
| 4. 检查 [最新发布版](https://github.com/syuilo/misskey/releases/latest) 标签。 | 4. 检查 [最新发布版](https://github.com/misskey-dev/misskey/releases/latest) 标签。 | ||||||
|  |  | ||||||
| 	`git checkout master` | 	`git checkout master` | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										32
									
								
								gulpfile.ts
									
									
									
									
									
								
							
							
						
						
									
										32
									
								
								gulpfile.ts
									
									
									
									
									
								
							| @@ -4,25 +4,14 @@ | |||||||
|  |  | ||||||
| import * as fs from 'fs'; | import * as fs from 'fs'; | ||||||
| import * as gulp from 'gulp'; | import * as gulp from 'gulp'; | ||||||
| import * as ts from 'gulp-typescript'; | import rimraf from 'rimraf'; | ||||||
| import * as rimraf from 'rimraf'; | const replace = require('gulp-replace'); | ||||||
| import * as replace from 'gulp-replace'; |  | ||||||
| const terser = require('gulp-terser'); | const terser = require('gulp-terser'); | ||||||
| const cssnano = require('gulp-cssnano'); | const cssnano = require('gulp-cssnano'); | ||||||
|  |  | ||||||
| const locales: { [x: string]: any } = require('./locales'); | const locales: { [x: string]: any } = require('./locales'); | ||||||
| const meta = require('./package.json'); | const meta = require('./package.json'); | ||||||
|  |  | ||||||
| gulp.task('build:ts', () => { |  | ||||||
| 	const tsProject = ts.createProject('./tsconfig.json'); |  | ||||||
|  |  | ||||||
| 	return tsProject |  | ||||||
| 		.src() |  | ||||||
| 		.pipe(tsProject()) |  | ||||||
| 		.on('error', () => {}) |  | ||||||
| 		.pipe(gulp.dest('./built/')); |  | ||||||
| }); |  | ||||||
|  |  | ||||||
| gulp.task('build:copy:views', () => | gulp.task('build:copy:views', () => | ||||||
| 	gulp.src('./src/server/web/views/**/*').pipe(gulp.dest('./built/server/web/views')) | 	gulp.src('./src/server/web/views/**/*').pipe(gulp.dest('./built/server/web/views')) | ||||||
| ); | ); | ||||||
| @@ -64,7 +53,6 @@ gulp.task('build:client:style', () => { | |||||||
| gulp.task('build:copy', gulp.parallel('build:copy:locales', 'build:copy:views', 'build:client:script', 'build:client:style', 'build:copy:fonts', () => | gulp.task('build:copy', gulp.parallel('build:copy:locales', 'build:copy:views', 'build:client:script', 'build:client:style', 'build:copy:fonts', () => | ||||||
| 	gulp.src([ | 	gulp.src([ | ||||||
| 		'./src/emojilist.json', | 		'./src/emojilist.json', | ||||||
| 		'./src/server/web/views/**/*', |  | ||||||
| 		'./src/**/assets/**/*', | 		'./src/**/assets/**/*', | ||||||
| 		'!./src/client/assets/**/*' | 		'!./src/client/assets/**/*' | ||||||
| 	]).pipe(gulp.dest('./built/')) | 	]).pipe(gulp.dest('./built/')) | ||||||
| @@ -78,17 +66,15 @@ gulp.task('cleanall', gulp.parallel('clean', cb => | |||||||
| 	rimraf('./node_modules', cb) | 	rimraf('./node_modules', cb) | ||||||
| )); | )); | ||||||
|  |  | ||||||
| gulp.task('copy:docs', () => |  | ||||||
| 		gulp.src([ |  | ||||||
| 			'./src/docs/**/*', |  | ||||||
| 		]) |  | ||||||
| 		.pipe(gulp.dest('./built/assets/docs/')) |  | ||||||
| ); |  | ||||||
|  |  | ||||||
| gulp.task('build', gulp.parallel( | gulp.task('build', gulp.parallel( | ||||||
| 	'build:ts', |  | ||||||
| 	'build:copy', | 	'build:copy', | ||||||
| 	'copy:docs', |  | ||||||
| )); | )); | ||||||
|  |  | ||||||
| gulp.task('default', gulp.task('build')); | gulp.task('default', gulp.task('build')); | ||||||
|  |  | ||||||
|  | gulp.task('watch', () => { | ||||||
|  | 	gulp.watch([ | ||||||
|  | 		'./src/**/*', | ||||||
|  | 		'!./src/client/**/*' | ||||||
|  | 	], { ignoreInitial: false }, gulp.task('build')); | ||||||
|  | }); | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| # **DO NOT edit locale files** except `ja-JP.yml`. | # **DO NOT edit locale files** except `ja-JP.yml`. | ||||||
|  |  | ||||||
| When you add text to the ja-JP file (of syuilo/misskey), it will automatically be applied to other language files. | When you add text to the ja-JP file (of misskey-dev/misskey), it will automatically be applied to other language files. | ||||||
| Translations added in ja-JP file should contain the original Japanese strings. | Translations added in ja-JP file should contain the original Japanese strings. | ||||||
|  |  | ||||||
| Please see [Contribution guide](../CONTRIBUTING.md) for more information. | Please see [Contribution guide](../CONTRIBUTING.md) for more information. | ||||||
|   | |||||||
| @@ -111,7 +111,6 @@ customEmojis: "إيموجي مخصص" | |||||||
| addEmoji: "إضافة إيموجي" | addEmoji: "إضافة إيموجي" | ||||||
| cacheRemoteFiles: "خزن مؤقتا الملفات البعيدة" | cacheRemoteFiles: "خزن مؤقتا الملفات البعيدة" | ||||||
| autoAcceptFollowed: "اقبل طلبات المتابعة تلقائيا من الحسابات المتابَعة" | autoAcceptFollowed: "اقبل طلبات المتابعة تلقائيا من الحسابات المتابَعة" | ||||||
| addAcount: "إضافة حساب" |  | ||||||
| loginFailed: "فشل الولوج" | loginFailed: "فشل الولوج" | ||||||
| showOnRemote: "رؤيته على مثيل الخادم البُعدي" | showOnRemote: "رؤيته على مثيل الخادم البُعدي" | ||||||
| general: "الرئيسية" | general: "الرئيسية" | ||||||
| @@ -260,8 +259,6 @@ monthX: "{month}" | |||||||
| yearX: "{year}" | yearX: "{year}" | ||||||
| pages: "الصفحات" | pages: "الصفحات" | ||||||
| integration: "دمج" | integration: "دمج" | ||||||
| connectSerice: "أوصل" |  | ||||||
| disconnectSerice: "قطع الاتصال" |  | ||||||
| enableLocalTimeline: "تفعيل الخيط المحلي" | enableLocalTimeline: "تفعيل الخيط المحلي" | ||||||
| enableGlobalTimeline: "تفعيل الخيط الزمني الشامل" | enableGlobalTimeline: "تفعيل الخيط الزمني الشامل" | ||||||
| disablingTimelinesInfo: "سيتمكن المسؤولون ومن تعديل دائمًا و من الوصول إلى جميع المخططات الزمنية ، حتى إذا لم يتم تمكينها." | disablingTimelinesInfo: "سيتمكن المسؤولون ومن تعديل دائمًا و من الوصول إلى جميع المخططات الزمنية ، حتى إذا لم يتم تمكينها." | ||||||
| @@ -354,7 +351,6 @@ category: "الفئات" | |||||||
| tags: "الوسوم" | tags: "الوسوم" | ||||||
| docSource: "مصدر هذا المستند" | docSource: "مصدر هذا المستند" | ||||||
| createAccount: "أنشئ حسابًا" | createAccount: "أنشئ حسابًا" | ||||||
| existingAcount: "الحسابات الموجودة" |  | ||||||
| regenerate: "أعِد التوليد" | regenerate: "أعِد التوليد" | ||||||
| fontSize: "حجم الخط" | fontSize: "حجم الخط" | ||||||
| openImageInNewTab: "إفتح الصورة بصفحة جديدة" | openImageInNewTab: "إفتح الصورة بصفحة جديدة" | ||||||
| @@ -429,6 +425,11 @@ latestVersion: "آخر نسخة مستقرة" | |||||||
| usageAmount: "الإستخدام" | usageAmount: "الإستخدام" | ||||||
| capacity: "السعة" | capacity: "السعة" | ||||||
| inUse: "مستخدم" | inUse: "مستخدم" | ||||||
|  | info: "عن" | ||||||
|  | user: "المستخدمون" | ||||||
|  | administration: "إدارة " | ||||||
|  | expiration: "ينتهي استطلاع الرأي في" | ||||||
|  | middle: "متوسط" | ||||||
| _email: | _email: | ||||||
|   _follow: |   _follow: | ||||||
|     title: "يتابعك" |     title: "يتابعك" | ||||||
|   | |||||||
| @@ -1,2 +1,482 @@ | |||||||
| --- | --- | ||||||
| _lang_: "Čeština" | _lang_: "Čeština" | ||||||
|  | headlineMisskey: "Síť propojená poznámkami" | ||||||
|  | introMisskey: "Vítejte! Misskey je otevřený a decentralizovaný microblogový servis.\n\"Poznámkami\" můžete sdílet co se zrovna děje se všemi ve Vašem okolí. 📡\nPomocí \"reakcí\" můžete sdílet své názory a pocity na ostatní poznámky. 👍\nPojďte objevovat nový svět! 🚀" | ||||||
|  | monthAndDay: "{day}. {month}." | ||||||
|  | search: "Vyhledávání" | ||||||
|  | notifications: "Oznámení" | ||||||
|  | username: "Uživatelské jméno" | ||||||
|  | password: "Heslo" | ||||||
|  | forgotPassword: "Zapomenuté heslo" | ||||||
|  | fetchingAsApObject: "Načítám data z Fediversu..." | ||||||
|  | ok: "Potvrdit" | ||||||
|  | gotIt: "Rozumím!" | ||||||
|  | cancel: "Zrušit" | ||||||
|  | enterUsername: "Zadej uživatelské jméno" | ||||||
|  | renotedBy: "{user} přeposla/a" | ||||||
|  | noNotes: "Žádné poznámky" | ||||||
|  | noNotifications: "Žádná oznámení" | ||||||
|  | instance: "Instance" | ||||||
|  | settings: "Nastavení" | ||||||
|  | basicSettings: "Obecná nastavení" | ||||||
|  | otherSettings: "Rozšířená nastavení" | ||||||
|  | openInWindow: "Otevřít v novém okně" | ||||||
|  | profile: "Váš profil" | ||||||
|  | timeline: "Časová osa" | ||||||
|  | noAccountDescription: "Tento uživatel zatím nenapsal svou biografii." | ||||||
|  | login: "Přihlásit se" | ||||||
|  | loggingIn: "Probíhá přihlašování" | ||||||
|  | logout: "Odhlásit" | ||||||
|  | signup: "Registrace" | ||||||
|  | uploading: "Nahrávám" | ||||||
|  | save: "Uložit" | ||||||
|  | users: "Uživatelé" | ||||||
|  | addUser: "Přidat uživatele" | ||||||
|  | favorite: "Oblíbené" | ||||||
|  | favorites: "Oblíbené" | ||||||
|  | unfavorite: "Odebrat z oblízených" | ||||||
|  | favorited: "Přidáno do oblíbených" | ||||||
|  | alreadyFavorited: "Už je mezi oblíbenými" | ||||||
|  | cantFavorite: "Nepodařilo se přidat mezi oblíbené." | ||||||
|  | pin: "Připnout" | ||||||
|  | unpin: "Odepnout" | ||||||
|  | copyContent: "Zkopírovat obsah" | ||||||
|  | copyLink: "Kopírovat odkaz" | ||||||
|  | delete: "Smazat" | ||||||
|  | deleteAndEdit: "Smazat a upravit" | ||||||
|  | deleteAndEditConfirm: "Jste si jistí že chcete smazat tuto poznámku a editovat ji? Ztratíte tím všechny reakce, sdílení a odpovědi na ni." | ||||||
|  | addToList: "Přidat do seznamu" | ||||||
|  | sendMessage: "Odeslat zprávu" | ||||||
|  | copyUsername: "Kopírovat uživatelské jméno" | ||||||
|  | searchUser: "Vyhledat uživatele" | ||||||
|  | reply: "Odpovědět" | ||||||
|  | loadMore: "Zobrazit více" | ||||||
|  | showMore: "Zobrazit více" | ||||||
|  | mention: "Zmínění" | ||||||
|  | mentions: "Zmínění" | ||||||
|  | importAndExport: "Import a export" | ||||||
|  | import: "Importovat" | ||||||
|  | export: "Exportovat" | ||||||
|  | files: "Soubor(ů)" | ||||||
|  | download: "Stáhnout" | ||||||
|  | unfollowConfirm: "Jste si jisti že už nechcete sledovat {name}?" | ||||||
|  | importRequested: "Požádali jste o export. To může chvilku trvat." | ||||||
|  | lists: "Seznamy" | ||||||
|  | noLists: "Nemáte žádné seznamy" | ||||||
|  | note: "Poznámka" | ||||||
|  | notes: "Poznámky" | ||||||
|  | following: "Sledovaní" | ||||||
|  | followers: "Sledující" | ||||||
|  | followsYou: "Sledují vás" | ||||||
|  | createList: "Vytvořit seznam" | ||||||
|  | manageLists: "Spravovat seznam" | ||||||
|  | error: "Chyba" | ||||||
|  | somethingHappened: "Jejda. Něco se nepovedlo." | ||||||
|  | retry: "Opakovat" | ||||||
|  | pageLoadError: "Nepodařilo se načíst stránku" | ||||||
|  | enterListName: "Jméno seznamu" | ||||||
|  | privacy: "Soukromí" | ||||||
|  | follow: "Sledovaní" | ||||||
|  | unfollow: "Přestat sledovat" | ||||||
|  | renote: "Přeposlat" | ||||||
|  | cantReRenote: "Odpověď nemůže být odstraněna." | ||||||
|  | quote: "Citovat" | ||||||
|  | pinned: "Připnout" | ||||||
|  | you: "Vy" | ||||||
|  | clickToShow: "Klikněte pro zobrazení" | ||||||
|  | sensitive: "NSFW" | ||||||
|  | add: "Přidat" | ||||||
|  | reaction: "Reakce" | ||||||
|  | reactionSettingDescription: "Vyberte Vaší oblíbenou reakci, kterou chcete připnout ve výběru." | ||||||
|  | reactionSettingDescription2: "Přetažením změníte pořadí, kliknutím smažete, zmáčkněte \"+\" k přidání" | ||||||
|  | rememberNoteVisibility: "Zapamatovat nastavení zobrazení poznámky" | ||||||
|  | attachCancel: "Odstranit přílohu" | ||||||
|  | markAsSensitive: "Označit jako NSFW" | ||||||
|  | unmarkAsSensitive: "Odznačit jako NSFW" | ||||||
|  | enterFileName: "Zadejte název souboru" | ||||||
|  | mute: "Ztlumit" | ||||||
|  | unmute: "Odmlčet" | ||||||
|  | block: "Zablokovat" | ||||||
|  | unblock: "Odblokovat" | ||||||
|  | suspend: "Zmrazit" | ||||||
|  | unsuspend: "Odmrazit" | ||||||
|  | blockConfirm: "Jste si jistí že chcete zablokovat tento účet?" | ||||||
|  | unblockConfirm: "Jste si jistí že chcete odblokovat tento účet?" | ||||||
|  | suspendConfirm: "Jste si jistí že chcete suspendovat tenhle účet?" | ||||||
|  | unsuspendConfirm: "Jste si jistí že chcete obnovit tenhle účet?" | ||||||
|  | selectList: "Vybrat seznam" | ||||||
|  | selectAntenna: "Vyberte Anténu" | ||||||
|  | selectWidget: "Zvolte widget" | ||||||
|  | editWidgets: "Upravit widget" | ||||||
|  | editWidgetsExit: "Hotovo" | ||||||
|  | customEmojis: "Vlastní emoji" | ||||||
|  | emoji: "Emoji" | ||||||
|  | emojiName: "Jméno emoji" | ||||||
|  | emojiUrl: "URL obrázku" | ||||||
|  | addEmoji: "Přidat emoji" | ||||||
|  | settingGuide: "Doporučené nastavení" | ||||||
|  | cacheRemoteFiles: "Ukládání vzdálených souborů do mezipaměti" | ||||||
|  | cacheRemoteFilesDescription: "Zakázání tohoto nastavení způsobí, že vzdálené soubory budou odkazovány přímo, místo aby byly ukládány do mezipaměti. Tím se ušetří úložiště na serveru, ale zvýší se provoz, protože se negenerují miniatury." | ||||||
|  | flagAsBot: "Tento účet je bot" | ||||||
|  | flagAsBotDescription: "Pokud je tento účet kontrolován programem zaškrtněte tuto možnost. To označí tento účet jako bot pro ostatní vývojáře a zabrání tak nekonečným interakcím s ostatními boty a upraví Misskey systém aby se choval k tomuhle účtu jako bot." | ||||||
|  | flagAsCat: "Tenhle účet je kočka" | ||||||
|  | flagAsCatDescription: "Vyberte tuto možnost aby tento účet byl označen jako kočka." | ||||||
|  | autoAcceptFollowed: "Automaticky akceptovat následování od účtů které sledujete" | ||||||
|  | addAccount: "Přidat účet" | ||||||
|  | loginFailed: "Přihlášení se nezdařilo." | ||||||
|  | showOnRemote: "Více na původním profilu" | ||||||
|  | general: "Obecně" | ||||||
|  | wallpaper: "Obrázek na pozadí" | ||||||
|  | setWallpaper: "Nastavení obrázku na pozadí" | ||||||
|  | removeWallpaper: "Odstranit pozadí" | ||||||
|  | youHaveNoLists: "Nemáte žádné seznamy" | ||||||
|  | proxyAccount: "Proxy účet" | ||||||
|  | proxyAccountDescription: "Proxy účet je účet, který za určitých podmínek sleduje uživatele na dálku vaším jménem. Například když uživatel zařadí vzdáleného uživatele do seznamu, pokud nikdo nesleduje uživatele na seznamu, aktivita nebude doručena instanci, takže místo toho bude uživatele sledovat účet proxy." | ||||||
|  | host: "Hostitel" | ||||||
|  | selectUser: "Vyberte uživatele" | ||||||
|  | recipient: "Pro" | ||||||
|  | annotation: "Komentáře" | ||||||
|  | instances: "Instance" | ||||||
|  | registeredAt: "Registrován" | ||||||
|  | latestRequestSentAt: "Poslední požadavek poslán" | ||||||
|  | latestRequestReceivedAt: "Poslední požadavek přijat" | ||||||
|  | latestStatus: "Poslední status" | ||||||
|  | storageUsage: "Využití úložiště" | ||||||
|  | charts: "Grafy" | ||||||
|  | perHour: "za hodinu" | ||||||
|  | perDay: "za den" | ||||||
|  | blockThisInstance: "Blokovat tuto instanci" | ||||||
|  | operations: "Operace" | ||||||
|  | software: "Software" | ||||||
|  | version: "Verze" | ||||||
|  | metadata: "Metadata" | ||||||
|  | withNFiles: "{n} soubor(ů)" | ||||||
|  | monitor: "Monitorovat" | ||||||
|  | jobQueue: "Fronta úloh" | ||||||
|  | cpuAndMemory: "CPU a paměť" | ||||||
|  | network: "Síť" | ||||||
|  | disk: "Disk" | ||||||
|  | instanceInfo: "Informace o instanci" | ||||||
|  | statistics: "Statistiky" | ||||||
|  | clearQueue: "Vyčistit frontu" | ||||||
|  | clearQueueConfirmTitle: "Jste si jisti že zrušit všechny úlohy ve frontě?" | ||||||
|  | clearCachedFiles: "Vyprázdnit mezipaměť" | ||||||
|  | blockedInstances: "Blokované instance" | ||||||
|  | editProfile: "Upravit můj profil" | ||||||
|  | pinLimitExceeded: "Nemůžete připnout další poznámky." | ||||||
|  | intro: "Instalace Misskey byla dokončena! Prosím vytvořte admina." | ||||||
|  | done: "Hotovo" | ||||||
|  | processing: "Zpracovávám" | ||||||
|  | preview: "Náhled" | ||||||
|  | default: "Výchozí" | ||||||
|  | blocked: "Blokováno" | ||||||
|  | suspended: "Suspendováno" | ||||||
|  | all: "Vše" | ||||||
|  | subscribing: "Odebíráte" | ||||||
|  | publishing: "Publikuji" | ||||||
|  | notResponding: "Neodpovídá" | ||||||
|  | instanceFollowing: "Následovníci na instanci" | ||||||
|  | instanceFollowers: "Následovníci na instanci" | ||||||
|  | instanceUsers: "Uživatelé této instance" | ||||||
|  | changePassword: "Změnit heslo" | ||||||
|  | security: "Zabezpečení" | ||||||
|  | currentPassword: "Současné heslo" | ||||||
|  | newPassword: "Nové heslo" | ||||||
|  | newPasswordRetype: "Nové heslo (znovu)" | ||||||
|  | attachFile: "Přiložit soubor" | ||||||
|  | more: "Více!" | ||||||
|  | featured: "Oblíbené poznámky" | ||||||
|  | usernameOrUserId: "Uživatelské jméno nebo uživatelské id" | ||||||
|  | noSuchUser: "Uživatel nebyl nalezen" | ||||||
|  | announcements: "Oznámení" | ||||||
|  | imageUrl: "URL obrázku" | ||||||
|  | remove: "Smazat" | ||||||
|  | removed: "Smazáno" | ||||||
|  | removeAreYouSure: "Jste si jistí že chcete smazat \"{x}\"?" | ||||||
|  | deleteAreYouSure: "Jste si jistí že chcete smazat \"{x}\"?" | ||||||
|  | resetAreYouSure: "Opravdu resetovat?" | ||||||
|  | saved: "Uloženo" | ||||||
|  | messaging: "Zprávy" | ||||||
|  | upload: "Nahrát soubory" | ||||||
|  | fromDrive: "Z disku" | ||||||
|  | fromUrl: "Z URL" | ||||||
|  | uploadFromUrl: "Nahrát z URL adresy" | ||||||
|  | uploadFromUrlDescription: "URL adresa souboru, který chcete nahrát" | ||||||
|  | uploadFromUrlMayTakeTime: "Může trvat nějakou dobu, dokud nebude dokončeno nahrávání." | ||||||
|  | explore: "Objevovat" | ||||||
|  | games: "Misskey hry" | ||||||
|  | messageRead: "Přečtené" | ||||||
|  | noMoreHistory: "To je vše" | ||||||
|  | startMessaging: "Zahájit chat" | ||||||
|  | nUsersRead: "přečteno {n} uživateli" | ||||||
|  | agreeTo: "Souhlasím s {0}" | ||||||
|  | tos: "Podmínky užívání" | ||||||
|  | start: "Začít" | ||||||
|  | home: "Domů" | ||||||
|  | remoteUserCaution: "Tyto informace nemusí být aktuální jelikož uživatel je ze vzdálené instance." | ||||||
|  | activity: "Aktivita" | ||||||
|  | images: "Obrázky" | ||||||
|  | birthday: "Datum narození" | ||||||
|  | yearsOld: "{age} let" | ||||||
|  | registeredDate: "Datum registrace" | ||||||
|  | location: "Lokace" | ||||||
|  | theme: "Vzhled" | ||||||
|  | themeForLightMode: "Vzhled pro použití ve světlém režimu" | ||||||
|  | themeForDarkMode: "Vzhled k použití v tmavém režimu" | ||||||
|  | light: "Světlý" | ||||||
|  | dark: "Tmavý" | ||||||
|  | lightThemes: "Světlý vzhled" | ||||||
|  | darkThemes: "Tmavý vzhled" | ||||||
|  | syncDeviceDarkMode: "Synchronizovat tmavý vzhled s nastavením Vašeho systému" | ||||||
|  | drive: "Úložiště" | ||||||
|  | fileName: "Název souboru" | ||||||
|  | selectFile: "Vybrat soubor" | ||||||
|  | selectFiles: "Vybrat soubory" | ||||||
|  | selectFolder: "Vyberte složku" | ||||||
|  | selectFolders: "Vyberte složky" | ||||||
|  | renameFile: "Přejmenovat soubor" | ||||||
|  | folderName: "Název složky" | ||||||
|  | createFolder: "Vytvořit složku" | ||||||
|  | renameFolder: "Přejmenovat složku" | ||||||
|  | deleteFolder: "Odstranit složku" | ||||||
|  | addFile: "Přidat soubor" | ||||||
|  | emptyFolder: "Tato složka je prázdná" | ||||||
|  | unableToDelete: "Nelze smazat" | ||||||
|  | inputNewFileName: "Zadejte nový název" | ||||||
|  | copyUrl: "Kopírovat URL" | ||||||
|  | rename: "Přejmenovat" | ||||||
|  | avatar: "Avatar" | ||||||
|  | banner: "Baner" | ||||||
|  | nsfw: "NSFW" | ||||||
|  | disconnectedFromServer: "Spojení bylo přerušeno" | ||||||
|  | reload: "Aktualizovat" | ||||||
|  | doNothing: "Ignorovat" | ||||||
|  | watch: "Sledovat" | ||||||
|  | unwatch: "Přestat sledovat" | ||||||
|  | accept: "Souhlasím" | ||||||
|  | reject: "Odmítnout" | ||||||
|  | normal: "Normální" | ||||||
|  | instanceName: "Název instance" | ||||||
|  | instanceDescription: "Popis instance" | ||||||
|  | maintainerName: "Správce" | ||||||
|  | maintainerEmail: "E-mailová adresa správce" | ||||||
|  | tosUrl: "URL pro smluvní podmínky" | ||||||
|  | thisYear: "Tento rok" | ||||||
|  | thisMonth: "Tento měsíc" | ||||||
|  | today: "Dnes" | ||||||
|  | dayX: "{day}" | ||||||
|  | monthX: "{month}" | ||||||
|  | yearX: "{year}" | ||||||
|  | pages: "Stránky" | ||||||
|  | integration: "Integrace" | ||||||
|  | enableLocalTimeline: "Povolit lokální čas" | ||||||
|  | enableGlobalTimeline: "Povolit globální čas" | ||||||
|  | registration: "Registrace" | ||||||
|  | enableRegistration: "Povolit registraci novým uživatelům" | ||||||
|  | invite: "Pozvat" | ||||||
|  | inMb: "V megabajtech" | ||||||
|  | iconUrl: "Favicon URL" | ||||||
|  | bannerUrl: "Baner URL" | ||||||
|  | basicInfo: "Základní informace" | ||||||
|  | hcaptcha: "hCaptcha" | ||||||
|  | hcaptchaSecretKey: "Tajný Klíč (Secret Key)" | ||||||
|  | recaptcha: "reCAPTCHA" | ||||||
|  | enableRecaptcha: "Zapnout ReCAPTCHu" | ||||||
|  | recaptchaSecretKey: "Tajný Klíč (Secret Key)" | ||||||
|  | antennas: "Antény" | ||||||
|  | manageAntennas: "Spravovat Antény" | ||||||
|  | name: "Jméno" | ||||||
|  | antennaSource: "Zdroj Antény" | ||||||
|  | enableServiceworker: "Povolit ServiceWorker" | ||||||
|  | caseSensitive: "Rozlišuje malá a velká písmena" | ||||||
|  | connectedTo: "Následující účty jsou připojeny" | ||||||
|  | userList: "Seznamy" | ||||||
|  | about: "Informace" | ||||||
|  | aboutMisskey: "O Misskey" | ||||||
|  | administrator: "Administrátor" | ||||||
|  | token: "Token" | ||||||
|  | twoStepAuthentication: "Dvoufaktorová autentikace" | ||||||
|  | moderator: "Moderátor" | ||||||
|  | nUsersMentioned: "{n} uživatelů zmínilo" | ||||||
|  | securityKey: "Bezpečnostní klíč" | ||||||
|  | securityKeyName: "Název klíče" | ||||||
|  | registerSecurityKey: "Registrovat bezpečnostní klíč" | ||||||
|  | lastUsed: "Naposledy použito" | ||||||
|  | unregister: "Odstranit" | ||||||
|  | resetPassword: "Resetovat heslo" | ||||||
|  | newPasswordIs: "Nové heslo je \"{password}\"" | ||||||
|  | reduceUiAnimation: "Snížit UI animace" | ||||||
|  | share: "Sdílet" | ||||||
|  | notFound: "Nenalezeno" | ||||||
|  | notFoundDescription: "Nebyla nalezená žádná stránka korespondující se zadanou URL." | ||||||
|  | uploadFolder: "Výchozí lokace pro upload" | ||||||
|  | cacheClear: "Vymazat cache" | ||||||
|  | markAsReadAllNotifications: "Označit všechna oznámení za přečtená" | ||||||
|  | markAsReadAllUnreadNotes: "Označit všechny příspěvky za přečtené" | ||||||
|  | markAsReadAllTalkMessages: "Označit všechny zprávy za přečtené" | ||||||
|  | help: "Nápověda" | ||||||
|  | inputMessageHere: "Sem zadejte zprávu" | ||||||
|  | close: "Zavřít" | ||||||
|  | group: "Skupina" | ||||||
|  | groups: "Skupiny" | ||||||
|  | createGroup: "Vytvořit skupinu" | ||||||
|  | ownedGroups: "Vlastněné skupiny" | ||||||
|  | joinedGroups: "Členství ve skupinách" | ||||||
|  | invites: "Pozvat" | ||||||
|  | groupName: "Název skupiny" | ||||||
|  | members: "Členové" | ||||||
|  | transfer: "Převod" | ||||||
|  | title: "Titulek" | ||||||
|  | text: "Text" | ||||||
|  | enable: "Povolit" | ||||||
|  | next: "Další" | ||||||
|  | retype: "Zadejte znovu" | ||||||
|  | noteOf: "{user} poznámky" | ||||||
|  | inviteToGroup: "Pozvat do skupiny" | ||||||
|  | invitations: "Pozvat" | ||||||
|  | checking: "Ověřuji" | ||||||
|  | available: "K dispozici" | ||||||
|  | unavailable: "Není k dispozici" | ||||||
|  | usernameInvalidFormat: "Písmena, čísla a _ jsou povolená." | ||||||
|  | tooShort: "Příliš krátké" | ||||||
|  | tooLong: "Příliš dlouhé" | ||||||
|  | weakPassword: "Slabé heslo" | ||||||
|  | normalPassword: "Dobré heslo" | ||||||
|  | strongPassword: "Silné heslo" | ||||||
|  | passwordMatched: "Hesla se schodují" | ||||||
|  | passwordNotMatched: "Hesla se neschodují" | ||||||
|  | signinWith: "Přihlásit se s {x}" | ||||||
|  | signinFailed: "Nelze se přihlásit. Zkontrolujte prosím své uživatelské jméno a heslo." | ||||||
|  | or: "Nebo" | ||||||
|  | language: "Jazyk" | ||||||
|  | uiLanguage: "Jazyk uživatelského rozhraní" | ||||||
|  | groupInvited: "Pozvat do skupiny" | ||||||
|  | aboutX: "O {x}" | ||||||
|  | useOsNativeEmojis: "Použití nativních emoji operačního systému" | ||||||
|  | youHaveNoGroups: "Nemáte žádné skupiny" | ||||||
|  | joinOrCreateGroup: "Můžete požádat o pozvání do stávající skupiny nebo vytvořit novou." | ||||||
|  | noHistory: "Žádná historie" | ||||||
|  | signinHistory: "Historie přihlášení" | ||||||
|  | category: "Kategorie" | ||||||
|  | tags: "Štítky" | ||||||
|  | createAccount: "Vytvořit účet" | ||||||
|  | fontSize: "Velikost písma" | ||||||
|  | openImageInNewTab: "Otevřít obrázek v novém panelu" | ||||||
|  | dashboard: "Přehled" | ||||||
|  | local: "Lokální" | ||||||
|  | total: "Celkem" | ||||||
|  | weekOverWeekChanges: "Týdně" | ||||||
|  | dayOverDayChanges: "Denně" | ||||||
|  | appearance: "Vzhled" | ||||||
|  | clientSettings: "Nastavení klienta" | ||||||
|  | accountSettings: "Nastavení účtu" | ||||||
|  | promotion: "Propagace" | ||||||
|  | promote: "Propagovat" | ||||||
|  | numberOfDays: "Počet dní" | ||||||
|  | chooseEmoji: "Vybrat emotikon" | ||||||
|  | unableToProcess: "Operace nebyla dokončena." | ||||||
|  | recentUsed: "Naposledy použité" | ||||||
|  | install: "Nainstalovat" | ||||||
|  | uninstall: "Odinstalovat" | ||||||
|  | installedApps: "Autorizované aplikace" | ||||||
|  | nothing: "Nic nebylo nalezeno" | ||||||
|  | lastUsedDate: "Poslední použití" | ||||||
|  | state: "Stav" | ||||||
|  | ascendingOrder: "Vzestupně" | ||||||
|  | descendingOrder: "Sestupně" | ||||||
|  | scratchpad: "Zápisník" | ||||||
|  | output: "Výstup" | ||||||
|  | script: "Skript" | ||||||
|  | deleteAllFiles: "Smazat všechny soubory" | ||||||
|  | deleteAllFilesConfirm: "Jste si jistí že chcete smazat všechny soubory?" | ||||||
|  | userSuspended: "Tomuto uživateli byl pozastaven účet." | ||||||
|  | sidebar: "Postranní panel" | ||||||
|  | addItem: "Přidat položku" | ||||||
|  | rooms: "Místnost" | ||||||
|  | inboxUrl: "Inbox URL" | ||||||
|  | deletedNote: "Odstraněné příspěvky" | ||||||
|  | invisibleNote: "Skryté příspěvky" | ||||||
|  | smtpHost: "Hostitel" | ||||||
|  | smtpUser: "Uživatelské jméno" | ||||||
|  | smtpPass: "Heslo" | ||||||
|  | clearCache: "Vyprázdnit mezipaměť" | ||||||
|  | info: "Informace" | ||||||
|  | user: "Uživatelé" | ||||||
|  | _mfm: | ||||||
|  |   mention: "Zmínění" | ||||||
|  |   quote: "Citovat" | ||||||
|  |   emoji: "Vlastní emoji" | ||||||
|  |   search: "Vyhledávání" | ||||||
|  | _reversi: | ||||||
|  |   total: "Celkem" | ||||||
|  | _sidebar: | ||||||
|  |   icon: "Avatar" | ||||||
|  | _theme: | ||||||
|  |   keys: | ||||||
|  |     mention: "Zmínění" | ||||||
|  |     renote: "Přeposlat" | ||||||
|  | _sfx: | ||||||
|  |   note: "Poznámky" | ||||||
|  |   notification: "Oznámení" | ||||||
|  |   chat: "Zprávy" | ||||||
|  | _widgets: | ||||||
|  |   notifications: "Oznámení" | ||||||
|  |   timeline: "Časová osa" | ||||||
|  |   activity: "Aktivita" | ||||||
|  |   jobQueue: "Fronta úloh" | ||||||
|  | _cw: | ||||||
|  |   show: "Zobrazit více" | ||||||
|  | _visibility: | ||||||
|  |   home: "Domů" | ||||||
|  |   followers: "Sledující" | ||||||
|  | _profile: | ||||||
|  |   name: "Jméno" | ||||||
|  |   username: "Uživatelské jméno" | ||||||
|  | _exportOrImport: | ||||||
|  |   followingList: "Sledovaní" | ||||||
|  |   muteList: "Ztlumit" | ||||||
|  |   blockingList: "Zablokovat" | ||||||
|  |   userLists: "Seznamy" | ||||||
|  | _timelines: | ||||||
|  |   home: "Domů" | ||||||
|  | _rooms: | ||||||
|  |   _roomType: | ||||||
|  |     default: "Výchozí" | ||||||
|  |   _furnitures: | ||||||
|  |     monitor: "Monitorovat" | ||||||
|  | _pages: | ||||||
|  |   blocks: | ||||||
|  |     image: "Obrázky" | ||||||
|  |   script: | ||||||
|  |     categories: | ||||||
|  |       list: "Seznamy" | ||||||
|  |     blocks: | ||||||
|  |       _join: | ||||||
|  |         arg1: "Seznamy" | ||||||
|  |       _randomPick: | ||||||
|  |         arg1: "Seznamy" | ||||||
|  |       _dailyRandomPick: | ||||||
|  |         arg1: "Seznamy" | ||||||
|  |       _seedRandomPick: | ||||||
|  |         arg2: "Seznamy" | ||||||
|  |       _pick: | ||||||
|  |         arg1: "Seznamy" | ||||||
|  |       _listLen: | ||||||
|  |         arg1: "Seznamy" | ||||||
|  |     types: | ||||||
|  |       array: "Seznamy" | ||||||
|  | _notification: | ||||||
|  |   youWereInvitedToGroup: "Pozvat do skupiny" | ||||||
|  |   _types: | ||||||
|  |     follow: "Sledovaní" | ||||||
|  |     mention: "Zmínění" | ||||||
|  |     renote: "Přeposlat" | ||||||
|  |     quote: "Citovat" | ||||||
|  |     reaction: "Reakce" | ||||||
|  | _deck: | ||||||
|  |   _columns: | ||||||
|  |     notifications: "Oznámení" | ||||||
|  |     tl: "Časová osa" | ||||||
|  |     antenna: "Antény" | ||||||
|  |     list: "Seznamy" | ||||||
|  |     mentions: "Zmínění" | ||||||
|   | |||||||
| @@ -7,6 +7,7 @@ search: "Suchen" | |||||||
| notifications: "Benachrichtigungen" | notifications: "Benachrichtigungen" | ||||||
| username: "Benutzername" | username: "Benutzername" | ||||||
| password: "Passwort" | password: "Passwort" | ||||||
|  | forgotPassword: "Passwort vergessen" | ||||||
| fetchingAsApObject: "Wird aus dem Fediverse angefragt..." | fetchingAsApObject: "Wird aus dem Fediverse angefragt..." | ||||||
| ok: "OK" | ok: "OK" | ||||||
| gotIt: "Verstanden!" | gotIt: "Verstanden!" | ||||||
| @@ -134,11 +135,11 @@ settingGuide: "Empfohlene Einstellung" | |||||||
| cacheRemoteFiles: "Dateien von anderen Instanzen im Cache speichern" | cacheRemoteFiles: "Dateien von anderen Instanzen im Cache speichern" | ||||||
| cacheRemoteFilesDescription: "Wenn diese Einstellung deaktiviert ist, werden Dateien anderer Instanzen direkt von dort geladen. Hierdurch wird Speicherplatz gespart, aber mehr Bandbreite verbraucht, da keine Vorschaubilder generiert werden." | cacheRemoteFilesDescription: "Wenn diese Einstellung deaktiviert ist, werden Dateien anderer Instanzen direkt von dort geladen. Hierdurch wird Speicherplatz gespart, aber mehr Bandbreite verbraucht, da keine Vorschaubilder generiert werden." | ||||||
| flagAsBot: "Als Bot markieren" | flagAsBot: "Als Bot markieren" | ||||||
| flagAsBotDescription: "Wenn dieser Account durch ein Programm gesteuert wird, setze diesen Haken. Falls aktiviert, agiert es als Flag für andere Entwickler um endlose Kettenreaktionen mit anderen Bots zu verhindern und lässt Misskey's interne Systeme diesen Account als Bot behandeln." | flagAsBotDescription: "Wenn dieses Benutzerkonto durch ein Programm gesteuert wird, setze diesen Haken. Falls aktiviert, agiert es als Flag für andere Entwickler um endlose Kettenreaktionen mit anderen Bots zu verhindern und lässt Misskey's interne Systeme dieses Benutzerkonto als Bot behandeln." | ||||||
| flagAsCat: "Als Katze markieren" | flagAsCat: "Als Katze markieren" | ||||||
| flagAsCatDescription: "Setze diese Flag um dieses Benutzerkonto als Katze zu markieren." | flagAsCatDescription: "Setze diese Flag um dieses Benutzerkonto als Katze zu markieren." | ||||||
| autoAcceptFollowed: "Follow-Anfragen automatisch akzeptieren" | autoAcceptFollowed: "Follow-Anfragen automatisch akzeptieren" | ||||||
| addAcount: "Benutzerkonto hinzufügen" | addAccount: "Benutzerkonto hinzufügen" | ||||||
| loginFailed: "Login fehlgeschlagen" | loginFailed: "Login fehlgeschlagen" | ||||||
| showOnRemote: "Auf Ursprungsinstanz ansehen" | showOnRemote: "Auf Ursprungsinstanz ansehen" | ||||||
| general: "Allgemein" | general: "Allgemein" | ||||||
| @@ -278,6 +279,7 @@ emptyDrive: "Drive ist leer" | |||||||
| emptyFolder: "Der Ordner ist leer" | emptyFolder: "Der Ordner ist leer" | ||||||
| unableToDelete: "Nicht löschbar" | unableToDelete: "Nicht löschbar" | ||||||
| inputNewFileName: "Gib einen neuen Dateinamen ein" | inputNewFileName: "Gib einen neuen Dateinamen ein" | ||||||
|  | inputNewDescription: "Gib eine neue Beschreibung ein" | ||||||
| inputNewFolderName: "Gib einen neuen Ordnernamen ein" | inputNewFolderName: "Gib einen neuen Ordnernamen ein" | ||||||
| circularReferenceFolder: "Der Zielordner ist ein Unterorder des Ordners, den du verschieben möchtest." | circularReferenceFolder: "Der Zielordner ist ein Unterorder des Ordners, den du verschieben möchtest." | ||||||
| hasChildFilesOrFolders: "Dieser Ordner kann nicht gelöscht werden, da er nicht leer ist." | hasChildFilesOrFolders: "Dieser Ordner kann nicht gelöscht werden, da er nicht leer ist." | ||||||
| @@ -298,8 +300,8 @@ reject: "Ablehnen" | |||||||
| normal: "Normal" | normal: "Normal" | ||||||
| instanceName: "Name der Instanz" | instanceName: "Name der Instanz" | ||||||
| instanceDescription: "Beschreibung der Instanz" | instanceDescription: "Beschreibung der Instanz" | ||||||
| maintainerName: "Betreiber" | maintainerName: "Administrator" | ||||||
| maintainerEmail: "Betreiber-Email" | maintainerEmail: "Administrator-Email" | ||||||
| tosUrl: "URL der Nutzungsbedingungen" | tosUrl: "URL der Nutzungsbedingungen" | ||||||
| thisYear: "Dieses Jahr" | thisYear: "Dieses Jahr" | ||||||
| thisMonth: "Dieser Monat" | thisMonth: "Dieser Monat" | ||||||
| @@ -309,8 +311,8 @@ monthX: "{month}" | |||||||
| yearX: "{year}" | yearX: "{year}" | ||||||
| pages: "Seiten" | pages: "Seiten" | ||||||
| integration: "Integration" | integration: "Integration" | ||||||
| connectSerice: "Verbinden" | connectService: "Verbinden" | ||||||
| disconnectSerice: "Trennen" | disconnectService: "Trennen" | ||||||
| enableLocalTimeline: "Lokale Chronik aktivieren" | enableLocalTimeline: "Lokale Chronik aktivieren" | ||||||
| enableGlobalTimeline: "Globale Chronik aktivieren" | enableGlobalTimeline: "Globale Chronik aktivieren" | ||||||
| disablingTimelinesInfo: "Administratoren und Moderatoren haben immer Zugriff auf alle Chroniken, auch wenn diese deaktiviert sind." | disablingTimelinesInfo: "Administratoren und Moderatoren haben immer Zugriff auf alle Chroniken, auch wenn diese deaktiviert sind." | ||||||
| @@ -349,7 +351,6 @@ antennaExcludeKeywords: "Schlüsselwörter, die ignoriert werden sollen" | |||||||
| antennaKeywordsDescription: "Mit Leerzeichen für eine \"UND\"-Verknüpfung trennen, durch Zeilenumbrüche für eine \"ODER\"-Verknüpfung trennen." | antennaKeywordsDescription: "Mit Leerzeichen für eine \"UND\"-Verknüpfung trennen, durch Zeilenumbrüche für eine \"ODER\"-Verknüpfung trennen." | ||||||
| notifyAntenna: "Über neue Notizen benachrichtigen" | notifyAntenna: "Über neue Notizen benachrichtigen" | ||||||
| withFileAntenna: "Nur Notizen mit Dateien" | withFileAntenna: "Nur Notizen mit Dateien" | ||||||
| serviceworker: "ServiceWorker" |  | ||||||
| enableServiceworker: "ServiceWorker aktivieren" | enableServiceworker: "ServiceWorker aktivieren" | ||||||
| antennaUsersDescription: "Benutzernamen getrennt durch Zeilenumbrüche angeben" | antennaUsersDescription: "Benutzernamen getrennt durch Zeilenumbrüche angeben" | ||||||
| caseSensitive: "Groß-/Kleinschreibung unterscheiden" | caseSensitive: "Groß-/Kleinschreibung unterscheiden" | ||||||
| @@ -453,7 +454,7 @@ category: "Kategorie" | |||||||
| tags: "Schlagwörter" | tags: "Schlagwörter" | ||||||
| docSource: "Quelle dieses Dokuments" | docSource: "Quelle dieses Dokuments" | ||||||
| createAccount: "Benutzerkonto erstellen" | createAccount: "Benutzerkonto erstellen" | ||||||
| existingAcount: "Bestehendes Benutzerkonto" | existingAccount: "Bestehendes Benutzerkonto" | ||||||
| regenerate: "Regenerieren" | regenerate: "Regenerieren" | ||||||
| fontSize: "Schriftgröße" | fontSize: "Schriftgröße" | ||||||
| noFollowRequests: "Du hast keine Follow-Anfragen" | noFollowRequests: "Du hast keine Follow-Anfragen" | ||||||
| @@ -546,6 +547,8 @@ disablePlayer: "Video-Player schließen" | |||||||
| expandTweet: "Tweet ausklappen" | expandTweet: "Tweet ausklappen" | ||||||
| themeEditor: "Farbthemen-Editor" | themeEditor: "Farbthemen-Editor" | ||||||
| description: "Beschreibung" | description: "Beschreibung" | ||||||
|  | describeFile: "Beschreibung hinzufügen" | ||||||
|  | enterFileDescription: "Beschreibung eingeben" | ||||||
| author: "Autor" | author: "Autor" | ||||||
| leaveConfirm: "Es gibt unspeicherte Änderungen. Möchtest du diese verwerfen?" | leaveConfirm: "Es gibt unspeicherte Änderungen. Möchtest du diese verwerfen?" | ||||||
| manage: "Verwaltung" | manage: "Verwaltung" | ||||||
| @@ -568,7 +571,7 @@ pluginTokenRequestedDescription: "Dieses Plugin wird die hier konfigurierten Ber | |||||||
| notificationType: "Benachrichtigungsart" | notificationType: "Benachrichtigungsart" | ||||||
| edit: "Bearbeiten" | edit: "Bearbeiten" | ||||||
| useStarForReactionFallback: "Verwende ★ falls das Reaktions-Emoji unbekannt ist" | useStarForReactionFallback: "Verwende ★ falls das Reaktions-Emoji unbekannt ist" | ||||||
| emailConfig: "Email-Server Konfiguration" | emailServer: "Email-Server" | ||||||
| enableEmail: "Email-Versand aktivieren" | enableEmail: "Email-Versand aktivieren" | ||||||
| emailConfigInfo: "Zur Email-Bestätigung bei Registrierung und zum Zurücksetzen des Passworts verwendet" | emailConfigInfo: "Zur Email-Bestätigung bei Registrierung und zum Zurücksetzen des Passworts verwendet" | ||||||
| email: "Email" | email: "Email" | ||||||
| @@ -687,6 +690,7 @@ textColor: "Text" | |||||||
| saveAs: "Speichern als…" | saveAs: "Speichern als…" | ||||||
| advanced: "Fortgeschritten" | advanced: "Fortgeschritten" | ||||||
| value: "Wert" | value: "Wert" | ||||||
|  | createdAt: "Erstellt am" | ||||||
| updatedAt: "Zuletzt geändert am" | updatedAt: "Zuletzt geändert am" | ||||||
| saveConfirm: "Änderungen speichern?" | saveConfirm: "Änderungen speichern?" | ||||||
| deleteConfirm: "Wirklich löschen?" | deleteConfirm: "Wirklich löschen?" | ||||||
| @@ -704,12 +708,70 @@ editCode: "Code bearbeiten" | |||||||
| apply: "Anwenden" | apply: "Anwenden" | ||||||
| receiveAnnouncementFromInstance: "E-Mail-Benachrichtigungen von dieser Instanz empfangen" | receiveAnnouncementFromInstance: "E-Mail-Benachrichtigungen von dieser Instanz empfangen" | ||||||
| emailNotification: "E-Mail-Benachrichtigungen" | emailNotification: "E-Mail-Benachrichtigungen" | ||||||
|  | publish: "Veröffentlichen" | ||||||
| inChannelSearch: "In Kanal suchen" | inChannelSearch: "In Kanal suchen" | ||||||
| useReactionPickerForContextMenu: "Reaktionsauswahl durch Rechtsklick öffnen" | useReactionPickerForContextMenu: "Reaktionsauswahl durch Rechtsklick öffnen" | ||||||
| typingUsers: "{users} ist/sind am schreiben..." | typingUsers: "{users} ist/sind am schreiben..." | ||||||
| jumpToSpecifiedDate: "Zu bestimmtem Datum springen" | jumpToSpecifiedDate: "Zu bestimmtem Datum springen" | ||||||
| showingPastTimeline: "Momentan wird eine alte Chronik angezeigt" | showingPastTimeline: "Momentan wird eine alte Chronik angezeigt" | ||||||
| clear: "Zurückkehren" | clear: "Zurückkehren" | ||||||
|  | markAllAsRead: "Alle als gelesen markieren" | ||||||
|  | goBack: "Zurück" | ||||||
|  | unlikeConfirm: "\"Gefällt mir\" wirklich entfernen?" | ||||||
|  | fullView: "Vollansicht" | ||||||
|  | quitFullView: "Vollansicht verlassen" | ||||||
|  | addDescription: "Beschreibung hinzufügen" | ||||||
|  | userPagePinTip: "Um Notizen hier erscheinen zu lassen, drücke \"Anpinnen\" im Menü individueller Notizen" | ||||||
|  | notSpecifiedMentionWarning: "Diese Notiz enthält Erwähnungen von Nutzern, die nicht als Empfänger ausgewählt sind" | ||||||
|  | info: "Über" | ||||||
|  | userInfo: "Benutzerinformation" | ||||||
|  | unknown: "Unbekannt" | ||||||
|  | onlineStatus: "Online-Status" | ||||||
|  | hideOnlineStatus: "Online-Status verbergen" | ||||||
|  | hideOnlineStatusDescription: "Das Verbergen deines Online-Statuses reduziert die Nützlichkeit von Funktionen wie der Suche." | ||||||
|  | online: "Online" | ||||||
|  | active: "Aktiv" | ||||||
|  | offline: "Offline" | ||||||
|  | notRecommended: "Nicht empfohlen" | ||||||
|  | botProtection: "Bot-Schutz" | ||||||
|  | instanceBlocking: "Blockierte Instanzen" | ||||||
|  | selectAccount: "Benutzerkonto auswählen" | ||||||
|  | enabled: "Aktiviert" | ||||||
|  | disabled: "Deaktiviert" | ||||||
|  | quickAction: "Schnellaktionen" | ||||||
|  | user: "Benutzer" | ||||||
|  | administration: "Verwaltung" | ||||||
|  | accounts: "Benutzerkonten" | ||||||
|  | switch: "Wechseln" | ||||||
|  | noMaintainerInformationWarning: "Administratorinformationen sind nicht konfiguriert." | ||||||
|  | noBotProtectionWarning: "Bot-Schutz ist nicht konfiguriert." | ||||||
|  | configure: "Konfigurieren" | ||||||
|  | postToGallery: "Beitrag zu Galerie hinzufügen" | ||||||
|  | gallery: "Galerie" | ||||||
|  | recentPosts: "Neue Beiträge" | ||||||
|  | popularPosts: "Beliebte Beiträge" | ||||||
|  | shareWithNote: "Mit Notiz teilen" | ||||||
|  | ads: "Werbung" | ||||||
|  | expiration: "Frist" | ||||||
|  | memo: "Merkzettel" | ||||||
|  | priority: "Priorität" | ||||||
|  | high: "Hoch" | ||||||
|  | middle: "Mittel" | ||||||
|  | low: "Niedrig" | ||||||
|  | emailNotConfiguredWarning: "Keine Email-Adresse hinterlegt" | ||||||
|  | ratio: "Verhältnis" | ||||||
|  | _ad: | ||||||
|  |   back: "Zurück" | ||||||
|  |   reduceFrequencyOfThisAd: "Diese Werbung weniger anzeigen" | ||||||
|  | _forgotPassword: | ||||||
|  |   enterEmail: "Gib die Email-Adresse ein, mit der du dich registriert hast. An diese wird ein Link gesendet, mit der du dein Passwort zurücksetzen kannst." | ||||||
|  |   ifNoEmail: "Solltest du bei der Registrierung keine Email-Adresse angegeben haben, wende dich bitte an den Administrator." | ||||||
|  |   contactAdmin: "Diese Instanz unterstützt die Verwendung von Email-Adressen nicht. Wende dich, um dein Passwort zurückzusetzen, an den Administrator." | ||||||
|  | _gallery: | ||||||
|  |   my: "Meine Galerie" | ||||||
|  |   liked: "Beiträge, die mir gefallen" | ||||||
|  |   like: "Gefällt mir" | ||||||
|  |   unlike: "\"Gefällt mir\" entfernen" | ||||||
| _email: | _email: | ||||||
|   _follow: |   _follow: | ||||||
|     title: "Du hast einen neuen Follower" |     title: "Du hast einen neuen Follower" | ||||||
| @@ -865,6 +927,7 @@ _theme: | |||||||
|   install: "Thema installieren" |   install: "Thema installieren" | ||||||
|   manage: "Themaverwaltung" |   manage: "Themaverwaltung" | ||||||
|   code: "Themen-Code" |   code: "Themen-Code" | ||||||
|  |   description: "Beschreibung" | ||||||
|   installed: "{name} wurde installiert" |   installed: "{name} wurde installiert" | ||||||
|   installedThemes: "Installierte Themen" |   installedThemes: "Installierte Themen" | ||||||
|   builtinThemes: "Eingebaute Themen" |   builtinThemes: "Eingebaute Themen" | ||||||
|   | |||||||
| @@ -7,6 +7,7 @@ search: "Search" | |||||||
| notifications: "Notifications" | notifications: "Notifications" | ||||||
| username: "Username" | username: "Username" | ||||||
| password: "Password" | password: "Password" | ||||||
|  | forgotPassword: "Forgot password" | ||||||
| fetchingAsApObject: "Fetching from Fediverse..." | fetchingAsApObject: "Fetching from Fediverse..." | ||||||
| ok: "OK" | ok: "OK" | ||||||
| gotIt: "Got it!" | gotIt: "Got it!" | ||||||
| @@ -138,7 +139,7 @@ flagAsBotDescription: "If this account is controlled by a program, set this opti | |||||||
| flagAsCat: "This account is a cat" | flagAsCat: "This account is a cat" | ||||||
| flagAsCatDescription: "Toggle this flag on for this account to be marked as a cat." | flagAsCatDescription: "Toggle this flag on for this account to be marked as a cat." | ||||||
| autoAcceptFollowed: "Automatically approve follow requests from users you're following" | autoAcceptFollowed: "Automatically approve follow requests from users you're following" | ||||||
| addAcount: "Add Account" | addAccount: "Add account" | ||||||
| loginFailed: "Failed to sign in" | loginFailed: "Failed to sign in" | ||||||
| showOnRemote: "View on remote instance" | showOnRemote: "View on remote instance" | ||||||
| general: "General" | general: "General" | ||||||
| @@ -278,6 +279,7 @@ emptyDrive: "The drive is empty" | |||||||
| emptyFolder: "This folder is empty" | emptyFolder: "This folder is empty" | ||||||
| unableToDelete: "Unable to delete" | unableToDelete: "Unable to delete" | ||||||
| inputNewFileName: "Enter a new filename" | inputNewFileName: "Enter a new filename" | ||||||
|  | inputNewDescription: "Enter new caption" | ||||||
| inputNewFolderName: "Enter a new folder name" | inputNewFolderName: "Enter a new folder name" | ||||||
| circularReferenceFolder: "The destination folder is a subfolder of the folder you wish to move." | circularReferenceFolder: "The destination folder is a subfolder of the folder you wish to move." | ||||||
| hasChildFilesOrFolders: "Since this folder is not empty, it can not be deleted." | hasChildFilesOrFolders: "Since this folder is not empty, it can not be deleted." | ||||||
| @@ -309,8 +311,8 @@ monthX: "{month}" | |||||||
| yearX: "{year} /" | yearX: "{year} /" | ||||||
| pages: "Pages" | pages: "Pages" | ||||||
| integration: "Integration" | integration: "Integration" | ||||||
| connectSerice: "Connect" | connectService: "Connect" | ||||||
| disconnectSerice: "Disconnect" | disconnectService: "Disconnect" | ||||||
| enableLocalTimeline: "Enable local timeline" | enableLocalTimeline: "Enable local timeline" | ||||||
| enableGlobalTimeline: "Enable global timeline" | enableGlobalTimeline: "Enable global timeline" | ||||||
| disablingTimelinesInfo: "Admins and Mods will always have access to all timelines, even if they are not enabled." | disablingTimelinesInfo: "Admins and Mods will always have access to all timelines, even if they are not enabled." | ||||||
| @@ -339,7 +341,7 @@ recaptcha: "reCAPTCHA" | |||||||
| enableRecaptcha: "Enable reCAPTCHA" | enableRecaptcha: "Enable reCAPTCHA" | ||||||
| recaptchaSiteKey: "Site key" | recaptchaSiteKey: "Site key" | ||||||
| recaptchaSecretKey: "Secret key" | recaptchaSecretKey: "Secret key" | ||||||
| avoidMultiCaptchaConfirm: "Using multiple Captchas may cause interference. Would you like to disable the other Captcha? You can leave multiple Captchas enabled by press cancel." | avoidMultiCaptchaConfirm: "Using multiple Captchas may cause interferences. Would you like to disable the other Captcha? You can leave multiple Captchas enabled by pressing cancel." | ||||||
| antennas: "Antennas" | antennas: "Antennas" | ||||||
| manageAntennas: "Manage Antennas" | manageAntennas: "Manage Antennas" | ||||||
| name: "Name" | name: "Name" | ||||||
| @@ -349,7 +351,6 @@ antennaExcludeKeywords: "Keywords to exclude" | |||||||
| antennaKeywordsDescription: "Separate with spaces for AND condition. Separate with line breaks for OR." | antennaKeywordsDescription: "Separate with spaces for AND condition. Separate with line breaks for OR." | ||||||
| notifyAntenna: "Notify for new notes" | notifyAntenna: "Notify for new notes" | ||||||
| withFileAntenna: "Filter only notes with file(s) attached" | withFileAntenna: "Filter only notes with file(s) attached" | ||||||
| serviceworker: "ServiceWorker" |  | ||||||
| enableServiceworker: "Enable ServiceWorker" | enableServiceworker: "Enable ServiceWorker" | ||||||
| antennaUsersDescription: "List one username per line" | antennaUsersDescription: "List one username per line" | ||||||
| caseSensitive: "Case sensitive" | caseSensitive: "Case sensitive" | ||||||
| @@ -453,7 +454,7 @@ category: "Category" | |||||||
| tags: "Tags" | tags: "Tags" | ||||||
| docSource: "Source of this document" | docSource: "Source of this document" | ||||||
| createAccount: "Create account" | createAccount: "Create account" | ||||||
| existingAcount: "Existing accounts" | existingAccount: "Existing account" | ||||||
| regenerate: "Regenerate" | regenerate: "Regenerate" | ||||||
| fontSize: "Font size" | fontSize: "Font size" | ||||||
| noFollowRequests: "You don't have any pending follow requests" | noFollowRequests: "You don't have any pending follow requests" | ||||||
| @@ -546,6 +547,8 @@ disablePlayer: "Close video player" | |||||||
| expandTweet: "Expand tweet" | expandTweet: "Expand tweet" | ||||||
| themeEditor: "Theme editor" | themeEditor: "Theme editor" | ||||||
| description: "Description" | description: "Description" | ||||||
|  | describeFile: "Add caption" | ||||||
|  | enterFileDescription: "Enter caption" | ||||||
| author: "Author" | author: "Author" | ||||||
| leaveConfirm: "There are unsaved changes. Do you want to discard them?" | leaveConfirm: "There are unsaved changes. Do you want to discard them?" | ||||||
| manage: "Management" | manage: "Management" | ||||||
| @@ -568,7 +571,7 @@ pluginTokenRequestedDescription: "This plugin will be able to use the permission | |||||||
| notificationType: "Notification type" | notificationType: "Notification type" | ||||||
| edit: "Edit" | edit: "Edit" | ||||||
| useStarForReactionFallback: "Use ★ as fallback if the reaction emoji is unknown" | useStarForReactionFallback: "Use ★ as fallback if the reaction emoji is unknown" | ||||||
| emailConfig: "Email server configuration" | emailServer: "Email server" | ||||||
| enableEmail: "Enable email distribution" | enableEmail: "Enable email distribution" | ||||||
| emailConfigInfo: "Used to confirm your email during sign-up and if you forget your password" | emailConfigInfo: "Used to confirm your email during sign-up and if you forget your password" | ||||||
| email: "Email" | email: "Email" | ||||||
| @@ -679,7 +682,7 @@ onlineUsersCount: "{n} people are online" | |||||||
| nUsers: "{n} Users" | nUsers: "{n} Users" | ||||||
| nNotes: "{n} Notes" | nNotes: "{n} Notes" | ||||||
| sendErrorReports: "Send error reports" | sendErrorReports: "Send error reports" | ||||||
| sendErrorReportsDescription: "When turned on, detailed error information will be shared with Misskey when a problem occurs, helping to improve the quality of Misskey." | sendErrorReportsDescription: "When turned on, detailed error information will be shared with Misskey when a problem occurs, helping to improve the quality of Misskey.\nThis may include informations such as your OS and its version, the kind of browser you're using, your activity history, etc." | ||||||
| myTheme: "My theme" | myTheme: "My theme" | ||||||
| backgroundColor: "Background" | backgroundColor: "Background" | ||||||
| accentColor: "Accent" | accentColor: "Accent" | ||||||
| @@ -687,6 +690,7 @@ textColor: "Text" | |||||||
| saveAs: "Save as..." | saveAs: "Save as..." | ||||||
| advanced: "Advanced" | advanced: "Advanced" | ||||||
| value: "Value" | value: "Value" | ||||||
|  | createdAt: "Created on" | ||||||
| updatedAt: "Updated at" | updatedAt: "Updated at" | ||||||
| saveConfirm: "Save changes?" | saveConfirm: "Save changes?" | ||||||
| deleteConfirm: "Really delete?" | deleteConfirm: "Really delete?" | ||||||
| @@ -704,12 +708,70 @@ editCode: "Edit code" | |||||||
| apply: "Apply" | apply: "Apply" | ||||||
| receiveAnnouncementFromInstance: "Receive Email notifications from this instance" | receiveAnnouncementFromInstance: "Receive Email notifications from this instance" | ||||||
| emailNotification: "Email notifications" | emailNotification: "Email notifications" | ||||||
|  | publish: "Publish" | ||||||
| inChannelSearch: "Search in channel" | inChannelSearch: "Search in channel" | ||||||
| useReactionPickerForContextMenu: "Open reaction picker on right-click" | useReactionPickerForContextMenu: "Open reaction picker on right-click" | ||||||
| typingUsers: "{users} is/are typing..." | typingUsers: "{users} is/are typing..." | ||||||
| jumpToSpecifiedDate: "Jump to specific date" | jumpToSpecifiedDate: "Jump to specific date" | ||||||
| showingPastTimeline: "Currently displaying an old timeline" | showingPastTimeline: "Currently displaying an old timeline" | ||||||
| clear: "Return" | clear: "Return" | ||||||
|  | markAllAsRead: "Mark all as read" | ||||||
|  | goBack: "Back" | ||||||
|  | unlikeConfirm: "Really remove your like?" | ||||||
|  | fullView: "Full view" | ||||||
|  | quitFullView: "Exit full view" | ||||||
|  | addDescription: "Add description" | ||||||
|  | userPagePinTip: "You can make notes be displayed here by selecting \"Pin to profile\" from the menu of individual notes" | ||||||
|  | notSpecifiedMentionWarning: "This note contains mentions of users not included as recipient" | ||||||
|  | info: "About" | ||||||
|  | userInfo: "User information" | ||||||
|  | unknown: "Unknown" | ||||||
|  | onlineStatus: "Online status" | ||||||
|  | hideOnlineStatus: "Hide online status" | ||||||
|  | hideOnlineStatusDescription: "Hiding your online status reduces the convenience of some functions such as search" | ||||||
|  | online: "Online" | ||||||
|  | active: "Active" | ||||||
|  | offline: "Offline" | ||||||
|  | notRecommended: "Not recommended" | ||||||
|  | botProtection: "Bot Protection" | ||||||
|  | instanceBlocking: "Blocked Instances" | ||||||
|  | selectAccount: "Select account" | ||||||
|  | enabled: "Enabled" | ||||||
|  | disabled: "Disabled" | ||||||
|  | quickAction: "Quick action" | ||||||
|  | user: "Users" | ||||||
|  | administration: "Management" | ||||||
|  | accounts: "Accounts" | ||||||
|  | switch: "Switch" | ||||||
|  | noMaintainerInformationWarning: "Maintainer information is not configured." | ||||||
|  | noBotProtectionWarning: "Bot protection is not configured." | ||||||
|  | configure: "Configure" | ||||||
|  | postToGallery: "Post to Gallery" | ||||||
|  | gallery: "Gallery" | ||||||
|  | recentPosts: "Recent posts" | ||||||
|  | popularPosts: "Popular posts" | ||||||
|  | shareWithNote: "Share with note" | ||||||
|  | ads: "Advertisements" | ||||||
|  | expiration: "Deadline" | ||||||
|  | memo: "Memo" | ||||||
|  | priority: "Priority" | ||||||
|  | high: "High" | ||||||
|  | middle: "Medium" | ||||||
|  | low: "Low" | ||||||
|  | emailNotConfiguredWarning: "Email address not set" | ||||||
|  | ratio: "Ratio" | ||||||
|  | _ad: | ||||||
|  |   back: "Back" | ||||||
|  |   reduceFrequencyOfThisAd: "Show this ad less" | ||||||
|  | _forgotPassword: | ||||||
|  |   enterEmail: "Enter the email address you used to register. A link with which you can reset your password will then be sent to it." | ||||||
|  |   ifNoEmail: "If you did not use an email during registration, please contact the administrator instead." | ||||||
|  |   contactAdmin: "This instance does not support using email addresses, please contact the administrator to reset your password instead." | ||||||
|  | _gallery: | ||||||
|  |   my: "My Gallery" | ||||||
|  |   liked: "Liked Posts" | ||||||
|  |   like: "Like" | ||||||
|  |   unlike: "Undo like" | ||||||
| _email: | _email: | ||||||
|   _follow: |   _follow: | ||||||
|     title: "You've got a new follower" |     title: "You've got a new follower" | ||||||
| @@ -865,6 +927,7 @@ _theme: | |||||||
|   install: "Install theme" |   install: "Install theme" | ||||||
|   manage: "Themes manager" |   manage: "Themes manager" | ||||||
|   code: "Theme code" |   code: "Theme code" | ||||||
|  |   description: "Description" | ||||||
|   installed: "{name} has been installed" |   installed: "{name} has been installed" | ||||||
|   installedThemes: "Installed themes" |   installedThemes: "Installed themes" | ||||||
|   builtinThemes: "Built-in themes" |   builtinThemes: "Built-in themes" | ||||||
| @@ -1026,7 +1089,7 @@ _auth: | |||||||
|   permissionAsk: "This application requires following permissions:" |   permissionAsk: "This application requires following permissions:" | ||||||
|   pleaseGoBack: "Please go back to the application" |   pleaseGoBack: "Please go back to the application" | ||||||
|   callback: "Returning back to the application" |   callback: "Returning back to the application" | ||||||
|   denied: "Access Denied" |   denied: "Access denied" | ||||||
| _antennaSources: | _antennaSources: | ||||||
|   all: "All notes" |   all: "All notes" | ||||||
|   homeTimeline: "Notes from following users" |   homeTimeline: "Notes from following users" | ||||||
|   | |||||||
| @@ -1,5 +1,6 @@ | |||||||
| --- | --- | ||||||
| _lang_: "Español" | _lang_: "Español" | ||||||
|  | headlineMisskey: "Red conectada por notas" | ||||||
| introMisskey: "¡Bienvenido/a! Misskey es un servicio de microblogging descentralizado de código abierto.\nEscribe \"notas\" para compartir lo que te ocurre ahora o para contar sobre ti a todos 📡\nCon la función de \"reacciones\", puedes también añadir una reacción rápida a las notas de todos 👍\nExplora un nuevo mundo 🚀" | introMisskey: "¡Bienvenido/a! Misskey es un servicio de microblogging descentralizado de código abierto.\nEscribe \"notas\" para compartir lo que te ocurre ahora o para contar sobre ti a todos 📡\nCon la función de \"reacciones\", puedes también añadir una reacción rápida a las notas de todos 👍\nExplora un nuevo mundo 🚀" | ||||||
| monthAndDay: "{day}/{month}" | monthAndDay: "{day}/{month}" | ||||||
| search: "Buscar" | search: "Buscar" | ||||||
| @@ -137,7 +138,7 @@ flagAsBotDescription: "En caso de que esta cuenta fuera usada por un programa, a | |||||||
| flagAsCat: "Esta cuenta es un gato" | flagAsCat: "Esta cuenta es un gato" | ||||||
| flagAsCatDescription: "En caso de que declare que esta cuenta es de un gato, active esta opción." | flagAsCatDescription: "En caso de que declare que esta cuenta es de un gato, active esta opción." | ||||||
| autoAcceptFollowed: "Aceptar automáticamente las solicitudes de seguimiento de los usuarios que sigues" | autoAcceptFollowed: "Aceptar automáticamente las solicitudes de seguimiento de los usuarios que sigues" | ||||||
| addAcount: "Agregar cuenta" | addAccount: "Agregar Cuenta" | ||||||
| loginFailed: "Error al iniciar sesión." | loginFailed: "Error al iniciar sesión." | ||||||
| showOnRemote: "Ver en una instancia remota" | showOnRemote: "Ver en una instancia remota" | ||||||
| general: "General" | general: "General" | ||||||
| @@ -308,8 +309,6 @@ monthX: "Mes {month}" | |||||||
| yearX: "Año {year}" | yearX: "Año {year}" | ||||||
| pages: "Páginas" | pages: "Páginas" | ||||||
| integration: "Integración" | integration: "Integración" | ||||||
| connectSerice: "Conectarse" |  | ||||||
| disconnectSerice: "Desconectarse" |  | ||||||
| enableLocalTimeline: "Habilitar linea de tiempo local" | enableLocalTimeline: "Habilitar linea de tiempo local" | ||||||
| enableGlobalTimeline: "Habilitar linea de tiempo global" | enableGlobalTimeline: "Habilitar linea de tiempo global" | ||||||
| disablingTimelinesInfo: "Aunque se desactiven estas lineas de tiempo, por conveniencia el administrador y los moderadores pueden seguir usándolos" | disablingTimelinesInfo: "Aunque se desactiven estas lineas de tiempo, por conveniencia el administrador y los moderadores pueden seguir usándolos" | ||||||
| @@ -348,7 +347,6 @@ antennaExcludeKeywords: "Palabras clave para excluir" | |||||||
| antennaKeywordsDescription: "Separar con espacios es una declaración AND, separar con una linea nueva es una declaración OR" | antennaKeywordsDescription: "Separar con espacios es una declaración AND, separar con una linea nueva es una declaración OR" | ||||||
| notifyAntenna: "Notificar nueva nota" | notifyAntenna: "Notificar nueva nota" | ||||||
| withFileAntenna: "Sólo notas con archivos adjuntados" | withFileAntenna: "Sólo notas con archivos adjuntados" | ||||||
| serviceworker: "ServiceWorker" |  | ||||||
| enableServiceworker: "Activar ServiceWorker" | enableServiceworker: "Activar ServiceWorker" | ||||||
| antennaUsersDescription: "Elegir nombres de usuarios separados por una linea nueva" | antennaUsersDescription: "Elegir nombres de usuarios separados por una linea nueva" | ||||||
| caseSensitive: "Distinguir mayúsculas de minúsculas" | caseSensitive: "Distinguir mayúsculas de minúsculas" | ||||||
| @@ -437,6 +435,7 @@ signinWith: "Inicie sesión con {x}" | |||||||
| signinFailed: "Autenticación fallida. Asegúrate de haber usado el nombre de usuario y contraseña correctos." | signinFailed: "Autenticación fallida. Asegúrate de haber usado el nombre de usuario y contraseña correctos." | ||||||
| tapSecurityKey: "Toque la clave de seguridad" | tapSecurityKey: "Toque la clave de seguridad" | ||||||
| or: "O" | or: "O" | ||||||
|  | language: "Idioma" | ||||||
| uiLanguage: "Idioma de visualización de la interfaz" | uiLanguage: "Idioma de visualización de la interfaz" | ||||||
| groupInvited: "Invitado al grupo" | groupInvited: "Invitado al grupo" | ||||||
| aboutX: "Acerca de {x}" | aboutX: "Acerca de {x}" | ||||||
| @@ -451,7 +450,7 @@ category: "Categoría" | |||||||
| tags: "Etiqueta" | tags: "Etiqueta" | ||||||
| docSource: "Fuente de este documento" | docSource: "Fuente de este documento" | ||||||
| createAccount: "Crear cuenta" | createAccount: "Crear cuenta" | ||||||
| existingAcount: "Cuentas existentes" | existingAccount: "Cuenta existente" | ||||||
| regenerate: "Regenerar" | regenerate: "Regenerar" | ||||||
| fontSize: "Tamaño de la letra" | fontSize: "Tamaño de la letra" | ||||||
| noFollowRequests: "No hay solicitudes de seguimiento" | noFollowRequests: "No hay solicitudes de seguimiento" | ||||||
| @@ -566,7 +565,7 @@ pluginTokenRequestedDescription: "Este plugin podrá usar los permisos descritos | |||||||
| notificationType: "Tipo de notificación" | notificationType: "Tipo de notificación" | ||||||
| edit: "Editar" | edit: "Editar" | ||||||
| useStarForReactionFallback: "En caso de que los emojis de reacciones no sean claros, usar en su lugar una estrella" | useStarForReactionFallback: "En caso de que los emojis de reacciones no sean claros, usar en su lugar una estrella" | ||||||
| emailConfig: "Configuración del servidor de correos" | emailServer: "Servidor de correo" | ||||||
| enableEmail: "Activar el envío de correos electrónicos" | enableEmail: "Activar el envío de correos electrónicos" | ||||||
| emailConfigInfo: "Usar en caso de validación de correo electrónico y pedido de contraseña" | emailConfigInfo: "Usar en caso de validación de correo electrónico y pedido de contraseña" | ||||||
| email: "Correo" | email: "Correo" | ||||||
| @@ -646,12 +645,30 @@ driveFilesCount: "Cantidad de archivos en el drive" | |||||||
| driveUsage: "Uso del drive" | driveUsage: "Uso del drive" | ||||||
| noCrawle: "Rechazar indexación del crawler" | noCrawle: "Rechazar indexación del crawler" | ||||||
| noCrawleDescription: "Pedir a los motores de búsqueda que no indexen tu perfil, notas, páginas, etc." | noCrawleDescription: "Pedir a los motores de búsqueda que no indexen tu perfil, notas, páginas, etc." | ||||||
|  | alwaysMarkSensitive: "Marcar los medios de comunicación como contenido sensible por defecto" | ||||||
|  | verificationEmailSent: "Se le ha enviado un correo electrónico de confirmación. Por favor, acceda al enlace proporcionado en el correo electrónico para completar la configuración." | ||||||
|  | notSet: "Sin especificar" | ||||||
|  | emailVerified: "Su dirección de correo electrónico ha sido verificada." | ||||||
|  | noteFavoritesCount: "Número de notas favoritas" | ||||||
|  | pageLikesCount: "Número de favoritos en la página" | ||||||
|  | pageLikedCount: "Número de favoritos de su página" | ||||||
|  | contact: "Contacto" | ||||||
| clips: "Clip" | clips: "Clip" | ||||||
| clearCache: "Limpiar caché" | clearCache: "Limpiar caché" | ||||||
| backgroundColor: "Fondo" | backgroundColor: "Fondo" | ||||||
| accentColor: "Acento" | accentColor: "Acento" | ||||||
| textColor: "Texto" | textColor: "Texto" | ||||||
| value: "Valores" | value: "Valores" | ||||||
|  | goBack: "Deseleccionar" | ||||||
|  | info: "Información" | ||||||
|  | user: "Usuarios" | ||||||
|  | administration: "Administrar" | ||||||
|  | expiration: "Termina el" | ||||||
|  | middle: "Mediano" | ||||||
|  | _ad: | ||||||
|  |   back: "Deseleccionar" | ||||||
|  | _gallery: | ||||||
|  |   unlike: "Quitar me gusta" | ||||||
| _email: | _email: | ||||||
|   _follow: |   _follow: | ||||||
|     title: "te ha seguido" |     title: "te ha seguido" | ||||||
| @@ -745,6 +762,7 @@ _theme: | |||||||
|   install: "Instalar tema" |   install: "Instalar tema" | ||||||
|   manage: "Gestor de temas" |   manage: "Gestor de temas" | ||||||
|   code: "Código del tema" |   code: "Código del tema" | ||||||
|  |   description: "Descripción" | ||||||
|   installed: "{name} ha sido instalado" |   installed: "{name} ha sido instalado" | ||||||
|   alreadyInstalled: "Este tema ya está instalado" |   alreadyInstalled: "Este tema ya está instalado" | ||||||
|   invalid: "El formato del tema no es válido" |   invalid: "El formato del tema no es válido" | ||||||
|   | |||||||
| @@ -7,6 +7,7 @@ search: "Rechercher" | |||||||
| notifications: "Notifications" | notifications: "Notifications" | ||||||
| username: "Nom d’utilisateur·rice" | username: "Nom d’utilisateur·rice" | ||||||
| password: "Mot de passe" | password: "Mot de passe" | ||||||
|  | forgotPassword: "Mot de passe oublié" | ||||||
| fetchingAsApObject: "Récupération depuis le fédiverse …" | fetchingAsApObject: "Récupération depuis le fédiverse …" | ||||||
| ok: "OK" | ok: "OK" | ||||||
| gotIt: "J’ai compris !" | gotIt: "J’ai compris !" | ||||||
| @@ -110,7 +111,7 @@ attachCancel: "Supprimer le fichier attaché" | |||||||
| markAsSensitive: "Marquer comme sensible" | markAsSensitive: "Marquer comme sensible" | ||||||
| unmarkAsSensitive: "Supprimer le marquage comme sensible" | unmarkAsSensitive: "Supprimer le marquage comme sensible" | ||||||
| enterFileName: "Entrer le nom du fichier" | enterFileName: "Entrer le nom du fichier" | ||||||
| mute: "Mettre en sourdine" | mute: "Masquer" | ||||||
| unmute: "Ne plus masquer" | unmute: "Ne plus masquer" | ||||||
| block: "Bloquer" | block: "Bloquer" | ||||||
| unblock: "Débloquer" | unblock: "Débloquer" | ||||||
| @@ -138,7 +139,7 @@ flagAsBotDescription: "Si ce compte est géré de manière automatisée , défin | |||||||
| flagAsCat: "Ce compte est un chat" | flagAsCat: "Ce compte est un chat" | ||||||
| flagAsCatDescription: "Activer l'option \" Je suis un chat \" pour ce compte." | flagAsCatDescription: "Activer l'option \" Je suis un chat \" pour ce compte." | ||||||
| autoAcceptFollowed: "Accepter automatiquement les demandes d’abonnement venant d’utilisateur·rice·s que vous suivez" | autoAcceptFollowed: "Accepter automatiquement les demandes d’abonnement venant d’utilisateur·rice·s que vous suivez" | ||||||
| addAcount: "Ajouter un compte" | addAccount: "Ajouter un compte" | ||||||
| loginFailed: "Échec de la connexion" | loginFailed: "Échec de la connexion" | ||||||
| showOnRemote: "Voir sur l’instance distante" | showOnRemote: "Voir sur l’instance distante" | ||||||
| general: "Général" | general: "Général" | ||||||
| @@ -206,7 +207,7 @@ all: "Tous" | |||||||
| subscribing: "Abonné" | subscribing: "Abonné" | ||||||
| publishing: "Publié" | publishing: "Publié" | ||||||
| notResponding: "Ne répond pas" | notResponding: "Ne répond pas" | ||||||
| instanceFollowing: "Suivre une instance" | instanceFollowing: "Abonnements de l'instance" | ||||||
| instanceFollowers: "Abonné·e·s de l’instance" | instanceFollowers: "Abonné·e·s de l’instance" | ||||||
| instanceUsers: "Utilisateur·rice·s de cette l’instance" | instanceUsers: "Utilisateur·rice·s de cette l’instance" | ||||||
| changePassword: "Modifier votre mot de passe" | changePassword: "Modifier votre mot de passe" | ||||||
| @@ -309,20 +310,18 @@ monthX: "{month}" | |||||||
| yearX: "{year}" | yearX: "{year}" | ||||||
| pages: "Pages" | pages: "Pages" | ||||||
| integration: "Intégrations" | integration: "Intégrations" | ||||||
| connectSerice: "Connecter" |  | ||||||
| disconnectSerice: "Déconnecter" |  | ||||||
| enableLocalTimeline: "Activer le fil local" | enableLocalTimeline: "Activer le fil local" | ||||||
| enableGlobalTimeline: "Activer le fil global" | enableGlobalTimeline: "Activer le fil global" | ||||||
| disablingTimelinesInfo: "Même si vous désactivez ces fils, les administrateur·rice·s et les modérateur·rice·s pourront toujours y accéder." | disablingTimelinesInfo: "Même si vous désactivez ces fils, les administrateur·rice·s et les modérateur·rice·s pourront toujours y accéder." | ||||||
| registration: "S’inscrire" | registration: "S’inscrire" | ||||||
| enableRegistration: "Autoriser les nouvelles inscriptions" | enableRegistration: "Autoriser les nouvelles inscriptions" | ||||||
| invite: "Inviter" | invite: "Inviter" | ||||||
| proxyRemoteFiles: "Proxy fichiers distants" | proxyRemoteFiles: "Utiliser les fichiers distants comme proxy" | ||||||
| proxyRemoteFilesDescription: "Si vous activez ce paramètre, les fichiers distants non stockés ou supprimés en raison d'une capacité excédentaire seront affichés via un proxy local et généreront une miniature. Cela n'affectera pas le stockage du serveur." | proxyRemoteFilesDescription: "Si vous activez ce paramètre, les fichiers distants non stockés ou supprimés en raison d'une capacité excédentaire seront affichés via un proxy local et généreront une miniature. Cela n'affectera pas le stockage du serveur." | ||||||
| driveCapacityPerLocalAccount: "Volume du Drive par utilisateur local" | driveCapacityPerLocalAccount: "Volume du Drive par utilisateur local" | ||||||
| driveCapacityPerRemoteAccount: "Volume du Drive par utilisateur distant" | driveCapacityPerRemoteAccount: "Volume du Drive par utilisateur distant" | ||||||
| inMb: "en mégaoctets" | inMb: "en mégaoctets" | ||||||
| iconUrl: "URL de l’image de l’avatar" | iconUrl: "URL de l'icône" | ||||||
| bannerUrl: "URL de l’image de la bannière" | bannerUrl: "URL de l’image de la bannière" | ||||||
| basicInfo: "Informations basiques" | basicInfo: "Informations basiques" | ||||||
| pinnedUsers: "Utilisateur·rice épinglé·e" | pinnedUsers: "Utilisateur·rice épinglé·e" | ||||||
| @@ -349,7 +348,6 @@ antennaExcludeKeywords: "Mots clés à exclure" | |||||||
| antennaKeywordsDescription: "Séparer avec des espaces pour la condition AND. Séparer avec un saut de ligne pour une condition OR." | antennaKeywordsDescription: "Séparer avec des espaces pour la condition AND. Séparer avec un saut de ligne pour une condition OR." | ||||||
| notifyAntenna: "Je souhaite recevoir les notifications des nouvelles notes" | notifyAntenna: "Je souhaite recevoir les notifications des nouvelles notes" | ||||||
| withFileAntenna: "Notes ayant des attachements uniquement" | withFileAntenna: "Notes ayant des attachements uniquement" | ||||||
| serviceworker: "ServiceWorker" |  | ||||||
| enableServiceworker: "Activer ServiceWorker" | enableServiceworker: "Activer ServiceWorker" | ||||||
| antennaUsersDescription: "Saisissez un seul nom d’utilisateur·rice par ligne" | antennaUsersDescription: "Saisissez un seul nom d’utilisateur·rice par ligne" | ||||||
| caseSensitive: "Sensible à la casse" | caseSensitive: "Sensible à la casse" | ||||||
| @@ -453,7 +451,7 @@ category: "Catégorie" | |||||||
| tags: "Étiquettes" | tags: "Étiquettes" | ||||||
| docSource: "Source de ce document" | docSource: "Source de ce document" | ||||||
| createAccount: "Créer un compte" | createAccount: "Créer un compte" | ||||||
| existingAcount: "Comptes existants" | existingAccount: "Compte existant" | ||||||
| regenerate: "Générer à nouveau" | regenerate: "Générer à nouveau" | ||||||
| fontSize: "Taille de la police" | fontSize: "Taille de la police" | ||||||
| noFollowRequests: "Vous n’avez aucune demande d’abonnement en attente" | noFollowRequests: "Vous n’avez aucune demande d’abonnement en attente" | ||||||
| @@ -487,11 +485,11 @@ objectStorageRegionDesc: "Spécifiez une région comme 'xx-east-1'. Si votre ser | |||||||
| objectStorageUseSSL: "Utiliser SSL" | objectStorageUseSSL: "Utiliser SSL" | ||||||
| objectStorageUseSSLDesc: "Désactivez cette option si vous n'utilisez pas HTTPS pour la connexion API" | objectStorageUseSSLDesc: "Désactivez cette option si vous n'utilisez pas HTTPS pour la connexion API" | ||||||
| objectStorageUseProxy: "Se connecter via proxy" | objectStorageUseProxy: "Se connecter via proxy" | ||||||
| objectStorageUseProxyDesc: "Désactivez cette option si vous n'utilisez pas Proxy pour la connexion API" | objectStorageUseProxyDesc: "Désactivez cette option si vous n'utilisez pas de proxy pour la connexion API" | ||||||
| objectStorageSetPublicRead: "Régler sur « public » lors de l'envoi" | objectStorageSetPublicRead: "Régler sur « public » lors de l'envoi" | ||||||
| serverLogs: "Journal du serveur" | serverLogs: "Journal du serveur" | ||||||
| deleteAll: "Supprimer tout" | deleteAll: "Supprimer tout" | ||||||
| showFixedPostForm: "Afficher le formulaire en haut du fil d'actualité" | showFixedPostForm: "Afficher le formulaire de publication en haut du fil d'actualité" | ||||||
| newNoteRecived: "Vous avez reçu une nouvelle note" | newNoteRecived: "Vous avez reçu une nouvelle note" | ||||||
| sounds: "Sons" | sounds: "Sons" | ||||||
| listen: "Écouter" | listen: "Écouter" | ||||||
| @@ -541,8 +539,8 @@ enableInfiniteScroll: "Activer le défilement infini" | |||||||
| visibility: "Visibilité" | visibility: "Visibilité" | ||||||
| poll: "Sondage" | poll: "Sondage" | ||||||
| useCw: "Masquer le contenu" | useCw: "Masquer le contenu" | ||||||
| enablePlayer: "Activer le lecteur vidéo" | enablePlayer: "Ouvrir dans le lecteur vidéo" | ||||||
| disablePlayer: "Désactiver le lecteur vidéo" | disablePlayer: "Fermer le lecteur vidéo" | ||||||
| expandTweet: "Étendre le tweet" | expandTweet: "Étendre le tweet" | ||||||
| themeEditor: "Éditeur de thèmes" | themeEditor: "Éditeur de thèmes" | ||||||
| description: "Description" | description: "Description" | ||||||
| @@ -568,7 +566,7 @@ pluginTokenRequestedDescription: "Ce plugin pourra utiliser les autorisations d | |||||||
| notificationType: "Type de notifications" | notificationType: "Type de notifications" | ||||||
| edit: "Editer" | edit: "Editer" | ||||||
| useStarForReactionFallback: "Utiliser ★ comme alternative si l’émoji de réaction est inconnu" | useStarForReactionFallback: "Utiliser ★ comme alternative si l’émoji de réaction est inconnu" | ||||||
| emailConfig: "Configuration du serveur email" | emailServer: "Serveur mail" | ||||||
| enableEmail: "Activer la distribution de courriel" | enableEmail: "Activer la distribution de courriel" | ||||||
| emailConfigInfo: "Utilisé pour confirmer votre adresse de courriel et la réinitialisation de votre mot de passe en cas d’oubli." | emailConfigInfo: "Utilisé pour confirmer votre adresse de courriel et la réinitialisation de votre mot de passe en cas d’oubli." | ||||||
| email: "E-mail " | email: "E-mail " | ||||||
| @@ -601,12 +599,13 @@ useGlobalSettingDesc: "S'il est activé, les paramètres de notification de votr | |||||||
| other: "Autre" | other: "Autre" | ||||||
| regenerateLoginToken: "Régénérer le jeton de connexion" | regenerateLoginToken: "Régénérer le jeton de connexion" | ||||||
| regenerateLoginTokenDescription: "Générer un nouveau jeton d'authentification. Cette opération ne devrait pas être nécessaire ; lors de la génération d'un nouveau jeton, tous les appareils seront déconnectés. " | regenerateLoginTokenDescription: "Générer un nouveau jeton d'authentification. Cette opération ne devrait pas être nécessaire ; lors de la génération d'un nouveau jeton, tous les appareils seront déconnectés. " | ||||||
| setMultipleBySeparatingWithSpace: "Vous pouvez définir plus d’un, séparés par des espaces." | setMultipleBySeparatingWithSpace: "Vous pouvez en définir plusieurs, en les séparant par des espaces." | ||||||
| fileIdOrUrl: "ID du fichier ou URL" | fileIdOrUrl: "ID du fichier ou URL" | ||||||
| chatOpenBehavior: "Comportement de la fenêtre de discussion lors de son ouverture" | chatOpenBehavior: "Comportement de la fenêtre de discussion lors de son ouverture" | ||||||
| behavior: "Comportement" | behavior: "Comportement" | ||||||
|  | sample: "Exemple" | ||||||
| abuseReports: "Signalements" | abuseReports: "Signalements" | ||||||
| reportAbuse: "Signalements" | reportAbuse: "Signaler" | ||||||
| reportAbuseOf: "Signaler {name}" | reportAbuseOf: "Signaler {name}" | ||||||
| fillAbuseReportDescription: "Veuillez expliquer les raisons du signalement. S'il s'agit d'une note précise, veuillez en donner le lien." | fillAbuseReportDescription: "Veuillez expliquer les raisons du signalement. S'il s'agit d'une note précise, veuillez en donner le lien." | ||||||
| abuseReported: "Le rapport est envoyé. Merci." | abuseReported: "Le rapport est envoyé. Merci." | ||||||
| @@ -616,12 +615,14 @@ openInNewTab: "Ouvrir dans un nouvel onglet" | |||||||
| openInSideView: "Ouvrir en vue latérale" | openInSideView: "Ouvrir en vue latérale" | ||||||
| defaultNavigationBehaviour: "Navigation par défaut" | defaultNavigationBehaviour: "Navigation par défaut" | ||||||
| editTheseSettingsMayBreakAccount: "La modification de ces paramètres peut endommager votre compte." | editTheseSettingsMayBreakAccount: "La modification de ces paramètres peut endommager votre compte." | ||||||
|  | instanceTicker: "Nom de l'instance d'origine des notes" | ||||||
| waitingFor: "En attente de {x}" | waitingFor: "En attente de {x}" | ||||||
| random: "Aléatoire" | random: "Aléatoire" | ||||||
| system: "Système" | system: "Système" | ||||||
| switchUi: "Modifier l'interface utilisateur" | switchUi: "Modifier l'interface utilisateur" | ||||||
| desktop: "Bureau" | desktop: "Bureau" | ||||||
| clip: "Clip" | clip: "Clip" | ||||||
|  | createNew: "Créer nouveau" | ||||||
| optional: "Facultatif" | optional: "Facultatif" | ||||||
| createNewClip: "Créer un nouveau clip" | createNewClip: "Créer un nouveau clip" | ||||||
| public: "Public" | public: "Public" | ||||||
| @@ -676,7 +677,7 @@ onlineUsersCount: "{n} utilisateur(s) en ligne" | |||||||
| nUsers: "{n} utilisateur·rice·s" | nUsers: "{n} utilisateur·rice·s" | ||||||
| nNotes: "{n} Notes" | nNotes: "{n} Notes" | ||||||
| sendErrorReports: "Envoyer les rapports d’erreur" | sendErrorReports: "Envoyer les rapports d’erreur" | ||||||
| sendErrorReportsDescription: "Lorsqu'il est activé, des informations détaillées sur les erreurs sont partagées avec Misskey lorsqu'un problème survient, ce qui contribue à améliorer la qualité de Misskey." | sendErrorReportsDescription: "Si vous activez l'envoi des rapports d'erreur, vous contribuerez à améliorer la qualité de Misskey grâce au partage d'informations détaillées sur les erreurs lorsqu'un problème survient.\nCela inclut des informations telles que la version de votre système d'exploitation, le type de navigateur que vous utilisez, votre historique d'activité, etc." | ||||||
| myTheme: "Mes thèmes" | myTheme: "Mes thèmes" | ||||||
| backgroundColor: "Arrière-plan" | backgroundColor: "Arrière-plan" | ||||||
| accentColor: "Accentuation" | accentColor: "Accentuation" | ||||||
| @@ -684,6 +685,7 @@ textColor: "Texte" | |||||||
| saveAs: "Enregistrer sous ..." | saveAs: "Enregistrer sous ..." | ||||||
| advanced: "Avancé" | advanced: "Avancé" | ||||||
| value: "Valeur" | value: "Valeur" | ||||||
|  | createdAt: "Date de création" | ||||||
| updatedAt: "Mis à jour le" | updatedAt: "Mis à jour le" | ||||||
| saveConfirm: "Voulez-vous sauvegarder les modifications?" | saveConfirm: "Voulez-vous sauvegarder les modifications?" | ||||||
| deleteConfirm: "Confirmez-vous la suppression?" | deleteConfirm: "Confirmez-vous la suppression?" | ||||||
| @@ -701,12 +703,70 @@ editCode: "Modifier le code" | |||||||
| apply: "Appliquer" | apply: "Appliquer" | ||||||
| receiveAnnouncementFromInstance: "Recevoir les messages d'information de l'instance" | receiveAnnouncementFromInstance: "Recevoir les messages d'information de l'instance" | ||||||
| emailNotification: "Notifications par mail" | emailNotification: "Notifications par mail" | ||||||
|  | publish: "Public" | ||||||
| inChannelSearch: "Chercher dans le canal" | inChannelSearch: "Chercher dans le canal" | ||||||
| useReactionPickerForContextMenu: "Clic-droit pour ouvrir le panneau de réactions" | useReactionPickerForContextMenu: "Clic-droit pour ouvrir le panneau de réactions" | ||||||
| typingUsers: "{users} est en train d'écrire" | typingUsers: "{users} est en train d'écrire" | ||||||
| jumpToSpecifiedDate: "Se rendre à la date" | jumpToSpecifiedDate: "Se rendre à la date" | ||||||
| showingPastTimeline: "Un fil ancien est affiché" | showingPastTimeline: "Un fil ancien est affiché" | ||||||
| clear: "Effacer" | clear: "Effacer" | ||||||
|  | markAllAsRead: "Tout marquer comme lu" | ||||||
|  | goBack: "Retour" | ||||||
|  | unlikeConfirm: "Êtes-vous sûr·e de ne plus vouloir aimer cette publication ?" | ||||||
|  | fullView: "Plein écran" | ||||||
|  | quitFullView: "Quitter le plein écran" | ||||||
|  | addDescription: "Ajouter une description" | ||||||
|  | userPagePinTip: "Vous pouvez afficher des notes ici en sélectionnant l'option « Épingler au profil » dans le menu de chaque note." | ||||||
|  | notSpecifiedMentionWarning: "Vous avez mentionné des utilisateur·rice·s qui ne font pas partie de la liste des destinataires" | ||||||
|  | info: "Informations" | ||||||
|  | userInfo: "Informations sur l'utilisateur" | ||||||
|  | unknown: "Inconnu" | ||||||
|  | onlineStatus: "Statut" | ||||||
|  | hideOnlineStatus: "Se rendre invisible" | ||||||
|  | hideOnlineStatusDescription: "Rendre votre statut invisible peut diminuer les performances de certaines fonctionnalités, telles que la Recherche." | ||||||
|  | online: "En ligne" | ||||||
|  | active: "Actif·ve" | ||||||
|  | offline: "Hors ligne" | ||||||
|  | notRecommended: "Déconseillé" | ||||||
|  | botProtection: "Protection contre les bots" | ||||||
|  | instanceBlocking: "Instances bloquées" | ||||||
|  | selectAccount: "Sélectionner un compte" | ||||||
|  | enabled: "Activé" | ||||||
|  | disabled: "Désactivé" | ||||||
|  | quickAction: "Actions rapides" | ||||||
|  | user: "Utilisateur·rice·s" | ||||||
|  | administration: "Gestion" | ||||||
|  | accounts: "Comptes" | ||||||
|  | switch: "Remplacer" | ||||||
|  | noMaintainerInformationWarning: "Informations administrateur non configurées." | ||||||
|  | noBotProtectionWarning: "La protection contre les bots n'est pas configurée." | ||||||
|  | configure: "Configurer" | ||||||
|  | postToGallery: "Publier dans la galerie" | ||||||
|  | gallery: "Galerie" | ||||||
|  | recentPosts: "Les plus récentes" | ||||||
|  | popularPosts: "Les plus consultées" | ||||||
|  | shareWithNote: "Partager dans une note" | ||||||
|  | ads: "Publicité" | ||||||
|  | expiration: "Échéance" | ||||||
|  | memo: "Pense-bête" | ||||||
|  | priority: "Priorité" | ||||||
|  | high: "Haute" | ||||||
|  | middle: "Moyen" | ||||||
|  | low: "Basse" | ||||||
|  | emailNotConfiguredWarning: "Vous n'avez pas configuré d'adresse e-mail." | ||||||
|  | ratio: "Ratio" | ||||||
|  | _ad: | ||||||
|  |   back: "Retour" | ||||||
|  |   reduceFrequencyOfThisAd: "Voir cette publicité moins souvent" | ||||||
|  | _forgotPassword: | ||||||
|  |   enterEmail: "Entrez ici l'adresse e-mail que vous avez enregistrée pour votre compte. Un lien vous permettant de réinitialiser votre mot de passe sera envoyé à cette adresse." | ||||||
|  |   ifNoEmail: "Si vous n'avez pas enregistré d'adresse e-mail, merci de contacter l'administrateur·rice de votre instance." | ||||||
|  |   contactAdmin: "Cette instance ne permettant pas l'utilisation d'adresses e-mail, prenez contact avec l'administrateur·rice pour procéder à la réinitialisation de votre mot de passe." | ||||||
|  | _gallery: | ||||||
|  |   my: "Mes publications" | ||||||
|  |   liked: " Publications que j'ai aimées" | ||||||
|  |   like: "J'aime" | ||||||
|  |   unlike: "Je n’aime pas" | ||||||
| _email: | _email: | ||||||
|   _follow: |   _follow: | ||||||
|     title: "Vous suit" |     title: "Vous suit" | ||||||
| @@ -717,6 +777,7 @@ _plugin: | |||||||
|   installWarn: "N’installez que des extensions provenant de sources de confiance." |   installWarn: "N’installez que des extensions provenant de sources de confiance." | ||||||
|   manage: "Gestion des plugins" |   manage: "Gestion des plugins" | ||||||
| _registry: | _registry: | ||||||
|  |   scope: "Portée" | ||||||
|   key: "Clé " |   key: "Clé " | ||||||
|   keys: "Clé " |   keys: "Clé " | ||||||
|   domain: "Domaine" |   domain: "Domaine" | ||||||
| @@ -750,18 +811,38 @@ _mfm: | |||||||
|   boldDescription: "Il est possible de mettre le texte en exergue en le mettant en gras." |   boldDescription: "Il est possible de mettre le texte en exergue en le mettant en gras." | ||||||
|   small: "Diminuer l'emphase" |   small: "Diminuer l'emphase" | ||||||
|   smallDescription: "Le contenu peut être affiché en petit et fin." |   smallDescription: "Le contenu peut être affiché en petit et fin." | ||||||
|   center: "Centrée" |   center: "Centrer" | ||||||
|   centerDescription: "Le contenu peut être centré" |   centerDescription: "Le contenu peut être centré" | ||||||
|   inlineCode: "Code (inline)" |   inlineCode: "Code (inline)" | ||||||
|  |   inlineCodeDescription: "Coloration syntaxique des lignes de code." | ||||||
|   blockCode: "Bloc de code" |   blockCode: "Bloc de code" | ||||||
|  |   blockCodeDescription: "Coloration syntaxique des lignes de code pour les blocs multi-lignes." | ||||||
|   inlineMath: "Formule mathématique (inline)" |   inlineMath: "Formule mathématique (inline)" | ||||||
|  |   inlineMathDescription: "Afficher les formules mathématiques (KaTeX)." | ||||||
|   blockMath: "Formule mathématique (bloc)" |   blockMath: "Formule mathématique (bloc)" | ||||||
|  |   blockMathDescription: "Afficher les formules mathématiques (KaTeX) multi-lignes dans un bloc." | ||||||
|   quote: "Citer" |   quote: "Citer" | ||||||
|   quoteDescription: "Affiche le contenu sous forme de citation." |   quoteDescription: "Affiche le contenu sous forme de citation." | ||||||
|   emoji: "Émojis personnalisés" |   emoji: "Émojis personnalisés" | ||||||
|  |   emojiDescription: "Entourez le nom de l'émoji personnalisé de deux points pour l'afficher." | ||||||
|   search: "Rechercher" |   search: "Rechercher" | ||||||
|  |   searchDescription: "Affiche une boîte de recherche avec du texte pré-saisi." | ||||||
|   flip: "Inverser" |   flip: "Inverser" | ||||||
|   flipDescription: "Rotation verticale ou horizontale du contenu" |   flipDescription: "Rotation verticale ou horizontale du contenu" | ||||||
|  |   jelly: "Animation (Gelée)" | ||||||
|  |   jellyDescription: "Donne une animation d'étirement." | ||||||
|  |   tada: "Animation (Tada)" | ||||||
|  |   tadaDescription: "Donne une animation qui donne une impression de \"Tada !\"" | ||||||
|  |   jump: "Animation (Saut)" | ||||||
|  |   jumpDescription: "Donne une animation qui saute." | ||||||
|  |   bounce: "Animation (Rebond)" | ||||||
|  |   bounceDescription: "Donne une animation de rebondissement." | ||||||
|  |   shake: "Animation (Secousse)" | ||||||
|  |   shakeDescription: "Donne une animation tremblante." | ||||||
|  |   twitch: "Animation (Tremblement)" | ||||||
|  |   twitchDescription: "Donne une animation de tremblement intense." | ||||||
|  |   spin: "Animation (Rotation)" | ||||||
|  |   spinDescription: "Donne une animation de rotation." | ||||||
|   x2: "Grand" |   x2: "Grand" | ||||||
|   x2Description: "Afficher le contenu en grand." |   x2Description: "Afficher le contenu en grand." | ||||||
|   x3: "Très grand" |   x3: "Très grand" | ||||||
| @@ -803,9 +884,11 @@ _reversi: | |||||||
|   ended: "Fin de partie" |   ended: "Fin de partie" | ||||||
|   playing: "En cours" |   playing: "En cours" | ||||||
|   isLlotheo: "Celui ou celle qui a le moins de pièces gagne (Llotheo)" |   isLlotheo: "Celui ou celle qui a le moins de pièces gagne (Llotheo)" | ||||||
|  |   loopedMap: "Carte en boucle" | ||||||
|   canPutEverywhere: "Les pions peuvent être placés partout " |   canPutEverywhere: "Les pions peuvent être placés partout " | ||||||
| _instanceTicker: | _instanceTicker: | ||||||
|   none: "Cacher " |   none: "Cacher " | ||||||
|  |   remote: "Montrer pour les utilisateur·ice·s distant·e·s" | ||||||
|   always: "Toujours afficher" |   always: "Toujours afficher" | ||||||
| _serverDisconnectedBehavior: | _serverDisconnectedBehavior: | ||||||
|   reload: "Rechargement automatique" |   reload: "Rechargement automatique" | ||||||
| @@ -823,11 +906,12 @@ _channel: | |||||||
|   notesCount: "{n} Notes" |   notesCount: "{n} Notes" | ||||||
| _sidebar: | _sidebar: | ||||||
|   full: "Complet" |   full: "Complet" | ||||||
|   icon: "Avatar" |   icon: "Icônes" | ||||||
|   hide: "Masquer" |   hide: "Masquer" | ||||||
| _wordMute: | _wordMute: | ||||||
|   muteWords: "Mots à filtrer" |   muteWords: "Mots à filtrer" | ||||||
|   muteWordsDescription: "Séparer avec des espaces pour la condition AND. Séparer avec un saut de ligne pour une condition OR." |   muteWordsDescription: "Séparer avec des espaces pour la condition AND. Séparer avec un saut de ligne pour une condition OR." | ||||||
|  |   muteWordsDescription2: "Pour utiliser des expressions régulières (regex), mettez les mots-clés entre barres obliques." | ||||||
|   softDescription: "Masquez les notes de votre fil selon les paramètres que vous définissez." |   softDescription: "Masquez les notes de votre fil selon les paramètres que vous définissez." | ||||||
|   hardDescription: "Empêchez votre fil de charger les notes selon les paramètres que vous définissez. Cette action est irréversible : si vous modifiez ces paramètres plus tard, les notes précédemment filtrées ne seront pas récupérées." |   hardDescription: "Empêchez votre fil de charger les notes selon les paramètres que vous définissez. Cette action est irréversible : si vous modifiez ces paramètres plus tard, les notes précédemment filtrées ne seront pas récupérées." | ||||||
|   soft: "Doux" |   soft: "Doux" | ||||||
| @@ -838,6 +922,7 @@ _theme: | |||||||
|   install: "Installer un thème" |   install: "Installer un thème" | ||||||
|   manage: "Gestion des thèmes" |   manage: "Gestion des thèmes" | ||||||
|   code: "Code du thème" |   code: "Code du thème" | ||||||
|  |   description: "Description" | ||||||
|   installed: "{name} a été installé" |   installed: "{name} a été installé" | ||||||
|   installedThemes: "Thèmes installés" |   installedThemes: "Thèmes installés" | ||||||
|   builtinThemes: "Thèmes intégrés" |   builtinThemes: "Thèmes intégrés" | ||||||
| @@ -849,17 +934,21 @@ _theme: | |||||||
|   constant: "Constante" |   constant: "Constante" | ||||||
|   defaultValue: "Valeur par défaut" |   defaultValue: "Valeur par défaut" | ||||||
|   color: "Couleur" |   color: "Couleur" | ||||||
|   refConst: "Référencez une constante" |   refProp: "Appeler une propriété" | ||||||
|  |   refConst: "Appeler une constante" | ||||||
|   key: "Clé " |   key: "Clé " | ||||||
|   func: "Fonction" |   func: "Fonction" | ||||||
|   funcKind: "Type de fonction" |   funcKind: "Type de fonction" | ||||||
|   argument: "Argument" |   argument: "Argument" | ||||||
|  |   basedProp: "Nom de la propriété référencée" | ||||||
|   alpha: "Transparence" |   alpha: "Transparence" | ||||||
|   darken: "Assombrir" |   darken: "Sombre" | ||||||
|  |   lighten: "Clair" | ||||||
|   inputConstantName: "Insérez un nom de constante" |   inputConstantName: "Insérez un nom de constante" | ||||||
|   importInfo: "Vous pouvez importer un thème vers l’éditeur de thèmes en saisissant son code ici." |   importInfo: "Vous pouvez importer un thème vers l’éditeur de thèmes en saisissant son code ici." | ||||||
|   deleteConstantConfirm: "Êtes-vous sûr·e de vouloir supprimer la constante {const} ?" |   deleteConstantConfirm: "Êtes-vous sûr·e de vouloir supprimer la constante {const} ?" | ||||||
|   keys: |   keys: | ||||||
|  |     accent: "Accentuation" | ||||||
|     bg: "Arrière-plan" |     bg: "Arrière-plan" | ||||||
|     fg: "Texte" |     fg: "Texte" | ||||||
|     focus: "Mise au point" |     focus: "Mise au point" | ||||||
| @@ -877,31 +966,41 @@ _theme: | |||||||
|     mention: "Mentionner" |     mention: "Mentionner" | ||||||
|     mentionMe: "Mentions (Moi)" |     mentionMe: "Mentions (Moi)" | ||||||
|     renote: "Partager" |     renote: "Partager" | ||||||
|  |     modalBg: "Modal d'arrière-plan" | ||||||
|     divider: "Séparateur" |     divider: "Séparateur" | ||||||
|     scrollbarHandle: "Poignée de la barre de navigation" |     scrollbarHandle: "Poignée de la barre de navigation" | ||||||
|     scrollbarHandleHover: "Poignée de la barre de navigation (survolée)" |     scrollbarHandleHover: "Poignée de la barre de navigation (survolée)" | ||||||
|  |     dateLabelFg: "Texte de l'étiquette de la date" | ||||||
|  |     infoBg: "Arrière-plan pour les informations" | ||||||
|     infoFg: "Texte d'information" |     infoFg: "Texte d'information" | ||||||
|     infoWarnBg: "Arrière-plan des avertissements" |     infoWarnBg: "Arrière-plan des avertissements" | ||||||
|     infoWarnFg: "Texte d’avertissement" |     infoWarnFg: "Texte d’avertissement" | ||||||
|     cwBg: "Arrière-plan du CW" |     cwBg: "Arrière-plan du CW" | ||||||
|     cwFg: "Texte du bouton CW" |     cwFg: "Texte du bouton CW" | ||||||
|     cwHoverBg: "Arrière-plan du bouton CW (survolé)" |     cwHoverBg: "Arrière-plan du bouton CW (survolé)" | ||||||
|  |     toastBg: "Arrière-plan de la bulle de notification" | ||||||
|  |     toastFg: "Texte de la bulle de notification" | ||||||
|     buttonBg: "Arrière-plan du bouton" |     buttonBg: "Arrière-plan du bouton" | ||||||
|     buttonHoverBg: "Arrière-plan du bouton (survolé)" |     buttonHoverBg: "Arrière-plan du bouton (survolé)" | ||||||
|     inputBorder: "Cadre de la zone de texte" |     inputBorder: "Cadre de la zone de texte" | ||||||
|     listItemHoverBg: "Arrière-plan d'item de liste (survolé)" |     listItemHoverBg: "Arrière-plan d'item de liste (survolé)" | ||||||
|     driveFolderBg: "Arrière-plan du dossier de disque" |     driveFolderBg: "Arrière-plan du dossier de disque" | ||||||
|  |     wallpaperOverlay: "Superposition de fond d'écran" | ||||||
|     badge: "Badge" |     badge: "Badge" | ||||||
|     messageBg: "Arrière plan de la discussion" |     messageBg: "Arrière plan de la discussion" | ||||||
|  |     accentDarken: "Plus sombre" | ||||||
|  |     accentLighten: "Plus clair" | ||||||
|     fgHighlighted: "Texte mis en évidence" |     fgHighlighted: "Texte mis en évidence" | ||||||
| _sfx: | _sfx: | ||||||
|   note: "Nouvelle note" |   note: "Nouvelle note" | ||||||
|   noteMy: "Ma note" |   noteMy: "Ma note" | ||||||
|   notification: "Notifications" |   notification: "Notifications" | ||||||
|   chat: "Discuter" |   chat: "Discuter" | ||||||
|   chatBg: "Discuter (De fond)" |   chatBg: "Discussion (arrière-plan)" | ||||||
|   antenna: "Réception de l’antenne" |   antenna: "Réception de l’antenne" | ||||||
|   channel: "Notifications de canal" |   channel: "Notifications de canal" | ||||||
|  |   reversiPutBlack: "Reversi : les pions noirs ont joué" | ||||||
|  |   reversiPutWhite: "Reversi : les pions blancs ont joué" | ||||||
| _ago: | _ago: | ||||||
|   unknown: "Inconnu" |   unknown: "Inconnu" | ||||||
|   future: "Futur" |   future: "Futur" | ||||||
| @@ -930,7 +1029,7 @@ _tutorial: | |||||||
|   step3_3: "Remplissez le cadran et cliquez sur le bouton en haut à droite pour envoyer." |   step3_3: "Remplissez le cadran et cliquez sur le bouton en haut à droite pour envoyer." | ||||||
|   step3_4: "Vous n’avez rien à dire ? Essayez d’écrire « J’ai commencé à utiliser Misskey »." |   step3_4: "Vous n’avez rien à dire ? Essayez d’écrire « J’ai commencé à utiliser Misskey »." | ||||||
|   step4_1: "Avez-vous publié votre première note ?" |   step4_1: "Avez-vous publié votre première note ?" | ||||||
|   step4_2: "Youpi ! Celle-ci est maintenant affiché sur votre fil d’actualité." |   step4_2: "Youpi ! Celle-ci est maintenant affichée sur votre fil d’actualité." | ||||||
|   step5_1: "Maintenant, essayons de nous abonner à d’autres personnes afin de rendre votre fil plus vivant." |   step5_1: "Maintenant, essayons de nous abonner à d’autres personnes afin de rendre votre fil plus vivant." | ||||||
|   step5_2: "La page {featured} affiche les notes en tendance sur la présente instance et {explore} vous permet de trouver des utilisateur·rice·s en tendance. Essayez de vous abonner aux gens que vous aimez !" |   step5_2: "La page {featured} affiche les notes en tendance sur la présente instance et {explore} vous permet de trouver des utilisateur·rice·s en tendance. Essayez de vous abonner aux gens que vous aimez !" | ||||||
|   step5_3: "Pour pouvoir suivre d’autres utilisateur·rice, cliquez sur leur avatar afin d’afficher la page du profil utilisateur ensuite appuyez sur le bouton « S’abonner »." |   step5_3: "Pour pouvoir suivre d’autres utilisateur·rice, cliquez sur leur avatar afin d’afficher la page du profil utilisateur ensuite appuyez sur le bouton « S’abonner »." | ||||||
| @@ -940,29 +1039,29 @@ _tutorial: | |||||||
|   step6_3: "Pour ajouter une réaction à une note, cliquez sur le signe « + » de celle-ci et sélectionnez l’émoji souhaité." |   step6_3: "Pour ajouter une réaction à une note, cliquez sur le signe « + » de celle-ci et sélectionnez l’émoji souhaité." | ||||||
|   step7_1: "Félicitations ! Vous avez atteint la fin du tutoriel de base pour l’utilisation de Misskey." |   step7_1: "Félicitations ! Vous avez atteint la fin du tutoriel de base pour l’utilisation de Misskey." | ||||||
|   step7_2: "Si vous désirez en savoir plus sur Misskey, jetez un œil sur la section {help}." |   step7_2: "Si vous désirez en savoir plus sur Misskey, jetez un œil sur la section {help}." | ||||||
|   step7_3: "Bon courage et amusez-vous bien sur Misskey 🚀" |   step7_3: "Bon courage et amusez-vous bien sur Misskey ! 🚀" | ||||||
| _2fa: | _2fa: | ||||||
|   alreadyRegistered: "Cette étape à déjà été complétée" |   alreadyRegistered: "Configuration déjà achevée." | ||||||
|   registerDevice: "Ajouter un nouvel appareil" |   registerDevice: "Ajouter un nouvel appareil" | ||||||
|   registerKey: "S’inscrire la clé" |   registerKey: "Enregistrer une clef" | ||||||
|   step1: "Tout d'abord, installez une application d'authentification, telle que {a} ou {b}, sur votre appareil." |   step1: "Tout d'abord, installez une application d'authentification, telle que {a} ou {b}, sur votre appareil." | ||||||
|   step2: "Ensuite, scannez le code QR affiché sur l’écran." |   step2: "Ensuite, scannez le code QR affiché sur l’écran." | ||||||
|   step3: "Entrez le jeton affiché sur votre application pour compléter la configuration." |   step3: "Entrez le jeton affiché sur votre application pour compléter la configuration." | ||||||
|   step4: "Lorsque vous vous connectez, entrez le jeton de la même manière." |   step4: "À partir de maintenant, ce même jeton vous sera demandé à chacune de vos connexions." | ||||||
|   securityKeyInfo: "Vous pouvez configurer l'authentification WebAuthN pour sécuriser davantage le processus de connexion avec non seulement la clé de sécurité matérielle qui prend en charge FIDO2, mais également l'authentification par empreinte digitale ou PIN sur votre appareil." |   securityKeyInfo: "Vous pouvez configurer l'authentification WebAuthN pour sécuriser davantage le processus de connexion grâce à une clé de sécurité matérielle qui prend en charge FIDO2, ou bien en configurant l'authentification par empreinte digitale ou par code PIN sur votre appareil." | ||||||
| _permissions: | _permissions: | ||||||
|   "read:account": "Afficher les informations du compte" |   "read:account": "Afficher les informations du compte" | ||||||
|   "write:account": "Mettre à jour les informations de votre compte" |   "write:account": "Mettre à jour les informations de votre compte" | ||||||
|   "read:blocks": "Voir les blocs" |   "read:blocks": "Voir les comptes bloqués" | ||||||
|   "write:blocks": "Écrire des blocs" |   "write:blocks": "Gérer les comptes bloqués" | ||||||
|   "read:drive": "Parcourir le Drive" |   "read:drive": "Parcourir le Drive" | ||||||
|   "write:drive": "Écrire sur le Drive" |   "write:drive": "Écrire sur le Drive" | ||||||
|   "read:favorites": "Afficher les favoris" |   "read:favorites": "Afficher les favoris" | ||||||
|   "write:favorites": "Écrire des favoris" |   "write:favorites": "Gérer les favoris" | ||||||
|   "read:following": "Voir les informations de vos abonnements" |   "read:following": "Voir les informations de vos abonnements" | ||||||
|   "write:following": "Abonnements/Se désabonner" |   "write:following": "Abonnements/Se désabonner" | ||||||
|   "read:messaging": "Cherche à discuter" |   "read:messaging": "Voir vos discussions" | ||||||
|   "write:messaging": "Contrôler le discuter" |   "write:messaging": "Gérer les discussions" | ||||||
|   "read:mutes": "Voir les comptes masqués" |   "read:mutes": "Voir les comptes masqués" | ||||||
|   "write:mutes": "Gérer les comptes masqués" |   "write:mutes": "Gérer les comptes masqués" | ||||||
|   "write:notes": "Créer / supprimer des notes" |   "write:notes": "Créer / supprimer des notes" | ||||||
| @@ -971,10 +1070,10 @@ _permissions: | |||||||
|   "read:reactions": "Lire les réactions" |   "read:reactions": "Lire les réactions" | ||||||
|   "write:reactions": "Gérer vos réactions" |   "write:reactions": "Gérer vos réactions" | ||||||
|   "write:votes": "Voter" |   "write:votes": "Voter" | ||||||
|   "read:pages": "Afficher la page" |   "read:pages": "Voir vos pages" | ||||||
|   "write:pages": "Mettre à jour les Pages" |   "write:pages": "Gérer les pages" | ||||||
|   "read:page-likes": "Voir les favoris sur les Pages" |   "read:page-likes": "Voir les mentions « J'aime » des pages" | ||||||
|   "write:page-likes": "Mettre à jour les favoris sur les Pages" |   "write:page-likes": "Gérer les mentions « J'aime » sur les pages" | ||||||
|   "read:user-groups": "Voir les groupes d'utilisateur·rice·s" |   "read:user-groups": "Voir les groupes d'utilisateur·rice·s" | ||||||
|   "write:user-groups": "Éditer les groupes des utilisateur·rice·s" |   "write:user-groups": "Éditer les groupes des utilisateur·rice·s" | ||||||
|   "read:channels": "Lire les canaux" |   "read:channels": "Lire les canaux" | ||||||
| @@ -1012,7 +1111,7 @@ _widgets: | |||||||
|   photos: "Photos" |   photos: "Photos" | ||||||
|   digitalClock: "Horloge numérique" |   digitalClock: "Horloge numérique" | ||||||
|   federation: "Fédération" |   federation: "Fédération" | ||||||
|   postForm: "Formulaire à publier" |   postForm: "Formulaire de publication" | ||||||
|   slideshow: "Diaporama" |   slideshow: "Diaporama" | ||||||
|   button: "Bouton" |   button: "Bouton" | ||||||
|   onlineUsers: "Utilisateurs en ligne" |   onlineUsers: "Utilisateurs en ligne" | ||||||
| @@ -1063,7 +1162,7 @@ _postForm: | |||||||
|   channelPlaceholder: "Publier vers le canal" |   channelPlaceholder: "Publier vers le canal" | ||||||
|   _placeholders: |   _placeholders: | ||||||
|     a: "Quoi de neuf ?" |     a: "Quoi de neuf ?" | ||||||
|     b: "Quoi de neuf ?" |     b: "Il s'est passé quelque chose ?" | ||||||
|     c: "Qu’avez-vous en tête ?" |     c: "Qu’avez-vous en tête ?" | ||||||
|     d: "Désirez-vous publier quelques mots ?" |     d: "Désirez-vous publier quelques mots ?" | ||||||
|     e: "Écrivez ici" |     e: "Écrivez ici" | ||||||
| @@ -1083,35 +1182,35 @@ _profile: | |||||||
| _exportOrImport: | _exportOrImport: | ||||||
|   allNotes: "Toutes les notes" |   allNotes: "Toutes les notes" | ||||||
|   followingList: "Abonnements" |   followingList: "Abonnements" | ||||||
|   muteList: "Liste des comptes maqués" |   muteList: "Comptes masqués" | ||||||
|   blockingList: "Bloquer" |   blockingList: "Comptes bloqués" | ||||||
|   userLists: "Listes" |   userLists: "Listes" | ||||||
| _charts: | _charts: | ||||||
|   federationInstancesIncDec: "Variation du nombre des instances fédérées" |   federationInstancesIncDec: "Variation du nombre d'instances fédérées" | ||||||
|   federationInstancesTotal: "Nombre total des instances fédérées" |   federationInstancesTotal: "Nombre total d'instances fédérées" | ||||||
|   usersIncDec: "Variation du nombre d'utilisateur·rice·s" |   usersIncDec: "Variation du nombre d'utilisateur·rice·s" | ||||||
|   usersTotal: "Nombre des utilisateur·rice·s au total" |   usersTotal: "Nombre des utilisateur·rice·s au total" | ||||||
|   activeUsers: "Utilisateur·rice·s actif·ve·s" |   activeUsers: "Utilisateur·rice·s actif·ve·s" | ||||||
|   notesIncDec: "Variation du nombre des notes" |   notesIncDec: "Variation du nombre des notes" | ||||||
|   localNotesIncDec: "Variation du nombre de notes local" |   localNotesIncDec: "Variation du nombre de notes locales" | ||||||
|   remoteNotesIncDec: "Variation du nombre d’notes distant" |   remoteNotesIncDec: "Variation du nombre de notes distantes" | ||||||
|   notesTotal: "Nombre total des notes" |   notesTotal: "Nombre total des notes" | ||||||
|   filesIncDec: "Variation du nombre de fichiers" |   filesIncDec: "Variation du nombre de fichiers" | ||||||
|   filesTotal: "Nombre de fichiers au total" |   filesTotal: "Nombre total de fichiers" | ||||||
|   storageUsageIncDec: "Variation de l'utilisation du stockage" |   storageUsageIncDec: "Variation de l'utilisation du stockage" | ||||||
|   storageUsageTotal: "Utilisation totale du stockage" |   storageUsageTotal: "Utilisation totale du stockage" | ||||||
| _instanceCharts: | _instanceCharts: | ||||||
|   requests: "Requêtes" |   requests: "Requêtes" | ||||||
|   users: "Variation du nombre d'utilisateur·rice·s" |   users: "Variation du nombre d'utilisateur·rice·s" | ||||||
|   usersTotal: "Nombre d'utilisateur·rice·s au total cumulé" |   usersTotal: "Total cumulé du nombre d'utilisateur·rice·s" | ||||||
|   notes: "Variation du nombre des notes" |   notes: "Variation du nombre de notes" | ||||||
|   notesTotal: "Nombre total cumulé des notes" |   notesTotal: "Nombre total cumulé des notes" | ||||||
|   ff: "Variation des abonné·e·s" |   ff: "Variation des abonné·e·s / abonnements" | ||||||
|   ffTotal: "Nombre d'abonné·e·s au total cumulé" |   ffTotal: "Total cumulé du nombre d'abonné·e·s / abonnements" | ||||||
|   cacheSize: "Variation de la taille du cache" |   cacheSize: "Variation de la taille du cache" | ||||||
|   cacheSizeTotal: "La taille du cache au total cumulé" |   cacheSizeTotal: "Total cumulé de la taille du cache" | ||||||
|   files: "Variation du nombre de fichiers" |   files: "Variation du nombre de fichiers" | ||||||
|   filesTotal: "Nombre de fichiers au total cumulé" |   filesTotal: "Total cumulé du nombre de fichiers" | ||||||
| _timelines: | _timelines: | ||||||
|   home: "Principal" |   home: "Principal" | ||||||
|   local: "Local" |   local: "Local" | ||||||
| @@ -1134,7 +1233,7 @@ _rooms: | |||||||
|     default: "Par défaut" |     default: "Par défaut" | ||||||
|     washitsu: "Style japonnais" |     washitsu: "Style japonnais" | ||||||
|   _furnitures: |   _furnitures: | ||||||
|     milk: "Lait en carton" |     milk: "Brique de lait" | ||||||
|     bed: "Lit" |     bed: "Lit" | ||||||
|     low-table: "Table basse" |     low-table: "Table basse" | ||||||
|     desk: "Bureau" |     desk: "Bureau" | ||||||
| @@ -1153,7 +1252,7 @@ _rooms: | |||||||
|     book: "Livre" |     book: "Livre" | ||||||
|     book2: "Livre 2" |     book2: "Livre 2" | ||||||
|     piano: "Piano" |     piano: "Piano" | ||||||
|     facial-tissue: "Mouchoirs en papier" |     facial-tissue: "Boîte de mouchoirs" | ||||||
|     server: "Serveurs" |     server: "Serveurs" | ||||||
|     moon: "Lune" |     moon: "Lune" | ||||||
|     corkboard: "Tableau en liège" |     corkboard: "Tableau en liège" | ||||||
| @@ -1166,7 +1265,7 @@ _rooms: | |||||||
|     wall-clock: "Horloge murale" |     wall-clock: "Horloge murale" | ||||||
|     photoframe: "Cadre photo" |     photoframe: "Cadre photo" | ||||||
|     cube: "Cube" |     cube: "Cube" | ||||||
|     tv: "Téléviseur" |     tv: "Télé" | ||||||
|     pinguin: "Pingouin" |     pinguin: "Pingouin" | ||||||
|     rubik-cube: "Cube de Rubik" |     rubik-cube: "Cube de Rubik" | ||||||
|     poster-h: "Affiche (horizontale)" |     poster-h: "Affiche (horizontale)" | ||||||
| @@ -1182,13 +1281,13 @@ _rooms: | |||||||
| _pages: | _pages: | ||||||
|   newPage: "Créer une page" |   newPage: "Créer une page" | ||||||
|   editPage: "Modifier une page" |   editPage: "Modifier une page" | ||||||
|   readPage: "Voir la source" |   readPage: "Affichage de la source en cours" | ||||||
|   created: "La page a été créée !" |   created: "La page a été créée !" | ||||||
|   updated: "La page a été mise à jour !" |   updated: "La page a été mise à jour !" | ||||||
|   deleted: "La page a bien été supprimée" |   deleted: "La page a été supprimée" | ||||||
|   pageSetting: "Paramètres de la Page" |   pageSetting: "Paramètres de la Page" | ||||||
|   nameAlreadyExists: "La URL de page spécifiée existe déjà" |   nameAlreadyExists: "L'URL de page spécifiée existe déjà" | ||||||
|   invalidNameTitle: "La URL de la page spécifiée n’est pas valide" |   invalidNameTitle: "L'URL de page spécifiée n’est pas valide" | ||||||
|   invalidNameText: "Assurez-vous qu’il n’est pas vide" |   invalidNameText: "Assurez-vous qu’il n’est pas vide" | ||||||
|   editThisPage: "Éditer cette page" |   editThisPage: "Éditer cette page" | ||||||
|   viewSource: "Afficher la source" |   viewSource: "Afficher la source" | ||||||
| @@ -1203,21 +1302,21 @@ _pages: | |||||||
|   content: "Bloc de page" |   content: "Bloc de page" | ||||||
|   variables: "Variables" |   variables: "Variables" | ||||||
|   title: "Titre" |   title: "Titre" | ||||||
|   url: "URL de page" |   url: "URL de la page" | ||||||
|   summary: "Résumé de page" |   summary: "Résumé de page" | ||||||
|   alignCenter: "Centrée" |   alignCenter: "Centrée" | ||||||
|   hideTitleWhenPinned: "Masquer le titre de la page lorsque celle-ci est épinglée au profil" |   hideTitleWhenPinned: "Masquer le titre de la page lorsque celle-ci est épinglée au profil" | ||||||
|   font: "Police de caractères" |   font: "Police de caractères" | ||||||
|   fontSerif: "Serif" |   fontSerif: "Serif" | ||||||
|   fontSansSerif: "Sans Serif" |   fontSansSerif: "Sans Serif" | ||||||
|   eyeCatchingImageSet: "Définir une image attirante" |   eyeCatchingImageSet: "Définir une image attractive" | ||||||
|   eyeCatchingImageRemove: "Supprimer une image attirante" |   eyeCatchingImageRemove: "Supprimer l'image attractive" | ||||||
|   chooseBlock: "Ajouter un bloc" |   chooseBlock: "Ajouter un bloc" | ||||||
|   selectType: "Choisir un type" |   selectType: "Choisir un type" | ||||||
|   enterVariableName: "Veuillez entrer un nom pour votre variable" |   enterVariableName: "Veuillez entrer un nom pour votre variable" | ||||||
|   variableNameIsAlreadyUsed: "Cette variable est déjà utilisée" |   variableNameIsAlreadyUsed: "Ce nom de variable est déjà utilisé" | ||||||
|   contentBlocks: "Contenu" |   contentBlocks: "Contenu" | ||||||
|   inputBlocks: "Entrée" |   inputBlocks: "Blocs d'entrée" | ||||||
|   specialBlocks: "Spécial" |   specialBlocks: "Spécial" | ||||||
|   blocks: |   blocks: | ||||||
|     text: "Texte" |     text: "Texte" | ||||||
| @@ -1228,17 +1327,17 @@ _pages: | |||||||
|     if: "Si" |     if: "Si" | ||||||
|     _if: |     _if: | ||||||
|       variable: "Variables" |       variable: "Variables" | ||||||
|     post: "Formulaire à publier" |     post: "Formulaire de publication" | ||||||
|     _post: |     _post: | ||||||
|       text: "Contenu" |       text: "Contenu" | ||||||
|       attachCanvasImage: "Publier avec Toile comme image" |       attachCanvasImage: "Publier avec Toile comme image" | ||||||
|       canvasId: "Toile ID" |       canvasId: "Toile ID" | ||||||
|     textInput: "Entrée de textuelle" |     textInput: "Entrée textuelle" | ||||||
|     _textInput: |     _textInput: | ||||||
|       name: "Nom de la variable" |       name: "Nom de la variable" | ||||||
|       text: "Titre" |       text: "Titre" | ||||||
|       default: "Valeur par défaut" |       default: "Valeur par défaut" | ||||||
|     textareaInput: "Entrée de textuelle multiligne" |     textareaInput: "Entrée textuelle multi-ligne" | ||||||
|     _textareaInput: |     _textareaInput: | ||||||
|       name: "Nom de la variable" |       name: "Nom de la variable" | ||||||
|       text: "Titre" |       text: "Titre" | ||||||
| @@ -1253,10 +1352,12 @@ _pages: | |||||||
|       id: "Toile ID" |       id: "Toile ID" | ||||||
|       width: "Largeur" |       width: "Largeur" | ||||||
|       height: "Hauteur" |       height: "Hauteur" | ||||||
|  |     note: "Note intégrée" | ||||||
|     _note: |     _note: | ||||||
|       id: "Identifiant de la note" |       id: "Identifiant de la note" | ||||||
|  |       idDescription: "Pour configurer la note, vous pouvez aussi coller ici l'URL correspondante." | ||||||
|       detailed: "Afficher les détails" |       detailed: "Afficher les détails" | ||||||
|     switch: "Basculer" |     switch: "Interrupteur" | ||||||
|     _switch: |     _switch: | ||||||
|       name: "Nom de la variable" |       name: "Nom de la variable" | ||||||
|       text: "Titre" |       text: "Titre" | ||||||
| @@ -1265,16 +1366,16 @@ _pages: | |||||||
|     _counter: |     _counter: | ||||||
|       name: "Nom de la variable" |       name: "Nom de la variable" | ||||||
|       text: "Titre" |       text: "Titre" | ||||||
|       inc: "Augmenter le chiffre" |       inc: "Augmenter de" | ||||||
|     _button: |     _button: | ||||||
|       text: "Titre" |       text: "Titre" | ||||||
|       colored: "Coloré" |       colored: "Coloré" | ||||||
|       action: "L'opération lorsque le bouton sera pressé" |       action: "Opération à effectuer lorsque le bouton est pressé" | ||||||
|       _action: |       _action: | ||||||
|         dialog: "Afficher une fenêtre de dialogue" |         dialog: "Afficher une fenêtre de dialogue" | ||||||
|         _dialog: |         _dialog: | ||||||
|           content: "Contenu" |           content: "Contenu" | ||||||
|         resetRandom: "Réinitialiser le nombre aléatoire" |         resetRandom: "Réinitialiser un nombre aléatoire" | ||||||
|         pushEvent: "Envoyer un évènement" |         pushEvent: "Envoyer un évènement" | ||||||
|         _pushEvent: |         _pushEvent: | ||||||
|           event: "Nom de l’évènement" |           event: "Nom de l’évènement" | ||||||
| @@ -1288,7 +1389,7 @@ _pages: | |||||||
|     _radioButton: |     _radioButton: | ||||||
|       name: "Nom de la variable" |       name: "Nom de la variable" | ||||||
|       title: "Titre" |       title: "Titre" | ||||||
|       values: "Choix séparés par des sauts de ligne" |       values: "Liste des choix (un par ligne)" | ||||||
|       default: "Valeur par défaut" |       default: "Valeur par défaut" | ||||||
|   script: |   script: | ||||||
|     categories: |     categories: | ||||||
| @@ -1304,7 +1405,7 @@ _pages: | |||||||
|       list: "Listes" |       list: "Listes" | ||||||
|     blocks: |     blocks: | ||||||
|       text: "Texte" |       text: "Texte" | ||||||
|       multiLineText: "Texte (Multi-lignes)" |       multiLineText: "Texte (multi-ligne)" | ||||||
|       textList: "Liste de texte" |       textList: "Liste de texte" | ||||||
|       _textList: |       _textList: | ||||||
|         info: "Veuillez séparer chaque entrée avec un saut de ligne" |         info: "Veuillez séparer chaque entrée avec un saut de ligne" | ||||||
| @@ -1347,10 +1448,10 @@ _pages: | |||||||
|       _mod: |       _mod: | ||||||
|         arg1: "A" |         arg1: "A" | ||||||
|         arg2: "B" |         arg2: "B" | ||||||
|       round: "Décimal rond" |       round: "Arrondir les décimales" | ||||||
|       _round: |       _round: | ||||||
|         arg1: "Numérique" |         arg1: "Numérique" | ||||||
|       eq: "A et B sont équivalents" |       eq: "A et B sont égaux" | ||||||
|       _eq: |       _eq: | ||||||
|         arg1: "A" |         arg1: "A" | ||||||
|         arg2: "B" |         arg2: "B" | ||||||
| @@ -1366,7 +1467,7 @@ _pages: | |||||||
|       _or: |       _or: | ||||||
|         arg1: "A" |         arg1: "A" | ||||||
|         arg2: "B" |         arg2: "B" | ||||||
|       lt: "A est plus petit que B" |       lt: "A est inférieur à B" | ||||||
|       _lt: |       _lt: | ||||||
|         arg1: "A" |         arg1: "A" | ||||||
|         arg2: "B" |         arg2: "B" | ||||||
| @@ -1374,7 +1475,7 @@ _pages: | |||||||
|       _gt: |       _gt: | ||||||
|         arg1: "A" |         arg1: "A" | ||||||
|         arg2: "B" |         arg2: "B" | ||||||
|       ltEq: "A est plus petit ou égal à B" |       ltEq: "A est inférieur ou égal à B" | ||||||
|       _ltEq: |       _ltEq: | ||||||
|         arg1: "A" |         arg1: "A" | ||||||
|         arg2: "B" |         arg2: "B" | ||||||
| @@ -1440,7 +1541,7 @@ _pages: | |||||||
|       numberToString: "Convertir du numérique en texte" |       numberToString: "Convertir du numérique en texte" | ||||||
|       _numberToString: |       _numberToString: | ||||||
|         arg1: "Numérique" |         arg1: "Numérique" | ||||||
|       splitStrByLine: "Séparer le texte par lignes" |       splitStrByLine: "Séparer le texte par des sauts de lignes" | ||||||
|       _splitStrByLine: |       _splitStrByLine: | ||||||
|         arg1: "Texte" |         arg1: "Texte" | ||||||
|       ref: "Variables" |       ref: "Variables" | ||||||
| @@ -1448,7 +1549,7 @@ _pages: | |||||||
|       fn: "Fonction" |       fn: "Fonction" | ||||||
|       _fn: |       _fn: | ||||||
|         slots: "Slots" |         slots: "Slots" | ||||||
|         slots-info: "Veuillez délimiter chaque slot par un saut de ligne" |         slots-info: "Veuillez insérer un seul slot par ligne" | ||||||
|         arg1: "Sortie" |         arg1: "Sortie" | ||||||
|       for: "Répéter" |       for: "Répéter" | ||||||
|       _for: |       _for: | ||||||
| @@ -1482,18 +1583,19 @@ _notification: | |||||||
|   youWereFollowed: "Vous suit" |   youWereFollowed: "Vous suit" | ||||||
|   youReceivedFollowRequest: "Vous avez reçu une demande d’abonnement" |   youReceivedFollowRequest: "Vous avez reçu une demande d’abonnement" | ||||||
|   yourFollowRequestAccepted: "Votre demande d’abonnement a été accepté" |   yourFollowRequestAccepted: "Votre demande d’abonnement a été accepté" | ||||||
|   youWereInvitedToGroup: "Invité au groupe" |   youWereInvitedToGroup: "Invité·e au groupe" | ||||||
|   _types: |   _types: | ||||||
|     all: "Toutes" |     all: "Toutes" | ||||||
|     follow: "Abonnements" |     follow: "Abonnements" | ||||||
|     mention: "Mentionner" |     mention: "Mentions" | ||||||
|     reply: "Réponses" |     reply: "Réponses" | ||||||
|     renote: "Partager" |     renote: "Partager" | ||||||
|     quote: "Citer" |     quote: "Citer" | ||||||
|     reaction: "Réactions" |     reaction: "Réactions" | ||||||
|  |     pollVote: "Votes dans des sondages" | ||||||
|     receiveFollowRequest: "Demande d'abonnement reçue" |     receiveFollowRequest: "Demande d'abonnement reçue" | ||||||
|     followRequestAccepted: "Demande d'abonnement acceptée" |     followRequestAccepted: "Demande d'abonnement acceptée" | ||||||
|     groupInvited: "Invité aux groupes" |     groupInvited: "Invitation à un groupe" | ||||||
|     app: "Notifications provenant des apps" |     app: "Notifications provenant des apps" | ||||||
| _deck: | _deck: | ||||||
|   alwaysShowMainColumn: "Toujours afficher la colonne principale" |   alwaysShowMainColumn: "Toujours afficher la colonne principale" | ||||||
| @@ -1506,7 +1608,7 @@ _deck: | |||||||
|   swapUp: "Déplacer vers le haut" |   swapUp: "Déplacer vers le haut" | ||||||
|   swapDown: "Déplacer vers le bas" |   swapDown: "Déplacer vers le bas" | ||||||
|   stackLeft: "Empiler à gauche" |   stackLeft: "Empiler à gauche" | ||||||
|   popRight: "Vers la droite" |   popRight: "Extraire à droite" | ||||||
|   profile: "Profil" |   profile: "Profil" | ||||||
|   _columns: |   _columns: | ||||||
|     main: "Principale" |     main: "Principale" | ||||||
|   | |||||||
							
								
								
									
										1390
									
								
								locales/id-ID.yml
									
									
									
									
									
								
							
							
						
						
									
										1390
									
								
								locales/id-ID.yml
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -21,6 +21,7 @@ const languages = [ | |||||||
| 	'en-US', | 	'en-US', | ||||||
| 	'es-ES', | 	'es-ES', | ||||||
| 	'fr-FR', | 	'fr-FR', | ||||||
|  | 	'id-ID', | ||||||
| 	'ja-JP', | 	'ja-JP', | ||||||
| 	'ja-KS', | 	'ja-KS', | ||||||
| 	'kab-KAB', | 	'kab-KAB', | ||||||
|   | |||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -7,6 +7,7 @@ search: "検索" | |||||||
| notifications: "通知" | notifications: "通知" | ||||||
| username: "ユーザー名" | username: "ユーザー名" | ||||||
| password: "パスワード" | password: "パスワード" | ||||||
|  | forgotPassword: "パスワードを忘れた" | ||||||
| fetchingAsApObject: "連合に照会中" | fetchingAsApObject: "連合に照会中" | ||||||
| ok: "OK" | ok: "OK" | ||||||
| gotIt: "わかった" | gotIt: "わかった" | ||||||
| @@ -138,7 +139,7 @@ flagAsBotDescription: "このアカウントがプログラムによって運用 | |||||||
| flagAsCat: "Catとして設定" | flagAsCat: "Catとして設定" | ||||||
| flagAsCatDescription: "このアカウントが猫であることを示す場合は、このフラグをオンにします。" | flagAsCatDescription: "このアカウントが猫であることを示す場合は、このフラグをオンにします。" | ||||||
| autoAcceptFollowed: "フォロー中ユーザーからのフォロリクを自動承認" | autoAcceptFollowed: "フォロー中ユーザーからのフォロリクを自動承認" | ||||||
| addAcount: "アカウント追加" | addAccount: "アカウントを追加" | ||||||
| loginFailed: "ログインに失敗しました" | loginFailed: "ログインに失敗しました" | ||||||
| showOnRemote: "リモートで表示" | showOnRemote: "リモートで表示" | ||||||
| general: "全般" | general: "全般" | ||||||
| @@ -183,7 +184,7 @@ clearQueueConfirmTitle: "キューをクリアしますか?" | |||||||
| clearQueueConfirmText: "未配達の投稿は配送されなくなります。通常この操作を行う必要はありません。" | clearQueueConfirmText: "未配達の投稿は配送されなくなります。通常この操作を行う必要はありません。" | ||||||
| clearCachedFiles: "キャッシュをクリア" | clearCachedFiles: "キャッシュをクリア" | ||||||
| clearCachedFilesConfirm: "キャッシュされたリモートファイルをすべて削除しますか?" | clearCachedFilesConfirm: "キャッシュされたリモートファイルをすべて削除しますか?" | ||||||
| blockedInstances: "インスタンスブロック" | blockedInstances: "ブロックしたインスタンス" | ||||||
| blockedInstancesDescription: "ブロックしたいインスタンスのホストを改行で区切って設定します。ブロックされたインスタンスは、このインスタンスとやり取りできなくなります。" | blockedInstancesDescription: "ブロックしたいインスタンスのホストを改行で区切って設定します。ブロックされたインスタンスは、このインスタンスとやり取りできなくなります。" | ||||||
| muteAndBlock: "ミュートとブロック" | muteAndBlock: "ミュートとブロック" | ||||||
| mutedUsers: "ミュートしたユーザー" | mutedUsers: "ミュートしたユーザー" | ||||||
| @@ -278,6 +279,7 @@ emptyDrive: "ドライブは空です" | |||||||
| emptyFolder: "フォルダーは空です" | emptyFolder: "フォルダーは空です" | ||||||
| unableToDelete: "削除できません" | unableToDelete: "削除できません" | ||||||
| inputNewFileName: "新しいファイル名を入力してください" | inputNewFileName: "新しいファイル名を入力してください" | ||||||
|  | inputNewDescription: "新しいキャプションを入力してください" | ||||||
| inputNewFolderName: "新しいフォルダ名を入力してください" | inputNewFolderName: "新しいフォルダ名を入力してください" | ||||||
| circularReferenceFolder: "移動先のフォルダーは、移動するフォルダーのサブフォルダーです。" | circularReferenceFolder: "移動先のフォルダーは、移動するフォルダーのサブフォルダーです。" | ||||||
| hasChildFilesOrFolders: "このフォルダは空でないため、削除できません。" | hasChildFilesOrFolders: "このフォルダは空でないため、削除できません。" | ||||||
| @@ -309,8 +311,8 @@ monthX: "{month}月" | |||||||
| yearX: "{year}年" | yearX: "{year}年" | ||||||
| pages: "ページ" | pages: "ページ" | ||||||
| integration: "連携" | integration: "連携" | ||||||
| connectSerice: "接続する" | connectService: "接続する" | ||||||
| disconnectSerice: "切断する" | disconnectService: "切断する" | ||||||
| enableLocalTimeline: "ローカルタイムラインを有効にする" | enableLocalTimeline: "ローカルタイムラインを有効にする" | ||||||
| enableGlobalTimeline: "グローバルタイムラインを有効にする" | enableGlobalTimeline: "グローバルタイムラインを有効にする" | ||||||
| disablingTimelinesInfo: "これらのタイムラインを無効化しても、利便性のため管理者およびモデレーターは引き続き利用することができます。" | disablingTimelinesInfo: "これらのタイムラインを無効化しても、利便性のため管理者およびモデレーターは引き続き利用することができます。" | ||||||
| @@ -322,7 +324,7 @@ proxyRemoteFilesDescription: "この設定を有効にすると、未保存ま | |||||||
| driveCapacityPerLocalAccount: "ローカルユーザーひとりあたりのドライブ容量" | driveCapacityPerLocalAccount: "ローカルユーザーひとりあたりのドライブ容量" | ||||||
| driveCapacityPerRemoteAccount: "リモートユーザーひとりあたりのドライブ容量" | driveCapacityPerRemoteAccount: "リモートユーザーひとりあたりのドライブ容量" | ||||||
| inMb: "メガバイト単位" | inMb: "メガバイト単位" | ||||||
| iconUrl: "アイコン画像のURL" | iconUrl: "アイコン画像のURL (faviconなど)" | ||||||
| bannerUrl: "バナー画像のURL" | bannerUrl: "バナー画像のURL" | ||||||
| basicInfo: "基本情報" | basicInfo: "基本情報" | ||||||
| pinnedUsers: "ピン留めユーザー" | pinnedUsers: "ピン留めユーザー" | ||||||
| @@ -349,7 +351,6 @@ antennaExcludeKeywords: "除外キーワード" | |||||||
| antennaKeywordsDescription: "スペースで区切るとAND指定になり、改行で区切るとOR指定になります" | antennaKeywordsDescription: "スペースで区切るとAND指定になり、改行で区切るとOR指定になります" | ||||||
| notifyAntenna: "新しいノートを通知する" | notifyAntenna: "新しいノートを通知する" | ||||||
| withFileAntenna: "ファイルが添付されたノートのみ" | withFileAntenna: "ファイルが添付されたノートのみ" | ||||||
| serviceworker: "ServiceWorker" |  | ||||||
| enableServiceworker: "ServiceWorkerを有効にする" | enableServiceworker: "ServiceWorkerを有効にする" | ||||||
| antennaUsersDescription: "ユーザー名を改行で区切って指定します" | antennaUsersDescription: "ユーザー名を改行で区切って指定します" | ||||||
| caseSensitive: "大文字小文字を区別する" | caseSensitive: "大文字小文字を区別する" | ||||||
| @@ -453,7 +454,7 @@ category: "カテゴリ" | |||||||
| tags: "タグ" | tags: "タグ" | ||||||
| docSource: "このドキュメントのソース" | docSource: "このドキュメントのソース" | ||||||
| createAccount: "アカウントを作成" | createAccount: "アカウントを作成" | ||||||
| existingAcount: "既存のアカウント" | existingAccount: "既存のアカウント" | ||||||
| regenerate: "再生成" | regenerate: "再生成" | ||||||
| fontSize: "フォントサイズ" | fontSize: "フォントサイズ" | ||||||
| noFollowRequests: "フォロー申請はありません" | noFollowRequests: "フォロー申請はありません" | ||||||
| @@ -546,6 +547,8 @@ disablePlayer: "プレイヤーを閉じる" | |||||||
| expandTweet: "ツイートを展開する" | expandTweet: "ツイートを展開する" | ||||||
| themeEditor: "テーマエディター" | themeEditor: "テーマエディター" | ||||||
| description: "説明" | description: "説明" | ||||||
|  | describeFile: "キャプションを付ける" | ||||||
|  | enterFileDescription: "キャプションを入力" | ||||||
| author: "作者" | author: "作者" | ||||||
| leaveConfirm: "未保存の変更があります。破棄しますか?" | leaveConfirm: "未保存の変更があります。破棄しますか?" | ||||||
| manage: "管理" | manage: "管理" | ||||||
| @@ -568,7 +571,7 @@ pluginTokenRequestedDescription: "このプラグインはここで設定した | |||||||
| notificationType: "通知の種類" | notificationType: "通知の種類" | ||||||
| edit: "編集" | edit: "編集" | ||||||
| useStarForReactionFallback: "リアクション絵文字が不明な場合、代わりに★を使う" | useStarForReactionFallback: "リアクション絵文字が不明な場合、代わりに★を使う" | ||||||
| emailConfig: "メールサーバー設定" | emailServer: "メールサーバー" | ||||||
| enableEmail: "メール配信機能を有効化する" | enableEmail: "メール配信機能を有効化する" | ||||||
| emailConfigInfo: "メールアドレスの確認やパスワードリセットの際に使います" | emailConfigInfo: "メールアドレスの確認やパスワードリセットの際に使います" | ||||||
| email: "メール" | email: "メール" | ||||||
| @@ -687,6 +690,7 @@ textColor: "文字" | |||||||
| saveAs: "名前を付けて保存" | saveAs: "名前を付けて保存" | ||||||
| advanced: "高度" | advanced: "高度" | ||||||
| value: "値" | value: "値" | ||||||
|  | createdAt: "作成日時" | ||||||
| updatedAt: "更新日時" | updatedAt: "更新日時" | ||||||
| saveConfirm: "保存しますか?" | saveConfirm: "保存しますか?" | ||||||
| deleteConfirm: "削除しますか?" | deleteConfirm: "削除しますか?" | ||||||
| @@ -704,12 +708,73 @@ editCode: "コードを編集" | |||||||
| apply: "適用" | apply: "適用" | ||||||
| receiveAnnouncementFromInstance: "インスタンスからのお知らせを受け取る" | receiveAnnouncementFromInstance: "インスタンスからのお知らせを受け取る" | ||||||
| emailNotification: "メール通知" | emailNotification: "メール通知" | ||||||
|  | publish: "公開" | ||||||
| inChannelSearch: "チャンネル内検索" | inChannelSearch: "チャンネル内検索" | ||||||
| useReactionPickerForContextMenu: "右クリックでリアクションピッカーを開く" | useReactionPickerForContextMenu: "右クリックでリアクションピッカーを開く" | ||||||
| typingUsers: "{users}が入力中" | typingUsers: "{users}が入力中" | ||||||
| jumpToSpecifiedDate: "特定の日付にジャンプ" | jumpToSpecifiedDate: "特定の日付にジャンプ" | ||||||
| showingPastTimeline: "過去のタイムラインを表示しています" | showingPastTimeline: "過去のタイムラインを表示しています" | ||||||
| clear: "クリア" | clear: "クリア" | ||||||
|  | markAllAsRead: "全て既読にする" | ||||||
|  | goBack: "戻る" | ||||||
|  | unlikeConfirm: "いいね解除しますか?" | ||||||
|  | fullView: "フルビュー" | ||||||
|  | quitFullView: "フルビュー解除" | ||||||
|  | addDescription: "説明を追加" | ||||||
|  | userPagePinTip: "個々のノートのメニューから「ピン留め」を選択することで、ここにノートを表示しておくことができます。" | ||||||
|  | notSpecifiedMentionWarning: "宛先に含まれていないメンションがあります" | ||||||
|  | info: "情報" | ||||||
|  | userInfo: "ユーザー情報" | ||||||
|  | unknown: "不明" | ||||||
|  | onlineStatus: "オンライン状態" | ||||||
|  | hideOnlineStatus: "オンライン状態を隠す" | ||||||
|  | hideOnlineStatusDescription: "オンライン状態を隠すと、検索などの一部機能において利便性が低下することがあります。" | ||||||
|  | online: "オンライン" | ||||||
|  | active: "アクティブ" | ||||||
|  | offline: "オフライン" | ||||||
|  | notRecommended: "非推奨" | ||||||
|  | botProtection: "Bot防御" | ||||||
|  | instanceBlocking: "インスタンスブロック" | ||||||
|  | selectAccount: "アカウントを選択" | ||||||
|  | enabled: "有効" | ||||||
|  | disabled: "無効" | ||||||
|  | quickAction: "クイックアクション" | ||||||
|  | user: "ユーザー" | ||||||
|  | administration: "管理" | ||||||
|  | accounts: "アカウント" | ||||||
|  | switch: "切り替え" | ||||||
|  | noMaintainerInformationWarning: "管理者情報が設定されていません。" | ||||||
|  | noBotProtectionWarning: "Bot防御が設定されていません。" | ||||||
|  | configure: "設定する" | ||||||
|  | postToGallery: "ギャラリーへ投稿" | ||||||
|  | gallery: "ギャラリー" | ||||||
|  | recentPosts: "最近の投稿" | ||||||
|  | popularPosts: "人気の投稿" | ||||||
|  | shareWithNote: "ノートで共有" | ||||||
|  | ads: "広告" | ||||||
|  | expiration: "期限" | ||||||
|  | memo: "メモ" | ||||||
|  | priority: "優先度" | ||||||
|  | high: "高" | ||||||
|  | middle: "中" | ||||||
|  | low: "低" | ||||||
|  | emailNotConfiguredWarning: "メールアドレスの設定がされていません。" | ||||||
|  | ratio: "比率" | ||||||
|  |  | ||||||
|  | _ad: | ||||||
|  |   back: "戻る" | ||||||
|  |   reduceFrequencyOfThisAd: "この広告の表示頻度を下げる" | ||||||
|  |  | ||||||
|  | _forgotPassword: | ||||||
|  |   enterEmail: "アカウントに登録したメールアドレスを入力してください。そのアドレス宛てに、パスワードリセット用のリンクが送信されます。" | ||||||
|  |   ifNoEmail: "メールアドレスを登録していない場合は、管理者までお問い合わせください。" | ||||||
|  |   contactAdmin: "このインスタンスではメールがサポートされていないため、パスワードリセットを行う場合は管理者までお問い合わせください。" | ||||||
|  |  | ||||||
|  | _gallery: | ||||||
|  |   my: "自分の投稿" | ||||||
|  |   liked: "いいねした投稿" | ||||||
|  |   like: "いいね!" | ||||||
|  |   unlike: "いいね解除" | ||||||
|  |  | ||||||
| _email: | _email: | ||||||
|   _follow: |   _follow: | ||||||
| @@ -878,6 +943,7 @@ _theme: | |||||||
|   install: "テーマのインストール" |   install: "テーマのインストール" | ||||||
|   manage: "テーマの管理" |   manage: "テーマの管理" | ||||||
|   code: "テーマコード" |   code: "テーマコード" | ||||||
|  |   description: "説明" | ||||||
|   installed: "{name}をインストールしました" |   installed: "{name}をインストールしました" | ||||||
|   installedThemes: "インストールされたテーマ" |   installedThemes: "インストールされたテーマ" | ||||||
|   builtinThemes: "標準のテーマ" |   builtinThemes: "標準のテーマ" | ||||||
|   | |||||||
| @@ -1,5 +1,6 @@ | |||||||
| --- | --- | ||||||
| _lang_: "日本語 (関西弁)" | _lang_: "日本語 (関西弁)" | ||||||
|  | headlineMisskey: "ノートでつながるネットワーク" | ||||||
| introMisskey: "ようお越し!Misskeyは、オープンソースの分散型マイクロブログサービスやねん。\n「ノート」を作って、いま起こっとることを共有したり、あんたについて皆に発信しよう📡\n「リアクション」機能で、皆のノートに素早く反応を追加したりもできるで✌\nほな新しい世界を探検しよか🚀" | introMisskey: "ようお越し!Misskeyは、オープンソースの分散型マイクロブログサービスやねん。\n「ノート」を作って、いま起こっとることを共有したり、あんたについて皆に発信しよう📡\n「リアクション」機能で、皆のノートに素早く反応を追加したりもできるで✌\nほな新しい世界を探検しよか🚀" | ||||||
| monthAndDay: "{month}月 {day}日" | monthAndDay: "{month}月 {day}日" | ||||||
| search: "探す" | search: "探す" | ||||||
| @@ -54,7 +55,7 @@ youGotNewFollower: "フォローされたで" | |||||||
| receiveFollowRequest: "フォローリクエストされたで" | receiveFollowRequest: "フォローリクエストされたで" | ||||||
| followRequestAccepted: "フォローが承認されたで" | followRequestAccepted: "フォローが承認されたで" | ||||||
| mention: "メンション" | mention: "メンション" | ||||||
| mentions: "あんた宛て" | mentions: "うち宛て" | ||||||
| directNotes: "ダイレクト投稿" | directNotes: "ダイレクト投稿" | ||||||
| importAndExport: "インポートとエクスポート" | importAndExport: "インポートとエクスポート" | ||||||
| import: "インポート" | import: "インポート" | ||||||
| @@ -81,7 +82,7 @@ pageLoadError: "ページの読み込みに失敗してしもうたで…" | |||||||
| pageLoadErrorDescription: "これは普通、ネットワークかブラウザキャッシュが原因やからね。キャッシュをクリアするか、もうちっとだけ待ってくれへんか?" | pageLoadErrorDescription: "これは普通、ネットワークかブラウザキャッシュが原因やからね。キャッシュをクリアするか、もうちっとだけ待ってくれへんか?" | ||||||
| enterListName: "リスト名を入れてや" | enterListName: "リスト名を入れてや" | ||||||
| privacy: "プライバシー" | privacy: "プライバシー" | ||||||
| makeFollowManuallyApprove: "ええって言わなフォローできへんようにする" | makeFollowManuallyApprove: "自分が認めた人だけがこのアカウントをフォローできるようにする" | ||||||
| defaultNoteVisibility: "もとからの公開範囲" | defaultNoteVisibility: "もとからの公開範囲" | ||||||
| follow: "フォロー" | follow: "フォロー" | ||||||
| followRequest: "フォローを頼む" | followRequest: "フォローを頼む" | ||||||
| @@ -137,7 +138,6 @@ flagAsBotDescription: "もしこのアカウントがプログラムによって | |||||||
| flagAsCat: "Catやで" | flagAsCat: "Catやで" | ||||||
| flagAsCatDescription: "ワレ、猫ちゃんならこのフラグをつけてみ?" | flagAsCatDescription: "ワレ、猫ちゃんならこのフラグをつけてみ?" | ||||||
| autoAcceptFollowed: "フォローしとるユーザーからのフォローリクエストを勝手に許可しとく" | autoAcceptFollowed: "フォローしとるユーザーからのフォローリクエストを勝手に許可しとく" | ||||||
| addAcount: "アカウント追加" |  | ||||||
| loginFailed: "ログインに失敗してしもうた…" | loginFailed: "ログインに失敗してしもうた…" | ||||||
| showOnRemote: "リモートで見る" | showOnRemote: "リモートで見る" | ||||||
| general: "全般" | general: "全般" | ||||||
| @@ -308,8 +308,6 @@ monthX: "{month}月" | |||||||
| yearX: "{year}年" | yearX: "{year}年" | ||||||
| pages: "ページ" | pages: "ページ" | ||||||
| integration: "連携" | integration: "連携" | ||||||
| connectSerice: "つなげる" |  | ||||||
| disconnectSerice: "切ってまう" |  | ||||||
| enableLocalTimeline: "ローカルタイムラインを使えるようにする" | enableLocalTimeline: "ローカルタイムラインを使えるようにする" | ||||||
| enableGlobalTimeline: "グローバルタイムラインを使えるようにする" | enableGlobalTimeline: "グローバルタイムラインを使えるようにする" | ||||||
| disablingTimelinesInfo: "ここらへんのタイムラインを使えんようにしてしもても、管理者とモデレーターは使えるままになってるで、そうやなかったら不便やからな。" | disablingTimelinesInfo: "ここらへんのタイムラインを使えんようにしてしもても、管理者とモデレーターは使えるままになってるで、そうやなかったら不便やからな。" | ||||||
| @@ -346,7 +344,6 @@ antennaExcludeKeywords: "除外キーワード" | |||||||
| antennaKeywordsDescription: "スペースで区切ったるとAND指定で、改行で区切ったるとOR指定や" | antennaKeywordsDescription: "スペースで区切ったるとAND指定で、改行で区切ったるとOR指定や" | ||||||
| notifyAntenna: "新しいノートを追加すんで" | notifyAntenna: "新しいノートを追加すんで" | ||||||
| withFileAntenna: "なんか添付されたノートだけ" | withFileAntenna: "なんか添付されたノートだけ" | ||||||
| serviceworker: "ServiceWorker" |  | ||||||
| enableServiceworker: "ServiceWorkerをつこて" | enableServiceworker: "ServiceWorkerをつこて" | ||||||
| antennaUsersDescription: "ユーザー名を改行で区切ったってな" | antennaUsersDescription: "ユーザー名を改行で区切ったってな" | ||||||
| caseSensitive: "大文字と小文字は別もんや" | caseSensitive: "大文字と小文字は別もんや" | ||||||
| @@ -392,7 +389,7 @@ markAsReadAllUnreadNotes: "投稿は全て読んだわっ" | |||||||
| markAsReadAllTalkMessages: "チャットはもうぜんぶ読んだわっ" | markAsReadAllTalkMessages: "チャットはもうぜんぶ読んだわっ" | ||||||
| help: "ヘルプ" | help: "ヘルプ" | ||||||
| inputMessageHere: "ここにメッセージ書いてや" | inputMessageHere: "ここにメッセージ書いてや" | ||||||
| close: "さいなら" | close: "閉じる" | ||||||
| group: "グループ" | group: "グループ" | ||||||
| groups: "グループ" | groups: "グループ" | ||||||
| createGroup: "グループを作るで" | createGroup: "グループを作るで" | ||||||
| @@ -433,6 +430,7 @@ passwordMatched: "よし!一致や!" | |||||||
| passwordNotMatched: "一致しとらんで?" | passwordNotMatched: "一致しとらんで?" | ||||||
| signinWith: "{x}でログイン" | signinWith: "{x}でログイン" | ||||||
| or: "それか" | or: "それか" | ||||||
|  | language: "言語" | ||||||
| uiLanguage: "UIの表示言語" | uiLanguage: "UIの表示言語" | ||||||
| groupInvited: "グループに招待されとるで" | groupInvited: "グループに招待されとるで" | ||||||
| aboutX: "{x}について" | aboutX: "{x}について" | ||||||
| @@ -446,7 +444,6 @@ category: "カテゴリ" | |||||||
| tags: "タグ" | tags: "タグ" | ||||||
| docSource: "このドキュメントのソース" | docSource: "このドキュメントのソース" | ||||||
| createAccount: "アカウントを作成" | createAccount: "アカウントを作成" | ||||||
| existingAcount: "既存のアカウント" |  | ||||||
| regenerate: "再生成" | regenerate: "再生成" | ||||||
| fontSize: "フォントサイズ" | fontSize: "フォントサイズ" | ||||||
| noFollowRequests: "フォロー申請はあらへんで" | noFollowRequests: "フォロー申請はあらへんで" | ||||||
| @@ -454,40 +451,365 @@ openImageInNewTab: "画像を新しいタブで開く" | |||||||
| dashboard: "ダッシュボード" | dashboard: "ダッシュボード" | ||||||
| local: "ローカル" | local: "ローカル" | ||||||
| remote: "リモート" | remote: "リモート" | ||||||
|  | total: "合計" | ||||||
|  | weekOverWeekChanges: "前週比" | ||||||
|  | dayOverDayChanges: "前日比" | ||||||
|  | appearance: "見た目" | ||||||
|  | clientSettings: "クライアントの設定" | ||||||
|  | accountSettings: "アカウントの設定" | ||||||
|  | promotion: "宣伝" | ||||||
|  | promote: "宣伝" | ||||||
|  | numberOfDays: "日数" | ||||||
|  | hideThisNote: "このノートは表示せんでいい" | ||||||
|  | showFeaturedNotesInTimeline: "タイムラインにおすすめのノートを表示してや" | ||||||
|  | objectStorage: "オブジェクトストレージ" | ||||||
|  | useObjectStorage: "オブジェクトストレージを使う" | ||||||
|  | objectStorageBaseUrl: "Base URL" | ||||||
|  | objectStorageBaseUrlDesc: "参照に使うにURLやで。CDNやProxyを使用してるんならそのURL、S3: 'https://<bucket>.s3.amazonaws.com'、GCSとかなら: 'https://storage.googleapis.com/<bucket>'。" | ||||||
|  | objectStorageBucket: "Bucket" | ||||||
|  | objectStoragePrefix: "Prefix" | ||||||
|  | objectStorageEndpoint: "Endpoint" | ||||||
|  | objectStorageRegion: "Region" | ||||||
|  | objectStorageUseSSL: "SSLを使う" | ||||||
|  | objectStorageUseProxy: "Proxyを使う" | ||||||
|  | objectStorageUseProxyDesc: "API接続にproxy使わんのやったら切ってくれへん?" | ||||||
|  | objectStorageSetPublicRead: "アップロードした時に'public-read'を設定してや" | ||||||
|  | serverLogs: "サーバーログ" | ||||||
|  | deleteAll: "全て削除してや" | ||||||
|  | showFixedPostForm: "タイムラインの上の方で投稿できるようにやってくれへん?" | ||||||
|  | newNoteRecived: "新しいノートがあるで" | ||||||
|  | sounds: "サウンド" | ||||||
|  | listen: "聴く" | ||||||
|  | none: "なし" | ||||||
|  | showInPage: "ページで表示" | ||||||
|  | popout: "ポップアウト" | ||||||
|  | volume: "音量" | ||||||
|  | masterVolume: "全体の音量" | ||||||
|  | details: "もっと" | ||||||
|  | chooseEmoji: "絵文字を選ぶ" | ||||||
|  | unableToProcess: "なんか作業が止まってしまったようやね" | ||||||
|  | recentUsed: "最近使ったやつ" | ||||||
|  | install: "インストール" | ||||||
|  | uninstall: "アンインストール" | ||||||
|  | installedApps: "インストールされとるアプリ" | ||||||
|  | nothing: "あらへん" | ||||||
|  | installedDate: "インストールした日時" | ||||||
|  | lastUsedDate: "最後に使った日時" | ||||||
|  | state: "状態" | ||||||
|  | sort: "仕分ける" | ||||||
|  | ascendingOrder: "小さい順" | ||||||
|  | descendingOrder: "大きい順" | ||||||
|  | scratchpad: "スクラッチパッド" | ||||||
| scratchpadDescription: "スクラッチパッドではAiScriptを色々試すことができるんや。Misskeyに対して色々できるコードを書いて動かしてみたり、結果を見たりできるで。" | scratchpadDescription: "スクラッチパッドではAiScriptを色々試すことができるんや。Misskeyに対して色々できるコードを書いて動かしてみたり、結果を見たりできるで。" | ||||||
|  | output: "出力" | ||||||
|  | script: "スクリプト" | ||||||
|  | disablePagesScript: "Pagesのスクリプトを無効にしてや" | ||||||
|  | updateRemoteUser: "リモートユーザー情報の更新してくれん?" | ||||||
|  | deleteAllFiles: "すべてのファイルを削除" | ||||||
|  | deleteAllFilesConfirm: "ホンマにすべてのファイルを削除するん?消したもんはもう戻ってこんのやで?" | ||||||
|  | removeAllFollowing: "フォローを全解除" | ||||||
|  | removeAllFollowingDescription: "{host}からのフォローをすべて解除するで。そのインスタンスが消えて無くなった時とかには便利な機能やで。" | ||||||
|  | userSuspended: "このユーザーは...凍結されとる。" | ||||||
|  | userSilenced: "このユーザーは...サイレンスされとる。" | ||||||
|  | sidebar: "サイドバー" | ||||||
|  | divider: "分割線" | ||||||
|  | rooms: "ルーム" | ||||||
|  | relays: "リレー" | ||||||
|  | addRelay: "リレーの追加" | ||||||
|  | inboxUrl: "inboxのURL" | ||||||
|  | addedRelays: "追加済みのリレー" | ||||||
|  | poll: "アンケート" | ||||||
|  | enablePlayer: "プレイヤーを開く" | ||||||
|  | disablePlayer: "プレイヤーを閉じる" | ||||||
|  | expandTweet: "ツイートを展開する" | ||||||
|  | themeEditor: "テーマエディター" | ||||||
|  | description: "説明" | ||||||
|  | author: "作者" | ||||||
| leaveConfirm: "未保存の変更があるで!ほかしてええか?" | leaveConfirm: "未保存の変更があるで!ほかしてええか?" | ||||||
|  | manage: "管理" | ||||||
|  | plugins: "プラグイン" | ||||||
|  | deck: "デッキ" | ||||||
|  | undeck: "デッキ解除" | ||||||
|  | width: "幅" | ||||||
|  | height: "高さ" | ||||||
|  | large: "大" | ||||||
|  | medium: "中" | ||||||
|  | small: "小" | ||||||
|  | edit: "編集" | ||||||
|  | enableEmail: "メール配信を受け取る" | ||||||
| emailConfigInfo: "メールアドレスの確認とかパスワードリセットの時に使うで" | emailConfigInfo: "メールアドレスの確認とかパスワードリセットの時に使うで" | ||||||
|  | email: "メール" | ||||||
|  | emailAddress: "メールアドレス" | ||||||
|  | smtpConfig: "SMTP サーバーの設定" | ||||||
| smtpHost: "ホスト" | smtpHost: "ホスト" | ||||||
|  | smtpPort: "ポート" | ||||||
| smtpUser: "ユーザー名" | smtpUser: "ユーザー名" | ||||||
| smtpPass: "パスワード" | smtpPass: "パスワード" | ||||||
|  | emptyToDisableSmtpAuth: "ユーザー名とパスワードになんも入れんかったら、SMTP認証を無効化するで" | ||||||
|  | smtpSecure: "SMTP 接続に暗黙的なSSL/TLSを使用する" | ||||||
|  | testEmail: "配信テスト" | ||||||
|  | wordMute: "ワードミュート" | ||||||
|  | userSaysSomething: "{name}が何か言ったようやで" | ||||||
|  | makeActive: "使うで" | ||||||
|  | display: "表示" | ||||||
|  | copy: "コピー" | ||||||
|  | metrics: "メトリクス" | ||||||
|  | overview: "概要" | ||||||
|  | logs: "ログ" | ||||||
|  | delayed: "遅延" | ||||||
|  | database: "データベース" | ||||||
|  | channel: "チャンネル" | ||||||
|  | create: "作成" | ||||||
|  | notificationSetting: "通知設定" | ||||||
| notificationSettingDesc: "表示する通知の種類えらんでや。" | notificationSettingDesc: "表示する通知の種類えらんでや。" | ||||||
|  | useGlobalSetting: "グローバル設定を使ってや" | ||||||
|  | other: "その他" | ||||||
|  | regenerateLoginToken: "ログイントークンを再生成" | ||||||
|  | behavior: "動作" | ||||||
|  | sample: "サンプル" | ||||||
|  | abuseReports: "通報" | ||||||
|  | reportAbuse: "通報" | ||||||
|  | reportAbuseOf: "{name}を通報する" | ||||||
|  | send: "送信" | ||||||
|  | abuseMarkAsResolved: "対応したで" | ||||||
|  | openInNewTab: "新しいタブで開く" | ||||||
|  | openInSideView: "サイドビューで開く" | ||||||
|  | defaultNavigationBehaviour: "デフォルトのナビゲーション" | ||||||
|  | editTheseSettingsMayBreakAccount: "このへんの設定をようわからんままイジるとアカウントが壊れて使えんくなるかも知れへんで?" | ||||||
|  | instanceTicker: "ノートのインスタンス情報" | ||||||
|  | waitingFor: "{x}を待っとるで" | ||||||
|  | random: "ランダム" | ||||||
|  | system: "システム" | ||||||
|  | switchUi: "UI切り替え" | ||||||
|  | desktop: "デスクトップ" | ||||||
|  | clip: "クリップ" | ||||||
|  | receivedReactionsCount: "リアクションされた数" | ||||||
|  | pollVotesCount: "アンケートに投票した数" | ||||||
|  | pollVotedCount: "アンケートに投票された数" | ||||||
|  | yes: "はい" | ||||||
|  | no: "いいえ" | ||||||
|  | driveFilesCount: "ドライブのファイル数" | ||||||
| emailVerified: "メールアドレスは確認されたで" | emailVerified: "メールアドレスは確認されたで" | ||||||
| pageLikesCount: "Pageにええやんと思った数" | pageLikesCount: "Pageにええやんと思った数" | ||||||
| pageLikedCount: "Pageにええやんと思ってくれた数" | pageLikedCount: "Pageにええやんと思ってくれた数" | ||||||
|  | clips: "クリップ" | ||||||
|  | duplicate: "複製" | ||||||
|  | left: "左" | ||||||
|  | center: "中央" | ||||||
|  | wide: "広い" | ||||||
|  | narrow: "狭い" | ||||||
| reloadToApplySetting: "設定はページリロード後に反映されるで。今リロードしとくか?" | reloadToApplySetting: "設定はページリロード後に反映されるで。今リロードしとくか?" | ||||||
|  | showTitlebar: "タイトルバーを見せる" | ||||||
| clearCache: "キャッシュをほかす" | clearCache: "キャッシュをほかす" | ||||||
| onlineUsersCount: "{n}人が起きとるで" | onlineUsersCount: "{n}人が起きとるで" | ||||||
|  | nUsers: "{n}ユーザー" | ||||||
|  | nNotes: "{n}ノート" | ||||||
|  | sendErrorReports: "エラーリポートを送る" | ||||||
| sendErrorReportsDescription: "オンにしたら、なんか変なことが起きたときにエラーの詳細がMisskeyに共有されて、ソフトウェアの品質向上に役立てられるんや。エラー情報には、OSのバージョン、ブラウザの種類、行動履歴などが含まれるで。" | sendErrorReportsDescription: "オンにしたら、なんか変なことが起きたときにエラーの詳細がMisskeyに共有されて、ソフトウェアの品質向上に役立てられるんや。エラー情報には、OSのバージョン、ブラウザの種類、行動履歴などが含まれるで。" | ||||||
|  | myTheme: "マイテーマ" | ||||||
|  | backgroundColor: "背景" | ||||||
|  | accentColor: "アクセント" | ||||||
|  | textColor: "文字" | ||||||
|  | saveAs: "名前を付けて保存" | ||||||
|  | advanced: "高度" | ||||||
|  | value: "値" | ||||||
|  | createdAt: "作成した日" | ||||||
|  | updatedAt: "更新日時" | ||||||
|  | saveConfirm: "保存するで?" | ||||||
|  | deleteConfirm: "ホンマに削除するで?" | ||||||
|  | registry: "レジストリ" | ||||||
|  | closeAccount: "アカウントを閉鎖する" | ||||||
|  | currentVersion: "現在のバージョン" | ||||||
|  | latestVersion: "最新のバージョン" | ||||||
| youAreRunningUpToDateClient: "今使ってるクライアントが最新やで!" | youAreRunningUpToDateClient: "今使ってるクライアントが最新やで!" | ||||||
| newVersionOfClientAvailable: "新しいバージョンのクライアントが使えるで。" | newVersionOfClientAvailable: "新しいバージョンのクライアントが使えるで。" | ||||||
|  | usageAmount: "使用量" | ||||||
|  | capacity: "容量" | ||||||
|  | inUse: "使用中" | ||||||
|  | editCode: "コードを編集" | ||||||
|  | apply: "適用" | ||||||
|  | receiveAnnouncementFromInstance: "インスタンスからのお知らせを受け取る" | ||||||
|  | emailNotification: "メール通知" | ||||||
|  | inChannelSearch: "チャンネル内検索" | ||||||
|  | useReactionPickerForContextMenu: "右クリックでリアクションピッカーを開くようにする" | ||||||
|  | typingUsers: "{users}が今書きよるで" | ||||||
|  | jumpToSpecifiedDate: "特定の日付にジャンプ" | ||||||
|  | showingPastTimeline: "過去のタイムラインを表示してるで" | ||||||
|  | clear: "クリア" | ||||||
|  | markAllAsRead: "もうみな読んでもうたわ" | ||||||
|  | goBack: "戻る" | ||||||
|  | info: "情報" | ||||||
|  | user: "ユーザー" | ||||||
|  | administration: "管理" | ||||||
|  | ads: "広告" | ||||||
|  | expiration: "期限" | ||||||
|  | memo: "メモ" | ||||||
|  | high: "高い" | ||||||
|  | middle: "中" | ||||||
|  | low: "低い" | ||||||
|  | _ad: | ||||||
|  |   back: "戻る" | ||||||
|  | _gallery: | ||||||
|  |   unlike: "良くないわ" | ||||||
| _email: | _email: | ||||||
|   _follow: |   _follow: | ||||||
|     title: "フォローされたで" |     title: "フォローされたで" | ||||||
|  |   _receiveFollowRequest: | ||||||
|  |     title: "フォローリクエストを受け取ったで" | ||||||
|  | _plugin: | ||||||
|  |   install: "プラグインのインストール" | ||||||
|  |   installWarn: "信頼できへんプラグインはインストールせんとってな" | ||||||
|  |   manage: "プラグインの管理" | ||||||
|  | _registry: | ||||||
|  |   scope: "スコープ" | ||||||
|  |   key: "キー" | ||||||
|  |   keys: "キー" | ||||||
|  |   domain: "ドメイン" | ||||||
|  |   createKey: "キーを作る" | ||||||
|  | _aboutMisskey: | ||||||
|  |   about: "Misskeyはsyuiloが2014年からずっと作ってはる、オープンソースなソフトウェアや。" | ||||||
|  |   contributors: "主な貢献者" | ||||||
|  |   allContributors: "全ての貢献者" | ||||||
|  |   source: "ソースコード" | ||||||
|  |   translation: "Misskeyを翻訳" | ||||||
|  |   donate: "Misskeyに寄付" | ||||||
|  |   morePatrons: "他にもぎょうさんの人からサポートしてもろてんねん。ほんまおおきに🥰" | ||||||
|  |   patrons: "支援者" | ||||||
| _mfm: | _mfm: | ||||||
|  |   cheatSheet: "MFMチートシート" | ||||||
|   mention: "メンション" |   mention: "メンション" | ||||||
|  |   hashtag: "ハッシュタグ" | ||||||
|  |   url: "URL" | ||||||
|  |   link: "リンク" | ||||||
|  |   bold: "太字" | ||||||
|  |   center: "中央寄せ" | ||||||
|  |   inlineCode: "コード(インライン)" | ||||||
|  |   blockCode: "コード(ブロック)" | ||||||
|  |   inlineMath: "数式(インライン)" | ||||||
|   quote: "引用" |   quote: "引用" | ||||||
|   emoji: "カスタム絵文字" |   emoji: "カスタム絵文字" | ||||||
|   search: "探す" |   search: "探す" | ||||||
|  |   shake: "アニメーション(ぶるぶる)" | ||||||
|  |   twitch: "アニメーション(ブレ)" | ||||||
|  |   spin: "アニメーション(回転)" | ||||||
|  |   blur: "ぼかし" | ||||||
|  |   font: "フォント" | ||||||
|  | _reversi: | ||||||
|  |   reversi: "リバーシ" | ||||||
|  |   gameSettings: "対局の設定" | ||||||
|  |   chooseBoard: "ボードを選択" | ||||||
|  |   blackOrWhite: "先行/後攻" | ||||||
|  |   blackIs: "{name}が黒(先行)" | ||||||
|  |   rules: "ルール" | ||||||
|  |   botSettings: "Botのオプション" | ||||||
|  |   pastTurnOf: "{name}のターン" | ||||||
|  |   surrender: "投了" | ||||||
|  |   surrendered: "投了により" | ||||||
|  |   drawn: "引き分け" | ||||||
|  |   won: "{name}の勝ち" | ||||||
|  |   black: "黒" | ||||||
|  |   white: "白" | ||||||
|  |   total: "合計" | ||||||
|  |   turnCount: "{count}ターン目" | ||||||
|  |   myGames: "自分の対局" | ||||||
|  |   allGames: "みんなの対局" | ||||||
|  |   ended: "終了" | ||||||
|  |   playing: "対局中" | ||||||
|  |   isLlotheo: "石の少ない方が勝ち(ロセオ)" | ||||||
|  |   loopedMap: "ループマップ" | ||||||
|  | _instanceTicker: | ||||||
|  |   none: "表示せん" | ||||||
|  |   remote: "リモートユーザーに表示" | ||||||
|  |   always: "常に表示" | ||||||
|  | _serverDisconnectedBehavior: | ||||||
|  |   reload: "自動でリロード" | ||||||
|  |   dialog: "ダイアログで警告" | ||||||
| _channel: | _channel: | ||||||
|  |   create: "チャンネルを作る" | ||||||
|  |   edit: "チャンネルを編集" | ||||||
|  |   setBanner: "バナーを設定" | ||||||
|  |   removeBanner: "バナーを削除" | ||||||
|  |   featured: "トレンド" | ||||||
|   notesCount: "{n}こ投稿があるで" |   notesCount: "{n}こ投稿があるで" | ||||||
| _sidebar: | _sidebar: | ||||||
|  |   full: "フル" | ||||||
|   icon: "アイコン" |   icon: "アイコン" | ||||||
|  |   hide: "隠す" | ||||||
|  | _wordMute: | ||||||
|  |   soft: "ソフト" | ||||||
|  |   hard: "ハード" | ||||||
| _theme: | _theme: | ||||||
|  |   explore: "テーマを探す" | ||||||
|  |   install: "テーマのインストール" | ||||||
|  |   manage: "テーマの管理" | ||||||
|  |   code: "テーマコード" | ||||||
|  |   description: "説明" | ||||||
|  |   installed: "{name}をインストールしたで。" | ||||||
|  |   installedThemes: "インストールされとるテーマ" | ||||||
|  |   builtinThemes: "標準のテーマ" | ||||||
|  |   alreadyInstalled: "そのテーマはもうインストールされとるで?" | ||||||
|  |   make: "テーマを作る" | ||||||
|  |   base: "ベース" | ||||||
|  |   addConstant: "定数を追加" | ||||||
|  |   defaultValue: "デフォルト値" | ||||||
|  |   color: "色" | ||||||
|  |   refProp: "プロパティを参照" | ||||||
|  |   refConst: "定数を参照" | ||||||
|  |   key: "キー" | ||||||
|  |   func: "関数" | ||||||
|  |   funcKind: "関数の種類" | ||||||
|  |   argument: "引数" | ||||||
|  |   basedProp: "元にするプロパティの名前" | ||||||
|  |   alpha: "不透明度" | ||||||
|  |   darken: "暗さ" | ||||||
|  |   lighten: "明るさ" | ||||||
|   keys: |   keys: | ||||||
|  |     accent: "アクセント" | ||||||
|  |     bg: "背景" | ||||||
|  |     fg: "文字" | ||||||
|  |     focus: "フォーカス" | ||||||
|  |     indicator: "インジケーター" | ||||||
|  |     panel: "パネル" | ||||||
|  |     shadow: "影" | ||||||
|  |     header: "ヘッダー" | ||||||
|  |     navBg: "サイドバーの背景" | ||||||
|  |     navFg: "サイドバーの文字" | ||||||
|  |     navHoverFg: "サイドバー文字(ホバー)" | ||||||
|  |     navActive: "サイドバー文字(アクティブ)" | ||||||
|  |     navIndicator: "サイドバーのインジケーター" | ||||||
|  |     link: "リンク" | ||||||
|  |     hashtag: "ハッシュタグ" | ||||||
|     mention: "メンション" |     mention: "メンション" | ||||||
|  |     mentionMe: "うち宛てのメンション" | ||||||
|     renote: "Renote" |     renote: "Renote" | ||||||
|  |     modalBg: "モーダルの背景" | ||||||
|  |     divider: "分割線" | ||||||
|  |     scrollbarHandle: "スクロールバーの取っ手" | ||||||
|  |     scrollbarHandleHover: "スクロールバーの取っ手(ホバー)" | ||||||
|  |     dateLabelFg: "日付ラベルの文字" | ||||||
|  |     infoBg: "情報の背景" | ||||||
|  |     infoFg: "情報の文字" | ||||||
|  |     infoWarnBg: "警告の背景" | ||||||
|  |     infoWarnFg: "警告の文字" | ||||||
|  |     cwBg: "CW ボタンの背景" | ||||||
|  |     cwFg: "CW ボタンの文字" | ||||||
|  |     cwHoverBg: "CW ボタンの背景 (ホバー)" | ||||||
|  |     toastBg: "通知トーストの背景" | ||||||
|  |     toastFg: "通知トーストの文字" | ||||||
|  |     buttonBg: "ボタンの背景" | ||||||
|  |     buttonHoverBg: "ボタンの背景 (ホバー)" | ||||||
|  |     inputBorder: "入力ボックスの縁取り" | ||||||
|  |     listItemHoverBg: "リスト項目の背景 (ホバー)" | ||||||
|  |     driveFolderBg: "ドライブフォルダーの背景" | ||||||
|  |     wallpaperOverlay: "壁紙のオーバーレイ" | ||||||
|  |     badge: "バッジ" | ||||||
|  |     messageBg: "チャットの背景" | ||||||
|  |     accentDarken: "アクセント (暗め)" | ||||||
|  |     accentLighten: "アクセント (明るめ)" | ||||||
|  |     fgHighlighted: "強調されとる文字" | ||||||
| _sfx: | _sfx: | ||||||
|   note: "ノート" |   note: "ノート" | ||||||
|  |   noteMy: "ノート(自分)" | ||||||
|   notification: "通知" |   notification: "通知" | ||||||
|   chat: "チャット" |   chat: "チャット" | ||||||
| _ago: | _ago: | ||||||
| @@ -511,24 +833,63 @@ _tutorial: | |||||||
| _2fa: | _2fa: | ||||||
|   alreadyRegistered: "もう設定終わっとるわ。" |   alreadyRegistered: "もう設定終わっとるわ。" | ||||||
| _permissions: | _permissions: | ||||||
|  |   "read:reactions": "リアクションを見る" | ||||||
|  |   "write:votes": "投票する" | ||||||
|  |   "read:pages": "ページを見る" | ||||||
|   "read:page-likes": "ページのええやんを見る" |   "read:page-likes": "ページのええやんを見る" | ||||||
|   "write:page-likes": "ページのええやんを操作する" |   "write:page-likes": "ページのええやんを操作する" | ||||||
|  |   "read:user-groups": "ユーザーグループを見る" | ||||||
|  |   "read:channels": "チャンネルを見る" | ||||||
| _auth: | _auth: | ||||||
|   permissionAsk: "このアプリは次の権限を要求しとるで" |   permissionAsk: "このアプリは次の権限を要求しとるで" | ||||||
| _antennaSources: | _antennaSources: | ||||||
|   all: "みなのノート" |   all: "みなのノート" | ||||||
|   homeTimeline: "フォローしとるユーザーのノート" |   homeTimeline: "フォローしとるユーザーのノート" | ||||||
|  | _weekday: | ||||||
|  |   sunday: "日曜日" | ||||||
|  |   monday: "月曜日" | ||||||
|  |   tuesday: "火曜日" | ||||||
|  |   wednesday: "水曜日" | ||||||
|  |   thursday: "木曜日" | ||||||
|  |   friday: "金曜日" | ||||||
|  |   saturday: "土曜日" | ||||||
| _widgets: | _widgets: | ||||||
|  |   memo: "付箋" | ||||||
|   notifications: "通知" |   notifications: "通知" | ||||||
|   timeline: "タイムライン" |   timeline: "タイムライン" | ||||||
|  |   calendar: "カレンダー" | ||||||
|  |   trends: "トレンド" | ||||||
|  |   clock: "時計" | ||||||
|  |   rss: "RSSリーダー" | ||||||
|   activity: "アクティビティ" |   activity: "アクティビティ" | ||||||
|  |   photos: "フォト" | ||||||
|  |   digitalClock: "デジタル時計" | ||||||
|   federation: "連合" |   federation: "連合" | ||||||
|  |   postForm: "投稿フォーム" | ||||||
|  |   slideshow: "スライドショー" | ||||||
|  |   button: "ボタン" | ||||||
|  |   onlineUsers: "オンラインユーザー" | ||||||
|   jobQueue: "ジョブキュー" |   jobQueue: "ジョブキュー" | ||||||
|  |   serverMetric: "サーバーメトリクス" | ||||||
|  |   aiscript: "AiScriptコンソール" | ||||||
| _cw: | _cw: | ||||||
|  |   hide: "隠す" | ||||||
|   show: "続き見して!" |   show: "続き見して!" | ||||||
|  |   chars: "{count}文字" | ||||||
|  |   files: "{count}ファイル" | ||||||
| _poll: | _poll: | ||||||
|  |   choiceN: "選択肢{n}" | ||||||
|   noMore: "これ以上追加でけへん" |   noMore: "これ以上追加でけへん" | ||||||
|  |   canMultipleVote: "複数回答可" | ||||||
|  |   expiration: "期限" | ||||||
|  |   infinite: "無期限" | ||||||
|  |   at: "日時指定" | ||||||
|  |   after: "経過指定" | ||||||
|  |   deadlineDate: "期日" | ||||||
|   deadlineTime: "時間" |   deadlineTime: "時間" | ||||||
|  |   duration: "期間" | ||||||
|  |   votesCount: "{n}票" | ||||||
|  |   vote: "投票する" | ||||||
| _visibility: | _visibility: | ||||||
|   publicDescription: "みなのユーザーに公開" |   publicDescription: "みなのユーザーに公開" | ||||||
|   home: "ホーム" |   home: "ホーム" | ||||||
| @@ -542,44 +903,372 @@ _exportOrImport: | |||||||
|   muteList: "ミュート" |   muteList: "ミュート" | ||||||
|   blockingList: "ブロック" |   blockingList: "ブロック" | ||||||
|   userLists: "リスト" |   userLists: "リスト" | ||||||
|  | _charts: | ||||||
|  |   usersTotal: "ユーザーの合計" | ||||||
|  |   activeUsers: "アクティブユーザー数" | ||||||
|  |   notesIncDec: "ノートの増減" | ||||||
|  |   localNotesIncDec: "ローカルのノートの増減" | ||||||
|  |   remoteNotesIncDec: "リモートのノートの増減" | ||||||
|  |   notesTotal: "ノートの合計" | ||||||
|  |   filesIncDec: "ファイルの増減" | ||||||
|  |   filesTotal: "ファイルの合計" | ||||||
|  |   storageUsageIncDec: "ストレージ使用量の増減" | ||||||
|  |   storageUsageTotal: "ストレージ使用量の合計" | ||||||
|  | _instanceCharts: | ||||||
|  |   requests: "リクエスト" | ||||||
|  |   users: "ユーザーの増減" | ||||||
|  |   usersTotal: "ユーザーの累積" | ||||||
|  |   notes: "ノートの増減" | ||||||
|  |   notesTotal: "ノートの累積" | ||||||
|  |   ff: "フォロー/フォロワーの増減" | ||||||
|  |   ffTotal: "フォロー/フォロワーの累積" | ||||||
|  |   cacheSize: "キャッシュサイズの増減" | ||||||
|  |   cacheSizeTotal: "キャッシュサイズの累積" | ||||||
|  |   files: "ファイル数の増減" | ||||||
|  |   filesTotal: "ファイル数の累積" | ||||||
| _timelines: | _timelines: | ||||||
|   home: "ホーム" |   home: "ホーム" | ||||||
|  |   local: "ローカル" | ||||||
|  |   social: "ソーシャル" | ||||||
|  |   global: "グローバル" | ||||||
| _rooms: | _rooms: | ||||||
|  |   roomOf: "{user}のルーム" | ||||||
|  |   addFurniture: "家具を置く" | ||||||
|  |   translate: "移動" | ||||||
|  |   rotate: "回転" | ||||||
|  |   exit: "戻る" | ||||||
|  |   remove: "しまう" | ||||||
|  |   clear: "片付け" | ||||||
|  |   clearConfirm: "家具ぜんぶしまうけど、ホンマにええん?" | ||||||
|   leaveConfirm: "未保存の変更があるけど、移動してええか?" |   leaveConfirm: "未保存の変更があるけど、移動してええか?" | ||||||
|  |   chooseImage: "画像を選ぶ" | ||||||
|  |   roomType: "部屋のタイプ" | ||||||
|  |   carpetColor: "床の色" | ||||||
|   _roomType: |   _roomType: | ||||||
|     default: "デフォルト" |     default: "デフォルト" | ||||||
|  |     washitsu: "和室" | ||||||
|   _furnitures: |   _furnitures: | ||||||
|  |     milk: "牛乳パック" | ||||||
|  |     bed: "ベッド" | ||||||
|  |     low-table: "ローテーブル" | ||||||
|  |     desk: "デスク" | ||||||
|  |     chair: "チェア" | ||||||
|  |     chair2: "チェア2" | ||||||
|  |     fan: "換気扇" | ||||||
|  |     pc: "パソコン" | ||||||
|  |     plant: "観葉植物" | ||||||
|  |     plant2: "観葉植物2" | ||||||
|  |     eraser: "消しゴム" | ||||||
|  |     pencil: "鉛筆" | ||||||
|  |     pudding: "プリン" | ||||||
|  |     cardboard-box: "段ボール箱" | ||||||
|  |     cardboard-box2: "段ボール箱2" | ||||||
|  |     cardboard-box3: "段ボール箱3" | ||||||
|  |     book: "本" | ||||||
|  |     book2: "本2" | ||||||
|  |     piano: "ピアノ" | ||||||
|  |     facial-tissue: "ティッシュボックス" | ||||||
|  |     server: "サーバー" | ||||||
|  |     moon: "月" | ||||||
|  |     corkboard: "コルクボード" | ||||||
|  |     mousepad: "マウスパッド" | ||||||
|     monitor: "モニター" |     monitor: "モニター" | ||||||
|  |     keyboard: "キーボード" | ||||||
|  |     carpet-stripe: "カーペット(縞)" | ||||||
|  |     mat: "マット" | ||||||
|  |     color-box: "カラーボックス" | ||||||
|  |     wall-clock: "壁掛け時計" | ||||||
|  |     photoframe: "額縁" | ||||||
|  |     cube: "キューブ" | ||||||
|  |     tv: "テレビ" | ||||||
|  |     pinguin: "ピンギン" | ||||||
|  |     rubik-cube: "ルービックキューブ" | ||||||
|  |     poster-h: "ルービックキューブ" | ||||||
|  |     poster-v: "ポスター(縦長)" | ||||||
|  |     sofa: "ソファ" | ||||||
|  |     spiral: "螺旋階段" | ||||||
|  |     bin: "ゴミ箱" | ||||||
|  |     cup-noodle: "カップ麺" | ||||||
|  |     holo-display: "ホログラフィックディスプレイ" | ||||||
|  |     energy-drink: "エナジードリンク" | ||||||
|  |     doll-ai: "藍ちゃん人形" | ||||||
|  |     banknote: "札束" | ||||||
| _pages: | _pages: | ||||||
|  |   newPage: "ページを作る" | ||||||
|  |   editPage: "ページの編集" | ||||||
|  |   readPage: "ソースを表示中" | ||||||
|  |   created: "ページを作成したで" | ||||||
|  |   updated: "ページを更新したで" | ||||||
|  |   deleted: "ページを削除したで" | ||||||
|  |   pageSetting: "ページ設定" | ||||||
|  |   viewPage: "ページを見る" | ||||||
|   like: "ええやん" |   like: "ええやん" | ||||||
|   unlike: "良くないわ" |   unlike: "良くないわ" | ||||||
|   liked: "ええと思ったページ" |   liked: "ええと思ったページ" | ||||||
|  |   contents: "コンテンツ" | ||||||
|  |   summary: "ページの要約" | ||||||
|  |   alignCenter: "中央寄せ" | ||||||
|  |   font: "フォント" | ||||||
|  |   fontSerif: "セリフ" | ||||||
|  |   fontSansSerif: "サンセリフ" | ||||||
|  |   eyeCatchingImageSet: "アイキャッチ画像を設定" | ||||||
|  |   eyeCatchingImageRemove: "アイキャッチ画像を削除" | ||||||
|  |   chooseBlock: "ブロックを追加" | ||||||
|  |   selectType: "種類を選択" | ||||||
|  |   contentBlocks: "コンテンツ" | ||||||
|  |   inputBlocks: "入力" | ||||||
|  |   specialBlocks: "特殊" | ||||||
|   blocks: |   blocks: | ||||||
|  |     text: "テキスト" | ||||||
|  |     textarea: "テキストエリア" | ||||||
|  |     section: "セクション" | ||||||
|     image: "画像" |     image: "画像" | ||||||
|  |     button: "ボタン" | ||||||
|  |     if: "もし" | ||||||
|  |     _if: | ||||||
|  |       variable: "変数" | ||||||
|  |     post: "投稿フォーム" | ||||||
|  |     _post: | ||||||
|  |       text: "内容" | ||||||
|  |       canvasId: "キャンバスID" | ||||||
|  |     textInput: "テキスト入力" | ||||||
|  |     _textInput: | ||||||
|  |       name: "変数名" | ||||||
|  |       text: "タイトル" | ||||||
|  |       default: "デフォルト値" | ||||||
|  |     textareaInput: "複数行テキスト入力" | ||||||
|  |     _textareaInput: | ||||||
|  |       name: "変数名" | ||||||
|  |       text: "タイトル" | ||||||
|  |       default: "デフォルト値" | ||||||
|  |     numberInput: "数値入力" | ||||||
|  |     _numberInput: | ||||||
|  |       name: "変数名" | ||||||
|  |       text: "タイトル" | ||||||
|  |       default: "デフォルト値" | ||||||
|  |     canvas: "キャンバス" | ||||||
|  |     _canvas: | ||||||
|  |       id: "キャンバスID" | ||||||
|  |       width: "幅" | ||||||
|  |       height: "高さ" | ||||||
|  |     note: "ノート埋め込み" | ||||||
|  |     _note: | ||||||
|  |       id: "ノートID" | ||||||
|  |       detailed: "詳細な表示" | ||||||
|  |     switch: "スイッチ" | ||||||
|  |     _switch: | ||||||
|  |       name: "変数名" | ||||||
|  |       text: "タイトル" | ||||||
|  |       default: "デフォルト値" | ||||||
|  |     counter: "カウンター" | ||||||
|  |     _counter: | ||||||
|  |       name: "変数名" | ||||||
|  |       text: "タイトル" | ||||||
|  |       inc: "増加値" | ||||||
|  |     _button: | ||||||
|  |       text: "タイトル" | ||||||
|  |       colored: "色付き" | ||||||
|  |       action: "ボタンを押したときの動作" | ||||||
|  |       _action: | ||||||
|  |         dialog: "ダイアログを表示する" | ||||||
|  |         _dialog: | ||||||
|  |           content: "内容" | ||||||
|  |         resetRandom: "乱数をリセット" | ||||||
|  |         pushEvent: "イベントを送信させる" | ||||||
|  |         _pushEvent: | ||||||
|  |           event: "イベント名" | ||||||
|  |           no-variable: "なし" | ||||||
|  |         callAiScript: "AiScript呼び出し" | ||||||
|  |         _callAiScript: | ||||||
|  |           functionName: "関数名" | ||||||
|  |     radioButton: "選択肢" | ||||||
|  |     _radioButton: | ||||||
|  |       name: "変数名" | ||||||
|  |       title: "タイトル" | ||||||
|  |       values: "改行で区切った選択肢" | ||||||
|  |       default: "デフォルト値" | ||||||
|   script: |   script: | ||||||
|     categories: |     categories: | ||||||
|  |       flow: "制御" | ||||||
|  |       logical: "論理演算" | ||||||
|  |       operation: "計算" | ||||||
|  |       comparison: "比較" | ||||||
|  |       random: "ランダム" | ||||||
|  |       value: "値" | ||||||
|  |       fn: "関数" | ||||||
|  |       text: "関数" | ||||||
|  |       convert: "変換" | ||||||
|       list: "リスト" |       list: "リスト" | ||||||
|     blocks: |     blocks: | ||||||
|  |       text: "テキスト" | ||||||
|  |       multiLineText: "テキスト(複数行)" | ||||||
|  |       textList: "テキストのリスト" | ||||||
|  |       strLen: "テキストの長さ" | ||||||
|  |       _strLen: | ||||||
|  |         arg1: "テキスト" | ||||||
|  |       strPick: "文字取り出し" | ||||||
|  |       _strPick: | ||||||
|  |         arg1: "テキスト" | ||||||
|  |         arg2: "文字の位置" | ||||||
|  |       strReplace: "テキスト置き換え" | ||||||
|  |       _strReplace: | ||||||
|  |         arg1: "テキスト" | ||||||
|  |         arg2: "置き換え前" | ||||||
|  |         arg3: "置き換え後" | ||||||
|  |       strReverse: "テキストを反転" | ||||||
|  |       _strReverse: | ||||||
|  |         arg1: "テキスト" | ||||||
|  |       join: "テキストを連結" | ||||||
|       _join: |       _join: | ||||||
|         arg1: "リスト" |         arg1: "リスト" | ||||||
|  |         arg2: "区切り" | ||||||
|  |       add: "足す" | ||||||
|  |       _add: | ||||||
|  |         arg1: "A" | ||||||
|  |         arg2: "B" | ||||||
|  |       subtract: "引く" | ||||||
|  |       _subtract: | ||||||
|  |         arg1: "A" | ||||||
|  |         arg2: "A" | ||||||
|  |       multiply: "掛ける" | ||||||
|  |       _multiply: | ||||||
|  |         arg1: "A" | ||||||
|  |         arg2: "B" | ||||||
|  |       divide: "割る" | ||||||
|  |       _divide: | ||||||
|  |         arg1: "A" | ||||||
|  |         arg2: "B" | ||||||
|  |       mod: "割った余り" | ||||||
|  |       _mod: | ||||||
|  |         arg1: "A" | ||||||
|  |         arg2: "B" | ||||||
|  |       round: "小数を丸める" | ||||||
|  |       _round: | ||||||
|  |         arg1: "数値" | ||||||
|  |       eq: "AとBが同じ" | ||||||
|  |       _eq: | ||||||
|  |         arg1: "A" | ||||||
|  |         arg2: "B" | ||||||
|  |       notEq: "AとBが異なる" | ||||||
|  |       _notEq: | ||||||
|  |         arg1: "A" | ||||||
|  |         arg2: "B" | ||||||
|  |       and: "AかつB" | ||||||
|  |       _and: | ||||||
|  |         arg1: "A" | ||||||
|  |         arg2: "B" | ||||||
|  |       or: "AまたはB" | ||||||
|  |       _or: | ||||||
|  |         arg1: "A" | ||||||
|  |         arg2: "B" | ||||||
|  |       lt: "< AがBより小さい" | ||||||
|  |       _lt: | ||||||
|  |         arg1: "A" | ||||||
|  |         arg2: "B" | ||||||
|  |       gt: "> AがBより大きい" | ||||||
|  |       _gt: | ||||||
|  |         arg1: "A" | ||||||
|  |         arg2: "B" | ||||||
|  |       ltEq: "<= AがBと同じか小さい" | ||||||
|  |       _ltEq: | ||||||
|  |         arg1: "A" | ||||||
|  |         arg2: "B" | ||||||
|  |       gtEq: ">= AがBと同じか大きい" | ||||||
|  |       _gtEq: | ||||||
|  |         arg1: "A" | ||||||
|  |         arg2: "B" | ||||||
|  |       if: "分岐" | ||||||
|  |       _if: | ||||||
|  |         arg1: "もし" | ||||||
|  |         arg2: "なら" | ||||||
|  |         arg3: "そうでなければ" | ||||||
|  |       not: "否定" | ||||||
|  |       _not: | ||||||
|  |         arg1: "否定" | ||||||
|  |       random: "ランダム" | ||||||
|  |       _random: | ||||||
|  |         arg1: "確率" | ||||||
|  |       rannum: "乱数" | ||||||
|  |       _rannum: | ||||||
|  |         arg1: "最小" | ||||||
|  |         arg2: "最大" | ||||||
|  |       randomPick: "リストからランダムに選ぶ" | ||||||
|       _randomPick: |       _randomPick: | ||||||
|         arg1: "リスト" |         arg1: "リスト" | ||||||
|  |       dailyRandom: "ランダム (ユーザーごとに日替わり)" | ||||||
|  |       _dailyRandom: | ||||||
|  |         arg1: "確率" | ||||||
|  |       dailyRannum: "乱数 (ユーザーごとに日替わり)" | ||||||
|  |       _dailyRannum: | ||||||
|  |         arg1: "最小" | ||||||
|  |         arg2: "最大" | ||||||
|  |       dailyRandomPick: "リストからランダムに選ぶ (ユーザーごとに日替わり)" | ||||||
|       _dailyRandomPick: |       _dailyRandomPick: | ||||||
|         arg1: "リスト" |         arg1: "リスト" | ||||||
|  |       seedRandom: "ランダム (シード)" | ||||||
|  |       _seedRandom: | ||||||
|  |         arg1: "シード" | ||||||
|  |         arg2: "確率" | ||||||
|  |       seedRannum: "乱数 (シード)" | ||||||
|  |       _seedRannum: | ||||||
|  |         arg1: "シード" | ||||||
|  |         arg2: "最小" | ||||||
|  |         arg3: "最大" | ||||||
|  |       seedRandomPick: "リストからランダムに選択 (シード)" | ||||||
|       _seedRandomPick: |       _seedRandomPick: | ||||||
|  |         arg1: "シード" | ||||||
|         arg2: "リスト" |         arg2: "リスト" | ||||||
|  |       DRPWPM: "確率付きリストからランダムに選ぶ (ユーザーごとに日替わり)" | ||||||
|  |       _DRPWPM: | ||||||
|  |         arg1: "テキストのリスト" | ||||||
|  |       pick: "リストから選ぶ" | ||||||
|       _pick: |       _pick: | ||||||
|         arg1: "リスト" |         arg1: "リスト" | ||||||
|  |         arg2: "位置" | ||||||
|  |       listLen: "リストの長さを取得" | ||||||
|       _listLen: |       _listLen: | ||||||
|         arg1: "リスト" |         arg1: "リスト" | ||||||
|  |       number: "数値" | ||||||
|  |       stringToNumber: "テキストを数値に" | ||||||
|  |       _stringToNumber: | ||||||
|  |         arg1: "テキスト" | ||||||
|  |       numberToString: "数値をテキストに" | ||||||
|  |       _numberToString: | ||||||
|  |         arg1: "数値" | ||||||
|  |       splitStrByLine: "テキストを行で分割" | ||||||
|  |       _splitStrByLine: | ||||||
|  |         arg1: "テキスト" | ||||||
|  |       ref: "変数" | ||||||
|  |       aiScriptVar: "AiScript変数" | ||||||
|  |       fn: "関数" | ||||||
|  |       _fn: | ||||||
|  |         slots: "スロット" | ||||||
|  |         arg1: "出力" | ||||||
|  |       for: "繰り返し" | ||||||
|  |       _for: | ||||||
|  |         arg1: "回数" | ||||||
|  |         arg2: "処理" | ||||||
|  |     thereIsEmptySlot: "スロット{slot}が空っぽやで!" | ||||||
|     types: |     types: | ||||||
|  |       string: "テキスト" | ||||||
|  |       number: "数値" | ||||||
|  |       boolean: "フラグ" | ||||||
|       array: "リスト" |       array: "リスト" | ||||||
|  |       stringArray: "テキストのリスト" | ||||||
|  |     emptySlot: "空のスロット" | ||||||
|  |     enviromentVariables: "環境変数" | ||||||
|  |     pageVariables: "ページ要素" | ||||||
|  |     argVariables: "入力スロット" | ||||||
| _notification: | _notification: | ||||||
|  |   fileUploaded: "ファイルが無事アップロードされたで。" | ||||||
|  |   youGotMention: "{name}からのメンション" | ||||||
|  |   youGotReply: "{name}からのリプライ" | ||||||
|   youWereFollowed: "フォローされたで" |   youWereFollowed: "フォローされたで" | ||||||
|   youReceivedFollowRequest: "フォロー許可してほしいみたいやな" |   youReceivedFollowRequest: "フォロー許可してほしいみたいやな" | ||||||
|   yourFollowRequestAccepted: "フォローさせてもろたで" |   yourFollowRequestAccepted: "フォローさせてもろたで" | ||||||
|   youWereInvitedToGroup: "グループに招待されとるで" |   youWereInvitedToGroup: "グループに招待されとるで" | ||||||
|   _types: |   _types: | ||||||
|  |     all: "すべて" | ||||||
|     follow: "フォロー" |     follow: "フォロー" | ||||||
|     mention: "メンション" |     mention: "メンション" | ||||||
|     renote: "Renote" |     renote: "Renote" | ||||||
| @@ -588,9 +1277,24 @@ _notification: | |||||||
|     receiveFollowRequest: "フォロー許可してほしいみたいやで" |     receiveFollowRequest: "フォロー許可してほしいみたいやで" | ||||||
|     followRequestAccepted: "フォローが受理されたで" |     followRequestAccepted: "フォローが受理されたで" | ||||||
| _deck: | _deck: | ||||||
|  |   alwaysShowMainColumn: "いつもメインカラムを表示" | ||||||
|  |   columnAlign: "カラムの寄せ" | ||||||
|  |   columnMargin: "カラム間のマージン" | ||||||
|  |   columnHeaderHeight: "カラムのヘッダー幅" | ||||||
|  |   addColumn: "カラムを追加" | ||||||
|  |   swapLeft: "左に移動" | ||||||
|  |   swapRight: "右に移動" | ||||||
|  |   swapUp: "上に移動" | ||||||
|  |   swapDown: "下に移動" | ||||||
|  |   stackLeft: "左に重ねる" | ||||||
|  |   popRight: "右に出す" | ||||||
|  |   profile: "プロファイル" | ||||||
|   _columns: |   _columns: | ||||||
|  |     main: "メイン" | ||||||
|  |     widgets: "ウィジェット" | ||||||
|     notifications: "通知" |     notifications: "通知" | ||||||
|     tl: "タイムライン" |     tl: "タイムライン" | ||||||
|     antenna: "アンテナ" |     antenna: "アンテナ" | ||||||
|     list: "リスト" |     list: "リスト" | ||||||
|     mentions: "あんた宛て" |     mentions: "あんた宛て" | ||||||
|  |     direct: "ダイレクト" | ||||||
|   | |||||||
| @@ -58,6 +58,7 @@ instances: "ನಿದರ್ಶನ" | |||||||
| remove: "ಅಳಿಸು" | remove: "ಅಳಿಸು" | ||||||
| smtpUser: "ಬಳಕೆಹೆಸರು" | smtpUser: "ಬಳಕೆಹೆಸರು" | ||||||
| smtpPass: "ಗುಪ್ತಪದ" | smtpPass: "ಗುಪ್ತಪದ" | ||||||
|  | user: "ಬಳಕೆದಾರ" | ||||||
| _email: | _email: | ||||||
|   _follow: |   _follow: | ||||||
|     title: "ಹಿಂಬಾಲಿಸಿದರು" |     title: "ಹಿಂಬಾಲಿಸಿದರು" | ||||||
|   | |||||||
| @@ -7,6 +7,7 @@ search: "검색" | |||||||
| notifications: "알림" | notifications: "알림" | ||||||
| username: "유저명" | username: "유저명" | ||||||
| password: "비밀번호" | password: "비밀번호" | ||||||
|  | forgotPassword: "비밀번호 재설정" | ||||||
| fetchingAsApObject: "연합에서 조회 중" | fetchingAsApObject: "연합에서 조회 중" | ||||||
| ok: "OK" | ok: "OK" | ||||||
| gotIt: "알겠어요" | gotIt: "알겠어요" | ||||||
| @@ -138,7 +139,7 @@ flagAsBotDescription: "이 계정을 자동화된 수단으로 운용할 경우 | |||||||
| flagAsCat: "나는 고양이다냥" | flagAsCat: "나는 고양이다냥" | ||||||
| flagAsCatDescription: "이 계정이 고양이라면 활성화 해주세요." | flagAsCatDescription: "이 계정이 고양이라면 활성화 해주세요." | ||||||
| autoAcceptFollowed: "팔로우 중인 유저로부터의 팔로우 요청을 자동 수락" | autoAcceptFollowed: "팔로우 중인 유저로부터의 팔로우 요청을 자동 수락" | ||||||
| addAcount: "계정 추가" | addAccount: "계정 추가" | ||||||
| loginFailed: "로그인에 실패했습니다" | loginFailed: "로그인에 실패했습니다" | ||||||
| showOnRemote: "리모트에서 보기" | showOnRemote: "리모트에서 보기" | ||||||
| general: "일반" | general: "일반" | ||||||
| @@ -278,6 +279,7 @@ emptyDrive: "드라이브가 비어 있습니다" | |||||||
| emptyFolder: "폴더가 비어 있습니다" | emptyFolder: "폴더가 비어 있습니다" | ||||||
| unableToDelete: "삭제할 수 없습니다" | unableToDelete: "삭제할 수 없습니다" | ||||||
| inputNewFileName: "바꿀 파일명을 입력해 주세요" | inputNewFileName: "바꿀 파일명을 입력해 주세요" | ||||||
|  | inputNewDescription: "새 캡션을 입력해 주세요" | ||||||
| inputNewFolderName: "바꿀 폴더명을 입력해 주세요" | inputNewFolderName: "바꿀 폴더명을 입력해 주세요" | ||||||
| circularReferenceFolder: "지정한 폴더가 이동할 폴더의 하위 폴더입니다." | circularReferenceFolder: "지정한 폴더가 이동할 폴더의 하위 폴더입니다." | ||||||
| hasChildFilesOrFolders: "이 폴더는 비어있지 않기 때문에 삭제할 수 없습니다." | hasChildFilesOrFolders: "이 폴더는 비어있지 않기 때문에 삭제할 수 없습니다." | ||||||
| @@ -309,8 +311,8 @@ monthX: "{month}월" | |||||||
| yearX: "{year}년" | yearX: "{year}년" | ||||||
| pages: "페이지" | pages: "페이지" | ||||||
| integration: "연동" | integration: "연동" | ||||||
| connectSerice: "접속" | connectService: "계정 연동" | ||||||
| disconnectSerice: "연결 끊기" | disconnectService: "계정 연동 해제" | ||||||
| enableLocalTimeline: "로컬 타임라인 활성화" | enableLocalTimeline: "로컬 타임라인 활성화" | ||||||
| enableGlobalTimeline: "글로벌 타임라인 활성화" | enableGlobalTimeline: "글로벌 타임라인 활성화" | ||||||
| disablingTimelinesInfo: "특정 타임라인을 비활성화하더라도 관리자 및 모더레이터는 계속 사용할 수 있습니다." | disablingTimelinesInfo: "특정 타임라인을 비활성화하더라도 관리자 및 모더레이터는 계속 사용할 수 있습니다." | ||||||
| @@ -349,7 +351,6 @@ antennaExcludeKeywords: "제외할 키워드" | |||||||
| antennaKeywordsDescription: "공백으로 구분하는 경우 AND, 줄바꿈으로 구분하는 경우 OR로 지정됩니다" | antennaKeywordsDescription: "공백으로 구분하는 경우 AND, 줄바꿈으로 구분하는 경우 OR로 지정됩니다" | ||||||
| notifyAntenna: "새로운 노트를 알림" | notifyAntenna: "새로운 노트를 알림" | ||||||
| withFileAntenna: "파일이 첨부된 노트만" | withFileAntenna: "파일이 첨부된 노트만" | ||||||
| serviceworker: "ServiceWorker" |  | ||||||
| enableServiceworker: "ServiceWorker 사용" | enableServiceworker: "ServiceWorker 사용" | ||||||
| antennaUsersDescription: "유저명을 한 줄에 한 명씩 적습니다" | antennaUsersDescription: "유저명을 한 줄에 한 명씩 적습니다" | ||||||
| caseSensitive: "대소문자를 구분" | caseSensitive: "대소문자를 구분" | ||||||
| @@ -453,7 +454,7 @@ category: "카테고리" | |||||||
| tags: "태그" | tags: "태그" | ||||||
| docSource: "이 문서의 소스" | docSource: "이 문서의 소스" | ||||||
| createAccount: "계정 만들기" | createAccount: "계정 만들기" | ||||||
| existingAcount: "기존 계정" | existingAccount: "기존 계정" | ||||||
| regenerate: "재생성" | regenerate: "재생성" | ||||||
| fontSize: "글자 크기" | fontSize: "글자 크기" | ||||||
| noFollowRequests: "처리되지 않은 팔로우 요청이 없습니다" | noFollowRequests: "처리되지 않은 팔로우 요청이 없습니다" | ||||||
| @@ -546,12 +547,16 @@ disablePlayer: "플레이어 닫기" | |||||||
| expandTweet: "트윗 확장하기" | expandTweet: "트윗 확장하기" | ||||||
| themeEditor: "테마 에디터" | themeEditor: "테마 에디터" | ||||||
| description: "설명" | description: "설명" | ||||||
|  | describeFile: "캡션 추가" | ||||||
|  | enterFileDescription: "캡션 입력" | ||||||
| author: "작성자" | author: "작성자" | ||||||
| leaveConfirm: "저장하지 않은 변경사항이 있습니다. 취소하시겠습니까?" | leaveConfirm: "저장하지 않은 변경사항이 있습니다. 취소하시겠습니까?" | ||||||
| manage: "관리" | manage: "관리" | ||||||
| plugins: "플러그인" | plugins: "플러그인" | ||||||
| deck: "덱" | deck: "덱" | ||||||
| undeck: "덱 해제" | undeck: "덱 해제" | ||||||
|  | useBlurEffectForModal: "모달에 흐림 효과 사용" | ||||||
|  | useFullReactionPicker: "모든 기능이 포함된 리액션 선택기 사용" | ||||||
| width: "폭" | width: "폭" | ||||||
| height: "높이" | height: "높이" | ||||||
| large: "크게" | large: "크게" | ||||||
| @@ -566,7 +571,7 @@ pluginTokenRequestedDescription: "이 플러그인은 여기서 설정한 권한 | |||||||
| notificationType: "알림 유형" | notificationType: "알림 유형" | ||||||
| edit: "편집" | edit: "편집" | ||||||
| useStarForReactionFallback: "알 수 없는 리액션 이모지 대신 ★ 사용" | useStarForReactionFallback: "알 수 없는 리액션 이모지 대신 ★ 사용" | ||||||
| emailConfig: "메일 서버 설정" | emailServer: "메일 서버" | ||||||
| enableEmail: "이메일 송신 기능 활성화" | enableEmail: "이메일 송신 기능 활성화" | ||||||
| emailConfigInfo: "가입 시 메일 주소 확인이나 비밀번호 초기화 시에 사용합니다." | emailConfigInfo: "가입 시 메일 주소 확인이나 비밀번호 초기화 시에 사용합니다." | ||||||
| email: "이메일" | email: "이메일" | ||||||
| @@ -613,6 +618,7 @@ send: "전송" | |||||||
| abuseMarkAsResolved: "해결됨으로 표시" | abuseMarkAsResolved: "해결됨으로 표시" | ||||||
| openInNewTab: "새 탭에서 열기" | openInNewTab: "새 탭에서 열기" | ||||||
| openInSideView: "사이드뷰로 열기" | openInSideView: "사이드뷰로 열기" | ||||||
|  | defaultNavigationBehaviour: "기본 탐색 동작" | ||||||
| editTheseSettingsMayBreakAccount: "이 설정을 변경하면 계정이 손상될 수 있습니다." | editTheseSettingsMayBreakAccount: "이 설정을 변경하면 계정이 손상될 수 있습니다." | ||||||
| instanceTicker: "노트의 인스턴스 정보" | instanceTicker: "노트의 인스턴스 정보" | ||||||
| waitingFor: "{x}을(를) 기다리고 있습니다" | waitingFor: "{x}을(를) 기다리고 있습니다" | ||||||
| @@ -684,6 +690,7 @@ textColor: "문자 색" | |||||||
| saveAs: "다른 이름으로 저장" | saveAs: "다른 이름으로 저장" | ||||||
| advanced: "고급" | advanced: "고급" | ||||||
| value: "값" | value: "값" | ||||||
|  | createdAt: "생성된 날짜" | ||||||
| updatedAt: "수정한 날짜" | updatedAt: "수정한 날짜" | ||||||
| saveConfirm: "저장하시겠습니까?" | saveConfirm: "저장하시겠습니까?" | ||||||
| deleteConfirm: "삭제하시겠습니까?" | deleteConfirm: "삭제하시겠습니까?" | ||||||
| @@ -692,15 +699,88 @@ registry: "레지스트리" | |||||||
| closeAccount: "계정 폐쇄" | closeAccount: "계정 폐쇄" | ||||||
| currentVersion: "현재 버전" | currentVersion: "현재 버전" | ||||||
| latestVersion: "최신 버전" | latestVersion: "최신 버전" | ||||||
|  | youAreRunningUpToDateClient: "사용 중인 클라이언트는 최신입니다." | ||||||
| newVersionOfClientAvailable: "새로운 버전의 클라이언트를 이용할 수 있습니다." | newVersionOfClientAvailable: "새로운 버전의 클라이언트를 이용할 수 있습니다." | ||||||
| usageAmount: "사용량" | usageAmount: "사용량" | ||||||
| capacity: "용량" | capacity: "용량" | ||||||
| inUse: "사용중" | inUse: "사용중" | ||||||
| editCode: "코드 수정" | editCode: "코드 수정" | ||||||
| apply: "적용" | apply: "적용" | ||||||
|  | receiveAnnouncementFromInstance: "이 인스턴스의 알림을 이메일로 수신할게요" | ||||||
|  | emailNotification: "메일 알림" | ||||||
|  | publish: "게시" | ||||||
|  | inChannelSearch: "채널에서 검색" | ||||||
|  | useReactionPickerForContextMenu: "우클릭하여 리액션 선택기 열기" | ||||||
|  | typingUsers: "{users} 님이 입력하고 있어요.." | ||||||
|  | jumpToSpecifiedDate: "특정 날짜로 이동" | ||||||
|  | showingPastTimeline: "과거의 타임라인을 표시하고 있어요" | ||||||
|  | clear: "지우기" | ||||||
|  | markAllAsRead: "모두 읽은 상태로 표시" | ||||||
|  | goBack: "뒤로" | ||||||
|  | unlikeConfirm: "좋아요를 취소할까요?" | ||||||
|  | fullView: "전체 화면" | ||||||
|  | quitFullView: "전체 화면 해제" | ||||||
|  | addDescription: "설명 추가" | ||||||
|  | userPagePinTip: "각 노트의 메뉴에서 「프로필에 고정」을 선택하는 것으로, 여기에 노트를 표시해 둘 수 있어요." | ||||||
|  | notSpecifiedMentionWarning: "수신자가 선택되지 않은 멘션이 있어요" | ||||||
|  | info: "정보" | ||||||
|  | userInfo: "유저 정보" | ||||||
|  | unknown: "알 수 없음" | ||||||
|  | onlineStatus: "온라인 상태" | ||||||
|  | hideOnlineStatus: "온라인 상태 숨기기" | ||||||
|  | hideOnlineStatusDescription: "온라인 상태를 숨기면, 검색과 같은 일부 기능에 영향을 미칠 수 있습니다." | ||||||
|  | online: "온라인" | ||||||
|  | active: "최근에 활동함" | ||||||
|  | offline: "오프라인" | ||||||
|  | notRecommended: "추천하지 않음" | ||||||
|  | botProtection: "Bot 방어" | ||||||
|  | instanceBlocking: "인스턴스 차단" | ||||||
|  | selectAccount: "계정 선택" | ||||||
|  | enabled: "활성화" | ||||||
|  | disabled: "비활성화" | ||||||
|  | quickAction: "빠른 동작" | ||||||
|  | user: "유저" | ||||||
|  | administration: "관리" | ||||||
|  | accounts: "계정" | ||||||
|  | switch: "전환" | ||||||
|  | noMaintainerInformationWarning: "관리자 정보가 설정되어 있지 않습니다." | ||||||
|  | noBotProtectionWarning: "Bot 방어가 설정되어 있지 않습니다." | ||||||
|  | configure: "설정하기" | ||||||
|  | postToGallery: "갤러리에 업로드" | ||||||
|  | gallery: "갤러리" | ||||||
|  | recentPosts: "최근 포스트" | ||||||
|  | popularPosts: "인기 포스트" | ||||||
|  | shareWithNote: "노트로 공유" | ||||||
|  | ads: "광고" | ||||||
|  | expiration: "기한" | ||||||
|  | memo: "메모" | ||||||
|  | priority: "우선순위" | ||||||
|  | high: "높음" | ||||||
|  | middle: "보통" | ||||||
|  | low: "낮음" | ||||||
|  | emailNotConfiguredWarning: "메일 주소가 설정되어 있지 않습니다." | ||||||
|  | ratio: "비율" | ||||||
|  | _ad: | ||||||
|  |   back: "뒤로" | ||||||
|  |   reduceFrequencyOfThisAd: "이 광고의 표시 빈도 낮추기" | ||||||
|  | _forgotPassword: | ||||||
|  |   enterEmail: "여기에 계정에 등록한 메일 주소를 입력해 주세요. 입력한 메일 주소로 비밀번호 재설정 링크를 발송합니다." | ||||||
|  |   ifNoEmail: "메일 주소를 등록하지 않은 경우, 관리자에 문의해 주십시오." | ||||||
|  |   contactAdmin: "이 인스턴스에서는 메일 기능이 지원되지 않습니다. 비밀번호를 재설정하려면 관리자에게 문의해 주십시오." | ||||||
|  | _gallery: | ||||||
|  |   my: "내 갤러리" | ||||||
|  |   liked: "좋아요 한 갤러리" | ||||||
|  |   like: "좋아요!" | ||||||
|  |   unlike: "좋아요 취소" | ||||||
| _email: | _email: | ||||||
|   _follow: |   _follow: | ||||||
|     title: "새로운 팔로워가 있습니다" |     title: "새로운 팔로워가 있습니다" | ||||||
|  |   _receiveFollowRequest: | ||||||
|  |     title: "팔로우 요청을 받았습니다" | ||||||
|  | _plugin: | ||||||
|  |   install: "플러그인 설치" | ||||||
|  |   installWarn: "신뢰할 수 없는 플러그인은 설치하지 않는 것이 좋습니다." | ||||||
|  |   manage: "플러그인 관리" | ||||||
| _registry: | _registry: | ||||||
|   scope: "범위" |   scope: "범위" | ||||||
|   key: "키" |   key: "키" | ||||||
| @@ -734,6 +814,7 @@ _mfm: | |||||||
|   linkDescription: "문장의 특정 범위를 URL로 표시합니다." |   linkDescription: "문장의 특정 범위를 URL로 표시합니다." | ||||||
|   bold: "굵음/볼드체" |   bold: "굵음/볼드체" | ||||||
|   boldDescription: "문자를 굵게 강조합니다." |   boldDescription: "문자를 굵게 강조합니다." | ||||||
|  |   small: "눈에 띄지 않음" | ||||||
|   smallDescription: "내용을 작고 연하게 보이게 합니다." |   smallDescription: "내용을 작고 연하게 보이게 합니다." | ||||||
|   center: "가운데 정렬" |   center: "가운데 정렬" | ||||||
|   centerDescription: "내용을 가운데 정렬로 보이게 합니다." |   centerDescription: "내용을 가운데 정렬로 보이게 합니다." | ||||||
| @@ -746,19 +827,35 @@ _mfm: | |||||||
|   blockMath: "수식(블록)" |   blockMath: "수식(블록)" | ||||||
|   blockMathDescription: "여러 줄의 수식(KaTeX)를 블록으로 보이게 합니다." |   blockMathDescription: "여러 줄의 수식(KaTeX)를 블록으로 보이게 합니다." | ||||||
|   quote: "인용" |   quote: "인용" | ||||||
|  |   quoteDescription: "내용을 인용문으로 표시합니다." | ||||||
|   emoji: "커스텀 이모지" |   emoji: "커스텀 이모지" | ||||||
|   emojiDescription: "커스텀 이모지의 이름을 쌍점(:)으로 감싸서 커스텀 이모지를 사용합니다." |   emojiDescription: "커스텀 이모지의 이름을 쌍점(:)으로 감싸서 커스텀 이모지를 사용합니다." | ||||||
|   search: "검색" |   search: "검색" | ||||||
|   searchDescription: "주어진 키워드가 입력된 검색창을 보이게 합니다." |   searchDescription: "주어진 키워드가 입력된 검색창을 보이게 합니다." | ||||||
|   flip: "플립" |   flip: "플립" | ||||||
|   flipDescription: "내용을 상하 또는 좌우로 반전시킵니다." |   flipDescription: "내용을 상하 또는 좌우로 반전시킵니다." | ||||||
|  |   jelly: "애니메이션 (젤리)" | ||||||
|  |   jellyDescription: "젤리처럼 탱글탱글한 느낌의 효과를 줍니다." | ||||||
|  |   tada: "애니메이션 (짠!)" | ||||||
|  |   tadaDescription: "짠! 하는 느낌의 효과를 줍니다." | ||||||
|   jump: "애니메이션(점프)" |   jump: "애니메이션(점프)" | ||||||
|  |   jumpDescription: "펄쩍 뛸 듯한 느낌의 효과를 줍니다." | ||||||
|  |   bounce: "애니메이션 (바운스)" | ||||||
|  |   bounceDescription: "통통 튀는 느낌의 효과를 줍니다." | ||||||
|  |   shake: "애니메이션 (부들부들)" | ||||||
|  |   shakeDescription: "부들부들 떠는 느낌의 효과를 줍니다." | ||||||
|  |   twitch: "애니메이션 (경련)" | ||||||
|  |   twitchDescription: "격하게 흔들리는 느낌의 효과를 줍니다." | ||||||
|  |   spin: "애니메이션 (회전)" | ||||||
|  |   spinDescription: "회전 효과를 줍니다." | ||||||
|   x2: "크게" |   x2: "크게" | ||||||
|   x2Description: "내용을 크게 표시합니다." |   x2Description: "내용을 크게 표시합니다." | ||||||
|   x3: "더 크게" |   x3: "더 크게" | ||||||
|   x3Description: "내용을 더 크게 표시합니다." |   x3Description: "내용을 더 크게 표시합니다." | ||||||
|   x4: "매우 크게" |   x4: "매우 크게" | ||||||
|   x4Description: "내용을 매우 크게 표시합니다." |   x4Description: "내용을 매우 크게 표시합니다." | ||||||
|  |   blur: "흐림" | ||||||
|  |   blurDescription: "내용이 흐리게 보입니다. 마우스를 위에 올려두면 내용이 보입니다." | ||||||
|   font: "폰트" |   font: "폰트" | ||||||
|   fontDescription: "내용의 글꼴을 지정할 수 있습니다." |   fontDescription: "내용의 글꼴을 지정할 수 있습니다." | ||||||
| _reversi: | _reversi: | ||||||
| @@ -772,6 +869,7 @@ _reversi: | |||||||
|   thisGameIsStartedSoon: "잠시 후에 대국이 시작됩니다" |   thisGameIsStartedSoon: "잠시 후에 대국이 시작됩니다" | ||||||
|   waitingForOther: "상대의 준비가 완료될 때까지 기다리고 있습니다" |   waitingForOther: "상대의 준비가 완료될 때까지 기다리고 있습니다" | ||||||
|   waitingForMe: "당신의 준비 완료를 기다리고 있습니다" |   waitingForMe: "당신의 준비 완료를 기다리고 있습니다" | ||||||
|  |   waitingBoth: "준비해 주세요" | ||||||
|   ready: "준비 완료" |   ready: "준비 완료" | ||||||
|   cancelReady: "준비 취소" |   cancelReady: "준비 취소" | ||||||
|   opponentTurn: "상대의 차례입니다" |   opponentTurn: "상대의 차례입니다" | ||||||
| @@ -812,6 +910,7 @@ _channel: | |||||||
|   usersCount: "{n}명 참여 중" |   usersCount: "{n}명 참여 중" | ||||||
|   notesCount: "{n}노트" |   notesCount: "{n}노트" | ||||||
| _sidebar: | _sidebar: | ||||||
|  |   full: "전체" | ||||||
|   icon: "아이콘" |   icon: "아이콘" | ||||||
|   hide: "숨기기" |   hide: "숨기기" | ||||||
| _wordMute: | _wordMute: | ||||||
| @@ -820,12 +919,15 @@ _wordMute: | |||||||
|   muteWordsDescription2: "정규 표현식을 사용하려면 키워드를 빗금표(/)로 감싸 주세요." |   muteWordsDescription2: "정규 표현식을 사용하려면 키워드를 빗금표(/)로 감싸 주세요." | ||||||
|   softDescription: "지정한 조건의 노트를 타임라인에서 숨깁니다." |   softDescription: "지정한 조건의 노트를 타임라인에서 숨깁니다." | ||||||
|   hardDescription: "지정한 조건의 노트를 타임라인에 추가하지 않습니다. 타임라인에 추가되지 않은 노트는 조건을 변경해도 표시되지 않습니다." |   hardDescription: "지정한 조건의 노트를 타임라인에 추가하지 않습니다. 타임라인에 추가되지 않은 노트는 조건을 변경해도 표시되지 않습니다." | ||||||
|  |   soft: "보통" | ||||||
|  |   hard: "보다 높은 수준" | ||||||
|   mutedNotes: "뮤트된 노트" |   mutedNotes: "뮤트된 노트" | ||||||
| _theme: | _theme: | ||||||
|   explore: "테마 찾아보기" |   explore: "테마 찾아보기" | ||||||
|   install: "테마 설치" |   install: "테마 설치" | ||||||
|   manage: "테마 관리" |   manage: "테마 관리" | ||||||
|   code: "테마 코드" |   code: "테마 코드" | ||||||
|  |   description: "설명" | ||||||
|   installed: "{name} 테마가 설치되었습니다" |   installed: "{name} 테마가 설치되었습니다" | ||||||
|   installedThemes: "설치된 테마" |   installedThemes: "설치된 테마" | ||||||
|   builtinThemes: "표준 테마" |   builtinThemes: "표준 테마" | ||||||
| @@ -843,17 +945,57 @@ _theme: | |||||||
|   func: "함수" |   func: "함수" | ||||||
|   funcKind: "함수 종류" |   funcKind: "함수 종류" | ||||||
|   argument: "매개변수" |   argument: "매개변수" | ||||||
|  |   basedProp: "기준으로 할 속성 이름" | ||||||
|  |   alpha: "불투명도" | ||||||
|  |   darken: "어두움" | ||||||
|  |   lighten: "밝음" | ||||||
|   inputConstantName: "상수 이름을 입력하세요" |   inputConstantName: "상수 이름을 입력하세요" | ||||||
|   importInfo: "여기에 테마 코드를 붙여 넣어 에디터로 불러올 수 있습니다." |   importInfo: "여기에 테마 코드를 붙여 넣어 에디터로 불러올 수 있습니다." | ||||||
|   deleteConstantConfirm: "상수 {const}를 삭제하시겠습니까?" |   deleteConstantConfirm: "상수 {const}를 삭제하시겠습니까?" | ||||||
|   keys: |   keys: | ||||||
|     accent: "강조 색상" |     accent: "강조 색상" | ||||||
|  |     bg: "배경" | ||||||
|  |     fg: "텍스트" | ||||||
|  |     focus: "포커스" | ||||||
|  |     indicator: "인디케이터" | ||||||
|     panel: "패널" |     panel: "패널" | ||||||
|  |     shadow: "그림자" | ||||||
|  |     header: "헤더" | ||||||
|  |     navBg: "사이드바 배경" | ||||||
|  |     navFg: "사이드바 텍스트" | ||||||
|  |     navHoverFg: "사이드바 텍스트 (호버)" | ||||||
|  |     navActive: "사이드바 텍스트 (활성)" | ||||||
|  |     navIndicator: "사이드바 인디케이터" | ||||||
|     link: "링크" |     link: "링크" | ||||||
|     hashtag: "해시태그" |     hashtag: "해시태그" | ||||||
|     mention: "멘션" |     mention: "멘션" | ||||||
|  |     mentionMe: "나에게 보낸 멘션" | ||||||
|     renote: "Renote" |     renote: "Renote" | ||||||
|  |     modalBg: "모달 배경" | ||||||
|     divider: "구분선" |     divider: "구분선" | ||||||
|  |     scrollbarHandle: "스크롤바 핸들" | ||||||
|  |     scrollbarHandleHover: "스크롤바 핸들 (호버)" | ||||||
|  |     dateLabelFg: "날짜 레이블 텍스트" | ||||||
|  |     infoBg: "정보창 배경" | ||||||
|  |     infoFg: "정보창 텍스트" | ||||||
|  |     infoWarnBg: "경고창 배경" | ||||||
|  |     infoWarnFg: "경고창 텍스트" | ||||||
|  |     cwBg: "CW 버튼 배경" | ||||||
|  |     cwFg: "CW 버튼 텍스트" | ||||||
|  |     cwHoverBg: "CW 버튼 배경 (호버)" | ||||||
|  |     toastBg: "알림창 배경" | ||||||
|  |     toastFg: "알림창 텍스트" | ||||||
|  |     buttonBg: "버튼 배경" | ||||||
|  |     buttonHoverBg: "버튼 배경 (호버)" | ||||||
|  |     inputBorder: "입력 필드 테두리" | ||||||
|  |     listItemHoverBg: "리스트 항목 배경 (호버)" | ||||||
|  |     driveFolderBg: "드라이브 폴더 배경" | ||||||
|  |     wallpaperOverlay: "배경화면 오버레이" | ||||||
|  |     badge: "배지" | ||||||
|  |     messageBg: "채팅 배경" | ||||||
|  |     accentDarken: "강조 색상 (어두움)" | ||||||
|  |     accentLighten: "강조 색상 (밝음)" | ||||||
|  |     fgHighlighted: "강조된 텍스트" | ||||||
| _sfx: | _sfx: | ||||||
|   note: "새 노트" |   note: "새 노트" | ||||||
|   noteMy: "내 노트" |   noteMy: "내 노트" | ||||||
| @@ -977,8 +1119,10 @@ _widgets: | |||||||
|   postForm: "글 입력란" |   postForm: "글 입력란" | ||||||
|   slideshow: "슬라이드 쇼" |   slideshow: "슬라이드 쇼" | ||||||
|   button: "버튼" |   button: "버튼" | ||||||
|  |   onlineUsers: "온라인 유저" | ||||||
|   jobQueue: "작업 대기열" |   jobQueue: "작업 대기열" | ||||||
|   serverMetric: "서버 통계" |   serverMetric: "서버 통계" | ||||||
|  |   aiscript: "AiScript 콘솔" | ||||||
| _cw: | _cw: | ||||||
|   hide: "숨기기" |   hide: "숨기기" | ||||||
|   show: "더 보기" |   show: "더 보기" | ||||||
| @@ -1033,8 +1177,13 @@ _profile: | |||||||
|   username: "유저명" |   username: "유저명" | ||||||
|   description: "자기소개" |   description: "자기소개" | ||||||
|   youCanIncludeHashtags: "해시 태그를 포함할 수 있습니다." |   youCanIncludeHashtags: "해시 태그를 포함할 수 있습니다." | ||||||
|  |   metadata: "추가 정보" | ||||||
|  |   metadataEdit: "추가 정보 편집" | ||||||
|  |   metadataDescription: "프로필에 최대 4개의 추가 정보를 표시할 수 있어요" | ||||||
|   metadataLabel: "라벨" |   metadataLabel: "라벨" | ||||||
|   metadataContent: "내용" |   metadataContent: "내용" | ||||||
|  |   changeAvatar: "아바타 이미지 변경" | ||||||
|  |   changeBanner: "배너 이미지 변경" | ||||||
| _exportOrImport: | _exportOrImport: | ||||||
|   allNotes: "모든 노트" |   allNotes: "모든 노트" | ||||||
|   followingList: "팔로잉" |   followingList: "팔로잉" | ||||||
| @@ -1434,19 +1583,30 @@ _notification: | |||||||
|   youGotQuote: "{name}님이 인용함" |   youGotQuote: "{name}님이 인용함" | ||||||
|   youRenoted: "{name}님이 Renote" |   youRenoted: "{name}님이 Renote" | ||||||
|   youGotPoll: "{name}님이 투표함" |   youGotPoll: "{name}님이 투표함" | ||||||
|  |   youGotMessagingMessageFromUser: "{name} 님이 보낸 채팅이 있어요" | ||||||
|  |   youGotMessagingMessageFromGroup: "{name}에서 보낸 채팅이 있어요" | ||||||
|   youWereFollowed: "새로운 팔로워가 있습니다" |   youWereFollowed: "새로운 팔로워가 있습니다" | ||||||
|   youReceivedFollowRequest: "새로운 팔로우 요청이 있습니다" |   youReceivedFollowRequest: "새로운 팔로우 요청이 있습니다" | ||||||
|   yourFollowRequestAccepted: "팔로우 요청이 수락되었습니다" |   yourFollowRequestAccepted: "팔로우 요청이 수락되었습니다" | ||||||
|   youWereInvitedToGroup: "그룹에 초대되었습니다" |   youWereInvitedToGroup: "그룹에 초대되었습니다" | ||||||
|   _types: |   _types: | ||||||
|  |     all: "전부" | ||||||
|     follow: "팔로잉" |     follow: "팔로잉" | ||||||
|     mention: "멘션" |     mention: "멘션" | ||||||
|  |     reply: "답글" | ||||||
|     renote: "Renote" |     renote: "Renote" | ||||||
|     quote: "인용" |     quote: "인용" | ||||||
|     reaction: "리액션" |     reaction: "리액션" | ||||||
|  |     pollVote: "투표 참여" | ||||||
|  |     receiveFollowRequest: "팔로우 요청을 받았을 때" | ||||||
|  |     followRequestAccepted: "팔로우 요청이 승인되었을 때" | ||||||
|  |     groupInvited: "그룹에 초대되었을 때" | ||||||
|  |     app: "연동된 앱을 통한 알림" | ||||||
| _deck: | _deck: | ||||||
|   alwaysShowMainColumn: "메인 칼럼 항상 표시" |   alwaysShowMainColumn: "메인 칼럼 항상 표시" | ||||||
|   columnAlign: "칼럼 정렬" |   columnAlign: "칼럼 정렬" | ||||||
|  |   columnMargin: "칼럼 간 여백" | ||||||
|  |   columnHeaderHeight: "칼럼 헤더 폭" | ||||||
|   addColumn: "칼럼 추가" |   addColumn: "칼럼 추가" | ||||||
|   swapLeft: "왼쪽으로 이동" |   swapLeft: "왼쪽으로 이동" | ||||||
|   swapRight: "오른쪽으로 이동" |   swapRight: "오른쪽으로 이동" | ||||||
|   | |||||||
| @@ -1,2 +1,3 @@ | |||||||
| --- | --- | ||||||
| _lang_: "Nederlands" | _lang_: "Nederlands" | ||||||
|  | headlineMisskey: "Netwerk verbonden door notities" | ||||||
|   | |||||||
| @@ -1,11 +1,13 @@ | |||||||
| --- | --- | ||||||
| _lang_: "język polski" | _lang_: "język polski" | ||||||
| headlineMisskey: "Sieć połączona wpisami" | headlineMisskey: "Sieć połączona wpisami" | ||||||
|  | introMisskey: "Misskey jest serwisem mikroblogowym typu open source.\nMisskey to opensource'owy serwis mikroblogowy, w którym możesz tworzyć \"notatki\", aby dzielić się tym, co się dzieje i opowiadać wszystkim o sobie.\nMożesz również użyć funkcji \"Reakcje\", aby szybko dodać własne reakcje do notatek innych użytkowników👍.\nOdkrywaj nowy świat🚀!" | ||||||
| monthAndDay: "{month}-{day}" | monthAndDay: "{month}-{day}" | ||||||
| search: "Szukaj" | search: "Szukaj" | ||||||
| notifications: "Powiadomienia" | notifications: "Powiadomienia" | ||||||
| username: "Nazwa użytkownika" | username: "Nazwa użytkownika" | ||||||
| password: "Hasło" | password: "Hasło" | ||||||
|  | forgotPassword: "Nie pamiętam hasła" | ||||||
| fetchingAsApObject: "Pobieranie z Fediwersum…" | fetchingAsApObject: "Pobieranie z Fediwersum…" | ||||||
| ok: "OK" | ok: "OK" | ||||||
| gotIt: "Rozumiem!" | gotIt: "Rozumiem!" | ||||||
| @@ -61,7 +63,10 @@ import: "Importuj" | |||||||
| export: "Eksportuj" | export: "Eksportuj" | ||||||
| files: "Pliki" | files: "Pliki" | ||||||
| download: "Pobierz" | download: "Pobierz" | ||||||
|  | driveFileDeleteConfirm: "Czy chcesz usunąć plik \"{name}\"? Zniknie również notatka, do której dołączony jest ten plik." | ||||||
| unfollowConfirm: "Czy na pewno chcesz przestać obserwować {name}?" | unfollowConfirm: "Czy na pewno chcesz przestać obserwować {name}?" | ||||||
|  | exportRequested: "Zażądałeś eksportu. Może to zająć trochę czasu. Po zakończeniu eksportu zostanie on dodany do Twoich \"dysków\"." | ||||||
|  | importRequested: "Zażądano importu. Może to zająć chwilę." | ||||||
| lists: "Listy" | lists: "Listy" | ||||||
| noLists: "Nie masz żadnych list" | noLists: "Nie masz żadnych list" | ||||||
| note: "Utwórz wpis" | note: "Utwórz wpis" | ||||||
| @@ -130,10 +135,11 @@ settingGuide: "Proponowana konfiguracja" | |||||||
| cacheRemoteFiles: "Przechowuj zdalne pliki w pamięci podręcznej" | cacheRemoteFiles: "Przechowuj zdalne pliki w pamięci podręcznej" | ||||||
| cacheRemoteFilesDescription: "Gdy ta opcja jest wyłączona, zdalne pliki są ładowane bezpośrednio ze zdalnych instancji. Wyłączenie the opcji zmniejszy użycie powierzchni dyskowej, ale zwiększy transfer, ponieważ miniaturki nie będą generowane." | cacheRemoteFilesDescription: "Gdy ta opcja jest wyłączona, zdalne pliki są ładowane bezpośrednio ze zdalnych instancji. Wyłączenie the opcji zmniejszy użycie powierzchni dyskowej, ale zwiększy transfer, ponieważ miniaturki nie będą generowane." | ||||||
| flagAsBot: "To konto jest botem" | flagAsBot: "To konto jest botem" | ||||||
|  | flagAsBotDescription: "Jeżeli ten kanał jest kontrolowany przez jakiś program, ustaw tę opcję. Jeżeli włączona, będzie działać jako flaga informująca innych programistów, aby zapobiegać nieskończonej interakcji z różnymi botami i dostosowywać wewnętrzne systemy Misskey, traktując konto jako bota." | ||||||
| flagAsCat: "To konto jest kotem" | flagAsCat: "To konto jest kotem" | ||||||
| flagAsCatDescription: "Przełącz tę opcję, aby konto było oznaczone jako kot." | flagAsCatDescription: "Przełącz tę opcję, aby konto było oznaczone jako kot." | ||||||
| autoAcceptFollowed: "Automatycznie przyjmuj prośby o możliwość obserwacji od użytkowników, których obserwujesz" | autoAcceptFollowed: "Automatycznie przyjmuj prośby o możliwość obserwacji od użytkowników, których obserwujesz" | ||||||
| addAcount: "Dodaj konto" | addAccount: "Dodaj konto" | ||||||
| loginFailed: "Nie udało się zalogować" | loginFailed: "Nie udało się zalogować" | ||||||
| showOnRemote: "Zobacz na zdalnej instancji" | showOnRemote: "Zobacz na zdalnej instancji" | ||||||
| general: "Ogólne" | general: "Ogólne" | ||||||
| @@ -177,6 +183,7 @@ clearQueueConfirmTitle: "Czy na pewno chcesz wyczyścić kolejkę?" | |||||||
| clearCachedFiles: "Wyczyść pamięć podręczną" | clearCachedFiles: "Wyczyść pamięć podręczną" | ||||||
| clearCachedFilesConfirm: "Czy na pewno chcesz usunąć wszystkie zdalne pliki z pamięci podręcznej?" | clearCachedFilesConfirm: "Czy na pewno chcesz usunąć wszystkie zdalne pliki z pamięci podręcznej?" | ||||||
| blockedInstances: "Zablokowane instancje" | blockedInstances: "Zablokowane instancje" | ||||||
|  | blockedInstancesDescription: "Wypisz nazwy hostów instancji, które powinny zostać zablokowane. Wypisane instancje nie będą mogły dłużej komunikować się z tą instancją." | ||||||
| muteAndBlock: "Wycisz / Zablokuj" | muteAndBlock: "Wycisz / Zablokuj" | ||||||
| mutedUsers: "Wyciszeni użytkownicy" | mutedUsers: "Wyciszeni użytkownicy" | ||||||
| blockedUsers: "Zablokowani użytkownicy" | blockedUsers: "Zablokowani użytkownicy" | ||||||
| @@ -269,6 +276,7 @@ emptyDrive: "Dysk jest pusty" | |||||||
| emptyFolder: "Ten katalog jest pusty" | emptyFolder: "Ten katalog jest pusty" | ||||||
| unableToDelete: "Nie można usunąć" | unableToDelete: "Nie można usunąć" | ||||||
| inputNewFileName: "Wprowadź nową nazwę pliku" | inputNewFileName: "Wprowadź nową nazwę pliku" | ||||||
|  | inputNewDescription: "Proszę wpisać nowy napis" | ||||||
| inputNewFolderName: "Wprowadź nową nazwę katalogu" | inputNewFolderName: "Wprowadź nową nazwę katalogu" | ||||||
| circularReferenceFolder: "Katalog docelowy jest podkatalogiem katalogu, który chcesz przenieść." | circularReferenceFolder: "Katalog docelowy jest podkatalogiem katalogu, który chcesz przenieść." | ||||||
| hasChildFilesOrFolders: "Ponieważ ten katalog nie jest pusty, nie może być usunięty." | hasChildFilesOrFolders: "Ponieważ ten katalog nie jest pusty, nie może być usunięty." | ||||||
| @@ -289,16 +297,17 @@ reject: "Odrzuć" | |||||||
| normal: "Normalny" | normal: "Normalny" | ||||||
| instanceName: "Nazwa instancji" | instanceName: "Nazwa instancji" | ||||||
| instanceDescription: "Opis instancji" | instanceDescription: "Opis instancji" | ||||||
|  | maintainerName: "Administrator" | ||||||
|  | maintainerEmail: "E-mail administratora" | ||||||
| tosUrl: "Adres URL regulaminu" | tosUrl: "Adres URL regulaminu" | ||||||
| thisYear: "Rok" | thisYear: "Rok" | ||||||
| thisMonth: "Miesiąc" | thisMonth: "Miesiąc" | ||||||
| today: "Dziś" | today: "Dziś" | ||||||
| dayX: "{day}" | dayX: "{day}" | ||||||
| monthX: "{month}" | monthX: "{month}" | ||||||
|  | yearX: "{year}" | ||||||
| pages: "Strony" | pages: "Strony" | ||||||
| integration: "Integracja" | integration: "Integracja" | ||||||
| connectSerice: "Połącz" |  | ||||||
| disconnectSerice: "Rozłącz" |  | ||||||
| enableLocalTimeline: "Włącz lokalną oś czasu" | enableLocalTimeline: "Włącz lokalną oś czasu" | ||||||
| enableGlobalTimeline: "Włącz globalną oś czasu" | enableGlobalTimeline: "Włącz globalną oś czasu" | ||||||
| disablingTimelinesInfo: "Administratorzy i moderatorzy będą zawsze mieć dostęp do wszystkich osi czasu, nawet gdy są one wyłączone." | disablingTimelinesInfo: "Administratorzy i moderatorzy będą zawsze mieć dostęp do wszystkich osi czasu, nawet gdy są one wyłączone." | ||||||
| @@ -330,8 +339,8 @@ manageAntennas: "Zarządzaj Antenami" | |||||||
| name: "Nazwa" | name: "Nazwa" | ||||||
| antennaSource: "Źródło Anteny" | antennaSource: "Źródło Anteny" | ||||||
| antennaExcludeKeywords: "Wykluczone słowa kluczowe" | antennaExcludeKeywords: "Wykluczone słowa kluczowe" | ||||||
|  | notifyAntenna: "Powiadamiaj o nowych wpisach" | ||||||
| withFileAntenna: "Filtruj tylko wpisy z załączonym plikiem" | withFileAntenna: "Filtruj tylko wpisy z załączonym plikiem" | ||||||
| serviceworker: "ServiceWorker" |  | ||||||
| enableServiceworker: "Włącz ServiceWorker" | enableServiceworker: "Włącz ServiceWorker" | ||||||
| antennaUsersDescription: "Wypisz po jednej nazwie użytkownika w linii" | antennaUsersDescription: "Wypisz po jednej nazwie użytkownika w linii" | ||||||
| caseSensitive: "Wielkość liter ma znaczenie" | caseSensitive: "Wielkość liter ma znaczenie" | ||||||
| @@ -357,6 +366,7 @@ administrator: "Admin" | |||||||
| token: "Token" | token: "Token" | ||||||
| twoStepAuthentication: "Uwierzytelnianie dwuskładnikowe" | twoStepAuthentication: "Uwierzytelnianie dwuskładnikowe" | ||||||
| moderator: "Moderator" | moderator: "Moderator" | ||||||
|  | nUsersMentioned: "{n} wspomnianych użytkowników" | ||||||
| securityKey: "Klucz bezpieczeństwa" | securityKey: "Klucz bezpieczeństwa" | ||||||
| securityKeyName: "Nazwa klucza" | securityKeyName: "Nazwa klucza" | ||||||
| registerSecurityKey: "Zarejestruj klucz bezpieczeństwa" | registerSecurityKey: "Zarejestruj klucz bezpieczeństwa" | ||||||
| @@ -396,6 +406,7 @@ retype: "Wprowadź ponownie" | |||||||
| noteOf: "Wpisy {user}" | noteOf: "Wpisy {user}" | ||||||
| inviteToGroup: "Zaproś do grupy" | inviteToGroup: "Zaproś do grupy" | ||||||
| maxNoteTextLength: "Limit znaków dla wpisów" | maxNoteTextLength: "Limit znaków dla wpisów" | ||||||
|  | quoteAttached: "Zacytowano" | ||||||
| quoteQuestion: "Czy na pewno chcesz umieścić cytat?" | quoteQuestion: "Czy na pewno chcesz umieścić cytat?" | ||||||
| noMessagesYet: "Nie napisano jeszcze wiadomości" | noMessagesYet: "Nie napisano jeszcze wiadomości" | ||||||
| newMessageExists: "Masz nową wiadomość" | newMessageExists: "Masz nową wiadomość" | ||||||
| @@ -418,6 +429,7 @@ signinWith: "Zaloguj się z {x}" | |||||||
| signinFailed: "Nie udało się zalogować. Wprowadzona nazwa użytkownika lub hasło są nieprawidłowe." | signinFailed: "Nie udało się zalogować. Wprowadzona nazwa użytkownika lub hasło są nieprawidłowe." | ||||||
| tapSecurityKey: "Wybierz swój klucz bezpieczeństwa" | tapSecurityKey: "Wybierz swój klucz bezpieczeństwa" | ||||||
| or: "Lub" | or: "Lub" | ||||||
|  | language: "Język" | ||||||
| uiLanguage: "Język wyświetlania UI" | uiLanguage: "Język wyświetlania UI" | ||||||
| groupInvited: "Zaproszony(-a) do grupy" | groupInvited: "Zaproszony(-a) do grupy" | ||||||
| aboutX: "O {x}" | aboutX: "O {x}" | ||||||
| @@ -431,7 +443,7 @@ category: "Kategoria" | |||||||
| tags: "Tagi" | tags: "Tagi" | ||||||
| docSource: "Źródło tego dokumentu" | docSource: "Źródło tego dokumentu" | ||||||
| createAccount: "Utwórz konto" | createAccount: "Utwórz konto" | ||||||
| existingAcount: "Istniejące konta" | existingAccount: "Istniejące konto" | ||||||
| regenerate: "Wygeneruj ponownie" | regenerate: "Wygeneruj ponownie" | ||||||
| fontSize: "Rozmiar czcionki" | fontSize: "Rozmiar czcionki" | ||||||
| noFollowRequests: "Nie masz żadnych oczekujących próśb o możliwość obserwacji" | noFollowRequests: "Nie masz żadnych oczekujących próśb o możliwość obserwacji" | ||||||
| @@ -453,6 +465,8 @@ showFeaturedNotesInTimeline: "Pokazuj wyróżnione wpisy w osi czasu" | |||||||
| objectStorage: "Pamięć obiektowa" | objectStorage: "Pamięć obiektowa" | ||||||
| useObjectStorage: "Używaj pamięci obiektowej" | useObjectStorage: "Używaj pamięci obiektowej" | ||||||
| objectStorageBaseUrl: "Podstawowy URL" | objectStorageBaseUrl: "Podstawowy URL" | ||||||
|  | objectStorageBucket: "Bucket" | ||||||
|  | objectStorageBucketDesc: "Podaj nazwę „wiadra” używaną przez konfigurowaną usługę." | ||||||
| objectStoragePrefix: "Prefiks" | objectStoragePrefix: "Prefiks" | ||||||
| objectStoragePrefixDesc: "Pliki będą przechowywane w katalogu z tym prefiksem." | objectStoragePrefixDesc: "Pliki będą przechowywane w katalogu z tym prefiksem." | ||||||
| objectStorageEndpoint: "Punkt końcowy" | objectStorageEndpoint: "Punkt końcowy" | ||||||
| @@ -519,6 +533,8 @@ disablePlayer: "Zamknij odtwarzacz wideo" | |||||||
| expandTweet: "Rozwiń tweet" | expandTweet: "Rozwiń tweet" | ||||||
| themeEditor: "Edytor motywu" | themeEditor: "Edytor motywu" | ||||||
| description: "Opis" | description: "Opis" | ||||||
|  | describeFile: "dodaj podpis" | ||||||
|  | enterFileDescription: "Wprowadź napis" | ||||||
| author: "Autor" | author: "Autor" | ||||||
| leaveConfirm: "Są niezapisane zmiany. Czy chcesz je odrzucić?" | leaveConfirm: "Są niezapisane zmiany. Czy chcesz je odrzucić?" | ||||||
| manage: "Zarządzanie" | manage: "Zarządzanie" | ||||||
| @@ -540,7 +556,7 @@ pluginTokenRequestedDescription: "Ta wtyczka będzie mogła korzystać z ustawio | |||||||
| notificationType: "Rodzaj powiadomień" | notificationType: "Rodzaj powiadomień" | ||||||
| edit: "Edytuj" | edit: "Edytuj" | ||||||
| useStarForReactionFallback: "Użyj ★ jako zapasowego emoji, gdy emoji reakcji jest nieznane" | useStarForReactionFallback: "Użyj ★ jako zapasowego emoji, gdy emoji reakcji jest nieznane" | ||||||
| emailConfig: "Konfiguracja serwera e-mail" | emailServer: "Serwer poczty e-mail" | ||||||
| enableEmail: "Włącz dostarczanie wiadomości e-mail" | enableEmail: "Włącz dostarczanie wiadomości e-mail" | ||||||
| emailConfigInfo: "Wykorzystywany do potwierdzenia adresu e-mail w trakcie rejestracji, lub gdy zapomnisz hasła" | emailConfigInfo: "Wykorzystywany do potwierdzenia adresu e-mail w trakcie rejestracji, lub gdy zapomnisz hasła" | ||||||
| email: "Adres e-mail" | email: "Adres e-mail" | ||||||
| @@ -553,6 +569,7 @@ smtpPass: "Hasło" | |||||||
| emptyToDisableSmtpAuth: "Pozostaw adres e-mail i hasło puste, aby wyłączyć weryfikację SMTP" | emptyToDisableSmtpAuth: "Pozostaw adres e-mail i hasło puste, aby wyłączyć weryfikację SMTP" | ||||||
| smtpSecureInfo: "Wyłącz, jeżeli używasz STARTTLS" | smtpSecureInfo: "Wyłącz, jeżeli używasz STARTTLS" | ||||||
| testEmail: "Przetestuj dostarczanie wiadomości e-mail" | testEmail: "Przetestuj dostarczanie wiadomości e-mail" | ||||||
|  | wordMute: "Wyciszenie słowa" | ||||||
| userSaysSomething: "{name} powiedział(-a) coś" | userSaysSomething: "{name} powiedział(-a) coś" | ||||||
| makeActive: "Aktywuj" | makeActive: "Aktywuj" | ||||||
| display: "Wyświetlanie" | display: "Wyświetlanie" | ||||||
| @@ -623,6 +640,7 @@ emailVerified: "Adres e-mail został potwierdzony" | |||||||
| noteFavoritesCount: "Liczba polubionych wpisów" | noteFavoritesCount: "Liczba polubionych wpisów" | ||||||
| pageLikesCount: "Liczba otrzymanych polubień stron" | pageLikesCount: "Liczba otrzymanych polubień stron" | ||||||
| pageLikedCount: "Liczba polubionych stron" | pageLikedCount: "Liczba polubionych stron" | ||||||
|  | reversiCount: "Liczba rozgrywek Reversi" | ||||||
| contact: "Kontakt" | contact: "Kontakt" | ||||||
| useSystemFont: "Używaj domyślnej czcionki systemu" | useSystemFont: "Używaj domyślnej czcionki systemu" | ||||||
| experimentalFeatures: "Eksperymentalne funkcje" | experimentalFeatures: "Eksperymentalne funkcje" | ||||||
| @@ -631,6 +649,7 @@ makeExplorable: "Pokazuj konto na stronie „Eksploruj”" | |||||||
| makeExplorableDescription: "Jeżeli wyłączysz tę opcję, Twoje konto nie będzie wyświetlać się w sekcji „Eksploruj”." | makeExplorableDescription: "Jeżeli wyłączysz tę opcję, Twoje konto nie będzie wyświetlać się w sekcji „Eksploruj”." | ||||||
| showGapBetweenNotesInTimeline: "Pokazuj odstęp między wpisami na osi czasu." | showGapBetweenNotesInTimeline: "Pokazuj odstęp między wpisami na osi czasu." | ||||||
| duplicate: "Duplikuj" | duplicate: "Duplikuj" | ||||||
|  | left: "Lewo" | ||||||
| center: "Wyśsrodkuj" | center: "Wyśsrodkuj" | ||||||
| wide: "Szerokie" | wide: "Szerokie" | ||||||
| narrow: "Wąskie" | narrow: "Wąskie" | ||||||
| @@ -640,16 +659,107 @@ clearCache: "Wyczyść pamięć podręczną" | |||||||
| onlineUsersCount: "{n} osób jest online" | onlineUsersCount: "{n} osób jest online" | ||||||
| nUsers: "{n} użytkowników" | nUsers: "{n} użytkowników" | ||||||
| nNotes: "{n} wpisów" | nNotes: "{n} wpisów" | ||||||
|  | sendErrorReports: "Wyślij raporty o błędach" | ||||||
|  | myTheme: "Mój motyw" | ||||||
| backgroundColor: "Tło" | backgroundColor: "Tło" | ||||||
| accentColor: "Akcent" | accentColor: "Akcent" | ||||||
| textColor: "Tekst" | textColor: "Tekst" | ||||||
|  | saveAs: "Zapisz jako…" | ||||||
|  | advanced: "Zaawansowane" | ||||||
| value: "Wartość" | value: "Wartość" | ||||||
|  | createdAt: "Utworzono" | ||||||
|  | updatedAt: "Zaktualizowano" | ||||||
|  | saveConfirm: "Zapisać zmiany?" | ||||||
|  | deleteConfirm: "Na pewno usunąć?" | ||||||
|  | invalidValue: "Nieprawidłowa wartość." | ||||||
|  | registry: "Rejestr" | ||||||
|  | closeAccount: "Zamknij konto" | ||||||
|  | currentVersion: "Bieżąca wersja" | ||||||
|  | latestVersion: "Najnowsza wersja" | ||||||
|  | youAreRunningUpToDateClient: "Korzystasz z najnowszej wersji klienta." | ||||||
|  | newVersionOfClientAvailable: "Nowsza wersja klienta jest dostępna." | ||||||
|  | usageAmount: "Użycie" | ||||||
|  | capacity: "Pojemność" | ||||||
|  | inUse: "Użyto" | ||||||
|  | editCode: "Edytuj kod" | ||||||
|  | apply: "Zastosuj" | ||||||
|  | receiveAnnouncementFromInstance: "Otrzymuj powiadomienia e-mail z tej instancji" | ||||||
|  | emailNotification: "Powiadomienia e-mail" | ||||||
|  | publish: "Publikuj" | ||||||
|  | inChannelSearch: "Szukaj na kanale" | ||||||
|  | useReactionPickerForContextMenu: "Otwórz wybornik reakcji prawym kliknięciem" | ||||||
|  | typingUsers: "{users} pisze(-ą)..." | ||||||
|  | jumpToSpecifiedDate: "Przejdź do określonej daty" | ||||||
|  | showingPastTimeline: "Obecnie wyświetla starą oś czasu" | ||||||
|  | clear: "Wróć" | ||||||
|  | markAllAsRead: "Oznacz wszystkie jako przeczytane" | ||||||
|  | goBack: "Wróć" | ||||||
|  | unlikeConfirm: "Na pewno chcesz usunąć polubienie?" | ||||||
|  | fullView: "Pełny widok" | ||||||
|  | quitFullView: "Opuść pełny widok" | ||||||
|  | addDescription: "Dodaj opis" | ||||||
|  | info: "Informacje" | ||||||
|  | userInfo: "Informacje o użykowniku" | ||||||
|  | unknown: "Nieznane" | ||||||
|  | onlineStatus: "Status online" | ||||||
|  | hideOnlineStatus: "Ukryj status online" | ||||||
|  | hideOnlineStatusDescription: "Ukrywanie statusu online ogranicza wygody niektórych funkcji, tj. wyszukiwanie" | ||||||
|  | online: "Online" | ||||||
|  | active: "Aktywny" | ||||||
|  | offline: "Offline" | ||||||
|  | notRecommended: "Nie zalecane" | ||||||
|  | botProtection: "Zabezpieczenie przed botami" | ||||||
|  | instanceBlocking: "Zablokowane instancje" | ||||||
|  | selectAccount: "Wybierz konto" | ||||||
|  | enabled: "Właczono" | ||||||
|  | disabled: "Wyłączono" | ||||||
|  | quickAction: "Szybkie działania" | ||||||
|  | user: "Użytkownicy" | ||||||
|  | administration: "Zarządzanie" | ||||||
|  | accounts: "Konta" | ||||||
|  | switch: "Przełącz" | ||||||
|  | noMaintainerInformationWarning: "Informacje o administratorze nie są skonfigurowane." | ||||||
|  | noBotProtectionWarning: "Zabezpieczenie przed botami nie jest skonfigurowane." | ||||||
|  | configure: "Skonfiguruj" | ||||||
|  | postToGallery: "Opublikuj w galerii" | ||||||
|  | gallery: "Galeria" | ||||||
|  | recentPosts: "Ostatnie wpisy" | ||||||
|  | popularPosts: "Popularne wpisy" | ||||||
|  | shareWithNote: "Udostępnij z wpisem" | ||||||
|  | ads: "Reklamy" | ||||||
|  | expiration: "Ankieta kończy się" | ||||||
|  | memo: "Notatki" | ||||||
|  | priority: "Priorytet" | ||||||
|  | high: "Wysoki" | ||||||
|  | middle: "Średnie" | ||||||
|  | low: "Niski" | ||||||
|  | emailNotConfiguredWarning: "Nie podano adresu e-mail" | ||||||
|  | ratio: "Stosunek" | ||||||
|  | _ad: | ||||||
|  |   back: "Wróć" | ||||||
|  |   reduceFrequencyOfThisAd: "Pokazuj tę reklamę rzadziej" | ||||||
|  | _forgotPassword: | ||||||
|  |   ifNoEmail: "Jeżeli nie podano adresu e-mail podczas rejestracji, skontaktuj się z administratorem zamiast tego." | ||||||
|  |   contactAdmin: "Jeżeli Twoja instancja nie obsługuje adresów e-mail, skontaktuj się zamiast tego z administratorem, aby zresetować hasło." | ||||||
|  | _gallery: | ||||||
|  |   my: "Moja galeria" | ||||||
|  |   liked: "Polubione wpisy" | ||||||
|  |   like: "Polub" | ||||||
|  |   unlike: "Cofnij polubienie" | ||||||
| _email: | _email: | ||||||
|   _follow: |   _follow: | ||||||
|     title: "Zaobserwował(a) Cię" |     title: "Zaobserwował(a) Cię" | ||||||
|  |   _receiveFollowRequest: | ||||||
|  |     title: "Otrzymano prośbę o możliwość obserwacji" | ||||||
|  | _plugin: | ||||||
|  |   install: "Zainstaluj wtyczki" | ||||||
|  |   installWarn: "Nie instaluj niezaufanych wtyczek." | ||||||
|  |   manage: "Zarządzanie wtyczkami" | ||||||
| _registry: | _registry: | ||||||
|  |   scope: "Zakres" | ||||||
|   key: "Klucz" |   key: "Klucz" | ||||||
|   keys: "Klucz" |   keys: "Klucz" | ||||||
|  |   domain: "Domena" | ||||||
|   createKey: "Utwórz klucz" |   createKey: "Utwórz klucz" | ||||||
| _aboutMisskey: | _aboutMisskey: | ||||||
|   about: "Misskey jest oprogramowanie open source rozwijanym przez syuilo od 2014." |   about: "Misskey jest oprogramowanie open source rozwijanym przez syuilo od 2014." | ||||||
| @@ -699,6 +809,7 @@ _mfm: | |||||||
|   x4Description: "Czyni treść jeszcze większą niż jeszcze większa." |   x4Description: "Czyni treść jeszcze większą niż jeszcze większa." | ||||||
|   blur: "Rozmycie" |   blur: "Rozmycie" | ||||||
|   font: "Czcionka" |   font: "Czcionka" | ||||||
|  |   fontDescription: "Wybiera czcionkę do wyświetlania treści." | ||||||
| _reversi: | _reversi: | ||||||
|   reversi: "Reversi" |   reversi: "Reversi" | ||||||
|   gameSettings: "Ustawienia gry" |   gameSettings: "Ustawienia gry" | ||||||
| @@ -762,6 +873,7 @@ _theme: | |||||||
|   install: "Zainstaluj motyw" |   install: "Zainstaluj motyw" | ||||||
|   manage: "Zarządzanie motywami" |   manage: "Zarządzanie motywami" | ||||||
|   code: "Kod motywu" |   code: "Kod motywu" | ||||||
|  |   description: "Opis" | ||||||
|   installed: "Zainstalowano {name}" |   installed: "Zainstalowano {name}" | ||||||
|   installedThemes: "Zainstalowane motywy" |   installedThemes: "Zainstalowane motywy" | ||||||
|   builtinThemes: "Wbudowane motywy" |   builtinThemes: "Wbudowane motywy" | ||||||
| @@ -962,16 +1074,21 @@ _profile: | |||||||
|   username: "Nazwa użytkownika" |   username: "Nazwa użytkownika" | ||||||
|   description: "Opis" |   description: "Opis" | ||||||
|   youCanIncludeHashtags: "Możesz umieścić hashtagi w swoim opisie." |   youCanIncludeHashtags: "Możesz umieścić hashtagi w swoim opisie." | ||||||
|  |   metadata: "Dodatkowe informacje" | ||||||
|  |   metadataEdit: "Edytuj dodatkowe informacje" | ||||||
|  |   metadataDescription: "Możesz wyświetlać do czterech sekcji dodatkowych informacji na swoim profilu." | ||||||
|   metadataLabel: "Etykieta" |   metadataLabel: "Etykieta" | ||||||
|   metadataContent: "Treść" |   metadataContent: "Treść" | ||||||
|   changeAvatar: "Zmień awatar" |   changeAvatar: "Zmień awatar" | ||||||
|   changeBanner: "Zmień baner" |   changeBanner: "Zmień baner" | ||||||
| _exportOrImport: | _exportOrImport: | ||||||
|  |   allNotes: "Wszystkie wpisy" | ||||||
|   followingList: "Obserwowani" |   followingList: "Obserwowani" | ||||||
|   muteList: "Wycisz" |   muteList: "Wycisz" | ||||||
|   blockingList: "Zablokuj" |   blockingList: "Zablokuj" | ||||||
|   userLists: "Listy" |   userLists: "Listy" | ||||||
| _charts: | _charts: | ||||||
|  |   federationInstancesTotal: "Łącznie sfederowanych instancji" | ||||||
|   usersTotal: "Łącznie # użytkowników" |   usersTotal: "Łącznie # użytkowników" | ||||||
|   activeUsers: "Aktywni użytkownicy" |   activeUsers: "Aktywni użytkownicy" | ||||||
| _instanceCharts: | _instanceCharts: | ||||||
| @@ -986,6 +1103,7 @@ _instanceCharts: | |||||||
| _timelines: | _timelines: | ||||||
|   home: "Strona główna" |   home: "Strona główna" | ||||||
|   local: "Lokalne" |   local: "Lokalne" | ||||||
|  |   social: "Społeczność" | ||||||
|   global: "Globalna" |   global: "Globalna" | ||||||
| _rooms: | _rooms: | ||||||
|   roomOf: "Pokój {user}" |   roomOf: "Pokój {user}" | ||||||
| @@ -1356,6 +1474,8 @@ _deck: | |||||||
|   swapRight: "Przesuń w prawo" |   swapRight: "Przesuń w prawo" | ||||||
|   swapUp: "Zamień z powyższym" |   swapUp: "Zamień z powyższym" | ||||||
|   swapDown: "Zamień z poniższym" |   swapDown: "Zamień z poniższym" | ||||||
|  |   stackLeft: "Przypnij do lewej" | ||||||
|  |   popRight: "Odepnij w prawo" | ||||||
|   profile: "Profil" |   profile: "Profil" | ||||||
|   _columns: |   _columns: | ||||||
|     main: "Główna" |     main: "Główna" | ||||||
|   | |||||||
| @@ -138,7 +138,7 @@ flagAsBotDescription: "Включите, если этот аккаунт упр | |||||||
| flagAsCat: "Аккаунт кота" | flagAsCat: "Аккаунт кота" | ||||||
| flagAsCatDescription: "Включите, и этот аккаунт будет помечен как кошачий." | flagAsCatDescription: "Включите, и этот аккаунт будет помечен как кошачий." | ||||||
| autoAcceptFollowed: "Принимать подписчиков автоматически" | autoAcceptFollowed: "Принимать подписчиков автоматически" | ||||||
| addAcount: "Добавить аккаунт" | addAccount: "Добавить учётную запись" | ||||||
| loginFailed: "Неудачная попытка входа" | loginFailed: "Неудачная попытка входа" | ||||||
| showOnRemote: "Перейти к оригиналу на сайт" | showOnRemote: "Перейти к оригиналу на сайт" | ||||||
| general: "Общее" | general: "Общее" | ||||||
| @@ -241,7 +241,7 @@ explore: "Обзор" | |||||||
| games: "Игры Misskey" | games: "Игры Misskey" | ||||||
| messageRead: "Прочитали" | messageRead: "Прочитали" | ||||||
| noMoreHistory: "История закончилась" | noMoreHistory: "История закончилась" | ||||||
| startMessaging: "Отправить сообщение" | startMessaging: "Начать общение" | ||||||
| nUsersRead: "Прочитали {n}" | nUsersRead: "Прочитали {n}" | ||||||
| agreeTo: "Я соглашаюсь с {0}" | agreeTo: "Я соглашаюсь с {0}" | ||||||
| tos: "Пользовательское соглашение" | tos: "Пользовательское соглашение" | ||||||
| @@ -309,8 +309,6 @@ monthX: "{month} месяц" | |||||||
| yearX: "{year} год" | yearX: "{year} год" | ||||||
| pages: "Страницы" | pages: "Страницы" | ||||||
| integration: "Интеграция" | integration: "Интеграция" | ||||||
| connectSerice: "Соединение" |  | ||||||
| disconnectSerice: "Отключение" |  | ||||||
| enableLocalTimeline: "Включить локальную ленту" | enableLocalTimeline: "Включить локальную ленту" | ||||||
| enableGlobalTimeline: "Включить глобальную ленту" | enableGlobalTimeline: "Включить глобальную ленту" | ||||||
| disablingTimelinesInfo: "У администраторов и модераторов есть доступ ко всем лентам, даже если они отключены." | disablingTimelinesInfo: "У администраторов и модераторов есть доступ ко всем лентам, даже если они отключены." | ||||||
| @@ -329,7 +327,7 @@ pinnedUsers: "Прикреплённый пользователь" | |||||||
| pinnedUsersDescription: "Перечислите по одному имени пользователя в строке. Пользователи, перечисленные здесь, будут привязаны к закладке \"Изучение\"." | pinnedUsersDescription: "Перечислите по одному имени пользователя в строке. Пользователи, перечисленные здесь, будут привязаны к закладке \"Изучение\"." | ||||||
| pinnedPages: "Закрепленные страницы" | pinnedPages: "Закрепленные страницы" | ||||||
| pinnedPagesDescription: "Если хотите закрепить страницы на главной сайта, сюда можно добавить пути к ним, каждый в отдельной строке." | pinnedPagesDescription: "Если хотите закрепить страницы на главной сайта, сюда можно добавить пути к ним, каждый в отдельной строке." | ||||||
| pinnedClipId: "Идентификатор закреплённой памятки" | pinnedClipId: "Идентификатор закреплённой подборки" | ||||||
| pinnedNotes: "Закреплённая заметка" | pinnedNotes: "Закреплённая заметка" | ||||||
| hcaptcha: "hCaptcha" | hcaptcha: "hCaptcha" | ||||||
| enableHcaptcha: "Включить hCaptcha" | enableHcaptcha: "Включить hCaptcha" | ||||||
| @@ -349,7 +347,6 @@ antennaExcludeKeywords: "Исключения" | |||||||
| antennaKeywordsDescription: "Пишите слова через пробел в одной строке, чтобы ловить их появление вместе; на отдельных строках располагайте слова, или группы слов, чтобы ловить любые из них." | antennaKeywordsDescription: "Пишите слова через пробел в одной строке, чтобы ловить их появление вместе; на отдельных строках располагайте слова, или группы слов, чтобы ловить любые из них." | ||||||
| notifyAntenna: "Уведомлять о новых заметках" | notifyAntenna: "Уведомлять о новых заметках" | ||||||
| withFileAntenna: "Только заметки с вложениями" | withFileAntenna: "Только заметки с вложениями" | ||||||
| serviceworker: "ServiceWorker" |  | ||||||
| enableServiceworker: "Включить ServiceWorker" | enableServiceworker: "Включить ServiceWorker" | ||||||
| antennaUsersDescription: "Пишите каждое название аккаута на отдельной строке" | antennaUsersDescription: "Пишите каждое название аккаута на отдельной строке" | ||||||
| caseSensitive: "С учётом регистра" | caseSensitive: "С учётом регистра" | ||||||
| @@ -405,8 +402,8 @@ invites: "Приглашения" | |||||||
| groupName: "Название группы" | groupName: "Название группы" | ||||||
| members: "Участники" | members: "Участники" | ||||||
| transfer: "Отдать" | transfer: "Отдать" | ||||||
| messagingWithUser: "Сообщения пользователей" | messagingWithUser: "Общение с другим пользователем" | ||||||
| messagingWithGroup: "Чат в группе" | messagingWithGroup: "Общение в группе" | ||||||
| title: "Заголовок" | title: "Заголовок" | ||||||
| text: "Текст" | text: "Текст" | ||||||
| enable: "Включить" | enable: "Включить" | ||||||
| @@ -453,7 +450,7 @@ category: "Категория" | |||||||
| tags: "Метки" | tags: "Метки" | ||||||
| docSource: "Источник документа" | docSource: "Источник документа" | ||||||
| createAccount: "Новая учётная запись" | createAccount: "Новая учётная запись" | ||||||
| existingAcount: "Уже существующий" | existingAccount: "Существующая учётная запись" | ||||||
| regenerate: "Создать повторно" | regenerate: "Создать повторно" | ||||||
| fontSize: "Размер шрифта" | fontSize: "Размер шрифта" | ||||||
| noFollowRequests: "Нерассмотренные запросы на подписку отсутствуют" | noFollowRequests: "Нерассмотренные запросы на подписку отсутствуют" | ||||||
| @@ -471,7 +468,7 @@ promotion: "Продвинуто" | |||||||
| promote: "Продвинуть" | promote: "Продвинуть" | ||||||
| numberOfDays: "Количество дней" | numberOfDays: "Количество дней" | ||||||
| hideThisNote: "Спрятать эту запись" | hideThisNote: "Спрятать эту запись" | ||||||
| showFeaturedNotesInTimeline: "Показывать в ленте заметки из подборки сайта" | showFeaturedNotesInTimeline: "Показывать в ленте заметки из «Горячего»" | ||||||
| objectStorage: "Хранилище" | objectStorage: "Хранилище" | ||||||
| useObjectStorage: "Занято в хранилище" | useObjectStorage: "Занято в хранилище" | ||||||
| objectStorageBaseUrl: "Базовый адрес" | objectStorageBaseUrl: "Базовый адрес" | ||||||
| @@ -524,7 +521,7 @@ deleteAllFiles: "Удалить все файлы" | |||||||
| deleteAllFilesConfirm: "Вы хотите удалить все файлы?" | deleteAllFilesConfirm: "Вы хотите удалить все файлы?" | ||||||
| removeAllFollowing: "Удалить всех подписчиков" | removeAllFollowing: "Удалить всех подписчиков" | ||||||
| removeAllFollowingDescription: "Отменить все подписки с домена {host}? Пожалуйста, применяйте это действие, если инстанс больше не существует." | removeAllFollowingDescription: "Отменить все подписки с домена {host}? Пожалуйста, применяйте это действие, если инстанс больше не существует." | ||||||
| userSuspended: "Этот пользователь был заморожен" | userSuspended: "Эта учётная запись заморожена" | ||||||
| userSilenced: "Этот пользователь был заглушен" | userSilenced: "Этот пользователь был заглушен" | ||||||
| sidebar: "Боковая панель" | sidebar: "Боковая панель" | ||||||
| divider: "Линия-разделитель" | divider: "Линия-разделитель" | ||||||
| @@ -568,7 +565,7 @@ pluginTokenRequestedDescription: "Это расширение сможет по | |||||||
| notificationType: "Тип уведомления" | notificationType: "Тип уведомления" | ||||||
| edit: "Изменить" | edit: "Изменить" | ||||||
| useStarForReactionFallback: "Ставить ★ в качестве реакции вместо неизвестного эмодзи" | useStarForReactionFallback: "Ставить ★ в качестве реакции вместо неизвестного эмодзи" | ||||||
| emailConfig: "Настройки почтового сервера" | emailServer: "Сервер электронной почты" | ||||||
| enableEmail: "Включить обмен электронной почтой" | enableEmail: "Включить обмен электронной почтой" | ||||||
| emailConfigInfo: "Используется для подтверждения адреса электронной почты и сброса пароля." | emailConfigInfo: "Используется для подтверждения адреса электронной почты и сброса пароля." | ||||||
| email: "Электронная почта" | email: "Электронная почта" | ||||||
| @@ -623,30 +620,30 @@ random: "Случайные" | |||||||
| system: "Система" | system: "Система" | ||||||
| switchUi: "Выбор вида" | switchUi: "Выбор вида" | ||||||
| desktop: "Стол" | desktop: "Стол" | ||||||
| clip: "В памятку" | clip: "Подборка" | ||||||
| createNew: "Новый документ" | createNew: "Новый документ" | ||||||
| optional: "Необязательно" | optional: "Необязательно" | ||||||
| createNewClip: "Новая памятка" | createNewClip: "Новая подборка" | ||||||
| public: "Общедоступно" | public: "Общедоступно" | ||||||
| i18nInfo: "Misskey переводят на разные языки добровольцы со всего света. Ваша помощь тоже пригодится здесь: {link}." | i18nInfo: "Misskey переводят на разные языки добровольцы со всего света. Ваша помощь тоже пригодится здесь: {link}." | ||||||
| manageAccessTokens: "Управление токенами доступа" | manageAccessTokens: "Управление токенами доступа" | ||||||
| accountInfo: "Сведения об учётной записи" | accountInfo: "Сведения об учётной записи" | ||||||
| notesCount: "Количество заметок" | notesCount: "Количество заметок" | ||||||
| repliesCount: "Сколько раз пользователь кому-то ответил" | repliesCount: "Сколько раз пользователь кому-то ответил" | ||||||
| renotesCount: "Сколько раз пользователь передал чужие заметки" | renotesCount: "Сколько раз пользователь делился заметками" | ||||||
| repliedCount: "Сколько раз ответили пользователю" | repliedCount: "Сколько раз ответили пользователю" | ||||||
| renotedCount: "Сколько раз передавали заметки пользователя" | renotedCount: "Сколько раз делились заметками пользователя" | ||||||
| followingCount: "Количество подписок" | followingCount: "Количество подписок" | ||||||
| followersCount: "Количество подписавшихся" | followersCount: "Количество подписавшихся" | ||||||
| sentReactionsCount: "Сколько раз пользователь отреагировал" | sentReactionsCount: "Количество реакций пользователя" | ||||||
| receivedReactionsCount: "Сколько раз отреагировали на заметки пользователя" | receivedReactionsCount: "Количество реакций на заметки пользователя" | ||||||
| pollVotesCount: "Сколько раз участвовал в опросах" | pollVotesCount: "Сколько раз пользователь участвовал в опросах" | ||||||
| pollVotedCount: "Сколько раз участвовали в опросах пользователя" | pollVotedCount: "Сколько раз участвовали в опросах пользователя" | ||||||
| yes: "Да" | yes: "Да" | ||||||
| no: "Нет" | no: "Нет" | ||||||
| driveFilesCount: "Количество файлов на диске" | driveFilesCount: "Количество файлов на диске" | ||||||
| driveUsage: "Сколько места занято на диске" | driveUsage: "Занято места на диске" | ||||||
| noCrawle: "Паукам вход воспрещён" | noCrawle: "Запретить паукам индексировать сайт" | ||||||
| noCrawleDescription: "Просьба поисковым системам не ходить по вашему профилю, по заметкам, страницам и не индексировать их." | noCrawleDescription: "Просьба поисковым системам не ходить по вашему профилю, по заметкам, страницам и не индексировать их." | ||||||
| lockedAccountInfo: "Даже если вы вручную подтверждаете подписки, кто угодно может читать ваши заметки, если вы не отмечаете их «для подписчиков»." | lockedAccountInfo: "Даже если вы вручную подтверждаете подписки, кто угодно может читать ваши заметки, если вы не отмечаете их «для подписчиков»." | ||||||
| alwaysMarkSensitive: "Отмечать файлы как «содержимое не для всех» по умолчанию" | alwaysMarkSensitive: "Отмечать файлы как «содержимое не для всех» по умолчанию" | ||||||
| @@ -661,7 +658,7 @@ pageLikedCount: "Количество страниц, понравившихся | |||||||
| reversiCount: "Количество сыгранных игр в реверси" | reversiCount: "Количество сыгранных игр в реверси" | ||||||
| contact: "Как связаться" | contact: "Как связаться" | ||||||
| useSystemFont: "Использовать шрифт, предлагаемый системой" | useSystemFont: "Использовать шрифт, предлагаемый системой" | ||||||
| clips: "Памятки" | clips: "Подборки" | ||||||
| experimentalFeatures: "Экспериментальные функции" | experimentalFeatures: "Экспериментальные функции" | ||||||
| developer: "Разработчик" | developer: "Разработчик" | ||||||
| makeExplorable: "Опубликовать профиль в «Обзоре»." | makeExplorable: "Опубликовать профиль в «Обзоре»." | ||||||
| @@ -687,6 +684,7 @@ textColor: "Текст" | |||||||
| saveAs: "Сохранить под названием…" | saveAs: "Сохранить под названием…" | ||||||
| advanced: "Для продвинутых" | advanced: "Для продвинутых" | ||||||
| value: "Значения" | value: "Значения" | ||||||
|  | createdAt: "Создано" | ||||||
| updatedAt: "Обновлено" | updatedAt: "Обновлено" | ||||||
| saveConfirm: "Сохранить изменения?" | saveConfirm: "Сохранить изменения?" | ||||||
| deleteConfirm: "Удалить?" | deleteConfirm: "Удалить?" | ||||||
| @@ -704,12 +702,58 @@ editCode: "Редактировать исходный текст" | |||||||
| apply: "Применить" | apply: "Применить" | ||||||
| receiveAnnouncementFromInstance: "Получать оповещения с инстанса" | receiveAnnouncementFromInstance: "Получать оповещения с инстанса" | ||||||
| emailNotification: "Уведомления по электронной почте" | emailNotification: "Уведомления по электронной почте" | ||||||
|  | publish: "Опубликовать" | ||||||
| inChannelSearch: "Поиск по каналу" | inChannelSearch: "Поиск по каналу" | ||||||
| useReactionPickerForContextMenu: "Открывать палитру реакций правой кнопкой" | useReactionPickerForContextMenu: "Открывать палитру реакций правой кнопкой" | ||||||
| typingUsers: "Стук клавиш. Это {users}…" | typingUsers: "Стук клавиш. Это {users}…" | ||||||
| jumpToSpecifiedDate: "Перейти к заданной дате" | jumpToSpecifiedDate: "Перейти к заданной дате" | ||||||
| showingPastTimeline: "Отображается старая лента" | showingPastTimeline: "Отображается старая лента" | ||||||
| clear: "Очистить" | clear: "Очистить" | ||||||
|  | markAllAsRead: "Отметить всё как прочитанное" | ||||||
|  | goBack: "Выход" | ||||||
|  | unlikeConfirm: "В самом деле отменить «нравится»?" | ||||||
|  | fullView: "Полный вид" | ||||||
|  | quitFullView: "Закрыть полный вид" | ||||||
|  | addDescription: "Добавить описание" | ||||||
|  | userPagePinTip: "Можно добавить сюда заметки, выбрав нужную, и включив в её меню пункт «Закрепить в профиле»." | ||||||
|  | notSpecifiedMentionWarning: "В этой заметке есть упоминание тех, кто не включён в адресаты" | ||||||
|  | info: "Описание" | ||||||
|  | userInfo: "Сведения о пользователе" | ||||||
|  | unknown: "Неизвестно" | ||||||
|  | onlineStatus: "Присутствие в сети" | ||||||
|  | hideOnlineStatus: "Скрыть присутствие" | ||||||
|  | hideOnlineStatusDescription: "Сокрытие присутствия делает некоторые функции, такие как поиск, менее удобными." | ||||||
|  | online: "В сети" | ||||||
|  | active: "Действует" | ||||||
|  | offline: "Не в сети" | ||||||
|  | notRecommended: "Не рекомендуется" | ||||||
|  | botProtection: "Ботозащита" | ||||||
|  | instanceBlocking: "Блокировка инстансов" | ||||||
|  | selectAccount: "Выберите учётную запись" | ||||||
|  | enabled: "Вкл." | ||||||
|  | disabled: "Откл." | ||||||
|  | quickAction: "Быстрое действие" | ||||||
|  | user: "Пользователи" | ||||||
|  | administration: "Управление" | ||||||
|  | accounts: "Учётные записи" | ||||||
|  | switch: "Переключение" | ||||||
|  | noMaintainerInformationWarning: "Не заполнены сведения об администраторах" | ||||||
|  | noBotProtectionWarning: "Ботозащита не настроена" | ||||||
|  | configure: "Настроить" | ||||||
|  | postToGallery: "Опубликовать в галерею" | ||||||
|  | gallery: "Галерея" | ||||||
|  | recentPosts: "Недавние публикации" | ||||||
|  | popularPosts: "Популярные публикации" | ||||||
|  | shareWithNote: "Поделиться заметкой" | ||||||
|  | expiration: "Опрос длится" | ||||||
|  | middle: "Средне" | ||||||
|  | _ad: | ||||||
|  |   back: "Выход" | ||||||
|  | _gallery: | ||||||
|  |   my: "Личная" | ||||||
|  |   liked: "Понравившееся" | ||||||
|  |   like: "Нравится!" | ||||||
|  |   unlike: "Отменить «нравится»" | ||||||
| _email: | _email: | ||||||
|   _follow: |   _follow: | ||||||
|     title: "Новый подписчик" |     title: "Новый подписчик" | ||||||
| @@ -865,6 +909,7 @@ _theme: | |||||||
|   install: "Установить тему" |   install: "Установить тему" | ||||||
|   manage: "Менеджер тем" |   manage: "Менеджер тем" | ||||||
|   code: "Код темы" |   code: "Код темы" | ||||||
|  |   description: "Описание" | ||||||
|   installed: "Тема «{name}» установлена." |   installed: "Тема «{name}» установлена." | ||||||
|   installedThemes: "Установленные темы" |   installedThemes: "Установленные темы" | ||||||
|   builtinThemes: "Встроенные темы" |   builtinThemes: "Встроенные темы" | ||||||
| @@ -983,7 +1028,7 @@ _tutorial: | |||||||
|   step7_2: "Хотите изучить Misskey глубже — добро пожаловать в раздел «{help}»." |   step7_2: "Хотите изучить Misskey глубже — добро пожаловать в раздел «{help}»." | ||||||
|   step7_3: "Приятно вам провести время с Misskey🚀" |   step7_3: "Приятно вам провести время с Misskey🚀" | ||||||
| _2fa: | _2fa: | ||||||
|   alreadyRegistered: "Настройка завершена" |   alreadyRegistered: "Двухфакторная аутентификация уже настроена." | ||||||
|   registerDevice: "Зарегистрируйте ваше устройство" |   registerDevice: "Зарегистрируйте ваше устройство" | ||||||
|   registerKey: "Зарегистрировать ключ" |   registerKey: "Зарегистрировать ключ" | ||||||
|   step1: "Прежде всего, установите на устройство приложение для аутентификации, например, {a} или {b}." |   step1: "Прежде всего, установите на устройство приложение для аутентификации, например, {a} или {b}." | ||||||
| @@ -1240,7 +1285,7 @@ _pages: | |||||||
|   liked: "Понравившиеся страницы" |   liked: "Понравившиеся страницы" | ||||||
|   featured: "Популярные" |   featured: "Популярные" | ||||||
|   inspector: "Инспектор" |   inspector: "Инспектор" | ||||||
|   contents: "Содержательные" |   contents: "Содержимое" | ||||||
|   content: "Содержимое" |   content: "Содержимое" | ||||||
|   variables: "Переменные" |   variables: "Переменные" | ||||||
|   title: "Заголовок" |   title: "Заголовок" | ||||||
|   | |||||||
| @@ -138,7 +138,6 @@ flagAsBotDescription: "Ввімкніть якщо цей обліковий з | |||||||
| flagAsCat: "Акаунт кота" | flagAsCat: "Акаунт кота" | ||||||
| flagAsCatDescription: "Ввімкніть, щоб позначити, що обліковий запис є котиком." | flagAsCatDescription: "Ввімкніть, щоб позначити, що обліковий запис є котиком." | ||||||
| autoAcceptFollowed: "Автоматично приймати запити на підписку від користувачів, на яких ви підписані" | autoAcceptFollowed: "Автоматично приймати запити на підписку від користувачів, на яких ви підписані" | ||||||
| addAcount: "Додати акаунт" |  | ||||||
| loginFailed: "Не вдалося увійти" | loginFailed: "Не вдалося увійти" | ||||||
| showOnRemote: "Переглянути в оригіналі" | showOnRemote: "Переглянути в оригіналі" | ||||||
| general: "Загальне" | general: "Загальне" | ||||||
| @@ -308,8 +307,6 @@ monthX: "{month}" | |||||||
| yearX: "{year}" | yearX: "{year}" | ||||||
| pages: "Сторінки" | pages: "Сторінки" | ||||||
| integration: "Інтеграція" | integration: "Інтеграція" | ||||||
| connectSerice: "Під’єднати" |  | ||||||
| disconnectSerice: "Відключитися" |  | ||||||
| enableLocalTimeline: "Увімкнути локальну стрічку" | enableLocalTimeline: "Увімкнути локальну стрічку" | ||||||
| enableGlobalTimeline: "Увімкнути глобальну стрічку" | enableGlobalTimeline: "Увімкнути глобальну стрічку" | ||||||
| disablingTimelinesInfo: "Адміністратори та модератори завжди мають доступ до всіх стрічок, навіть якщо вони вимкнуті." | disablingTimelinesInfo: "Адміністратори та модератори завжди мають доступ до всіх стрічок, навіть якщо вони вимкнуті." | ||||||
| @@ -347,7 +344,6 @@ antennaExcludeKeywords: "Винятки" | |||||||
| antennaKeywordsDescription: "Розділення ключових слів пробілами для \"І\" або з нової лінійки для \"АБО\"" | antennaKeywordsDescription: "Розділення ключових слів пробілами для \"І\" або з нової лінійки для \"АБО\"" | ||||||
| notifyAntenna: "Сповіщати про нові нотатки" | notifyAntenna: "Сповіщати про нові нотатки" | ||||||
| withFileAntenna: "Тільки нотатки з вкладеними файлами" | withFileAntenna: "Тільки нотатки з вкладеними файлами" | ||||||
| serviceworker: "ServiceWorker" |  | ||||||
| enableServiceworker: "Ввімкнути ServiceWorker" | enableServiceworker: "Ввімкнути ServiceWorker" | ||||||
| antennaUsersDescription: "Список імя користувачів в стопчик" | antennaUsersDescription: "Список імя користувачів в стопчик" | ||||||
| caseSensitive: "З урахуванням регістру" | caseSensitive: "З урахуванням регістру" | ||||||
| @@ -450,7 +446,6 @@ category: "Категорія" | |||||||
| tags: "Теги" | tags: "Теги" | ||||||
| docSource: "Джерело цього документа" | docSource: "Джерело цього документа" | ||||||
| createAccount: "Створити акаунт" | createAccount: "Створити акаунт" | ||||||
| existingAcount: "Існуючий акаунт" |  | ||||||
| regenerate: "Оновити" | regenerate: "Оновити" | ||||||
| fontSize: "Розмір шрифту" | fontSize: "Розмір шрифту" | ||||||
| noFollowRequests: "Немає запитів на підписку" | noFollowRequests: "Немає запитів на підписку" | ||||||
| @@ -564,7 +559,6 @@ pluginTokenRequestedDescription: "Цей плагін зможе викорис | |||||||
| notificationType: "Тип сповіщення" | notificationType: "Тип сповіщення" | ||||||
| edit: "Редагувати" | edit: "Редагувати" | ||||||
| useStarForReactionFallback: "Використовувати ★ як запасний варіант, якщо емодзі реакції невідомий" | useStarForReactionFallback: "Використовувати ★ як запасний варіант, якщо емодзі реакції невідомий" | ||||||
| emailConfig: "Налаштування email сервера" |  | ||||||
| enableEmail: "Увімкнути функцію доставки пошти" | enableEmail: "Увімкнути функцію доставки пошти" | ||||||
| emailConfigInfo: "Використовується для підтвердження електронної пошти підчас реєстрації, а також для відновлення паролю." | emailConfigInfo: "Використовується для підтвердження електронної пошти підчас реєстрації, а також для відновлення паролю." | ||||||
| email: "E-mail" | email: "E-mail" | ||||||
| @@ -689,6 +683,16 @@ deleteConfirm: "Ви дійсно бажаєте це видалити?" | |||||||
| invalidValue: "Некоректне значення." | invalidValue: "Некоректне значення." | ||||||
| registry: "Реєстр" | registry: "Реєстр" | ||||||
| closeAccount: "Закрити обліковий запис" | closeAccount: "Закрити обліковий запис" | ||||||
|  | goBack: "Назад" | ||||||
|  | info: "Інформація" | ||||||
|  | user: "Користувачі" | ||||||
|  | administration: "Управління" | ||||||
|  | expiration: "Опитування закінчується" | ||||||
|  | middle: "Середній" | ||||||
|  | _ad: | ||||||
|  |   back: "Назад" | ||||||
|  | _gallery: | ||||||
|  |   unlike: "Не вподобати" | ||||||
| _email: | _email: | ||||||
|   _follow: |   _follow: | ||||||
|     title: "Новий підписник" |     title: "Новий підписник" | ||||||
| @@ -830,6 +834,7 @@ _theme: | |||||||
|   install: "Встановити тему" |   install: "Встановити тему" | ||||||
|   manage: "Керування темами" |   manage: "Керування темами" | ||||||
|   code: "Код теми" |   code: "Код теми" | ||||||
|  |   description: "Опис" | ||||||
|   installed: "Тему {name} встановлено" |   installed: "Тему {name} встановлено" | ||||||
|   installedThemes: "Встановлені теми" |   installedThemes: "Встановлені теми" | ||||||
|   builtinThemes: "Вбудоваі теми" |   builtinThemes: "Вбудоваі теми" | ||||||
|   | |||||||
| @@ -7,6 +7,7 @@ search: "搜索" | |||||||
| notifications: "通知" | notifications: "通知" | ||||||
| username: "用户名" | username: "用户名" | ||||||
| password: "密码" | password: "密码" | ||||||
|  | forgotPassword: "忘记密码" | ||||||
| fetchingAsApObject: "联合查询中" | fetchingAsApObject: "联合查询中" | ||||||
| ok: "OK" | ok: "OK" | ||||||
| gotIt: "我明白了" | gotIt: "我明白了" | ||||||
| @@ -138,7 +139,7 @@ flagAsBotDescription: "如果此帐户由程序控制,请启用此项。启用 | |||||||
| flagAsCat: "这个账户是Cat" | flagAsCat: "这个账户是Cat" | ||||||
| flagAsCatDescription: "如果您想表明此帐户是一只猫,请打开此标志。" | flagAsCatDescription: "如果您想表明此帐户是一只猫,请打开此标志。" | ||||||
| autoAcceptFollowed: "自动允许关注" | autoAcceptFollowed: "自动允许关注" | ||||||
| addAcount: "添加账户" | addAccount: "添加账户" | ||||||
| loginFailed: "登录失败" | loginFailed: "登录失败" | ||||||
| showOnRemote: "转到所在实例显示" | showOnRemote: "转到所在实例显示" | ||||||
| general: "常规设置" | general: "常规设置" | ||||||
| @@ -173,7 +174,7 @@ metadata: "元数据" | |||||||
| withNFiles: "{n}个文件" | withNFiles: "{n}个文件" | ||||||
| monitor: "监视器" | monitor: "监视器" | ||||||
| jobQueue: "作业队列" | jobQueue: "作业队列" | ||||||
| cpuAndMemory: "CPU使用量" | cpuAndMemory: "CPU和内存" | ||||||
| network: "网络" | network: "网络" | ||||||
| disk: "存储" | disk: "存储" | ||||||
| instanceInfo: "实例信息" | instanceInfo: "实例信息" | ||||||
| @@ -278,6 +279,7 @@ emptyDrive: "驱动器为空" | |||||||
| emptyFolder: "空文件夹" | emptyFolder: "空文件夹" | ||||||
| unableToDelete: "无法删除" | unableToDelete: "无法删除" | ||||||
| inputNewFileName: "请输入新文件名" | inputNewFileName: "请输入新文件名" | ||||||
|  | inputNewDescription: "请输入新标题" | ||||||
| inputNewFolderName: "请输入新文件名" | inputNewFolderName: "请输入新文件名" | ||||||
| circularReferenceFolder: "目标文件夹是您要移动的文件夹的子文件夹。" | circularReferenceFolder: "目标文件夹是您要移动的文件夹的子文件夹。" | ||||||
| hasChildFilesOrFolders: "此文件夹不为空,无法删除。" | hasChildFilesOrFolders: "此文件夹不为空,无法删除。" | ||||||
| @@ -309,8 +311,8 @@ monthX: "{month}月" | |||||||
| yearX: "{year}年" | yearX: "{year}年" | ||||||
| pages: "页面" | pages: "页面" | ||||||
| integration: "关联" | integration: "关联" | ||||||
| connectSerice: "连接" | connectService: "连接" | ||||||
| disconnectSerice: "断开连接" | disconnectService: "断开连接" | ||||||
| enableLocalTimeline: "启用本地时间线功能" | enableLocalTimeline: "启用本地时间线功能" | ||||||
| enableGlobalTimeline: "启用全局时间线" | enableGlobalTimeline: "启用全局时间线" | ||||||
| disablingTimelinesInfo: "即使时间线功能被禁用,出于便利性的原因,管理员和数据图表也可以继续使用。" | disablingTimelinesInfo: "即使时间线功能被禁用,出于便利性的原因,管理员和数据图表也可以继续使用。" | ||||||
| @@ -349,7 +351,6 @@ antennaExcludeKeywords: "排除关键字" | |||||||
| antennaKeywordsDescription: "使用空格分隔会产生AND规范,并且使用换行符分隔会产生OR规范" | antennaKeywordsDescription: "使用空格分隔会产生AND规范,并且使用换行符分隔会产生OR规范" | ||||||
| notifyAntenna: "通知新帖子" | notifyAntenna: "通知新帖子" | ||||||
| withFileAntenna: "仅带有附件的帖子" | withFileAntenna: "仅带有附件的帖子" | ||||||
| serviceworker: "ServiceWorker" |  | ||||||
| enableServiceworker: "启用ServiceWorker" | enableServiceworker: "启用ServiceWorker" | ||||||
| antennaUsersDescription: "指定用户名,用换行符分隔" | antennaUsersDescription: "指定用户名,用换行符分隔" | ||||||
| caseSensitive: "区分大小写" | caseSensitive: "区分大小写" | ||||||
| @@ -453,7 +454,7 @@ category: "类别" | |||||||
| tags: "标签" | tags: "标签" | ||||||
| docSource: "文件来源" | docSource: "文件来源" | ||||||
| createAccount: "注册账户" | createAccount: "注册账户" | ||||||
| existingAcount: "现有的帐户" | existingAccount: "现有的帐户" | ||||||
| regenerate: "重新生成" | regenerate: "重新生成" | ||||||
| fontSize: "字体大小" | fontSize: "字体大小" | ||||||
| noFollowRequests: "没有关注申请" | noFollowRequests: "没有关注申请" | ||||||
| @@ -546,6 +547,8 @@ disablePlayer: "关闭播放器" | |||||||
| expandTweet: "展开贴文" | expandTweet: "展开贴文" | ||||||
| themeEditor: "主题编辑器" | themeEditor: "主题编辑器" | ||||||
| description: "描述" | description: "描述" | ||||||
|  | describeFile: "添加标题" | ||||||
|  | enterFileDescription: "输入标题" | ||||||
| author: "作者" | author: "作者" | ||||||
| leaveConfirm: "存在未保存的更改。要放弃更改吗?" | leaveConfirm: "存在未保存的更改。要放弃更改吗?" | ||||||
| manage: "管理" | manage: "管理" | ||||||
| @@ -568,7 +571,7 @@ pluginTokenRequestedDescription: "此插件将能够拥有此处设置的权限" | |||||||
| notificationType: "通知类型" | notificationType: "通知类型" | ||||||
| edit: "编辑" | edit: "编辑" | ||||||
| useStarForReactionFallback: "如果回应的是未知表情符号,则使用★作为代替" | useStarForReactionFallback: "如果回应的是未知表情符号,则使用★作为代替" | ||||||
| emailConfig: "邮件服务器设置" | emailServer: "邮件服务器" | ||||||
| enableEmail: "启用发送邮件功能" | enableEmail: "启用发送邮件功能" | ||||||
| emailConfigInfo: "用于确认电子邮件和密码重置" | emailConfigInfo: "用于确认电子邮件和密码重置" | ||||||
| email: "邮箱" | email: "邮箱" | ||||||
| @@ -579,12 +582,12 @@ smtpPort: "端口" | |||||||
| smtpUser: "用户名" | smtpUser: "用户名" | ||||||
| smtpPass: "密码" | smtpPass: "密码" | ||||||
| emptyToDisableSmtpAuth: "用户名和密码留空可以禁用SMTP验证" | emptyToDisableSmtpAuth: "用户名和密码留空可以禁用SMTP验证" | ||||||
| smtpSecure: "在 SMTP 连接中默认使用 SSL / TLS" | smtpSecure: "在 SMTP 连接中使用隐式 SSL / TLS" | ||||||
| smtpSecureInfo: "使用STARTTLS时关闭。" | smtpSecureInfo: "使用STARTTLS时关闭。" | ||||||
| testEmail: "邮件发送测试" | testEmail: "邮件发送测试" | ||||||
| wordMute: "文字屏蔽" | wordMute: "文字屏蔽" | ||||||
| userSaysSomething: "{name}说了什么" | userSaysSomething: "{name}说了什么" | ||||||
| makeActive: "激活" | makeActive: "启用" | ||||||
| display: "显示" | display: "显示" | ||||||
| copy: "复制" | copy: "复制" | ||||||
| metrics: "指标" | metrics: "指标" | ||||||
| @@ -687,6 +690,7 @@ textColor: "文本" | |||||||
| saveAs: "另存为" | saveAs: "另存为" | ||||||
| advanced: "高级" | advanced: "高级" | ||||||
| value: "值" | value: "值" | ||||||
|  | createdAt: "创建日期" | ||||||
| updatedAt: "更新时间" | updatedAt: "更新时间" | ||||||
| saveConfirm: "确定保存?" | saveConfirm: "确定保存?" | ||||||
| deleteConfirm: "确定删除?" | deleteConfirm: "确定删除?" | ||||||
| @@ -704,12 +708,70 @@ editCode: "编辑代码" | |||||||
| apply: "应用" | apply: "应用" | ||||||
| receiveAnnouncementFromInstance: "从实例接收通知" | receiveAnnouncementFromInstance: "从实例接收通知" | ||||||
| emailNotification: "邮件通知" | emailNotification: "邮件通知" | ||||||
|  | publish: "发布" | ||||||
| inChannelSearch: "频道内搜索" | inChannelSearch: "频道内搜索" | ||||||
| useReactionPickerForContextMenu: "单击右键打开回应工具栏" | useReactionPickerForContextMenu: "单击右键打开回应工具栏" | ||||||
| typingUsers: "{users}正在输入" | typingUsers: "{users}正在输入" | ||||||
| jumpToSpecifiedDate: "跳转到特定日期" | jumpToSpecifiedDate: "跳转到特定日期" | ||||||
| showingPastTimeline: "显示过去的时间线" | showingPastTimeline: "显示过去的时间线" | ||||||
| clear: "清除" | clear: "清除" | ||||||
|  | markAllAsRead: "全部标记为已读" | ||||||
|  | goBack: "返回" | ||||||
|  | unlikeConfirm: "取消赞?" | ||||||
|  | fullView: "全屏" | ||||||
|  | quitFullView: "退出全屏" | ||||||
|  | addDescription: "添加描述" | ||||||
|  | userPagePinTip: "在帖子的菜单中选择“置顶”,即可显示该条帖子。" | ||||||
|  | notSpecifiedMentionWarning: "有未指定的提及" | ||||||
|  | info: "关于" | ||||||
|  | userInfo: "用户信息" | ||||||
|  | unknown: "未知" | ||||||
|  | onlineStatus: "在线状态" | ||||||
|  | hideOnlineStatus: "隐藏在线状态" | ||||||
|  | hideOnlineStatusDescription: "隐藏在线状态后,可能会降低例如搜索等功能的便利性。" | ||||||
|  | online: "在线" | ||||||
|  | active: "活动" | ||||||
|  | offline: "离线" | ||||||
|  | notRecommended: "不推荐" | ||||||
|  | botProtection: "Bot防御" | ||||||
|  | instanceBlocking: "被阻拦的实例" | ||||||
|  | selectAccount: "选择账户" | ||||||
|  | enabled: "已启用" | ||||||
|  | disabled: "已禁用 " | ||||||
|  | quickAction: "快捷操作" | ||||||
|  | user: "用户" | ||||||
|  | administration: "管理" | ||||||
|  | accounts: "账户" | ||||||
|  | switch: "切换" | ||||||
|  | noMaintainerInformationWarning: "管理人员信息未设置。" | ||||||
|  | noBotProtectionWarning: "Bot保护未设置。" | ||||||
|  | configure: "设置" | ||||||
|  | postToGallery: "发送到图库" | ||||||
|  | gallery: "图库" | ||||||
|  | recentPosts: "最新发布" | ||||||
|  | popularPosts: "热门投稿" | ||||||
|  | shareWithNote: "在帖子中分享" | ||||||
|  | ads: "广告" | ||||||
|  | expiration: "截止时间" | ||||||
|  | memo: "便笺" | ||||||
|  | priority: "优先级" | ||||||
|  | high: "高" | ||||||
|  | middle: "中" | ||||||
|  | low: "低" | ||||||
|  | emailNotConfiguredWarning: "电子邮件地址未设置。" | ||||||
|  | ratio: "比率" | ||||||
|  | _ad: | ||||||
|  |   back: "返回" | ||||||
|  |   reduceFrequencyOfThisAd: "减少此广告的频率" | ||||||
|  | _forgotPassword: | ||||||
|  |   enterEmail: "请输入您用来注册帐户的电子邮件地址。密码重置链接将发送到该地址。" | ||||||
|  |   ifNoEmail: "如果您没有使用电子邮件地址注册,请联系管理员。" | ||||||
|  |   contactAdmin: "该实例不支持电子邮件。如果您想重设密码,请联系管理员。" | ||||||
|  | _gallery: | ||||||
|  |   my: "我的图库" | ||||||
|  |   liked: "喜欢的图片" | ||||||
|  |   like: "喜欢" | ||||||
|  |   unlike: "取消喜欢" | ||||||
| _email: | _email: | ||||||
|   _follow: |   _follow: | ||||||
|     title: "你有新的关注者" |     title: "你有新的关注者" | ||||||
| @@ -865,6 +927,7 @@ _theme: | |||||||
|   install: "安装主题" |   install: "安装主题" | ||||||
|   manage: "主题管理" |   manage: "主题管理" | ||||||
|   code: "主题代码" |   code: "主题代码" | ||||||
|  |   description: "描述" | ||||||
|   installed: "{name} 已安装" |   installed: "{name} 已安装" | ||||||
|   installedThemes: "已安装的主题" |   installedThemes: "已安装的主题" | ||||||
|   builtinThemes: "标准主题" |   builtinThemes: "标准主题" | ||||||
| @@ -1235,7 +1298,7 @@ _pages: | |||||||
|   viewSource: "查看源代码" |   viewSource: "查看源代码" | ||||||
|   viewPage: "查看页面" |   viewPage: "查看页面" | ||||||
|   like: "赞" |   like: "赞" | ||||||
|   unlike: "取消赞" |   unlike: "取消喜欢" | ||||||
|   my: "我的页面" |   my: "我的页面" | ||||||
|   liked: "喜欢的页面" |   liked: "喜欢的页面" | ||||||
|   featured: "热门" |   featured: "热门" | ||||||
|   | |||||||
| @@ -1,18 +1,19 @@ | |||||||
| --- | --- | ||||||
| _lang_: "繁體中文" | _lang_: "繁體中文" | ||||||
| headlineMisskey: "貼文連繫網絡" | headlineMisskey: "貼文連繫網路" | ||||||
| introMisskey: "歡迎! Misskey是一個開源且去中心化的社群網絡。\n通過「貼文」分享周邊新鮮事,並告訴其他人您的想法!📡\n透過「情感」功能,對大家的貼文表達情感!👍\n一起來探索這個新的世界吧!🚀" | introMisskey: "歡迎! Misskey是一個開放原始碼且去中心化的社群網路。\n透過「貼文」分享周邊新鮮事,並告訴其他人您的想法!📡\n透過「情感」功能,對大家的貼文表達情感!👍\n一起來探索這個新的世界吧!🚀" | ||||||
| monthAndDay: "{month}月 {day}日" | monthAndDay: "{month}月 {day}日" | ||||||
| search: "搜尋" | search: "搜尋" | ||||||
| notifications: "通知" | notifications: "通知" | ||||||
| username: "使用者名稱" | username: "使用者名稱" | ||||||
| password: "密碼" | password: "密碼" | ||||||
|  | forgotPassword: "忘記密碼" | ||||||
| fetchingAsApObject: "從聯邦宇宙取得中..." | fetchingAsApObject: "從聯邦宇宙取得中..." | ||||||
| ok: "OK" | ok: "OK" | ||||||
| gotIt: "知道了" | gotIt: "知道了" | ||||||
| cancel: "取消" | cancel: "取消" | ||||||
| enterUsername: "輸入使用者名稱" | enterUsername: "輸入使用者名稱" | ||||||
| renotedBy: "{user} 轉發了" | renotedBy: "{user} 轉傳了" | ||||||
| noNotes: "貼文不可用。" | noNotes: "貼文不可用。" | ||||||
| noNotifications: "沒有通知" | noNotifications: "沒有通知" | ||||||
| instance: "實例" | instance: "實例" | ||||||
| @@ -44,7 +45,7 @@ copyLink: "複製連結" | |||||||
| delete: "刪除" | delete: "刪除" | ||||||
| deleteAndEdit: "刪除並編輯" | deleteAndEdit: "刪除並編輯" | ||||||
| deleteAndEditConfirm: "要刪除並再次編輯嗎?此貼文的所有情感、轉發和回覆也將會消失。" | deleteAndEditConfirm: "要刪除並再次編輯嗎?此貼文的所有情感、轉發和回覆也將會消失。" | ||||||
| addToList: "新增至清單" | addToList: "加入至清單" | ||||||
| sendMessage: "發送訊息" | sendMessage: "發送訊息" | ||||||
| copyUsername: "複製用戶名" | copyUsername: "複製用戶名" | ||||||
| searchUser: "搜尋用戶" | searchUser: "搜尋用戶" | ||||||
| @@ -56,7 +57,7 @@ receiveFollowRequest: "您有新的追隨請求" | |||||||
| followRequestAccepted: "追隨請求已接受" | followRequestAccepted: "追隨請求已接受" | ||||||
| mention: "提及" | mention: "提及" | ||||||
| mentions: "提及" | mentions: "提及" | ||||||
| directNotes: "指定使用者發佈" | directNotes: "私訊" | ||||||
| importAndExport: "匯入與匯出" | importAndExport: "匯入與匯出" | ||||||
| import: "匯入" | import: "匯入" | ||||||
| export: "匯出" | export: "匯出" | ||||||
| @@ -92,9 +93,9 @@ followRequestPending: "追隨許可批准中" | |||||||
| enterEmoji: "輸入表情符號" | enterEmoji: "輸入表情符號" | ||||||
| renote: "轉發" | renote: "轉發" | ||||||
| unrenote: "取消轉發" | unrenote: "取消轉發" | ||||||
| renoted: "轉發成功" | renoted: "轉傳成功" | ||||||
| cantRenote: "無法轉發此貼文。" | cantRenote: "無法轉發此貼文。" | ||||||
| cantReRenote: "無法轉發之前已經轉發過的內容" | cantReRenote: "無法轉傳之前已經轉傳過的內容。" | ||||||
| quote: "引用" | quote: "引用" | ||||||
| pinnedNote: "已置頂的貼文" | pinnedNote: "已置頂的貼文" | ||||||
| pinned: "置頂" | pinned: "置頂" | ||||||
| @@ -129,7 +130,7 @@ customEmojis: "自訂表情符號" | |||||||
| emoji: "表情符號" | emoji: "表情符號" | ||||||
| emojiName: "表情符號名稱" | emojiName: "表情符號名稱" | ||||||
| emojiUrl: "表情符號URL" | emojiUrl: "表情符號URL" | ||||||
| addEmoji: "新增表情符號" | addEmoji: "加入表情符號" | ||||||
| settingGuide: "推薦設定" | settingGuide: "推薦設定" | ||||||
| cacheRemoteFiles: "緩存非遠程檔案" | cacheRemoteFiles: "緩存非遠程檔案" | ||||||
| cacheRemoteFilesDescription: "禁用此設定會停止遠端檔案的緩存,從而節省儲存空間,但資料會因直接連線從而產生額外連接數據。" | cacheRemoteFilesDescription: "禁用此設定會停止遠端檔案的緩存,從而節省儲存空間,但資料會因直接連線從而產生額外連接數據。" | ||||||
| @@ -138,7 +139,7 @@ flagAsBotDescription: "如果本帳戶是由程式控制,請啟用此選項。 | |||||||
| flagAsCat: "此使用者是貓" | flagAsCat: "此使用者是貓" | ||||||
| flagAsCatDescription: "如果想將本帳戶標示為一隻貓,請開啟此標示" | flagAsCatDescription: "如果想將本帳戶標示為一隻貓,請開啟此標示" | ||||||
| autoAcceptFollowed: "自動追隨中使用者的追隨請求" | autoAcceptFollowed: "自動追隨中使用者的追隨請求" | ||||||
| addAcount: "新增帳戶" | addAccount: "添加帳戶" | ||||||
| loginFailed: "登入失敗" | loginFailed: "登入失敗" | ||||||
| showOnRemote: "轉到所在實例顯示" | showOnRemote: "轉到所在實例顯示" | ||||||
| general: "一般" | general: "一般" | ||||||
| @@ -149,7 +150,7 @@ searchWith: "搜尋: {q}" | |||||||
| youHaveNoLists: "你沒有任何清單" | youHaveNoLists: "你沒有任何清單" | ||||||
| followConfirm: "你真的要追隨{name}嗎?" | followConfirm: "你真的要追隨{name}嗎?" | ||||||
| proxyAccount: "代理帳號" | proxyAccount: "代理帳號" | ||||||
| proxyAccountDescription: "代理帳號是在某些情況下充當其他服務器用戶的帳號。例如,當用戶將一個來自其他服務器的帳號放在列表中時,由於沒有其他用戶關注該帳號,該指令不會傳送到該服務器上,因此會由代理帳戶關注。" | proxyAccountDescription: "代理帳號是在某些情況下充當其他伺服器用戶的帳號。例如,當使用者將一個來自其他伺服器的帳號放在列表中時,由於沒有其他使用者關注該帳號,該指令不會傳送到該伺服器上,因此會由代理帳戶關注。" | ||||||
| host: "主機" | host: "主機" | ||||||
| selectUser: "選取使用者" | selectUser: "選取使用者" | ||||||
| recipient: "收件人" | recipient: "收件人" | ||||||
| @@ -180,9 +181,9 @@ instanceInfo: "實例資訊" | |||||||
| statistics: "統計" | statistics: "統計" | ||||||
| clearQueue: "清除佇列" | clearQueue: "清除佇列" | ||||||
| clearQueueConfirmTitle: "確定要清除佇列嗎?" | clearQueueConfirmTitle: "確定要清除佇列嗎?" | ||||||
| clearQueueConfirmText: "未發佈的帖子將不會發佈。您通常不需要確認。" | clearQueueConfirmText: "未發佈的貼文將不會發佈。您通常不需要確認。" | ||||||
| clearCachedFiles: "清除快取資料" | clearCachedFiles: "清除快取資料" | ||||||
| clearCachedFilesConfirm: "確定要清除緩存資料嗎?" | clearCachedFilesConfirm: "確定要清除所有遠端暫存資料嗎?" | ||||||
| blockedInstances: "已封鎖的實例" | blockedInstances: "已封鎖的實例" | ||||||
| blockedInstancesDescription: "請逐行輸入需要封鎖的實例。已封鎖的實例將無法與本實例進行通訊。" | blockedInstancesDescription: "請逐行輸入需要封鎖的實例。已封鎖的實例將無法與本實例進行通訊。" | ||||||
| muteAndBlock: "靜音和封鎖" | muteAndBlock: "靜音和封鎖" | ||||||
| @@ -192,12 +193,12 @@ noUsers: "沒有任何使用者" | |||||||
| editProfile: "編輯個人檔案" | editProfile: "編輯個人檔案" | ||||||
| noteDeleteConfirm: "確定刪除此貼文嗎?" | noteDeleteConfirm: "確定刪除此貼文嗎?" | ||||||
| pinLimitExceeded: "不能置頂更多貼文了" | pinLimitExceeded: "不能置頂更多貼文了" | ||||||
| intro: "Misskey 部署完成!請開設管理員帳號!" | intro: "Misskey 部署完成!請建立管理員帳號!" | ||||||
| done: "完成" | done: "完成" | ||||||
| processing: "處理中" | processing: "處理中" | ||||||
| preview: "預覽" | preview: "預覽" | ||||||
| default: "預設" | default: "預設" | ||||||
| noCustomEmojis: "沒有表情符號" | noCustomEmojis: "沒有自訂的表情符號" | ||||||
| noJobs: "沒有任務" | noJobs: "沒有任務" | ||||||
| federating: "整合搜索中" | federating: "整合搜索中" | ||||||
| blocked: "已封鎖" | blocked: "已封鎖" | ||||||
| @@ -215,10 +216,10 @@ retypedNotMatch: "兩次輸入不一致。" | |||||||
| currentPassword: "目前密碼" | currentPassword: "目前密碼" | ||||||
| newPassword: "新密碼" | newPassword: "新密碼" | ||||||
| newPasswordRetype: "確認密碼" | newPasswordRetype: "確認密碼" | ||||||
| attachFile: "添加附件" | attachFile: "上傳附件" | ||||||
| more: "更多!" | more: "更多!" | ||||||
| featured: "精選" | featured: "精選" | ||||||
| usernameOrUserId: "使用者名稱或用戶ID" | usernameOrUserId: "使用者名稱或使用者ID" | ||||||
| noSuchUser: "使用者不存在" | noSuchUser: "使用者不存在" | ||||||
| lookup: "查詢" | lookup: "查詢" | ||||||
| announcements: "公告" | announcements: "公告" | ||||||
| @@ -231,7 +232,7 @@ resetAreYouSure: "確定要重設嗎?" | |||||||
| saved: "已儲存" | saved: "已儲存" | ||||||
| messaging: "傳送訊息" | messaging: "傳送訊息" | ||||||
| upload: "上傳" | upload: "上傳" | ||||||
| fromDrive: "從雲端" | fromDrive: "從雲端空間" | ||||||
| fromUrl: "從URL" | fromUrl: "從URL" | ||||||
| uploadFromUrl: "從網址上傳" | uploadFromUrl: "從網址上傳" | ||||||
| uploadFromUrlDescription: "您要上傳的文件的URL" | uploadFromUrlDescription: "您要上傳的文件的URL" | ||||||
| @@ -247,7 +248,7 @@ agreeTo: "我同意{0}" | |||||||
| tos: "使用條款" | tos: "使用條款" | ||||||
| start: "開始" | start: "開始" | ||||||
| home: "首頁" | home: "首頁" | ||||||
| remoteUserCaution: "由於該用戶來自遠端實例,因此資料用戶並未即時更新。" | remoteUserCaution: "由於該使用者來自遠端實例,因此資訊可能非即時的。" | ||||||
| activity: "動態" | activity: "動態" | ||||||
| images: "圖片" | images: "圖片" | ||||||
| birthday: "生日" | birthday: "生日" | ||||||
| @@ -256,12 +257,12 @@ registeredDate: "註冊日期" | |||||||
| location: "位置" | location: "位置" | ||||||
| theme: "外觀主題" | theme: "外觀主題" | ||||||
| themeForLightMode: "在淺色模式下使用的主題" | themeForLightMode: "在淺色模式下使用的主題" | ||||||
| themeForDarkMode: "在深色模式下使用的主題" | themeForDarkMode: "在黑暗模式下使用的主題" | ||||||
| light: "淺色" | light: "淺色" | ||||||
| dark: "灰暗" | dark: "黑暗" | ||||||
| lightThemes: "明亮主題" | lightThemes: "明亮主題" | ||||||
| darkThemes: "灰暗主題" | darkThemes: "黑暗主題" | ||||||
| syncDeviceDarkMode: "將深色模式與設備設置同步" | syncDeviceDarkMode: "將黑暗模式與設備設置同步" | ||||||
| drive: "雲端硬碟" | drive: "雲端硬碟" | ||||||
| fileName: "檔案名稱" | fileName: "檔案名稱" | ||||||
| selectFile: "選擇檔案" | selectFile: "選擇檔案" | ||||||
| @@ -273,7 +274,7 @@ folderName: "資料夾名稱" | |||||||
| createFolder: "新增資料夾" | createFolder: "新增資料夾" | ||||||
| renameFolder: "重新命名資料夾" | renameFolder: "重新命名資料夾" | ||||||
| deleteFolder: "刪除資料夾" | deleteFolder: "刪除資料夾" | ||||||
| addFile: "添加附件" | addFile: "加入附件" | ||||||
| emptyDrive: "雲端硬碟為空" | emptyDrive: "雲端硬碟為空" | ||||||
| emptyFolder: "資料夾為空" | emptyFolder: "資料夾為空" | ||||||
| unableToDelete: "無法刪除" | unableToDelete: "無法刪除" | ||||||
| @@ -286,11 +287,11 @@ rename: "重新命名" | |||||||
| avatar: "大頭貼" | avatar: "大頭貼" | ||||||
| banner: "橫幅" | banner: "橫幅" | ||||||
| nsfw: "敏感內容" | nsfw: "敏感內容" | ||||||
| whenServerDisconnected: "與服務器的連接中斷時" | whenServerDisconnected: "與伺服器的連接中斷時" | ||||||
| disconnectedFromServer: "與伺服器中斷連線" | disconnectedFromServer: "與伺服器中斷連線" | ||||||
| reload: "重新載入" | reload: "重新整理" | ||||||
| doNothing: "無視" | doNothing: "無視" | ||||||
| reloadConfirm: "確定要重新嘗試嗎?" | reloadConfirm: "確定要重新整理嗎?" | ||||||
| watch: "關注" | watch: "關注" | ||||||
| unwatch: "取消追隨" | unwatch: "取消追隨" | ||||||
| accept: "接受" | accept: "接受" | ||||||
| @@ -309,24 +310,22 @@ monthX: "{month}月" | |||||||
| yearX: "{year}年" | yearX: "{year}年" | ||||||
| pages: "頁面" | pages: "頁面" | ||||||
| integration: "整合" | integration: "整合" | ||||||
| connectSerice: "連線" |  | ||||||
| disconnectSerice: "中斷連線" |  | ||||||
| enableLocalTimeline: "開啟本地時間軸" | enableLocalTimeline: "開啟本地時間軸" | ||||||
| enableGlobalTimeline: "啟用公開時間軸" | enableGlobalTimeline: "啟用公開時間軸" | ||||||
| disablingTimelinesInfo: "即使您禁用了時間線功能,管理員和協調人仍可以繼續使用,以方便您。" | disablingTimelinesInfo: "即使您關閉了時間線功能,管理員和協調人仍可以繼續使用,以方便您。" | ||||||
| registration: "註冊" | registration: "註冊" | ||||||
| enableRegistration: "開啟新用戶註冊" | enableRegistration: "開啟新使用者註冊" | ||||||
| invite: "邀請" | invite: "邀請" | ||||||
| proxyRemoteFiles: "遠端代理檔案" | proxyRemoteFiles: "遠端代理檔案" | ||||||
| proxyRemoteFilesDescription: "啟用此設置後,由於超出存儲容量而未保存或刪除的遠程文件將被本地代理,並且將生成預覽圖。這不影響服務器的存儲。" | proxyRemoteFilesDescription: "啟用此設置後,由於超出存儲容量而未保存或刪除的遠程文件將被本地代理,並且將生成預覽圖。這不影響伺服器的存儲。" | ||||||
| driveCapacityPerLocalAccount: "每個本地用戶的雲端容量" | driveCapacityPerLocalAccount: "每個本地用戶的雲端空間大小" | ||||||
| driveCapacityPerRemoteAccount: "每個非本地用戶的雲端容量" | driveCapacityPerRemoteAccount: "每個非本地用戶的雲端容量" | ||||||
| inMb: "以Mbps為單位" | inMb: "以Mbps為單位" | ||||||
| iconUrl: "圖像URL" | iconUrl: "圖像URL" | ||||||
| bannerUrl: "橫幅圖片URL" | bannerUrl: "橫幅圖像URL" | ||||||
| basicInfo: "基本資訊" | basicInfo: "基本資訊" | ||||||
| pinnedUsers: "置頂用戶" | pinnedUsers: "置頂用戶" | ||||||
| pinnedUsersDescription: "在「發現」頁面中使用換行標記想要置頂的用戶。" | pinnedUsersDescription: "在「發現」頁面中使用換行標記想要置頂的使用者。" | ||||||
| pinnedPages: "釘選頁面" | pinnedPages: "釘選頁面" | ||||||
| pinnedPagesDescription: "輸入要固定至實例首頁的頁面路徑,以換行符分隔。" | pinnedPagesDescription: "輸入要固定至實例首頁的頁面路徑,以換行符分隔。" | ||||||
| pinnedClipId: "置頂的摘錄ID" | pinnedClipId: "置頂的摘錄ID" | ||||||
| @@ -339,7 +338,7 @@ recaptcha: "reCAPTCHA" | |||||||
| enableRecaptcha: "啟用 reCAPTCHA" | enableRecaptcha: "啟用 reCAPTCHA" | ||||||
| recaptchaSiteKey: "網站金鑰" | recaptchaSiteKey: "網站金鑰" | ||||||
| recaptchaSecretKey: "金鑰" | recaptchaSecretKey: "金鑰" | ||||||
| avoidMultiCaptchaConfirm: "使用多種驗證方式可能會造成干擾,您要禁用其他驗證方式嗎?您可以按“取消”保留多種驗證方式。" | avoidMultiCaptchaConfirm: "使用多種驗證方式可能會造成干擾,您要關閉其他驗證方式嗎?您可以按“取消”保留多種驗證方式。" | ||||||
| antennas: "天線" | antennas: "天線" | ||||||
| manageAntennas: "管理天線" | manageAntennas: "管理天線" | ||||||
| name: "名稱" | name: "名稱" | ||||||
| @@ -349,7 +348,6 @@ antennaExcludeKeywords: "排除關鍵字" | |||||||
| antennaKeywordsDescription: "用空格分隔指定AND、用換行符分隔指定OR" | antennaKeywordsDescription: "用空格分隔指定AND、用換行符分隔指定OR" | ||||||
| notifyAntenna: "通知有新貼文" | notifyAntenna: "通知有新貼文" | ||||||
| withFileAntenna: "僅帶有附件的貼文" | withFileAntenna: "僅帶有附件的貼文" | ||||||
| serviceworker: "ServiceWorker" |  | ||||||
| enableServiceworker: "開啟 ServiceWorker" | enableServiceworker: "開啟 ServiceWorker" | ||||||
| antennaUsersDescription: "指定用換行符分隔的用戶名" | antennaUsersDescription: "指定用換行符分隔的用戶名" | ||||||
| caseSensitive: "區分大小寫" | caseSensitive: "區分大小寫" | ||||||
| @@ -361,11 +359,11 @@ silence: "禁言" | |||||||
| silenceConfirm: "確定要禁言此用戶嗎?" | silenceConfirm: "確定要禁言此用戶嗎?" | ||||||
| unsilence: "解除禁言" | unsilence: "解除禁言" | ||||||
| unsilenceConfirm: "確定要解除禁言嗎?" | unsilenceConfirm: "確定要解除禁言嗎?" | ||||||
| popularUsers: "熱門用戶" | popularUsers: "熱門使用者" | ||||||
| recentlyUpdatedUsers: "最近發文的用戶" | recentlyUpdatedUsers: "最近發文的使用者" | ||||||
| recentlyRegisteredUsers: "新加入用戶" | recentlyRegisteredUsers: "新加入使用者" | ||||||
| recentlyDiscoveredUsers: "最近發現的用戶" | recentlyDiscoveredUsers: "最近發現的使用者" | ||||||
| exploreUsersCount: "有{count}個用戶" | exploreUsersCount: "有{count}個使用者" | ||||||
| exploreFediverse: "探索聯邦世界" | exploreFediverse: "探索聯邦世界" | ||||||
| popularTags: "熱門標籤" | popularTags: "熱門標籤" | ||||||
| userList: "清單" | userList: "清單" | ||||||
| @@ -373,14 +371,14 @@ about: "資訊" | |||||||
| aboutMisskey: "關於 Misskey" | aboutMisskey: "關於 Misskey" | ||||||
| administrator: "管理員" | administrator: "管理員" | ||||||
| token: "權杖" | token: "權杖" | ||||||
| twoStepAuthentication: "雙重身份驗證" | twoStepAuthentication: "兩階段驗證" | ||||||
| moderator: "板主" | moderator: "板主" | ||||||
| nUsersMentioned: "提到了{n}" | nUsersMentioned: "提到了{n}" | ||||||
| securityKey: "安全金鑰" | securityKey: "安全金鑰" | ||||||
| securityKeyName: "金鑰名稱" | securityKeyName: "金鑰名稱" | ||||||
| registerSecurityKey: "註冊安全金鑰" | registerSecurityKey: "註冊安全金鑰" | ||||||
| lastUsed: "最後活躍時間" | lastUsed: "上次使用" | ||||||
| unregister: "刪除賬戶" | unregister: "註銷帳號" | ||||||
| passwordLessLogin: "設置無密碼登入" | passwordLessLogin: "設置無密碼登入" | ||||||
| resetPassword: "重置密碼" | resetPassword: "重置密碼" | ||||||
| newPasswordIs: "新密碼為「{password}」" | newPasswordIs: "新密碼為「{password}」" | ||||||
| @@ -405,7 +403,7 @@ invites: "邀請" | |||||||
| groupName: "群組名稱" | groupName: "群組名稱" | ||||||
| members: "成員" | members: "成員" | ||||||
| transfer: "轉讓" | transfer: "轉讓" | ||||||
| messagingWithUser: "傳送訊息給其他用戶" | messagingWithUser: "傳送訊息給其他使用者" | ||||||
| messagingWithGroup: "發送訊息至群組" | messagingWithGroup: "發送訊息至群組" | ||||||
| title: "標題" | title: "標題" | ||||||
| text: "文字" | text: "文字" | ||||||
| @@ -419,7 +417,7 @@ quoteAttached: "引用" | |||||||
| quoteQuestion: "是否要引用?" | quoteQuestion: "是否要引用?" | ||||||
| noMessagesYet: "沒有訊息" | noMessagesYet: "沒有訊息" | ||||||
| newMessageExists: "有新的訊息" | newMessageExists: "有新的訊息" | ||||||
| onlyOneFileCanBeAttached: "只能添加一個附件" | onlyOneFileCanBeAttached: "只能加入一個附件" | ||||||
| signinRequired: "請先登入" | signinRequired: "請先登入" | ||||||
| invitations: "邀請" | invitations: "邀請" | ||||||
| invitationCode: "邀請碼" | invitationCode: "邀請碼" | ||||||
| @@ -431,13 +429,14 @@ tooShort: "過短" | |||||||
| tooLong: "過長" | tooLong: "過長" | ||||||
| weakPassword: "密碼強度過弱" | weakPassword: "密碼強度過弱" | ||||||
| normalPassword: "密碼強度普通" | normalPassword: "密碼強度普通" | ||||||
| strongPassword: "密碼強度堅強" | strongPassword: "密碼強度高" | ||||||
| passwordMatched: "密碼一致" | passwordMatched: "密碼一致" | ||||||
| passwordNotMatched: "密碼不一致" | passwordNotMatched: "密碼不一致" | ||||||
| signinWith: "以{x}登錄" | signinWith: "以{x}登錄" | ||||||
| signinFailed: "登入失敗。 請檢查用戶名和密碼。" | signinFailed: "登入失敗。 請檢查使用者名稱和密碼。" | ||||||
| tapSecurityKey: "點擊安全密鑰" | tapSecurityKey: "點擊安全密鑰" | ||||||
| or: "或者" | or: "或者" | ||||||
|  | language: "語言" | ||||||
| uiLanguage: "介面語言" | uiLanguage: "介面語言" | ||||||
| groupInvited: "您有新的群組邀請" | groupInvited: "您有新的群組邀請" | ||||||
| aboutX: "關於{x}" | aboutX: "關於{x}" | ||||||
| @@ -445,14 +444,14 @@ useOsNativeEmojis: "使用OS原生表情符號" | |||||||
| youHaveNoGroups: "找不到群組" | youHaveNoGroups: "找不到群組" | ||||||
| joinOrCreateGroup: "請加入現有群組,或創建新群組。" | joinOrCreateGroup: "請加入現有群組,或創建新群組。" | ||||||
| noHistory: "沒有歷史紀錄" | noHistory: "沒有歷史紀錄" | ||||||
| signinHistory: "登錄歷史" | signinHistory: "登入歷史" | ||||||
| disableAnimatedMfm: "禁用MFM動畫" | disableAnimatedMfm: "禁用MFM動畫" | ||||||
| doing: "正在進行" | doing: "正在進行" | ||||||
| category: "類別" | category: "類別" | ||||||
| tags: "標籤" | tags: "標籤" | ||||||
| docSource: "文件來源" | docSource: "文件來源" | ||||||
| createAccount: "建立帳戶" | createAccount: "建立帳戶" | ||||||
| existingAcount: "現有帳戶" | existingAccount: "現有帳戶" | ||||||
| regenerate: "再生" | regenerate: "再生" | ||||||
| fontSize: "字體大小" | fontSize: "字體大小" | ||||||
| noFollowRequests: "沒有要求跟隨您的申請" | noFollowRequests: "沒有要求跟隨您的申請" | ||||||
| @@ -476,12 +475,12 @@ useObjectStorage: "使用Object Storage" | |||||||
| objectStorageBaseUrl: "Base URL" | objectStorageBaseUrl: "Base URL" | ||||||
| objectStorageBucket: "儲存空間(Bucket)" | objectStorageBucket: "儲存空間(Bucket)" | ||||||
| objectStoragePrefix: "前綴" | objectStoragePrefix: "前綴" | ||||||
| objectStorageEndpoint: "訪問網域名稱(Endpoint)" | objectStorageEndpoint: "端點(Endpoint)" | ||||||
| objectStorageEndpointDesc: "如要使用AWS S3,請留空。否則請根據伺服器要求以'<host>'或 '<host>:<port>'的形式設定訪問網域名稱(Endpoint)。" | objectStorageEndpointDesc: "如要使用AWS S3,請留空。否則請依照你使用的服務商的說明書進行設定,以'<host>'或 '<host>:<port>'的形式設定端點(Endpoint)。" | ||||||
| objectStorageRegion: "地域(Region)" | objectStorageRegion: "地域(Region)" | ||||||
| objectStorageUseSSL: "使用SSL" | objectStorageUseSSL: "使用SSL" | ||||||
| objectStorageUseProxy: "使用網路代理" | objectStorageUseProxy: "使用網路代理" | ||||||
| objectStorageSetPublicRead: "上載時設定為\"public-read\"" | objectStorageSetPublicRead: "上傳時設定為\"public-read\"" | ||||||
| serverLogs: "伺服器日誌" | serverLogs: "伺服器日誌" | ||||||
| deleteAll: "刪除所有記錄" | deleteAll: "刪除所有記錄" | ||||||
| showFixedPostForm: "於時間軸頁頂顯示「發送貼文」方框" | showFixedPostForm: "於時間軸頁頂顯示「發送貼文」方框" | ||||||
| @@ -494,7 +493,7 @@ popout: "彈出型窗口" | |||||||
| volume: "音量" | volume: "音量" | ||||||
| masterVolume: "主音量" | masterVolume: "主音量" | ||||||
| details: "詳細資訊" | details: "詳細資訊" | ||||||
| chooseEmoji: "選擇您的表情符號\n" | chooseEmoji: "選擇您的表情符號" | ||||||
| unableToProcess: "操作無法完成" | unableToProcess: "操作無法完成" | ||||||
| recentUsed: "最近使用" | recentUsed: "最近使用" | ||||||
| install: "安裝" | install: "安裝" | ||||||
| @@ -511,24 +510,24 @@ scratchpad: "暫存記憶體" | |||||||
| output: "輸出" | output: "輸出" | ||||||
| script: "腳本" | script: "腳本" | ||||||
| disablePagesScript: "停用頁面的AiScript腳本" | disablePagesScript: "停用頁面的AiScript腳本" | ||||||
| updateRemoteUser: "更新非本地用戶資料" | updateRemoteUser: "更新遠端使用者資訊" | ||||||
| deleteAllFiles: "刪除所有檔案" | deleteAllFiles: "刪除所有檔案" | ||||||
| deleteAllFilesConfirm: "要删除所有檔案吗?" | deleteAllFilesConfirm: "要删除所有檔案嗎?" | ||||||
| removeAllFollowing: "解除所有追隨" | removeAllFollowing: "解除所有追蹤" | ||||||
| removeAllFollowingDescription: "解除{host}所有的跟隨。在實例不再存在時執行。" | removeAllFollowingDescription: "解除{host}所有的追蹤。在實例不再存在時執行。" | ||||||
| userSuspended: "該用戶已被凍結" | userSuspended: "該使用者已被停用" | ||||||
| userSilenced: "該用戶已被禁言。" | userSilenced: "該用戶已被禁言。" | ||||||
| sidebar: "側邊列" | sidebar: "側邊列" | ||||||
| divider: "分割線" | divider: "分割線" | ||||||
| addItem: "新增項目" | addItem: "新增項目" | ||||||
| rooms: "房間" | rooms: "房間" | ||||||
| relays: "中繼" | relays: "中繼" | ||||||
| addRelay: "添加中繼" | addRelay: "新增中繼" | ||||||
| inboxUrl: "私信URL" | inboxUrl: "收件夾URL" | ||||||
| addedRelays: "已添加的中繼" | addedRelays: "已加入的中繼" | ||||||
| serviceworkerInfo: "您需要啟用推送通知" | serviceworkerInfo: "您需要啟用推送通知" | ||||||
| deletedNote: "已删除的貼文" | deletedNote: "已删除的貼文" | ||||||
| invisibleNote: "隱藏的帖子" | invisibleNote: "隱藏的貼文" | ||||||
| enableInfiniteScroll: "啟用自動滾動頁面模式" | enableInfiniteScroll: "啟用自動滾動頁面模式" | ||||||
| visibility: "可見性" | visibility: "可見性" | ||||||
| poll: "投票" | poll: "投票" | ||||||
| @@ -545,7 +544,7 @@ plugins: "插件" | |||||||
| deck: "多欄模式" | deck: "多欄模式" | ||||||
| undeck: "取消多欄模式" | undeck: "取消多欄模式" | ||||||
| useBlurEffectForModal: "在模態框使用模糊效果" | useBlurEffectForModal: "在模態框使用模糊效果" | ||||||
| useFullReactionPicker: "使用大尺寸的情感選擇欄" | useFullReactionPicker: "使用全尺寸的反應選擇器" | ||||||
| width: "寬度" | width: "寬度" | ||||||
| height: "高度" | height: "高度" | ||||||
| large: "大" | large: "大" | ||||||
| @@ -554,22 +553,22 @@ small: "小" | |||||||
| permission: "權限" | permission: "權限" | ||||||
| enableAll: "啟用全部" | enableAll: "啟用全部" | ||||||
| disableAll: "停用全部" | disableAll: "停用全部" | ||||||
| tokenRequested: "允許訪問帳號" | tokenRequested: "允許存取帳號" | ||||||
| notificationType: "通知形式" | notificationType: "通知形式" | ||||||
| edit: "編輯" | edit: "編輯" | ||||||
| useStarForReactionFallback: "以★代替未知的表情符號" | useStarForReactionFallback: "以★代替未知的表情符號" | ||||||
| emailConfig: "電子郵件伺服器設定" | emailServer: "電郵伺服器" | ||||||
| enableEmail: "啟用發送電郵功能" | enableEmail: "啟用發送電郵功能" | ||||||
| emailConfigInfo: "用於確認電郵地址及密碼重置" | emailConfigInfo: "用於確認電郵地址及密碼重置" | ||||||
| email: "電子郵件" | email: "電子郵件" | ||||||
| emailAddress: "電郵地址" | emailAddress: "電郵地址" | ||||||
| smtpConfig: "SMTP伺服器設定" | smtpConfig: "SMTP伺服器設定" | ||||||
| smtpHost: "主機" | smtpHost: "主機" | ||||||
| smtpPort: "端口" | smtpPort: "埠" | ||||||
| smtpUser: "使用者名稱" | smtpUser: "使用者名稱" | ||||||
| smtpPass: "密碼" | smtpPass: "密碼" | ||||||
| emptyToDisableSmtpAuth: "留空使用者名稱和密碼以禁用SMTP驗證。" | emptyToDisableSmtpAuth: "留空使用者名稱和密碼以關閉SMTP驗證。" | ||||||
| testEmail: "郵件測試發送" | testEmail: "測試郵件發送" | ||||||
| wordMute: "靜音文字" | wordMute: "靜音文字" | ||||||
| userSaysSomething: "{name}說了什麼" | userSaysSomething: "{name}說了什麼" | ||||||
| makeActive: "啟用" | makeActive: "啟用" | ||||||
| @@ -585,23 +584,26 @@ create: "新增" | |||||||
| notificationSetting: "通知設定" | notificationSetting: "通知設定" | ||||||
| notificationSettingDesc: "選擇顯示通知的類型" | notificationSettingDesc: "選擇顯示通知的類型" | ||||||
| useGlobalSetting: "使用全域設定" | useGlobalSetting: "使用全域設定" | ||||||
|  | useGlobalSettingDesc: "啟用時,將使用帳戶通知設定。停用時,則可以單獨設定。" | ||||||
| other: "其他" | other: "其他" | ||||||
| regenerateLoginToken: "再生登入權杖" | regenerateLoginToken: "重新產生登入權杖" | ||||||
| regenerateLoginTokenDescription: "再生用於登入的內部權杖。一般情況下是不需要這樣做的。一旦再生,所有裝置將會被登出。" | regenerateLoginTokenDescription: "重新產生用於登入的內部權杖。一般情況下是不需要這樣做的。一旦重產,所有裝置將會被登出。" | ||||||
| fileIdOrUrl: "文檔ID或者URL" | setMultipleBySeparatingWithSpace: "您可以使用空格分隔多個項目。" | ||||||
|  | fileIdOrUrl: "檔案ID或URL" | ||||||
| chatOpenBehavior: "開啟聊天窗口時的行為" | chatOpenBehavior: "開啟聊天窗口時的行為" | ||||||
| behavior: "行為" | behavior: "行為" | ||||||
| sample: "範例 " | sample: "範例" | ||||||
| abuseReports: "檢舉" | abuseReports: "檢舉" | ||||||
| reportAbuse: "檢舉" | reportAbuse: "檢舉" | ||||||
| reportAbuseOf: "檢舉{name}" | reportAbuseOf: "檢舉{name}" | ||||||
| fillAbuseReportDescription: "請填寫檢舉的詳細理由。可以的話,請附上針對的URL網址。" | fillAbuseReportDescription: "請填寫檢舉的詳細理由。可以的話,請附上針對的URL網址。" | ||||||
| abuseReported: "內容已經發送。感謝您的報告。" | abuseReported: "回報已送出。感謝您的報告。" | ||||||
| send: "發送" | send: "發送" | ||||||
| abuseMarkAsResolved: "處理完畢" | abuseMarkAsResolved: "處理完畢" | ||||||
| openInNewTab: "在新分頁中開啟" | openInNewTab: "在新分頁中開啟" | ||||||
| openInSideView: "在側欄中開啟" | openInSideView: "在側欄中開啟" | ||||||
| editTheseSettingsMayBreakAccount: "修改這些設定可能會毀壞您的帳戶" | defaultNavigationBehaviour: "默認導航" | ||||||
|  | editTheseSettingsMayBreakAccount: "修改這些設定可能會毀損您的帳戶" | ||||||
| instanceTicker: "貼文的實例來源" | instanceTicker: "貼文的實例來源" | ||||||
| waitingFor: "等待{x}" | waitingFor: "等待{x}" | ||||||
| random: "隨機" | random: "隨機" | ||||||
| @@ -617,7 +619,7 @@ i18nInfo: "Misskey已經被志願者們翻譯成各種語言版本,如果想 | |||||||
| manageAccessTokens: "管理存取權杖" | manageAccessTokens: "管理存取權杖" | ||||||
| accountInfo: "帳戶資訊" | accountInfo: "帳戶資訊" | ||||||
| notesCount: "貼文數量" | notesCount: "貼文數量" | ||||||
| repliesCount: "回覆數量\n" | repliesCount: "回覆數量" | ||||||
| renotesCount: "轉發數量" | renotesCount: "轉發數量" | ||||||
| repliedCount: "回覆數量" | repliedCount: "回覆數量" | ||||||
| renotedCount: "轉發次數" | renotedCount: "轉發次數" | ||||||
| @@ -631,26 +633,30 @@ yes: "確定" | |||||||
| no: "取消" | no: "取消" | ||||||
| driveFilesCount: "雲端硬碟檔案數量" | driveFilesCount: "雲端硬碟檔案數量" | ||||||
| driveUsage: "雲端硬碟使用量" | driveUsage: "雲端硬碟使用量" | ||||||
| noCrawleDescription: "請求網路搜尋引擎不要索引你的個人資料頁、貼文及頁面等。" | noCrawle: "拒絕搜尋引擎索引" | ||||||
|  | noCrawleDescription: "要求網路搜尋引擎不要索引你的個人資料頁、貼文及頁面等。" | ||||||
| lockedAccountInfo: "即使你通過了追隨者請求,除非你將貼文的可見性設定為 「追隨者」,否則任何人都能看見你的貼文。" | lockedAccountInfo: "即使你通過了追隨者請求,除非你將貼文的可見性設定為 「追隨者」,否則任何人都能看見你的貼文。" | ||||||
| loadRawImages: "以原始圖像質量顯示附件圖像的縮略圖" | alwaysMarkSensitive: "默認將圖像/影像標記為敏感內容" | ||||||
| disableShowingAnimatedImages: "不播放動態圖像" | loadRawImages: "以原始圖檔顯示附件圖檔的縮圖" | ||||||
|  | disableShowingAnimatedImages: "不播放動態圖檔" | ||||||
|  | verificationEmailSent: "已發送驗證電子郵件。請點擊進入電子郵件中的鏈接完成驗證。" | ||||||
| notSet: "未設定" | notSet: "未設定" | ||||||
| emailVerified: "已成功驗證您的電郵" | emailVerified: "已成功驗證您的電郵" | ||||||
| noteFavoritesCount: "我的最愛貼文的數目" | noteFavoritesCount: "我的最愛貼文的數目" | ||||||
| pageLikesCount: "頁面被喜歡次數" | pageLikesCount: "頁面被按讚次數" | ||||||
| pageLikedCount: "頁面被喜歡次數" | pageLikedCount: "頁面被按讚次數" | ||||||
|  | reversiCount: "黑白棋對戰次數" | ||||||
| contact: "聯絡人" | contact: "聯絡人" | ||||||
| useSystemFont: "使用系統默認的字型" | useSystemFont: "使用系統預設的字型" | ||||||
| clips: "摘錄" | clips: "摘錄" | ||||||
| experimentalFeatures: "測試中的功能" | experimentalFeatures: "實驗中的功能" | ||||||
| developer: "開發者" | developer: "開發者" | ||||||
| makeExplorable: "讓自己的帳戶能夠在“探索”版面顯示" | makeExplorable: "使自己的帳戶能夠在“探索”頁面中顯示" | ||||||
| makeExplorableDescription: "如果關閉,帳戶將不會被顯示在\"探索\"版面中。" | makeExplorableDescription: "如果關閉,帳戶將不會被顯示在\"探索\"頁面中。" | ||||||
| showGapBetweenNotesInTimeline: "分開顯示時間線上的貼文。" | showGapBetweenNotesInTimeline: "分開顯示時間線上的貼文。" | ||||||
| duplicate: "複製" | duplicate: "複製" | ||||||
| left: "左" | left: "左" | ||||||
| center: "向中央" | center: "置中" | ||||||
| wide: "寬" | wide: "寬" | ||||||
| narrow: "窄" | narrow: "窄" | ||||||
| reloadToApplySetting: "設定將會在頁面重新載入之後生效。要現在就重載頁面嗎?" | reloadToApplySetting: "設定將會在頁面重新載入之後生效。要現在就重載頁面嗎?" | ||||||
| @@ -659,27 +665,87 @@ clearCache: "清除快取資料" | |||||||
| onlineUsersCount: "{n}人正在線上" | onlineUsersCount: "{n}人正在線上" | ||||||
| nUsers: "{n}用戶" | nUsers: "{n}用戶" | ||||||
| nNotes: "{n}貼文" | nNotes: "{n}貼文" | ||||||
|  | sendErrorReports: "傳送錯誤報告" | ||||||
|  | sendErrorReportsDescription: "啟用後,問題報告將傳送至開發者以提升軟體品質。問題報告可能包括OS版本,瀏覽器類型,行為歷史記錄等。" | ||||||
| myTheme: "我的佈景主題" | myTheme: "我的佈景主題" | ||||||
| backgroundColor: "背景" | backgroundColor: "背景" | ||||||
| accentColor: "重點色彩" | accentColor: "重點色彩" | ||||||
| textColor: "文本" | textColor: "文字" | ||||||
|  | saveAs: "另存為..." | ||||||
| advanced: "進階" | advanced: "進階" | ||||||
| value: "數值 " | value: "數值" | ||||||
|  | createdAt: "建立於" | ||||||
| updatedAt: "最後更新" | updatedAt: "最後更新" | ||||||
| saveConfirm: "您要儲存變更嗎?" | saveConfirm: "您要儲存變更嗎?" | ||||||
| deleteConfirm: "你確定要刪除嗎?" | deleteConfirm: "你確定要刪除嗎?" | ||||||
| invalidValue: "輸入值無效。" | invalidValue: "輸入值無效。" | ||||||
| registry: "登錄表" | registry: "登錄表" | ||||||
| closeAccount: "停用帳戶" | closeAccount: "停用帳戶" | ||||||
| currentVersion: "當前版本" | currentVersion: "目前版本" | ||||||
| latestVersion: "最新版本" | latestVersion: "最新版本" | ||||||
|  | youAreRunningUpToDateClient: "您所使用的用戶端已經是最新的。" | ||||||
| newVersionOfClientAvailable: "新版本的用戶端可用。" | newVersionOfClientAvailable: "新版本的用戶端可用。" | ||||||
| usageAmount: "使用量" | usageAmount: "使用量" | ||||||
| capacity: "容量" | capacity: "容量" | ||||||
| inUse: "已使用" | inUse: "已使用" | ||||||
|  | editCode: "編輯代碼" | ||||||
|  | apply: "套用" | ||||||
|  | receiveAnnouncementFromInstance: "接收由本實例發出的電郵通知" | ||||||
|  | emailNotification: "郵件通知" | ||||||
|  | publish: "發佈" | ||||||
|  | inChannelSearch: "頻道内搜尋" | ||||||
|  | useReactionPickerForContextMenu: "點擊右鍵開啟回應工具欄" | ||||||
|  | typingUsers: "{users}輸入中..." | ||||||
|  | jumpToSpecifiedDate: "跳轉到特定日期" | ||||||
|  | showingPastTimeline: "顯示過往的時間線" | ||||||
|  | clear: "清除" | ||||||
|  | markAllAsRead: "全部標示為已讀" | ||||||
|  | goBack: "返回" | ||||||
|  | unlikeConfirm: "要取消按讚嗎?" | ||||||
|  | fullView: "全熒幕顯示" | ||||||
|  | quitFullView: "退出全熒幕顯示" | ||||||
|  | addDescription: "添加描述" | ||||||
|  | userPagePinTip: "在貼文的選單中選擇\"置頂\",即可置頂該貼文至您的個人檔案頁面。" | ||||||
|  | notSpecifiedMentionWarning: "此貼文有未指定的提及" | ||||||
|  | info: "資訊" | ||||||
|  | userInfo: "用戶資料" | ||||||
|  | unknown: "未知" | ||||||
|  | onlineStatus: "在線狀態" | ||||||
|  | hideOnlineStatus: "隱藏在線狀態" | ||||||
|  | hideOnlineStatusDescription: "隱藏在線狀態後,可能會降低檢索等功能的便利性。" | ||||||
|  | online: "線上" | ||||||
|  | active: "最近活躍" | ||||||
|  | offline: "離線" | ||||||
|  | notRecommended: "不推薦" | ||||||
|  | botProtection: "Bot防護" | ||||||
|  | instanceBlocking: "已封鎖的實例" | ||||||
|  | selectAccount: "選擇帳戶" | ||||||
|  | enabled: "已啟用" | ||||||
|  | disabled: "已停用" | ||||||
|  | quickAction: "快捷操作" | ||||||
|  | user: "使用者" | ||||||
|  | administration: "管理" | ||||||
|  | accounts: "帳戶" | ||||||
|  | switch: "切換" | ||||||
|  | noMaintainerInformationWarning: "尚未設定管理員信息。" | ||||||
|  | noBotProtectionWarning: "尚未設定Bot防護。" | ||||||
|  | configure: "設定" | ||||||
|  | expiration: "期限" | ||||||
|  | middle: "中" | ||||||
|  | emailNotConfiguredWarning: "沒有設定電子郵件地址" | ||||||
|  | _ad: | ||||||
|  |   back: "返回" | ||||||
|  | _gallery: | ||||||
|  |   unlike: "收回喜歡" | ||||||
| _email: | _email: | ||||||
|   _follow: |   _follow: | ||||||
|     title: "您有新的追隨者" |     title: "您有新的追隨者" | ||||||
|  |   _receiveFollowRequest: | ||||||
|  |     title: "收到追隨請求" | ||||||
|  | _plugin: | ||||||
|  |   install: "安裝外掛組件" | ||||||
|  |   installWarn: "請不要安裝來源不明的外掛組件。" | ||||||
|  |   manage: "管理插件" | ||||||
| _registry: | _registry: | ||||||
|   scope: "範圍" |   scope: "範圍" | ||||||
|   key: "機碼" |   key: "機碼" | ||||||
| @@ -687,13 +753,13 @@ _registry: | |||||||
|   domain: "域" |   domain: "域" | ||||||
|   createKey: "新增機碼" |   createKey: "新增機碼" | ||||||
| _aboutMisskey: | _aboutMisskey: | ||||||
|   about: "Misskey是由syuilo於2014年開發的開源軟件。" |   about: "Misskey是由syuilo自2014年起開發的開源軟體。" | ||||||
|   contributors: "主要貢獻者" |   contributors: "主要貢獻者" | ||||||
|   allContributors: "全體貢獻人員" |   allContributors: "全體貢獻人員" | ||||||
|   source: "原始碼" |   source: "原始碼" | ||||||
|   translation: "翻譯Misskey" |   translation: "翻譯Misskey" | ||||||
|   donate: "捐贈給Misskey" |   donate: "贊助Misskey" | ||||||
|   morePatrons: "感謝你們的支持、 幫助。 🥰" |   morePatrons: "還有許許多多幫助我們的其他人,非常感謝你們。 🥰" | ||||||
|   patrons: "贊助者" |   patrons: "贊助者" | ||||||
| _nsfw: | _nsfw: | ||||||
|   respect: "隱藏敏感內容" |   respect: "隱藏敏感內容" | ||||||
| @@ -702,9 +768,13 @@ _nsfw: | |||||||
| _mfm: | _mfm: | ||||||
|   cheatSheet: "MFM代碼小抄" |   cheatSheet: "MFM代碼小抄" | ||||||
|   intro: "MFM是Misskey專用的標記語言,可以在Misskey中的各個位置使用。 您可以這裏看到MFM可用語法列表。" |   intro: "MFM是Misskey專用的標記語言,可以在Misskey中的各個位置使用。 您可以這裏看到MFM可用語法列表。" | ||||||
|  |   dummy: "Misskey拓展了Fediverse的世界" | ||||||
|   mention: "提及" |   mention: "提及" | ||||||
|  |   mentionDescription: "透過 @+用戶名 來標示特定使用者。" | ||||||
|   hashtag: "#tag" |   hashtag: "#tag" | ||||||
|  |   hashtagDescription: "可以使用\"#\"符號後加文字表示話題標籤。" | ||||||
|   url: "URL" |   url: "URL" | ||||||
|  |   urlDescription: "可以展示URL位址。" | ||||||
|   link: "鏈接" |   link: "鏈接" | ||||||
|   bold: "粗體" |   bold: "粗體" | ||||||
|   small: "縮小" |   small: "縮小" | ||||||
| @@ -735,7 +805,7 @@ _mfm: | |||||||
|   x4Description: "將顯示內容放至最大。" |   x4Description: "將顯示內容放至最大。" | ||||||
|   blur: "模糊" |   blur: "模糊" | ||||||
|   font: "字型" |   font: "字型" | ||||||
|   fontDescription: "可設置顯示內容所使用的字型" |   fontDescription: "您可以設定顯示內容的字型" | ||||||
| _reversi: | _reversi: | ||||||
|   reversi: "黑白棋" |   reversi: "黑白棋" | ||||||
|   gameSettings: "對弈設定" |   gameSettings: "對弈設定" | ||||||
| @@ -756,7 +826,7 @@ _reversi: | |||||||
|   pastTurnOf: "{name}的回合" |   pastTurnOf: "{name}的回合" | ||||||
|   surrender: "認輸" |   surrender: "認輸" | ||||||
|   surrendered: "對手認輸" |   surrendered: "對手認輸" | ||||||
|   drawn: "平局" |   drawn: "平手" | ||||||
|   won: "{name}獲勝" |   won: "{name}獲勝" | ||||||
|   black: "黑" |   black: "黑" | ||||||
|   white: "白" |   white: "白" | ||||||
| @@ -766,6 +836,7 @@ _reversi: | |||||||
|   allGames: "所有對弈" |   allGames: "所有對弈" | ||||||
|   ended: "已結束" |   ended: "已結束" | ||||||
|   playing: "正在對弈" |   playing: "正在對弈" | ||||||
|  |   loopedMap: "循環棋盤" | ||||||
| _instanceTicker: | _instanceTicker: | ||||||
|   none: "隱藏" |   none: "隱藏" | ||||||
|   remote: "向遠端使用者顯示" |   remote: "向遠端使用者顯示" | ||||||
| @@ -777,16 +848,16 @@ _serverDisconnectedBehavior: | |||||||
| _channel: | _channel: | ||||||
|   create: "建立頻道" |   create: "建立頻道" | ||||||
|   edit: "編輯頻道" |   edit: "編輯頻道" | ||||||
|   setBanner: "設定橫幅" |   setBanner: "設定橫幅圖像" | ||||||
|   removeBanner: "移除封面圖" |   removeBanner: "移除橫幅圖像" | ||||||
|   featured: "發燒內容" |   featured: "熱門貼文" | ||||||
|   owned: "管理中" |   owned: "管理中" | ||||||
|   following: "關注中" |   following: "關注中" | ||||||
|   usersCount: "有{n}人參與" |   usersCount: "有{n}人參與" | ||||||
|   notesCount: "有{n}個帖子" |   notesCount: "有{n}個貼文" | ||||||
| _sidebar: | _sidebar: | ||||||
|   full: "全部" |   full: "全部" | ||||||
|   icon: "頭像" |   icon: "大頭貼" | ||||||
|   hide: "隱藏" |   hide: "隱藏" | ||||||
| _wordMute: | _wordMute: | ||||||
|   muteWords: "加入靜音文字" |   muteWords: "加入靜音文字" | ||||||
| @@ -797,6 +868,7 @@ _theme: | |||||||
|   install: "安裝佈景主題" |   install: "安裝佈景主題" | ||||||
|   manage: "佈景主題管理員" |   manage: "佈景主題管理員" | ||||||
|   code: "主題代碼" |   code: "主題代碼" | ||||||
|  |   description: "描述" | ||||||
|   installed: "{name}已安裝" |   installed: "{name}已安裝" | ||||||
|   installedThemes: "已經安裝的主題" |   installedThemes: "已經安裝的主題" | ||||||
|   builtinThemes: "標準主題" |   builtinThemes: "標準主題" | ||||||
| @@ -816,16 +888,18 @@ _theme: | |||||||
|   keys: |   keys: | ||||||
|     bg: "背景" |     bg: "背景" | ||||||
|     fg: "文本" |     fg: "文本" | ||||||
|  |     panel: "面板" | ||||||
|     shadow: "陰影" |     shadow: "陰影" | ||||||
|  |     navActive: "側邊欄文本 (活動)" | ||||||
|     navIndicator: "側邊欄指示符" |     navIndicator: "側邊欄指示符" | ||||||
|     link: "鏈接" |     link: "鏈接" | ||||||
|     hashtag: "#tag" |     hashtag: "#tag" | ||||||
|     mention: "提及" |     mention: "提到" | ||||||
|     mentionMe: "提及我" |     mentionMe: "提到了我" | ||||||
|     renote: "轉發貼文" |     renote: "轉發貼文" | ||||||
|     divider: "分割線" |     divider: "分割線" | ||||||
|     scrollbarHandle: "滾動條" |     scrollbarHandle: "捲動條" | ||||||
|     scrollbarHandleHover: "滾動條 (漂浮)" |     scrollbarHandleHover: "捲動條 (漂浮)" | ||||||
|     dateLabelFg: "日期標籤文字" |     dateLabelFg: "日期標籤文字" | ||||||
|     infoBg: "資訊背景" |     infoBg: "資訊背景" | ||||||
|     infoFg: "資訊內容" |     infoFg: "資訊內容" | ||||||
| @@ -834,13 +908,16 @@ _theme: | |||||||
|     cwBg: "CW 按鈕背景" |     cwBg: "CW 按鈕背景" | ||||||
|     cwFg: "CW 按鈕文本" |     cwFg: "CW 按鈕文本" | ||||||
|     cwHoverBg: "CW 按鈕背景 (漂浮)" |     cwHoverBg: "CW 按鈕背景 (漂浮)" | ||||||
|  |     toastBg: "通知背景" | ||||||
|  |     toastFg: "通知文本" | ||||||
|     buttonBg: "按鈕背景" |     buttonBg: "按鈕背景" | ||||||
|     buttonHoverBg: "按鈕背景 (漂浮)" |     buttonHoverBg: "按鈕背景 (漂浮)" | ||||||
|     inputBorder: "輸入框邊框" |     inputBorder: "輸入框邊框" | ||||||
|     listItemHoverBg: "列表物品背景 (漂浮)" |     listItemHoverBg: "列表物品背景 (漂浮)" | ||||||
|     driveFolderBg: "雲端硬碟文件夾背景" |     driveFolderBg: "雲端硬碟文件夾背景" | ||||||
|  |     wallpaperOverlay: "壁紙覆蓋層" | ||||||
|     badge: "獎章" |     badge: "獎章" | ||||||
|     messageBg: "私信背景" |     messageBg: "私訊背景" | ||||||
|     accentDarken: "強調色(偏暗)" |     accentDarken: "強調色(偏暗)" | ||||||
|     accentLighten: "強調色(明亮)" |     accentLighten: "強調色(明亮)" | ||||||
|     fgHighlighted: "高亮顯示文本" |     fgHighlighted: "高亮顯示文本" | ||||||
| @@ -849,6 +926,7 @@ _sfx: | |||||||
|   noteMy: "我的貼文" |   noteMy: "我的貼文" | ||||||
|   notification: "通知" |   notification: "通知" | ||||||
|   chat: "傳送訊息" |   chat: "傳送訊息" | ||||||
|  |   chatBg: "聊天背景" | ||||||
|   antenna: "天線接收" |   antenna: "天線接收" | ||||||
|   channel: "頻道通知" |   channel: "頻道通知" | ||||||
| _ago: | _ago: | ||||||
| @@ -874,18 +952,19 @@ _tutorial: | |||||||
|   step1_3: "由於你沒有發佈任何貼文,也沒有追隨任何人,所以你的時間軸目前是空的。" |   step1_3: "由於你沒有發佈任何貼文,也沒有追隨任何人,所以你的時間軸目前是空的。" | ||||||
|   step2_1: "在發文或追隨其他人之前先讓我們設定一下個人資料吧。" |   step2_1: "在發文或追隨其他人之前先讓我們設定一下個人資料吧。" | ||||||
|   step2_2: "提供一些關於自己的資訊來讓其他人更有追隨你的意願。" |   step2_2: "提供一些關於自己的資訊來讓其他人更有追隨你的意願。" | ||||||
|   step3_1: "個人資料都打理好了嗎?" |   step3_1: "個人資料都設定好了嗎?" | ||||||
|   step3_2: "下一步讓我們來試試看發個文,按一下畫面上的鉛筆圖示來開始" |   step3_2: "接下來,讓我們來試試看發個文,按一下畫面上的鉛筆圖示來開始" | ||||||
|   step3_3: "輸入完內容後,按視窗右上角的按鈕來發文" |   step3_3: "輸入完內容後,按視窗右上角的按鈕來發文" | ||||||
|   step3_4: "不知道該寫什麼內容嗎?試試看「開始使用Misskey了」如何。" |   step3_4: "不知道該寫什麼內容嗎?試試看「開始使用Misskey了」如何。" | ||||||
|   step4_1: "貼文發出去了嗎?" |   step4_1: "貼文發出去了嗎?" | ||||||
|   step4_2: "如果你的貼文出現在時間軸上,就代表發文成功。" |   step4_2: "如果你的貼文出現在時間軸上,就代表發文成功。" | ||||||
|   step5_1: "現在試試看追隨其他人來讓你的時間軸變得更生動吧。" |   step5_1: "現在試試看追隨其他人來讓你的時間軸變得更生動吧。" | ||||||
|   step5_2: "你會在{featured}上看到受歡迎的貼文,你也可以從列表中追隨你喜歡的人,或者在{explore}上找到熱門使用者。" |   step5_2: "你會在{featured}上看到受歡迎的貼文,你也可以從列表中追隨你喜歡的人,或者在{explore}上找到熱門使用者。" | ||||||
|   step5_3: "想要追隨其他人,只要點擊他們的頭像並按「追隨」即可。" |   step5_3: "想要追隨其他人,只要點擊他們的大頭貼並按「追隨」即可。" | ||||||
|   step5_4: "如果使用者的名字旁有鎖頭的圖示,代表他們需要手動核准你的追隨請求。" |   step5_4: "如果使用者的名字旁有鎖頭的圖示,代表他們需要手動核准你的追隨請求。" | ||||||
|   step6_1: "現在你可以在時間軸上看到其他用戶的貼文。" |   step6_1: "現在你可以在時間軸上看到其他用戶的貼文。" | ||||||
|   step6_2: "你也可以對別人的貼文作出「情感」,作出簡單的回覆。" |   step6_2: "你也可以對別人的貼文作出「情感」,作出簡單的回覆。" | ||||||
|  |   step6_3: "在他人的貼文按下\"+\"圖標,即可選擇喜好的表情符號進行回應。" | ||||||
|   step7_1: "以上為Misskey的基本操作說明,教學在此告一段落。辛苦了。" |   step7_1: "以上為Misskey的基本操作說明,教學在此告一段落。辛苦了。" | ||||||
|   step7_2: "歡迎到{help}來瞭解更多Misskey相關介紹。" |   step7_2: "歡迎到{help}來瞭解更多Misskey相關介紹。" | ||||||
|   step7_3: "那麼,祝您在Misskey玩的開心~ 🚀" |   step7_3: "那麼,祝您在Misskey玩的開心~ 🚀" | ||||||
| @@ -893,16 +972,17 @@ _2fa: | |||||||
|   alreadyRegistered: "此設備已經被註冊過了" |   alreadyRegistered: "此設備已經被註冊過了" | ||||||
|   registerDevice: "註冊裝置" |   registerDevice: "註冊裝置" | ||||||
|   step1: "首先,在您的設備上安裝二步驗證程式,例如{a}或{b}。" |   step1: "首先,在您的設備上安裝二步驗證程式,例如{a}或{b}。" | ||||||
|   step2: "然後,掃描熒幕上的QR code。" |   step2: "然後,掃描螢幕上的QR code。" | ||||||
| _permissions: | _permissions: | ||||||
|   "read:account": "查看帳戶信息" |   "read:account": "查看帳戶信息" | ||||||
|   "write:account": "更改帳戶信息" |   "write:account": "更改帳戶信息" | ||||||
|   "read:blocks": "已封鎖用戶名單" |   "read:blocks": "已封鎖用戶名單" | ||||||
|   "write:blocks": "編輯已封鎖用戶名單" |   "write:blocks": "編輯已封鎖用戶名單" | ||||||
|   "read:drive": "存取雲端硬碟\n" |   "read:drive": "存取雲端硬碟" | ||||||
|   "write:drive": "編輯雲端硬碟的檔案" |   "write:drive": "編輯雲端硬碟的檔案" | ||||||
|   "read:favorites": "瀏覽我的最愛" |   "read:favorites": "瀏覽我的最愛" | ||||||
|   "write:favorites": "編輯我的最愛列表" |   "write:favorites": "編輯我的最愛列表" | ||||||
|  |   "read:following": "查看追隨中的用戶資訊" | ||||||
|   "write:following": "追隨/解除追隨" |   "write:following": "追隨/解除追隨" | ||||||
|   "read:messaging": "顯示訊息" |   "read:messaging": "顯示訊息" | ||||||
|   "write:messaging": "撰寫或刪除私人訊息" |   "write:messaging": "撰寫或刪除私人訊息" | ||||||
| @@ -916,7 +996,7 @@ _permissions: | |||||||
|   "write:votes": "投票" |   "write:votes": "投票" | ||||||
|   "read:pages": "顯示頁面" |   "read:pages": "顯示頁面" | ||||||
|   "write:pages": "編輯頁面" |   "write:pages": "編輯頁面" | ||||||
|   "read:page-likes": "顯示頁面的已喜歡" |   "read:page-likes": "顯示已按讚的頁面" | ||||||
|   "write:page-likes": "編輯頁面上喜歡" |   "write:page-likes": "編輯頁面上喜歡" | ||||||
|   "read:user-groups": "顯示使用者群組" |   "read:user-groups": "顯示使用者群組" | ||||||
|   "write:user-groups": "編輯使用者群組" |   "write:user-groups": "編輯使用者群組" | ||||||
| @@ -958,7 +1038,7 @@ _widgets: | |||||||
|   postForm: "發佈窗口" |   postForm: "發佈窗口" | ||||||
|   slideshow: "幻燈片" |   slideshow: "幻燈片" | ||||||
|   button: "按鈕" |   button: "按鈕" | ||||||
|   onlineUsers: "在線上的用戶" |   onlineUsers: "線上的用戶" | ||||||
|   jobQueue: "佇列" |   jobQueue: "佇列" | ||||||
| _cw: | _cw: | ||||||
|   hide: "隱藏" |   hide: "隱藏" | ||||||
| @@ -969,6 +1049,7 @@ _poll: | |||||||
|   noOnlyOneChoice: "至少需要兩個選項。" |   noOnlyOneChoice: "至少需要兩個選項。" | ||||||
|   choiceN: "選擇{n}" |   choiceN: "選擇{n}" | ||||||
|   noMore: "沒辦法再添加選項了" |   noMore: "沒辦法再添加選項了" | ||||||
|  |   canMultipleVote: "可以多次投票" | ||||||
|   expiration: "期限" |   expiration: "期限" | ||||||
|   infinite: "無期限" |   infinite: "無期限" | ||||||
|   at: "結束時間" |   at: "結束時間" | ||||||
| @@ -1012,6 +1093,8 @@ _profile: | |||||||
|   metadataEdit: "編輯進階資訊" |   metadataEdit: "編輯進階資訊" | ||||||
|   metadataLabel: "標籤" |   metadataLabel: "標籤" | ||||||
|   metadataContent: "内容" |   metadataContent: "内容" | ||||||
|  |   changeAvatar: "更換大頭貼" | ||||||
|  |   changeBanner: "變更橫幅圖像" | ||||||
| _exportOrImport: | _exportOrImport: | ||||||
|   allNotes: "所有貼文" |   allNotes: "所有貼文" | ||||||
|   followingList: "追隨中" |   followingList: "追隨中" | ||||||
| @@ -1395,7 +1478,7 @@ _notification: | |||||||
|     reply: "回覆" |     reply: "回覆" | ||||||
|     renote: "轉發貼文" |     renote: "轉發貼文" | ||||||
|     quote: "引用" |     quote: "引用" | ||||||
|     reaction: "情感" |     reaction: "反應" | ||||||
|     pollVote: "統計已投票數" |     pollVote: "統計已投票數" | ||||||
|     receiveFollowRequest: "已收到追隨請求" |     receiveFollowRequest: "已收到追隨請求" | ||||||
|     followRequestAccepted: "追隨請求已接受" |     followRequestAccepted: "追隨請求已接受" | ||||||
|   | |||||||
| @@ -4,8 +4,8 @@ export class AddSomeUrls1557761316509 implements MigrationInterface { | |||||||
|  |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |     public async up(queryRunner: QueryRunner): Promise<any> { | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "ToSUrl" character varying(512)`); |         await queryRunner.query(`ALTER TABLE "meta" ADD "ToSUrl" character varying(512)`); | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "repositoryUrl" character varying(512) NOT NULL DEFAULT 'https://github.com/syuilo/misskey'`); |         await queryRunner.query(`ALTER TABLE "meta" ADD "repositoryUrl" character varying(512) NOT NULL DEFAULT 'https://github.com/misskey-dev/misskey'`); | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "feedbackUrl" character varying(512) DEFAULT 'https://github.com/syuilo/misskey/issues/new'`); |         await queryRunner.query(`ALTER TABLE "meta" ADD "feedbackUrl" character varying(512) DEFAULT 'https://github.com/misskey-dev/misskey/issues/new'`); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |     public async down(queryRunner: QueryRunner): Promise<any> { | ||||||
|   | |||||||
							
								
								
									
										40
									
								
								migration/1611397665007-gallery.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								migration/1611397665007-gallery.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,40 @@ | |||||||
|  | import {MigrationInterface, QueryRunner} from "typeorm"; | ||||||
|  |  | ||||||
|  | export class gallery1611397665007 implements MigrationInterface { | ||||||
|  |     name = 'gallery1611397665007' | ||||||
|  |  | ||||||
|  |     public async up(queryRunner: QueryRunner): Promise<void> { | ||||||
|  |         await queryRunner.query(`CREATE TABLE "gallery_post" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "updatedAt" TIMESTAMP WITH TIME ZONE NOT NULL, "title" character varying(256) NOT NULL, "description" character varying(2048), "userId" character varying(32) NOT NULL, "fileIds" character varying(32) array NOT NULL DEFAULT '{}'::varchar[], "isSensitive" boolean NOT NULL DEFAULT false, "likedCount" integer NOT NULL DEFAULT '0', "tags" character varying(128) array NOT NULL DEFAULT '{}'::varchar[], CONSTRAINT "PK_8e90d7b6015f2c4518881b14753" PRIMARY KEY ("id")); COMMENT ON COLUMN "gallery_post"."createdAt" IS 'The created date of the GalleryPost.'; COMMENT ON COLUMN "gallery_post"."updatedAt" IS 'The updated date of the GalleryPost.'; COMMENT ON COLUMN "gallery_post"."userId" IS 'The ID of author.'; COMMENT ON COLUMN "gallery_post"."isSensitive" IS 'Whether the post is sensitive.'`); | ||||||
|  |         await queryRunner.query(`CREATE INDEX "IDX_8f1a239bd077c8864a20c62c2c" ON "gallery_post" ("createdAt") `); | ||||||
|  |         await queryRunner.query(`CREATE INDEX "IDX_f631d37835adb04792e361807c" ON "gallery_post" ("updatedAt") `); | ||||||
|  |         await queryRunner.query(`CREATE INDEX "IDX_985b836dddd8615e432d7043dd" ON "gallery_post" ("userId") `); | ||||||
|  |         await queryRunner.query(`CREATE INDEX "IDX_3ca50563facd913c425e7a89ee" ON "gallery_post" ("fileIds") `); | ||||||
|  |         await queryRunner.query(`CREATE INDEX "IDX_f2d744d9a14d0dfb8b96cb7fc5" ON "gallery_post" ("isSensitive") `); | ||||||
|  |         await queryRunner.query(`CREATE INDEX "IDX_1a165c68a49d08f11caffbd206" ON "gallery_post" ("likedCount") `); | ||||||
|  |         await queryRunner.query(`CREATE INDEX "IDX_05cca34b985d1b8edc1d1e28df" ON "gallery_post" ("tags") `); | ||||||
|  |         await queryRunner.query(`CREATE TABLE "gallery_like" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "userId" character varying(32) NOT NULL, "postId" character varying(32) NOT NULL, CONSTRAINT "PK_853ab02be39b8de45cd720cc15f" PRIMARY KEY ("id"))`); | ||||||
|  |         await queryRunner.query(`CREATE INDEX "IDX_8fd5215095473061855ceb948c" ON "gallery_like" ("userId") `); | ||||||
|  |         await queryRunner.query(`CREATE UNIQUE INDEX "IDX_df1b5f4099e99fb0bc5eae53b6" ON "gallery_like" ("userId", "postId") `); | ||||||
|  |         await queryRunner.query(`ALTER TABLE "gallery_post" ADD CONSTRAINT "FK_985b836dddd8615e432d7043ddb" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`); | ||||||
|  |         await queryRunner.query(`ALTER TABLE "gallery_like" ADD CONSTRAINT "FK_8fd5215095473061855ceb948cf" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`); | ||||||
|  |         await queryRunner.query(`ALTER TABLE "gallery_like" ADD CONSTRAINT "FK_b1cb568bfe569e47b7051699fc8" FOREIGN KEY ("postId") REFERENCES "gallery_post"("id") ON DELETE CASCADE ON UPDATE NO ACTION`); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public async down(queryRunner: QueryRunner): Promise<void> { | ||||||
|  |         await queryRunner.query(`ALTER TABLE "gallery_like" DROP CONSTRAINT "FK_b1cb568bfe569e47b7051699fc8"`); | ||||||
|  |         await queryRunner.query(`ALTER TABLE "gallery_like" DROP CONSTRAINT "FK_8fd5215095473061855ceb948cf"`); | ||||||
|  |         await queryRunner.query(`ALTER TABLE "gallery_post" DROP CONSTRAINT "FK_985b836dddd8615e432d7043ddb"`); | ||||||
|  |         await queryRunner.query(`DROP INDEX "IDX_df1b5f4099e99fb0bc5eae53b6"`); | ||||||
|  |         await queryRunner.query(`DROP INDEX "IDX_8fd5215095473061855ceb948c"`); | ||||||
|  |         await queryRunner.query(`DROP TABLE "gallery_like"`); | ||||||
|  |         await queryRunner.query(`DROP INDEX "IDX_05cca34b985d1b8edc1d1e28df"`); | ||||||
|  |         await queryRunner.query(`DROP INDEX "IDX_1a165c68a49d08f11caffbd206"`); | ||||||
|  |         await queryRunner.query(`DROP INDEX "IDX_f2d744d9a14d0dfb8b96cb7fc5"`); | ||||||
|  |         await queryRunner.query(`DROP INDEX "IDX_3ca50563facd913c425e7a89ee"`); | ||||||
|  |         await queryRunner.query(`DROP INDEX "IDX_985b836dddd8615e432d7043dd"`); | ||||||
|  |         await queryRunner.query(`DROP INDEX "IDX_f631d37835adb04792e361807c"`); | ||||||
|  |         await queryRunner.query(`DROP INDEX "IDX_8f1a239bd077c8864a20c62c2c"`); | ||||||
|  |         await queryRunner.query(`DROP TABLE "gallery_post"`); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										218
									
								
								migration/1615965918224-chart-v2.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										218
									
								
								migration/1615965918224-chart-v2.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,218 @@ | |||||||
|  | import {MigrationInterface, QueryRunner} from "typeorm"; | ||||||
|  |  | ||||||
|  | export class chartV21615965918224 implements MigrationInterface { | ||||||
|  | 	name = 'chartV21615965918224' | ||||||
|  |  | ||||||
|  | 	public async up(queryRunner: QueryRunner): Promise<void> { | ||||||
|  | 		await queryRunner.query(`DELETE FROM "__chart__active_users" WHERE "span" = 'day'`); | ||||||
|  | 		await queryRunner.query(`DELETE FROM "__chart__drive" WHERE "span" = 'day'`); | ||||||
|  | 		await queryRunner.query(`DELETE FROM "__chart__federation" WHERE "span" = 'day'`); | ||||||
|  | 		await queryRunner.query(`DELETE FROM "__chart__hashtag" WHERE "span" = 'day'`); | ||||||
|  | 		await queryRunner.query(`DELETE FROM "__chart__instance" WHERE "span" = 'day'`); | ||||||
|  | 		await queryRunner.query(`DELETE FROM "__chart__network" WHERE "span" = 'day'`); | ||||||
|  | 		await queryRunner.query(`DELETE FROM "__chart__notes" WHERE "span" = 'day'`); | ||||||
|  | 		await queryRunner.query(`DELETE FROM "__chart__per_user_drive" WHERE "span" = 'day'`); | ||||||
|  | 		await queryRunner.query(`DELETE FROM "__chart__per_user_following" WHERE "span" = 'day'`); | ||||||
|  | 		await queryRunner.query(`DELETE FROM "__chart__per_user_notes" WHERE "span" = 'day'`); | ||||||
|  | 		await queryRunner.query(`DELETE FROM "__chart__per_user_reaction" WHERE "span" = 'day'`); | ||||||
|  | 		await queryRunner.query(`DELETE FROM "__chart__test" WHERE "span" = 'day'`); | ||||||
|  | 		await queryRunner.query(`DELETE FROM "__chart__test_grouped" WHERE "span" = 'day'`); | ||||||
|  | 		await queryRunner.query(`DELETE FROM "__chart__test_unique" WHERE "span" = 'day'`); | ||||||
|  | 		await queryRunner.query(`DELETE FROM "__chart__users" WHERE "span" = 'day'`); | ||||||
|  |  | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_15e91a03aeeac9dbccdf43fc06"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_20f57cc8f142c131340ee16742"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_c26e2c1cbb6e911e0554b27416"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_3fa0d0f17ca72e3dc80999a032"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_6e1df243476e20cbf86572ecc0"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_06690fc959f1c9fdaf21928222"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_e447064455928cf627590ef527"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_2d416e6af791a82e338c79d480"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_e9cd07672b37d8966cf3709283"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_fcc181fb8283009c61cc4083ef"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_49975586f50ed7b800fdd88fbd"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_6d6f156ceefc6bc5f273a0e370"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_c12f0af4a66cdd30c2287ce8aa"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_d0a4f79af5a97b08f37b547197"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_f5448d9633cff74208d850aabe"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_f8dd01baeded2ffa833e0a610a"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_08fac0eb3b11f04c200c0b40dd"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_9ff6944f01acb756fdc92d7563"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_e69096589f11e3baa98ddd64d0"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_0c9a159c5082cbeef3ca6706b5"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_924fc196c80ca24bae01dd37e4"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_328f259961e60c4fa0bfcf55ca"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_42ea9381f0fda8dfe0fa1c8b53"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_f2aeafde2ae6fbad38e857631b"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_f92dd6d03f8d994f29987f6214"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_57b5458d0d3d6d1e7f13d4e57f"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_4db3b84c7be0d3464714f3e0b1"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_8d2cbbc8114d90d19b44d626b6"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_046feeb12e9ef5f783f409866a"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_f68a5ab958f9f5fa17a32ac23b"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_65633a106bce43fc7c5c30a5c7"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_edeb73c09c3143a81bcb34d569"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_e316f01a6d24eb31db27f88262"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_2be7ec6cebddc14dc11e206686"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_a5133470f4825902e170328ca5"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_84e661abb7bd1e51b690d4b017"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_5c73bf61da4f6e6f15bae88ed1"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_d70c86baedc68326be11f9c0ce"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_66e1e1ecd2f29e57778af35b59"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_92255988735563f0fe4aba1f05"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_c5870993e25c3d5771f91f5003"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_f170de677ea75ad4533de2723e"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_7c184198ecf66a8d3ecb253ab3"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_f091abb24193d50c653c6b77fc"`); | ||||||
|  | 		await queryRunner.query(`DROP INDEX "IDX_a770a57c70e668cc61590c9161"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__active_users" DROP COLUMN "span"`); | ||||||
|  | 		await queryRunner.query(`DROP TYPE "public"."__chart__active_users_span_enum"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__active_users" DROP COLUMN "unique"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__active_users" DROP COLUMN "___local_count"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__active_users" DROP COLUMN "___remote_count"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__drive" DROP COLUMN "span"`); | ||||||
|  | 		await queryRunner.query(`DROP TYPE "public"."__chart__drive_span_enum"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__drive" DROP COLUMN "unique"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__federation" DROP COLUMN "span"`); | ||||||
|  | 		await queryRunner.query(`DROP TYPE "public"."__chart__federation_span_enum"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__federation" DROP COLUMN "unique"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__hashtag" DROP COLUMN "span"`); | ||||||
|  | 		await queryRunner.query(`DROP TYPE "public"."__chart__hashtag_span_enum"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__hashtag" DROP COLUMN "unique"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__hashtag" DROP COLUMN "___local_count"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__hashtag" DROP COLUMN "___remote_count"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__instance" DROP COLUMN "span"`); | ||||||
|  | 		await queryRunner.query(`DROP TYPE "public"."__chart__instance_span_enum"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__instance" DROP COLUMN "unique"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__network" DROP COLUMN "span"`); | ||||||
|  | 		await queryRunner.query(`DROP TYPE "public"."__chart__network_span_enum"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__network" DROP COLUMN "unique"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__notes" DROP COLUMN "span"`); | ||||||
|  | 		await queryRunner.query(`DROP TYPE "public"."__chart__notes_span_enum"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__notes" DROP COLUMN "unique"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__per_user_drive" DROP COLUMN "span"`); | ||||||
|  | 		await queryRunner.query(`DROP TYPE "public"."__chart__per_user_drive_span_enum"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__per_user_drive" DROP COLUMN "unique"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__per_user_following" DROP COLUMN "span"`); | ||||||
|  | 		await queryRunner.query(`DROP TYPE "public"."__chart__per_user_following_span_enum"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__per_user_following" DROP COLUMN "unique"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__per_user_notes" DROP COLUMN "span"`); | ||||||
|  | 		await queryRunner.query(`DROP TYPE "public"."__chart__per_user_notes_span_enum"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__per_user_notes" DROP COLUMN "unique"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__per_user_reaction" DROP COLUMN "span"`); | ||||||
|  | 		await queryRunner.query(`DROP TYPE "public"."__chart__per_user_reaction_span_enum"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__per_user_reaction" DROP COLUMN "unique"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__test_grouped" DROP COLUMN "span"`); | ||||||
|  | 		await queryRunner.query(`DROP TYPE "public"."__chart__test_grouped_span_enum"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__test_grouped" DROP COLUMN "unique"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__test_unique" DROP COLUMN "span"`); | ||||||
|  | 		await queryRunner.query(`DROP TYPE "public"."__chart__test_unique_span_enum"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__test_unique" DROP COLUMN "unique"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__test_unique" DROP COLUMN "___foo"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__test" DROP COLUMN "span"`); | ||||||
|  | 		await queryRunner.query(`DROP TYPE "public"."__chart__test_span_enum"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__test" DROP COLUMN "unique"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__users" DROP COLUMN "span"`); | ||||||
|  | 		await queryRunner.query(`DROP TYPE "public"."__chart__users_span_enum"`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__users" DROP COLUMN "unique"`); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	public async down(queryRunner: QueryRunner): Promise<void> { | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__users" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); | ||||||
|  | 		await queryRunner.query(`CREATE TYPE "public"."__chart__users_span_enum" AS ENUM('hour', 'day')`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__users" ADD "span" "__chart__users_span_enum" NOT NULL`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__test" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); | ||||||
|  | 		await queryRunner.query(`CREATE TYPE "public"."__chart__test_span_enum" AS ENUM('hour', 'day')`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__test" ADD "span" "__chart__test_span_enum" NOT NULL`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__test_unique" ADD "___foo" bigint NOT NULL`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__test_unique" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); | ||||||
|  | 		await queryRunner.query(`CREATE TYPE "public"."__chart__test_unique_span_enum" AS ENUM('hour', 'day')`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__test_unique" ADD "span" "__chart__test_unique_span_enum" NOT NULL`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__test_grouped" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); | ||||||
|  | 		await queryRunner.query(`CREATE TYPE "public"."__chart__test_grouped_span_enum" AS ENUM('hour', 'day')`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__test_grouped" ADD "span" "__chart__test_grouped_span_enum" NOT NULL`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__per_user_reaction" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); | ||||||
|  | 		await queryRunner.query(`CREATE TYPE "public"."__chart__per_user_reaction_span_enum" AS ENUM('hour', 'day')`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__per_user_reaction" ADD "span" "__chart__per_user_reaction_span_enum" NOT NULL`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__per_user_notes" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); | ||||||
|  | 		await queryRunner.query(`CREATE TYPE "public"."__chart__per_user_notes_span_enum" AS ENUM('hour', 'day')`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__per_user_notes" ADD "span" "__chart__per_user_notes_span_enum" NOT NULL`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__per_user_following" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); | ||||||
|  | 		await queryRunner.query(`CREATE TYPE "public"."__chart__per_user_following_span_enum" AS ENUM('hour', 'day')`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__per_user_following" ADD "span" "__chart__per_user_following_span_enum" NOT NULL`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__per_user_drive" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); | ||||||
|  | 		await queryRunner.query(`CREATE TYPE "public"."__chart__per_user_drive_span_enum" AS ENUM('hour', 'day')`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__per_user_drive" ADD "span" "__chart__per_user_drive_span_enum" NOT NULL`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__notes" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); | ||||||
|  | 		await queryRunner.query(`CREATE TYPE "public"."__chart__notes_span_enum" AS ENUM('hour', 'day')`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__notes" ADD "span" "__chart__notes_span_enum" NOT NULL`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__network" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); | ||||||
|  | 		await queryRunner.query(`CREATE TYPE "public"."__chart__network_span_enum" AS ENUM('hour', 'day')`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__network" ADD "span" "__chart__network_span_enum" NOT NULL`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__instance" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); | ||||||
|  | 		await queryRunner.query(`CREATE TYPE "public"."__chart__instance_span_enum" AS ENUM('hour', 'day')`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__instance" ADD "span" "__chart__instance_span_enum" NOT NULL`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__hashtag" ADD "___remote_count" bigint NOT NULL`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__hashtag" ADD "___local_count" bigint NOT NULL`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__hashtag" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); | ||||||
|  | 		await queryRunner.query(`CREATE TYPE "public"."__chart__hashtag_span_enum" AS ENUM('hour', 'day')`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__hashtag" ADD "span" "__chart__hashtag_span_enum" NOT NULL`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__federation" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); | ||||||
|  | 		await queryRunner.query(`CREATE TYPE "public"."__chart__federation_span_enum" AS ENUM('hour', 'day')`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__federation" ADD "span" "__chart__federation_span_enum" NOT NULL`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__drive" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); | ||||||
|  | 		await queryRunner.query(`CREATE TYPE "public"."__chart__drive_span_enum" AS ENUM('hour', 'day')`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__drive" ADD "span" "__chart__drive_span_enum" NOT NULL`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__active_users" ADD "___remote_count" bigint NOT NULL`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__active_users" ADD "___local_count" bigint NOT NULL`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__active_users" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); | ||||||
|  | 		await queryRunner.query(`CREATE TYPE "public"."__chart__active_users_span_enum" AS ENUM('hour', 'day')`); | ||||||
|  | 		await queryRunner.query(`ALTER TABLE "__chart__active_users" ADD "span" "__chart__active_users_span_enum" NOT NULL`); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_a770a57c70e668cc61590c9161" ON "__chart__users" ("date", "group", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_f091abb24193d50c653c6b77fc" ON "__chart__users" ("date", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_7c184198ecf66a8d3ecb253ab3" ON "__chart__users" ("span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_f170de677ea75ad4533de2723e" ON "__chart__test" ("date", "group", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_c5870993e25c3d5771f91f5003" ON "__chart__test" ("date", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_92255988735563f0fe4aba1f05" ON "__chart__test" ("span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_66e1e1ecd2f29e57778af35b59" ON "__chart__test_unique" ("date", "group", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_d70c86baedc68326be11f9c0ce" ON "__chart__test_unique" ("date", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_5c73bf61da4f6e6f15bae88ed1" ON "__chart__test_unique" ("span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_84e661abb7bd1e51b690d4b017" ON "__chart__test_grouped" ("date", "group", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_a5133470f4825902e170328ca5" ON "__chart__test_grouped" ("date", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_2be7ec6cebddc14dc11e206686" ON "__chart__test_grouped" ("span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_e316f01a6d24eb31db27f88262" ON "__chart__per_user_reaction" ("date", "group", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_edeb73c09c3143a81bcb34d569" ON "__chart__per_user_reaction" ("date", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_65633a106bce43fc7c5c30a5c7" ON "__chart__per_user_reaction" ("span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_f68a5ab958f9f5fa17a32ac23b" ON "__chart__per_user_notes" ("date", "group", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_046feeb12e9ef5f783f409866a" ON "__chart__per_user_notes" ("date", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_8d2cbbc8114d90d19b44d626b6" ON "__chart__per_user_notes" ("span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_4db3b84c7be0d3464714f3e0b1" ON "__chart__per_user_following" ("date", "group", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_57b5458d0d3d6d1e7f13d4e57f" ON "__chart__per_user_following" ("date", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_f92dd6d03f8d994f29987f6214" ON "__chart__per_user_following" ("span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_f2aeafde2ae6fbad38e857631b" ON "__chart__per_user_drive" ("date", "group", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_42ea9381f0fda8dfe0fa1c8b53" ON "__chart__per_user_drive" ("date", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_328f259961e60c4fa0bfcf55ca" ON "__chart__per_user_drive" ("span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_924fc196c80ca24bae01dd37e4" ON "__chart__notes" ("date", "group", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_0c9a159c5082cbeef3ca6706b5" ON "__chart__notes" ("date", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_e69096589f11e3baa98ddd64d0" ON "__chart__notes" ("span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_9ff6944f01acb756fdc92d7563" ON "__chart__network" ("date", "group", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_08fac0eb3b11f04c200c0b40dd" ON "__chart__network" ("date", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_f8dd01baeded2ffa833e0a610a" ON "__chart__network" ("span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_f5448d9633cff74208d850aabe" ON "__chart__instance" ("date", "group", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_d0a4f79af5a97b08f37b547197" ON "__chart__instance" ("date", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_c12f0af4a66cdd30c2287ce8aa" ON "__chart__instance" ("span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_6d6f156ceefc6bc5f273a0e370" ON "__chart__hashtag" ("date", "group", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_49975586f50ed7b800fdd88fbd" ON "__chart__hashtag" ("date", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_fcc181fb8283009c61cc4083ef" ON "__chart__hashtag" ("span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_e9cd07672b37d8966cf3709283" ON "__chart__federation" ("date", "group", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_2d416e6af791a82e338c79d480" ON "__chart__federation" ("date", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_e447064455928cf627590ef527" ON "__chart__federation" ("span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_06690fc959f1c9fdaf21928222" ON "__chart__drive" ("date", "group", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_6e1df243476e20cbf86572ecc0" ON "__chart__drive" ("date", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_3fa0d0f17ca72e3dc80999a032" ON "__chart__drive" ("span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_c26e2c1cbb6e911e0554b27416" ON "__chart__active_users" ("date", "group", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_20f57cc8f142c131340ee16742" ON "__chart__active_users" ("date", "span") `); | ||||||
|  | 		await queryRunner.query(`CREATE INDEX "IDX_15e91a03aeeac9dbccdf43fc06" ON "__chart__active_users" ("span") `); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										22
									
								
								migration/1615966519402-chart-v2-2.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								migration/1615966519402-chart-v2-2.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | |||||||
|  | import {MigrationInterface, QueryRunner} from "typeorm"; | ||||||
|  |  | ||||||
|  | export class chartV221615966519402 implements MigrationInterface { | ||||||
|  |     name = 'chartV221615966519402' | ||||||
|  |  | ||||||
|  |     public async up(queryRunner: QueryRunner): Promise<void> { | ||||||
|  |         await queryRunner.query(`ALTER TABLE "__chart__active_users" ADD "___local_users" character varying array NOT NULL DEFAULT '{}'::varchar[]`); | ||||||
|  |         await queryRunner.query(`ALTER TABLE "__chart__active_users" ADD "___remote_users" character varying array NOT NULL DEFAULT '{}'::varchar[]`); | ||||||
|  |         await queryRunner.query(`ALTER TABLE "__chart__hashtag" ADD "___local_users" character varying array NOT NULL DEFAULT '{}'::varchar[]`); | ||||||
|  |         await queryRunner.query(`ALTER TABLE "__chart__hashtag" ADD "___remote_users" character varying array NOT NULL DEFAULT '{}'::varchar[]`); | ||||||
|  |         await queryRunner.query(`ALTER TABLE "__chart__test_unique" ADD "___foo" character varying array NOT NULL DEFAULT '{}'::varchar[]`); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public async down(queryRunner: QueryRunner): Promise<void> { | ||||||
|  |         await queryRunner.query(`ALTER TABLE "__chart__test_unique" DROP COLUMN "___foo"`); | ||||||
|  |         await queryRunner.query(`ALTER TABLE "__chart__hashtag" DROP COLUMN "___remote_users"`); | ||||||
|  |         await queryRunner.query(`ALTER TABLE "__chart__hashtag" DROP COLUMN "___local_users"`); | ||||||
|  |         await queryRunner.query(`ALTER TABLE "__chart__active_users" DROP COLUMN "___remote_users"`); | ||||||
|  |         await queryRunner.query(`ALTER TABLE "__chart__active_users" DROP COLUMN "___local_users"`); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										16
									
								
								migration/1618637372000-user-last-active-date.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								migration/1618637372000-user-last-active-date.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | import {MigrationInterface, QueryRunner} from "typeorm"; | ||||||
|  |  | ||||||
|  | export class userLastActiveDate1618637372000 implements MigrationInterface { | ||||||
|  |     name = 'userLastActiveDate1618637372000' | ||||||
|  |  | ||||||
|  |     public async up(queryRunner: QueryRunner): Promise<void> { | ||||||
|  |         await queryRunner.query(`ALTER TABLE "user" ADD "lastActiveDate" TIMESTAMP WITH TIME ZONE DEFAULT NULL`); | ||||||
|  |         await queryRunner.query(`CREATE INDEX "IDX_seoignmeoprigmkpodgrjmkpormg" ON "user" ("lastActiveDate") `); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public async down(queryRunner: QueryRunner): Promise<void> { | ||||||
|  |         await queryRunner.query(`DROP INDEX "IDX_seoignmeoprigmkpodgrjmkpormg"`); | ||||||
|  |         await queryRunner.query(`ALTER TABLE "user" DROP COLUMN "lastActiveDate"`); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										14
									
								
								migration/1618639857000-user-hide-online-status.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								migration/1618639857000-user-hide-online-status.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | import {MigrationInterface, QueryRunner} from "typeorm"; | ||||||
|  |  | ||||||
|  | export class userHideOnlineStatus1618639857000 implements MigrationInterface { | ||||||
|  |     name = 'userHideOnlineStatus1618639857000' | ||||||
|  |  | ||||||
|  |     public async up(queryRunner: QueryRunner): Promise<void> { | ||||||
|  | 			await queryRunner.query(`ALTER TABLE "user" ADD "hideOnlineStatus" boolean NOT NULL DEFAULT false`); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public async down(queryRunner: QueryRunner): Promise<void> { | ||||||
|  |         await queryRunner.query(`ALTER TABLE "user" DROP COLUMN "hideOnlineStatus"`); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										20
									
								
								migration/1619942102890-password-reset.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								migration/1619942102890-password-reset.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | |||||||
|  | import {MigrationInterface, QueryRunner} from "typeorm"; | ||||||
|  |  | ||||||
|  | export class passwordReset1619942102890 implements MigrationInterface { | ||||||
|  |     name = 'passwordReset1619942102890' | ||||||
|  |  | ||||||
|  |     public async up(queryRunner: QueryRunner): Promise<void> { | ||||||
|  |         await queryRunner.query(`CREATE TABLE "password_reset_request" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "token" character varying(256) NOT NULL, "userId" character varying(32) NOT NULL, CONSTRAINT "PK_fcf4b02eae1403a2edaf87fd074" PRIMARY KEY ("id"))`); | ||||||
|  |         await queryRunner.query(`CREATE UNIQUE INDEX "IDX_0b575fa9a4cfe638a925949285" ON "password_reset_request" ("token") `); | ||||||
|  |         await queryRunner.query(`CREATE INDEX "IDX_4bb7fd4a34492ae0e6cc8d30ac" ON "password_reset_request" ("userId") `); | ||||||
|  |         await queryRunner.query(`ALTER TABLE "password_reset_request" ADD CONSTRAINT "FK_4bb7fd4a34492ae0e6cc8d30ac8" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public async down(queryRunner: QueryRunner): Promise<void> { | ||||||
|  |         await queryRunner.query(`ALTER TABLE "password_reset_request" DROP CONSTRAINT "FK_4bb7fd4a34492ae0e6cc8d30ac8"`); | ||||||
|  |         await queryRunner.query(`DROP INDEX "IDX_4bb7fd4a34492ae0e6cc8d30ac"`); | ||||||
|  |         await queryRunner.query(`DROP INDEX "IDX_0b575fa9a4cfe638a925949285"`); | ||||||
|  |         await queryRunner.query(`DROP TABLE "password_reset_request"`); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										18
									
								
								migration/1620019354680-ad.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								migration/1620019354680-ad.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | |||||||
|  | import {MigrationInterface, QueryRunner} from "typeorm"; | ||||||
|  |  | ||||||
|  | export class ad1620019354680 implements MigrationInterface { | ||||||
|  |     name = 'ad1620019354680' | ||||||
|  |  | ||||||
|  |     public async up(queryRunner: QueryRunner): Promise<void> { | ||||||
|  |         await queryRunner.query(`CREATE TABLE "ad" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "expiresAt" TIMESTAMP WITH TIME ZONE NOT NULL, "place" character varying(32) NOT NULL, "priority" character varying(32) NOT NULL, "url" character varying(1024) NOT NULL, "imageUrl" character varying(1024) NOT NULL, "memo" character varying(8192) NOT NULL, CONSTRAINT "PK_0193d5ef09746e88e9ea92c634d" PRIMARY KEY ("id")); COMMENT ON COLUMN "ad"."createdAt" IS 'The created date of the Ad.'; COMMENT ON COLUMN "ad"."expiresAt" IS 'The expired date of the Ad.'`); | ||||||
|  |         await queryRunner.query(`CREATE INDEX "IDX_1129c2ef687fc272df040bafaa" ON "ad" ("createdAt") `); | ||||||
|  |         await queryRunner.query(`CREATE INDEX "IDX_2da24ce20ad209f1d9dc032457" ON "ad" ("expiresAt") `); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public async down(queryRunner: QueryRunner): Promise<void> { | ||||||
|  |         await queryRunner.query(`DROP INDEX "IDX_2da24ce20ad209f1d9dc032457"`); | ||||||
|  |         await queryRunner.query(`DROP INDEX "IDX_1129c2ef687fc272df040bafaa"`); | ||||||
|  |         await queryRunner.query(`DROP TABLE "ad"`); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										14
									
								
								migration/1620364649428-ad2.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								migration/1620364649428-ad2.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | import {MigrationInterface, QueryRunner} from "typeorm"; | ||||||
|  |  | ||||||
|  | export class ad21620364649428 implements MigrationInterface { | ||||||
|  |     name = 'ad21620364649428' | ||||||
|  |  | ||||||
|  |     public async up(queryRunner: QueryRunner): Promise<void> { | ||||||
|  |         await queryRunner.query(`ALTER TABLE "ad" ADD "ratio" integer NOT NULL DEFAULT '1'`); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public async down(queryRunner: QueryRunner): Promise<void> { | ||||||
|  |         await queryRunner.query(`ALTER TABLE "ad" DROP COLUMN "ratio"`); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										16
									
								
								migration/1621479946000-add-note-indexes.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								migration/1621479946000-add-note-indexes.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | import {MigrationInterface, QueryRunner} from "typeorm"; | ||||||
|  |  | ||||||
|  | export class addNoteIndexes1621479946000 implements MigrationInterface { | ||||||
|  |     name = 'addNoteIndexes1621479946000' | ||||||
|  |  | ||||||
|  |     public async up(queryRunner: QueryRunner): Promise<void> { | ||||||
|  |         await queryRunner.query(`CREATE INDEX "IDX_NOTE_MENTIONS" ON "note" USING gin ("mentions")`, undefined); | ||||||
|  | 				await queryRunner.query(`CREATE INDEX "IDX_NOTE_VISIBLE_USER_IDS" ON "note" USING gin ("visibleUserIds")`, undefined); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public async down(queryRunner: QueryRunner): Promise<void> { | ||||||
|  |         await queryRunner.query(`DROP INDEX "IDX_NOTE_MENTIONS"`, undefined); | ||||||
|  | 				await queryRunner.query(`DROP INDEX "IDX_NOTE_VISIBLE_USER_IDS"`, undefined); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										200
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										200
									
								
								package.json
									
									
									
									
									
								
							| @@ -1,101 +1,97 @@ | |||||||
| { | { | ||||||
| 	"name": "misskey", | 	"name": "misskey", | ||||||
| 	"author": "syuilo <syuilotan@yahoo.co.jp>", | 	"author": "syuilo <syuilotan@yahoo.co.jp>", | ||||||
| 	"version": "12.74.1", | 	"version": "12.82.0", | ||||||
| 	"codename": "indigo", | 	"codename": "indigo", | ||||||
| 	"repository": { | 	"repository": { | ||||||
| 		"type": "git", | 		"type": "git", | ||||||
| 		"url": "https://github.com/syuilo/misskey.git" | 		"url": "https://github.com/misskey-dev/misskey.git" | ||||||
| 	}, | 	}, | ||||||
| 	"main": "./index.js", | 	"main": "./index.js", | ||||||
| 	"private": true, | 	"private": true, | ||||||
| 	"scripts": { | 	"scripts": { | ||||||
| 		"start": "node ./index.js", | 		"start": "node ./index.js", | ||||||
| 		"start-product": "cross-env NODE_ENV=production node ./index.js", |  | ||||||
| 		"init": "npm run migrate", | 		"init": "npm run migrate", | ||||||
| 		"ormconfig": "node ./built/ormconfig.js", | 		"ormconfig": "node ./built/ormconfig.js", | ||||||
| 		"migrate": "ts-node ./node_modules/typeorm/cli.js migration:run", | 		"migrate": "ts-node ./node_modules/typeorm/cli.js migration:run", | ||||||
| 		"migrateandstart": "npm run migrate && npm run start", | 		"migrateandstart": "npm run migrate && npm run start", | ||||||
| 		"build": "webpack && gulp build", | 		"build": "npm run build-webpack && npm run build-ts && npm run build-gulp", | ||||||
| 		"build-product": "cross-env NODE_ENV=production webpack && gulp build", | 		"build-webpack": "webpack", | ||||||
| 		"webpack": "webpack", | 		"build-ts": "tsc -p src/tsconfig.json || echo done. && tsc-alias -p src/tsconfig.json", | ||||||
| 		"watch": "webpack --watch", | 		"build-gulp": "gulp build", | ||||||
| 		"gulp": "gulp build", | 		"watch": "concurrently \"npm:watch-*\"", | ||||||
|  | 		"watch-webpack": "webpack --watch", | ||||||
|  | 		"watch-ts": "tsc -w -p src/tsconfig.json && tsc-alias -w -p src/tsconfig.json", | ||||||
|  | 		"watch-gulp": "gulp watch", | ||||||
| 		"clean": "gulp clean", | 		"clean": "gulp clean", | ||||||
| 		"cleanall": "gulp cleanall", | 		"cleanall": "gulp cleanall", | ||||||
| 		"lint": "tslint 'src/**/*.ts'", | 		"lint": "tslint 'src/**/*.ts'", | ||||||
| 		"test": "cross-env TS_NODE_FILES=true TS_NODE_TRANSPILE_ONLY=true TS_NODE_COMPILER_OPTIONS=\"{\\\"target\\\":\\\"es2017\\\",\\\"module\\\":\\\"commonjs\\\",\\\"typeRoots\\\":[\\\"node_modules/@types\\\",\\\"src/@types\\\"]}\" mocha", | 		"test": "cross-env TS_NODE_FILES=true TS_NODE_TRANSPILE_ONLY=true TS_NODE_PROJECT=\"./test/tsconfig.json\" mocha", | ||||||
| 		"format": "gulp format" | 		"format": "gulp format" | ||||||
| 	}, | 	}, | ||||||
| 	"resolutions": { | 	"resolutions": { | ||||||
|  | 		"mfm-js/twemoji-parser": "13.1.x", | ||||||
| 		"chokidar": "^3.3.1", | 		"chokidar": "^3.3.1", | ||||||
| 		"constantinople": "^4.0.1", | 		"constantinople": "^4.0.1", | ||||||
| 		"gulp/gulp-cli/yargs/yargs-parser": "5.0.0-security.0", |  | ||||||
| 		"jsonld/rdf-canonize/node-forge": "0.10.0", | 		"jsonld/rdf-canonize/node-forge": "0.10.0", | ||||||
| 		"lodash": "^4.17.20" | 		"lodash": "^4.17.20" | ||||||
| 	}, | 	}, | ||||||
| 	"dependencies": { | 	"dependencies": { | ||||||
| 		"@babel/plugin-transform-runtime": "7.13.9", | 		"@babel/plugin-transform-runtime": "7.14.3", | ||||||
| 		"@elastic/elasticsearch": "7.11.0", | 		"@elastic/elasticsearch": "7.11.0", | ||||||
| 		"@fortawesome/fontawesome-svg-core": "1.2.34", |  | ||||||
| 		"@fortawesome/free-brands-svg-icons": "5.15.2", |  | ||||||
| 		"@fortawesome/free-regular-svg-icons": "5.15.2", |  | ||||||
| 		"@fortawesome/free-solid-svg-icons": "5.15.2", |  | ||||||
| 		"@fortawesome/vue-fontawesome": "3.0.0-3", |  | ||||||
| 		"@koa/cors": "3.1.0", | 		"@koa/cors": "3.1.0", | ||||||
| 		"@koa/multer": "3.0.0", | 		"@koa/multer": "3.0.0", | ||||||
| 		"@koa/router": "9.0.1", | 		"@koa/router": "9.0.1", | ||||||
| 		"@sentry/browser": "5.29.2", | 		"@sentry/browser": "5.29.2", | ||||||
| 		"@sentry/tracing": "5.29.2", | 		"@sentry/tracing": "5.29.2", | ||||||
| 		"@sinonjs/fake-timers": "6.0.1", | 		"@sinonjs/fake-timers": "7.1.2", | ||||||
| 		"@syuilo/aiscript": "0.11.1", | 		"@syuilo/aiscript": "0.11.1", | ||||||
| 		"@types/bcryptjs": "2.4.2", | 		"@types/bcryptjs": "2.4.2", | ||||||
| 		"@types/bull": "3.15.0", | 		"@types/bull": "3.15.1", | ||||||
| 		"@types/cbor": "5.0.1", | 		"@types/cbor": "6.0.0", | ||||||
| 		"@types/dateformat": "3.0.1", | 		"@types/dateformat": "3.0.1", | ||||||
| 		"@types/double-ended-queue": "2.1.1", |  | ||||||
| 		"@types/escape-regexp": "0.0.0", | 		"@types/escape-regexp": "0.0.0", | ||||||
| 		"@types/glob": "7.1.3", | 		"@types/glob": "7.1.3", | ||||||
| 		"@types/gulp": "4.0.8", | 		"@types/gulp": "4.0.8", | ||||||
| 		"@types/gulp-rename": "2.0.0", | 		"@types/gulp-rename": "2.0.0", | ||||||
| 		"@types/gulp-replace": "0.0.31", | 		"@types/is-url": "1.2.29", | ||||||
| 		"@types/is-url": "1.2.28", | 		"@types/js-yaml": "4.0.1", | ||||||
| 		"@types/js-yaml": "4.0.0", | 		"@types/jsdom": "16.2.10", | ||||||
| 		"@types/jsdom": "16.2.6", | 		"@types/jsonld": "1.5.5", | ||||||
| 		"@types/jsonld": "1.5.4", |  | ||||||
| 		"@types/katex": "0.11.0", | 		"@types/katex": "0.11.0", | ||||||
| 		"@types/koa": "2.13.0", | 		"@types/koa": "2.13.3", | ||||||
| 		"@types/koa-bodyparser": "4.3.0", | 		"@types/koa-bodyparser": "4.3.0", | ||||||
| 		"@types/koa-cors": "0.0.0", | 		"@types/koa-cors": "0.0.0", | ||||||
| 		"@types/koa-favicon": "2.0.19", | 		"@types/koa-favicon": "2.0.19", | ||||||
| 		"@types/koa-logger": "3.1.1", | 		"@types/koa-logger": "3.1.1", | ||||||
| 		"@types/koa-mount": "4.0.0", | 		"@types/koa-mount": "4.0.0", | ||||||
| 		"@types/koa-send": "4.1.2", | 		"@types/koa-send": "4.1.2", | ||||||
| 		"@types/koa-views": "2.0.4", | 		"@types/koa-views": "7.0.0", | ||||||
| 		"@types/koa__cors": "3.0.2", | 		"@types/koa__cors": "3.0.2", | ||||||
| 		"@types/koa__multer": "2.0.2", | 		"@types/koa__multer": "2.0.2", | ||||||
| 		"@types/koa__router": "8.0.4", | 		"@types/koa__router": "8.0.4", | ||||||
| 		"@types/markdown-it": "12.0.1", | 		"@types/markdown-it": "12.0.1", | ||||||
| 		"@types/matter-js": "0.14.10", | 		"@types/matter-js": "0.14.12", | ||||||
| 		"@types/mocha": "8.2.1", | 		"@types/mocha": "8.2.2", | ||||||
| 		"@types/node": "14.14.31", | 		"@types/node": "15.6.1", | ||||||
| 		"@types/node-fetch": "2.5.8", | 		"@types/node-fetch": "2.5.10", | ||||||
| 		"@types/nodemailer": "6.4.0", | 		"@types/nodemailer": "6.4.2", | ||||||
| 		"@types/nprogress": "0.2.0", | 		"@types/nprogress": "0.2.0", | ||||||
| 		"@types/oauth": "0.9.1", | 		"@types/oauth": "0.9.1", | ||||||
| 		"@types/parse5": "6.0.0", | 		"@types/parse5": "6.0.0", | ||||||
| 		"@types/parsimmon": "1.10.6", | 		"@types/parsimmon": "1.10.6", | ||||||
| 		"@types/portscanner": "2.1.0", | 		"@types/portscanner": "2.1.0", | ||||||
| 		"@types/pug": "2.0.4", | 		"@types/pug": "2.0.4", | ||||||
|  | 		"@types/punycode": "2.1.0", | ||||||
| 		"@types/qrcode": "1.4.0", | 		"@types/qrcode": "1.4.0", | ||||||
| 		"@types/random-seed": "0.3.3", | 		"@types/random-seed": "0.3.3", | ||||||
| 		"@types/ratelimiter": "3.4.1", | 		"@types/ratelimiter": "3.4.1", | ||||||
| 		"@types/redis": "2.8.28", | 		"@types/redis": "2.8.29", | ||||||
| 		"@types/rename": "1.0.2", | 		"@types/rename": "1.0.3", | ||||||
| 		"@types/request-stats": "3.0.0", | 		"@types/request-stats": "3.0.0", | ||||||
| 		"@types/rimraf": "3.0.0", | 		"@types/rimraf": "3.0.0", | ||||||
| 		"@types/seedrandom": "2.4.28", | 		"@types/seedrandom": "2.4.28", | ||||||
| 		"@types/sharp": "0.27.1", | 		"@types/sharp": "0.28.2", | ||||||
| 		"@types/sinonjs__fake-timers": "6.0.2", | 		"@types/sinonjs__fake-timers": "6.0.2", | ||||||
| 		"@types/speakeasy": "2.0.5", | 		"@types/speakeasy": "2.0.5", | ||||||
| 		"@types/throttle-debounce": "2.1.0", | 		"@types/throttle-debounce": "2.1.0", | ||||||
| @@ -103,69 +99,67 @@ | |||||||
| 		"@types/tmp": "0.2.0", | 		"@types/tmp": "0.2.0", | ||||||
| 		"@types/uuid": "8.3.0", | 		"@types/uuid": "8.3.0", | ||||||
| 		"@types/web-push": "3.3.0", | 		"@types/web-push": "3.3.0", | ||||||
| 		"@types/webpack": "4.41.26", | 		"@types/webpack": "5.28.0", | ||||||
| 		"@types/webpack-stream": "3.2.11", | 		"@types/webpack-stream": "3.2.12", | ||||||
| 		"@types/websocket": "1.0.1", | 		"@types/websocket": "1.0.2", | ||||||
| 		"@types/ws": "7.4.0", | 		"@types/ws": "7.4.4", | ||||||
| 		"@typescript-eslint/parser": "4.16.1", | 		"@typescript-eslint/parser": "4.25.0", | ||||||
| 		"@vue/compiler-sfc": "3.0.5", | 		"@vue/compiler-sfc": "3.0.11", | ||||||
| 		"abort-controller": "3.0.0", | 		"abort-controller": "3.0.0", | ||||||
| 		"apexcharts": "3.25.0", | 		"apexcharts": "3.26.3", | ||||||
| 		"autobind-decorator": "2.4.0", | 		"autobind-decorator": "2.4.0", | ||||||
| 		"autosize": "4.0.2", | 		"autosize": "4.0.4", | ||||||
| 		"autwh": "0.1.0", | 		"autwh": "0.1.0", | ||||||
| 		"aws-sdk": "2.848.0", | 		"aws-sdk": "2.918.0", | ||||||
| 		"bcryptjs": "2.4.3", | 		"bcryptjs": "2.4.3", | ||||||
| 		"blurhash": "1.1.3", | 		"blurhash": "1.1.3", | ||||||
| 		"broadcast-channel": "3.4.1", | 		"broadcast-channel": "3.6.0", | ||||||
| 		"bull": "3.20.1", | 		"bull": "3.22.6", | ||||||
| 		"cafy": "15.2.1", | 		"cafy": "15.2.1", | ||||||
| 		"cbor": "7.0.3", | 		"cbor": "7.0.5", | ||||||
| 		"chalk": "4.1.0", | 		"chalk": "4.1.1", | ||||||
| 		"chart.js": "2.9.4", | 		"chart.js": "2.9.4", | ||||||
| 		"cli-highlight": "2.1.10", | 		"cli-highlight": "2.1.11", | ||||||
| 		"commander": "4.1.1", | 		"commander": "7.2.0", | ||||||
|  | 		"concurrently": "6.2.0", | ||||||
| 		"content-disposition": "0.5.3", | 		"content-disposition": "0.5.3", | ||||||
| 		"core-js": "3.9.0", | 		"core-js": "3.13.1", | ||||||
| 		"crc-32": "1.2.0", | 		"crc-32": "1.2.0", | ||||||
| 		"css-loader": "5.0.2", | 		"css-loader": "5.2.6", | ||||||
| 		"cssnano": "4.1.10", | 		"cssnano": "5.0.5", | ||||||
| 		"dateformat": "4.5.1", | 		"dateformat": "4.5.1", | ||||||
| 		"diskusage": "1.1.3", | 		"diskusage": "1.1.3", | ||||||
| 		"double-ended-queue": "2.1.0-0", |  | ||||||
| 		"escape-regexp": "0.0.1", | 		"escape-regexp": "0.0.1", | ||||||
| 		"eslint": "7.21.0", | 		"eslint": "7.27.0", | ||||||
| 		"eslint-plugin-vue": "7.6.0", | 		"eslint-plugin-vue": "7.10.0", | ||||||
| 		"eventemitter3": "4.0.7", | 		"eventemitter3": "4.0.7", | ||||||
| 		"feed": "4.2.2", | 		"feed": "4.2.2", | ||||||
| 		"fibers": "5.0.0", | 		"file-type": "16.5.0", | ||||||
| 		"file-type": "16.2.0", |  | ||||||
| 		"fluent-ffmpeg": "2.1.2", | 		"fluent-ffmpeg": "2.1.2", | ||||||
| 		"glob": "7.1.6", | 		"glob": "7.1.7", | ||||||
| 		"got": "11.8.1", | 		"got": "11.8.2", | ||||||
| 		"gulp": "4.0.2", | 		"gulp": "4.0.2", | ||||||
| 		"gulp-cssnano": "2.1.3", | 		"gulp-cssnano": "2.1.3", | ||||||
| 		"gulp-rename": "2.0.0", | 		"gulp-rename": "2.0.0", | ||||||
| 		"gulp-replace": "1.0.0", | 		"gulp-replace": "1.1.3", | ||||||
| 		"gulp-terser": "2.0.1", | 		"gulp-terser": "2.0.1", | ||||||
| 		"gulp-tslint": "8.1.4", | 		"gulp-tslint": "8.1.4", | ||||||
| 		"gulp-typescript": "6.0.0-alpha.1", |  | ||||||
| 		"hard-source-webpack-plugin": "0.13.1", | 		"hard-source-webpack-plugin": "0.13.1", | ||||||
| 		"html-minifier": "4.0.0", | 		"html-minifier": "4.0.0", | ||||||
| 		"http-proxy-agent": "4.0.1", | 		"http-proxy-agent": "4.0.1", | ||||||
| 		"http-signature": "1.3.5", | 		"http-signature": "1.3.5", | ||||||
| 		"https-proxy-agent": "5.0.0", | 		"https-proxy-agent": "5.0.0", | ||||||
| 		"idb-keyval": "5.0.2", | 		"idb-keyval": "5.0.6", | ||||||
| 		"insert-text-at-cursor": "0.3.0", | 		"insert-text-at-cursor": "0.3.0", | ||||||
| 		"is-root": "2.1.0", | 		"is-root": "2.1.0", | ||||||
| 		"is-svg": "4.2.1", | 		"is-svg": "4.3.1", | ||||||
| 		"js-yaml": "4.0.0", | 		"js-yaml": "4.1.0", | ||||||
| 		"jsdom": "16.4.0", | 		"jsdom": "16.6.0", | ||||||
| 		"json5": "2.2.0", | 		"json5": "2.2.0", | ||||||
| 		"json5-loader": "4.0.1", | 		"json5-loader": "4.0.1", | ||||||
| 		"jsonld": "4.0.1", | 		"jsonld": "4.0.1", | ||||||
| 		"jsrsasign": "8.0.20", | 		"jsrsasign": "8.0.20", | ||||||
| 		"katex": "0.12.0", | 		"katex": "0.13.11", | ||||||
| 		"koa": "2.13.1", | 		"koa": "2.13.1", | ||||||
| 		"koa-bodyparser": "4.3.0", | 		"koa-bodyparser": "4.3.0", | ||||||
| 		"koa-favicon": "2.1.0", | 		"koa-favicon": "2.1.0", | ||||||
| @@ -174,41 +168,41 @@ | |||||||
| 		"koa-mount": "4.0.0", | 		"koa-mount": "4.0.0", | ||||||
| 		"koa-send": "5.0.1", | 		"koa-send": "5.0.1", | ||||||
| 		"koa-slow": "2.1.0", | 		"koa-slow": "2.1.0", | ||||||
| 		"koa-views": "6.3.1", | 		"koa-views": "7.0.1", | ||||||
| 		"langmap": "0.0.16", | 		"langmap": "0.0.16", | ||||||
| 		"lookup-dns-cache": "2.1.0", | 		"lookup-dns-cache": "2.1.0", | ||||||
| 		"markdown-it": "12.0.4", | 		"markdown-it": "12.0.6", | ||||||
| 		"markdown-it-anchor": "7.0.2", | 		"markdown-it-anchor": "7.1.0", | ||||||
| 		"matter-js": "0.16.1", | 		"matter-js": "0.17.1", | ||||||
| 		"mocha": "8.3.0", | 		"mfm-js": "0.16.4", | ||||||
|  | 		"misskey-js": "0.0.2", | ||||||
|  | 		"mocha": "8.4.0", | ||||||
| 		"moji": "0.5.1", | 		"moji": "0.5.1", | ||||||
| 		"ms": "2.1.3", | 		"ms": "2.1.3", | ||||||
| 		"multer": "1.4.2", | 		"multer": "1.4.2", | ||||||
| 		"nested-property": "4.0.0", | 		"nested-property": "4.0.0", | ||||||
| 		"node-fetch": "2.6.1", | 		"node-fetch": "2.6.1", | ||||||
| 		"nodemailer": "6.5.0", | 		"nodemailer": "6.6.1", | ||||||
| 		"object-assign-deep": "0.4.0", | 		"object-assign-deep": "0.4.0", | ||||||
| 		"os-utils": "0.0.14", | 		"os-utils": "0.0.14", | ||||||
| 		"p-cancelable": "2.0.0", |  | ||||||
| 		"parse5": "6.0.1", | 		"parse5": "6.0.1", | ||||||
| 		"parsimmon": "1.16.0", | 		"pg": "8.6.0", | ||||||
| 		"pg": "8.5.1", |  | ||||||
| 		"portscanner": "2.2.0", | 		"portscanner": "2.2.0", | ||||||
| 		"postcss": "8.2.7", | 		"postcss": "8.3.0", | ||||||
| 		"postcss-loader": "5.0.0", | 		"postcss-loader": "5.3.0", | ||||||
| 		"prismjs": "1.23.0", | 		"prismjs": "1.23.0", | ||||||
| 		"probe-image-size": "6.0.0", | 		"probe-image-size": "7.1.1", | ||||||
| 		"promise-limit": "2.7.0", | 		"promise-limit": "2.7.0", | ||||||
| 		"promise-sequential": "1.1.1", | 		"promise-sequential": "1.1.1", | ||||||
| 		"pug": "2.0.4", | 		"pug": "3.0.2", | ||||||
| 		"punycode": "2.1.1", | 		"punycode": "2.1.1", | ||||||
| 		"pureimage": "0.2.5", | 		"pureimage": "0.3.2", | ||||||
| 		"qrcode": "1.4.4", | 		"qrcode": "1.4.4", | ||||||
| 		"random-seed": "0.3.0", | 		"random-seed": "0.3.0", | ||||||
| 		"ratelimiter": "3.4.1", | 		"ratelimiter": "3.4.1", | ||||||
| 		"re2": "1.15.9", | 		"re2": "1.16.0", | ||||||
| 		"reconnecting-websocket": "4.4.0", | 		"reconnecting-websocket": "4.4.0", | ||||||
| 		"redis": "3.0.2", | 		"redis": "3.1.2", | ||||||
| 		"redis-lock": "0.1.4", | 		"redis-lock": "0.1.4", | ||||||
| 		"reflect-metadata": "0.1.13", | 		"reflect-metadata": "0.1.13", | ||||||
| 		"regenerator-runtime": "0.13.7", | 		"regenerator-runtime": "0.13.7", | ||||||
| @@ -218,52 +212,56 @@ | |||||||
| 		"rimraf": "3.0.2", | 		"rimraf": "3.0.2", | ||||||
| 		"rndstr": "1.0.0", | 		"rndstr": "1.0.0", | ||||||
| 		"s-age": "1.1.2", | 		"s-age": "1.1.2", | ||||||
| 		"sass": "1.32.8", | 		"sass": "1.34.0", | ||||||
| 		"sass-loader": "11.0.1", | 		"sass-loader": "11.1.1", | ||||||
| 		"seedrandom": "3.0.5", | 		"seedrandom": "3.0.5", | ||||||
| 		"sharp": "0.27.1", | 		"sharp": "0.28.3", | ||||||
| 		"speakeasy": "2.0.0", | 		"speakeasy": "2.0.0", | ||||||
| 		"stringz": "2.1.0", | 		"stringz": "2.1.0", | ||||||
| 		"style-loader": "2.0.0", | 		"style-loader": "2.0.0", | ||||||
| 		"summaly": "2.4.0", | 		"summaly": "2.4.0", | ||||||
| 		"syslog-pro": "1.0.0", | 		"syslog-pro": "1.0.0", | ||||||
| 		"systeminformation": "5.6.1", | 		"systeminformation": "5.7.4", | ||||||
| 		"syuilo-password-strength": "0.0.1", | 		"syuilo-password-strength": "0.0.1", | ||||||
| 		"textarea-caret": "3.1.0", | 		"textarea-caret": "3.1.0", | ||||||
| 		"three": "0.117.1", | 		"three": "0.117.1", | ||||||
| 		"throttle-debounce": "3.0.1", | 		"throttle-debounce": "3.0.1", | ||||||
| 		"tinycolor2": "1.4.2", | 		"tinycolor2": "1.4.2", | ||||||
| 		"tmp": "0.2.1", | 		"tmp": "0.2.1", | ||||||
| 		"ts-loader": "8.0.17", | 		"ts-loader": "9.2.2", | ||||||
| 		"ts-node": "9.1.1", | 		"ts-node": "10.0.0", | ||||||
|  | 		"tsc-alias": "1.2.11", | ||||||
|  | 		"tsconfig-paths": "3.9.0", | ||||||
| 		"tslint": "6.1.3", | 		"tslint": "6.1.3", | ||||||
| 		"tslint-sonarts": "1.9.0", | 		"tslint-sonarts": "1.9.0", | ||||||
| 		"typeorm": "0.2.31", | 		"twemoji-parser": "13.1.0", | ||||||
| 		"typescript": "4.1.5", | 		"typeorm": "0.2.32", | ||||||
|  | 		"typescript": "4.3.2", | ||||||
| 		"ulid": "2.3.0", | 		"ulid": "2.3.0", | ||||||
| 		"url-loader": "4.1.1", |  | ||||||
| 		"uuid": "8.3.2", | 		"uuid": "8.3.2", | ||||||
| 		"v-debounce": "0.1.2", | 		"v-debounce": "0.1.2", | ||||||
| 		"vanilla-tilt": "1.7.0", | 		"vanilla-tilt": "1.7.0", | ||||||
| 		"vue": "3.0.5", | 		"vue": "3.0.11", | ||||||
| 		"vue-color": "2.8.1", | 		"vue-color": "2.8.1", | ||||||
| 		"vue-json-pretty": "1.7.1", | 		"vue-json-pretty": "1.7.1", | ||||||
| 		"vue-loader": "16.1.2", | 		"vue-loader": "16.1.2", | ||||||
| 		"vue-prism-editor": "2.0.0-alpha.2", | 		"vue-prism-editor": "2.0.0-alpha.2", | ||||||
| 		"vue-router": "4.0.4", | 		"vue-router": "4.0.5", | ||||||
| 		"vue-style-loader": "4.1.3", | 		"vue-style-loader": "4.1.3", | ||||||
|  | 		"vue-svg-loader": "0.17.0-beta.2", | ||||||
| 		"vuedraggable": "4.0.1", | 		"vuedraggable": "4.0.1", | ||||||
| 		"web-push": "3.4.4", | 		"web-push": "3.4.4", | ||||||
| 		"webpack": "5.24.2", | 		"webpack": "5.38.1", | ||||||
| 		"webpack-cli": "4.5.0", | 		"webpack-cli": "4.7.0", | ||||||
| 		"websocket": "1.0.33", | 		"websocket": "1.0.34", | ||||||
| 		"ws": "7.4.3", | 		"ws": "7.4.6", | ||||||
| 		"xev": "2.0.1" | 		"xev": "2.0.1" | ||||||
| 	}, | 	}, | ||||||
| 	"devDependencies": { | 	"devDependencies": { | ||||||
| 		"@types/chai": "4.2.15", | 		"@redocly/openapi-core": "1.0.0-beta.44", | ||||||
| 		"@types/fluent-ffmpeg": "2.1.16", | 		"@types/chai": "4.2.16", | ||||||
| 		"chai": "4.3.0", | 		"@types/fluent-ffmpeg": "2.1.17", | ||||||
|  | 		"chai": "4.3.4", | ||||||
| 		"cross-env": "7.0.3" | 		"cross-env": "7.0.3" | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										6
									
								
								src/.eslintrc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								src/.eslintrc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | { | ||||||
|  | 	"env": { | ||||||
|  | 		"node": true, | ||||||
|  | 		"commonjs": true | ||||||
|  | 	} | ||||||
|  | } | ||||||
							
								
								
									
										3
									
								
								src/@types/meta.json.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								src/@types/meta.json.d.ts
									
									
									
									
										vendored
									
									
								
							| @@ -1,3 +0,0 @@ | |||||||
| declare module '*/meta.json' { |  | ||||||
| 	const version: string; |  | ||||||
| } |  | ||||||
| @@ -1,5 +1,7 @@ | |||||||
| import * as program from 'commander'; | import { Command } from 'commander'; | ||||||
| import config from './config'; | import config from '@/config'; | ||||||
|  |  | ||||||
|  | const program = new Command(); | ||||||
|  |  | ||||||
| program | program | ||||||
| 	.version(config.version) | 	.version(config.version) | ||||||
|   | |||||||
| @@ -6,13 +6,13 @@ import * as isRoot from 'is-root'; | |||||||
| import { getConnection } from 'typeorm'; | import { getConnection } from 'typeorm'; | ||||||
|  |  | ||||||
| import Logger from '../services/logger'; | import Logger from '../services/logger'; | ||||||
| import loadConfig from '../config/load'; | import loadConfig from '@/config/load'; | ||||||
| import { Config } from '../config/types'; | import { Config } from '@/config/types'; | ||||||
| import { lessThan } from '../prelude/array'; | import { lessThan } from '../prelude/array'; | ||||||
| import { program } from '../argv'; | import { program } from '../argv'; | ||||||
| import { showMachineInfo } from '../misc/show-machine-info'; | import { showMachineInfo } from '@/misc/show-machine-info'; | ||||||
| import { initDb } from '../db/postgre'; | import { initDb } from '../db/postgre'; | ||||||
| import * as meta from '../meta.json'; | const meta = require('../meta.json'); | ||||||
|  |  | ||||||
| const logger = new Logger('core', 'cyan'); | const logger = new Logger('core', 'cyan'); | ||||||
| const bootLogger = logger.createSubLogger('boot', 'magenta', false); | const bootLogger = logger.createSubLogger('boot', 'magenta', false); | ||||||
| @@ -45,26 +45,15 @@ function greet() { | |||||||
| export async function masterMain() { | export async function masterMain() { | ||||||
| 	let config!: Config; | 	let config!: Config; | ||||||
|  |  | ||||||
|  | 	// initialize app | ||||||
| 	try { | 	try { | ||||||
| 		greet(); | 		greet(); | ||||||
|  | 		showEnvironment(); | ||||||
| 		// initialize app | 		await showMachineInfo(bootLogger); | ||||||
| 		config = await init(); | 		showNodejsVersion(); | ||||||
|  | 		config = loadConfigBoot(); | ||||||
| 		if (config.port == null || Number.isNaN(config.port)) { | 		await connectDb(); | ||||||
| 			bootLogger.error('The port is not configured. Please configure port.', null, true); | 		await validatePort(config); | ||||||
| 			process.exit(1); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		if (process.platform === 'linux' && isWellKnownPort(config.port) && !isRoot()) { |  | ||||||
| 			bootLogger.error('You need root privileges to listen on well-known port on Linux', null, true); |  | ||||||
| 			process.exit(1); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		if (!await isPortAvailable(config.port)) { |  | ||||||
| 			bootLogger.error(`Port ${config.port} is already in use`, null, true); |  | ||||||
| 			process.exit(1); |  | ||||||
| 		} |  | ||||||
| 	} catch (e) { | 	} catch (e) { | ||||||
| 		bootLogger.error('Fatal error occurred during initialization', null, true); | 		bootLogger.error('Fatal error occurred during initialization', null, true); | ||||||
| 		process.exit(1); | 		process.exit(1); | ||||||
| @@ -89,14 +78,6 @@ const runningNodejsVersion = process.version.slice(1).split('.').map(x => parseI | |||||||
| const requiredNodejsVersion = [11, 7, 0]; | const requiredNodejsVersion = [11, 7, 0]; | ||||||
| const satisfyNodejsVersion = !lessThan(runningNodejsVersion, requiredNodejsVersion); | const satisfyNodejsVersion = !lessThan(runningNodejsVersion, requiredNodejsVersion); | ||||||
|  |  | ||||||
| function isWellKnownPort(port: number): boolean { |  | ||||||
| 	return port < 1024; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| async function isPortAvailable(port: number): Promise<boolean> { |  | ||||||
| 	return await portscanner.checkPortStatus(port, '127.0.0.1') === 'closed'; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function showEnvironment(): void { | function showEnvironment(): void { | ||||||
| 	const env = process.env.NODE_ENV; | 	const env = process.env.NODE_ENV; | ||||||
| 	const logger = bootLogger.createSubLogger('env'); | 	const logger = bootLogger.createSubLogger('env'); | ||||||
| @@ -110,14 +91,7 @@ function showEnvironment(): void { | |||||||
| 	logger.info(`You ${isRoot() ? '' : 'do not '}have root privileges`); | 	logger.info(`You ${isRoot() ? '' : 'do not '}have root privileges`); | ||||||
| } | } | ||||||
|  |  | ||||||
| /** | function showNodejsVersion(): void { | ||||||
|  * Init app |  | ||||||
|  */ |  | ||||||
| async function init(): Promise<Config> { |  | ||||||
| 	showEnvironment(); |  | ||||||
|  |  | ||||||
| 	await showMachineInfo(bootLogger); |  | ||||||
|  |  | ||||||
| 	const nodejsLogger = bootLogger.createSubLogger('nodejs'); | 	const nodejsLogger = bootLogger.createSubLogger('nodejs'); | ||||||
|  |  | ||||||
| 	nodejsLogger.info(`Version ${runningNodejsVersion.join('.')}`); | 	nodejsLogger.info(`Version ${runningNodejsVersion.join('.')}`); | ||||||
| @@ -126,7 +100,9 @@ async function init(): Promise<Config> { | |||||||
| 		nodejsLogger.error(`Node.js version is less than ${requiredNodejsVersion.join('.')}. Please upgrade it.`, null, true); | 		nodejsLogger.error(`Node.js version is less than ${requiredNodejsVersion.join('.')}. Please upgrade it.`, null, true); | ||||||
| 		process.exit(1); | 		process.exit(1); | ||||||
| 	} | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function loadConfigBoot(): Config { | ||||||
| 	const configLogger = bootLogger.createSubLogger('config'); | 	const configLogger = bootLogger.createSubLogger('config'); | ||||||
| 	let config; | 	let config; | ||||||
|  |  | ||||||
| @@ -146,6 +122,10 @@ async function init(): Promise<Config> { | |||||||
|  |  | ||||||
| 	configLogger.succ('Loaded'); | 	configLogger.succ('Loaded'); | ||||||
|  |  | ||||||
|  | 	return config; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | async function connectDb(): Promise<void> { | ||||||
| 	const dbLogger = bootLogger.createSubLogger('db'); | 	const dbLogger = bootLogger.createSubLogger('db'); | ||||||
|  |  | ||||||
| 	// Try to connect to DB | 	// Try to connect to DB | ||||||
| @@ -159,8 +139,29 @@ async function init(): Promise<Config> { | |||||||
| 		dbLogger.error(e); | 		dbLogger.error(e); | ||||||
| 		process.exit(1); | 		process.exit(1); | ||||||
| 	} | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
| 	return config; | async function validatePort(config: Config): Promise<void> { | ||||||
|  | 	const isWellKnownPort = (port: number) => port < 1024; | ||||||
|  |  | ||||||
|  | 	async function isPortAvailable(port: number): Promise<boolean> { | ||||||
|  | 		return await portscanner.checkPortStatus(port, '127.0.0.1') === 'closed'; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if (config.port == null || Number.isNaN(config.port)) { | ||||||
|  | 		bootLogger.error('The port is not configured. Please configure port.', null, true); | ||||||
|  | 		process.exit(1); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if (process.platform === 'linux' && isWellKnownPort(config.port) && !isRoot()) { | ||||||
|  | 		bootLogger.error('You need root privileges to listen on well-known port on Linux', null, true); | ||||||
|  | 		process.exit(1); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if (!await isPortAvailable(config.port)) { | ||||||
|  | 		bootLogger.error(`Port ${config.port} is already in use`, null, true); | ||||||
|  | 		process.exit(1); | ||||||
|  | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
| async function spawnWorkers(limit: number = 1) { | async function spawnWorkers(limit: number = 1) { | ||||||
|   | |||||||
| @@ -1,4 +1,24 @@ | |||||||
| { | { | ||||||
|  | 	"env": { | ||||||
|  | 		"node": false, | ||||||
|  | 	}, | ||||||
|  | 	"extends": [ | ||||||
|  | 		"eslint:recommended", | ||||||
|  | 		"plugin:vue/recommended" | ||||||
|  | 	], | ||||||
|  | 	"rules": { | ||||||
|  | 		"vue/require-v-for-key": 0, | ||||||
|  | 		"vue/max-attributes-per-line": 0, | ||||||
|  | 		"vue/html-indent": 0, | ||||||
|  | 		"vue/html-self-closing": 0, | ||||||
|  | 		"vue/no-unused-vars": 0, | ||||||
|  | 		"vue/attributes-order": 0, | ||||||
|  | 		"vue/require-prop-types": 0, | ||||||
|  | 		"vue/require-default-prop": 0, | ||||||
|  | 		"vue/html-closing-bracket-spacing": 0, | ||||||
|  | 		"vue/singleline-html-element-content-newline": 0, | ||||||
|  | 		"vue/no-v-html": 0 | ||||||
|  | 	}, | ||||||
| 	"globals": { | 	"globals": { | ||||||
| 		"_DEV_": false, | 		"_DEV_": false, | ||||||
| 		"_LANGS_": false, | 		"_LANGS_": false, | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| import { reactive } from 'vue'; | import { reactive } from 'vue'; | ||||||
| import { apiUrl } from '@/config'; | import { apiUrl } from '@client/config'; | ||||||
| import { waiting } from '@/os'; | import { waiting } from '@client/os'; | ||||||
| import { unisonReload } from '@/scripts/unison-reload'; | import { unisonReload } from '@client/scripts/unison-reload'; | ||||||
|  |  | ||||||
| // TODO: 他のタブと永続化されたstateを同期 | // TODO: 他のタブと永続化されたstateを同期 | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,26 +1,22 @@ | |||||||
| <template> | <template> | ||||||
| <XWindow ref="window" :initial-width="400" :initial-height="500" :can-resize="true" @closed="$emit('closed')"> | <XWindow ref="window" :initial-width="400" :initial-height="500" :can-resize="true" @closed="$emit('closed')"> | ||||||
| 	<template #header> | 	<template #header> | ||||||
| 		<Fa :icon="faExclamationCircle" style="margin-right: 0.5em;"/> | 		<i class="fas fa-exclamation-circle" style="margin-right: 0.5em;"></i> | ||||||
| 		<I18n :src="$ts.reportAbuseOf" tag="span"> | 		<I18n :src="$ts.reportAbuseOf" tag="span"> | ||||||
| 			<template #name> | 			<template #name> | ||||||
| 				<b><MkAcct :user="user"/></b> | 				<b><MkAcct :user="user"/></b> | ||||||
| 			</template> | 			</template> | ||||||
| 		</I18n> | 		</I18n> | ||||||
| 	</template> | 	</template> | ||||||
| 	<div class="dpvffvvy"> | 	<div class="dpvffvvy _monolithic_"> | ||||||
| 		<div class="_section"> | 		<div class="_section"> | ||||||
| 			<div class="_content"> | 			<MkTextarea v-model:value="comment"> | ||||||
| 				<MkTextarea v-model:value="comment"> | 				<span>{{ $ts.details }}</span> | ||||||
| 					<span>{{ $ts.details }}</span> | 				<template #desc>{{ $ts.fillAbuseReportDescription }}</template> | ||||||
| 					<template #desc>{{ $ts.fillAbuseReportDescription }}</template> | 			</MkTextarea> | ||||||
| 				</MkTextarea> |  | ||||||
| 			</div> |  | ||||||
| 		</div> | 		</div> | ||||||
| 		<div class="_section"> | 		<div class="_section"> | ||||||
| 			<div class="_content"> | 			<MkButton @click="send" primary full :disabled="comment.length === 0">{{ $ts.send }}</MkButton> | ||||||
| 				<MkButton @click="send" primary full :disabled="comment.length === 0">{{ $ts.send }}</MkButton> |  | ||||||
| 			</div> |  | ||||||
| 		</div> | 		</div> | ||||||
| 	</div> | 	</div> | ||||||
| </XWindow> | </XWindow> | ||||||
| @@ -28,11 +24,10 @@ | |||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent, markRaw } from 'vue'; | import { defineComponent, markRaw } from 'vue'; | ||||||
| import { faExclamationCircle } from '@fortawesome/free-solid-svg-icons'; | import XWindow from '@client/components/ui/window.vue'; | ||||||
| import XWindow from '@/components/ui/window.vue'; | import MkTextarea from '@client/components/ui/textarea.vue'; | ||||||
| import MkTextarea from '@/components/ui/textarea.vue'; | import MkButton from '@client/components/ui/button.vue'; | ||||||
| import MkButton from '@/components/ui/button.vue'; | import * as os from '@client/os'; | ||||||
| import * as os from '@/os'; |  | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	components: { | 	components: { | ||||||
| @@ -57,7 +52,6 @@ export default defineComponent({ | |||||||
| 	data() { | 	data() { | ||||||
| 		return { | 		return { | ||||||
| 			comment: this.initialComment || '', | 			comment: this.initialComment || '', | ||||||
| 			faExclamationCircle, |  | ||||||
| 		}; | 		}; | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| @@ -80,6 +74,6 @@ export default defineComponent({ | |||||||
|  |  | ||||||
| <style lang="scss" scoped> | <style lang="scss" scoped> | ||||||
| .dpvffvvy { | .dpvffvvy { | ||||||
| 	--section-padding: 16px; | 	--root-margin: 16px; | ||||||
| } | } | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -36,7 +36,7 @@ | |||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent } from 'vue'; | import { defineComponent } from 'vue'; | ||||||
| import * as tinycolor from 'tinycolor2'; | import * as tinycolor from 'tinycolor2'; | ||||||
| import * as os from '@/os'; | import * as os from '@client/os'; | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	data() { | 	data() { | ||||||
|   | |||||||
| @@ -29,12 +29,12 @@ | |||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent, markRaw } from 'vue'; | import { defineComponent, markRaw } from 'vue'; | ||||||
| import { emojilist } from '../../misc/emojilist'; | import { emojilist } from '@/misc/emojilist'; | ||||||
| import contains from '@/scripts/contains'; | import contains from '@client/scripts/contains'; | ||||||
| import { twemojiSvgBase } from '../../misc/twemoji-base'; | import { twemojiSvgBase } from '@/misc/twemoji-base'; | ||||||
| import { getStaticImageUrl } from '@/scripts/get-static-image-url'; | import { getStaticImageUrl } from '@client/scripts/get-static-image-url'; | ||||||
| import { acct } from '@/filters/user'; | import { acct } from '@client/filters/user'; | ||||||
| import * as os from '@/os'; | import * as os from '@client/os'; | ||||||
|  |  | ||||||
| type EmojiDef = { | type EmojiDef = { | ||||||
| 	emoji: string; | 	emoji: string; | ||||||
|   | |||||||
| @@ -1,14 +1,14 @@ | |||||||
| <template> | <template> | ||||||
| <div> | <div> | ||||||
| 	<div v-for="user in us" :key="user.id" style="display:inline-block;width:32px;height:32px;margin-right:8px;"> | 	<div v-for="user in us" :key="user.id" style="display:inline-block;width:32px;height:32px;margin-right:8px;"> | ||||||
| 		<MkAvatar :user="user" style="width:32px;height:32px;"/> | 		<MkAvatar :user="user" style="width:32px;height:32px;" :show-indicator="true"/> | ||||||
| 	</div> | 	</div> | ||||||
| </div> | </div> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent } from 'vue'; | import { defineComponent } from 'vue'; | ||||||
| import * as os from '@/os'; | import * as os from '@client/os'; | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	props: { | 	props: { | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ | |||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent } from 'vue'; | import { defineComponent, PropType } from 'vue'; | ||||||
|  |  | ||||||
| type Captcha = { | type Captcha = { | ||||||
| 	render(container: string | Node, options: { | 	render(container: string | Node, options: { | ||||||
| @@ -18,7 +18,7 @@ type Captcha = { | |||||||
| 	getResponse(id: string): string; | 	getResponse(id: string): string; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| type CaptchaProvider = 'hcaptcha' | 'grecaptcha'; | type CaptchaProvider = 'hcaptcha' | 'recaptcha'; | ||||||
|  |  | ||||||
| type CaptchaContainer = { | type CaptchaContainer = { | ||||||
| 	readonly [_ in CaptchaProvider]?: Captcha; | 	readonly [_ in CaptchaProvider]?: Captcha; | ||||||
| @@ -32,7 +32,7 @@ declare global { | |||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	props: { | 	props: { | ||||||
| 		provider: { | 		provider: { | ||||||
| 			type: String, | 			type: String as PropType<CaptchaProvider>, | ||||||
| 			required: true, | 			required: true, | ||||||
| 		}, | 		}, | ||||||
| 		sitekey: { | 		sitekey: { | ||||||
| @@ -51,19 +51,25 @@ export default defineComponent({ | |||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| 	computed: { | 	computed: { | ||||||
| 		loaded() { | 		variable(): string { | ||||||
| 			return !!window[this.provider as CaptchaProvider]; | 			switch (this.provider) { | ||||||
|  | 				case 'hcaptcha': return 'hcaptcha'; | ||||||
|  | 				case 'recaptcha': return 'grecaptcha'; | ||||||
|  | 			} | ||||||
| 		}, | 		}, | ||||||
| 		src() { | 		loaded(): boolean { | ||||||
|  | 			return !!window[this.variable]; | ||||||
|  | 		}, | ||||||
|  | 		src(): string { | ||||||
| 			const endpoint = ({ | 			const endpoint = ({ | ||||||
| 				hcaptcha: 'https://hcaptcha.com/1', | 				hcaptcha: 'https://hcaptcha.com/1', | ||||||
| 				grecaptcha: 'https://www.recaptcha.net/recaptcha', | 				recaptcha: 'https://www.recaptcha.net/recaptcha', | ||||||
| 			} as Record<PropertyKey, unknown>)[this.provider]; | 			} as Record<CaptchaProvider, string>)[this.provider]; | ||||||
|  |  | ||||||
| 			return `${typeof endpoint == 'string' ? endpoint : 'about:invalid'}/api.js?render=explicit`; | 			return `${typeof endpoint === 'string' ? endpoint : 'about:invalid'}/api.js?render=explicit`; | ||||||
| 		}, | 		}, | ||||||
| 		captcha() { | 		captcha(): Captcha { | ||||||
| 			return window[this.provider as CaptchaProvider] || {} as unknown as Captcha; | 			return window[this.variable] || {} as unknown as Captcha; | ||||||
| 		}, | 		}, | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| @@ -94,7 +100,7 @@ export default defineComponent({ | |||||||
|  |  | ||||||
| 	methods: { | 	methods: { | ||||||
| 		reset() { | 		reset() { | ||||||
| 			this.captcha?.reset(); | 			if (this.captcha?.reset) this.captcha.reset(); | ||||||
| 		}, | 		}, | ||||||
| 		requestRender() { | 		requestRender() { | ||||||
| 			if (this.captcha.render && this.$refs.captcha instanceof Element) { | 			if (this.captcha.render && this.$refs.captcha instanceof Element) { | ||||||
|   | |||||||
| @@ -6,22 +6,21 @@ | |||||||
| > | > | ||||||
| 	<template v-if="!wait"> | 	<template v-if="!wait"> | ||||||
| 		<template v-if="isFollowing"> | 		<template v-if="isFollowing"> | ||||||
| 			<span v-if="full">{{ $ts.unfollow }}</span><Fa :icon="faMinus"/> | 			<span v-if="full">{{ $ts.unfollow }}</span><i class="fas fa-minus"></i> | ||||||
| 		</template> | 		</template> | ||||||
| 		<template v-else> | 		<template v-else> | ||||||
| 			<span v-if="full">{{ $ts.follow }}</span><Fa :icon="faPlus"/> | 			<span v-if="full">{{ $ts.follow }}</span><i class="fas fa-plus"></i> | ||||||
| 		</template> | 		</template> | ||||||
| 	</template> | 	</template> | ||||||
| 	<template v-else> | 	<template v-else> | ||||||
| 		<span v-if="full">{{ $ts.processing }}</span><Fa :icon="faSpinner" pulse fixed-width/> | 		<span v-if="full">{{ $ts.processing }}</span><i class="fas fa-spinner fa-pulse fa-fw"></i> | ||||||
| 	</template> | 	</template> | ||||||
| </button> | </button> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent } from 'vue'; | import { defineComponent } from 'vue'; | ||||||
| import { faSpinner, faPlus, faMinus, } from '@fortawesome/free-solid-svg-icons'; | import * as os from '@client/os'; | ||||||
| import * as os from '@/os'; |  | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	props: { | 	props: { | ||||||
| @@ -40,7 +39,6 @@ export default defineComponent({ | |||||||
| 		return { | 		return { | ||||||
| 			isFollowing: this.channel.isFollowing, | 			isFollowing: this.channel.isFollowing, | ||||||
| 			wait: false, | 			wait: false, | ||||||
| 			faSpinner, faPlus, faMinus, |  | ||||||
| 		}; | 		}; | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2,10 +2,10 @@ | |||||||
| <MkA :to="`/channels/${channel.id}`" class="eftoefju _panel" tabindex="-1"> | <MkA :to="`/channels/${channel.id}`" class="eftoefju _panel" tabindex="-1"> | ||||||
| 	<div class="banner" :style="bannerStyle"> | 	<div class="banner" :style="bannerStyle"> | ||||||
| 		<div class="fade"></div> | 		<div class="fade"></div> | ||||||
| 		<div class="name"><Fa :icon="faSatelliteDish"/> {{ channel.name }}</div> | 		<div class="name"><i class="fas fa-satellite-dish"></i> {{ channel.name }}</div> | ||||||
| 		<div class="status"> | 		<div class="status"> | ||||||
| 			<div> | 			<div> | ||||||
| 				<Fa :icon="faUsers" fixed-width/> | 				<i class="fas fa-users fa-fw"></i> | ||||||
| 				<I18n :src="$ts._channel.usersCount" tag="span" style="margin-left: 4px;"> | 				<I18n :src="$ts._channel.usersCount" tag="span" style="margin-left: 4px;"> | ||||||
| 					<template #n> | 					<template #n> | ||||||
| 						<b>{{ channel.usersCount }}</b> | 						<b>{{ channel.usersCount }}</b> | ||||||
| @@ -13,7 +13,7 @@ | |||||||
| 				</I18n> | 				</I18n> | ||||||
| 			</div> | 			</div> | ||||||
| 			<div> | 			<div> | ||||||
| 				<Fa :icon="faPencilAlt" fixed-width/> | 				<i class="fas fa-pencil-alt fa-fw"></i> | ||||||
| 				<I18n :src="$ts._channel.notesCount" tag="span" style="margin-left: 4px;"> | 				<I18n :src="$ts._channel.notesCount" tag="span" style="margin-left: 4px;"> | ||||||
| 					<template #n> | 					<template #n> | ||||||
| 						<b>{{ channel.notesCount }}</b> | 						<b>{{ channel.notesCount }}</b> | ||||||
| @@ -35,7 +35,6 @@ | |||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent } from 'vue'; | import { defineComponent } from 'vue'; | ||||||
| import { faSatelliteDish, faUsers, faPencilAlt } from '@fortawesome/free-solid-svg-icons'; |  | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	props: { | 	props: { | ||||||
| @@ -57,7 +56,6 @@ export default defineComponent({ | |||||||
|  |  | ||||||
| 	data() { | 	data() { | ||||||
| 		return { | 		return { | ||||||
| 			faSatelliteDish, faUsers, faPencilAlt, |  | ||||||
| 		}; | 		}; | ||||||
| 	}, | 	}, | ||||||
| }); | }); | ||||||
| @@ -123,7 +121,7 @@ export default defineComponent({ | |||||||
|  |  | ||||||
| 	> footer { | 	> footer { | ||||||
| 		padding: 12px 16px; | 		padding: 12px 16px; | ||||||
| 		border-top: solid 1px var(--divider); | 		border-top: solid 0.5px var(--divider); | ||||||
|  |  | ||||||
| 		> span { | 		> span { | ||||||
| 			opacity: 0.7; | 			opacity: 0.7; | ||||||
|   | |||||||
| @@ -1,12 +1,11 @@ | |||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent, h, TransitionGroup } from 'vue'; | import { defineComponent, h, PropType, TransitionGroup } from 'vue'; | ||||||
| import { faAngleUp, faAngleDown } from '@fortawesome/free-solid-svg-icons'; | import MkAd from '@client/components/global/ad.vue'; | ||||||
| import { FontAwesomeIcon } from '@fortawesome/vue-fontawesome'; |  | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	props: { | 	props: { | ||||||
| 		items: { | 		items: { | ||||||
| 			type: Array, | 			type: Array as PropType<{ id: string; createdAt: string; _shouldInsertAd_: boolean; }[]>, | ||||||
| 			required: true, | 			required: true, | ||||||
| 		}, | 		}, | ||||||
| 		direction: { | 		direction: { | ||||||
| @@ -18,17 +17,25 @@ export default defineComponent({ | |||||||
| 			type: Boolean, | 			type: Boolean, | ||||||
| 			required: false, | 			required: false, | ||||||
| 			default: false | 			default: false | ||||||
| 		} | 		}, | ||||||
|  | 		noGap: { | ||||||
|  | 			type: Boolean, | ||||||
|  | 			required: false, | ||||||
|  | 			default: false | ||||||
|  | 		}, | ||||||
|  | 		ad: { | ||||||
|  | 			type: Boolean, | ||||||
|  | 			required: false, | ||||||
|  | 			default: false | ||||||
|  | 		}, | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| 	methods: { | 	methods: { | ||||||
| 		focus() { | 		focus() { | ||||||
| 			this.$slots.default[0].elm.focus(); | 			this.$slots.default[0].elm.focus(); | ||||||
| 		} | 		}, | ||||||
| 	}, |  | ||||||
|  |  | ||||||
| 	render() { | 		getDateText(time: string) { | ||||||
| 		const getDateText = (time: string) => { |  | ||||||
| 			const date = new Date(time).getDate(); | 			const date = new Date(time).getDate(); | ||||||
| 			const month = new Date(time).getMonth() + 1; | 			const month = new Date(time).getMonth() + 1; | ||||||
| 			return this.$t('monthAndDay', { | 			return this.$t('monthAndDay', { | ||||||
| @@ -36,15 +43,19 @@ export default defineComponent({ | |||||||
| 				day: date.toString() | 				day: date.toString() | ||||||
| 			}); | 			}); | ||||||
| 		} | 		} | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	render() { | ||||||
|  | 		if (this.items.length === 0) return; | ||||||
|  |  | ||||||
| 		return h(this.$store.state.animation ? TransitionGroup : 'div', this.$store.state.animation ? { | 		return h(this.$store.state.animation ? TransitionGroup : 'div', this.$store.state.animation ? { | ||||||
| 			class: 'sqadhkmv _list_', | 			class: 'sqadhkmv' + (this.noGap ? ' noGap _block' : ''), | ||||||
| 			name: 'list', | 			name: 'list', | ||||||
| 			tag: 'div', | 			tag: 'div', | ||||||
| 			'data-direction': this.direction, | 			'data-direction': this.direction, | ||||||
| 			'data-reversed': this.reversed ? 'true' : 'false', | 			'data-reversed': this.reversed ? 'true' : 'false', | ||||||
| 		} : { | 		} : { | ||||||
| 			class: 'sqadhkmv _list_', | 			class: 'sqadhkmv' + (this.noGap ? ' noGap _block' : ''), | ||||||
| 		}, this.items.map((item, i) => { | 		}, this.items.map((item, i) => { | ||||||
| 			const el = this.$slots.default({ | 			const el = this.$slots.default({ | ||||||
| 				item: item | 				item: item | ||||||
| @@ -53,11 +64,7 @@ export default defineComponent({ | |||||||
|  |  | ||||||
| 			if ( | 			if ( | ||||||
| 				i != this.items.length - 1 && | 				i != this.items.length - 1 && | ||||||
| 				new Date(item.createdAt).getDate() != new Date(this.items[i + 1].createdAt).getDate() && | 				new Date(item.createdAt).getDate() != new Date(this.items[i + 1].createdAt).getDate() | ||||||
| 				!item._prId_ && |  | ||||||
| 				!this.items[i + 1]._prId_ && |  | ||||||
| 				!item._featuredId_ && |  | ||||||
| 				!this.items[i + 1]._featuredId_ |  | ||||||
| 			) { | 			) { | ||||||
| 				const separator = h('div', { | 				const separator = h('div', { | ||||||
| 					class: 'separator', | 					class: 'separator', | ||||||
| @@ -66,24 +73,30 @@ export default defineComponent({ | |||||||
| 					class: 'date' | 					class: 'date' | ||||||
| 				}, [ | 				}, [ | ||||||
| 					h('span', [ | 					h('span', [ | ||||||
| 						h(FontAwesomeIcon, { | 						h('i', { | ||||||
| 							class: 'icon', | 							class: 'fas fa-angle-up icon', | ||||||
| 							icon: faAngleUp, |  | ||||||
| 						}), | 						}), | ||||||
| 						getDateText(item.createdAt) | 						this.getDateText(item.createdAt) | ||||||
| 					]), | 					]), | ||||||
| 					h('span', [ | 					h('span', [ | ||||||
| 						getDateText(this.items[i + 1].createdAt), | 						this.getDateText(this.items[i + 1].createdAt), | ||||||
| 						h(FontAwesomeIcon, { | 						h('i', { | ||||||
| 							class: 'icon', | 							class: 'fas fa-angle-down icon', | ||||||
| 							icon: faAngleDown, |  | ||||||
| 						}) | 						}) | ||||||
| 					]) | 					]) | ||||||
| 				])); | 				])); | ||||||
|  |  | ||||||
| 				return [el, separator]; | 				return [el, separator]; | ||||||
| 			} else { | 			} else { | ||||||
| 				return el; | 				if (this.ad && item._shouldInsertAd_) { | ||||||
|  | 					return [h(MkAd, { | ||||||
|  | 						class: 'a', // advertiseの意(ブロッカー対策) | ||||||
|  | 						key: item.id + ':ad', | ||||||
|  | 						prefer: ['horizontal', 'horizontal-big'], | ||||||
|  | 					}), el]; | ||||||
|  | 				} else { | ||||||
|  | 					return el; | ||||||
|  | 				} | ||||||
| 			} | 			} | ||||||
| 		})); | 		})); | ||||||
| 	}, | 	}, | ||||||
| @@ -92,6 +105,10 @@ export default defineComponent({ | |||||||
|  |  | ||||||
| <style lang="scss"> | <style lang="scss"> | ||||||
| .sqadhkmv { | .sqadhkmv { | ||||||
|  | 	> *:empty { | ||||||
|  | 		display: none; | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	> *:not(:last-child) { | 	> *:not(:last-child) { | ||||||
| 		margin-bottom: var(--margin); | 		margin-bottom: var(--margin); | ||||||
| 	} | 	} | ||||||
| @@ -117,11 +134,7 @@ export default defineComponent({ | |||||||
| 			transform: translateY(-64px); | 			transform: translateY(-64px); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| } |  | ||||||
| </style> |  | ||||||
|  |  | ||||||
| <style lang="scss"> |  | ||||||
| .sqadhkmv { |  | ||||||
| 	> .separator { | 	> .separator { | ||||||
| 		text-align: center; | 		text-align: center; | ||||||
|  |  | ||||||
| @@ -154,5 +167,18 @@ export default defineComponent({ | |||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	&.noGap { | ||||||
|  | 		> * { | ||||||
|  | 			margin: 0 !important; | ||||||
|  | 			border: none; | ||||||
|  | 			border-radius: 0; | ||||||
|  | 			box-shadow: none; | ||||||
|  |  | ||||||
|  | 			&:not(:last-child) { | ||||||
|  | 				border-bottom: solid 0.5px var(--divider); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
| } | } | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -2,15 +2,15 @@ | |||||||
| <MkModal ref="modal" @click="done(true)" @closed="$emit('closed')"> | <MkModal ref="modal" @click="done(true)" @closed="$emit('closed')"> | ||||||
| 	<div class="mk-dialog"> | 	<div class="mk-dialog"> | ||||||
| 		<div class="icon" v-if="icon"> | 		<div class="icon" v-if="icon"> | ||||||
| 			<Fa :icon="icon"/> | 			<i :class="icon"></i> | ||||||
| 		</div> | 		</div> | ||||||
| 		<div class="icon" v-else-if="!input && !select" :class="type"> | 		<div class="icon" v-else-if="!input && !select" :class="type"> | ||||||
| 			<Fa :icon="faCheck" v-if="type === 'success'"/> | 			<i v-if="type === 'success'" class="fas fa-check"></i> | ||||||
| 			<Fa :icon="faTimesCircle" v-if="type === 'error'"/> | 			<i v-else-if="type === 'error'" class="fas fa-times-circle"></i> | ||||||
| 			<Fa :icon="faExclamationTriangle" v-if="type === 'warning'"/> | 			<i v-else-if="type === 'warning'" class="fas fa-exclamation-triangle"></i> | ||||||
| 			<Fa :icon="faInfoCircle" v-if="type === 'info'"/> | 			<i v-else-if="type === 'info'" class="fas fa-info-circle"></i> | ||||||
| 			<Fa :icon="faQuestionCircle" v-if="type === 'question'"/> | 			<i v-else-if="type === 'question'" class="fas fa-question-circle"></i> | ||||||
| 			<Fa :icon="faSpinner" pulse v-if="type === 'waiting'"/> | 			<i v-else-if="type === 'waiting'" class="fas fa-spinner fa-pulse"></i> | ||||||
| 		</div> | 		</div> | ||||||
| 		<header v-if="title"><Mfm :text="title"/></header> | 		<header v-if="title"><Mfm :text="title"/></header> | ||||||
| 		<div class="body" v-if="text"><Mfm :text="text"/></div> | 		<div class="body" v-if="text"><Mfm :text="text"/></div> | ||||||
| @@ -38,12 +38,10 @@ | |||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent } from 'vue'; | import { defineComponent } from 'vue'; | ||||||
| import { faSpinner, faInfoCircle, faExclamationTriangle, faCheck } from '@fortawesome/free-solid-svg-icons'; | import MkModal from '@client/components/ui/modal.vue'; | ||||||
| import { faTimesCircle, faQuestionCircle } from '@fortawesome/free-regular-svg-icons'; | import MkButton from '@client/components/ui/button.vue'; | ||||||
| import MkModal from '@/components/ui/modal.vue'; | import MkInput from '@client/components/ui/input.vue'; | ||||||
| import MkButton from '@/components/ui/button.vue'; | import MkSelect from '@client/components/ui/select.vue'; | ||||||
| import MkInput from '@/components/ui/input.vue'; |  | ||||||
| import MkSelect from '@/components/ui/select.vue'; |  | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	components: { | 	components: { | ||||||
| @@ -99,7 +97,6 @@ export default defineComponent({ | |||||||
| 		return { | 		return { | ||||||
| 			inputValue: this.input && this.input.default ? this.input.default : null, | 			inputValue: this.input && this.input.default ? this.input.default : null, | ||||||
| 			selectedValue: this.select ? this.select.default ? this.select.default : this.select.items ? this.select.items[0].value : this.select.groupedItems[0].items[0].value : null, | 			selectedValue: this.select ? this.select.default ? this.select.default : this.select.items ? this.select.items[0].value : this.select.groupedItems[0].items[0].value : null, | ||||||
| 			faTimesCircle, faQuestionCircle, faSpinner, faInfoCircle, faExclamationTriangle, faCheck |  | ||||||
| 		}; | 		}; | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,33 +1,23 @@ | |||||||
| <template> | <template> | ||||||
| <div class="zdjebgpv" ref="thumbnail"> | <div class="zdjebgpv" ref="thumbnail"> | ||||||
| 	<ImgWithBlurhash v-if="isThumbnailAvailable" :hash="file.blurhash" :src="file.thumbnailUrl" :alt="file.name" :title="file.name" :style="`object-fit: ${ fit }`"/> | 	<ImgWithBlurhash v-if="isThumbnailAvailable" :hash="file.blurhash" :src="file.thumbnailUrl" :alt="file.name" :title="file.name" :style="`object-fit: ${ fit }`"/> | ||||||
| 	<Fa :icon="faFileImage" class="icon" v-else-if="is === 'image'"/> | 	<i v-else-if="is === 'image'" class="fas fa-file-image icon"></i> | ||||||
| 	<Fa :icon="faFileVideo" class="icon" v-else-if="is === 'video'"/> | 	<i v-else-if="is === 'video'" class="fas fa-file-video icon"></i> | ||||||
| 	<Fa :icon="faMusic" class="icon" v-else-if="is === 'audio' || is === 'midi'"/> | 	<i v-else-if="is === 'audio' || is === 'midi'" class="fas fa-music icon"></i> | ||||||
| 	<Fa :icon="faFileCsv" class="icon" v-else-if="is === 'csv'"/> | 	<i v-else-if="is === 'csv'" class="fas fa-file-csv icon"></i> | ||||||
| 	<Fa :icon="faFilePdf" class="icon" v-else-if="is === 'pdf'"/> | 	<i v-else-if="is === 'pdf'" class="fas fa-file-pdf icon"></i> | ||||||
| 	<Fa :icon="faFileAlt" class="icon" v-else-if="is === 'textfile'"/> | 	<i v-else-if="is === 'textfile'" class="fas fa-file-alt icon"></i> | ||||||
| 	<Fa :icon="faFileArchive" class="icon" v-else-if="is === 'archive'"/> | 	<i v-else-if="is === 'archive'" class="fas fa-file-archive icon"></i> | ||||||
| 	<Fa :icon="faFile" class="icon" v-else/> | 	<i v-else class="fas fa-file icon"></i> | ||||||
| 	<Fa :icon="faFilm" class="icon-sub" v-if="isThumbnailAvailable && is === 'video'"/> |  | ||||||
|  | 	<i v-if="isThumbnailAvailable && is === 'video'" class="fas fa-film icon-sub"></i> | ||||||
| </div> | </div> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent } from 'vue'; | import { defineComponent } from 'vue'; | ||||||
| import { | import ImgWithBlurhash from '@client/components/img-with-blurhash.vue'; | ||||||
| 	faFile, | import { ColdDeviceStorage } from '@client/store'; | ||||||
| 	faFileAlt, |  | ||||||
| 	faFileImage, |  | ||||||
| 	faMusic, |  | ||||||
| 	faFileVideo, |  | ||||||
| 	faFileCsv, |  | ||||||
| 	faFilePdf, |  | ||||||
| 	faFileArchive, |  | ||||||
| 	faFilm |  | ||||||
| 	} from '@fortawesome/free-solid-svg-icons'; |  | ||||||
| import ImgWithBlurhash from './img-with-blurhash.vue'; |  | ||||||
| import { ColdDeviceStorage } from '@/store'; |  | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	components: { | 	components: { | ||||||
| @@ -49,15 +39,6 @@ export default defineComponent({ | |||||||
| 			isContextmenuShowing: false, | 			isContextmenuShowing: false, | ||||||
| 			isDragging: false, | 			isDragging: false, | ||||||
|  |  | ||||||
| 			faFile, |  | ||||||
| 			faFileAlt, |  | ||||||
| 			faFileImage, |  | ||||||
| 			faMusic, |  | ||||||
| 			faFileVideo, |  | ||||||
| 			faFileCsv, |  | ||||||
| 			faFilePdf, |  | ||||||
| 			faFileArchive, |  | ||||||
| 			faFilm |  | ||||||
| 		}; | 		}; | ||||||
| 	}, | 	}, | ||||||
| 	computed: { | 	computed: { | ||||||
|   | |||||||
| @@ -20,8 +20,8 @@ | |||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent } from 'vue'; | import { defineComponent } from 'vue'; | ||||||
| import XDrive from './drive.vue'; | import XDrive from './drive.vue'; | ||||||
| import XModalWindow from '@/components/ui/modal-window.vue'; | import XModalWindow from '@client/components/ui/modal-window.vue'; | ||||||
| import number from '@/filters/number'; | import number from '@client/filters/number'; | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	components: { | 	components: { | ||||||
|   | |||||||
| @@ -15,7 +15,7 @@ | |||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent } from 'vue'; | import { defineComponent } from 'vue'; | ||||||
| import XDrive from './drive.vue'; | import XDrive from './drive.vue'; | ||||||
| import XWindow from '@/components/ui/window.vue'; | import XWindow from '@client/components/ui/window.vue'; | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	components: { | 	components: { | ||||||
|   | |||||||
| @@ -32,12 +32,10 @@ | |||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent } from 'vue'; | import { defineComponent } from 'vue'; | ||||||
| import { faEye, faEyeSlash } from '@fortawesome/free-regular-svg-icons'; | import copyToClipboard from '@client/scripts/copy-to-clipboard'; | ||||||
| import { faDownload, faLink, faICursor, faTrashAlt } from '@fortawesome/free-solid-svg-icons'; |  | ||||||
| import copyToClipboard from '@/scripts/copy-to-clipboard'; |  | ||||||
| import MkDriveFileThumbnail from './drive-file-thumbnail.vue'; | import MkDriveFileThumbnail from './drive-file-thumbnail.vue'; | ||||||
| import bytes from '@/filters/bytes'; | import bytes from '@client/filters/bytes'; | ||||||
| import * as os from '@/os'; | import * as os from '@client/os'; | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	components: { | 	components: { | ||||||
| @@ -83,26 +81,30 @@ export default defineComponent({ | |||||||
| 		getMenu() { | 		getMenu() { | ||||||
| 			return [{ | 			return [{ | ||||||
| 				text: this.$ts.rename, | 				text: this.$ts.rename, | ||||||
| 				icon: faICursor, | 				icon: 'fas fa-i-cursor', | ||||||
| 				action: this.rename | 				action: this.rename | ||||||
| 			}, { | 			}, { | ||||||
| 				text: this.file.isSensitive ? this.$ts.unmarkAsSensitive : this.$ts.markAsSensitive, | 				text: this.file.isSensitive ? this.$ts.unmarkAsSensitive : this.$ts.markAsSensitive, | ||||||
| 				icon: this.file.isSensitive ? faEye : faEyeSlash, | 				icon: this.file.isSensitive ? 'fas fa-eye' : 'fas fa-eye-slash', | ||||||
| 				action: this.toggleSensitive | 				action: this.toggleSensitive | ||||||
|  | 			}, { | ||||||
|  | 				text: this.$ts.describeFile, | ||||||
|  | 				icon: 'fas fa-i-cursor', | ||||||
|  | 				action: this.describe | ||||||
| 			}, null, { | 			}, null, { | ||||||
| 				text: this.$ts.copyUrl, | 				text: this.$ts.copyUrl, | ||||||
| 				icon: faLink, | 				icon: 'fas fa-link', | ||||||
| 				action: this.copyUrl | 				action: this.copyUrl | ||||||
| 			}, { | 			}, { | ||||||
| 				type: 'a', | 				type: 'a', | ||||||
| 				href: this.file.url, | 				href: this.file.url, | ||||||
| 				target: '_blank', | 				target: '_blank', | ||||||
| 				text: this.$ts.download, | 				text: this.$ts.download, | ||||||
| 				icon: faDownload, | 				icon: 'fas fa-download', | ||||||
| 				download: this.file.name | 				download: this.file.name | ||||||
| 			}, null, { | 			}, null, { | ||||||
| 				text: this.$ts.delete, | 				text: this.$ts.delete, | ||||||
| 				icon: faTrashAlt, | 				icon: 'fas fa-trash-alt', | ||||||
| 				danger: true, | 				danger: true, | ||||||
| 				action: this.deleteFile | 				action: this.deleteFile | ||||||
| 			}]; | 			}]; | ||||||
| @@ -152,6 +154,26 @@ export default defineComponent({ | |||||||
| 			}); | 			}); | ||||||
| 		}, | 		}, | ||||||
|  |  | ||||||
|  | 		describe() { | ||||||
|  | 			os.popup(import('@client/components/media-caption.vue'), { | ||||||
|  | 				title: this.$ts.describeFile, | ||||||
|  | 				input: { | ||||||
|  | 					placeholder: this.$ts.inputNewDescription, | ||||||
|  | 					default: this.file.comment !== null ? this.file.comment : '', | ||||||
|  | 				}, | ||||||
|  | 				image: this.file | ||||||
|  | 			}, { | ||||||
|  | 				done: result => { | ||||||
|  | 					if (!result || result.canceled) return; | ||||||
|  | 					let comment = result.result; | ||||||
|  | 					os.api('drive/files/update', { | ||||||
|  | 						fileId: this.file.id, | ||||||
|  | 						comment: comment.length == 0 ? null : comment | ||||||
|  | 					}); | ||||||
|  | 				} | ||||||
|  | 			}, 'closed'); | ||||||
|  | 		}, | ||||||
|  |  | ||||||
| 		toggleSensitive() { | 		toggleSensitive() { | ||||||
| 			os.api('drive/files/update', { | 			os.api('drive/files/update', { | ||||||
| 				fileId: this.file.id, | 				fileId: this.file.id, | ||||||
| @@ -330,8 +352,8 @@ export default defineComponent({ | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	> .thumbnail { | 	> .thumbnail { | ||||||
| 		width: 128px; | 		width: 110px; | ||||||
| 		height: 128px; | 		height: 110px; | ||||||
| 		margin: auto; | 		margin: auto; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -15,8 +15,8 @@ | |||||||
| 	:title="title" | 	:title="title" | ||||||
| > | > | ||||||
| 	<p class="name"> | 	<p class="name"> | ||||||
| 		<template v-if="hover"><Fa :icon="faFolderOpen" fixed-width/></template> | 		<template v-if="hover"><i class="fas fa-folder-open fa-fw"></i></template> | ||||||
| 		<template v-if="!hover"><Fa :icon="faFolder" fixed-width/></template> | 		<template v-if="!hover"><i class="fas fa-folder fa-fw"></i></template> | ||||||
| 		{{ folder.name }} | 		{{ folder.name }} | ||||||
| 	</p> | 	</p> | ||||||
| 	<p class="upload" v-if="$store.state.uploadFolder == folder.id"> | 	<p class="upload" v-if="$store.state.uploadFolder == folder.id"> | ||||||
| @@ -28,9 +28,7 @@ | |||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent } from 'vue'; | import { defineComponent } from 'vue'; | ||||||
| import { faFolder, faFolderOpen, faTrashAlt, faWindowRestore } from '@fortawesome/free-regular-svg-icons'; | import * as os from '@client/os'; | ||||||
| import * as os from '@/os'; |  | ||||||
| import { faICursor } from '@fortawesome/free-solid-svg-icons'; |  | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	props: { | 	props: { | ||||||
| @@ -57,7 +55,6 @@ export default defineComponent({ | |||||||
| 			hover: false, | 			hover: false, | ||||||
| 			draghover: false, | 			draghover: false, | ||||||
| 			isDragging: false, | 			isDragging: false, | ||||||
| 			faFolder, faFolderOpen |  | ||||||
| 		}; | 		}; | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| @@ -241,7 +238,7 @@ export default defineComponent({ | |||||||
| 		onContextmenu(e) { | 		onContextmenu(e) { | ||||||
| 			os.contextMenu([{ | 			os.contextMenu([{ | ||||||
| 				text: this.$ts.openInWindow, | 				text: this.$ts.openInWindow, | ||||||
| 				icon: faWindowRestore, | 				icon: 'fas fa-window-restore', | ||||||
| 				action: () => { | 				action: () => { | ||||||
| 					os.popup(import('./drive-window.vue'), { | 					os.popup(import('./drive-window.vue'), { | ||||||
| 						initialFolder: this.folder | 						initialFolder: this.folder | ||||||
| @@ -250,11 +247,11 @@ export default defineComponent({ | |||||||
| 				} | 				} | ||||||
| 			}, null, { | 			}, null, { | ||||||
| 				text: this.$ts.rename, | 				text: this.$ts.rename, | ||||||
| 				icon: faICursor, | 				icon: 'fas fa-i-cursor', | ||||||
| 				action: this.rename | 				action: this.rename | ||||||
| 			}, null, { | 			}, null, { | ||||||
| 				text: this.$ts.delete, | 				text: this.$ts.delete, | ||||||
| 				icon: faTrashAlt, | 				icon: 'fas fa-trash-alt', | ||||||
| 				danger: true, | 				danger: true, | ||||||
| 				action: this.deleteFolder | 				action: this.deleteFolder | ||||||
| 			}], e); | 			}], e); | ||||||
| @@ -312,7 +309,7 @@ export default defineComponent({ | |||||||
| 		font-size: 0.9em; | 		font-size: 0.9em; | ||||||
| 		color: var(--desktopDriveFolderFg); | 		color: var(--desktopDriveFolderFg); | ||||||
|  |  | ||||||
| 		> [data-icon] { | 		> i { | ||||||
| 			margin-right: 4px; | 			margin-right: 4px; | ||||||
| 			margin-left: 2px; | 			margin-left: 2px; | ||||||
| 			text-align: left; | 			text-align: left; | ||||||
|   | |||||||
| @@ -7,15 +7,14 @@ | |||||||
| 	@dragleave="onDragleave" | 	@dragleave="onDragleave" | ||||||
| 	@drop.stop="onDrop" | 	@drop.stop="onDrop" | ||||||
| > | > | ||||||
| 	<i v-if="folder == null"><Fa :icon="faCloud"/></i> | 	<i v-if="folder == null" class="fas fa-cloud"></i> | ||||||
| 	<span>{{ folder == null ? $ts.drive : folder.name }}</span> | 	<span>{{ folder == null ? $ts.drive : folder.name }}</span> | ||||||
| </div> | </div> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent } from 'vue'; | import { defineComponent } from 'vue'; | ||||||
| import { faCloud } from '@fortawesome/free-solid-svg-icons'; | import * as os from '@client/os'; | ||||||
| import * as os from '@/os'; |  | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	props: { | 	props: { | ||||||
| @@ -29,7 +28,6 @@ export default defineComponent({ | |||||||
| 		return { | 		return { | ||||||
| 			hover: false, | 			hover: false, | ||||||
| 			draghover: false, | 			draghover: false, | ||||||
| 			faCloud |  | ||||||
| 		}; | 		}; | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,14 +4,14 @@ | |||||||
| 		<div class="path" @contextmenu.prevent.stop="() => {}"> | 		<div class="path" @contextmenu.prevent.stop="() => {}"> | ||||||
| 			<XNavFolder :class="{ current: folder == null }"/> | 			<XNavFolder :class="{ current: folder == null }"/> | ||||||
| 			<template v-for="f in hierarchyFolders"> | 			<template v-for="f in hierarchyFolders"> | ||||||
| 				<span class="separator"><Fa :icon="faAngleRight"/></span> | 				<span class="separator"><i class="fas fa-angle-right"></i></span> | ||||||
| 				<XNavFolder :folder="f"/> | 				<XNavFolder :folder="f"/> | ||||||
| 			</template> | 			</template> | ||||||
| 			<span class="separator" v-if="folder != null"><Fa :icon="faAngleRight"/></span> | 			<span class="separator" v-if="folder != null"><i class="fas fa-angle-right"></i></span> | ||||||
| 			<span class="folder current" v-if="folder != null">{{ folder.name }}</span> | 			<span class="folder current" v-if="folder != null">{{ folder.name }}</span> | ||||||
| 		</div> | 		</div> | ||||||
| 	</nav> | 	</nav> | ||||||
| 	<div class="main _section" :class="{ uploading: uploadings.length > 0, fetching }" | 	<div class="main" :class="{ uploading: uploadings.length > 0, fetching }" | ||||||
| 		ref="main" | 		ref="main" | ||||||
| 		@dragover.prevent.stop="onDragover" | 		@dragover.prevent.stop="onDragover" | ||||||
| 		@dragenter="onDragenter" | 		@dragenter="onDragenter" | ||||||
| @@ -47,13 +47,11 @@ | |||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent } from 'vue'; | import { defineComponent } from 'vue'; | ||||||
| import { faAngleRight, faFolderPlus, faICursor, faLink, faUpload } from '@fortawesome/free-solid-svg-icons'; |  | ||||||
| import XNavFolder from './drive.nav-folder.vue'; | import XNavFolder from './drive.nav-folder.vue'; | ||||||
| import XFolder from './drive.folder.vue'; | import XFolder from './drive.folder.vue'; | ||||||
| import XFile from './drive.file.vue'; | import XFile from './drive.file.vue'; | ||||||
| import MkButton from './ui/button.vue'; | import MkButton from './ui/button.vue'; | ||||||
| import * as os from '@/os'; | import * as os from '@client/os'; | ||||||
| import { faTrashAlt } from '@fortawesome/free-regular-svg-icons'; |  | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	components: { | 	components: { | ||||||
| @@ -125,7 +123,6 @@ export default defineComponent({ | |||||||
| 			), | 			), | ||||||
| 			moreFilesElement: null as Element, | 			moreFilesElement: null as Element, | ||||||
|  |  | ||||||
| 			faAngleRight |  | ||||||
| 		}; | 		}; | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| @@ -142,7 +139,7 @@ export default defineComponent({ | |||||||
| 			}); | 			}); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		this.connection = os.stream.useSharedConnection('drive'); | 		this.connection = os.stream.useChannel('drive'); | ||||||
|  |  | ||||||
| 		this.connection.on('fileCreated', this.onStreamDriveFileCreated); | 		this.connection.on('fileCreated', this.onStreamDriveFileCreated); | ||||||
| 		this.connection.on('fileUpdated', this.onStreamDriveFileUpdated); | 		this.connection.on('fileUpdated', this.onStreamDriveFileUpdated); | ||||||
| @@ -304,7 +301,7 @@ export default defineComponent({ | |||||||
| 				} | 				} | ||||||
| 			}).then(({ canceled, result: url }) => { | 			}).then(({ canceled, result: url }) => { | ||||||
| 				if (canceled) return; | 				if (canceled) return; | ||||||
| 				os.api('drive/files/upload_from_url', { | 				os.api('drive/files/upload-from-url', { | ||||||
| 					url: url, | 					url: url, | ||||||
| 					folderId: this.folder ? this.folder.id : undefined | 					folderId: this.folder ? this.folder.id : undefined | ||||||
| 				}); | 				}); | ||||||
| @@ -606,26 +603,26 @@ export default defineComponent({ | |||||||
| 				type: 'label' | 				type: 'label' | ||||||
| 			}, { | 			}, { | ||||||
| 				text: this.$ts.upload, | 				text: this.$ts.upload, | ||||||
| 				icon: faUpload, | 				icon: 'fas fa-upload', | ||||||
| 				action: () => { this.selectLocalFile(); } | 				action: () => { this.selectLocalFile(); } | ||||||
| 			}, { | 			}, { | ||||||
| 				text: this.$ts.fromUrl, | 				text: this.$ts.fromUrl, | ||||||
| 				icon: faLink, | 				icon: 'fas fa-link', | ||||||
| 				action: () => { this.urlUpload(); } | 				action: () => { this.urlUpload(); } | ||||||
| 			}, null, { | 			}, null, { | ||||||
| 				text: this.folder ? this.folder.name : this.$ts.drive, | 				text: this.folder ? this.folder.name : this.$ts.drive, | ||||||
| 				type: 'label' | 				type: 'label' | ||||||
| 			}, this.folder ? { | 			}, this.folder ? { | ||||||
| 				text: this.$ts.renameFolder, | 				text: this.$ts.renameFolder, | ||||||
| 				icon: faICursor, | 				icon: 'fas fa-i-cursor', | ||||||
| 				action: () => { this.renameFolder(this.folder); } | 				action: () => { this.renameFolder(this.folder); } | ||||||
| 			} : undefined, this.folder ? { | 			} : undefined, this.folder ? { | ||||||
| 				text: this.$ts.deleteFolder, | 				text: this.$ts.deleteFolder, | ||||||
| 				icon: faTrashAlt, | 				icon: 'fas fa-trash-alt', | ||||||
| 				action: () => { this.deleteFolder(this.folder); } | 				action: () => { this.deleteFolder(this.folder); } | ||||||
| 			} : undefined, { | 			} : undefined, { | ||||||
| 				text: this.$ts.createFolder, | 				text: this.$ts.createFolder, | ||||||
| 				icon: faFolderPlus, | 				icon: 'fas fa-folder-plus', | ||||||
| 				action: () => { this.createFolder(); } | 				action: () => { this.createFolder(); } | ||||||
| 			}]; | 			}]; | ||||||
| 		}, | 		}, | ||||||
| @@ -693,7 +690,7 @@ export default defineComponent({ | |||||||
| 					opacity: 0.5; | 					opacity: 0.5; | ||||||
| 					cursor: default; | 					cursor: default; | ||||||
|  |  | ||||||
| 					> [data-icon] { | 					> i { | ||||||
| 						margin: 0; | 						margin: 0; | ||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
| @@ -704,6 +701,7 @@ export default defineComponent({ | |||||||
| 	> .main { | 	> .main { | ||||||
| 		flex: 1; | 		flex: 1; | ||||||
| 		overflow: auto; | 		overflow: auto; | ||||||
|  | 		padding: var(--margin); | ||||||
|  |  | ||||||
| 		&, * { | 		&, * { | ||||||
| 			user-select: none; | 			user-select: none; | ||||||
| @@ -735,7 +733,7 @@ export default defineComponent({ | |||||||
| 				> .folder, | 				> .folder, | ||||||
| 				> .file { | 				> .file { | ||||||
| 					flex-grow: 1; | 					flex-grow: 1; | ||||||
| 					width: 144px; | 					width: 128px; | ||||||
| 					margin: 4px; | 					margin: 4px; | ||||||
| 					box-sizing: border-box; | 					box-sizing: border-box; | ||||||
| 				} | 				} | ||||||
| @@ -743,7 +741,7 @@ export default defineComponent({ | |||||||
| 				> .padding { | 				> .padding { | ||||||
| 					flex-grow: 1; | 					flex-grow: 1; | ||||||
| 					pointer-events: none; | 					pointer-events: none; | ||||||
| 					width: 144px + 8px; | 					width: 128px + 8px; | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,13 +1,13 @@ | |||||||
| <template> | <template> | ||||||
| <MkModal ref="modal" :manual-showing="manualShowing" :src="src" @click="$refs.modal.close()" @opening="opening" @close="$emit('close')" @closed="$emit('closed')"> | <MkModal ref="modal" :manual-showing="manualShowing" :src="src" :front="true" @click="$refs.modal.close()" @opening="opening" @close="$emit('close')" @closed="$emit('closed')"> | ||||||
| 	<MkEmojiPicker :show-pinned="showPinned" :as-reaction-picker="asReactionPicker" @chosen="chosen" ref="picker"/> | 	<MkEmojiPicker :show-pinned="showPinned" :as-reaction-picker="asReactionPicker" @chosen="chosen" ref="picker"/> | ||||||
| </MkModal> | </MkModal> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent, markRaw } from 'vue'; | import { defineComponent, markRaw } from 'vue'; | ||||||
| import MkModal from '@/components/ui/modal.vue'; | import MkModal from '@client/components/ui/modal.vue'; | ||||||
| import MkEmojiPicker from '@/components/emoji-picker.vue'; | import MkEmojiPicker from '@client/components/emoji-picker.vue'; | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	components: { | 	components: { | ||||||
| @@ -123,7 +123,7 @@ export default defineComponent({ | |||||||
| 		> .index { | 		> .index { | ||||||
| 			min-height: var(--height); | 			min-height: var(--height); | ||||||
| 			position: relative; | 			position: relative; | ||||||
| 			border-bottom: solid 1px var(--divider); | 			border-bottom: solid 0.5px var(--divider); | ||||||
| 				 | 				 | ||||||
| 			> .arrow { | 			> .arrow { | ||||||
| 				position: absolute; | 				position: absolute; | ||||||
| @@ -181,7 +181,7 @@ export default defineComponent({ | |||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 			&.result { | 			&.result { | ||||||
| 				border-bottom: solid 1px var(--divider); | 				border-bottom: solid 0.5px var(--divider); | ||||||
|  |  | ||||||
| 				&:empty { | 				&:empty { | ||||||
| 					display: none; | 					display: none; | ||||||
|   | |||||||
| @@ -13,8 +13,8 @@ | |||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent, markRaw } from 'vue'; | import { defineComponent, markRaw } from 'vue'; | ||||||
| import MkWindow from '@/components/ui/window.vue'; | import MkWindow from '@client/components/ui/window.vue'; | ||||||
| import MkEmojiPicker from '@/components/emoji-picker.vue'; | import MkEmojiPicker from '@client/components/emoji-picker.vue'; | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	components: { | 	components: { | ||||||
| @@ -119,7 +119,7 @@ export default defineComponent({ | |||||||
| 		> .index { | 		> .index { | ||||||
| 			min-height: var(--height); | 			min-height: var(--height); | ||||||
| 			position: relative; | 			position: relative; | ||||||
| 			border-bottom: solid 1px var(--divider); | 			border-bottom: solid 0.5px var(--divider); | ||||||
| 				 | 				 | ||||||
| 			> .arrow { | 			> .arrow { | ||||||
| 				position: absolute; | 				position: absolute; | ||||||
| @@ -177,7 +177,7 @@ export default defineComponent({ | |||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 			&.result { | 			&.result { | ||||||
| 				border-bottom: solid 1px var(--divider); | 				border-bottom: solid 0.5px var(--divider); | ||||||
|  |  | ||||||
| 				&:empty { | 				&:empty { | ||||||
| 					display: none; | 					display: none; | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| <template> | <template> | ||||||
| <section> | <section> | ||||||
| 	<header class="_acrylic" @click="shown = !shown"> | 	<header class="_acrylic" @click="shown = !shown"> | ||||||
| 		<Fa :icon="shown ? faChevronDown : faChevronUp" :key="shown" fixed-width class="toggle"/> <slot></slot> ({{ emojis.length }}) | 		<i class="toggle fa-fw" :class="shown ? 'fas fa-chevron-down' : 'fas fa-chevron-up'"></i> <slot></slot> ({{ emojis.length }}) | ||||||
| 	</header> | 	</header> | ||||||
| 	<div v-if="shown"> | 	<div v-if="shown"> | ||||||
| 		<button v-for="emoji in emojis" | 		<button v-for="emoji in emojis" | ||||||
| @@ -17,8 +17,7 @@ | |||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent, markRaw } from 'vue'; | import { defineComponent, markRaw } from 'vue'; | ||||||
| import { faChevronUp, faChevronDown } from '@fortawesome/free-solid-svg-icons'; | import { getStaticImageUrl } from '@client/scripts/get-static-image-url'; | ||||||
| import { getStaticImageUrl } from '@/scripts/get-static-image-url'; |  | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	props: { | 	props: { | ||||||
| @@ -36,7 +35,6 @@ export default defineComponent({ | |||||||
| 		return { | 		return { | ||||||
| 			getStaticImageUrl, | 			getStaticImageUrl, | ||||||
| 			shown: this.initialShown, | 			shown: this.initialShown, | ||||||
| 			faChevronUp, faChevronDown, |  | ||||||
| 		}; | 		}; | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
|   | |||||||
| @@ -35,6 +35,7 @@ | |||||||
| 						class="_button" | 						class="_button" | ||||||
| 						@click="chosen(emoji, $event)" | 						@click="chosen(emoji, $event)" | ||||||
| 						tabindex="0" | 						tabindex="0" | ||||||
|  | 						:key="emoji" | ||||||
| 					> | 					> | ||||||
| 						<MkEmoji :emoji="emoji" :normal="true"/> | 						<MkEmoji :emoji="emoji" :normal="true"/> | ||||||
| 					</button> | 					</button> | ||||||
| @@ -42,7 +43,7 @@ | |||||||
| 			</section> | 			</section> | ||||||
|  |  | ||||||
| 			<section> | 			<section> | ||||||
| 				<header class="_acrylic"><Fa :icon="faClock" fixed-width/> {{ $ts.recentUsed }}</header> | 				<header class="_acrylic"><i class="far fa-clock fa-fw"></i> {{ $ts.recentUsed }}</header> | ||||||
| 				<div> | 				<div> | ||||||
| 					<button v-for="emoji in $store.state.recentlyUsedEmojis" | 					<button v-for="emoji in $store.state.recentlyUsedEmojis" | ||||||
| 						class="_button" | 						class="_button" | ||||||
| @@ -64,25 +65,23 @@ | |||||||
| 		</div> | 		</div> | ||||||
| 	</div> | 	</div> | ||||||
| 	<div class="tabs"> | 	<div class="tabs"> | ||||||
| 		<button class="_button tab" :class="{ active: tab === 'index' }" @click="tab = 'index'"><Fa :icon="faAsterisk" fixed-width/></button> | 		<button class="_button tab" :class="{ active: tab === 'index' }" @click="tab = 'index'"><i class="fas fa-asterisk fa-fw"></i></button> | ||||||
| 		<button class="_button tab" :class="{ active: tab === 'custom' }" @click="tab = 'custom'"><Fa :icon="faLaugh" fixed-width/></button> | 		<button class="_button tab" :class="{ active: tab === 'custom' }" @click="tab = 'custom'"><i class="fas fa-laugh fa-fw"></i></button> | ||||||
| 		<button class="_button tab" :class="{ active: tab === 'unicode' }" @click="tab = 'unicode'"><Fa :icon="faLeaf" fixed-width/></button> | 		<button class="_button tab" :class="{ active: tab === 'unicode' }" @click="tab = 'unicode'"><i class="fas fa-leaf fa-fw"></i></button> | ||||||
| 		<button class="_button tab" :class="{ active: tab === 'tags' }" @click="tab = 'tags'"><Fa :icon="faHashtag" fixed-width/></button> | 		<button class="_button tab" :class="{ active: tab === 'tags' }" @click="tab = 'tags'"><i class="fas fa-hashtag fa-fw"></i></button> | ||||||
| 	</div> | 	</div> | ||||||
| </div> | </div> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent, markRaw } from 'vue'; | import { defineComponent, markRaw } from 'vue'; | ||||||
| import { emojilist } from '../../misc/emojilist'; | import { emojilist } from '@/misc/emojilist'; | ||||||
| import { getStaticImageUrl } from '@/scripts/get-static-image-url'; | import { getStaticImageUrl } from '@client/scripts/get-static-image-url'; | ||||||
| import { faAsterisk, faLeaf, faUtensils, faFutbol, faCity, faDice, faGlobe, faClock, faUser, faChevronDown, faShapes, faBicycle, faHashtag } from '@fortawesome/free-solid-svg-icons'; | import Particle from '@client/components/particle.vue'; | ||||||
| import { faHeart, faFlag, faLaugh } from '@fortawesome/free-regular-svg-icons'; | import * as os from '@client/os'; | ||||||
| import Particle from '@/components/particle.vue'; | import { isDeviceTouch } from '@client/scripts/is-device-touch'; | ||||||
| import * as os from '@/os'; | import { isMobile } from '@client/scripts/is-mobile'; | ||||||
| import { isDeviceTouch } from '@/scripts/is-device-touch'; | import { emojiCategories } from '@client/instance'; | ||||||
| import { isMobile } from '@/scripts/is-mobile'; |  | ||||||
| import { emojiCategories } from '@/instance'; |  | ||||||
| import XSection from './emoji-picker.section.vue'; | import XSection from './emoji-picker.section.vue'; | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| @@ -106,7 +105,7 @@ export default defineComponent({ | |||||||
| 		return { | 		return { | ||||||
| 			emojilist: markRaw(emojilist), | 			emojilist: markRaw(emojilist), | ||||||
| 			getStaticImageUrl, | 			getStaticImageUrl, | ||||||
| 			pinned: this.$store.state.reactions, | 			pinned: this.$store.reactiveState.reactions, | ||||||
| 			width: this.asReactionPicker ? this.$store.state.reactionPickerWidth : 3, | 			width: this.asReactionPicker ? this.$store.state.reactionPickerWidth : 3, | ||||||
| 			height: this.asReactionPicker ? this.$store.state.reactionPickerHeight : 2, | 			height: this.asReactionPicker ? this.$store.state.reactionPickerHeight : 2, | ||||||
| 			big: this.asReactionPicker ? isDeviceTouch : false, | 			big: this.asReactionPicker ? isDeviceTouch : false, | ||||||
| @@ -117,7 +116,6 @@ export default defineComponent({ | |||||||
| 			searchResultUnicode: [], | 			searchResultUnicode: [], | ||||||
| 			tab: 'index', | 			tab: 'index', | ||||||
| 			categories: ['face', 'people', 'animals_and_nature', 'food_and_drink', 'activity', 'travel_and_places', 'objects', 'symbols', 'flags'], | 			categories: ['face', 'people', 'animals_and_nature', 'food_and_drink', 'activity', 'travel_and_places', 'objects', 'symbols', 'flags'], | ||||||
| 			faGlobe, faClock, faChevronDown, faAsterisk, faLaugh, faUtensils, faLeaf, faShapes, faBicycle, faHashtag, |  | ||||||
| 		}; | 		}; | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| @@ -402,7 +400,7 @@ export default defineComponent({ | |||||||
| 		> .tab { | 		> .tab { | ||||||
| 			flex: 1; | 			flex: 1; | ||||||
| 			height: 38px; | 			height: 38px; | ||||||
| 			border-top: solid 1px var(--divider); | 			border-top: solid 0.5px var(--divider); | ||||||
|  |  | ||||||
| 			&.active { | 			&.active { | ||||||
| 				border-top: solid 1px var(--accent); | 				border-top: solid 1px var(--accent); | ||||||
| @@ -425,7 +423,7 @@ export default defineComponent({ | |||||||
| 		> div { | 		> div { | ||||||
| 			&:not(.index) { | 			&:not(.index) { | ||||||
| 				padding: 4px 0 8px 0; | 				padding: 4px 0 8px 0; | ||||||
| 				border-top: solid 1px var(--divider); | 				border-top: solid 0.5px var(--divider); | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 			> header { | 			> header { | ||||||
| @@ -492,7 +490,7 @@ export default defineComponent({ | |||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 			&.result { | 			&.result { | ||||||
| 				border-bottom: solid 1px var(--divider); | 				border-bottom: solid 0.5px var(--divider); | ||||||
|  |  | ||||||
| 				&:empty { | 				&:empty { | ||||||
| 					display: none; | 					display: none; | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ | |||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent } from 'vue'; | import { defineComponent } from 'vue'; | ||||||
| import * as os from '@/os'; | import * as os from '@client/os'; | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	components: { | 	components: { | ||||||
|   | |||||||
| @@ -1,13 +1,12 @@ | |||||||
| <template> | <template> | ||||||
| <span class="mk-file-type-icon"> | <span class="mk-file-type-icon"> | ||||||
| 	<template v-if="kind == 'image'"><Fa :icon="faFileImage"/></template> | 	<template v-if="kind == 'image'"><i class="fas fa-file-image"></i></template> | ||||||
| </span> | </span> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent } from 'vue'; | import { defineComponent } from 'vue'; | ||||||
| import { faFileImage } from '@fortawesome/free-solid-svg-icons'; | import * as os from '@client/os'; | ||||||
| import * as os from '@/os'; |  | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	props: { | 	props: { | ||||||
| @@ -18,7 +17,6 @@ export default defineComponent({ | |||||||
| 	}, | 	}, | ||||||
| 	data() { | 	data() { | ||||||
| 		return { | 		return { | ||||||
| 			faFileImage |  | ||||||
| 		}; | 		}; | ||||||
| 	}, | 	}, | ||||||
| 	computed: { | 	computed: { | ||||||
|   | |||||||
| @@ -6,31 +6,30 @@ | |||||||
| > | > | ||||||
| 	<template v-if="!wait"> | 	<template v-if="!wait"> | ||||||
| 		<template v-if="hasPendingFollowRequestFromYou && user.isLocked"> | 		<template v-if="hasPendingFollowRequestFromYou && user.isLocked"> | ||||||
| 			<span v-if="full">{{ $ts.followRequestPending }}</span><Fa :icon="faHourglassHalf"/> | 			<span v-if="full">{{ $ts.followRequestPending }}</span><i class="fas fa-hourglass-half"></i> | ||||||
| 		</template> | 		</template> | ||||||
| 		<template v-else-if="hasPendingFollowRequestFromYou && !user.isLocked"> <!-- つまりリモートフォローの場合。 --> | 		<template v-else-if="hasPendingFollowRequestFromYou && !user.isLocked"> <!-- つまりリモートフォローの場合。 --> | ||||||
| 			<span v-if="full">{{ $ts.processing }}</span><Fa :icon="faSpinner" pulse/> | 			<span v-if="full">{{ $ts.processing }}</span><i class="fas fa-spinner fa-pulse"></i> | ||||||
| 		</template> | 		</template> | ||||||
| 		<template v-else-if="isFollowing"> | 		<template v-else-if="isFollowing"> | ||||||
| 			<span v-if="full">{{ $ts.unfollow }}</span><Fa :icon="faMinus"/> | 			<span v-if="full">{{ $ts.unfollow }}</span><i class="fas fa-minus"></i> | ||||||
| 		</template> | 		</template> | ||||||
| 		<template v-else-if="!isFollowing && user.isLocked"> | 		<template v-else-if="!isFollowing && user.isLocked"> | ||||||
| 			<span v-if="full">{{ $ts.followRequest }}</span><Fa :icon="faPlus"/> | 			<span v-if="full">{{ $ts.followRequest }}</span><i class="fas fa-plus"></i> | ||||||
| 		</template> | 		</template> | ||||||
| 		<template v-else-if="!isFollowing && !user.isLocked"> | 		<template v-else-if="!isFollowing && !user.isLocked"> | ||||||
| 			<span v-if="full">{{ $ts.follow }}</span><Fa :icon="faPlus"/> | 			<span v-if="full">{{ $ts.follow }}</span><i class="fas fa-plus"></i> | ||||||
| 		</template> | 		</template> | ||||||
| 	</template> | 	</template> | ||||||
| 	<template v-else> | 	<template v-else> | ||||||
| 		<span v-if="full">{{ $ts.processing }}</span><Fa :icon="faSpinner" pulse fixed-width/> | 		<span v-if="full">{{ $ts.processing }}</span><i class="fas fa-spinner fa-pulse fa-fw"></i> | ||||||
| 	</template> | 	</template> | ||||||
| </button> | </button> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent } from 'vue'; | import { defineComponent } from 'vue'; | ||||||
| import { faSpinner, faPlus, faMinus, faHourglassHalf } from '@fortawesome/free-solid-svg-icons'; | import * as os from '@client/os'; | ||||||
| import * as os from '@/os'; |  | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	props: { | 	props: { | ||||||
| @@ -56,7 +55,6 @@ export default defineComponent({ | |||||||
| 			hasPendingFollowRequestFromYou: this.user.hasPendingFollowRequestFromYou, | 			hasPendingFollowRequestFromYou: this.user.hasPendingFollowRequestFromYou, | ||||||
| 			wait: false, | 			wait: false, | ||||||
| 			connection: null, | 			connection: null, | ||||||
| 			faSpinner, faPlus, faMinus, faHourglassHalf |  | ||||||
| 		}; | 		}; | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| @@ -73,7 +71,7 @@ export default defineComponent({ | |||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| 	mounted() { | 	mounted() { | ||||||
| 		this.connection = os.stream.useSharedConnection('main'); | 		this.connection = os.stream.useChannel('main'); | ||||||
|  |  | ||||||
| 		this.connection.on('follow', this.onFollowChange); | 		this.connection.on('follow', this.onFollowChange); | ||||||
| 		this.connection.on('unfollow', this.onFollowChange); | 		this.connection.on('unfollow', this.onFollowChange); | ||||||
|   | |||||||
							
								
								
									
										71
									
								
								src/client/components/forgot-password.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										71
									
								
								src/client/components/forgot-password.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,71 @@ | |||||||
|  | <template> | ||||||
|  | <XModalWindow ref="dialog" | ||||||
|  | 	:width="370" | ||||||
|  | 	:height="400" | ||||||
|  | 	@close="$refs.dialog.close()" | ||||||
|  | 	@closed="$emit('closed')" | ||||||
|  | > | ||||||
|  | 	<template #header>{{ $ts.forgotPassword }}</template> | ||||||
|  |  | ||||||
|  | 	<form class="_monolithic_" @submit.prevent="onSubmit" v-if="$instance.enableEmail"> | ||||||
|  | 		<div class="_section"> | ||||||
|  | 			<MkInput v-model:value="username" type="text" pattern="^[a-zA-Z0-9_]+$" spellcheck="false" autofocus required> | ||||||
|  | 				<span>{{ $ts.username }}</span> | ||||||
|  | 				<template #prefix>@</template> | ||||||
|  | 			</MkInput> | ||||||
|  |  | ||||||
|  | 			<MkInput v-model:value="email" type="email" spellcheck="false" required> | ||||||
|  | 				<span>{{ $ts.emailAddress }}</span> | ||||||
|  | 				<template #desc>{{ $ts._forgotPassword.enterEmail }}</template> | ||||||
|  | 			</MkInput> | ||||||
|  |  | ||||||
|  | 			<MkButton type="submit" :disabled="processing" primary style="margin: 0 auto;">{{ $ts.send }}</MkButton> | ||||||
|  | 		</div> | ||||||
|  | 		<div class="_section"> | ||||||
|  | 			<MkA to="/about" class="_link">{{ $ts._forgotPassword.ifNoEmail }}</MkA> | ||||||
|  | 		</div> | ||||||
|  | 	</form> | ||||||
|  | 	<div v-else> | ||||||
|  | 		{{ $ts._forgotPassword.contactAdmin }} | ||||||
|  | 	</div> | ||||||
|  | </XModalWindow> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script lang="ts"> | ||||||
|  | import { defineComponent } from 'vue'; | ||||||
|  | import XModalWindow from '@client/components/ui/modal-window.vue'; | ||||||
|  | import MkButton from '@client/components/ui/button.vue'; | ||||||
|  | import MkInput from '@client/components/ui/input.vue'; | ||||||
|  | import * as os from '@client/os'; | ||||||
|  |  | ||||||
|  | export default defineComponent({ | ||||||
|  | 	components: { | ||||||
|  | 		XModalWindow, | ||||||
|  | 		MkButton, | ||||||
|  | 		MkInput, | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	emits: ['done', 'closed'], | ||||||
|  |  | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			username: '', | ||||||
|  | 			email: '', | ||||||
|  | 			processing: false, | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	methods: { | ||||||
|  | 		async onSubmit() { | ||||||
|  | 			this.processing = true; | ||||||
|  | 			await os.apiWithDialog('request-reset-password', { | ||||||
|  | 				username: this.username, | ||||||
|  | 				email: this.email, | ||||||
|  | 			}); | ||||||
|  |  | ||||||
|  | 			this.$emit('done'); | ||||||
|  | 			this.$refs.dialog.close(); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | }); | ||||||
|  | </script> | ||||||
| @@ -48,7 +48,7 @@ | |||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent } from 'vue'; | import { defineComponent } from 'vue'; | ||||||
| import XModalWindow from '@/components/ui/modal-window.vue'; | import XModalWindow from '@client/components/ui/modal-window.vue'; | ||||||
| import FormBase from './form/base.vue'; | import FormBase from './form/base.vue'; | ||||||
| import FormInput from './form/input.vue'; | import FormInput from './form/input.vue'; | ||||||
| import FormTextarea from './form/textarea.vue'; | import FormTextarea from './form/textarea.vue'; | ||||||
|   | |||||||
| @@ -20,12 +20,21 @@ export default defineComponent({ | |||||||
|  |  | ||||||
| <style lang="scss" scoped> | <style lang="scss" scoped> | ||||||
| .rbusrurv { | .rbusrurv { | ||||||
| 	line-height: 1.4em; | 	// 他のCSSからも参照されるので消さないように | ||||||
|  | 	--formXPadding: 32px; | ||||||
|  | 	--formYPadding: 32px; | ||||||
|  |  | ||||||
|  | 	--formContentHMargin: 16px; | ||||||
|  |  | ||||||
|  | 	font-size: 95%; | ||||||
|  | 	line-height: 1.3em; | ||||||
| 	background: var(--bg); | 	background: var(--bg); | ||||||
| 	padding: 32px; | 	padding: var(--formYPadding) var(--formXPadding); | ||||||
|  | 	max-width: 750px; | ||||||
|  | 	margin: 0 auto; | ||||||
|  |  | ||||||
| 	&:not(.wide).max-width_400px { | 	&:not(.wide).max-width_400px { | ||||||
| 		padding: 32px 0; | 		--formXPadding: 0px; | ||||||
|  |  | ||||||
| 		> ::v-deep(*) { | 		> ::v-deep(*) { | ||||||
| 			._formPanel { | 			._formPanel { | ||||||
| @@ -36,16 +45,16 @@ export default defineComponent({ | |||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 			._form_group { | 			._form_group { | ||||||
| 				> * { | 				> *:not(._formNoConcat) { | ||||||
| 					&:not(:first-child) { | 					&:not(:last-child):not(._formNoConcatPrev) { | ||||||
| 						&._formPanel, ._formPanel { | 						&._formPanel, ._formPanel { | ||||||
| 							border-top: none; | 							border-bottom: solid 0.5px var(--divider); | ||||||
| 						} | 						} | ||||||
| 					} | 					} | ||||||
|  |  | ||||||
| 					&:not(:last-child) { | 					&:not(:first-child):not(._formNoConcatNext) { | ||||||
| 						&._formPanel, ._formPanel { | 						&._formPanel, ._formPanel { | ||||||
| 							border-bottom: solid 0.5px var(--divider); | 							border-top: none; | ||||||
| 						} | 						} | ||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
|   | |||||||
| @@ -1,32 +1,48 @@ | |||||||
| ._formPanel { | ._formPanel { | ||||||
| 	background: var(--panel); | 	background: var(--panel); | ||||||
| 	border-radius: var(--radius); | 	border-radius: var(--radius); | ||||||
|  | 	transition: background 0.2s ease; | ||||||
|  |  | ||||||
| 	&._formClickable { | 	&._formClickable { | ||||||
| 		&:hover { | 		&:hover { | ||||||
| 			//background: var(--panelHighlight); | 			//background: var(--panelHighlight); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|  | 		&:active { | ||||||
|  | 			background: var(--panelHighlight); | ||||||
|  | 			transition: background 0s; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | ._formLabel, | ||||||
|  | ._formCaption { | ||||||
|  | 	font-size: 80%; | ||||||
|  | 	color: var(--fgTransparentWeak); | ||||||
|  |  | ||||||
|  | 	&:empty { | ||||||
|  | 		display: none; | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
| ._formLabel { | ._formLabel { | ||||||
| 	font-size: 80%; | 	position: sticky; | ||||||
| 	padding: 0 16px 8px 16px; | 	top: var(--stickyTop, 0px); | ||||||
| 	opacity: 0.8; | 	z-index: 2; | ||||||
|  | 	margin: -8px calc(var(--formXPadding) * -1) 0 calc(var(--formXPadding) * -1); | ||||||
|  | 	padding: 8px calc(var(--formContentHMargin) + var(--formXPadding)) 8px calc(var(--formContentHMargin) + var(--formXPadding)); | ||||||
|  | 	background: var(--X17); | ||||||
|  | 	-webkit-backdrop-filter: blur(10px); | ||||||
|  | 	backdrop-filter: blur(10px); | ||||||
|  | } | ||||||
|  |  | ||||||
| 	&:empty { | ._themeChanging_ ._formLabel { | ||||||
| 		display: none; | 	transition: none !important; | ||||||
| 	} | 	background: transparent; | ||||||
| } | } | ||||||
|  |  | ||||||
| ._formCaption { | ._formCaption { | ||||||
| 	font-size: 80%; | 	padding: 8px var(--formContentHMargin) 0 var(--formContentHMargin); | ||||||
| 	padding: 8px 16px 0 16px; |  | ||||||
| 	opacity: 0.8; |  | ||||||
|  |  | ||||||
| 	&:empty { |  | ||||||
| 		display: none; |  | ||||||
| 	} |  | ||||||
| } | } | ||||||
|  |  | ||||||
| ._formItem { | ._formItem { | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| <template> | <template> | ||||||
| <div class="vrtktovg _formItem" v-size="{ max: [500] }"> | <div class="vrtktovg _formItem _formNoConcat" v-size="{ max: [500] }" v-sticky-container> | ||||||
| 	<div class="_formLabel"><slot name="label"></slot></div> | 	<div class="_formLabel"><slot name="label"></slot></div> | ||||||
| 	<div class="main _form_group"> | 	<div class="main _form_group" ref="child"> | ||||||
| 		<slot></slot> | 		<slot></slot> | ||||||
| 	</div> | 	</div> | ||||||
| 	<div class="_formCaption"><slot name="caption"></slot></div> | 	<div class="_formCaption"><slot name="caption"></slot></div> | ||||||
| @@ -9,33 +9,69 @@ | |||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent } from 'vue'; | import { defineComponent, onMounted, ref } from 'vue'; | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
|  | 	setup(props, context) { | ||||||
|  | 		const child = ref<HTMLElement | null>(null); | ||||||
|  |  | ||||||
|  | 		const scanChild = () => { | ||||||
|  | 			if (child.value == null) return; | ||||||
|  | 			const els = Array.from(child.value.children); | ||||||
|  | 			for (let i = 0; i < els.length; i++) { | ||||||
|  | 				const el = els[i]; | ||||||
|  | 				if (el.classList.contains('_formNoConcat')) { | ||||||
|  | 					if (els[i - 1]) els[i - 1].classList.add('_formNoConcatPrev'); | ||||||
|  | 					if (els[i + 1]) els[i + 1].classList.add('_formNoConcatNext'); | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		onMounted(() => { | ||||||
|  | 			scanChild(); | ||||||
|  |  | ||||||
|  | 			const observer = new MutationObserver(records => { | ||||||
|  | 				scanChild(); | ||||||
|  | 			}); | ||||||
|  |  | ||||||
|  | 			observer.observe(child.value, { | ||||||
|  | 				childList: true, | ||||||
|  | 				subtree: false, | ||||||
|  | 				attributes: false, | ||||||
|  | 				characterData: false, | ||||||
|  | 			}); | ||||||
|  | 		}); | ||||||
|  |  | ||||||
|  | 		return { | ||||||
|  | 			child | ||||||
|  | 		}; | ||||||
|  | 	} | ||||||
| }); | }); | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="scss" scoped> | <style lang="scss" scoped> | ||||||
| .vrtktovg { | .vrtktovg { | ||||||
| 	> .main { | 	> .main { | ||||||
| 		> ::v-deep(*) { | 		> ::v-deep(*):not(._formNoConcat) { | ||||||
| 			margin: 0; | 			&:not(._formNoConcatNext) { | ||||||
|  | 				margin: 0; | ||||||
| 			&:not(:first-child) { |  | ||||||
| 				&._formPanel, ._formPanel { |  | ||||||
| 					border-top: none; |  | ||||||
| 					border-top-left-radius: 0; |  | ||||||
| 					border-top-right-radius: 0; |  | ||||||
| 				} |  | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 			&:not(:last-child) { | 			&:not(:last-child):not(._formNoConcatPrev) { | ||||||
| 				&._formPanel, ._formPanel { | 				&._formPanel, ._formPanel { | ||||||
| 					border-bottom: solid 0.5px var(--divider); | 					border-bottom: solid 0.5px var(--divider); | ||||||
| 					border-bottom-left-radius: 0; | 					border-bottom-left-radius: 0; | ||||||
| 					border-bottom-right-radius: 0; | 					border-bottom-right-radius: 0; | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
|  | 			&:not(:first-child):not(._formNoConcatNext) { | ||||||
|  | 				&._formPanel, ._formPanel { | ||||||
|  | 					border-top: none; | ||||||
|  | 					border-top-left-radius: 0; | ||||||
|  | 					border-top-right-radius: 0; | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										47
									
								
								src/client/components/form/info.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								src/client/components/form/info.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,47 @@ | |||||||
|  | <template> | ||||||
|  | <div class="fzenkabp _formItem"> | ||||||
|  | 	<div class="_formPanel" :class="{ warn }"> | ||||||
|  | 		<i v-if="warn" class="fas fa-exclamation-triangle"></i> | ||||||
|  | 		<i v-else class="fas fa-info-circle"></i> | ||||||
|  | 		<slot></slot> | ||||||
|  | 	</div> | ||||||
|  | </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script lang="ts"> | ||||||
|  | import { defineComponent } from 'vue'; | ||||||
|  |  | ||||||
|  | export default defineComponent({ | ||||||
|  | 	props: { | ||||||
|  | 		warn: { | ||||||
|  | 			type: Boolean, | ||||||
|  | 			required: false, | ||||||
|  | 			default: false | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 		}; | ||||||
|  | 	} | ||||||
|  | }); | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <style lang="scss" scoped> | ||||||
|  | .fzenkabp { | ||||||
|  | 	> div { | ||||||
|  | 		padding: 14px 16px; | ||||||
|  | 		font-size: 90%; | ||||||
|  | 		background: var(--infoBg); | ||||||
|  | 		color: var(--infoFg); | ||||||
|  |  | ||||||
|  | 		&.warn { | ||||||
|  | 			background: var(--infoWarnBg); | ||||||
|  | 			color: var(--infoWarnFg); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		> i { | ||||||
|  | 			margin-right: 4px; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | </style> | ||||||
| @@ -30,13 +30,12 @@ | |||||||
| 	</div> | 	</div> | ||||||
| 	<template #caption><slot name="desc"></slot></template> | 	<template #caption><slot name="desc"></slot></template> | ||||||
|  |  | ||||||
| 	<FormButton v-if="manualSave && changed" @click="updated" primary><Fa :icon="faSave"/> {{ $ts.save }}</FormButton> | 	<FormButton v-if="manualSave && changed" @click="updated" primary><i class="fas fa-save"></i> {{ $ts.save }}</FormButton> | ||||||
| </FormGroup> | </FormGroup> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent, onMounted, onUnmounted, nextTick, ref, watch, computed, toRefs } from 'vue'; | import { defineComponent, onMounted, onUnmounted, nextTick, ref, watch, computed, toRefs } from 'vue'; | ||||||
| import { faExclamationCircle, faSave } from '@fortawesome/free-solid-svg-icons'; |  | ||||||
| import './form.scss'; | import './form.scss'; | ||||||
| import FormButton from './button.vue'; | import FormButton from './button.vue'; | ||||||
| import FormGroup from './group.vue'; | import FormGroup from './group.vue'; | ||||||
| @@ -191,7 +190,6 @@ export default defineComponent({ | |||||||
| 			onInput, | 			onInput, | ||||||
| 			onKeydown, | 			onKeydown, | ||||||
| 			updated, | 			updated, | ||||||
| 			faExclamationCircle, faSave, |  | ||||||
| 		}; | 		}; | ||||||
| 	}, | 	}, | ||||||
| }); | }); | ||||||
| @@ -215,7 +213,7 @@ export default defineComponent({ | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	> .input { | 	> .input { | ||||||
| 		$height: 52px; | 		$height: 48px; | ||||||
| 		position: relative; | 		position: relative; | ||||||
|  |  | ||||||
| 		> input { | 		> input { | ||||||
|   | |||||||
| @@ -20,11 +20,19 @@ export default defineComponent({ | |||||||
| .anocepby { | .anocepby { | ||||||
| 	display: flex; | 	display: flex; | ||||||
| 	align-items: center; | 	align-items: center; | ||||||
| 	padding: 14px 16px; | 	padding: 14px var(--formContentHMargin); | ||||||
|  |  | ||||||
|  | 	> .key { | ||||||
|  | 		margin-right: 12px; | ||||||
|  | 		white-space: nowrap; | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	> .value { | 	> .value { | ||||||
| 		margin-left: auto; | 		margin-left: auto; | ||||||
| 		opacity: 0.7; | 		opacity: 0.7; | ||||||
|  | 		text-overflow: ellipsis; | ||||||
|  | 		white-space: nowrap; | ||||||
|  | 		overflow: hidden; | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ | |||||||
| 		<span class="text"><slot></slot></span> | 		<span class="text"><slot></slot></span> | ||||||
| 		<span class="right"> | 		<span class="right"> | ||||||
| 			<span class="text"><slot name="suffix"></slot></span> | 			<span class="text"><slot name="suffix"></slot></span> | ||||||
| 			<Fa :icon="faExternalLinkAlt" class="icon"/> | 			<i class="fas fa-external-link-alt icon"></i> | ||||||
| 		</span> | 		</span> | ||||||
| 	</a> | 	</a> | ||||||
| 	<MkA class="main _button _formPanel _formClickable" :class="{ active }" :to="to" :behavior="behavior" v-else> | 	<MkA class="main _button _formPanel _formClickable" :class="{ active }" :to="to" :behavior="behavior" v-else> | ||||||
| @@ -13,7 +13,7 @@ | |||||||
| 		<span class="text"><slot></slot></span> | 		<span class="text"><slot></slot></span> | ||||||
| 		<span class="right"> | 		<span class="right"> | ||||||
| 			<span class="text"><slot name="suffix"></slot></span> | 			<span class="text"><slot name="suffix"></slot></span> | ||||||
| 			<Fa :icon="faChevronRight" class="icon"/> | 			<i class="fas fa-chevron-right icon"></i> | ||||||
| 		</span> | 		</span> | ||||||
| 	</MkA> | 	</MkA> | ||||||
| </div> | </div> | ||||||
| @@ -21,7 +21,6 @@ | |||||||
|  |  | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| import { defineComponent } from 'vue'; | import { defineComponent } from 'vue'; | ||||||
| import { faChevronRight, faExternalLinkAlt } from '@fortawesome/free-solid-svg-icons'; |  | ||||||
| import './form.scss'; | import './form.scss'; | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| @@ -45,7 +44,6 @@ export default defineComponent({ | |||||||
| 	}, | 	}, | ||||||
| 	data() { | 	data() { | ||||||
| 		return { | 		return { | ||||||
| 			faChevronRight, faExternalLinkAlt |  | ||||||
| 		}; | 		}; | ||||||
| 	} | 	} | ||||||
| }); | }); | ||||||
| @@ -66,6 +64,7 @@ export default defineComponent({ | |||||||
|  |  | ||||||
| 		&.active { | 		&.active { | ||||||
| 			color: var(--accent); | 			color: var(--accent); | ||||||
|  | 			background: var(--panelHighlight); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		> .icon { | 		> .icon { | ||||||
|   | |||||||
							
								
								
									
										102
									
								
								src/client/components/form/object-view.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										102
									
								
								src/client/components/form/object-view.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,102 @@ | |||||||
|  | <template> | ||||||
|  | <FormGroup class="_formItem"> | ||||||
|  | 	<template #label><slot></slot></template> | ||||||
|  | 	<div class="drooglns _formItem" :class="{ tall }"> | ||||||
|  | 		<div class="input _formPanel"> | ||||||
|  | 			<textarea class="_monospace" | ||||||
|  | 				v-model="v" | ||||||
|  | 				readonly | ||||||
|  | 				:spellcheck="false" | ||||||
|  | 			></textarea> | ||||||
|  | 		</div> | ||||||
|  | 	</div> | ||||||
|  | 	<template #caption><slot name="desc"></slot></template> | ||||||
|  | </FormGroup> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script lang="ts"> | ||||||
|  | import { defineComponent, ref, toRefs, watch } from 'vue'; | ||||||
|  | import * as JSON5 from 'json5'; | ||||||
|  | import './form.scss'; | ||||||
|  | import FormGroup from './group.vue'; | ||||||
|  |  | ||||||
|  | export default defineComponent({ | ||||||
|  | 	components: { | ||||||
|  | 		FormGroup, | ||||||
|  | 	}, | ||||||
|  | 	props: { | ||||||
|  | 		value: { | ||||||
|  | 			required: false | ||||||
|  | 		}, | ||||||
|  | 		tall: { | ||||||
|  | 			type: Boolean, | ||||||
|  | 			required: false, | ||||||
|  | 			default: false | ||||||
|  | 		}, | ||||||
|  | 		pre: { | ||||||
|  | 			type: Boolean, | ||||||
|  | 			required: false, | ||||||
|  | 			default: false | ||||||
|  | 		}, | ||||||
|  | 		manualSave: { | ||||||
|  | 			type: Boolean, | ||||||
|  | 			required: false, | ||||||
|  | 			default: false | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  | 	setup(props, context) { | ||||||
|  | 		const { value } = toRefs(props); | ||||||
|  | 		const v = ref(''); | ||||||
|  |  | ||||||
|  | 		watch(() => value, newValue => { | ||||||
|  | 			v.value = JSON5.stringify(newValue.value, null, '\t'); | ||||||
|  | 		}, { | ||||||
|  | 			immediate: true | ||||||
|  | 		}); | ||||||
|  |  | ||||||
|  | 		return { | ||||||
|  | 			v, | ||||||
|  | 		}; | ||||||
|  | 	} | ||||||
|  | }); | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <style lang="scss" scoped> | ||||||
|  | .drooglns { | ||||||
|  | 	position: relative; | ||||||
|  |  | ||||||
|  | 	> .input { | ||||||
|  | 		position: relative; | ||||||
|  | 	 | ||||||
|  | 		> textarea { | ||||||
|  | 			display: block; | ||||||
|  | 			width: 100%; | ||||||
|  | 			min-width: 100%; | ||||||
|  | 			max-width: 100%; | ||||||
|  | 			min-height: 130px; | ||||||
|  | 			margin: 0; | ||||||
|  | 			padding: 16px var(--formContentHMargin); | ||||||
|  | 			box-sizing: border-box; | ||||||
|  | 			font: inherit; | ||||||
|  | 			font-weight: normal; | ||||||
|  | 			font-size: 1em; | ||||||
|  | 			background: transparent; | ||||||
|  | 			border: none; | ||||||
|  | 			border-radius: 0; | ||||||
|  | 			outline: none; | ||||||
|  | 			box-shadow: none; | ||||||
|  | 			color: var(--fg); | ||||||
|  | 			tab-size: 2; | ||||||
|  | 			white-space: pre; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	&.tall { | ||||||
|  | 		> .input { | ||||||
|  | 			> textarea { | ||||||
|  | 				min-height: 200px; | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | </style> | ||||||
| @@ -16,7 +16,7 @@ | |||||||
| import { defineComponent } from 'vue'; | import { defineComponent } from 'vue'; | ||||||
| import FormButton from './button.vue'; | import FormButton from './button.vue'; | ||||||
| import FormGroup from './group.vue'; | import FormGroup from './group.vue'; | ||||||
| import paging from '@/scripts/paging'; | import paging from '@client/scripts/paging'; | ||||||
|  |  | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
| 	components: { | 	components: { | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user