FEATURE: Add `Group#full_name`.

This commit is contained in:
Guo Xiang Tan 2016-12-13 16:16:26 +08:00
parent 5a2794a0c7
commit 43ee9f884e
14 changed files with 30 additions and 15 deletions

View File

@ -11,6 +11,11 @@
{{#if model.id}} {{#if model.id}}
{{#unless model.automatic}} {{#unless model.automatic}}
<div>
<label for='full_name'>{{i18n 'groups.edit.full_name'}}</label>
{{input type='text' name='full_name' value=model.full_name class='group-edit-full-name'}}
</div>
<div> <div>
<label for="bio">{{i18n 'groups.bio'}}</label> <label for="bio">{{i18n 'groups.bio'}}</label>
{{d-editor value=model.bio_raw}} {{d-editor value=model.bio_raw}}

View File

@ -36,9 +36,9 @@ export default Ember.Controller.extend({
return !automatic && isGroupOwner; return !automatic && isGroupOwner;
}, },
@computed('model.name', 'model.title') @computed('model.name', 'model.full_name')
groupName(name, title) { groupName(name, fullName) {
return (title || name).capitalize(); return (fullName || name).capitalize();
}, },
@computed('model.name', 'model.flair_url', 'model.flair_bg_color', 'model.flair_color') @computed('model.name', 'model.flair_url', 'model.flair_bg_color', 'model.flair_color')

View File

@ -134,7 +134,8 @@ const Group = Discourse.Model.extend({
flair_color: this.get('flairHexColor'), flair_color: this.get('flairHexColor'),
bio_raw: this.get('bio_raw'), bio_raw: this.get('bio_raw'),
public: this.get('public'), public: this.get('public'),
allow_membership_requests: this.get('allow_membership_requests') allow_membership_requests: this.get('allow_membership_requests'),
full_name: this.get('full_name')
}; };
}, },

View File

@ -1,8 +1,8 @@
<div class='group-edit'> <div class='group-edit'>
<form class="form-horizontal"> <form class="form-horizontal">
<div class="control-group"> <div class="control-group">
<label for='title'>{{i18n 'groups.edit.group_title'}}</label> <label for='full_name'>{{i18n 'groups.edit.full_name'}}</label>
{{input type='text' name='title' value=model.title class='group-edit-title'}} {{input type='text' name='full_name' value=model.full_name class='group-edit-full-name'}}
</div> </div>
<div class="control-group"> <div class="control-group">

View File

@ -16,7 +16,7 @@
<span class='group-title'>{{groupName}}</span> <span class='group-title'>{{groupName}}</span>
</h1> </h1>
{{#if model.title}} {{#if model.full_name}}
<h3 class='group-name'>@{{model.name}}</h3> <h3 class='group-name'>@{{model.name}}</h3>
{{/if}} {{/if}}
</span> </span>

View File

@ -69,6 +69,7 @@ class Admin::GroupsController < Admin::AdminController
group.flair_color = group_params[:flair_color].presence group.flair_color = group_params[:flair_color].presence
group.public = group_params[:public] if group_params[:public] group.public = group_params[:public] if group_params[:public]
group.bio_raw = group_params[:bio_raw] if group_params[:bio_raw] group.bio_raw = group_params[:bio_raw] if group_params[:bio_raw]
group.full_name = group_params[:full_name] if group_params[:full_name]
if group.save if group.save
Group.reset_counters(group.id, :group_users) Group.reset_counters(group.id, :group_users)
@ -145,7 +146,7 @@ class Admin::GroupsController < Admin::AdminController
:name, :alias_level, :visible, :automatic_membership_email_domains, :name, :alias_level, :visible, :automatic_membership_email_domains,
:automatic_membership_retroactive, :title, :primary_group, :automatic_membership_retroactive, :title, :primary_group,
:grant_trust_level, :incoming_email, :flair_url, :flair_bg_color, :grant_trust_level, :incoming_email, :flair_url, :flair_bg_color,
:flair_color, :bio_raw, :public, :allow_membership_requests :flair_color, :bio_raw, :public, :allow_membership_requests, :full_name
) )
end end
end end

View File

@ -239,7 +239,7 @@ class GroupsController < ApplicationController
:flair_bg_color, :flair_bg_color,
:flair_color, :flair_color,
:bio_raw, :bio_raw,
:title, :full_name,
:public, :public,
:allow_membership_requests :allow_membership_requests
) )

