@@ -174,6 +182,33 @@ export default Vue.extend({
padding 16px 16px 16px 154px
color var(--text)
+ > .fields
+ margin-top 16px
+
+ > .field
+ display flex
+ padding 0
+ margin 0
+
+ > .name
+ border-right solid 1px var(--faceDivider)
+ padding 4px
+ margin 4px
+ width 30%
+ overflow hidden
+ white-space nowrap
+ text-overflow ellipsis
+ font-weight bold
+ text-align center
+
+ > .value
+ padding 4px
+ margin 4px
+ width 70%
+ overflow hidden
+ white-space nowrap
+ text-overflow ellipsis
+
> .info
margin-top 16px
padding-top 16px
diff --git a/src/client/app/mobile/views/pages/user.vue b/src/client/app/mobile/views/pages/user.vue
index 804168a18..dc03f10f9 100644
--- a/src/client/app/mobile/views/pages/user.vue
+++ b/src/client/app/mobile/views/pages/user.vue
@@ -24,6 +24,14 @@
{{ user.profile.location }}
@@ -301,6 +309,33 @@ main
margin 8px 0
color var(--mobileUserPageDescription)
+ > .fields
+ margin 8px 0
+
+ > .field
+ display flex
+ padding 0
+ margin 0
+
+ > .name
+ padding 4px
+ margin 4px
+ width 30%
+ overflow hidden
+ white-space nowrap
+ text-overflow ellipsis
+ font-weight bold
+ color var(--mobileUserPageStatusHighlight)
+
+ > .value
+ padding 4px
+ margin 4px
+ width 70%
+ overflow hidden
+ white-space nowrap
+ text-overflow ellipsis
+ color var(--mobileUserPageStatusHighlight)
+
> .info
margin 8px 0
diff --git a/src/mfm/html-to-mfm.ts b/src/mfm/html-to-mfm.ts
index aa887c556..9a9fbbb86 100644
--- a/src/mfm/html-to-mfm.ts
+++ b/src/mfm/html-to-mfm.ts
@@ -41,7 +41,7 @@ export default function(html: string): string {
if ((rel && rel.value.match('tag') !== null) || !href || href.value == txt) {
text += txt;
// メンション
- } else if (txt.startsWith('@')) {
+ } else if (txt.startsWith('@') && !rel || !rel.value.match(/^me /)) {
const part = txt.split('@');
if (part.length == 2) {
diff --git a/src/models/user.ts b/src/models/user.ts
index 90c74fe27..0b19ffa7b 100644
--- a/src/models/user.ts
+++ b/src/models/user.ts
@@ -109,6 +109,10 @@ export interface ILocalUser extends IUserBase {
birthday: string; // 'YYYY-MM-DD'
tags: string[];
};
+ fields?: {
+ name: string;
+ value: string;
+ }[];
isCat: boolean;
isAdmin?: boolean;
isModerator?: boolean;
diff --git a/src/remote/activitypub/models/person.ts b/src/remote/activitypub/models/person.ts
index 9bbc41e62..6f62da5ca 100644
--- a/src/remote/activitypub/models/person.ts
+++ b/src/remote/activitypub/models/person.ts
@@ -17,6 +17,7 @@ import registerInstance from '../../../services/register-instance';
import Instance from '../../../models/instance';
import getDriveFileUrl from '../../../misc/get-drive-file-url';
import { IEmoji } from '../../../models/emoji';
+import { ITag } from './tag';
const log = debug('misskey:activitypub');
@@ -135,6 +136,10 @@ export async function createPerson(uri: string, resolver?: Resolver): Promise {
+ console.log(`cat not extract fields: ${e}`);
+ });
+
const isBot = object.type == 'Service';
// Create user
@@ -164,6 +169,7 @@ export async function createPerson(uri: string, resolver?: Resolver): Promise emoji.name);
+ const fields = await extractFields(person.attachment).catch(e => {
+ console.log(`cat not extract fields: ${e}`);
+ });
+
// Update user
await User.update({ _id: exist._id }, {
$set: {
@@ -346,6 +356,7 @@ export async function updatePerson(uri: string, resolver?: Resolver, hint?: obje
name: person.name,
url: person.url,
endpoints: person.endpoints,
+ fields,
isBot: object.type == 'Service',
isCat: (person as any).isCat === true,
isLocked: person.manuallyApprovesFollowers,
@@ -382,6 +393,18 @@ export async function resolvePerson(uri: string, verifier?: string, resolver?: R
return await createPerson(uri, resolver);
}
+export async function extractFields(attachments: ITag[]) {
+ if (!attachments) return [];
+
+ return attachments.filter(a => a.type === 'PropertyValue' && a.name && a.value)
+ .map(a => {
+ return {
+ name: a.name,
+ value: htmlToMFM(a.value)
+ };
+ });
+}
+
export async function updateFeatured(userId: mongo.ObjectID) {
const user = await User.findOne({ _id: userId });
if (!isRemoteUser(user)) return;
diff --git a/src/remote/activitypub/models/tag.ts b/src/remote/activitypub/models/tag.ts
index 5cdbfa43b..7c9b41eb2 100644
--- a/src/remote/activitypub/models/tag.ts
+++ b/src/remote/activitypub/models/tag.ts
@@ -7,6 +7,7 @@ export type ITag = {
id: string;
type: string;
name?: string;
+ value?: string;
updated?: Date;
icon?: IIcon;
};