diff --git a/CHANGELOG.md b/CHANGELOG.md index 9b5d8c830..e8879b747 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,6 +5,15 @@ ChangeLog This document describes breaking changes only. +7.0.0 +----- + +### Migration + +起動する前に、`node cli/migration/7.0.0`してください。 + +Please run `node cli/migration/7.0.0` before launch. + 6.0.0 ----- diff --git a/README.md b/README.md index a52ead65a..d28822021 100644 --- a/README.md +++ b/README.md @@ -7,10 +7,12 @@ [![][dependencies-badge]][dependencies-link] [![PRs Welcome](https://img.shields.io/badge/PRs-welcome-brightgreen.svg?style=flat-square)](http://makeapullrequest.com) [![Greenkeeper badge](https://badges.greenkeeper.io/syuilo/misskey.svg)](https://greenkeeper.io/) -**Microblogging. Redefined.** +Sophisticated microblogging platform, evolving forever. -**[Misskey](https://misskey.xyz)** is a completely open source, -ultimately sophisticated professional microblogging software. +[Misskey](https://misskey.xyz) is a decentralized microblogging platform born on Earth. +Since it exists within the Fediverse (a universe where various social media platforms are organized), +it is mutually linked with other social media platforms. +Why don't you take a short break from the hustle and bustle of the city, and dive into a new Internet? Become a Patron! @@ -28,7 +30,7 @@ ultimately sophisticated professional microblogging software. and more! You can see it with your own eyes at [misskey.xyz](https://misskey.xyz). -:package: Create your instance +:package: Create your own instance ---------------------------------------------------------------- If you want to run your own instance of Misskey, please see [Setup and installation guide](./docs/setup.en.md). @@ -43,6 +45,7 @@ If you want to... :heart: Backers & Sponsors ---------------------------------------------------------------- + @@ -71,6 +74,7 @@ If you want to...
gutfuckllc
+ :four_leaf_clover: Copyright ---------------------------------------------------------------- diff --git a/cli/clean-cached-remote-files.js b/cli/clean-cached-remote-files.js deleted file mode 100644 index 5b388c73b..000000000 --- a/cli/clean-cached-remote-files.js +++ /dev/null @@ -1,101 +0,0 @@ -const chalk = require('chalk'); -const log = require('single-line-log').stdout; -const sequential = require('promise-sequential'); -const { default: DriveFile, DriveFileChunk } = require('../built/models/drive-file'); -const { default: DriveFileThumbnail, DriveFileThumbnailChunk } = require('../built/models/drive-file-thumbnail'); -const { default: User } = require('../built/models/user'); - -const q = { - 'metadata._user.host': { - $ne: null - }, - 'metadata.withoutChunks': false -}; - -async function main() { - const promiseGens = []; - - const count = await DriveFile.count(q); - - let prev; - - for (let i = 0; i < count; i++) { - promiseGens.push(() => { - const promise = new Promise(async (res, rej) => { - const file = await DriveFile.findOne(prev ? Object.assign({ - _id: { $lt: prev._id } - }, q) : q, { - sort: { - _id: -1 - } - }); - - prev = file; - - function skip() { - res([i, file, false]); - } - - if (file == null) return skip(); - - log(chalk`{gray ${i}} scanning {bold ${file._id}} ${file.filename} ...`); - - const attachingUsersCount = await User.count({ - $or: [{ - avatarId: file._id - }, { - bannerId: file._id - }] - }, { limit: 1 }); - if (attachingUsersCount !== 0) return skip(); - - Promise.all([ - // チャンクをすべて削除 - DriveFileChunk.remove({ - files_id: file._id - }), - - DriveFile.update({ _id: file._id }, { - $set: { - 'metadata.withoutChunks': true - } - }) - ]).then(async () => { - res([i, file, true]); - - //#region サムネイルもあれば削除 - const thumbnail = await DriveFileThumbnail.findOne({ - 'metadata.originalId': file._id - }); - - if (thumbnail) { - DriveFileThumbnailChunk.remove({ - files_id: thumbnail._id - }); - - DriveFileThumbnail.remove({ _id: thumbnail._id }); - } - //#endregion - }); - }); - - promise.then(([i, file, deleted]) => { - if (deleted) { - log(chalk`{gray ${i}} {red deleted: {bold ${file._id}} ${file.filename}}`); - } else { - log(chalk`{gray ${i}} {green skipped: {bold ${file._id}} ${file.filename}}`); - } - log.clear(); - console.log(); - }); - - return promise; - }); - } - - return await sequential(promiseGens); -} - -main().then(() => { - console.log('ALL DONE'); -}).catch(console.error); diff --git a/cli/clean-unused-drive-files.js b/cli/clean-unused-drive-files.js deleted file mode 100644 index 87b158b9e..000000000 --- a/cli/clean-unused-drive-files.js +++ /dev/null @@ -1,80 +0,0 @@ -const chalk = require('chalk'); -const log = require('single-line-log').stdout; -const sequential = require('promise-sequential'); -const { default: DriveFile, deleteDriveFile } = require('../built/models/drive-file'); -const { default: Note } = require('../built/models/note'); -const { default: MessagingMessage } = require('../built/models/messaging-message'); -const { default: User } = require('../built/models/user'); - -async function main() { - const promiseGens = []; - - const count = await DriveFile.count({}); - - let prev; - - for (let i = 0; i < count; i++) { - promiseGens.push(() => { - const promise = new Promise(async (res, rej) => { - const file = await DriveFile.findOne(prev ? { - _id: { $lt: prev._id } - } : {}, { - sort: { - _id: -1 - } - }); - - prev = file; - - function skip() { - res([i, file, false]); - } - - if (file == null) return skip(); - - log(chalk`{gray ${i}} scanning {bold ${file._id}} ${file.filename} ...`); - - const attachingUsersCount = await User.count({ - $or: [{ - avatarId: file._id - }, { - bannerId: file._id - }] - }, { limit: 1 }); - if (attachingUsersCount !== 0) return skip(); - - const attachingNotesCount = await Note.count({ - mediaIds: file._id - }, { limit: 1 }); - if (attachingNotesCount !== 0) return skip(); - - const attachingMessagesCount = await MessagingMessage.count({ - fileId: file._id - }, { limit: 1 }); - if (attachingMessagesCount !== 0) return skip(); - - deleteDriveFile(file).then(() => { - res([i, file, true]); - }).catch(rej); - }); - - promise.then(([i, file, deleted]) => { - if (deleted) { - log(chalk`{gray ${i}} {red deleted: {bold ${file._id}} ${file.filename}}`); - } else { - log(chalk`{gray ${i}} {green skipped: {bold ${file._id}} ${file.filename}}`); - } - log.clear(); - console.log(); - }); - - return promise; - }); - } - - return await sequential(promiseGens); -} - -main().then(() => { - console.log('done'); -}).catch(console.error); diff --git a/cli/migration/7.0.0.js b/cli/migration/7.0.0.js new file mode 100644 index 000000000..fa5e363db --- /dev/null +++ b/cli/migration/7.0.0.js @@ -0,0 +1,134 @@ +const { default: Stats } = require('../../built/models/stats'); +const { default: User } = require('../../built/models/user'); +const { default: Note } = require('../../built/models/note'); +const { default: DriveFile } = require('../../built/models/drive-file'); + +const now = new Date(); +const y = now.getFullYear(); +const m = now.getMonth(); +const d = now.getDate(); +const today = new Date(y, m, d); + +async function main() { + const localUsersCount = await User.count({ + host: null + }); + + const remoteUsersCount = await User.count({ + host: { $ne: null } + }); + + const localNotesCount = await Note.count({ + '_user.host': null + }); + + const remoteNotesCount = await Note.count({ + '_user.host': { $ne: null } + }); + + const localDriveFilesCount = await DriveFile.count({ + 'metadata._user.host': null + }); + + const remoteDriveFilesCount = await DriveFile.count({ + 'metadata._user.host': { $ne: null } + }); + + const localDriveFilesSize = await DriveFile + .aggregate([{ + $match: { + 'metadata._user.host': null, + 'metadata.deletedAt': { $exists: false } + } + }, { + $project: { + length: true + } + }, { + $group: { + _id: null, + usage: { $sum: '$length' } + } + }]) + .then(aggregates => { + if (aggregates.length > 0) { + return aggregates[0].usage; + } + return 0; + }); + + const remoteDriveFilesSize = await DriveFile + .aggregate([{ + $match: { + 'metadata._user.host': { $ne: null }, + 'metadata.deletedAt': { $exists: false } + } + }, { + $project: { + length: true + } + }, { + $group: { + _id: null, + usage: { $sum: '$length' } + } + }]) + .then(aggregates => { + if (aggregates.length > 0) { + return aggregates[0].usage; + } + return 0; + }); + + await Stats.insert({ + date: today, + users: { + local: { + total: localUsersCount, + diff: 0 + }, + remote: { + total: remoteUsersCount, + diff: 0 + } + }, + notes: { + local: { + total: localNotesCount, + diff: 0, + diffs: { + normal: 0, + reply: 0, + renote: 0 + } + }, + remote: { + total: remoteNotesCount, + diff: 0, + diffs: { + normal: 0, + reply: 0, + renote: 0 + } + } + }, + drive: { + local: { + totalCount: localDriveFilesCount, + totalSize: localDriveFilesSize, + diffCount: 0, + diffSize: 0 + }, + remote: { + totalCount: remoteDriveFilesCount, + totalSize: remoteDriveFilesSize, + diffCount: 0, + diffSize: 0 + } + } + }); + + console.log('done'); +} + +main(); diff --git a/docs/manage.en.md b/docs/manage.en.md index a7296ce47..713070517 100644 --- a/docs/manage.en.md +++ b/docs/manage.en.md @@ -33,14 +33,3 @@ node cli/suspend @syuilo@misskey.xyz ``` shell node cli/reset-password (User-ID or Username) ``` - -## Clean up cached remote files -``` shell -node cli/clean-cached-remote-files -``` - -## Clean up unused drive files -``` shell -node cli/clean-unused-drive-files -``` -> We recommend that you announce a user that unused drive files will be deleted before performing this operation, as it may delete the user's important files. diff --git a/docs/manage.ja.md b/docs/manage.ja.md index f289037ad..897fae7ec 100644 --- a/docs/manage.ja.md +++ b/docs/manage.ja.md @@ -33,14 +33,3 @@ node cli/suspend @syuilo@misskey.xyz ``` shell node cli/reset-password (ユーザーID または ユーザー名) ``` - -## キャッシュされたリモートファイルをクリーンアップする -``` shell -node cli/clean-cached-remote-files -``` - -## 使われていないドライブのファイルをクリーンアップする -``` shell -node cli/clean-unused-drive-files -``` -> ユーザーの大事なファイルを削除する可能性があるので、この操作を実行する前にユーザーに告知することをお勧めします。 diff --git a/locales/index.js b/locales/index.js index 5b525c77d..a17fb6c5c 100644 --- a/locales/index.js +++ b/locales/index.js @@ -15,6 +15,7 @@ const langs = { 'en': loadLang('en'), 'fr': loadLang('fr'), 'ja': native, + 'ja-ks': loadLang('ja-ks'), 'pl': loadLang('pl'), 'es': loadLang('es') }; diff --git a/locales/ja-ks.yml b/locales/ja-ks.yml new file mode 100644 index 000000000..283b3f3e7 --- /dev/null +++ b/locales/ja-ks.yml @@ -0,0 +1,1412 @@ +meta: + lang: "日本語" + divider: "関西弁" + +common: + misskey: "A ⭐ of fediverse" + about-title: "A ⭐ of fediverse." + about: "ようMisskeyを見つけてくれて、おおきにやで。Misskeyは、地球で生まれた分散マイクロブログSNSやねん。Fediverse(ぎょうさんのSNSで構成されとる宇宙)っちゅうもんの中におるから、お隣さんのSNSとも仲良うさせてもろてんねん。ちょいとやかましい心斎橋から離れて、新しいインターネットにダイブしてみぃひん?" + adblock: + detected: "広告ブロッカーを切っとくれんか" + warning: "Misskeyは広告を掲載しとらんけど、広告をブロックする機能が有効やと一部の機能が利用できんくなったり、不具合が発生するかも分からん。知らんけど。" + application-authorization: "アプリの連携" + close: "ほなさいなら" + do-not-copy-paste: "ここにコードを入力したり張り付けたりせんといてください。アカウントが不正利用されるかも分からん。知らんけど。" + got-it: "ほい" + customization-tips: + title: "カスタマイズのヒント" + paragraph1: "ホームのカスタマイズでは、ウィジェットを追加/削除したり、ドラッグ&ドロップして並べ替えたりできんねやわ。。" + paragraph2: "一部のウィジェットは、クリックしたったら表示を変更できんねやわ。" + paragraph3: "ウィジェットを削除するんやったら、ヘッダーの「ゴミ箱」と書いたぁるエリアにウィジェットをドラッグ&ドロップしてな。" + paragraph4: "カスタマイズを終了するんやったら、右上の「完了」をクリックしてな。" + gotit: "Got it!" + notification: + file-uploaded: "ファイルがアップロードされたで" + message-from: "{}はんからメッセージ:" + reversi-invited: "対局への招待がきとるで" + reversi-invited-by: "{}はんから" + notified-by: "{}はんから" + reply-from: "{}はんから返信:" + quoted-by: "{}はんが引用:" + time: + unknown: "なぞのじかん" + future: "未来" + just_now: "たった今" + seconds_ago: "{}秒前" + minutes_ago: "{}分前" + hours_ago: "{}時間前" + days_ago: "{}日前" + weeks_ago: "{}週間前" + months_ago: "{}ヶ月前" + years_ago: "{}年前" + month-and-day: "{month}月 {day}日" + + trash: "ゴミ箱" + + weekday-short: + sunday: "日" + monday: "月" + tuesday: "火" + wednesday: "水" + thursday: "木" + friday: "金" + saturday: "土" + + weekday: + sunday: "日曜日" + monday: "月曜日" + tuesday: "火曜日" + wednesday: "水曜日" + thursday: "木曜日" + friday: "金曜日" + saturday: "土曜日" + + reactions: + like: "いいね" + love: "しゅき" + laugh: "笑" + hmm: "ふぅ~む" + surprise: "わお" + congrats: "おめでとう" + angry: "おこ" + confused: "こまこまのこまり" + rip: "RIP" + pudding: "Pudding" + + note-placeholders: + a: "今なにしてん?" + b: "何かあったんか?" + c: "何考えとりますん?" + d: "言いたいことは?" + e: "ここに書いてや" + f: "あんさんが書くのを待っちょります..." + + search: "検索" + delete: "削除" + loading: "読み込み中" + ok: "ほい" + update-available-title: "更新があるで" + update-available: "Misskeyの新しいバージョンがあるで({newer}。現在{current}を利用中)。ページを再度読み込みしたると更新が適用されるわ。" + my-token-regenerated: "あんさんのトークンが更新されたらしい、知らんけど。まあとりあえずサインアウトすんで。" + i-like-sushi: "寿司(のほうがプリンよりむしろ)ウマい、タコ焼きはあらへんけど。" + show-reversi-board-labels: "リバーシのボードの行と列のラベルを表示" + verified-user: "公式アカウント" + disable-animated-mfm: "投稿内の動きのあるテキストを無効にする" + + reversi: + drawn: "引き分け" + my-turn: "あんさんのターンや" + opponent-turn: "相手のターンや" + turn-of: "{}のターンです" + past-turn-of: "{}のターン" + won: "{}の勝ち" + black: "黒" + white: "白" + total: "合計" + this-turn: "{}ターン目" + + widgets: + analog-clock: "アナログ時計" + profile: "プロフィール" + calendar: "カレンダー" + timemachine: "カレンダー(タイムマシン)" + activity: "アクティビティ" + rss: "RSSリーダー" + memo: "付箋" + trends: "トレンド" + photo-stream: "フォトストリーム" + posts-monitor: "投稿チャート" + slideshow: "スライドショー" + version: "バージョン" + broadcast: "ブロードキャスト" + notifications: "通知" + users: "おすすめユーザー" + polls: "アンケート" + post-form: "投稿フォーム" + messaging: "メッセージ" + server: "サーバー情報" + donation: "寄付のお願い" + nav: "ナビゲーション" + tips: "ヒント" + hashtags: "ハッシュタグ" + + deck: + widgets: "ウィジェット" + home: "ホーム" + local: "ローカル" + hybrid: "ソーシャル" + global: "グローバル" + notifications: "通知" + list: "リスト" + swap-left: "左に移動" + swap-right: "右に移動" + swap-up: "上に移動" + swap-down: "下に移動" + remove: "カラムを削除" + add-column: "カラムを追加" + rename: "名前を変更" + stack-left: "左に重ねる" + pop-right: "右に出す" + +auth/views/form.vue: + share-access: "{{ app.name }}があんさんのアカウントにアクセスすんのを許可してもええか?" + permission-ask: "このアプリは次の権限を要求しとるで:" + account-read: "アカウントの情報を見させてもらうで。" + account-write: "アカウントの情報を操作させてもらうで。" + note-write: "投稿させてもらうで。" + like-write: "いいねしたりいいね解除させてもらうで。" + following-write: "フォローしたりフォロー解除させてもらうで。" + drive-read: "ドライブを見させてもらうで。" + drive-write: "ドライブを操作させてもらうで。" + notification-read: "通知を見させてもらうで。" + notification-write: "通知を操作させてもらうで。" + cancel: "キャンセル" + accept: "アクセスを許可" + +auth/views/index.vue: + loading: "読み込み中" + denied: "アプリケーションの連携をキャンセルしたわ。" + denied-paragraph: "このアプリがあんさんのアカウントにアクセスすることはあらへん。知らんけど。" + already-authorized: "このアプリはもう連携済みやったわ" + allowed: "アプリケーションの連携を許可したで" + callback-url: "アプリケーションに戻っとります" + please-go-back: "アプリケーションに戻って、気張ってってな。" + error: "セッションが存在しとらん。" + sign-in: "サインインしてや" + +common/views/components/games/reversi/reversi.vue: + matching: + waiting-for: "{}を待っとる" + cancel: "やっぱやめ" + +common/views/components/games/reversi/reversi.game.vue: + surrender: "投了" + surrendered: "投了により" + is-llotheo: "石の少ない方が勝ち(ロセオ)" + looped-map: "ループマップ" + can-put-everywhere: "どこでも置けるモード" + +common/views/components/games/reversi/reversi.index.vue: + title: "Misskey Reversi" + sub-title: "お隣のミスキストはんらとリバーシで対戦や!" + invite: "招待" + rule: "遊び方" + rule-desc: "リバーシは、相手と交互に石をボードに置いて、相手の石を挟んで自分の色に変えてって、最終的に残った石が多い方が勝ちっちゅうボードゲームや。" + mode-invite: "招待" + mode-invite-desc: "指定したユーザーと対戦するモードや。" + invitations: "対局の招待がきとるで。" + my-games: "自分の対局" + all-games: "みんなの対局" + enter-username: "ユーザー名を入力してや" + game-state: + ended: "終了" + playing: "進行中" + +common/views/components/games/reversi/reversi.room.vue: + settings-of-the-game: "ゲームの設定" + choose-map: "マップを選択" + random: "ランダム" + black-or-white: "先手/後手" + black-is: "{}が黒" + rules: "ルール" + is-llotheo: "石の少ない方が勝ち(ロセオ)" + looped-map: "ループマップ" + can-put-everywhere: "どこでも置けるモード" + settings-of-the-bot: "Botの設定" + this-game-is-started-soon: "ゲームは数秒後に開始されんで" + waiting-for-other: "相手の準備が完了すんのを待っとるで" + waiting-for-me: "あんさんの準備が完了すんのを待っとるで" + waiting-for-both: "準備中" + cancel: "キャンセル" + ready: "準備完了" + cancel-ready: "準備続行" + +common/views/components/connect-failed.vue: + title: "サーバーに接続できんわ" + description: "インターネット回線に問題が起きとるか、サーバーがダウンまたはメンテナンスしとるっぽいわ。知らんけど。とりあえずあとで{再試行}してや。" + thanks: "いつもMisskeyをつこてくれてほんまおおきにやで。" + troubleshoot: "トラブルシュート" + +common/views/components/connect-failed.troubleshooter.vue: + title: "トラブルシューティング" + network: "ネットワーク接続" + checking-network: "ネットワーク接続を確認中" + internet: "インターネット接続" + checking-internet: "インターネット接続を確認中" + server: "サーバー接続" + checking-server: "サーバー接続を確認中" + finding: "問題を調べとります" + no-network: "ネットワークに接続されとりません" + no-network-desc: "つこてるPCのネットワーク接続が正常か確認してや。" + no-internet: "インターネットに接続されとりません" + no-internet-desc: "ネットワークには接続されとるけど、インターネットには接続されとらんようやわ。つこてるPCのインターネット接続が正常か確認してや。" + no-server: "Misskeyのサーバーに接続できん" + no-server-desc: "つこてるPCのインターネット接続は正常やけど、Misskeyのサーバーにはつながらんわ。多分サーバーがダウンまたはメンテナンスしとるわ、知らんけど。すまんけどしばらくしてから再度アクセスしてみてや。" + success: "Misskeyのサーバーに接続できたわ" + success-desc: "正常に接続できるようやわ。ページを再度読み込みしてな。" + flush: "キャッシュの削除" + set-version: "バージョン指定" + +common/views/components/messaging.vue: + search-user: "ユーザーを探す" + you: "あんさん" + no-history: "履歴はあらへん" + +common/views/components/messaging-room.vue: + empty: "このユーザーと話したことはあらへん" + more: "もっと読む" + no-history: "これより過去の履歴はあらへん" + resize-form: "ドラッグしてフォームの広さを調整" + new-message: "新しいメッセージがあるで" + only-one-file-attached: "メッセージに添付できんのはひとつのファイルのみや" + +common/views/components/messaging-room.form.vue: + input-message-here: "ここにメッセージを入力" + send: "送信" + attach-from-local: "PCからファイルを添付する" + attach-from-drive: "ドライブからファイルを添付する" + only-one-file-attached: "メッセージに添付できんのはひとつのファイルのみや" + +common/views/components/messaging-room.message.vue: + is-read: "既読" + deleted: "このメッセージは削除されたわ" + +common/views/components/nav.vue: + about: "Misskeyについて" + stats: "統計" + status: "ステータス" + wiki: "Wiki" + donors: "ドナー" + repository: "リポジトリ" + develop: "開発者" + feedback: "フィードバック" + +common/views/components/note-menu.vue: + favorite: "お気に入り" + pin: "ピン留め" + delete: "削除" + delete-confirm: "この投稿を削除してもええか?" + remote: "投稿元で見る" + +common/views/components/poll.vue: + vote-to: "「{}」に投票や!" + vote-count: "{}票" + total-users: "{}人が投票" + vote: "投票する" + show-result: "結果を見る" + voted: "投票済み" + +common/views/components/poll-editor.vue: + no-only-one-choice: "アンケートには、選択肢が最低2つ必要や" + choice-n: "選択肢{}" + remove: "この選択肢を削除" + add: "+選択肢を追加" + destroy: "アンケートを破棄" + +common/views/components/reaction-picker.vue: + choose-reaction: "リアクションを選択" + +common/views/components/signin.vue: + username: "ユーザー名" + password: "パスワード" + token: "トークン" + signing-in: "やっとります..." + signin: "サインイン" + or: "または" + signin-with-twitter: "Twitterでログイン" + login-failed: "ログインできんかったわ。ユーザー名とパスワードを確認してや。" + +common/views/components/signup.vue: + invitation-code: "招待コード" + invitation-info: "招待コードをもっとらんのやったら、管理者まで連絡してや。" + username: "ユーザー名" + checking: "確認しとります..." + available: "利用できます" + unavailable: "既に利用されとります" + error: "通信エラー" + invalid-format: "a~z、A~Z、0~9、_が使えますねん" + too-short: "1文字以上でよろしゅうな!" + too-long: "20文字以内でよろしゅうな" + password: "パスワード" + password-placeholder: "8文字以上が推奨ですねん" + weak-password: "へぼいパスワード" + normal-password: "ぼちぼちパスワード" + strong-password: "ええ感じのパスワード" + retype: "再入力" + retype-placeholder: "確認のためもっぺん入力してや" + password-matched: "確認されたで" + password-not-matched: "一致しとらんで" + recaptcha: "認証" + create: "アカウント作成" + some-error: "何かよう分からんけど、アカウントの作成に失敗してしもたわ。すまんがもっぺん試してくれへんか?" + +common/views/components/special-message.vue: + new-year: "Happy New Year!" + christmas: "Merry Christmas!" + +common/views/components/stream-indicator.vue: + connecting: "接続中" + reconnecting: "再接続中" + connected: "接続完了" + +common/views/components/twitter-setting.vue: + description: "つことるTwitterアカウントをつことるMisskeyアカウントに接続しとくと、プロフィールでTwitterアカウント情報が表示されるようになったり、Twitterを用いた便利なサインインを利用できるようになったりすんで。" + connected-to: "次のTwitterアカウントに接続されとります" + detail: "詳細..." + reconnect: "再接続する" + connect: "Twitterと接続する" + disconnect: "切断する" + +common/views/components/uploader.vue: + waiting: "待機中" + +common/views/components/visibility-chooser.vue: + public: "公開" + home: "ホーム" + home-desc: "ホームタイムラインにのみ公開" + followers: "フォロワー" + followers-desc: "自分のフォロワーにのみ公開" + specified: "ダイレクト" + specified-desc: "指定したユーザーにのみ公開" + private: "非公開" + +common/views/widgets/broadcast.vue: + fetching: "確認中" + no-broadcasts: "お知らせはあらへん" + have-a-nice-day: "おおきに!" + next: "次" + +common/views/widgets/calendar.vue: + year: "{}年" + month: "{}月" + day: "{}日" + today: "今日:" + this-month: "今月:" + this-year: "今年:" + +common/views/widgets/donation.vue: + title: "寄付のお願い" + text: "Misskeyの運営にはドメイン、サーバー等のコストが掛かりますねん。Misskeyは広告を掲載したりせんから、収入を皆様からの寄付に頼ってますねん。もしご興味があれば、{}までご連絡よろしゅうな。ご協力おおきにやで。" + +common/views/widgets/photo-stream.vue: + title: "フォトストリーム" + no-photos: "写真はあらへん" + +common/views/widgets/posts-monitor.vue: + title: "投稿チャート" + toggle: "表示を切り替え" + +common/views/widgets/hashtags.vue: + title: "ハッシュタグ" + count: "{}人が投稿" + empty: "トレンドなし" + +common/views/widgets/server.vue: + title: "サーバー情報" + toggle: "表示を切り替え" + +common/views/widgets/memo.vue: + title: "付箋" + memo: "ここに書くねんで!" + save: "保存" + +common/views/widgets/slideshow.vue: + folder-customize-mode: "フォルダを指定するんやったら、カスタマイズモードを終了してや" + folder: "クリックしてフォルダを指定してや" + no-image: "このフォルダには画像があらへん" + +common/views/widgets/tips.vue: + tips-line1: "tでタイムラインにフォーカスできんで" + tips-line2: "pまたはnで投稿フォームを開くで" + tips-line3: "投稿フォームにはファイルをドラッグ&ドロップできんで" + tips-line4: "投稿フォームにクリップボードにおる画像データをペーストできんで" + tips-line5: "ドライブにファイルをドラッグ&ドロップしてアップロードできんで" + tips-line6: "ドライブでファイルをドラッグしてフォルダ移動できんで" + tips-line7: "ドライブでフォルダをドラッグしてフォルダ移動できんで" + tips-line8: "ホームは設定からカスタマイズできんで" + tips-line9: "MisskeyはAGPLv3やで" + tips-line10: "タイムマシンウィジェットを利用すると、簡単に過去のタイムラインに遡れんで" + tips-line11: "投稿の ... をクリックして、投稿をユーザーページにピン留めできんで" + tips-line13: "投稿に添付したファイルは全てドライブに保存されんで" + tips-line14: "ホームのカスタマイズ中、ウィジェットを右クリックしてデザインを変更できんで" + tips-line17: "「**」でテキストを囲ったると**強調表示**されんで" + tips-line19: "いくつかのウィンドウはブラウザの外に切り離すことができんで" + tips-line20: "カレンダーウィジェットのパーセンテージは、経過の割合を示してんねん" + tips-line21: "APIをつこてbotの開発なども行えんで" + tips-line23: "まゆかわいいよまゆ" + tips-line24: "Misskeyは2014年にサービスを開始してん" + tips-line25: "対応ブラウザやったらMisskeyを開いとらんでも通知を受け取れんで" + +common/views/pages/follow.vue: + signed-in-as: "{}としてサインイン中" + following: "フォロー中" + follow: "フォロー" + request-pending: "フォロー許可待ち" + follow-request: "フォロー申請" + +desktop: + banner-crop-title: "バナーとして表示する部分を選択" + banner: "バナー" + uploading-banner: "新しいバナーをアップロードしとります" + banner-updated: "バナーを更新したで" + choose-banner: "バナーにする画像を選択" + avatar-crop-title: "アバターとして表示する部分を選択" + avatar: "アバター" + uploading-avatar: "新しいアバターをアップロードしとります" + avatar-updated: "アバターを更新したで" + choose-avatar: "アバターにする画像を選択" + +desktop/views/components/activity.chart.vue: + total: "Black ... Total" + notes: "Blue ... Notes" + replies: "Red ... Replies" + renotes: "Green ... Renotes" + +desktop/views/components/activity.vue: + title: "アクティビティ" + toggle: "表示を切り替え" + +desktop/views/components/calendar.vue: + title: "{1}年 {2}月" + prev: "前の月" + next: "次の月" + go: "クリックして時間遡行" + +desktop/views/components/choose-file-from-drive-window.vue: + choose-file: "ファイル選択中" + upload: "PCからドライブにファイルをアップロード" + cancel: "キャンセル" + ok: "決定" + choose-prompt: "ファイルを選択" + +desktop/views/components/choose-folder-from-drive-window.vue: + cancel: "キャンセル" + ok: "決定" + choose-prompt: "フォルダを選択" + +desktop/views/components/crop-window.vue: + skip: "クロップをスキップ" + cancel: "キャンセル" + ok: "決定" + +desktop/views/components/drive-window.vue: + used: "使用中" + drive: "ドライブ" + +desktop/views/components/drive.file.vue: + avatar: "アイコン" + banner: "バナー" + contextmenu: + rename: "名前を変更" + mark-as-sensitive: "閲覧注意に設定" + unmark-as-sensitive: "閲覧注意を解除" + copy-url: "URLをコピー" + download: "ダウンロード" + else-files: "その他..." + set-as-avatar: "アイコンに設定" + set-as-banner: "バナーに設定" + open-in-app: "アプリで開く" + add-app: "アプリを追加" + rename-file: "ファイル名の変更" + input-new-file-name: "新しいファイル名を入力してや" + copied: "コピー完了" + copied-url-to-clipboard: "URLをクリップボードにコピーしたで" + +desktop/views/components/drive.folder.vue: + unable-to-process: "操作を完了できん" + circular-reference-detected: "移動先のフォルダーは、移動するフォルダーのサブフォルダーや。" + unhandled-error: "不明なエラー" + contextmenu: + move-to-this-folder: "このフォルダへ移動" + show-in-new-window: "新しいウィンドウで表示" + rename: "名前を変更" + rename-folder: "フォルダ名の変更" + input-new-folder-name: "新しいフォルダ名を入力してや" + +desktop/views/components/drive.nav-folder.vue: + drive: "ドライブ" + +desktop/views/components/drive.vue: + search: "検索" + load-more: "もっと読み込む" + empty-draghover: "ドロップですか?いいですよ、ボクはカワイイですからね" + empty-drive: "ドライブには何もあらへん。" + empty-drive-description: "右クリックして「ファイルをアップロード」を選んだり、ファイルをドラッグ&ドロップすることでもアップロードできんねん。" + empty-folder: "このフォルダーは空や" + unable-to-process: "操作を完了できん" + circular-reference-detected: "移動先のフォルダーは、移動するフォルダーのサブフォルダーや。" + unhandled-error: "不明なエラー" + url-upload: "URLアップロード" + url-of-file: "アップロードしたいファイルのURL" + url-upload-requested: "アップロードをリクエストしたで" + may-take-time: "アップロードが完了するまで時間がかかるかも分からん、知らんけど。" + create-folder: "フォルダー作成" + folder-name: "フォルダー名" + contextmenu: + create-folder: "フォルダーを作成" + upload: "ファイルをアップロード" + url-upload: "URLからアップロード" + +desktop/views/components/media-image.vue: + sensitive: "閲覧注意" + click-to-show: "クリックして表示" + +desktop/views/components/media-video.vue: + sensitive: "閲覧注意" + click-to-show: "クリックして表示" + +desktop/views/components/follow-button.vue: + following: "フォロー中" + follow: "フォロー" + request-pending: "フォロー許可待ち" + follow-request: "フォロー申請" + +desktop/views/components/followers-window.vue: + followers: "{} のフォロワー" + +desktop/views/components/followers.vue: + empty: "フォロワーはおらんっぽいで、知らんけど。" + +desktop/views/components/following-window.vue: + following: "{} のフォロー" + +desktop/views/components/following.vue: + empty: "フォロー中のユーザーはおらんっぽいで、知らんけど。" + +desktop/views/components/friends-maker.vue: + title: "気になるユーザーをフォロー:" + empty: "おすすめのユーザーはおらんかったわ。" + fetching: "読み込んどります" + refresh: "もっと見る" + close: "閉じる" + +desktop/views/components/game-window.vue: + game: "リバーシ" + +desktop/views/components/home.vue: + done: "完了" + add-widget: "ウィジェットを追加:" + add: "追加" + +desktop/views/input-dialog.vue: + cancel: "キャンセル" + ok: "決定" + +desktop/views/components/messaging-room-window.vue: + title: "メッセージ:" + +desktop/views/components/messaging-window.vue: + title: "メッセージ" + +desktop/views/components/note-detail.vue: + more: "会話をもっと読み込む" + private: "この投稿は非公開やねん" + deleted: "この投稿は削除されてん" + reposted-by: "{}がRenote" + location: "位置情報" + renote: "Renote" + add-reaction: "リアクション" + +desktop/views/components/notes.note.vue: + reposted-by: "{}がRenote" + reply: "返信" + renote: "Renote" + add-reaction: "リアクション" + detail: "詳細" + private: "この投稿は非公開やねん" + deleted: "この投稿は削除されてん" + hide: "隠す" + see-more: "もっと見る" + +desktop/views/components/notes.vue: + error: "読み込みに失敗したわ。" + retry: "リトライ" + load-more: "もっと読み込む" + +desktop/views/components/notifications.vue: + more: "もっと見る" + empty: "あらへん!" + +desktop/views/components/post-form.vue: + add-visible-user: "+ユーザーを追加" + attach-location-information: "位置情報を添付する" + hide-contents: "内容を隠す" + reply-placeholder: "この投稿への返信..." + quote-placeholder: "この投稿を引用..." + submit: "投稿" + reply: "返信" + renote: "Renote" + posted: "投稿したで!" + replied: "返信したで!" + reposted: "Renoteしたで!" + note-failed: "投稿に失敗したで" + reply-failed: "返信に失敗したで" + renote-failed: "Renoteに失敗したで" + posting: "投稿中" + attach-media-from-local: "PCからメディアを添付" + attach-media-from-drive: "ドライブからメディアを添付" + attach-cancel: "添付取り消し" + insert-a-kao: "v('ω')v" + create-poll: "アンケートを作成" + text-remain: "残り{}文字" + recent-tags: "最近" + click-to-tagging: "クリックでタグ付け" + visibility: "公開範囲" + geolocation-alert: "つこてる端末は位置情報に対応しとらんみたいやわ、知らんけど。" + error: "エラー" + enter-username: "ユーザー名を入力してや" + annotations: "内容への注釈 (オプション)" + +desktop/views/components/post-form-window.vue: + note: "新規投稿" + reply: "返信" + attaches: "添付: {}メディア" + uploading-media: "{}個のメディアをアップロード中" + +desktop/views/components/progress-dialog.vue: + waiting: "待機中" + +desktop/views/components/renote-form.vue: + quote: "引用する..." + cancel: "やっぱやめ" + renote: "Renote" + reposting: "やっとります..." + success: "Renoteしたで!" + failure: "Renoteに失敗したで" + +desktop/views/components/renote-form-window.vue: + title: "この投稿をRenoteしてもええか?" + +desktop/views/components/settings-window.vue: + settings: "設定" + +desktop/views/components/settings.vue: + profile: "プロフィール" + notification: "通知" + apps: "アプリ" + mute: "ミュート" + drive: "ドライブ" + security: "セキュリティ" + signin: "サインイン履歴" + password: "パスワード" + 2fa: "二段階認証" + other: "その他" + license: "ライセンス" + + behaviour: "動作" + fetch-on-scroll: "スクロールで自動読み込み" + fetch-on-scroll-desc: "ページを下までスクロールしたときに自動で追加のコンテンツを読み込むで。" + auto-popout: "ウィンドウの自動ポップアウト" + auto-popout-desc: "ウィンドウが開かれるとき、ポップアウト(ブラウザ外に切り離す)可能なら自動でポップアウトすんで。この設定はブラウザに記憶されんで。" + advanced: "詳細設定" + api-via-stream: "ストリームを経由したAPIリクエスト" + api-via-stream-desc: "この設定をオンにすると、WebSocket接続を経由してAPIリクエストが行われんで(パフォーマンス向上が期待できるかも分からん、知らんけど)。オフにすると、ネイティブの fetch API が利用されんねやわ。この設定はこのデバイスのみ有効やで。" + + display: "デザインと表示" + customize: "ホームをカスタマイズ" + choose-wallpaper: "壁紙を選択" + delete-wallpaper: "壁紙を削除" + dark-mode: "ダークモード" + circle-icons: "円形のアイコンを使用" + gradient-window-header: "ウィンドウのタイトルバーにグラデーションを使用" + post-form-on-timeline: "タイムライン上部に投稿フォームを表示すんで" + suggest-recent-hashtags: "最近のハッシュタグを投稿フォームに表示すんで" + show-reply-target: "リプライ先を表示すんで" + show-my-renotes: "自分の行ったRenoteをタイムラインに表示すんで" + show-renoted-my-notes: "自分の投稿のRenoteをタイムラインに表示すんで" + show-local-renotes: "ローカルの投稿のRenoteをタイムラインに表示すんで" + show-maps: "マップの自動展開" + show-maps-desc: "位置情報が添付された投稿のマップを自動的に展開すんで。" + + sound: "サウンド" + enable-sounds: "サウンドを有効にすんで" + enable-sounds-desc: "投稿やメッセージを送受信したときなどにサウンドを再生すんで。この設定はブラウザに記憶されんで。" + volume: "ボリューム" + test: "テスト" + + mobile: "モバイル" + disable-via-mobile: "「モバイルからの投稿」フラグを付けへん" + + language: "言語" + pick-language: "言語を選択" + recommended: "推奨" + auto: "自動" + specify-language: "言語を指定" + language-desc: "変更はページの再度読み込み後に反映されんで。" + + cache: "キャッシュ" + clean-cache: "クリーンアップ" + cache-warn: "クリーンアップを行うと、ブラウザに記憶されたアカウント情報のキャッシュ、書きかけの投稿・返信・メッセージ、およびその他のデータ(設定情報含む)が削除されますねん。クリーンアップを行った後はページを再度読み込みしてや。" + cache-cleared: "キャッシュを削除したで" + cache-cleared-desc: "ページを再度読み込みしてや。" + + auto-watch: "投稿の自動ウォッチ" + auto-watch-desc: "リアクションしたり返信したりした投稿に関する通知を自動的に受け取るようにすんで。" + + about: "Misskeyについて" + operator: "このサーバーの運営者" + + update: "Misskey Update" + version: "バージョン:" + latest-version: "最新のバージョン:" + update-checking: "アップデートを確認中" + do-update: "アップデートを確認" + update-settings: "詳細設定" + prevent-update: "アップデートを延期する(非推奨)" + prevent-update-desc: "この設定をオンにしとってもアップデートが反映される場合があるかも分からん、知らんけど気ぃつけてや。この設定はこのデバイスのみ有効やで。" + no-updates: "利用可能な更新はあらへん" + no-updates-desc: "つことるMisskeyは最新や!" + update-available: "新しいバージョンが利用可能や" + update-available-desc: "ページを再度読み込みすると更新が適用されんで。" + + advanced-settings: "高度な設定" + debug-mode: "デバッグモードを有効にすんで" + debug-mode-desc: "この設定はブラウザに記憶されんで。" + experimental: "実験的機能を有効にすんで" + experimental-desc: "実験的機能を有効にするとMisskeyの動作が不安定になるかも分からん、知らんけど気ぃつけてや。この設定はブラウザに記憶されんで。" + tools: "ツール" + task-manager: "タスクマネージャ" + third-parties: "サードパーティ" + +desktop/views/components/settings.2fa.vue: + intro: "二段階認証を設定すると、サインイン時にパスワードだけとちゃうくて、予め登録しておいた物理的なデバイス(例えばあんさんのスマートフォンなど)も必要になり、よりセキュリティが向上すんで。" + detail: "詳細..." + url: "https://www.google.co.jp/intl/ja/landing/2step/" + caution: "登録したデバイスを紛失するなどした場合、Misskeyにサインインできんくなるから気ぃつけてや。" + register: "デバイスを登録する" + already-registered: "既に設定は完了してまんねん。" + unregister: "設定を解除" + unregistered: "二段階認証が無効になりはったわ。" + enter-password: "パスワードを入力してや" + authenticator: "まず、Google Authenticatorをつこてるデバイスにインストールするやろ:" + howtoinstall: "インストール方法はこちら" + scan: "ほんなら、表示されているQRコードをスキャンしてな:" + done: "つこてるデバイスに表示されとるトークンを入力して完了や!:" + submit: "完了" + success: "設定が完了したで!" + failed: "設定に失敗したで。トークンを間違えとらんか確認してや。" + info: "次回サインインからは、同様にパスワードに加えてデバイスに表示されとるトークンを入力してな。" + +desktop/views/components/settings.api.vue: + intro: "APIを利用するには、上記のトークンを「i」っちゅうキーでパラメータに付加してリクエストしてや。" + caution: "アカウントを不正利用されるかも知れんから、このトークンは第三者に教えたらあきまへん(アプリなどにも入力しんといてな)。" + regeneration-of-token: "万が一このトークンが漏れたりその可能性がある場合はトークンを再生成できんで。" + regenerate-token: "トークンを再生成" + token: "Token:" + enter-password: "パスワードを入力してや" + +desktop/views/components/settings.apps.vue: + no-apps: "連携しているアプリケーションはあらへん" + +desktop/views/components/settings.drive.vue: + max: "中" + in-use: "使用中" + +desktop/views/components/settings.mute.vue: + no-users: "ミュートしているユーザーはおらん" + +desktop/views/components/settings.password.vue: + reset: "パスワードを変更する" + enter-current-password: "現在のパスワードを入力してや" + enter-new-password: "新しいパスワードを入力してや" + enter-new-password-again: "もう一度新しいパスワードを入力してや" + not-match: "新しいパスワードが一致しとらん" + changed: "パスワードを変更したで" + +desktop/views/components/settings.profile.vue: + avatar: "アイコン" + choice-avatar: "画像を選択" + name: "名前" + location: "場所" + description: "自己紹介" + birthday: "誕生日" + save: "保存" + locked-account: "アカウントの保護" + is-locked: "投稿を非公開にする" + other: "その他" + is-bot: "このアカウントはBotやで" + is-cat: "このアカウントはCatやで" + profile-updated: "プロフィールを更新したで" + +desktop/views/components/sub-note-content.vue: + private: "この投稿は非公開やねん" + deleted: "この投稿は削除されてん" + media-count: "{}つのメディア" + poll: "アンケート" + +desktop/views/components/taskmanager.vue: + title: "タスクマネージャ" + +desktop/views/components/timeline.vue: + home: "ホーム" + local: "ローカル" + hybrid: "ソーシャル" + global: "グローバル" + list: "リスト" + +desktop/views/components/ui.header.vue: + welcome-back: "おかいり、" + adjective: "さん" + +desktop/views/components/ui.header.account.vue: + profile: "プロフィール" + drive: "ドライブ" + favorites: "お気に入り" + lists: "リスト" + follow-requests: "フォロー申請" + customize: "ホームのカスタマイズ" + settings: "設定" + signout: "サインアウト" + dark: "ナイトゲームじゃ!" + +desktop/views/components/ui.header.nav.vue: + home: "ホーム" + deck: "デッキ" + messaging: "メッセージ" + game: "ゲーム" + +desktop/views/components/ui.header.notifications.vue: + title: "通知" + +desktop/views/components/ui.header.post.vue: + post: "新規投稿" + +desktop/views/components/ui.header.search.vue: + placeholder: "検索" + +desktop/views/components/received-follow-requests-window.vue: + title: "フォロー申請" + accept: "承認" + reject: "拒否" + +desktop/views/components/user-lists-window.vue: + title: "リスト" + create-list: "リストを作成" + list-name: "リスト名" + +desktop/views/components/user-preview.vue: + notes: "投稿" + following: "フォロー" + followers: "フォロワー" + +desktop/views/components/users-list.vue: + all: "すべて" + iknow: "知り合い" + load-more: "もっと" + fetching: "読み込んどります" + +desktop/views/components/users-list-item.vue: + followed: "フォローされとります" + +desktop/views/components/window.vue: + popout: "ポップアウト" + close: "ばいなら" + +desktop/views/pages/admin/admin.vue: + dashboard: "ダッシュボード" + drive: "ドライブ" + users: "ユーザー" + update: "更新" + +desktop/views/pages/admin/admin.dashboard.vue: + dashboard: "ダッシュボード" + all-users: "全てのユーザー" + original-users: "このインスタンスのユーザー" + all-notes: "全てのノート" + original-notes: "このインスタンスのノート" + invite: "招待" + +desktop/views/pages/admin/admin.suspend-user.vue: + suspend-user: "ユーザーの凍結" + suspend: "凍結" + suspended: "凍結したで" + +desktop/views/pages/admin/admin.unsuspend-user.vue: + unsuspend-user: "ユーザーの凍結の解除" + unsuspend: "凍結の解除" + unsuspended: "凍結を解除したで" + +desktop/views/pages/admin/admin.verify-user.vue: + verify-user: "ユーザーの公式アカウント設定" + verify: "公式アカウントにする" + verified: "公式アカウントにしたで" + +desktop/views/pages/admin/admin.unverify-user.vue: + unverify-user: "ユーザーの公式アカウント解除" + unverify: "公式アカウントを解除する" + unverified: "公式アカウントを解除したで" + +desktop/views/pages/admin/admin.notes-chart.vue: + title: "投稿" + local: "ローカル" + remote: "リモート" + +desktop/views/pages/admin/admin.users-chart.vue: + title: "ユーザー" + local: "ローカル" + remote: "リモート" + +desktop/views/pages/deck/deck.tl-column.vue: + is-media-only: "メディア投稿のみ" + is-media-view: "メディアビュー" + edit: "オプション" + +desktop/views/pages/deck/deck.note.vue: + reposted-by: "{}がRenote" + private: "この投稿は非公開やねん" + deleted: "この投稿は削除されてん" + +desktop/views/pages/welcome.vue: + about: "詳しく..." + gotit: "ほい" + signin: "ログイン" + signup: "新規登録" + signin-button: "やっとる" + signup-button: "やる" + timeline: "タイムライン" + powered-by-misskey: "Powered by Misskey." + +desktop/views/pages/drive.vue: + title: "Misskey Drive" + +desktop/views/pages/favorites.vue: + more: "さらに読み込む" + +desktop/views/pages/home-customize.vue: + title: "ホームのカスタマイズ" + +desktop/views/pages/note.vue: + prev: "前の投稿" + next: "次の投稿" + +desktop/views/pages/selectdrive.vue: + title: "ファイルを選択してや" + ok: "決定" + cancel: "キャンセル" + upload: "PCからドライブにファイルをアップロード" + +desktop/views/pages/search.vue: + not-available: "検索機能を利用することができへん。" + not-found: "「{}」に関する投稿はあらへん。" + +desktop/views/pages/share.vue: + share-with: "{}で共有" + +desktop/views/pages/tag.vue: + no-posts-found: "ハッシュタグ「{}」が付けられた投稿はあらへん。" + +desktop/views/pages/user-list.users.vue: + users: "ユーザー" + add-user: "ユーザーを追加" + username: "ユーザー名" + +desktop/views/pages/user/user.followers-you-know.vue: + title: "知り合いのフォロワー" + loading: "読み込み中" + no-users: "知り合いのフォロワーはおらん" + +desktop/views/pages/user/user.friends.vue: + title: "よく話すユーザー" + loading: "読み込み中" + no-users: "よく話すユーザーはおらん" + +desktop/views/pages/user/user.vue: + is-suspended: "このユーザーは凍結されとります。" + is-remote: "このユーザーはリモートユーザーや。" + view-remote: "正確な情報を見る" + +desktop/views/pages/user/user.home.vue: + last-used-at: "最終アクセス" + +desktop/views/pages/user/user.photos.vue: + title: "フォト" + loading: "読み込み中" + no-photos: "写真はあらへん" + +desktop/views/pages/user/user.profile.vue: + follows-you: "フォローされとります" + stalk: "ストークする" + stalking: "ストーキングしとります" + unstalk: "ストーク解除" + mute: "ミュートする" + muted: "ミュートしとります" + unmute: "ミュート解除" + push-to-a-list: "リストに追加" + list-pushed: "{user}を{list}に追加したで。" + +desktop/views/pages/user/user.header.vue: + posts: "投稿" + following: "フォロー" + followers: "フォロワー" + is-bot: "このアカウントはBotや" + +desktop/views/pages/user/user.timeline.vue: + default: "投稿" + with-replies: "投稿と返信" + with-media: "メディア" + empty: "このユーザーはまだ何も投稿しとらんようや。" + +desktop/views/widgets/messaging.vue: + title: "メッセージ" + +desktop/views/widgets/notifications.vue: + title: "通知" + settings: "通知の設定" + +desktop/views/widgets/polls.vue: + title: "アンケート" + refresh: "他を見る" + nothing: "あらへん!" + +desktop/views/widgets/post-form.vue: + title: "投稿" + note: "投稿" + +desktop/views/widgets/profile.vue: + update-banner: "クリックでバナー編集" + update-avatar: "クリックでアバター編集" + +desktop/views/widgets/trends.vue: + title: "トレンド" + refresh: "他を見る" + nothing: "あらへん!" + +desktop/views/widgets/users.vue: + title: "おすすめユーザー" + refresh: "他を見る" + no-one: "おらん!" + +mobile/views/components/drive.vue: + drive: "ドライブ" + used: "使用中" + folder-count: "フォルダ" + count-separator: "、" + file-count: "ファイル" + load-more: "もっと読み込む" + nothing-in-drive: "ドライブには何もあらへん" + folder-is-empty: "このフォルダは空や" + prompt: "何すんの?(数字を入力してや): <1 → ファイルをアップロード | 2 → ファイルをURLでアップロード | 3 → フォルダ作成 | 4 → このフォルダ名を変更 | 5 → このフォルダを移動 | 6 → このフォルダを削除>" + deletion-alert: "フォルダの削除は未実装やねん...。堪忍な!" + folder-name: "フォルダー名" + root-rename-alert: "現在おる場所はルートで、フォルダとちゃうから名前の変更はできへん。名前を変更したいフォルダに移動してからやってな。" + root-move-alert: "現在おる場所はルートで、フォルダとちゃうから移動はできへん。移動したいフォルダに移動してからやってな。" + url-prompt: "アップロードしたいファイルのURL" + uploading: "アップロードをリクエストしたで。アップロードが完了するまで時間がかかるかも分からん、知らんけど。" + +mobile/views/components/drive-file-detail.vue: + rename: "名前を変更" + +mobile/views/components/drive-file-chooser.vue: + select-file: "ファイルを選択" + +mobile/views/components/drive-folder-chooser.vue: + select-folder: "フォルダーを選択" + +mobile/views/components/drive.file-detail.vue: + download: "ダウンロード" + rename: "名前を変更" + move: "移動" + hash: "ハッシュ (md5)" + exif: "EXIF" + +mobile/views/components/media-image.vue: + sensitive: "閲覧注意" + click-to-show: "クリックして表示" + +mobile/views/components/media-video.vue: + sensitive: "閲覧注意" + click-to-show: "クリックして表示" + +mobile/views/components/follow-button.vue: + following: "フォロー中" + follow: "フォロー" + request-pending: "フォロー許可待ち" + follow-request: "フォロー申請" + +mobile/views/components/friends-maker.vue: + title: "気になるユーザーをフォロー" + empty: "おすすめのユーザーはおらん。" + fetching: "読み込んどります" + refresh: "もっと見る" + close: "閉じる" + +mobile/views/components/note.vue: + reposted-by: "{}がRenote" + more: "もっと見る" + less: "隠す" + private: "この投稿は非公開やねん" + deleted: "この投稿は削除されてん" + location: "位置情報" + +mobile/views/components/note-detail.vue: + reply: "返信" + reaction: "リアクション" + reposted-by: "{}がRenote" + private: "この投稿は非公開やねん" + deleted: "この投稿は削除されてん" + location: "位置情報" + +mobile/views/components/note-preview.vue: + admin: "admin" + bot: "bot" + cat: "cat" + +mobile/views/components/note-sub.vue: + admin: "admin" + bot: "bot" + cat: "cat" + +mobile/views/components/notes.vue: + failed: "読み込みに失敗したで。" + retry: "もっぺん" + +mobile/views/components/notifications.vue: + more: "もっと見る" + empty: "あらへん!" + +mobile/views/components/post-form.vue: + add-visible-user: "ユーザーを追加" + submit: "投稿" + reply: "返信" + renote: "Renote" + quote-placeholder: "この投稿を引用... (オプション)" + reply-placeholder: "この投稿への返信..." + cw-placeholder: "内容への注釈 (オプション)" + location-alert: "つこてる端末は位置情報に対応しとらんみたいやわ、知らんけど。" + error: "エラー" + username-prompt: "ユーザー名を入力してや" + +mobile/views/components/sub-note-content.vue: + private: "この投稿は非公開やねん" + deleted: "この投稿は削除されてん" + media-count: "{}つのメディア" + poll: "アンケート" + +mobile/views/components/timeline.vue: + empty: "投稿がありません" + load-more: "もっと" + +mobile/views/components/ui.header.vue: + welcome-back: "おかいり、" + adjective: "さん" + +mobile/views/components/ui.nav.vue: + timeline: "タイムライン" + notifications: "通知" + messaging: "メッセージ" + follow-requests: "フォロー申請" + search: "検索" + drive: "ドライブ" + favorites: "お気に入り" + user-lists: "リスト" + widgets: "ウィジェット" + game: "ゲーム" + darkmode: "ダークモード" + settings: "設定" + about: "Misskeyについて" + +mobile/views/components/user-timeline.vue: + no-notes: "このユーザーは投稿しとらんようや。" + no-notes-with-media: "メディア付き投稿はあらへん。" + load-more: "もっと" + +mobile/views/components/users-list.vue: + all: "すべて" + known: "知り合い" + load-more: "もっと" + +mobile/views/pages/favorites.vue: + title: "お気に入り" + +mobile/views/pages/user-lists.vue: + title: "リスト" + enter-list-name: "リスト名を入力してや" + +mobile/views/pages/drive.vue: + drive: "ドライブ" + more: "もっと見る" + +mobile/views/pages/signup.vue: + lets-start: "📦 始めようや" + +mobile/views/pages/followers.vue: + followers-of: "{}のフォロワー" + +mobile/views/pages/following.vue: + following-of: "{}のフォロー" + +mobile/views/pages/home.vue: + home: "ホーム" + local: "ローカル" + hybrid: "ソーシャル" + global: "グローバル" + +mobile/views/pages/tag.vue: + no-posts-found: "ハッシュタグ「{}」が付けられた投稿はあらへん。" + +mobile/views/pages/welcome.vue: + signup: "新規登録" + +mobile/views/pages/widgets.vue: + dashboard: "ダッシュボード" + widgets-hints: "ウィジェットを追加/削除したり並べ替えたりできんで。ウィジェットを移動するんやったら「三」をドラッグしてや。ウィジェットを削除するんやったら「x」をタップしてや。いくつかのウィジェットはタップしたったら表示を変更できるかも分からん、知らんけど。" + add-widget: "追加" + customization-tips: "カスタマイズのヒント" + +mobile/views/pages/widgets/activity.vue: + activity: "アクティビティ" + +mobile/views/pages/share.vue: + share-with: "{}で共有" + +mobile/views/pages/messaging.vue: + messaging: "メッセージ" + +mobile/views/pages/messaging-room.vue: + messaging: "メッセージ" + +mobile/views/pages/received-follow-requests.vue: + title: "フォロー申請" + accept: "承認" + reject: "拒否" + +mobile/views/pages/note.vue: + title: "投稿" + prev: "前の投稿" + next: "次の投稿" + +mobile/views/pages/notifications.vue: + notifications: "通知" + read-all: "すべての通知を既読にしてもええか?" + +mobile/views/pages/games/reversi.vue: + reversi: "リバーシ" + +mobile/views/pages/settings/settings.profile.vue: + title: "プロフィール" + name: "名前" + account: "アカウント" + location: "場所" + description: "自己紹介" + birthday: "誕生日" + avatar: "アイコン" + banner: "バナー" + is-cat: "このアカウントはCatや" + save: "保存" + saved: "プロフィールを保存したで" + uploading: "アップロード中" + upload-failed: "アップロードに失敗したで" + +mobile/views/pages/search.vue: + search: "検索" + empty: "「{}」に関する投稿はあらへん。" + not-found: "「{}」に関する投稿はあらへん。" + +mobile/views/pages/selectdrive.vue: + select-file: "ファイルを選択" + +mobile/views/pages/settings.vue: + signed-in-as: "{}としてサインイン中" + lang: "言語" + lang-tip: "変更はページの再読み込み後に反映されんで。" + recommended: "推奨" + auto: "自動" + specify-language: "言語を指定" + design: "デザインと表示" + dark-mode: "ダークモード" + i-am-under-limited-internet: "私は通信を制限されてんねん" + circle-icons: "円形のアイコンを使用" + timeline: "タイムライン" + show-reply-target: "リプライ先を表示すんで" + show-my-renotes: "自分の行ったRenoteを表示すんで" + show-renoted-my-notes: "自分の投稿のRenoteを表示すんで" + show-local-renotes: "ローカルの投稿のRenoteを表示すんで" + post-style: "投稿の表示スタイル" + post-style-standard: "標準" + post-style-smart: "スマート" + behavior: "動作" + fetch-on-scroll: "スクロールで自動読み込み" + disable-via-mobile: "「モバイルからの投稿」フラグを付けへん" + load-raw-images: "添付された画像を高画質で表示すんで" + load-remote-media: "リモートサーバーのメディアを表示すんで" + twitter: "Twitter連携" + twitter-connect: "Twitterアカウントに接続する" + twitter-reconnect: "再接続する" + twitter-disconnect: "切断する" + update: "Misskey Update" + version: "バージョン:" + latest-version: "最新のバージョン:" + update-checking: "アップデートを確認中" + check-for-updates: "アップデートを確認" + no-updates: "利用可能な更新はあらへん" + no-updates-desc: "つこてるMisskeyは最新や!" + update-available: "新しいバージョンが利用可能や" + update-available-desc: "ページを再度読み込みすると更新が適用されんで。" + settings: "設定" + signout: "サインアウト" + +mobile/views/pages/user.vue: + follows-you: "フォローされとります" + following: "フォロー" + followers: "フォロワー" + notes: "投稿" + overview: "概要" + timeline: "タイムライン" + media: "メディア" + is-suspended: "このユーザーは凍結されとります。" + is-remote: "このユーザーはリモートユーザーや。" + view-remote: "正確な情報を見る" + +mobile/views/pages/user/home.vue: + recent-notes: "最近の投稿" + images: "画像" + activity: "アクティビティ" + keywords: "キーワード" + domains: "頻出ドメイン" + frequently-replied-users: "よく会話するユーザー" + followers-you-know: "知り合いのフォロワー" + last-used-at: "最終ログイン" + +mobile/views/pages/user/home.followers-you-know.vue: + loading: "読み込み中" + no-users: "知り合いのユーザーはおらん" + +mobile/views/pages/user/home.friends.vue: + loading: "読み込み中" + no-users: "よく会話するユーザーはおらん" + +mobile/views/pages/user/home.notes.vue: + loading: "読み込み中" + no-notes: "投稿はありません" + +mobile/views/pages/user/home.photos.vue: + loading: "読み込み中" + no-photos: "写真はありません" + +docs: + edit-this-page-on-github: "間違いや改善点を見つけたん?" + edit-this-page-on-github-link: "このページをGitHubで編集" + + api: + entities: + properties: "プロパティ" + endpoints: + params: "パラメータ" + no-params: "パラメータはありません" + res: "レスポンス" + require-credential: "このエンドポイントは認証情報が必須や。" + require-permission: "このエンドポイントは{permission}の権限が必要や。" + has-limit: "レートリミットがあんで。" + duration-limit: "直近{duration}ミリ秒の間のこのエンドポイントへのリクエスト数の合計が{max}を超えてもうたらリクエストできへん。" + min-interval-limit: "前回のリクエストから{interval}ミリ秒経っとらんとリクエストできへん。" + show-src: "このエンドポイントのソースコードも閲覧できんで。" + show-src-link: "コードをGitHubで見る" + generated: "このドキュメントはAPI定義に基づき自動生成されてんねん。" + props: + name: "名前" + type: "型" + description: "説明" + + +dev/views/index.vue: + manage-apps: "アプリの管理" diff --git a/package.json b/package.json index 3d8df6aae..ff5eeae3f 100644 --- a/package.json +++ b/package.json @@ -1,8 +1,8 @@ { "name": "misskey", "author": "syuilo ", - "version": "6.2.0", - "clientVersion": "1.0.8417", + "version": "7.0.0", + "clientVersion": "1.0.8520", "codename": "nighthike", "main": "./built/index.js", "private": true, @@ -201,7 +201,7 @@ "typescript": "2.9.2", "typescript-eslint-parser": "18.0.0", "uglify-es": "3.3.9", - "url-loader": "1.1.0", + "url-loader": "1.1.1", "uuid": "3.3.2", "v-animate-css": "0.0.2", "vue": "2.5.17", diff --git a/src/client/app/common/scripts/get-face.ts b/src/client/app/common/scripts/get-face.ts new file mode 100644 index 000000000..79cf7a1be --- /dev/null +++ b/src/client/app/common/scripts/get-face.ts @@ -0,0 +1,10 @@ +const faces = [ + '(=^・・^=)', + 'v(\'ω\')v', + '🐡( \'-\' 🐡 )フグパンチ!!!!', + '🖕(´・_・`)🖕', + '(。>﹏<。)', + '(Δ・x・Δ)' +]; + +export default () => faces[Math.floor(Math.random() * faces.length)]; diff --git a/src/client/app/common/scripts/get-kao.ts b/src/client/app/common/scripts/get-kao.ts deleted file mode 100644 index ca83153b9..000000000 --- a/src/client/app/common/scripts/get-kao.ts +++ /dev/null @@ -1,9 +0,0 @@ -const kaos = [ - '(=^・・^=)', - 'v(\'ω\')v', - '🐡( \'-\' 🐡 )フグパンチ!!!!', - '🖕(´・_・`)🖕', - '(。>﹏<。)' -]; - -export default () => kaos[Math.floor(Math.random() * kaos.length)]; diff --git a/src/client/app/common/views/components/games/reversi/reversi.index.vue b/src/client/app/common/views/components/games/reversi/reversi.index.vue index d4d35f6a8..fa88aeaaf 100644 --- a/src/client/app/common/views/components/games/reversi/reversi.index.vue +++ b/src/client/app/common/views/components/games/reversi/reversi.index.vue @@ -32,6 +32,7 @@ {{ g.user1 | userName }} vs {{ g.user2 | userName }} {{ g.isEnded ? '%i18n:@game-state.ended%' : '%i18n:@game-state.playing%' }} +
@@ -41,6 +42,7 @@ {{ g.user1 | userName }} vs {{ g.user2 | userName }} {{ g.isEnded ? '%i18n:@game-state.ended%' : '%i18n:@game-state.playing%' }} +
diff --git a/src/client/app/common/views/components/signup.vue b/src/client/app/common/views/components/signup.vue index 45a183e14..1d3370215 100644 --- a/src/client/app/common/views/components/signup.vue +++ b/src/client/app/common/views/components/signup.vue @@ -1,5 +1,10 @@