Commit e3708bd5 authored by JC Brand's avatar JC Brand

Refactor headlines list to render everything with one view

parent c55a2171
...@@ -44,7 +44,7 @@ ...@@ -44,7 +44,7 @@
})); }));
it("will open and display headline messages", mock.initConverse( it("will open and display headline messages", mock.initConverse(
['rosterGroupsFetched'], {}, function (done, _converse) { ['rosterGroupsFetched'], {}, async function (done, _converse) {
/* <message from='notify.example.com' /* <message from='notify.example.com'
* to='romeo@im.example.com' * to='romeo@im.example.com'
...@@ -72,15 +72,10 @@ ...@@ -72,15 +72,10 @@
.c('url').t('imap://romeo@example.com/INBOX;UIDVALIDITY=385759043/;UID=18'); .c('url').t('imap://romeo@example.com/INBOX;UIDVALIDITY=385759043/;UID=18');
_converse.connection._dataRecv(test_utils.createRequest(stanza)); _converse.connection._dataRecv(test_utils.createRequest(stanza));
expect( await u.waitUntil(() => _converse.chatboxviews.keys().includes('notify.example.com'));
_.includes(
_converse.chatboxviews.keys(),
'notify.example.com')
).toBeTruthy();
expect(u.isHeadlineMessage.called).toBeTruthy(); expect(u.isHeadlineMessage.called).toBeTruthy();
expect(u.isHeadlineMessage.returned(true)).toBeTruthy(); expect(u.isHeadlineMessage.returned(true)).toBeTruthy();
u.isHeadlineMessage.restore(); // unwraps u.isHeadlineMessage.restore(); // unwraps
// Headlines boxes don't show an avatar
const view = _converse.chatboxviews.get('notify.example.com'); const view = _converse.chatboxviews.get('notify.example.com');
expect(view.model.get('show_avatar')).toBeFalsy(); expect(view.model.get('show_avatar')).toBeFalsy();
expect(view.el.querySelector('img.avatar')).toBe(null); expect(view.el.querySelector('img.avatar')).toBe(null);
......
...@@ -8,8 +8,7 @@ import { View } from 'skeletor.js/src/view.js'; ...@@ -8,8 +8,7 @@ import { View } from 'skeletor.js/src/view.js';
import { __ } from '@converse/headless/i18n'; import { __ } from '@converse/headless/i18n';
import converse from "@converse/headless/converse-core"; import converse from "@converse/headless/converse-core";
import tpl_chatbox from "templates/chatbox.html"; import tpl_chatbox from "templates/chatbox.html";
import tpl_headline_list from "templates/headline_list.js"; import tpl_headline_panel from "templates/headline_panel.js";
import tpl_headline_panel from "templates/headline_panel.html";
const u = converse.env.utils; const u = converse.env.utils;
...@@ -37,7 +36,7 @@ converse.plugins.add('converse-headlines-view', { ...@@ -37,7 +36,7 @@ converse.plugins.add('converse-headlines-view', {
ControlBoxView: { ControlBoxView: {
renderControlBoxPane () { renderControlBoxPane () {
this.__super__.renderControlBoxPane.apply(this, arguments); this.__super__.renderControlBoxPane.apply(this, arguments);
this.renderHeadlinePanel(); this.renderHeadlinesPanel();
}, },
}, },
}, },
...@@ -50,15 +49,12 @@ converse.plugins.add('converse-headlines-view', { ...@@ -50,15 +49,12 @@ converse.plugins.add('converse-headlines-view', {
const { _converse } = this; const { _converse } = this;
const viewWithHeadlinePanel = { const viewWithHeadlinesPanel = {
renderHeadlinePanel () { renderHeadlinesPanel () {
if (this.headlinepanel && u.isInDOM(this.headlinepanel.el)) { if (this.headlinepanel && u.isInDOM(this.headlinepanel.el)) {
return this.headlinepanel; return this.headlinepanel;
} }
this.headlinepanel = new _converse.HeadlinePanel(); this.headlinepanel = new _converse.HeadlinesPanel({'model': _converse.chatboxes});
this.el.querySelector('.controlbox-pane').insertAdjacentElement(
'beforeEnd', this.headlinepanel.render().el);
/** /**
* Triggered once the section of the { @link _converse.ControlBoxView } * Triggered once the section of the { @link _converse.ControlBoxView }
* which shows announcements has been rendered. * which shows announcements has been rendered.
...@@ -71,17 +67,17 @@ converse.plugins.add('converse-headlines-view', { ...@@ -71,17 +67,17 @@ converse.plugins.add('converse-headlines-view', {
} }
if (_converse.ControlBoxView) { if (_converse.ControlBoxView) {
Object.assign(_converse.ControlBoxView.prototype, viewWithHeadlinePanel); Object.assign(_converse.ControlBoxView.prototype, viewWithHeadlinesPanel);
} }
/** /**
* View which renders headlines section of the control box. * View which renders headlines section of the control box.
* @class * @class
* @namespace _converse.HeadlinePanel * @namespace _converse.HeadlinesPanel
* @memberOf _converse * @memberOf _converse
*/ */
_converse.HeadlinePanel = View.extend({ _converse.HeadlinesPanel = View.extend({
tagName: 'div', tagName: 'div',
className: 'controlbox-section', className: 'controlbox-section',
id: 'headline', id: 'headline',
...@@ -90,6 +86,26 @@ converse.plugins.add('converse-headlines-view', { ...@@ -90,6 +86,26 @@ converse.plugins.add('converse-headlines-view', {
'click .open-headline': 'openHeadline' 'click .open-headline': 'openHeadline'
}, },
initialize () {
this.listenTo(this.model, 'add', this.renderIfHeadline)
this.listenTo(this.model, 'remove', this.renderIfHeadline)
this.listenTo(this.model, 'destroy', this.renderIfHeadline)
this.render();
this.insertIntoDOM();
},
toHTML () {
return tpl_headline_panel({
'heading_headline': __('Announcements'),
'headlineboxes': this.model.filter(m => m.get('type') === _converse.HEADLINES_TYPE),
'open_title': __('Click to open this server message'),
});
},
renderIfHeadline (model) {
return (model && model.get('type') === _converse.HEADLINES_TYPE) && this.render();
},
openHeadline (ev) { openHeadline (ev) {
ev.preventDefault(); ev.preventDefault();
const jid = ev.target.getAttribute('data-headline-jid'); const jid = ev.target.getAttribute('data-headline-jid');
...@@ -97,9 +113,9 @@ converse.plugins.add('converse-headlines-view', { ...@@ -97,9 +113,9 @@ converse.plugins.add('converse-headlines-view', {
chat.maybeShow(true); chat.maybeShow(true);
}, },
render () { insertIntoDOM () {
this.el.innerHTML = tpl_headline_panel({'heading_headline': __('Announcements')}); const view = _converse.chatboxviews.get('controlbox');
return this; view && view.el.querySelector('.controlbox-pane').insertAdjacentElement('beforeEnd', this.el);
} }
}); });
...@@ -155,49 +171,7 @@ converse.plugins.add('converse-headlines-view', { ...@@ -155,49 +171,7 @@ converse.plugins.add('converse-headlines-view', {
}); });
_converse.HeadlinesListView = View.extend({ /************************ BEGIN Event Handlers ************************/
tagName: 'span',
initialize () {
this.listenTo(this.model, 'add', this.renderIfHeadline)
this.listenTo(this.model, 'remove', this.renderIfHeadline)
this.listenTo(this.model, 'destroy', this.renderIfHeadline)
this.render();
this.insertIntoControlBox();
},
toHTML () {
return tpl_headline_list({
'headlineboxes': this.model.filter(m => m.get('type') === _converse.HEADLINES_TYPE),
'open_title': __('Click to open this server message'),
});
},
renderIfHeadline (model) {
return (model && model.get('type') === _converse.HEADLINES_TYPE) && this.render();
},
insertIntoControlBox () {
const controlboxview = _converse.chatboxviews.get('controlbox');
if (controlboxview !== undefined && !u.rootContains(_converse.root, this.el)) {
const el = controlboxview.el.querySelector('.list-container--headline');
el && el.parentNode.replaceChild(this.el, el);
}
}
});
const initHeadlinesListView = function () {
_converse.headlines_list = new _converse.HeadlinesListView({'model': _converse.chatboxes});
/**
* Triggered once the _converse.HeadlinesListView has been created and initialized.
* @event _converse#roomsListInitialized
* @example _converse.api.listen.on('roomsListInitialized', status => { ... });
*/
_converse.api.trigger('headlinesListInitialized');
};
_converse.api.listen.on('chatBoxViewsInitialized', () => { _converse.api.listen.on('chatBoxViewsInitialized', () => {
const views = _converse.chatboxviews; const views = _converse.chatboxviews;
_converse.chatboxes.on('add', item => { _converse.chatboxes.on('add', item => {
...@@ -206,15 +180,5 @@ converse.plugins.add('converse-headlines-view', { ...@@ -206,15 +180,5 @@ converse.plugins.add('converse-headlines-view', {
} }
}); });
}); });
_converse.api.listen.on('connected', async () => {
await Promise.all([
_converse.api.waitUntil('chatBoxesFetched'),
_converse.api.waitUntil('headlinesPanelRendered')
]);
initHeadlinesListView();
});
_converse.api.listen.on('reconnected', initHeadlinesListView);
} }
}); });
<!-- <div id="headline"> -->
<div class="d-flex controlbox-padded">
<span class="w-100 controlbox-heading controlbox-heading--headline">{{{o.heading_headline}}}</span>
</div>
<div class="list-container list-container--headline hidden"></div>
<!-- </div> -->
import { html } from "lit-html";
import { __ } from '@converse/headless/i18n';
import tpl_headline_list from "templates/headline_list.js";
export default (o) => html`
<div class="d-flex controlbox-padded ${ o.headlineboxes.length ? '' : 'hidden' }">
<span class="w-100 controlbox-heading controlbox-heading--headline">${o.heading_headline}</span>
</div>
${ tpl_headline_list(o) }
`;
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