Commit 1062ae46 authored by Weblate's avatar Weblate

Merge remote-tracking branch 'origin/master'

parents 45c22b20 a6d4419c
...@@ -482,12 +482,14 @@ ...@@ -482,12 +482,14 @@
test_utils.waitUntil(function () { test_utils.waitUntil(function () {
return $('#chatrooms dl.bookmarks dd:visible').length; return $('#chatrooms dl.bookmarks dd:visible').length;
}, 300).then(function () { }, 300).then(function () {
expect($('#chatrooms dl.bookmarks').hasClass('collapsed')).toBeFalsy();
expect($('#chatrooms dl.bookmarks dd:visible').length).toBe(1); expect($('#chatrooms dl.bookmarks dd:visible').length).toBe(1);
expect(_converse.bookmarksview.list_model.get('toggle-state')).toBe(_converse.OPENED); expect(_converse.bookmarksview.list_model.get('toggle-state')).toBe(_converse.OPENED);
$('#chatrooms .bookmarks-toggle').click(); $('#chatrooms .bookmarks-toggle').click();
expect($('#chatrooms dl.bookmarks dd:visible').length).toBe(0); expect($('#chatrooms dl.bookmarks').hasClass('collapsed')).toBeTruthy();
expect(_converse.bookmarksview.list_model.get('toggle-state')).toBe(_converse.CLOSED); expect(_converse.bookmarksview.list_model.get('toggle-state')).toBe(_converse.CLOSED);
$('#chatrooms .bookmarks-toggle').click(); $('#chatrooms .bookmarks-toggle').click();
expect($('#chatrooms dl.bookmarks').hasClass('collapsed')).toBeFalsy();
expect($('#chatrooms dl.bookmarks dd:visible').length).toBe(1); expect($('#chatrooms dl.bookmarks dd:visible').length).toBe(1);
expect(_converse.bookmarksview.list_model.get('toggle-state')).toBe(_converse.OPENED); expect(_converse.bookmarksview.list_model.get('toggle-state')).toBe(_converse.OPENED);
done(); done();
......
...@@ -2417,6 +2417,13 @@ ...@@ -2417,6 +2417,13 @@
expect(view.renderPasswordForm).toHaveBeenCalled(); expect(view.renderPasswordForm).toHaveBeenCalled();
expect($chat_body.find('form.chatroom-form').length).toBe(1); expect($chat_body.find('form.chatroom-form').length).toBe(1);
expect($chat_body.find('legend').text()).toBe('This chatroom requires a password'); expect($chat_body.find('legend').text()).toBe('This chatroom requires a password');
// Let's submit the form
spyOn(view, 'join');
var input_el = view.el.querySelector('[name="password"]');
input_el.value = 'secret';
view.el.querySelector('input[type=submit]').click();
expect(view.join).toHaveBeenCalledWith(undefined, "secret");
done(); done();
})); }));
...@@ -2480,6 +2487,10 @@ ...@@ -2480,6 +2487,10 @@
spyOn(view, 'showErrorMessage').and.callThrough(); spyOn(view, 'showErrorMessage').and.callThrough();
view.onChatRoomPresence(presence); view.onChatRoomPresence(presence);
expect(view.$el.find('.chatroom-body form.chatroom-form label:first').text()).toBe('Please choose your nickname'); expect(view.$el.find('.chatroom-body form.chatroom-form label:first').text()).toBe('Please choose your nickname');
var $input = view.$el.find('.chatroom-body form.chatroom-form input:first');
$input.val('nicky');
view.el.querySelector('input[type=submit]').click();
done(); done();
})); }));
......
...@@ -10,8 +10,7 @@ ...@@ -10,8 +10,7 @@
* in XEP-0048. * in XEP-0048.
*/ */
(function (root, factory) { (function (root, factory) {
define(["jquery.noconflict", define(["utils",
"utils",
"converse-core", "converse-core",
"converse-muc", "converse-muc",
"tpl!chatroom_bookmark_form", "tpl!chatroom_bookmark_form",
...@@ -21,8 +20,7 @@ ...@@ -21,8 +20,7 @@
], ],
factory); factory);
}(this, function ( }(this, function (
$, u,
utils,
converse, converse,
muc, muc,
tpl_chatroom_bookmark_form, tpl_chatroom_bookmark_form,
...@@ -135,7 +133,7 @@ ...@@ -135,7 +133,7 @@
child.classList.add('hidden'); child.classList.add('hidden');
}); });
// Remove any existing forms // Remove any existing forms
_.each(body.querySelectorAll('.chatroom-form-container'), utils.removeElement); _.each(body.querySelectorAll('.chatroom-form-container'), u.removeElement);
body.insertAdjacentHTML( body.insertAdjacentHTML(
'beforeend', 'beforeend',
...@@ -163,18 +161,14 @@ ...@@ -163,18 +161,14 @@
onBookmarkFormSubmitted (ev) { onBookmarkFormSubmitted (ev) {
ev.preventDefault(); ev.preventDefault();
const { _converse } = this.__super__; const { _converse } = this.__super__;
const $form = $(ev.target), that = this;
_converse.bookmarks.createBookmark({ _converse.bookmarks.createBookmark({
'jid': this.model.get('jid'), 'jid': this.model.get('jid'),
'autojoin': $form.find('input[name="autojoin"]').prop('checked'), 'autojoin': _.get(ev.target.querySelector('input[name="autojoin"]'), 'checked') || false,
'name': $form.find('input[name=name]').val(), 'name': _.get(ev.target.querySelector('input[name=name]'), 'value'),
'nick': $form.find('input[name=nick]').val() 'nick': _.get(ev.target.querySelector('input[name=nick]'), 'value')
});
this.$el.find('div.chatroom-form-container').hide(
function () {
$(this).remove();
that.renderAfterTransition();
}); });
u.removeElement(this.el.querySelector('div.chatroom-form-container'));
this.renderAfterTransition();
}, },
toggleBookmark (ev) { toggleBookmark (ev) {
...@@ -249,6 +243,7 @@ ...@@ -249,6 +243,7 @@
_converse.Bookmarks = Backbone.Collection.extend({ _converse.Bookmarks = Backbone.Collection.extend({
model: _converse.Bookmark, model: _converse.Bookmark,
comparator: 'name',
initialize () { initialize () {
this.on('add', _.flow(this.openBookmarkedRoom, this.markRoomAsBookmarked)); this.on('add', _.flow(this.openBookmarkedRoom, this.markRoomAsBookmarked));
...@@ -270,7 +265,7 @@ ...@@ -270,7 +265,7 @@
}, },
fetchBookmarks () { fetchBookmarks () {
const deferred = utils.getResolveablePromise(); const deferred = u.getResolveablePromise();
if (this.browserStorage.records.length > 0) { if (this.browserStorage.records.length > 0) {
this.fetch({ this.fetch({
'success': _.bind(this.onCachedBookmarksFetched, this, deferred), 'success': _.bind(this.onCachedBookmarksFetched, this, deferred),
...@@ -363,12 +358,12 @@ ...@@ -363,12 +358,12 @@
}, },
onBookmarksReceived (deferred, iq) { onBookmarksReceived (deferred, iq) {
const bookmarks = $(iq).find( const bookmarks = sizzle(
'items[node="storage:bookmarks"] item[id="current"] storage conference' 'items[node="storage:bookmarks"] item[id="current"] storage conference',
); iq
const that = this; )
_.forEach(bookmarks, function (bookmark) { _.forEach(bookmarks, (bookmark) => {
that.create({ this.create({
'jid': bookmark.getAttribute('jid'), 'jid': bookmark.getAttribute('jid'),
'name': bookmark.getAttribute('name'), 'name': bookmark.getAttribute('name'),
'autojoin': bookmark.getAttribute('autojoin') === 'true', 'autojoin': bookmark.getAttribute('autojoin') === 'true',
...@@ -392,7 +387,7 @@ ...@@ -392,7 +387,7 @@
_converse.BookmarksView = Backbone.View.extend({ _converse.BookmarksView = Backbone.View.extend({
tagName: 'div', tagName: 'div',
className: 'bookmarks-list, rooms-list-container', className: 'bookmarks-list rooms-list-container hidden',
events: { events: {
'click .add-bookmark': 'addBookmark', 'click .add-bookmark': 'addBookmark',
'click .bookmarks-toggle': 'toggleBookmarksList', 'click .bookmarks-toggle': 'toggleBookmarksList',
...@@ -416,20 +411,19 @@ ...@@ -416,20 +411,19 @@
}, },
render () { render () {
this.$el.html(tpl_bookmarks_list({ this.el.innerHTML = tpl_bookmarks_list({
'toggle_state': this.list_model.get('toggle-state'), 'toggle_state': this.list_model.get('toggle-state'),
'desc_bookmarks': __('Click to toggle the bookmarks list'), 'desc_bookmarks': __('Click to toggle the bookmarks list'),
'label_bookmarks': __('Bookmarks') 'label_bookmarks': __('Bookmarks'),
})).hide(); '_converse': _converse
if (this.list_model.get('toggle-state') !== _converse.OPENED) { });
this.$('.bookmarks').hide();
}
this.model.each(this.renderBookmarkListElement.bind(this)); this.model.each(this.renderBookmarkListElement.bind(this));
const controlboxview = _converse.chatboxviews.get('controlbox'); const controlboxview = _converse.chatboxviews.get('controlbox');
if (!_.isUndefined(controlboxview)) { if (!_.isUndefined(controlboxview)) {
this.$el.prependTo(controlboxview.$('#chatrooms')); const chatrooms_el = controlboxview.el.querySelector('#chatrooms');
chatrooms_el.insertAdjacentElement('afterbegin', this.el);
} }
return this.$el; return this;
}, },
removeBookmark: _converse.removeBookmarkViaEvent, removeBookmark: _converse.removeBookmarkViaEvent,
...@@ -477,13 +471,11 @@ ...@@ -477,13 +471,11 @@
}, },
show () { show () {
if (!this.$el.is(':visible')) { u.showElement(this.el);
this.$el.show();
}
}, },
hide () { hide () {
this.$el.hide(); u.hideElement(this.el);
}, },
removeBookmarkListElement (item) { removeBookmarkListElement (item) {
...@@ -499,14 +491,15 @@ ...@@ -499,14 +491,15 @@
toggleBookmarksList (ev) { toggleBookmarksList (ev) {
if (ev && ev.preventDefault) { ev.preventDefault(); } if (ev && ev.preventDefault) { ev.preventDefault(); }
const $el = $(ev.target); if (u.hasClass(ev.target, 'icon-opened')) {
if ($el.hasClass("icon-opened")) { u.slideIn(this.el.querySelector('.bookmarks'));
this.$('.bookmarks').slideUp('fast');
this.list_model.save({'toggle-state': _converse.CLOSED}); this.list_model.save({'toggle-state': _converse.CLOSED});
$el.removeClass("icon-opened").addClass("icon-closed"); ev.target.classList.remove("icon-opened");
ev.target.classList.add("icon-closed");
} else { } else {
$el.removeClass("icon-closed").addClass("icon-opened"); ev.target.classList.remove("icon-closed");
this.$('.bookmarks').slideDown('fast'); ev.target.classList.add("icon-opened");
u.slideOut(this.el.querySelector('.bookmarks'));
this.list_model.save({'toggle-state': _converse.OPENED}); this.list_model.save({'toggle-state': _converse.OPENED});
} }
} }
......
...@@ -690,7 +690,7 @@ ...@@ -690,7 +690,7 @@
* objects. * objects.
*/ */
return _.map( return _.map(
$(iq).find(`query[xmlns="${Strophe.NS.MUC_ADMIN}"] item`), sizzle(`query[xmlns="${Strophe.NS.MUC_ADMIN}"] item`, iq),
(item) => ({ (item) => ({
'jid': item.getAttribute('jid'), 'jid': item.getAttribute('jid'),
'affiliation': item.getAttribute('affiliation'), 'affiliation': item.getAttribute('affiliation'),
...@@ -838,7 +838,7 @@ ...@@ -838,7 +838,7 @@
* Any amount of XMLElement objects, representing the IQ * Any amount of XMLElement objects, representing the IQ
* stanzas. * stanzas.
*/ */
return _.flatMap(arguments, this.parseMemberListIQ); return _.flatMap(arguments[0], this.parseMemberListIQ);
}, },
getJidsWithAffiliations (affiliations) { getJidsWithAffiliations (affiliations) {
...@@ -1016,7 +1016,7 @@ ...@@ -1016,7 +1016,7 @@
if (!_.isUndefined(ev)) { ev.stopPropagation(); } if (!_.isUndefined(ev)) { ev.stopPropagation(); }
const result = confirm(__("Are you sure you want to clear the messages from this room?")); const result = confirm(__("Are you sure you want to clear the messages from this room?"));
if (result === true) { if (result === true) {
this.$content.empty(); this.content.innerHTML = '';
} }
return this; return this;
}, },
...@@ -1305,31 +1305,38 @@ ...@@ -1305,31 +1305,38 @@
_.each(container_el.children, u.hideElement); _.each(container_el.children, u.hideElement);
container_el.insertAdjacentHTML('beforeend', tpl_chatroom_form()); container_el.insertAdjacentHTML('beforeend', tpl_chatroom_form());
const form = container_el.querySelector('form.chatroom-form'); const form_el = container_el.querySelector('form.chatroom-form'),
const $form = $(form); fieldset_el = form_el.querySelector('fieldset:first-child'),
let $fieldset = $form.children('fieldset:first'); fields = stanza.querySelectorAll('field'),
const $stanza = $(stanza), title = _.get(stanza.querySelector('title'), 'textContent'),
$fields = $stanza.find('field'), instructions = _.get(stanza.querySelector('instructions'), 'textContent');
title = $stanza.find('title').text(),
instructions = $stanza.find('instructions').text(); u.removeElement(fieldset_el.querySelector('span.spinner'));
$fieldset.find('span.spinner').remove(); fieldset_el.insertAdjacentHTML('beforeend', `<legend>${title}</legend>`);
$fieldset.append($('<legend>').text(title));
if (instructions && instructions !== title) { if (instructions && instructions !== title) {
$fieldset.append($('<p class="instructions">').text(instructions)); fieldset_el.insertAdjacentHTML('beforeend', `<p class="instructions">${instructions}</p>`);
} }
_.each($fields, function (field) { _.each(fields, function (field) {
$fieldset.append(u.xForm2webForm(field, stanza)); fieldset_el.insertAdjacentHTML('beforeend', u.xForm2webForm(field, stanza));
}); });
$form.append('<fieldset></fieldset>');
$fieldset = $form.children('fieldset:last'); // Render save/cancel buttons
$fieldset.append(`<input type="submit" class="pure-button button-primary" value="${__('Save')}"/>`); const last_fieldset_el = document.createElement('fieldset');
$fieldset.append(`<input type="button" class="pure-button button-cancel" value="${__('Cancel')}"/>`); last_fieldset_el.insertAdjacentHTML(
$fieldset.find('input[type=button]').on('click', (ev) => { 'beforeend',
`<input type="submit" class="pure-button button-primary" value="${__('Save')}"/>`);
last_fieldset_el.insertAdjacentHTML(
'beforeend',
`<input type="button" class="pure-button button-cancel" value="${__('Cancel')}"/>`);
form_el.insertAdjacentElement('beforeend', last_fieldset_el);
last_fieldset_el.querySelector('input[type=button]').addEventListener('click', (ev) => {
ev.preventDefault(); ev.preventDefault();
this.closeForm(); this.closeForm();
}); });
form.addEventListener('submit', (ev) => { form_el.addEventListener('submit', (ev) => {
ev.preventDefault(); ev.preventDefault();
this.saveConfiguration(ev.target).then( this.saveConfiguration(ev.target).then(
this.getRoomFeatures.bind(this) this.getRoomFeatures.bind(this)
...@@ -1373,11 +1380,8 @@ ...@@ -1373,11 +1380,8 @@
* (HTMLElement) form: The configuration form DOM element. * (HTMLElement) form: The configuration form DOM element.
*/ */
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
const $inputs = $(form).find(':input:not([type=button]):not([type=submit])'), const inputs = form ? sizzle(':input:not([type=button]):not([type=submit])', form) : [],
configArray = []; configArray = _.map(inputs, u.webForm2xForm);
$inputs.each(function () {
configArray.push(u.webForm2xForm(this));
});
this.sendConfiguration(configArray, resolve, reject); this.sendConfiguration(configArray, resolve, reject);
this.closeForm(); this.closeForm();
}); });
...@@ -1585,9 +1589,8 @@ ...@@ -1585,9 +1589,8 @@
* Parameters: * Parameters:
* (XMLElement) iq: The received IQ stanza * (XMLElement) iq: The received IQ stanza
*/ */
const nick = $(iq) const identity_el = iq.querySelector('query[node="x-roomuser-item"] identity'),
.find('query[node="x-roomuser-item"] identity') nick = identity_el ? identity_el.getAttribute('name') : null;
.attr('name');
if (!nick) { if (!nick) {
this.onNickNameNotFound(); this.onNickNameNotFound();
} else { } else {
...@@ -1673,8 +1676,8 @@ ...@@ -1673,8 +1676,8 @@
submitPassword (ev) { submitPassword (ev) {
ev.preventDefault(); ev.preventDefault();
const password = this.$el.find('.chatroom-form').find('input[type=password]').val(); const password = this.el.querySelector('.chatroom-form input[type=password]').value;
this.el.querySelector('.chatroom-form-container').outerHTML = tpl_spinner(); this.showSpinner();
this.join(this.model.get('nick'), password); this.join(this.model.get('nick'), password);
}, },
...@@ -2195,7 +2198,7 @@ ...@@ -2195,7 +2198,7 @@
}, },
destroy () { destroy () {
this.$el.remove(); this.el.parentElement.removeChild(this.el);
} }
}); });
...@@ -2614,9 +2617,9 @@ ...@@ -2614,9 +2617,9 @@
}, },
informNoRoomsFound () { informNoRoomsFound () {
const $available_chatrooms = this.$el.find('#available-chatrooms'); const chatrooms_el = this.el.querySelector('#available-chatrooms');
// For translators: %1$s is a variable and will be replaced with the XMPP server name // For translators: %1$s is a variable and will be replaced with the XMPP server name
$available_chatrooms.html(`<dt>${__('No rooms on %1$s', this.model.get('muc_domain'))}</dt>`); chatrooms_el.innerHTML = `<dt>${__('No rooms on %1$s', this.model.get('muc_domain'))}</dt>`;
const input_el = this.el.querySelector('input#show-rooms'); const input_el = this.el.querySelector('input#show-rooms');
input_el.classList.remove('hidden') input_el.classList.remove('hidden')
this.removeSpinner(); this.removeSpinner();
...@@ -2668,21 +2671,22 @@ ...@@ -2668,21 +2671,22 @@
type: "get" type: "get"
}).c("query", {xmlns: Strophe.NS.DISCO_ITEMS}), }).c("query", {xmlns: Strophe.NS.DISCO_ITEMS}),
this.onRoomsFound.bind(this), this.onRoomsFound.bind(this),
this.informNoRoomsFound.bind(this) this.informNoRoomsFound.bind(this),
5000
); );
}, },
showRooms () { showRooms () {
const $available_chatrooms = this.$el.find('#available-chatrooms'); const chatrooms_el = this.el.querySelector('#available-chatrooms');
const $server = this.$el.find('input.new-chatroom-server'); const server_el = this.el.querySelector('input.new-chatroom-server');
const server = $server.val(); const server = server_el.value;
if (!server) { if (!server) {
$server.addClass('error'); server_el.classList.add('error');
return; return;
} }
this.$el.find('input.new-chatroom-name').removeClass('error'); this.el.querySelector('input.new-chatroom-name').classList.remove('error');
$server.removeClass('error'); server_el.classList.remove('error');
$available_chatrooms.empty(); chatrooms_el.innerHTML = '';
const input_el = this.el.querySelector('input#show-rooms'); const input_el = this.el.querySelector('input#show-rooms');
input_el.classList.add('hidden') input_el.classList.add('hidden')
...@@ -2701,24 +2705,23 @@ ...@@ -2701,24 +2705,23 @@
* (XMLElement) stanza: The IQ stanza containing the room * (XMLElement) stanza: The IQ stanza containing the room
* info. * info.
*/ */
const $stanza = $(stanza);
// All MUC features found here: http://xmpp.org/registrar/disco-features.html // All MUC features found here: http://xmpp.org/registrar/disco-features.html
el.querySelector('span.spinner').outerHTML = el.querySelector('span.spinner').outerHTML =
tpl_room_description({ tpl_room_description({
'jid': stanza.getAttribute('from'), 'jid': stanza.getAttribute('from'),
'desc': $stanza.find('field[var="muc#roominfo_description"] value').text(), 'desc': _.get(_.head(sizzle('field[var="muc#roominfo_description"] value', stanza)), 'textContent'),
'occ': $stanza.find('field[var="muc#roominfo_occupants"] value').text(), 'occ': _.get(_.head(sizzle('field[var="muc#roominfo_occupants"] value', stanza)), 'textContent'),
'hidden': $stanza.find('feature[var="muc_hidden"]').length, 'hidden': sizzle('feature[var="muc_hidden"]', stanza).length,
'membersonly': $stanza.find('feature[var="muc_membersonly"]').length, 'membersonly': sizzle('feature[var="muc_membersonly"]', stanza).length,
'moderated': $stanza.find('feature[var="muc_moderated"]').length, 'moderated': sizzle('feature[var="muc_moderated"]', stanza).length,
'nonanonymous': $stanza.find('feature[var="muc_nonanonymous"]').length, 'nonanonymous': sizzle('feature[var="muc_nonanonymous"]', stanza).length,
'open': $stanza.find('feature[var="muc_open"]').length, 'open': sizzle('feature[var="muc_open"]', stanza).length,
'passwordprotected': $stanza.find('feature[var="muc_passwordprotected"]').length, 'passwordprotected': sizzle('feature[var="muc_passwordprotected"]', stanza).length,
'persistent': $stanza.find('feature[var="muc_persistent"]').length, 'persistent': sizzle('feature[var="muc_persistent"]', stanza).length,
'publicroom': $stanza.find('feature[var="muc_public"]').length, 'publicroom': sizzle('feature[var="muc_publicroom"]', stanza).length,
'semianonymous': $stanza.find('feature[var="muc_semianonymous"]').length, 'semianonymous': sizzle('feature[var="muc_semianonymous"]', stanza).length,
'temporary': $stanza.find('feature[var="muc_temporary"]').length, 'temporary': sizzle('feature[var="muc_temporary"]', stanza).length,
'unmoderated': $stanza.find('feature[var="muc_unmoderated"]').length, 'unmoderated': sizzle('feature[var="muc_unmoderated"]', stanza).length,
'label_desc': __('Description:'), 'label_desc': __('Description:'),
'label_jid': __('Room Address (JID):'), 'label_jid': __('Room Address (JID):'),
'label_occ': __('Occupants:'), 'label_occ': __('Occupants:'),
...@@ -2740,39 +2743,39 @@ ...@@ -2740,39 +2743,39 @@
toggleRoomInfo (ev) { toggleRoomInfo (ev) {
/* Show/hide extra information about a room in the listing. /* Show/hide extra information about a room in the listing.
*/ */
const { target } = ev, const parent_el = ev.target.parentElement,
$parent = $(target).parent('dd'), div_el = parent_el.querySelector('div.room-info');
$div = $parent.find('div.room-info'); if (div_el) {
if ($div.length) { u.slideIn(div_el).then(u.removeElement)
$div.remove();
} else { } else {
$parent.find('span.spinner').remove(); parent_el.insertAdjacentHTML('beforeend', tpl_spinner());
$parent.append(tpl_spinner);
_converse.connection.disco.info( _converse.connection.disco.info(
$(target).attr('data-room-jid'), null, _.partial(this.insertRoomInfo, $parent[0]) ev.target.getAttribute('data-room-jid'),
null,
_.partial(this.insertRoomInfo, parent_el)
); );
} }
}, },
parseRoomDataFromEvent (ev) { parseRoomDataFromEvent (ev) {
let name, $name, server, $server, jid; let name, jid;
if (ev.type === 'click') { if (ev.type === 'click') {
name = $(ev.target).text(); name = ev.target.textContent;
jid = $(ev.target).attr('data-room-jid'); jid = ev.target.getAttribute('data-room-jid');
} else { } else {
const $name = this.$el.find('input.new-chatroom-name'); const name_el = this.el.querySelector('input.new-chatroom-name');
const $server= this.$el.find('input.new-chatroom-server'); const server_el= this.el.querySelector('input.new-chatroom-server');
const server = $server.val(); const server = server_el.value;
name = $name.val().trim(); name = name_el.value.trim();
$name.val(''); // Clear the input name_el.value = ''; // Clear the input
if (name && server) { if (name && server) {
jid = Strophe.escapeNode(name.toLowerCase()) + '@' + server.toLowerCase(); jid = Strophe.escapeNode(name.toLowerCase()) + '@' + server.toLowerCase();
$name.removeClass('error'); name_el.classList.remove('error');
$server.removeClass('error'); server_el.classList.remove('error');
this.model.save({muc_domain: server}); this.model.save({muc_domain: server});
} else { } else {
if (!name) { $name.addClass('error'); } if (!name) { name_el.classList.add('error'); }
if (!server) { $server.addClass('error'); } if (!server) { server_el.classList.add('error'); }
return; return;
} }
} }
...@@ -2809,11 +2812,11 @@ ...@@ -2809,11 +2812,11 @@
* (XMLElement) message: The message stanza containing the * (XMLElement) message: The message stanza containing the
* invitation. * invitation.
*/ */
const $message = $(message), const x_el = message.querySelector('x[xmlns="jabber:x:conference"]'),
$x = $message.children('x[xmlns="jabber:x:conference"]'), from = Strophe.getBareJidFromJid(message.getAttribute('from')),
from = Strophe.getBareJidFromJid($message.attr('from')), room_jid = x_el.getAttribute('jid'),
room_jid = $x.attr('jid'), reason = x_el.getAttribute('reason');
reason = $x.attr('reason');
let contact = _converse.roster.get(from), let contact = _converse.roster.get(from),
result; result;
...@@ -2836,7 +2839,7 @@ ...@@ -2836,7 +2839,7 @@
if (result === true) { if (result === true) {
const chatroom = openChatRoom({ const chatroom = openChatRoom({
'jid': room_jid, 'jid': room_jid,
'password': $x.attr('password') 'password': x_el.getAttribute('password')
}); });
if (chatroom.get('connection_status') === converse.ROOMSTATUS.DISCONNECTED) { if (chatroom.get('connection_status') === converse.ROOMSTATUS.DISCONNECTED) {
_converse.chatboxviews.get(room_jid).join(); _converse.chatboxviews.get(room_jid).join();
......
<a href="#" class="rooms-toggle bookmarks-toggle icon-{{{o.toggle_state}}}" title="{{{o.desc_bookmarks}}}">{{{o.label_bookmarks}}}</a> <a href="#" class="rooms-toggle bookmarks-toggle icon-{{{o.toggle_state}}}" title="{{{o.desc_bookmarks}}}">{{{o.label_bookmarks}}}</a>
<dl class="bookmarks rooms-list"></dl> <dl class="bookmarks rooms-list {[ if (o.toggle_state !== o._converse.OPENED) { ]} hidden {[ } ]}"></dl>
...@@ -241,11 +241,11 @@ ...@@ -241,11 +241,11 @@
logger.warn(err); logger.warn(err);
return reject(new Error(err)); return reject(new Error(err));
} else if (_.includes(el.classList, 'collapsed')) { } else if (_.includes(el.classList, 'collapsed')) {
return resolve(); return resolve(el);
} else if (window.converse_disable_effects) { // Effects are disabled (for tests) } else if (window.converse_disable_effects) { // Effects are disabled (for tests)
el.classList.add('collapsed'); el.classList.add('collapsed');
el.style.height = ""; el.style.height = "";
return resolve(); return resolve(el);
} }
const marker = el.getAttribute('data-slider-marker'); const marker = el.getAttribute('data-slider-marker');
if (marker) { if (marker) {
...@@ -270,7 +270,7 @@ ...@@ -270,7 +270,7 @@
el.removeAttribute('data-slider-marker'); el.removeAttribute('data-slider-marker');
el.classList.add('collapsed'); el.classList.add('collapsed');
el.style.height = ""; el.style.height = "";
resolve(); resolve(el);
} }
} }
el.setAttribute( el.setAttribute(
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment