UX: Allow group owners to manage members from group members page.

This commit is contained in:
Guo Xiang Tan 2018-03-21 18:16:08 +08:00
parent a23509cbf3
commit be866dbe6e
11 changed files with 99 additions and 9 deletions

View File

@ -0,0 +1,32 @@
import { iconHTML } from 'discourse-common/lib/icon-library';
import DropdownButton from 'discourse/components/dropdown-button';
import computed from "ember-addons/ember-computed-decorators";
export default DropdownButton.extend({
buttonExtraClasses: 'no-text',
title: '',
text: iconHTML('ellipsis-h'),
classNames: ['group-member-dropdown'],
@computed()
dropDownContent() {
const items = [
{
id: 'removeMember',
title: I18n.t('groups.members.remove_member'),
description: I18n.t('groups.members.remove_member_description'),
icon: 'user-times'
}
];
return items;
},
clicked(id) {
switch (id) {
case 'removeMember':
this.sendAction('removeMember', this.get('member'));
break;
}
}
});

View File

@ -27,6 +27,11 @@ export default Ember.Controller.extend({
return members && members.length > 0; return members && members.length > 0;
}, },
@computed
canManageGroup() {
return this.currentUser && this.currentUser.canManageGroup(this.get('model'));
},
actions: { actions: {
toggleActions() { toggleActions() {
this.toggleProperty("showActions"); this.toggleProperty("showActions");

View File

@ -19,7 +19,8 @@ export default Ember.Controller.extend({
const membersTab = Tab.create({ const membersTab = Tab.create({
name: 'members', name: 'members',
route: 'group.index', route: 'group.index',
icon: 'users' icon: 'users',
i18nKey: "members.title"
}); });
membersTab.set('count', userCount); membersTab.set('count', userCount);

View File

@ -1,6 +1,6 @@
export default Discourse.Route.extend({ export default Discourse.Route.extend({
titleToken() { titleToken() {
return I18n.t('groups.members'); return I18n.t('groups.members.title');
}, },
model() { model() {

View File

@ -1,4 +1,4 @@
<label>{{i18n 'groups.members'}} ({{model.user_count}})</label> <label>{{i18n 'groups.members.title'}} ({{model.user_count}})</label>
{{#if model.members}} {{#if model.members}}
<div> <div>

View File

@ -5,6 +5,7 @@
{{group-index-toggle order=order desc=desc field='username_lower' i18nKey='username'}} {{group-index-toggle order=order desc=desc field='username_lower' i18nKey='username'}}
{{group-index-toggle order=order desc=desc field='last_posted_at' i18nKey='last_post'}} {{group-index-toggle order=order desc=desc field='last_posted_at' i18nKey='last_post'}}
{{group-index-toggle order=order desc=desc field='last_seen_at' i18nKey='last_seen'}} {{group-index-toggle order=order desc=desc field='last_seen_at' i18nKey='last_seen'}}
<th></th>
</thead> </thead>
<tbody> <tbody>
@ -21,6 +22,14 @@
<td> <td>
<span class="text">{{bound-date m.last_seen_at}}</span> <span class="text">{{bound-date m.last_seen_at}}</span>
</td> </td>
<td>
{{#if canManageGroup}}
{{group-member-dropdown
removeMember="removeMember"
member=m}}
{{/if}}
</td>
</tr> </tr>
{{/each}} {{/each}}
</tbody> </tbody>

View File

@ -124,6 +124,10 @@ table.group-members {
text-align: left; text-align: left;
} }
th:last-child {
width: 5%;
}
th.group-members-actions { th.group-members-actions {
width: 5%; width: 5%;
} }

View File

@ -0,0 +1,9 @@
.group-member-dropdown {
ul {
width: 250px;
top: 27px;
bottom: auto;
left: -217px;
text-align: left;
}
}

View File

@ -464,7 +464,10 @@ en:
one: "Group" one: "Group"
other: "Groups" other: "Groups"
activity: "Activity" activity: "Activity"
members: "Members" members:
title: "Members"
remove_member: "Remove member"
remove_member_description: "Remove a member from this group"
topics: "Topics" topics: "Topics"
posts: "Posts" posts: "Posts"
mentions: "Mentions" mentions: "Mentions"

View File

@ -0,0 +1,31 @@
import { acceptance, logIn } from "helpers/qunit-helpers";
acceptance("Group Members");
QUnit.test("Viewing Members as anon user", assert => {
visit("/groups/discourse");
andThen(() => {
assert.ok(count('.avatar-flair .fa-adjust') === 1, "it displays the group's avatar flair");
assert.ok(count('.group-members tr') > 0, "it lists group members");
assert.ok(
count('.group-member-dropdown') === 0,
'it does not allow anon user to manage group members'
);
});
});
QUnit.test("Viewing Members as an admin user", assert => {
logIn();
Discourse.reset();
visit("/groups/discourse");
andThen(() => {
assert.ok(
count('.group-member-dropdown') > 0,
'it allows admin user to manage group members'
);
});
});

View File

@ -69,10 +69,6 @@ QUnit.test("Anonymous Viewing Group", assert => {
visit("/groups/discourse"); visit("/groups/discourse");
andThen(() => { andThen(() => {
assert.ok(count('.avatar-flair .fa-adjust') === 1, "it displays the group's avatar flair");
assert.ok(count('.group-members tr') > 0, "it lists group members");
assert.ok(count('.group-message-button') === 0, 'it does not show group message button');
assert.equal( assert.equal(
count(".nav-pills li a[title='Messages']"), count(".nav-pills li a[title='Messages']"),
0, 0,