批量授予一组用户徽章

Badges are an excellent way to acknowledge someone who is doing a good job. Discourse now allows awarding a badge to a set of users.

If you go to the badges section in the admin panel, you’ll notice that a new button called “Bulk Award” is now available next to the “new” button:

After clicking it, you’ll be prompted to select a badge and get started:

Select the badge you want to award and upload a CSV file containing a list of user emails or usernames (one per line)

Then you’ll be prompted with this message:

Screen Shot 2020-01-15 at 11.39.25

Discourse will find matching users, award them the badge, and send them a notification.

48 个赞

This is cool.

I propose changing this language to “awarding a badge to a set of users”, as group has a specific meaning in Discourse and a bunch of random email addresses in a CSV isn’t it :wink:.

23 个赞

Very nice, This will be useful :slight_smile:

5 个赞

Awww Yiss, that’s very handy. Thanks :slight_smile:.

3 个赞

This is great, thanks for the feature :slight_smile:

5 个赞

Selecting them from a user list could be easier if possible. Good feature anyway.

5 个赞

Yes that’s my ideal idea. :grin:

Just press on users you want to award too.

2 个赞

Sorry, but I’m not 100% clear on this. Terminology I’m familiar with is:

enclosure, delimiter (the separator) and terminator

enclosure is often quotation marks
delimiter is often a comma
terminator is often a newline

eg.

"1", "Bob", "rkelly@gmail.com", "CA" 
"2", "Carol", "counselor@hotmail.com", "CA" 
"2", "Ted", "tman@yahoo.com", "FL" 

I doubt you mean

rkelly@gmail.com 
, 
counselor@hotmail.com 
, 
tman@yahoo.com 
1 个赞

What I meant was:

rkelly@gmail.com,
counselor@hotmail.com, 
tman@yahoo.com

I edited the post.

6 个赞

When bulk-adding users to a group, the system expects a list of user names. When bulk-adding users to a badge, the system expects a .csv file with e-mail addresses.

Personally I prefer the list of usernames, as it’s a lot easier to get those from the forums without jumping through admin-y hoops, and I’ve got some Excel tricks that can spit out a copy-and-pastable list. I used to bulk-assign badges by bulk-adding a list to a temporary group, then changing the badge query to assign to that whole group. When ‘award a badge to a set of users’ popped up I’d hoped to cut out a step…

Is there any way to make the list-of-users method a valid alternative way to bulk-assign badges?

8 个赞

I agree we should be supporting both.

If the first item in the list has an “@”, then import by email, otherwise, import by username.

Also, we could be a little more lenient when it comes to the format of that list.

We could just require the emails/usernames to be on their own line and then do a split("\n"), remove any empty lines, remove any trailing “,” and remove any pair of single/double quotes (eg. gsub(/^['"]|['"]$/, "")).

9 个赞

I know it’s hard and starts to risk mission-creep, but I wonder if over time the admin UI could aim towards more consistency across all Admin bulk operations? For example when:

  1. Awarding Badges in bulk: Select badge then upload a CSV of users’ email addresses

  2. Adding users to a Group in bulk: Select group then paste a list of usernames or emails, one per line

  3. Inviting users to Discourse in bulk: Upload a CSV containing users’ email addresses (optionally specifying groups(s) to add them to and the initial post to show them)

Clearly these have areas of commonality but also areas of definite disparity where they are not doing the same thing. So how easy it is to work towards a consistent UI paradigm for all Admin bulk actions, I don’t know. But I thought I’d raise the issue here since it is being discussed.

Of all three variants, I’d say the nicest at the moment is the Bulk Add To Group ‘Paste a list of usernames or emails, one per line’.

Quite often I want to Invite several users (say 5-10) and the one-by-one invite method is a bit irritatingly slow, but the CSV invite method is a bit faffy and requires me to fire up another program, or edit CSV manually. Even if the CSV upload was kept for the really BIG bulk invites, it would be great to have an Invite Users dialog like the Bulk Add To Group one. Of course it could only accept email addresses, one per line, but this would be fine.

8 个赞

Thanks everyone for the feedback! :slight_smile:

We added username support here:

13 个赞

Though still not as simply as pasting a list of usernames into a box, that’s a great step forward from needing e-mails! Are there any plans to unify the bulk handling of adding users to groups or badges? I’m not a programmer, but that sounds like re-usable code to me :slight_smile:

2 个赞

Is it possible to award users a badge multiple times using this? It seems to not be supported according to my own tests.

Awarding a badge in bulk to a list of users doesn’t grant the ones that already had the badge a second time.

1 个赞

If the badge’s “Can be granted multiple times” checkbox is checked (found in the bottom section of the badge admin page), you should be able to award the badge multiple times in this way.

3 个赞

I have it enabled, but with a CSV import (even only a list of usernames of people that already have the badge) it does not grant it again. I have to manually grant the badge to the user before it shows up as being granted multiple times.

2 个赞

是否可以手动授予一两个人徽章,而不是上传 CSV?

出于某种原因,“爱好者”(连续登录 10 天)徽章未授予已连续登录 12 天的用户。

1 个赞

我认为那个徽章相当可靠,但有时时区和 UTC 之间的差异可能会使其看起来并非如此。

我认为目前您无法手动授予该徽章,但创建一个只包含用户名的 CSV 文件只需一两秒钟。我刚用手机上的 Google 表格试了一下,速度非常快。:+1:

6 个赞

只是为了突出这个帖子,因为 OP 没有清楚地说明如何正确格式化 CSV。

3 个赞