UX: Enabled sorting for more columns in admin user list (#7208)

This commit is contained in:
Tim Lange 2019-03-21 10:16:58 +01:00 committed by Guo Xiang Tan
parent 4e594f2b2b
commit d16a0db4e1
7 changed files with 80 additions and 12 deletions

View File

@ -87,8 +87,8 @@ export default Ember.Controller.extend(CanCheckEmails, {
);
},
showEmails: function() {
this.set("showEmails", true);
toggleEmailVisibility: function() {
this.toggleProperty("showEmails");
this._refreshUsers();
}
}

View File

@ -18,7 +18,6 @@ export default Discourse.Route.extend({
order: transition.to.queryParams.order,
ascending: transition.to.queryParams.ascending,
query: params.filter,
showEmails: false,
refreshing: false
});

View File

@ -8,7 +8,11 @@
<div class="admin-title">
<h2>{{title}}</h2>
{{#if canCheckEmails}}
<button {{action "showEmails"}} class="show-emails btn btn-default">{{i18n 'admin.users.show_emails'}}</button>
{{#if showEmails}}
<button {{action "toggleEmailVisibility"}} class="hide-emails btn btn-default">{{i18n 'admin.users.hide_emails'}}</button>
{{else}}
<button {{action "toggleEmailVisibility"}} class="show-emails btn btn-default">{{i18n 'admin.users.show_emails'}}</button>
{{/if}}
{{/if}}
</div>
<div class='username controls'>
@ -23,9 +27,9 @@
{{#if showApproval}}
<th>{{input type="checkbox" checked=selectAll}}</th>
{{/if}}
<th>{{i18n 'username'}}</th>
<th class='email-heading'>{{i18n 'email'}}</th>
<th>{{i18n 'admin.users.last_emailed'}}</th>
{{admin-directory-toggle field="username" i18nKey='username' order=order ascending=ascending}}
{{admin-directory-toggle field="email" i18nKey='email' order=order ascending=ascending}}
{{admin-directory-toggle field="last_emailed" i18nKey='admin.users.last_emailed' order=order ascending=ascending}}
{{admin-directory-toggle field="seen" i18nKey='last_seen' order=order ascending=ascending}}
{{admin-directory-toggle field="topics_viewed" i18nKey="admin.user.topics_entered" order=order ascending=ascending}}
{{admin-directory-toggle field="posts_read" i18nKey="admin.user.posts_read_count" order=order ascending=ascending}}

View File

@ -435,7 +435,7 @@ $mobile-breakpoint: 700px;
display: flex;
flex-wrap: wrap;
align-items: flex-start;
.show-emails {
.show-emails, .hide-emails {
margin-left: auto;
}
}

View File

@ -3788,6 +3788,7 @@ en:
id_not_found: "Sorry, that user id doesn't exist in our system."
active: "Activated"
show_emails: "Show Emails"
hide_emails: "Hide Emails"
nav:
new: "New"
active: "Active"

View File

@ -9,6 +9,52 @@ QUnit.test("lists users", async assert => {
assert.ok(!exists(".user:eq(0) .email small"), "escapes email");
});
QUnit.test("sorts users", async assert => {
await visit("/admin/users/list/active");
assert.ok(exists(".users-list .user"));
await click(".users-list .sortable:nth-child(1)");
assert.ok(
find(".users-list .user:nth-child(1) .username")
.text()
.includes("eviltrout"),
"list should be sorted by username"
);
await click(".users-list .sortable:nth-child(1)");
assert.ok(
find(".users-list .user:nth-child(1) .username")
.text()
.includes("discobot"),
"list should be sorted ascending by username"
);
});
QUnit.test("toggles email visibility", async assert => {
await visit("/admin/users/list/active");
assert.ok(exists(".users-list .user"));
await click(".show-emails");
assert.equal(
find(".users-list .user:nth-child(1) .email").text(),
"<small>eviltrout@example.com</small>",
"shows the emails"
);
await click(".hide-emails");
assert.equal(
find(".users-list .user:nth-child(1) .email").text(),
"",
"hides the emails"
);
});
QUnit.test("switching tabs", async assert => {
const activeUser = "eviltrout@example.com";
const suspectUser = "sam@example.com";

View File

@ -448,14 +448,32 @@ export default function() {
overridden: true
};
this.get("/admin/users/list/active.json", () => {
return response(200, [
this.get("/admin/users/list/active.json", request => {
let store = [
{
id: 1,
username: "eviltrout",
email: "<small>eviltrout@example.com</small>"
},
{
id: 3,
username: "discobot",
email: "<small>discobot_email</small>"
}
]);
];
const ascending = request.queryParams.ascending;
const order = request.queryParams.order;
if (order) {
store = store.sort(function(a, b) {
return a[order] - b[order];
});
}
if (ascending) {
store = store.reverse();
}
return response(200, store);
});
this.get("/admin/users/list/suspect.json", () => {