Merge branch 'rylxes-master'
This commit is contained in:
@@ -55,4 +55,4 @@ SMTP_PORT=
|
|||||||
SMTP_USERNAME=
|
SMTP_USERNAME=
|
||||||
SMTP_PASSWORD=
|
SMTP_PASSWORD=
|
||||||
SMTP_FROM_EMAIL=
|
SMTP_FROM_EMAIL=
|
||||||
SMTP_REPLY_EMAIL=
|
SMTP_REPLY_EMAIL=
|
||||||
@@ -7,6 +7,7 @@ class User extends BaseModel {
|
|||||||
name: string;
|
name: string;
|
||||||
email: string;
|
email: string;
|
||||||
isAdmin: boolean;
|
isAdmin: boolean;
|
||||||
|
lastActiveAt: string;
|
||||||
isSuspended: boolean;
|
isSuspended: boolean;
|
||||||
createdAt: string;
|
createdAt: string;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -51,7 +51,7 @@ class UserListItem extends React.Component<Props> {
|
|||||||
subtitle={
|
subtitle={
|
||||||
<React.Fragment>
|
<React.Fragment>
|
||||||
{user.email ? `${user.email} · ` : undefined}
|
{user.email ? `${user.email} · ` : undefined}
|
||||||
Joined <Time dateTime={user.createdAt} /> ago
|
Active <Time dateTime={user.lastActiveAt} /> ago
|
||||||
{user.isAdmin && <Badge admin={user.isAdmin}>Admin</Badge>}
|
{user.isAdmin && <Badge admin={user.isAdmin}>Admin</Badge>}
|
||||||
{user.isSuspended && <Badge>Suspended</Badge>}
|
{user.isSuspended && <Badge>Suspended</Badge>}
|
||||||
</React.Fragment>
|
</React.Fragment>
|
||||||
|
|||||||
@@ -9,6 +9,7 @@ Object {
|
|||||||
"id": "46fde1d4-0050-428f-9f0b-0bf77f4bdf61",
|
"id": "46fde1d4-0050-428f-9f0b-0bf77f4bdf61",
|
||||||
"isAdmin": false,
|
"isAdmin": false,
|
||||||
"isSuspended": false,
|
"isSuspended": false,
|
||||||
|
"lastActiveAt": null,
|
||||||
"name": "User 1",
|
"name": "User 1",
|
||||||
},
|
},
|
||||||
"ok": true,
|
"ok": true,
|
||||||
@@ -43,6 +44,7 @@ Object {
|
|||||||
"id": "46fde1d4-0050-428f-9f0b-0bf77f4bdf61",
|
"id": "46fde1d4-0050-428f-9f0b-0bf77f4bdf61",
|
||||||
"isAdmin": false,
|
"isAdmin": false,
|
||||||
"isSuspended": false,
|
"isSuspended": false,
|
||||||
|
"lastActiveAt": null,
|
||||||
"name": "User 1",
|
"name": "User 1",
|
||||||
},
|
},
|
||||||
"ok": true,
|
"ok": true,
|
||||||
@@ -77,6 +79,7 @@ Object {
|
|||||||
"id": "46fde1d4-0050-428f-9f0b-0bf77f4bdf61",
|
"id": "46fde1d4-0050-428f-9f0b-0bf77f4bdf61",
|
||||||
"isAdmin": false,
|
"isAdmin": false,
|
||||||
"isSuspended": false,
|
"isSuspended": false,
|
||||||
|
"lastActiveAt": null,
|
||||||
"name": "User 1",
|
"name": "User 1",
|
||||||
},
|
},
|
||||||
Object {
|
Object {
|
||||||
@@ -85,6 +88,7 @@ Object {
|
|||||||
"id": "fa952cff-fa64-4d42-a6ea-6955c9689046",
|
"id": "fa952cff-fa64-4d42-a6ea-6955c9689046",
|
||||||
"isAdmin": true,
|
"isAdmin": true,
|
||||||
"isSuspended": false,
|
"isSuspended": false,
|
||||||
|
"lastActiveAt": null,
|
||||||
"name": "Admin User",
|
"name": "Admin User",
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
@@ -108,6 +112,7 @@ Object {
|
|||||||
"id": "46fde1d4-0050-428f-9f0b-0bf77f4bdf61",
|
"id": "46fde1d4-0050-428f-9f0b-0bf77f4bdf61",
|
||||||
"isAdmin": false,
|
"isAdmin": false,
|
||||||
"isSuspended": false,
|
"isSuspended": false,
|
||||||
|
"lastActiveAt": null,
|
||||||
"name": "User 1",
|
"name": "User 1",
|
||||||
},
|
},
|
||||||
Object {
|
Object {
|
||||||
@@ -117,6 +122,7 @@ Object {
|
|||||||
"id": "fa952cff-fa64-4d42-a6ea-6955c9689046",
|
"id": "fa952cff-fa64-4d42-a6ea-6955c9689046",
|
||||||
"isAdmin": true,
|
"isAdmin": true,
|
||||||
"isSuspended": false,
|
"isSuspended": false,
|
||||||
|
"lastActiveAt": null,
|
||||||
"name": "Admin User",
|
"name": "Admin User",
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
@@ -139,6 +145,7 @@ Object {
|
|||||||
"id": "46fde1d4-0050-428f-9f0b-0bf77f4bdf61",
|
"id": "46fde1d4-0050-428f-9f0b-0bf77f4bdf61",
|
||||||
"isAdmin": true,
|
"isAdmin": true,
|
||||||
"isSuspended": false,
|
"isSuspended": false,
|
||||||
|
"lastActiveAt": null,
|
||||||
"name": "User 1",
|
"name": "User 1",
|
||||||
},
|
},
|
||||||
"ok": true,
|
"ok": true,
|
||||||
@@ -173,6 +180,7 @@ Object {
|
|||||||
"id": "46fde1d4-0050-428f-9f0b-0bf77f4bdf61",
|
"id": "46fde1d4-0050-428f-9f0b-0bf77f4bdf61",
|
||||||
"isAdmin": false,
|
"isAdmin": false,
|
||||||
"isSuspended": true,
|
"isSuspended": true,
|
||||||
|
"lastActiveAt": null,
|
||||||
"name": "User 1",
|
"name": "User 1",
|
||||||
},
|
},
|
||||||
"ok": true,
|
"ok": true,
|
||||||
@@ -196,20 +204,4 @@ Object {
|
|||||||
"ok": false,
|
"ok": false,
|
||||||
"status": 401,
|
"status": 401,
|
||||||
}
|
}
|
||||||
`;
|
`;
|
||||||
|
|
||||||
exports[`#users.update should update user profile information 1`] = `
|
|
||||||
Object {
|
|
||||||
"data": Object {
|
|
||||||
"avatarUrl": "http://example.com/avatar.png",
|
|
||||||
"createdAt": "2018-01-02T00:00:00.000Z",
|
|
||||||
"email": "user1@example.com",
|
|
||||||
"id": "46fde1d4-0050-428f-9f0b-0bf77f4bdf61",
|
|
||||||
"isAdmin": false,
|
|
||||||
"isSuspended": false,
|
|
||||||
"name": "New name",
|
|
||||||
},
|
|
||||||
"ok": true,
|
|
||||||
"status": 200,
|
|
||||||
}
|
|
||||||
`;
|
|
||||||
@@ -107,7 +107,7 @@ describe('#users.update', async () => {
|
|||||||
const body = await res.json();
|
const body = await res.json();
|
||||||
|
|
||||||
expect(res.status).toEqual(200);
|
expect(res.status).toEqual(200);
|
||||||
expect(body).toMatchSnapshot();
|
expect(body.data.name).toEqual('New name');
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should require authentication', async () => {
|
it('should require authentication', async () => {
|
||||||
|
|||||||
@@ -7,6 +7,7 @@ Object {
|
|||||||
"id": "123",
|
"id": "123",
|
||||||
"isAdmin": undefined,
|
"isAdmin": undefined,
|
||||||
"isSuspended": undefined,
|
"isSuspended": undefined,
|
||||||
|
"lastActiveAt": undefined,
|
||||||
"name": "Test User",
|
"name": "Test User",
|
||||||
}
|
}
|
||||||
`;
|
`;
|
||||||
@@ -18,6 +19,7 @@ Object {
|
|||||||
"id": "123",
|
"id": "123",
|
||||||
"isAdmin": undefined,
|
"isAdmin": undefined,
|
||||||
"isSuspended": undefined,
|
"isSuspended": undefined,
|
||||||
|
"lastActiveAt": undefined,
|
||||||
"name": "Test User",
|
"name": "Test User",
|
||||||
}
|
}
|
||||||
`;
|
`;
|
||||||
|
|||||||
@@ -18,6 +18,7 @@ export default (user: User, options: Options = {}): ?UserPresentation => {
|
|||||||
const userData = {};
|
const userData = {};
|
||||||
userData.id = user.id;
|
userData.id = user.id;
|
||||||
userData.createdAt = user.createdAt;
|
userData.createdAt = user.createdAt;
|
||||||
|
userData.lastActiveAt = user.lastActiveAt;
|
||||||
userData.name = user.name;
|
userData.name = user.name;
|
||||||
userData.isAdmin = user.isAdmin;
|
userData.isAdmin = user.isAdmin;
|
||||||
userData.isSuspended = user.isSuspended;
|
userData.isSuspended = user.isSuspended;
|
||||||
|
|||||||
Reference in New Issue
Block a user