adds hound_bot's and zmagos suggestions

This commit is contained in:
Toni Dezman 2017-09-07 13:40:53 +02:00
parent b7bed5b5fe
commit 67d617deb5
3 changed files with 37 additions and 34 deletions

View file

@ -60,8 +60,9 @@ module ClientApi
timezone = if user.save timezone = if user.save
user.time_zone user.time_zone
else else
msg = 'You need to select valid TimeZone.'
user.reload.time_zone user.reload.time_zone
errors[:timezone_errors] << 'You need to select valid TimeZone.' errors[:timezone_errors] << msg
end end
respond_to do |format| respond_to do |format|
@ -86,7 +87,8 @@ module ClientApi
end end
respond_to do |format| respond_to do |format|
format.json { render json: { email: saved_email || current_email, errors: errors } } resp = { email: saved_email || current_email, errors: errors }
format.json { render json: resp }
end end
end end
@ -100,7 +102,8 @@ module ClientApi
end end
respond_to do |format| respond_to do |format|
format.json { render json: { fullName: saved_name, errors: user.errors.messages } } resp = { fullName: saved_name, errors: user.errors.messages }
format.json { render json: resp }
end end
end end

View file

@ -23,7 +23,7 @@ class NotificationsSwitchGroup extends Component {
super(props); super(props);
this.state = { this.state = {
isSciNoteSwitchOn: false, isSwitchOn: false,
isEmailSwitchOn: false isEmailSwitchOn: false
}; };
@ -36,7 +36,7 @@ class NotificationsSwitchGroup extends Component {
switch (this.props.type) { switch (this.props.type) {
case ASSIGNMENT_NOTIFICATION: case ASSIGNMENT_NOTIFICATION:
this.setState({ this.setState({
isSciNoteSwitchOn: this.props.assignmentsNotification, isSwitchOn: this.props.assignmentsNotification,
isEmailSwitchOn: this.props.assignmentsNotificationEmail, isEmailSwitchOn: this.props.assignmentsNotificationEmail,
sciNoteDispatch: state => sciNoteDispatch: state =>
this.props.changeAssignmentsNotification(state), this.props.changeAssignmentsNotification(state),
@ -46,7 +46,7 @@ class NotificationsSwitchGroup extends Component {
break; break;
case RECENT_NOTIFICATION: case RECENT_NOTIFICATION:
this.setState({ this.setState({
isSciNoteSwitchOn: this.props.recentNotification, isSwitchOn: this.props.recentNotification,
isEmailSwitchOn: this.props.recentNotificationEmail, isEmailSwitchOn: this.props.recentNotificationEmail,
sciNoteDispatch: state => this.props.changeRecentNotification(state), sciNoteDispatch: state => this.props.changeRecentNotification(state),
emailDispatch: state => emailDispatch: state =>
@ -55,7 +55,7 @@ class NotificationsSwitchGroup extends Component {
break; break;
case SYSTEM_NOTIFICATION: case SYSTEM_NOTIFICATION:
this.setState({ this.setState({
isSciNoteSwitchOn: true, isSwitchOn: true,
isEmailSwitchOn: this.props.systemMessageNotificationEmail, isEmailSwitchOn: this.props.systemMessageNotificationEmail,
sciNoteDispatch: state => `${state}: Do Nothing`, sciNoteDispatch: state => `${state}: Do Nothing`,
emailDispatch: state => emailDispatch: state =>
@ -64,19 +64,19 @@ class NotificationsSwitchGroup extends Component {
break; break;
default: default:
this.setState({ this.setState({
isSciNoteSwitchOn: false, isSwitchOn: false,
isEmailSwitchOn: false isEmailSwitchOn: false
}); });
} }
} }
toggleFirstSwitch() { toggleFirstSwitch() {
if (this.state.isSciNoteSwitchOn) { if (this.state.isSwitchOn) {
this.setState({ isSciNoteSwitchOn: false, isEmailSwitchOn: false }); this.setState({ isSwitchOn: false, isEmailSwitchOn: false });
this.state.sciNoteDispatch(false); this.state.sciNoteDispatch(false);
this.state.emailDispatch(false); this.state.emailDispatch(false);
} else { } else {
this.setState({ isSciNoteSwitchOn: true }); this.setState({ isSwitchOn: true });
this.state.sciNoteDispatch(true); this.state.sciNoteDispatch(true);
} }
} }
@ -104,7 +104,7 @@ class NotificationsSwitchGroup extends Component {
<div> <div>
<NotificationsSwitch <NotificationsSwitch
title="settings_page.show_in_scinote" title="settings_page.show_in_scinote"
isSwitchOn={this.state.isSciNoteSwitchOn} isSwitchOn={this.state.isSwitchOn}
toggleSwitch={this.toggleFirstSwitch} toggleSwitch={this.toggleFirstSwitch}
isDisabled={this.isSwitchDisabled()} isDisabled={this.isSwitchDisabled()}
/> />
@ -112,7 +112,7 @@ class NotificationsSwitchGroup extends Component {
title="settings_page.notify_me_via_email" title="settings_page.notify_me_via_email"
isSwitchOn={this.state.isEmailSwitchOn} isSwitchOn={this.state.isEmailSwitchOn}
toggleSwitch={this.toggleSecondSwitch} toggleSwitch={this.toggleSecondSwitch}
isDisabled={!this.state.isSciNoteSwitchOn} isDisabled={!this.state.isSwitchOn}
/> />
</div> </div>
); );

View file

@ -46,28 +46,28 @@ describe ClientApi::Users::UsersController, type: :controller do
it 'responds successfully' do it 'responds successfully' do
user = User.first user = User.first
expect(user.time_zone).to eq('UTC') expect(user.time_zone).to eq('UTC')
post :change_timezone, params: { timezone: 'Pacific/Fiji'}, format: :json post :change_timezone, params: { timezone: 'Pacific/Fiji' }, format: :json
expect(response).to have_http_status(:ok) expect(response).to have_http_status(:ok)
end end
it 'changes timezone' do it 'changes timezone' do
user = User.first user = User.first
expect(user.time_zone).to eq('UTC') expect(user.time_zone).to eq('UTC')
post :change_timezone, params: { timezone: 'Pacific/Fiji'}, format: :json post :change_timezone, params: { timezone: 'Pacific/Fiji' }, format: :json
expect(user.reload.time_zone).to eq('Pacific/Fiji') expect(user.reload.time_zone).to eq('Pacific/Fiji')
end end
end end
describe 'POST change_initials' do describe 'POST change_initials' do
it 'responds successfully' do it 'responds successfully' do
post :change_initials, params: { initials: 'TD'}, format: :json post :change_initials, params: { initials: 'TD' }, format: :json
expect(response).to have_http_status(:ok) expect(response).to have_http_status(:ok)
end end
it 'responds successfully' do it 'responds successfully' do
user = User.first user = User.first
expect(user.initials).not_to eq('TD') expect(user.initials).not_to eq('TD')
post :change_initials, params: { initials: 'TD'}, format: :json post :change_initials, params: { initials: 'TD' }, format: :json
expect(user.reload.initials).to eq('TD') expect(user.reload.initials).to eq('TD')
end end
end end