Merge "Type hint against LinkTarget in WatchedItemStore"
[lhc/web/wiklou.git] / resources / src / mediawiki.messagePoster / MessagePoster.js
1 ( function () {
2 /**
3 * This is the abstract base class for MessagePoster implementations.
4 *
5 * @abstract
6 * @class
7 *
8 * @constructor
9 * @param {mw.Title} title Title to post to
10 */
11 mw.messagePoster.MessagePoster = function MwMessagePoster() {};
12
13 OO.initClass( mw.messagePoster.MessagePoster );
14
15 /**
16 * Post a message (with subject and body) to a talk page.
17 *
18 * @abstract
19 * @param {string} subject Subject/topic title. The amount of wikitext supported is
20 * implementation-specific. It is recommended to only use basic wikilink syntax for
21 * maximum compatibility.
22 * @param {string} body Body, as wikitext. Signature code will automatically be added
23 * by MessagePosters that require one, unless the message already contains the string
24 * ~~~.
25 * @param {Object} [options] Message options. See MessagePoster implementations for details.
26 * @return {jQuery.Promise} Promise completing when the post succeeds or fails.
27 * For failure, will be rejected with three arguments:
28 *
29 * - primaryError - Primary error code. For a mw.Api failure,
30 * this should be 'api-fail'.
31 * - secondaryError - Secondary error code. For a mw.Api failure,
32 * this, should be mw.Api's code, e.g. 'http', 'ok-but-empty', or the error passed through
33 * from the server.
34 * - details - Further details about the error
35 *
36 * @localdoc
37 * The base class currently does nothing, but could be used for shared analytics or
38 * something.
39 */
40 mw.messagePoster.MessagePoster.prototype.post = function () {};
41 }() );