Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
converse.js
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
converse.js
Commits
93b1481a
Commit
93b1481a
authored
Apr 11, 2017
by
JC Brand
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Update Angular integration docs based on plugin changes in 3.0.x
parent
de2f33f3
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
19 additions
and
15 deletions
+19
-15
docs/source/other_frameworks.rst
docs/source/other_frameworks.rst
+19
-15
No files found.
docs/source/other_frameworks.rst
View file @
93b1481a
...
@@ -24,7 +24,7 @@ application, then putting it into a service is a good approach.
...
@@ -24,7 +24,7 @@ application, then putting it into a service is a good approach.
This lets us avoid having a global ``converse`` API object (accessible via
This lets us avoid having a global ``converse`` API object (accessible via
``windows.converse``), and instead we can get hold of the converse API via
``windows.converse``), and instead we can get hold of the converse API via
angular's dependency injection
,
when we specify it as a dependency for our
angular's dependency injection when we specify it as a dependency for our
angular components.
angular components.
Below is an example code that wraps converse.js as an angular.js service.
Below is an example code that wraps converse.js as an angular.js service.
...
@@ -33,27 +33,21 @@ Below is an example code that wraps converse.js as an angular.js service.
...
@@ -33,27 +33,21 @@ Below is an example code that wraps converse.js as an angular.js service.
angular.module('converse', []).service('converse', function() {
angular.module('converse', []).service('converse', function() {
// We create three promises, which will be resolved at various times
// We create three promises, which will be resolved at various times
var loaded_deferred = new $.Deferred(), // Converse.js has been loaded
var loaded_deferred = new $.Deferred(),
connected_deferred = new $.Deferred(), // An XMPP connection has been established
connected_deferred = new $.Deferred();
roster_deferred = new $.Deferred(); // The contacts roster has been fetched.
var loaded_promise = loaded_deferred.promise(),
connected_promise = connected_deferred.promise(),
roster_promise = roster_deferred.promise();
// This is the API of the service.
var service = {
var service = {
'waitUntilLoaded': _.constant(loaded_
promise
),
'waitUntilLoaded': _.constant(loaded_
deferred.promise()
),
'initialize': function initConverse(options) {
'initialize': function initConverse(options) {
this.waitUntilLoaded().done(_.partial(this.api.initialize, options));
this.waitUntilLoaded().done(_.partial(this.api.initialize, options));
},
},
'waitUntilConnected': _.constant(connected_promise),
'waitUntilConnected': _.constant(connected_deferred.promise())
'waitUntilRosterFetched': _.constant(roster_promise),
};
};
// Here we define the core components of converse.js that will be
// Here we define the core components of converse.js that will be
// loaded and used.
// loaded and used.
define(["converse-core",
define([
"converse-core",
// START: Removable components
// START: Removable components
// --------------------
// --------------------
// Any of the following components may be removed if they're not needed.
// Any of the following components may be removed if they're not needed.
...
@@ -79,7 +73,16 @@ Below is an example code that wraps converse.js as an angular.js service.
...
@@ -79,7 +73,16 @@ Below is an example code that wraps converse.js as an angular.js service.
], function(converse) {
], function(converse) {
service.api = converse;
service.api = converse;
return deferred.resolve();
// Register a plugin which resolves `waitUntilConnected` promise.
converse.plugins.add('conversejs-angular-service', {
initialize: function () {
this._converse.api.listen.on('connected', connected_deferred.resolve);
}
});
// Converse.js has been loaded, so we can resolve the `waitUntilLoaded` promise.
return loaded_deferred.resolve();
});
});
require(["converse"]);
require(["converse"]);
return service;
return service;
...
@@ -120,6 +123,7 @@ your components, for example:
...
@@ -120,6 +123,7 @@ your components, for example:
'jid': bare_jid,
'jid': bare_jid,
'keepalive': true,
'keepalive': true,
'credentials_url': credentials_url,
'credentials_url': credentials_url,
'whitelisted_plugins': ['conversejs-angular-service']
});
});
// More custom code could come here...
// More custom code could come here...
...
@@ -129,7 +133,7 @@ your components, for example:
...
@@ -129,7 +133,7 @@ your components, for example:
You might have noticed the ``waitUntilLoaded()`` method being called on the ``converse``
You might have noticed the ``waitUntilLoaded()`` method being called on the ``converse``
service. This is a special method added to the service (see the implementation
service. This is a special method added to the service (see the implementation
example above) that makes sure that converse.js is loaded and available. It
example above) that makes sure that converse.js is loaded and available. It
returns a
jQuery
promise which resolves once converse.js is available.
returns a promise which resolves once converse.js is available.
This is necessary because with otherwise you might run into race-conditions
This is necessary because with otherwise you might run into race-conditions
when your angular application loads more quickly then converse.js.
when your angular application loads more quickly then converse.js.
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment