Commit a45bd8d1 authored by JC Brand's avatar JC Brand

Convert older docstrings to JSDoc syntax

parent 7ed99092
...@@ -261,4 +261,4 @@ html: dev docsdev apidoc ...@@ -261,4 +261,4 @@ html: dev docsdev apidoc
PHONY: apidoc PHONY: apidoc
apidoc: apidoc:
$(JSDOC) --readme docs/source/jsdoc_intro.md -c docs/source/conf.json -d docs/html/api src/*.js src/utils/*.js src/headless/*.js src/headless/utils/*.js $(JSDOC) --private --readme docs/source/jsdoc_intro.md -c docs/source/conf.json -d docs/html/api src/*.js src/utils/*.js src/headless/*.js src/headless/utils/*.js
This diff is collapsed.
...@@ -41,6 +41,5 @@ to fix a bug or to add new functionality. ...@@ -41,6 +41,5 @@ to fix a bug or to add new functionality.
plugin_development plugin_development
api/index api/index
testing testing
events
other_frameworks other_frameworks
builds builds
...@@ -3,29 +3,31 @@ ...@@ -3,29 +3,31 @@
Welcome to the new Converse API documentation, generated with Welcome to the new Converse API documentation, generated with
[JSDoc](http://usejsdoc.org/). [JSDoc](http://usejsdoc.org/).
The old (increasingly out of date and incomplete) API documentation is This documentation replaces the (increasingly out of date and incomplete) [old API documentation](/docs/html/developer_api.html)
currently still [available here](/docs/html/developer_api.html). and [old "Events and Promises" documentation](/docs/html/events.html).
## The public and private API ## The public and private API
Converse has a public API and a private API. Converse has a public API and a private API only available to plugins.
r
The reason we make this distinction between public and private is so that API The reason we make this distinction between public and private is so that API
methods which might can be used to "impersonate" the user, for example by methods which could be used to "impersonate" the user, for example by
sending messages on their behalf, are not available to random scripts running sending messages on their behalf, are not available to random scripts running
in the websites. in your website.
The public API is accessible via the [window.converse](/docs/html/api/converse.html)
global and is therefore available to any JavaScript running in the page.
The public API is accessible via the `window.converse` global and is therefore The private API is only accessible to plugins, which have been whitelisted and
available to all JavaScript running in the page. registered before [converse.initialize](/docs/html/api/converse.html#.initialize)
(which is a public API method) has been called.
Tehe private API is only accessible to plugins, which have been whitelisted and See the [plugin development](/docs/html/plugin_development.html)
registered before `converse.initialize` (which is a public API method) has been
called. See the [plugin development](https://conversejs.org/docs/html/plugin_development.html)
section for more info on writing plugins. section for more info on writing plugins.
Inside a plugin, you can get access to the `_converse.api` object. Note the Inside a plugin, you can get access to the {@link _converse.api}
underscore in front of `_converse`, which indicates that this is a private, object. Note the underscore in front of {@link _converse},
closured object. which indicates that this is a private, closured object.
## API Namespaces ## API Namespaces
...@@ -35,9 +37,26 @@ group relevant methods. ...@@ -35,9 +37,26 @@ group relevant methods.
So, for example, all the XEP-0030 service discovery methods are under the So, for example, all the XEP-0030 service discovery methods are under the
{@link \_converse.api.disco} namespace, in the [private API]{@link \_converse.api}. {@link \_converse.api.disco} namespace, in the [private API]{@link \_converse.api}.
Which means that you access it via `_converse.api.disco`. Which means that you access it via {@link _converse.api.disco}.
### Nested Namespaces
Namespaces can be nested.
Namespaces can be nested. So the {@link \_converse.api.disco} namespace {@link _converse.api} is the top-level namespace, of which {@link \_converse.api.disco}
namespace has {@link \_converse.api.disco.own} as a nested namespace. is a nested, child namespace and {@link \_converse.api.disco.own} is nested another
level deeper.
Not all methods are however within a namespace. For example {@link converse.initialize}. Not all methods are however within a namespace. For example {@link converse.initialize}.
## Stable API versus unstable API
Converse uses [semantic versioning](https://semver.org/) for releases, which means that
we try to maintain a stable API for minor and patch releases and when we do change the
stable API we will make a major release.
In the JSDoc API documentation, all API methods that are **not** marked as *Private*
are considered to be part of the stable API, and you can therefore expect them to
not change between minor and patch releases. If a method is marked as *Private*,
then you could still use it, but we don't provide any guarantee that it won't change
between minor and patch releases.
...@@ -586,18 +586,18 @@ converse.plugins.add('converse-chatview', { ...@@ -586,18 +586,18 @@ converse.plugins.add('converse-chatview', {
); );
}, },
insertDayIndicator (next_msg_el) { /**
/* Inserts an indicator into the chat area, showing the * Inserts an indicator into the chat area, showing the
* day as given by the passed in date. * day as given by the passed in date.
*
* The indicator is only inserted if necessary. * The indicator is only inserted if necessary.
* * @private
* Parameters: * @method _converse.ChatBoxView#insertDayIndicator
* (HTMLElement) next_msg_el - The message element before * @param { HTMLElement } next_msg_el - The message element before
* which the day indicator element must be inserted. * which the day indicator element must be inserted.
* This element must have a "data-isodate" attribute * This element must have a "data-isodate" attribute
* which specifies its creation date. * which specifies its creation date.
*/ */
insertDayIndicator (next_msg_el) {
const prev_msg_el = u.getPreviousElement(next_msg_el, ".message:not(.chat-state-notification)"), const prev_msg_el = u.getPreviousElement(next_msg_el, ".message:not(.chat-state-notification)"),
prev_msg_date = _.isNull(prev_msg_el) ? null : prev_msg_el.getAttribute('data-isodate'), prev_msg_date = _.isNull(prev_msg_el) ? null : prev_msg_el.getAttribute('data-isodate'),
next_msg_date = next_msg_el.getAttribute('data-isodate'); next_msg_date = next_msg_el.getAttribute('data-isodate');
...@@ -616,13 +616,14 @@ converse.plugins.add('converse-chatview', { ...@@ -616,13 +616,14 @@ converse.plugins.add('converse-chatview', {
} }
}, },
getLastMessageDate (cutoff) { /**
/* Return the ISO8601 format date of the latest message. * Return the ISO8601 format date of the latest message.
* * @private
* Parameters: * @method _converse.ChatBoxView#getLastMessageDate
* (Object) cutoff: Moment Date cutoff date. The last * @param { object } cutoff - Moment Date cutoff date. The last
* message received cutoff this date will be returned. * message received cutoff this date will be returned.
*/ */
getLastMessageDate (cutoff) {
const first_msg = u.getFirstChildElement(this.content, '.message:not(.chat-state-notification)'), const first_msg = u.getFirstChildElement(this.content, '.message:not(.chat-state-notification)'),
oldest_date = first_msg ? first_msg.getAttribute('data-isodate') : null; oldest_date = first_msg ? first_msg.getAttribute('data-isodate') : null;
if (!_.isNull(oldest_date) && moment(oldest_date).isAfter(cutoff)) { if (!_.isNull(oldest_date) && moment(oldest_date).isAfter(cutoff)) {
...@@ -713,13 +714,14 @@ converse.plugins.add('converse-chatview', { ...@@ -713,13 +714,14 @@ converse.plugins.add('converse-chatview', {
return !u.isVisible(this.el); return !u.isVisible(this.el);
}, },
insertMessage (view) { /**
/* Given a view representing a message, insert it into the * Given a view representing a message, insert it into the
* content area of the chat box. * content area of the chat box.
* * @private
* Parameters: * @method _converse.ChatBoxView#insertMessage
* (Backbone.View) message: The message Backbone.View * @param { Backbone.View } message - The message Backbone.View
*/ */
insertMessage (view) {
if (view.model.get('type') === 'error') { if (view.model.get('type') === 'error') {
const previous_msg_el = this.content.querySelector(`[data-msgid="${view.model.get('msgid')}"]`); const previous_msg_el = this.content.querySelector(`[data-msgid="${view.model.get('msgid')}"]`);
if (previous_msg_el) { if (previous_msg_el) {
...@@ -746,8 +748,8 @@ converse.plugins.add('converse-chatview', { ...@@ -746,8 +748,8 @@ converse.plugins.add('converse-chatview', {
return this.trigger('messageInserted', view.el); return this.trigger('messageInserted', view.el);
}, },
markFollowups (el) { /**
/* Given a message element, determine wether it should be * Given a message element, determine wether it should be
* marked as a followup message to the previous element. * marked as a followup message to the previous element.
* *
* Also determine whether the element following it is a * Also determine whether the element following it is a
...@@ -757,9 +759,11 @@ converse.plugins.add('converse-chatview', { ...@@ -757,9 +759,11 @@ converse.plugins.add('converse-chatview', {
* author with no other conversation elements inbetween and * author with no other conversation elements inbetween and
* posted within 10 minutes of one another. * posted within 10 minutes of one another.
* *
* Parameters: * @private
* (HTMLElement) el - The message element. * @method _converse.ChatBoxView#markFollowups
* @param { HTMLElement } el - The message element
*/ */
markFollowups (el) {
const from = el.getAttribute('data-from'), const from = el.getAttribute('data-from'),
previous_el = el.previousElementSibling, previous_el = el.previousElementSibling,
date = moment(el.getAttribute('data-isodate')), date = moment(el.getAttribute('data-isodate')),
...@@ -783,15 +787,14 @@ converse.plugins.add('converse-chatview', { ...@@ -783,15 +787,14 @@ converse.plugins.add('converse-chatview', {
} }
}, },
async showMessage (message) { /**
/* Inserts a chat message into the content area of the chat box. * Inserts a chat message into the content area of the chat box.
* * Will also insert a new day indicator if the message is on a different day.
* Will also insert a new day indicator if the message is on a * @private
* different day. * @method _converse.ChatBoxView#showMessage
* * @param { _converse.Message } message - The message object
* Parameters:
* (Backbone.Model) message: The message object
*/ */
async showMessage (message) {
if (!u.isNewMessage(message) && u.isEmptyMessage(message)) { if (!u.isNewMessage(message) && u.isEmptyMessage(message)) {
// Handle archived or delayed messages without any message // Handle archived or delayed messages without any message
// text to show. // text to show.
...@@ -822,12 +825,13 @@ converse.plugins.add('converse-chatview', { ...@@ -822,12 +825,13 @@ converse.plugins.add('converse-chatview', {
} }
}, },
onMessageAdded (message) { /**
/* Handler that gets called when a new message object is created. * Handler that gets called when a new message object is created.
* * @private
* Parameters: * @method _converse.ChatBoxView#onMessageAdded
* (Object) message - The message Backbone object that was added. * @param { object } message - The message Backbone object that was added.
*/ */
onMessageAdded (message) {
this.showMessage(message); this.showMessage(message);
if (message.get('correcting')) { if (message.get('correcting')) {
this.insertIntoTextArea(message.get('message'), true, true); this.insertIntoTextArea(message.get('message'), true, true);
...@@ -865,17 +869,18 @@ converse.plugins.add('converse-chatview', { ...@@ -865,17 +869,18 @@ converse.plugins.add('converse-chatview', {
} }
}, },
setChatState (state, options) { /**
/* Mutator for setting the chat state of this chat session. * Mutator for setting the chat state of this chat session.
* Handles clearing of any chat state notification timeouts and * Handles clearing of any chat state notification timeouts and
* setting new ones if necessary. * setting new ones if necessary.
* Timeouts are set when the state being set is COMPOSING or PAUSED. * Timeouts are set when the state being set is COMPOSING or PAUSED.
* After the timeout, COMPOSING will become PAUSED and PAUSED will become INACTIVE. * After the timeout, COMPOSING will become PAUSED and PAUSED will become INACTIVE.
* See XEP-0085 Chat State Notifications. * See XEP-0085 Chat State Notifications.
* * @private
* Parameters: * @method _converse.ChatBoxView#setChatState
* (string) state - The chat state (consts ACTIVE, COMPOSING, PAUSED, INACTIVE, GONE) * @param { string } state - The chat state (consts ACTIVE, COMPOSING, PAUSED, INACTIVE, GONE)
*/ */
setChatState (state, options) {
if (!_.isUndefined(this.chat_state_timeout)) { if (!_.isUndefined(this.chat_state_timeout)) {
window.clearTimeout(this.chat_state_timeout); window.clearTimeout(this.chat_state_timeout);
delete this.chat_state_timeout; delete this.chat_state_timeout;
......
...@@ -378,11 +378,6 @@ converse.plugins.add('converse-controlbox', { ...@@ -378,11 +378,6 @@ converse.plugins.add('converse-controlbox', {
}, },
showHelpMessages () { showHelpMessages () {
/* Override showHelpMessages in ChatBoxView, for now do nothing.
*
* Parameters:
* (Array) msgs: Array of messages
*/
return; return;
} }
}); });
......
...@@ -203,15 +203,12 @@ converse.plugins.add('converse-muc-views', { ...@@ -203,15 +203,12 @@ converse.plugins.add('converse-muc-views', {
}; };
function insertRoomInfo (el, stanza) {
/* Insert groupchat info (based on returned #disco IQ stanza) /* Insert groupchat info (based on returned #disco IQ stanza)
* * @function insertRoomInfo
* Parameters: * @param { HTMLElement } el - The HTML DOM element that contains the info.
* (HTMLElement) el: The HTML DOM element that should * @param { XMLElement } stanza - The IQ stanza containing the groupchat info.
* contain the info.
* (XMLElement) stanza: The IQ stanza containing the groupchat
* info.
*/ */
function insertRoomInfo (el, stanza) {
// All MUC features found here: https://xmpp.org/registrar/disco-features.html // All MUC features found here: https://xmpp.org/registrar/disco-features.html
el.querySelector('span.spinner').remove(); el.querySelector('span.spinner').remove();
el.querySelector('a.room-info').classList.add('selected'); el.querySelector('a.room-info').classList.add('selected');
...@@ -1110,12 +1107,13 @@ converse.plugins.add('converse-muc-views', { ...@@ -1110,12 +1107,13 @@ converse.plugins.add('converse-muc-views', {
this.model.addHandler('message', 'ChatRoomView.showStatusMessages', this.showStatusMessages.bind(this)); this.model.addHandler('message', 'ChatRoomView.showStatusMessages', this.showStatusMessages.bind(this));
}, },
onPresence (pres) { /**
/* Handles all MUC presence stanzas. * Handles all MUC presence stanzas.
* * @private
* Parameters: * @method _converse.ChatRoomView#onPresence
* (XMLElement) pres: The stanza * @param { XMLElement } pres - The stanza
*/ */
onPresence (pres) {
// XXX: Current thinking is that excessive stanza // XXX: Current thinking is that excessive stanza
// processing inside a view is a "code smell". // processing inside a view is a "code smell".
// Instead stanza processing should happen inside the // Instead stanza processing should happen inside the
...@@ -1138,14 +1136,14 @@ converse.plugins.add('converse-muc-views', { ...@@ -1138,14 +1136,14 @@ converse.plugins.add('converse-muc-views', {
this.fetchMessages(); this.fetchMessages();
}, },
join (nick, password) { /**
/* Join the groupchat. * Join the groupchat.
* * @private
* Parameters: * @method _converse.ChatRoomView#join
* (String) nick: The user's nickname * @param { String } nick - The user's nickname
* (String) password: Optional password, if required by * @param { String } password - Optional password, if required by the groupchat
* the groupchat.
*/ */
join (nick, password) {
if (!nick && !this.model.get('nick')) { if (!nick && !this.model.get('nick')) {
this.checkForReservedNick(); this.checkForReservedNick();
return this; return this;
...@@ -1154,17 +1152,16 @@ converse.plugins.add('converse-muc-views', { ...@@ -1154,17 +1152,16 @@ converse.plugins.add('converse-muc-views', {
return this; return this;
}, },
renderConfigurationForm (stanza) { /**
/* Renders a form given an IQ stanza containing the current * Renders a form given an IQ stanza containing the current
* groupchat configuration. * groupchat configuration.
*
* Returns a promise which resolves once the user has * Returns a promise which resolves once the user has
* either submitted the form, or canceled it. * either submitted the form, or canceled it.
* * @private
* Parameters: * @method _converse.ChatRoomView#renderConfigurationForm
* (XMLElement) stanza: The IQ stanza containing the groupchat * @param { XMLElement } stanza: The IQ stanza containing the groupchat config.
* config.
*/ */
renderConfigurationForm (stanza) {
const container_el = this.el.querySelector('.chatroom-body'); const container_el = this.el.querySelector('.chatroom-body');
_.each(container_el.querySelectorAll('.chatroom-form-container'), u.removeElement); _.each(container_el.querySelectorAll('.chatroom-form-container'), u.removeElement);
_.each(container_el.children, u.hideElement); _.each(container_el.children, u.hideElement);
...@@ -1420,13 +1417,14 @@ converse.plugins.add('converse-muc-views', { ...@@ -1420,13 +1417,14 @@ converse.plugins.add('converse-muc-views', {
u.showElement(container); u.showElement(container);
}, },
getMessageFromStatus (stat, stanza, is_self) { /**
/* Parameters: * @private
* (XMLElement) stat: A <status> element. * @method _converse.ChatRoomView#getMessageFromStatus
* (Boolean) is_self: Whether the element refers to the * @param { XMLElement } stat: A <status> element
* current user. * @param { Boolean } is_self: Whether the element refers to the current user
* (XMLElement) stanza: The original stanza received. * @param { XMLElement } stanza: The original stanza received
*/ */
getMessageFromStatus (stat, stanza, is_self) {
const code = stat.getAttribute('code'); const code = stat.getAttribute('code');
if (code === '110' || (code === '100' && !is_self)) { return; } if (code === '110' || (code === '100' && !is_self)) { return; }
if (code in _converse.muc.info_messages) { if (code in _converse.muc.info_messages) {
...@@ -1697,14 +1695,14 @@ converse.plugins.add('converse-muc-views', { ...@@ -1697,14 +1695,14 @@ converse.plugins.add('converse-muc-views', {
this.scrollDown(); this.scrollDown();
}, },
showStatusMessages (stanza) { /**
/* Check for status codes and communicate their purpose to the user. * Check for status codes and communicate their purpose to the user.
* See: https://xmpp.org/registrar/mucstatus.html * See: https://xmpp.org/registrar/mucstatus.html
* * @private
* Parameters: * @method _converse.ChatRoomView#showStatusMessages
* (XMLElement) stanza: The message or presence stanza * @param { XMLElement } stanza - The message or presence stanza containing the status codes
* containing the status codes.
*/ */
showStatusMessages (stanza) {
const elements = sizzle(`x[xmlns="${Strophe.NS.MUC_USER}"]`, stanza); const elements = sizzle(`x[xmlns="${Strophe.NS.MUC_USER}"]`, stanza);
const is_self = stanza.querySelectorAll("status[code='110']").length; const is_self = stanza.querySelectorAll("status[code='110']").length;
const iteratee = _.partial(this.parseXUserElement.bind(this), _, stanza, is_self); const iteratee = _.partial(this.parseXUserElement.bind(this), _, stanza, is_self);
......
This diff is collapsed.
...@@ -442,13 +442,13 @@ converse.plugins.add('converse-chatboxes', { ...@@ -442,13 +442,13 @@ converse.plugins.add('converse-chatboxes', {
return false; return false;
}, },
createMessageStanza (message) { /**
/* Given a _converse.Message Backbone.Model, return the XML * Given a {@link _converse.Message} return the XML stanza that represents it.
* stanza that represents it. * @private
* * @method _converse.ChatBox#createMessageStanza
* Parameters: * @param { _converse.Message } message - The message object
* (Object) message - The Backbone.Model representing the message
*/ */
createMessageStanza (message) {
const stanza = $msg({ const stanza = $msg({
'from': _converse.connection.jid, 'from': _converse.connection.jid,
'to': this.get('jid'), 'to': this.get('jid'),
...@@ -630,13 +630,14 @@ converse.plugins.add('converse-chatboxes', { ...@@ -630,13 +630,14 @@ converse.plugins.add('converse-chatboxes', {
}); });
}, },
getStanzaIDs (stanza) { /**
/* Extract the XEP-0359 stanza IDs from the passed in stanza * Extract the XEP-0359 stanza IDs from the passed in stanza
* and return a map containing them. * and return a map containing them.
* * @private
* Parameters: * @method _converse.ChatBox#getStanzaIDs
* (XMLElement) stanza - The message stanza * @param { XMLElement } stanza - The message stanza
*/ */
getStanzaIDs (stanza) {
const attrs = {}; const attrs = {};
const stanza_ids = sizzle(`stanza-id[xmlns="${Strophe.NS.SID}"]`, stanza); const stanza_ids = sizzle(`stanza-id[xmlns="${Strophe.NS.SID}"]`, stanza);
if (stanza_ids.length) { if (stanza_ids.length) {
...@@ -659,18 +660,17 @@ converse.plugins.add('converse-chatboxes', { ...@@ -659,18 +660,17 @@ converse.plugins.add('converse-chatboxes', {
return !_.isNil(sizzle(`result[xmlns="${Strophe.NS.MAM}"]`, original_stanza).pop()); return !_.isNil(sizzle(`result[xmlns="${Strophe.NS.MAM}"]`, original_stanza).pop());
}, },
getMessageAttributesFromStanza (stanza, original_stanza) { /**
/* Parses a passed in message stanza and returns an object * Parses a passed in message stanza and returns an object
* of attributes. * of attributes.
* * @private
* Parameters: * @method _converse.ChatBox#getMessageAttributesFromStanza
* (XMLElement) stanza - The message stanza * @param { XMLElement } stanza - The message stanza
* (XMLElement) delay - The <delay> node from the * @param { XMLElement } delay - The <delay> node from the stanza, if there was one.
* stanza, if there was one. * @param { XMLElement } original_stanza - The original stanza, that contains the
* (XMLElement) original_stanza - The original stanza, * message stanza, if it was contained, otherwise it's the message stanza itself.
* that contains the message stanza, if it was
* contained, otherwise it's the message stanza itself.
*/ */
getMessageAttributesFromStanza (stanza, original_stanza) {
const spoiler = sizzle(`spoiler[xmlns="${Strophe.NS.SPOILER}"]`, original_stanza).pop(), const spoiler = sizzle(`spoiler[xmlns="${Strophe.NS.SPOILER}"]`, original_stanza).pop(),
delay = sizzle(`delay[xmlns="${Strophe.NS.DELAY}"]`, original_stanza).pop(), delay = sizzle(`delay[xmlns="${Strophe.NS.DELAY}"]`, original_stanza).pop(),
text = _converse.chatboxes.getMessageBody(stanza) || undefined, text = _converse.chatboxes.getMessageBody(stanza) || undefined,
...@@ -864,13 +864,13 @@ converse.plugins.add('converse-chatboxes', { ...@@ -864,13 +864,13 @@ converse.plugins.add('converse-chatboxes', {
} }
}, },
async onMessage (stanza) { /**
/* Handler method for all incoming single-user chat "message" * Handler method for all incoming single-user chat "message" stanzas.
* stanzas. * @private
* * @method _converse.ChatBox#onMessage
* Parameters: * @param { XMLElement } stanza - The incoming message stanza
* (XMLElement) stanza - The incoming message stanza
*/ */
async onMessage (stanza) {
let to_jid = stanza.getAttribute('to'); let to_jid = stanza.getAttribute('to');
const to_resource = Strophe.getResourceFromJid(to_jid); const to_resource = Strophe.getResourceFromJid(to_jid);
...@@ -970,15 +970,16 @@ converse.plugins.add('converse-chatboxes', { ...@@ -970,15 +970,16 @@ converse.plugins.add('converse-chatboxes', {
_converse.api.trigger('message', {'stanza': original_stanza, 'chatbox': chatbox}); _converse.api.trigger('message', {'stanza': original_stanza, 'chatbox': chatbox});
}, },
getChatBox (jid, attrs={}, create) { /**
/* Returns a chat box or optionally return a newly * Returns a chat box or optionally return a newly
* created one if one doesn't exist. * created one if one doesn't exist.
* * @private
* Parameters: * @method _converse.ChatBox#getChatBox
* (String) jid - The JID of the user whose chat box we want * @param { string } jid - The JID of the user whose chat box we want
* (Boolean) create - Should a new chat box be created if none exists? * @param { boolean } create - Should a new chat box be created if none exists?
* (Object) attrs - Optional chat box atributes. * @param { object } attrs - Optional chat box atributes.
*/ */
getChatBox (jid, attrs={}, create) {
if (_.isObject(jid)) { if (_.isObject(jid)) {
create = attrs; create = attrs;
attrs = jid; attrs = jid;
......
...@@ -225,20 +225,19 @@ _converse.default_settings = { ...@@ -225,20 +225,19 @@ _converse.default_settings = {
}; };
_converse.log = function (message, level, style='') { /**
/* Logs messages to the browser's developer console. * Logs messages to the browser's developer console.
*
* Parameters:
* (String) message - The message to be logged.
* (Integer) level - The loglevel which allows for filtering of log
* messages.
*
* Available loglevels are 0 for 'debug', 1 for 'info', 2 for 'warn', * Available loglevels are 0 for 'debug', 1 for 'info', 2 for 'warn',
* 3 for 'error' and 4 for 'fatal'. * 3 for 'error' and 4 for 'fatal'.
*
* When using the 'error' or 'warn' loglevels, a full stacktrace will be * When using the 'error' or 'warn' loglevels, a full stacktrace will be
* logged as well. * logged as well.
* @method log
* @private
* @memberOf _converse
* @param { string } message - The message to be logged
* @param { integer } level - The loglevel which allows for filtering of log messages
*/ */
_converse.log = function (message, level, style='') {
if (level === Strophe.LogLevel.ERROR || level === Strophe.LogLevel.FATAL) { if (level === Strophe.LogLevel.ERROR || level === Strophe.LogLevel.FATAL) {
style = style || 'color: maroon'; style = style || 'color: maroon';
} }
...@@ -275,12 +274,15 @@ Strophe.log = function (level, msg) { _converse.log(level+' '+msg, level); }; ...@@ -275,12 +274,15 @@ Strophe.log = function (level, msg) { _converse.log(level+' '+msg, level); };
Strophe.error = function (msg) { _converse.log(msg, Strophe.LogLevel.ERROR); }; Strophe.error = function (msg) { _converse.log(msg, Strophe.LogLevel.ERROR); };
_converse.__ = function (str) { /**
/* Translate the given string based on the current locale. * Translate the given string based on the current locale.
* * Handles all MUC presence stanzas.
* Parameters: * @method __
* (String) str - The string to translate. * @private
* @memberOf _converse
* @param { String } str - The string to translate
*/ */
_converse.__ = function (str) {
if (_.isUndefined(i18n)) { if (_.isUndefined(i18n)) {
return str; return str;
} }
...@@ -565,12 +567,14 @@ _converse.initialize = async function (settings, callback) { ...@@ -565,12 +567,14 @@ _converse.initialize = async function (settings, callback) {
this.generateResource = () => `/converse.js-${Math.floor(Math.random()*139749528).toString()}`; this.generateResource = () => `/converse.js-${Math.floor(Math.random()*139749528).toString()}`;
this.sendCSI = function (stat) { /**
/* Send out a Chat Status Notification (XEP-0352) * Send out a Chat Status Notification (XEP-0352)
* * @private
* Parameters: * @method sendCSI
* (String) stat: The user's chat status * @memberOf _converse
* @param { String } stat - The user's chat status
*/ */
this.sendCSI = function (stat) {
_converse.api.send($build(stat, {xmlns: Strophe.NS.CSI})); _converse.api.send($build(stat, {xmlns: Strophe.NS.CSI}));
_converse.inactive = (stat === _converse.INACTIVE) ? true : false; _converse.inactive = (stat === _converse.INACTIVE) ? true : false;
}; };
...@@ -661,14 +665,15 @@ _converse.initialize = async function (settings, callback) { ...@@ -661,14 +665,15 @@ _converse.initialize = async function (settings, callback) {
}); });
}; };
this.rejectPresenceSubscription = function (jid, message) { /**
/* Reject or cancel another user's subscription to our presence updates. * Reject or cancel another user's subscription to our presence updates.
* * @method rejectPresenceSubscription
* Parameters: * @private
* (String) jid - The Jabber ID of the user whose subscription * @memberOf _converse
* is being canceled. * @param { String } jid - The Jabber ID of the user whose subscription is being canceled
* (String) message - An optional message to the user * @param { String } message - An optional message to the user
*/ */
this.rejectPresenceSubscription = function (jid, message) {
const pres = $pres({to: jid, type: "unsubscribed"}); const pres = $pres({to: jid, type: "unsubscribed"});
if (message && message !== "") { pres.c("status").t(message); } if (message && message !== "") { pres.c("status").t(message); }
_converse.api.send(pres); _converse.api.send(pres);
......
...@@ -23,6 +23,11 @@ converse.plugins.add('converse-disco', { ...@@ -23,6 +23,11 @@ converse.plugins.add('converse-disco', {
_converse.api.promises.add('discoInitialized'); _converse.api.promises.add('discoInitialized');
/**
* @class
* @namespace _converse.DiscoEntity
* @memberOf _converse
*/
_converse.DiscoEntity = Backbone.Model.extend({ _converse.DiscoEntity = Backbone.Model.extend({
/* A Disco Entity is a JID addressable entity that can be queried /* A Disco Entity is a JID addressable entity that can be queried
* for features. * for features.
...@@ -64,14 +69,15 @@ converse.plugins.add('converse-disco', { ...@@ -64,14 +69,15 @@ converse.plugins.add('converse-disco', {
this.items.fetch(); this.items.fetch();
}, },
async getIdentity (category, type) { /**
/* Returns a Promise which resolves with a map indicating * Returns a Promise which resolves with a map indicating
* whether a given identity is provided by this entity. * whether a given identity is provided by this entity.
* * @private
* Parameters: * @method _converse.DiscoEntity#getIdentity
* (String) category - The identity category * @param { String } category - The identity category
* (String) type - The identity type * @param { String } type - The identity type
*/ */
async getIdentity (category, type) {
await this.waitUntilFeaturesDiscovered; await this.waitUntilFeaturesDiscovered;
return this.identities.findWhere({ return this.identities.findWhere({
'category': category, 'category': category,
...@@ -79,13 +85,14 @@ converse.plugins.add('converse-disco', { ...@@ -79,13 +85,14 @@ converse.plugins.add('converse-disco', {
}); });
}, },
async hasFeature (feature) { /**
/* Returns a Promise which resolves with a map indicating * Returns a Promise which resolves with a map indicating
* whether a given feature is supported. * whether a given feature is supported.
* * @private
* Parameters: * @method _converse.DiscoEntity#hasFeature
* (String) feature - The feature that might be supported. * @param { String } feature - The feature that might be supported.
*/ */
async hasFeature (feature) {
await this.waitUntilFeaturesDiscovered await this.waitUntilFeaturesDiscovered
if (this.features.findWhere({'var': feature})) { if (this.features.findWhere({'var': feature})) {
return this; return this;
......
This diff is collapsed.
This diff is collapsed.
...@@ -100,12 +100,6 @@ converse.plugins.add('converse-vcard', { ...@@ -100,12 +100,6 @@ converse.plugins.add('converse-vcard', {
} }
async function getVCard (_converse, jid) { async function getVCard (_converse, jid) {
/* Request the VCard of another user. Returns a promise.
*
* Parameters:
* (String) jid - The Jabber ID of the user whose VCard
* is being requested.
*/
const to = Strophe.getBareJidFromJid(jid) === _converse.bare_jid ? null : jid; const to = Strophe.getBareJidFromJid(jid) === _converse.bare_jid ? null : jid;
let iq; let iq;
try { try {
......
This diff is collapsed.
...@@ -44,9 +44,7 @@ import moment from "moment"; ...@@ -44,9 +44,7 @@ import moment from "moment";
function detectLocale (library_check) { function detectLocale (library_check) {
/* Determine which locale is supported by the user's system as well /* Determine which locale is supported by the user's system as well
* as by the relevant library (e.g. converse.js or moment.js). * as by the relevant library (e.g. converse.js or moment.js).
* * @param { Function } library_check - Returns a boolean indicating whether
* Parameters:
* (Function) library_check - Returns a boolean indicating whether
* the locale is supported. * the locale is supported.
*/ */
var locale, i; var locale, i;
...@@ -87,13 +85,11 @@ function getLocale (preferred_locale, isSupportedByLibrary) { ...@@ -87,13 +85,11 @@ function getLocale (preferred_locale, isSupportedByLibrary) {
return detectLocale(isSupportedByLibrary) || 'en'; return detectLocale(isSupportedByLibrary) || 'en';
} }
function isLocaleAvailable (locale, available) { /* Check whether the locale or sub locale (e.g. en-US, en) is supported.
/* Check whether the locale or sub locale (e.g. en-US, en) is supported. * @param { String } locale - The locale to check for
* * @param { Function } available - Returns a boolean indicating whether the locale is supported
* Parameters:
* (String) locale - The locale to check for
* (Function) available - returns a boolean indicating whether the locale is supported
*/ */
function isLocaleAvailable (locale, available) {
if (available(locale)) { if (available(locale)) {
return locale; return locale;
} else { } else {
...@@ -106,6 +102,9 @@ function isLocaleAvailable (locale, available) { ...@@ -106,6 +102,9 @@ function isLocaleAvailable (locale, available) {
let jed_instance; let jed_instance;
/**
* @namespace i18n
*/
export default { export default {
setLocales (preferred_locale, _converse) { setLocales (preferred_locale, _converse) {
...@@ -120,23 +119,23 @@ export default { ...@@ -120,23 +119,23 @@ export default {
if (_.isNil(jed_instance)) { if (_.isNil(jed_instance)) {
return Jed.sprintf.apply(Jed, arguments); return Jed.sprintf.apply(Jed, arguments);
} }
var t = jed_instance.translate(str); const t = jed_instance.translate(str);
if (arguments.length>1) { if (arguments.length > 1) {
return t.fetch.apply(t, [].slice.call(arguments, 1)); return t.fetch.apply(t, [].slice.call(arguments, 1));
} else { } else {
return t.fetch(); return t.fetch();
} }
}, },
fetchTranslations (locale, supported_locales, locale_url) { /**
/* Fetch the translations for the given local at the given URL. * Fetch the translations for the given local at the given URL.
* * @private
* Parameters: * @method i18n#fetchTranslations
* (String) locale: The given i18n locale * @param { String } locale -The given i18n locale
* (Array) supported_locales: List of locales supported * @param { Array } supported_locales - List of locales supported
* (String) locale_url: The URL from which the translations * @param { String } locale_url - The URL from which the translations should be fetched
* should be fetched.
*/ */
fetchTranslations (locale, supported_locales, locale_url) {
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
if (!isConverseLocale(locale, supported_locales) || locale === 'en') { if (!isConverseLocale(locale, supported_locales) || locale === 'en') {
return resolve(); return resolve();
......
...@@ -14,6 +14,11 @@ import { Strophe } from "strophe.js"; ...@@ -14,6 +14,11 @@ import { Strophe } from "strophe.js";
import _ from "../lodash.noconflict"; import _ from "../lodash.noconflict";
import sizzle from "sizzle"; import sizzle from "sizzle";
/**
* The utils object
* @namespace u
*/
const u = {}; const u = {};
u.toStanza = function (string) { u.toStanza = function (string) {
...@@ -147,14 +152,15 @@ u.applyUserSettings = function applyUserSettings (context, settings, user_settin ...@@ -147,14 +152,15 @@ u.applyUserSettings = function applyUserSettings (context, settings, user_settin
} }
}; };
u.stringToNode = function (s) { /**
/* Converts an HTML string into a DOM Node. * Converts an HTML string into a DOM Node.
* Expects that the HTML string has only one top-level element, * Expects that the HTML string has only one top-level element,
* i.e. not multiple ones. * i.e. not multiple ones.
* * @private
* Parameters: * @method u#stringToNode
* (String) s - The HTML string * @param { String } s - The HTML string
*/ */
u.stringToNode = function (s) {
var div = document.createElement('div'); var div = document.createElement('div');
div.innerHTML = s; div.innerHTML = s;
return div.firstElementChild; return div.firstElementChild;
...@@ -170,26 +176,28 @@ u.getOuterWidth = function (el, include_margin=false) { ...@@ -170,26 +176,28 @@ u.getOuterWidth = function (el, include_margin=false) {
return width; return width;
}; };
u.stringToElement = function (s) { /**
/* Converts an HTML string into a DOM element. * Converts an HTML string into a DOM element.
* Expects that the HTML string has only one top-level element, * Expects that the HTML string has only one top-level element,
* i.e. not multiple ones. * i.e. not multiple ones.
* * @private
* Parameters: * @method u#stringToElement
* (String) s - The HTML string * @param { String } s - The HTML string
*/ */
u.stringToElement = function (s) {
var div = document.createElement('div'); var div = document.createElement('div');
div.innerHTML = s; div.innerHTML = s;
return div.firstElementChild; return div.firstElementChild;
}; };
u.matchesSelector = function (el, selector) { /**
/* Checks whether the DOM element matches the given selector. * Checks whether the DOM element matches the given selector.
* * @private
* Parameters: * @method u#matchesSelector
* (DOMElement) el - The DOM element * @param { DOMElement } el - The DOM element
* (String) selector - The selector * @param { String } selector - The selector
*/ */
u.matchesSelector = function (el, selector) {
const match = ( const match = (
el.matches || el.matches ||
el.matchesSelector || el.matchesSelector ||
...@@ -201,15 +209,14 @@ u.matchesSelector = function (el, selector) { ...@@ -201,15 +209,14 @@ u.matchesSelector = function (el, selector) {
return match ? match.call(el, selector) : false; return match ? match.call(el, selector) : false;
}; };
u.queryChildren = function (el, selector) { /**
/* Returns a list of children of the DOM element that match the * Returns a list of children of the DOM element that match the selector.
* selector. * @private
* * @method u#queryChildren
* Parameters: * @param { DOMElement } el - the DOM element
* (DOMElement) el - the DOM element * @param { String } selector - the selector they should be matched against
* (String) selector - the selector they should be matched
* against.
*/ */
u.queryChildren = function (el, selector) {
return _.filter(el.childNodes, _.partial(u.matchesSelector, _, selector)); return _.filter(el.childNodes, _.partial(u.matchesSelector, _, selector));
}; };
...@@ -296,16 +303,17 @@ u.interpolate = function (string, o) { ...@@ -296,16 +303,17 @@ u.interpolate = function (string, o) {
}); });
}; };
u.onMultipleEvents = function (events=[], callback) { /**
/* Call the callback once all the events have been triggered * Call the callback once all the events have been triggered
* * @private
* Parameters: * @method u#onMultipleEvents
* (Array) events: An array of objects, with keys `object` and * @param { Array } events: An array of objects, with keys `object` and
* `event`, representing the event name and the object it's * `event`, representing the event name and the object it's
* triggered upon. * triggered upon.
* (Function) callback: The function to call once all events have * @param { Function } callback: The function to call once all events have
* been triggered. * been triggered.
*/ */
u.onMultipleEvents = function (events=[], callback) {
let triggered = []; let triggered = [];
function handler (result) { function handler (result) {
......
...@@ -10,12 +10,13 @@ import _ from "../lodash.noconflict"; ...@@ -10,12 +10,13 @@ import _ from "../lodash.noconflict";
import tpl_field from "../templates/field.html"; import tpl_field from "../templates/field.html";
import u from "./core"; import u from "./core";
u.webForm2xForm = function (field) { /**
/* Takes an HTML DOM and turns it into an XForm field. * Takes an HTML DOM and turns it into an XForm field.
* * @private
* Parameters: * @method u#webForm2xForm
* (DOMElement) field - the field to convert * @param { DOMElement } field - the field to convert
*/ */
u.webForm2xForm = function (field) {
let value; let value;
if (field.getAttribute('type') === 'checkbox') { if (field.getAttribute('type') === 'checkbox') {
value = field.checked && 1 || 0; value = field.checked && 1 || 0;
......
...@@ -15,8 +15,8 @@ import u from "./core"; ...@@ -15,8 +15,8 @@ import u from "./core";
const { Strophe, sizzle, _ } = converse.env; const { Strophe, sizzle, _ } = converse.env;
u.computeAffiliationsDelta = function computeAffiliationsDelta (exclude_existing, remove_absentees, new_list, old_list) { /**
/* Given two lists of objects with 'jid', 'affiliation' and * Given two lists of objects with 'jid', 'affiliation' and
* 'reason' properties, return a new list containing * 'reason' properties, return a new list containing
* those objects that are new, changed or removed * those objects that are new, changed or removed
* (depending on the 'remove_absentees' boolean). * (depending on the 'remove_absentees' boolean).
...@@ -26,22 +26,23 @@ u.computeAffiliationsDelta = function computeAffiliationsDelta (exclude_existing ...@@ -26,22 +26,23 @@ u.computeAffiliationsDelta = function computeAffiliationsDelta (exclude_existing
* *
* The 'reason' property is not taken into account when * The 'reason' property is not taken into account when
* comparing whether affiliations have been changed. * comparing whether affiliations have been changed.
* * @private
* Parameters: * @method u#computeAffiliationsDelta
* (Boolean) exclude_existing: Indicates whether JIDs from * @param { boolean } exclude_existing - Indicates whether JIDs from
* the new list which are also in the old list * the new list which are also in the old list
* (regardless of affiliation) should be excluded * (regardless of affiliation) should be excluded
* from the delta. One reason to do this * from the delta. One reason to do this
* would be when you want to add a JID only if it * would be when you want to add a JID only if it
* doesn't have *any* existing affiliation at all. * doesn't have *any* existing affiliation at all.
* (Boolean) remove_absentees: Indicates whether JIDs * @param { boolean } remove_absentees - Indicates whether JIDs
* from the old list which are not in the new list * from the old list which are not in the new list
* should be considered removed and therefore be * should be considered removed and therefore be
* included in the delta with affiliation set * included in the delta with affiliation set
* to 'none'. * to 'none'.
* (Array) new_list: Array containing the new affiliations * @param { array } new_list - Array containing the new affiliations
* (Array) old_list: Array containing the old affiliations * @param { array } old_list - Array containing the old affiliations
*/ */
u.computeAffiliationsDelta = function computeAffiliationsDelta (exclude_existing, remove_absentees, new_list, old_list) {
const new_jids = _.map(new_list, 'jid'); const new_jids = _.map(new_list, 'jid');
const old_jids = _.map(old_list, 'jid'); const old_jids = _.map(old_list, 'jid');
......
This diff is collapsed.
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