View File

@ -514,6 +514,7 @@ end
# bio_cooked :text # bio_cooked :text
# public :boolean default(FALSE), not null # public :boolean default(FALSE), not null
# allow_membership_requests :boolean default(FALSE), not null # allow_membership_requests :boolean default(FALSE), not null
# full_name :string
# #
# Indexes # Indexes
# #

View File

@ -18,7 +18,8 @@ class BasicGroupSerializer < ApplicationSerializer
:bio_raw, :bio_raw,
:bio_cooked, :bio_cooked,
:public, :public,
:allow_membership_requests :allow_membership_requests,
:full_name
def include_incoming_email? def include_incoming_email?
staff? staff?

View File

@ -396,7 +396,7 @@ en:
to: "To" to: "To"
edit: edit:
title: 'Edit Group' title: 'Edit Group'
group_title: 'Title' full_name: 'Full Name'
add_members: "Add Members" add_members: "Add Members"
delete_member_confirm: "Remove '%{username}' from the '%{group}' group?" delete_member_confirm: "Remove '%{username}' from the '%{group}' group?"
request_membership_pm: request_membership_pm:

View File

@ -0,0 +1,5 @@
class AddFullNameToGroups < ActiveRecord::Migration
def change
add_column :groups, :full_name, :string
end
end

View File

@ -41,7 +41,8 @@ describe Admin::GroupsController do
"bio_raw"=>nil, "bio_raw"=>nil,
"bio_cooked"=>nil, "bio_cooked"=>nil,
"public"=>false, "public"=>false,
"allow_membership_requests"=>false "allow_membership_requests"=>false,
"full_name"=>group.full_name
}]) }])
end end

View File

@ -54,7 +54,7 @@ describe "Groups" do
flair_color: 'BBB', flair_color: 'BBB',
flair_url: 'fa-adjust', flair_url: 'fa-adjust',
bio_raw: 'testing', bio_raw: 'testing',
title: 'awesome team', full_name: 'awesome team',
public: true, public: true,
allow_membership_requests: true allow_membership_requests: true
} } } }
@ -68,7 +68,7 @@ describe "Groups" do
expect(group.flair_color).to eq('BBB') expect(group.flair_color).to eq('BBB')
expect(group.flair_url).to eq('fa-adjust') expect(group.flair_url).to eq('fa-adjust')
expect(group.bio_raw).to eq('testing') expect(group.bio_raw).to eq('testing')
expect(group.title).to eq('awesome team') expect(group.full_name).to eq('awesome team')
expect(group.public).to eq(true) expect(group.public).to eq(true)
expect(group.allow_membership_requests).to eq(true) expect(group.allow_membership_requests).to eq(true)
expect(GroupHistory.last.subject).to eq('allow_membership_requests') expect(GroupHistory.last.subject).to eq('allow_membership_requests')

View File

@ -10,7 +10,7 @@ test("Editing group", () => {
andThen(() => { andThen(() => {
ok(find('.group-flair-inputs').length === 1, 'it should display avatar flair inputs'); ok(find('.group-flair-inputs').length === 1, 'it should display avatar flair inputs');
ok(find('.group-edit-bio').length === 1, 'it should display group bio input'); ok(find('.group-edit-bio').length === 1, 'it should display group bio input');
ok(find('.group-edit-title').length === 1, 'it should display group title input'); ok(find('.group-edit-full-name').length === 1, 'it should display group full name input');
ok(find('.group-edit-public').length === 1, 'it should display group public input'); ok(find('.group-edit-public').length === 1, 'it should display group public input');
ok(find('.group-edit-allow-membership-requests').length === 1, 'it should display group allow_membership_requets input'); ok(find('.group-edit-allow-membership-requests').length === 1, 'it should display group allow_membership_requets input');
ok(find('.group-members-input .item').length === 7, 'it should display group members'); ok(find('.group-members-input .item').length === 7, 'it should display group members');