Make the router global and clear login/register fragments
upon login or after registering.
This commit is contained in:
parent
61ed55dbaa
commit
46ca6c7de2
@ -550,6 +550,10 @@
|
|||||||
jid = Strophe.getBareJidFromJid(jid).toLowerCase()+'/'+resource;
|
jid = Strophe.getBareJidFromJid(jid).toLowerCase()+'/'+resource;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (_.includes(["converse/login", "converse/register"],
|
||||||
|
Backbone.history.getFragment())) {
|
||||||
|
_converse.router.navigate('', {'replace': true});
|
||||||
|
}
|
||||||
_converse.connection.reset();
|
_converse.connection.reset();
|
||||||
_converse.connection.connect(jid, password, _converse.onConnectStatusChanged);
|
_converse.connection.connect(jid, password, _converse.onConnectStatusChanged);
|
||||||
}
|
}
|
||||||
|
@ -230,6 +230,9 @@
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
_converse.router = new Backbone.Router();
|
||||||
|
|
||||||
|
|
||||||
_converse.initialize = function (settings, callback) {
|
_converse.initialize = function (settings, callback) {
|
||||||
"use strict";
|
"use strict";
|
||||||
settings = !_.isUndefined(settings) ? settings : {};
|
settings = !_.isUndefined(settings) ? settings : {};
|
||||||
|
@ -145,19 +145,15 @@
|
|||||||
providers_link: 'https://xmpp.net/directory.php', // Link to XMPP providers shown on registration page
|
providers_link: 'https://xmpp.net/directory.php', // Link to XMPP providers shown on registration page
|
||||||
});
|
});
|
||||||
|
|
||||||
const RegistrationRouter = Backbone.Router.extend({
|
|
||||||
initialize () {
|
function setActiveForm (value) {
|
||||||
this.route('converse/login', _.partial(this.setActiveForm, 'login'));
|
|
||||||
this.route('converse/register', _.partial(this.setActiveForm, 'register'));
|
|
||||||
},
|
|
||||||
setActiveForm (value) {
|
|
||||||
_converse.api.waitUntil('controlboxInitialized').then(() => {
|
_converse.api.waitUntil('controlboxInitialized').then(() => {
|
||||||
const controlbox = _converse.chatboxes.get('controlbox')
|
const controlbox = _converse.chatboxes.get('controlbox')
|
||||||
controlbox.set({'active-form': value});
|
controlbox.set({'active-form': value});
|
||||||
}).catch(_.partial(_converse.log, _, Strophe.LogLevel.FATAL));
|
}).catch(_.partial(_converse.log, _, Strophe.LogLevel.FATAL));
|
||||||
}
|
}
|
||||||
});
|
_converse.router.route('converse/login', _.partial(setActiveForm, 'login'));
|
||||||
const router = new RegistrationRouter();
|
_converse.router.route('converse/register', _.partial(setActiveForm, 'register'));
|
||||||
|
|
||||||
|
|
||||||
_converse.RegisterPanel = Backbone.View.extend({
|
_converse.RegisterPanel = Backbone.View.extend({
|
||||||
@ -419,11 +415,14 @@
|
|||||||
);
|
);
|
||||||
this.abortRegistration();
|
this.abortRegistration();
|
||||||
} else if (status_code === Strophe.Status.REGISTERED) {
|
} else if (status_code === Strophe.Status.REGISTERED) {
|
||||||
router.navigate(); // Strip the URL fragment
|
|
||||||
_converse.log("Registered successfully.");
|
_converse.log("Registered successfully.");
|
||||||
_converse.connection.reset();
|
_converse.connection.reset();
|
||||||
this.showSpinner();
|
this.showSpinner();
|
||||||
|
|
||||||
|
if (_.includes(["converse/login", "converse/register"], Backbone.History.getFragment())) {
|
||||||
|
_converse.router.navigate('', {'replace': true});
|
||||||
|
}
|
||||||
|
|
||||||
if (this.fields.password && this.fields.username) {
|
if (this.fields.password && this.fields.username) {
|
||||||
// automatically log the user in
|
// automatically log the user in
|
||||||
_converse.connection.connect(
|
_converse.connection.connect(
|
||||||
|
Loading…
Reference in New Issue
Block a user