From cd2542e0fd8578f6e41114ffebbda1f16f7d04ce Mon Sep 17 00:00:00 2001 From: syuilo Date: Mon, 2 Apr 2018 04:15:27 +0900 Subject: Refactor --- src/misc/user/get-acct.ts | 3 +++ src/misc/user/get-summary.ts | 18 ++++++++++++++++++ src/misc/user/parse-acct.ts | 4 ++++ 3 files changed, 25 insertions(+) create mode 100644 src/misc/user/get-acct.ts create mode 100644 src/misc/user/get-summary.ts create mode 100644 src/misc/user/parse-acct.ts (limited to 'src/misc/user') diff --git a/src/misc/user/get-acct.ts b/src/misc/user/get-acct.ts new file mode 100644 index 0000000000..9afb03d88b --- /dev/null +++ b/src/misc/user/get-acct.ts @@ -0,0 +1,3 @@ +export default user => { + return user.host === null ? user.username : `${user.username}@${user.host}`; +}; diff --git a/src/misc/user/get-summary.ts b/src/misc/user/get-summary.ts new file mode 100644 index 0000000000..2c71d3eae9 --- /dev/null +++ b/src/misc/user/get-summary.ts @@ -0,0 +1,18 @@ +import { IUser, isLocalUser } from '../../models/user'; +import getAcct from './get-acct'; + +/** + * ユーザーを表す文字列を取得します。 + * @param user ユーザー + */ +export default function(user: IUser): string { + let string = `${user.name} (@${getAcct(user)})\n` + + `${user.postsCount}投稿、${user.followingCount}フォロー、${user.followersCount}フォロワー\n`; + + if (isLocalUser(user)) { + const account = user.account; + string += `場所: ${account.profile.location}、誕生日: ${account.profile.birthday}\n`; + } + + return string + `「${user.description}」`; +} diff --git a/src/misc/user/parse-acct.ts b/src/misc/user/parse-acct.ts new file mode 100644 index 0000000000..ef1f55405d --- /dev/null +++ b/src/misc/user/parse-acct.ts @@ -0,0 +1,4 @@ +export default acct => { + const splitted = acct.split('@', 2); + return { username: splitted[0], host: splitted[1] || null }; +}; -- cgit v1.2.3-freya