Display modal in registration window when confirmations and/or approval are required
This commit is contained in:
parent
d8fe5c33d4
commit
e261a13430
4 changed files with 59 additions and 11 deletions
|
@ -1,6 +1,5 @@
|
||||||
import api from '../api';
|
import api from '../api';
|
||||||
import snackbar from 'soapbox/actions/snackbar';
|
import snackbar from 'soapbox/actions/snackbar';
|
||||||
import { fetchMe } from 'soapbox/actions/me';
|
|
||||||
|
|
||||||
export const AUTH_APP_CREATED = 'AUTH_APP_CREATED';
|
export const AUTH_APP_CREATED = 'AUTH_APP_CREATED';
|
||||||
export const AUTH_APP_AUTHORIZED = 'AUTH_APP_AUTHORIZED';
|
export const AUTH_APP_AUTHORIZED = 'AUTH_APP_AUTHORIZED';
|
||||||
|
@ -164,8 +163,6 @@ export function logOut() {
|
||||||
|
|
||||||
export function register(params) {
|
export function register(params) {
|
||||||
return (dispatch, getState) => {
|
return (dispatch, getState) => {
|
||||||
const needsConfirmation = getState().getIn(['instance', 'pleroma', 'metadata', 'account_activation_required']);
|
|
||||||
const needsApproval = getState().getIn(['instance', 'approval_required']);
|
|
||||||
params.fullname = params.username;
|
params.fullname = params.username;
|
||||||
dispatch({ type: AUTH_REGISTER_REQUEST });
|
dispatch({ type: AUTH_REGISTER_REQUEST });
|
||||||
return dispatch(createAppAndToken()).then(() => {
|
return dispatch(createAppAndToken()).then(() => {
|
||||||
|
@ -173,13 +170,6 @@ export function register(params) {
|
||||||
}).then(response => {
|
}).then(response => {
|
||||||
dispatch({ type: AUTH_REGISTER_SUCCESS, token: response.data });
|
dispatch({ type: AUTH_REGISTER_SUCCESS, token: response.data });
|
||||||
dispatch(authLoggedIn(response.data));
|
dispatch(authLoggedIn(response.data));
|
||||||
if (needsConfirmation) {
|
|
||||||
return dispatch(snackbar.info('You must confirm your email.'));
|
|
||||||
} else if (needsApproval) {
|
|
||||||
return dispatch(snackbar.info('Your account is pending review by an admin.'));
|
|
||||||
} else {
|
|
||||||
return dispatch(fetchMe());
|
|
||||||
}
|
|
||||||
}).catch(error => {
|
}).catch(error => {
|
||||||
dispatch({ type: AUTH_REGISTER_FAIL, error });
|
dispatch({ type: AUTH_REGISTER_FAIL, error });
|
||||||
throw error;
|
throw error;
|
||||||
|
|
|
@ -17,6 +17,8 @@ import CaptchaField from 'soapbox/features/auth_login/components/captcha';
|
||||||
import { Map as ImmutableMap } from 'immutable';
|
import { Map as ImmutableMap } from 'immutable';
|
||||||
import { v4 as uuidv4 } from 'uuid';
|
import { v4 as uuidv4 } from 'uuid';
|
||||||
import { getSettings } from 'soapbox/actions/settings';
|
import { getSettings } from 'soapbox/actions/settings';
|
||||||
|
import { fetchMe } from 'soapbox/actions/me';
|
||||||
|
import { openModal } from 'soapbox/actions/modal';
|
||||||
|
|
||||||
const messages = defineMessages({
|
const messages = defineMessages({
|
||||||
username: { id: 'registration.fields.username_placeholder', defaultMessage: 'Username' },
|
username: { id: 'registration.fields.username_placeholder', defaultMessage: 'Username' },
|
||||||
|
@ -26,11 +28,14 @@ const messages = defineMessages({
|
||||||
confirm: { id: 'registration.fields.confirm_placeholder', defaultMessage: 'Password (again)' },
|
confirm: { id: 'registration.fields.confirm_placeholder', defaultMessage: 'Password (again)' },
|
||||||
agreement: { id: 'registration.agreement', defaultMessage: 'I agree to the {tos}.' },
|
agreement: { id: 'registration.agreement', defaultMessage: 'I agree to the {tos}.' },
|
||||||
tos: { id: 'registration.tos', defaultMessage: 'Terms of Service' },
|
tos: { id: 'registration.tos', defaultMessage: 'Terms of Service' },
|
||||||
|
close: { id: 'registration.confirmation_modal.close', defaultMessage: 'Close' },
|
||||||
});
|
});
|
||||||
|
|
||||||
const mapStateToProps = (state, props) => ({
|
const mapStateToProps = (state, props) => ({
|
||||||
instance: state.get('instance'),
|
instance: state.get('instance'),
|
||||||
locale: getSettings(state).get('locale'),
|
locale: getSettings(state).get('locale'),
|
||||||
|
needsConfirmation: state.getIn(['instance', 'pleroma', 'metadata', 'account_activation_required']),
|
||||||
|
needsApproval: state.getIn(['instance', 'approval_required']),
|
||||||
});
|
});
|
||||||
|
|
||||||
export default @connect(mapStateToProps)
|
export default @connect(mapStateToProps)
|
||||||
|
@ -62,10 +67,48 @@ class RegistrationForm extends ImmutablePureComponent {
|
||||||
this.setParams({ [e.target.name]: e.target.checked });
|
this.setParams({ [e.target.name]: e.target.checked });
|
||||||
}
|
}
|
||||||
|
|
||||||
|
launchModal = () => {
|
||||||
|
const { dispatch, intl, needsConfirmation, needsApproval } = this.props;
|
||||||
|
|
||||||
|
const message = (<>
|
||||||
|
{needsConfirmation && <p>
|
||||||
|
<FormattedMessage
|
||||||
|
id='confirmations.register.needs_confirmation'
|
||||||
|
defaultMessage='Please check your inbox at {email} for confirmation instructions. You will need to verify your email address to continue.'
|
||||||
|
values={{ email: <strong>{this.state.params.get('email')}</strong> }}
|
||||||
|
/></p>}
|
||||||
|
{needsApproval && <p>
|
||||||
|
<FormattedMessage
|
||||||
|
id='confirmations.register.needs_approval'
|
||||||
|
defaultMessage='Your account will be manually approved by an admin. Please be patient while we review your details.'
|
||||||
|
/></p>}
|
||||||
|
</>);
|
||||||
|
|
||||||
|
dispatch(openModal('CONFIRM', {
|
||||||
|
message,
|
||||||
|
confirm: intl.formatMessage(messages.close),
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
|
||||||
|
postRegisterAction = () => {
|
||||||
|
const { dispatch, needsConfirmation, needsApproval } = this.props;
|
||||||
|
|
||||||
|
if (needsConfirmation || needsApproval) {
|
||||||
|
return this.launchModal();
|
||||||
|
} else {
|
||||||
|
return dispatch(fetchMe());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
onSubmit = e => {
|
onSubmit = e => {
|
||||||
|
const { dispatch } = this.props;
|
||||||
const params = this.state.params.set('locale', this.props.locale);
|
const params = this.state.params.set('locale', this.props.locale);
|
||||||
|
|
||||||
this.setState({ submissionLoading: true });
|
this.setState({ submissionLoading: true });
|
||||||
this.props.dispatch(register(params.toJS())).catch(error => {
|
|
||||||
|
dispatch(register(params.toJS())).then(() => {
|
||||||
|
this.postRegisterAction();
|
||||||
|
}).catch(error => {
|
||||||
this.setState({ submissionLoading: false });
|
this.setState({ submissionLoading: false });
|
||||||
this.refreshCaptcha();
|
this.refreshCaptcha();
|
||||||
});
|
});
|
||||||
|
|
|
@ -3,6 +3,7 @@ import { connect } from 'react-redux';
|
||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import { Switch, Route } from 'react-router-dom';
|
import { Switch, Route } from 'react-router-dom';
|
||||||
import NotificationsContainer from 'soapbox/features/ui/containers/notifications_container';
|
import NotificationsContainer from 'soapbox/features/ui/containers/notifications_container';
|
||||||
|
import ModalContainer from 'soapbox/features/ui/containers/modal_container';
|
||||||
import Header from './components/header';
|
import Header from './components/header';
|
||||||
import Footer from './components/footer';
|
import Footer from './components/footer';
|
||||||
import LandingPage from '../landing_page';
|
import LandingPage from '../landing_page';
|
||||||
|
@ -40,6 +41,7 @@ class PublicLayout extends ImmutablePureComponent {
|
||||||
</div>
|
</div>
|
||||||
<Footer />
|
<Footer />
|
||||||
<NotificationsContainer />
|
<NotificationsContainer />
|
||||||
|
<ModalContainer />
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -860,3 +860,16 @@
|
||||||
margin: 0 5px;
|
margin: 0 5px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.confirmation-modal p {
|
||||||
|
margin-bottom: 20px;
|
||||||
|
text-align: left;
|
||||||
|
|
||||||
|
strong {
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
&:last-child {
|
||||||
|
margin-bottom: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue