Commit 1050650c authored by JC Brand's avatar JC Brand

Update documentation

parent 1125940e
...@@ -995,7 +995,7 @@ This allows plugins to have "soft" dependencies which aren't declared as ...@@ -995,7 +995,7 @@ This allows plugins to have "soft" dependencies which aren't declared as
as dependencies. as dependencies.
synchronize_availability synchronize_availability
-------------------- ------------------------
* Default: ``true`` * Default: ``true``
......
Developer guidelines
====================
If you want to work with the non-minified Javascript and CSS files you'll soon
notice that there are references to missing *components* and *node_modules* directories.
Please follow the instructions below to create these directories and fetch Converse's
3rd-party dependencies.
.. note::
Windows environment: We recommend installing the required tools using `Chocolatey <https://chocolatey.org/>`_
You will need Node.js (nodejs.install), Git (git.install) and optionally to build using Makefile, GNU Make (make)
If you have trouble setting up a development environment on Windows,
please read `this post <http://librelist.com/browser//conversejs/2014/11/5/openfire-converse-and-visual-studio-questions/#b28387e7f8f126693b11598a8acbe810>`_
in the mailing list.:
Installing the development and front-end dependencies
-----------------------------------------------------
We use development tools (`Grunt <http://gruntjs.com>`_ and `Bower <http://bower.io>`_)
which depend on Node.js and npm (the Node package manager).
If you don't have Node.js installed, you can download and install the latest
version `here <https://nodejs.org/download>`_.
Also make sure you have ``Git`` installed. `Details <http://git-scm.com/book/en/Getting-Started-Installing-Git>`_.
.. note::
Windows users should use Chocolatey as recommended above.
.. note::
Debian & Ubuntu users : apt-get install git npm nodejs-legacy
Once you have *Node.js* and *git* installed, run the following command inside the Converse.js
directory:
::
make dev
On Windows you need to specify Makefile.win to be used by running: ::
make -f Makefile.win dev
Or alternatively, if you don't have GNU Make:
::
npm install
bower update
This will first install the Node.js development tools (like Grunt and Bower)
as well as Converse.js's front-end dependencies.
The front-end dependencies are those javascript files on which
Converse.js directly depends and which will be loaded in the browser.
To see the dependencies, take a look at whats under the *devDependencies* key in
`package.json <https://github.com/jcbrand/converse.js/blob/master/package.json>`_.
.. note::
After running ```make dev```, you should now have new directories *components*
and *node_modules*, which contain all the front-end dependencies of Converse.js.
If these directory does NOT exist, something must have gone wrong.
Double-check the output of ```make dev``` to see if there are any errors
listed. For support, you can write to the mailing list: conversejs@librelist.com
Loading converse.js and its dependencies
----------------------------------------
With AMD and require.js (recommended)
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Converse.js uses `require.js <http://requirejs.org>`_ to asynchronously load dependencies.
If you want to develop or customize converse.js, you'll want to load the
non-minified javascript files.
Add the following two lines to the *<head>* section of your webpage:
.. code-block:: html
<link rel="stylesheet" type="text/css" media="screen" href="converse.css">
<script data-main="main" src="components/requirejs/require.js"></script>
require.js will then let the main.js file be parsed (because of the *data-main*
attribute on the *script* tag), which will in turn cause converse.js to be
parsed.
Without AMD and require.js
~~~~~~~~~~~~~~~~~~~~~~~~~~
Converse.js can also be used without require.js. If you for some reason prefer
to use it this way, please refer to
`non_amd.html <https://github.com/jcbrand/converse.js/blob/master/non_amd.html>`_
for an example of how and in what order all the Javascript files that converse.js
depends on need to be loaded.
Before submitting a pull request
--------------------------------
Please follow the usual github workflow. Create your own local fork of this repository,
make your changes and then submit a pull request.
Follow the programming style guide
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Please read the `style guide </docs/html/style_guide.html>`_ and make sure that your code follows it.
Add tests for your bugfix or feature
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Add a test for any bug fixed or feature added. We use Jasmine
for testing.
Take a look at `tests.html <https://github.com/jcbrand/converse.js/blob/master/tests.html>`_
and the `spec files <https://github.com/jcbrand/converse.js/blob/master/tests.html>`_
to see how tests are implemented.
Check that the tests pass
~~~~~~~~~~~~~~~~~~~~~~~~~
Check that all tests complete sucessfully.
Run ``make check`` in your terminal or open `tests.html <https://github.com/jcbrand/converse.js/blob/master/tests.html>`_
in your browser.
This diff is collapsed.
...@@ -2,6 +2,8 @@ ...@@ -2,6 +2,8 @@
<div id="banner"><a href="https://github.com/jcbrand/converse.js/blob/master/docs/source/theming.rst">Edit me on GitHub</a></div> <div id="banner"><a href="https://github.com/jcbrand/converse.js/blob/master/docs/source/theming.rst">Edit me on GitHub</a></div>
.. _`events-API`:
Events emitted by converse.js Events emitted by converse.js
============================= =============================
......
...@@ -2,6 +2,8 @@ ...@@ -2,6 +2,8 @@
<div id="banner"><a href="https://github.com/jcbrand/converse.js/blob/master/docs/source/theming.rst">Edit me on GitHub</a></div> <div id="banner"><a href="https://github.com/jcbrand/converse.js/blob/master/docs/source/theming.rst">Edit me on GitHub</a></div>
.. _`writing-a-plugin`:
Writing a converse.js plugin Writing a converse.js plugin
============================ ============================
...@@ -36,17 +38,18 @@ Security and access to the inner workings ...@@ -36,17 +38,18 @@ Security and access to the inner workings
The globally available ``converse`` object, which exposes the API methods, such The globally available ``converse`` object, which exposes the API methods, such
as ``initialize`` and ``plugins.add``, is a wrapper that encloses and protects as ``initialize`` and ``plugins.add``, is a wrapper that encloses and protects
a sensitive inner object. a sensitive inner object, named ``_converse`` (not the underscore prefix).
This inner object contains all the Backbone models and views, as well as This inner ``_converse`` object contains all the Backbone models and views,
various other attributes and functions. as well as various other attributes and functions.
Within a plugin, you will have access to this internal Within a plugin, you will have access to this internal
`"closured" <https://developer.mozilla.org/en-US/docs/Web/JavaScript/Closures>`_ `"closured" <https://developer.mozilla.org/en-US/docs/Web/JavaScript/Closures>`_
converse object, which is normally not exposed in the global variable scope. The ``_converse`` object, which is normally not exposed in the global variable scope.
hiding of this inner object is due to the fact that it contains sensitive information,
such as the user's JID and password (if they logged in manually). You should We inner ``_converse`` object is made private in order to safely hide and
therefore make sure NOT to expose this object globally. encapsulate sensitive information and methods which should not be exposed
to any 3rd-party scripts that might be running in the same page.
An example plugin An example plugin
----------------- -----------------
...@@ -63,70 +66,57 @@ An example plugin ...@@ -63,70 +66,57 @@ An example plugin
// appears after the one from converse.js. // appears after the one from converse.js.
factory(converse); factory(converse);
} }
}(this, function (converse_api) { }(this, function (converse) {
// Commonly used utilities and variables can be found under the "env" // Commonly used utilities and variables can be found under the "env"
// namespace of converse_api // namespace of the "converse" global.
var Strophe = converse.env.Strophe,
// Strophe methods for building stanzas $iq = converse.env.$iq,
var Strophe = converse_api.env.Strophe, $msg = converse.env.$msg,
$iq = converse_api.env.$iq, $pres = converse.env.$pres,
$msg = converse_api.env.$msg, $build = converse.env.$build,
$pres = converse_api.env.$pres, b64_sha1 = converse.env.b64_sha1;
$build = converse_api.env.$build, $ = converse.env.jQuery,
b64_sha1 = converse_api.env.b64_sha1; _ = converse.env._,
moment = converse.env.moment;
// Other frequently used utilities
var $ = converse_api.env.jQuery,
_ = converse_api.env._,
moment = converse_api.env.moment;
// The following line registers your plugin. // The following line registers your plugin.
converse_api.plugins.add('myplugin', { converse.plugins.add('myplugin', {
initialize: function () { initialize: function () {
// Converse.js's plugin mechanism will call the initialize // Converse.js's plugin mechanism will call the initialize
// method on any plugin (if it exists) as soon as the plugin has // method on any plugin (if it exists) as soon as the plugin has
// been loaded. // been loaded.
// Inside this method, you have access to the protected "inner" // Inside this method, you have access to the closured
// converse object, from which you can get any configuration // _converse object, from which you can get any configuration
// options that the user might have passed in via // options that the user might have passed in via
// converse.initialize. These values are stored in the // converse.initialize. These values are stored in the
// "user_settings" attribute. // "user_settings" attribute.
// Let's assume the user might in a custom setting, like so: // Let's assume the user might pass in a custom setting, like so:
//
// converse.initialize({ // converse.initialize({
// "initialize_message": "My plugin has been initialized" // "initialize_message": "My plugin has been initialized"
// }); // });
// //
// Then we can alert that message, like so: // Then we can alert that message, like so:
alert(this.converse.user_settings.initialize_message); alert(this._converse.user_settings.initialize_message);
},
myFunction: function () {
// This is a function which does not override anything in
// converse.js itself, but in which you still have access to
// the protected "inner" converse object.
var converse = this.converse;
// Custom code comes here
// ...
}, },
overrides: { overrides: {
// If you want to override some function or a Backbone model or // If you want to override some function or a Backbone model or
// view defined inside converse, then you do that under this // view defined elsewhere in converse.js, then you do that under
// "overrides" namespace. // this "overrides" namespace.
// For example, the inner protected *converse* object has a // For example, the inner protected *_converse* object has a
// method "onConnected". You can override that method as follows: // method "onConnected". You can override that method as follows:
onConnected: function () { onConnected: function () {
// Overrides the onConnected method in converse.js // Overrides the onConnected method in converse.js
// Top-level functions in "overrides" are bound to the // Top-level functions in "overrides" are bound to the
// inner "converse" object. // inner "_converse" object.
var converse = this; var _converse = this;
// Your custom code comes here. // Your custom code comes here.
// ... // ...
...@@ -135,16 +125,16 @@ An example plugin ...@@ -135,16 +125,16 @@ An example plugin
// via the __super__ attribute. // via the __super__ attribute.
// Make sure to pass on the arguments supplied to this // Make sure to pass on the arguments supplied to this
// function and also to apply the proper "this" object. // function and also to apply the proper "this" object.
this.__super__.onConnected.apply(this, arguments); _converse.__super__.onConnected.apply(this, arguments);
}, },
XMPPStatus: { XMPPStatus: {
// Override converse.js's XMPPStatus Backbone model so that we can override the // Override converse.js's XMPPStatus Backbone model so that we can override the
// function that sends out the presence stanza. // function that sends out the presence stanza.
sendPresence: function (type, status_message, jid) { sendPresence: function (type, status_message, jid) {
// The "converse" object is available via the __super__ // The "_converse" object is available via the __super__
// attribute. // attribute.
var converse = this.__super__.converse; var _converse = this.__super__.converse;
// Custom code can come here // Custom code can come here
// ... // ...
...@@ -155,7 +145,7 @@ An example plugin ...@@ -155,7 +145,7 @@ An example plugin
// context as reference by the "this" variable. // context as reference by the "this" variable.
this.__super__.sendPresence.apply(this, arguments); this.__super__.sendPresence.apply(this, arguments);
} }
}, }
} }
}); });
})); }));
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