Merge pull request #2383 from matrix-org/travis/back-button

Fix browser navigation not working between /home, /login, /register, etc
pull/21833/head
Travis Ralston 2019-01-03 14:37:04 -07:00 committed by GitHub
commit 78592286bd
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 43 additions and 11 deletions

View File

@ -91,11 +91,15 @@ class HomePage extends React.Component {
this._unmounted = true; this._unmounted = true;
} }
onLoginClick() { onLoginClick(ev) {
ev.preventDefault();
ev.stopPropagation();
dis.dispatch({ action: 'start_login' }); dis.dispatch({ action: 'start_login' });
} }
onRegisterClick() { onRegisterClick(ev) {
ev.preventDefault();
ev.stopPropagation();
dis.dispatch({ action: 'start_registration' }); dis.dispatch({ action: 'start_registration' });
} }

View File

@ -927,6 +927,10 @@ export default React.createClass({
}, },
_viewHome: function() { _viewHome: function() {
// The home page requires the "logged in" view, so we'll set that.
this.setStateForNewView({
view: VIEWS.LOGGED_IN,
});
this._setPage(PageTypes.HomePage); this._setPage(PageTypes.HomePage);
this.notifyNewScreen('home'); this.notifyNewScreen('home');
}, },
@ -1183,10 +1187,7 @@ export default React.createClass({
* @param {string} teamToken * @param {string} teamToken
*/ */
_onLoggedIn: async function(teamToken) { _onLoggedIn: async function(teamToken) {
this.setState({ this.setStateForNewView({view: VIEWS.LOGGED_IN});
view: VIEWS.LOGGED_IN,
});
if (teamToken) { if (teamToken) {
// A team member has logged in, not a guest // A team member has logged in, not a guest
this._teamToken = teamToken; this._teamToken = teamToken;

View File

@ -162,6 +162,18 @@ module.exports = React.createClass({
this.setState(newState); this.setState(newState);
}, },
onLoginClick: function(ev) {
ev.preventDefault();
ev.stopPropagation();
this.props.onLoginClick();
},
onRegisterClick: function(ev) {
ev.preventDefault();
ev.stopPropagation();
this.props.onRegisterClick();
},
showErrorDialog: function(body, title) { showErrorDialog: function(body, title) {
const ErrorDialog = sdk.getComponent("dialogs.ErrorDialog"); const ErrorDialog = sdk.getComponent("dialogs.ErrorDialog");
Modal.createTrackedDialog('Forgot Password Error', '', ErrorDialog, { Modal.createTrackedDialog('Forgot Password Error', '', ErrorDialog, {
@ -253,10 +265,10 @@ module.exports = React.createClass({
</form> </form>
{ serverConfigSection } { serverConfigSection }
{ errorText } { errorText }
<a className="mx_Login_create" onClick={this.props.onLoginClick} href="#"> <a className="mx_Login_create" onClick={this.onLoginClick} href="#">
{ _t('Return to login screen') } { _t('Return to login screen') }
</a> </a>
<a className="mx_Login_create" onClick={this.props.onRegisterClick} href="#"> <a className="mx_Login_create" onClick={this.onRegisterClick} href="#">
{ _t('Create an account') } { _t('Create an account') }
</a> </a>
<LanguageSelector /> <LanguageSelector />

View File

@ -214,7 +214,10 @@ module.exports = React.createClass({
}).done(); }).done();
}, },
_onLoginAsGuestClick: function() { _onLoginAsGuestClick: function(ev) {
ev.preventDefault();
ev.stopPropagation();
const self = this; const self = this;
self.setState({ self.setState({
busy: true, busy: true,
@ -297,6 +300,12 @@ module.exports = React.createClass({
}); });
}, },
onRegisterClick: function(ev) {
ev.preventDefault();
ev.stopPropagation();
this.props.onRegisterClick();
},
_tryWellKnownDiscovery: async function(serverName) { _tryWellKnownDiscovery: async function(serverName) {
if (!serverName.trim()) { if (!serverName.trim()) {
// Nothing to discover // Nothing to discover
@ -567,7 +576,7 @@ module.exports = React.createClass({
{ errorTextSection } { errorTextSection }
{ this.componentForStep(this.state.currentFlow) } { this.componentForStep(this.state.currentFlow) }
{ serverConfig } { serverConfig }
<a className="mx_Login_create" onClick={this.props.onRegisterClick} href="#"> <a className="mx_Login_create" onClick={this.onRegisterClick} href="#">
{ _t('Create an account') } { _t('Create an account') }
</a> </a>
{ loginAsGuestJsx } { loginAsGuestJsx }

View File

@ -363,6 +363,12 @@ module.exports = React.createClass({
} }
}, },
onLoginClick: function(ev) {
ev.preventDefault();
ev.stopPropagation();
this.props.onLoginClick();
},
_makeRegisterRequest: function(auth) { _makeRegisterRequest: function(auth) {
// Only send the bind params if we're sending username / pw params // Only send the bind params if we're sending username / pw params
// (Since we need to send no params at all to use the ones saved in the // (Since we need to send no params at all to use the ones saved in the
@ -468,7 +474,7 @@ module.exports = React.createClass({
let signIn; let signIn;
if (!this.state.doingUIAuth) { if (!this.state.doingUIAuth) {
signIn = ( signIn = (
<a className="mx_Login_create" onClick={this.props.onLoginClick} href="#"> <a className="mx_Login_create" onClick={this.onLoginClick} href="#">
{ theme === 'status' ? _t('Sign in') : _t('I already have an account') } { theme === 'status' ? _t('Sign in') : _t('I already have an account') }
</a> </a>
); );