2014-05-06 21:19:35 +02:00
<!DOCTYPE html>
< html lang = "en" >
2013-03-28 17:52:07 +01:00
< head >
2014-05-06 15:25:31 +02:00
< title > Converse.js< / title >
2014-05-06 21:19:35 +02:00
< meta charset = "utf-8" >
2013-11-16 11:02:45 +01:00
< meta http-equiv = "Content-Type" content = "text/html; charset=utf-8" / >
2014-05-07 22:36:45 +02:00
< meta name = "viewport" content = "width=device-width, initial-scale=1.0" / >
2017-03-03 14:44:23 +01:00
< meta name = "description" content = "Converse.js: An XMPP chat client which can be integrated into any website" / >
2014-05-07 22:36:45 +02:00
< meta name = "author" content = "JC Brand" / >
2014-05-06 15:25:31 +02:00
< meta name = "keywords" content = "xmpp chat webchat converse.js" / >
2014-09-21 19:05:19 +02:00
< link rel = "shortcut icon" type = "image/ico" href = "css/images/favicon.ico" / >
2017-07-06 17:35:25 +02:00
< link type = "text/css" rel = "stylesheet" media = "screen" href = "css/bootstrap.min.css" / >
< link type = "text/css" rel = "stylesheet" media = "screen" href = "css/font-awesome.min.css" / >
2017-06-14 15:42:48 +02:00
< link type = "text/css" rel = "stylesheet" media = "screen" href = "css/theme.min.css" / >
2014-12-13 21:54:48 +01:00
< script type = "text/javascript" src = "analytics.js" > < / script >
2014-12-30 10:45:33 +01:00
< noscript > < p > < img src = "//stats.opkode.com/piwik.php?idsite=1" style = "border:0;" alt = "" / > < / p > < / noscript >
2017-09-04 09:09:48 +02:00
< script src = "src/website.js" > < / script >
2017-07-14 23:01:09 +02:00
<![if gte IE 11]>
2018-01-18 14:48:32 +01:00
< link type = "text/css" rel = "stylesheet" media = "screen" href = "https://cdn.conversejs.org/3.3.1/css/converse.min.css" / >
< script src = "https://cdn.conversejs.org/3.3.1/dist/converse.min.js" > < / script >
2014-12-07 13:45:14 +01:00
<![endif]>
2013-03-28 17:52:07 +01:00
< / head >
2014-05-06 21:19:35 +02:00
< body id = "page-top" data-spy = "scroll" data-target = ".navbar-custom" >
< nav class = "navbar navbar-custom navbar-fixed-top" role = "navigation" >
< div class = "container" >
< div class = "navbar-header page-scroll" >
< button type = "button" class = "navbar-toggle" data-toggle = "collapse" data-target = ".navbar-main-collapse" >
< i class = "fa fa-bars" > < / i >
< / button >
< a class = "navbar-brand" href = "#page-top" >
< i class = "fa fa-play-circle" > < / i > < span class = "light" > Home< / span >
< / a >
< / div >
<!-- Collect the nav links, forms, and other content for toggling -->
< div class = "collapse navbar-collapse navbar-right navbar-main-collapse" >
< ul class = "nav navbar-nav" >
<!-- Hidden li included to remove active class from about link when scrolled up past about section -->
< li class = "hidden" >
< a href = "#page-top" > < / a >
< / li >
< li class = "page-scroll" >
< a href = "#about" > About< / a >
< / li >
< li class = "page-scroll" >
< a href = "#features" > Features< / a >
< / li >
< li class = "page-scroll" >
< a href = "#contact" > Contact< / a >
< / li >
2017-12-05 14:11:48 +01:00
< li class = "page-scroll" >
< a href = "#sponsors" > Sponsor< / a >
< / li >
2015-05-02 00:22:50 +02:00
< li >
< a href = "/docs/html/manual.html" > User Manual< / a >
< / li >
2014-12-07 10:48:32 +01:00
< li >
2014-12-07 01:32:46 +01:00
< a href = "/docs/html/index.html" > Documentation< / a >
2014-05-06 21:19:35 +02:00
< / li >
2014-12-07 10:48:32 +01:00
< li >
2017-07-05 13:02:36 +02:00
< a href = "https://github.com/jcbrand/converse.js/releases" class = "button" target = "_blank" rel = "noopener" > Download< / a >
2014-12-07 10:48:32 +01:00
< / li >
2014-05-06 21:19:35 +02:00
< / ul >
< / div >
<!-- /.navbar - collapse -->
< / div >
<!-- /.container -->
< / nav >
2015-11-05 11:36:47 +01:00
< section class = "intro" class = "container" >
< div class = "row" >
2017-09-09 11:20:28 +02:00
< h1 class = "brand-heading" > < i class = "icon-conversejs" > < / i > converse< / h1 >
2015-11-05 11:36:47 +01:00
< div class = "col-md-8 col-md-offset-2" >
< p class = "intro-text" > A free and open-source XMPP chat client in your browser< / p >
2017-07-05 13:02:36 +02:00
< p > Now also available in a fullscreen version.
2017-12-05 14:11:48 +01:00
Check out < a href = "https://inverse.chat" target = "_blank" rel = "noopener" > inverse.chat< / a > < / br >
2017-12-06 11:40:04 +01:00
Please support this project via < a href = "https://www.patreon.com/jcbrand" target = "_blank" rel = "noopener" > Patreon< / a > or < a href = "https://liberapay.com/jcbrand" target = "_blank" rel = "noopener" > Liberapay< / a >
< / p >
2015-11-05 11:36:47 +01:00
< div class = "page-scroll" >
< a href = "#about" class = "btn btn-default btn-lg" > < span class = "btn-text" > Learn More< / span > < / a >
2014-05-06 21:19:35 +02:00
< / div >
2014-05-06 15:25:31 +02:00
< / div >
2014-05-06 21:19:35 +02:00
< / div >
2015-11-05 11:36:47 +01:00
< div class = "row" >
< div class = "col-md-8 col-md-offset-2 banner-social-buttons" >
< ul class = "list-inline" >
2017-07-05 13:02:36 +02:00
< li > < a href = "https://twitter.com/jcopkode" class = "btn btn-circle btn-lg" title = "Twitter" target = "_blank" rel = "noopener" > < i class = "fa fa-twitter" > < / i > < / a >
2015-11-05 11:36:47 +01:00
< / li >
2017-07-05 13:02:36 +02:00
< li > < a href = "https://github.com/jcbrand/converse.js" class = "btn btn-circle btn-lg" title = "GitHub" target = "_blank" rel = "noopener" > < i class = "fa fa-github" > < / i > < / a >
2015-11-05 11:36:47 +01:00
< / li >
< / ul >
< / div >
< / div >
2014-09-21 19:05:19 +02:00
< / section >
2013-03-28 16:42:49 +01:00
2014-05-06 21:19:35 +02:00
< section id = "about" class = "container content-section text-center" >
< div class = "row" >
< div class = "col-lg-8 col-lg-offset-2" >
2015-02-27 15:07:37 +01:00
< h2 > < strong > Converse.js< / strong > is written in Javascript and runs in your browser.< / h2 >
< p > You can start using it here immediately, or you can < a href = "/docs/html/index.html" > integrate it into your own website< / a > .< / p >
2017-02-17 20:59:35 +01:00
< p > Take a look at the < a href = "/demo" > demo page< / a > for other examples of how Converse.js can be configured and used.< / a >
2014-05-06 21:19:35 +02:00
< p >
2017-07-05 13:02:36 +02:00
You can connect to any publically accessible < a href = "http://xmpp.org" target = "_blank" rel = "noopener" > XMPP/Jabber< / a > server,
2015-01-07 11:17:12 +01:00
either from a < a href = "https://xmpp.net/directory.php" > public provider< / a > , or one you have set up yourself.
2014-05-06 21:19:35 +02:00
< / p >
2015-02-27 15:07:37 +01:00
< h3 > Don't have an XMPP/Jabber account?< / h3 >
< p > No problem! With converse.js you can register an account on any public XMPP server that allows registration.< / p >
2014-05-06 21:19:35 +02:00
< / div >
< / div >
< / section >
2014-05-06 22:30:37 +02:00
< section class = "features-section content-section" id = "features" >
2014-05-06 21:19:35 +02:00
< div class = "container" >
< div class = "row" >
< div class = "col-lg-4" >
< section >
2014-05-07 08:04:32 +02:00
< span class = "feature-icon page-scroll" > < a class = "fa fa-globe" href = "#features" title = "Integration" > < / a > < / span >
2014-05-06 21:19:35 +02:00
< header >
< h2 > Integration< / h2 >
< / header >
< ul class = "integration" >
2017-07-05 13:02:36 +02:00
< li > < a href = "https://github.com/mikemarsian/conversejs-rails" target = "_blank" rel = "noopener" > Ruby on Rails< / a > < / li >
< li > < a href = "http://github.com/collective/collective.xmpp.chat" target = "_blank" rel = "noopener" > Plone< / a > < / li >
< li > < a href = "https://pypi.python.org/pypi/django-conversejs" target = "_blank" rel = "noopener" > Django (option 1)< / a > < / li >
< li > < a href = "https://github.com/fpytloun/django-xmpp" target = "_blank" rel = "noopener" > Django (option 2)< / a > < / li >
< li > < a href = "https://github.com/devurandom/roundcube-converse.js-xmpp-plugin" target = "_blank" rel = "noopener" > Roundcube< / a > < / li >
< li > < a href = "http://wordpress.org/plugins/conversejs" target = "_blank" rel = "noopener" > Wordpress< / a > < / li >
< li > < a href = "https://github.com/jcbrand/patterns.converse" target = "_blank" rel = "noopener" > Patternslib< / a > < / li >
< li > < a href = "https://github.com/keensoft/alfresco-js-chat-share" target = "_blank" rel = "noopener" > Alfresco< / a > < / li >
< li > < a href = "https://github.com/friendica/friendica-addons/tree/master/xmpp/converse" target = "_blank" rel = "noopener" > Friendica< / a > < / li >
2014-05-06 21:19:35 +02:00
< / ul >
< / section >
< / div >
< div class = "col-lg-4" >
< section >
2014-05-07 08:04:32 +02:00
< span class = "feature-icon page-scroll" > < a class = "fa fa-check-square-o" href = "#features" title = "Features" > < / a > < / span >
2014-05-06 21:19:35 +02:00
< / section >
< header >
< h2 > Features< / h2 >
< / header >
< ul class = "features" >
2017-07-05 13:02:36 +02:00
< li > Available as overlayed chat boxes or as a fullscreen application.
See < a href = "https://inverse.chat" target = "_blank" rel = "noopener" > inverse.chat< / a > for the fullscreen version.
< / li >
2017-09-04 09:24:38 +02:00
< li > < a href = "https://conversejs.org/docs/html/plugin_development.html" > Plugin Architecture< / a > based on
< a href = "https://jcbrand.github.io/pluggable.js/" target = "_blank" rel = "noopener" > pluggable.js< / a > < / li >
2016-12-08 13:02:24 +01:00
< li > Presence information (online, busy, away)< / li >
2014-05-06 21:19:35 +02:00
< li > Single-user chat< / li >
2016-10-06 13:28:09 +02:00
< li > Contacts and groups< / li >
2017-07-05 13:02:36 +02:00
< li > Multi-user chatrooms (< a href = "http://xmpp.org/extensions/xep-0045.html" target = "_blank" rel = "noopener" > XEP 45< / a > )< / li >
< li > Chatroom bookmarks (< a href = "http://xmpp.org/extensions/xep-0048.html" target = "_blank" rel = "noopener" > XEP 48< / a > )< / li >
< li > Direct invitations to chat rooms (< a href = "http://xmpp.org/extensions/xep-0249.html" target = "_blank" rel = "noopener" > XEP 249< / a > )< / li >
< li > vCard support (< a href = "http://xmpp.org/extensions/xep-0054.html" target = "_blank" rel = "noopener" > XEP 54< / a > )< / li >
< li > Service discovery (< a href = "http://xmpp.org/extensions/xep-0030.html" target = "_blank" rel = "noopener" > XEP 30< / a > )< / li >
< li > In-band registration (< a href = "http://xmpp.org/extensions/xep-0077.html" target = "_blank" rel = "noopener" > XEP 77< / a > )< / li >
< li > Roster item exchange (< a href = "http://xmpp.org/extensions/xep-0144.html" target = "_blank" rel = "noopener" > XEP 144< / a > )< / li >
2014-05-06 21:19:35 +02:00
< li > Custom status messages< / li >
2017-07-05 13:02:36 +02:00
< li > Typing and chat state notifications (< a href = "http://xmpp.org/extensions/xep-0085.html" target = "_blank" rel = "noopener" > XEP 85< / a > )< / li >
2016-10-06 13:28:09 +02:00
< li > Desktop notifications< / li >
2017-07-05 13:02:36 +02:00
< li > Messages appear in all connected chat clients (< a href = "http://xmpp.org/extensions/xep-0280.html" target = "_blank" rel = "noopener" > XEP 280< / a > )< / li >
< li > Third person "/me" messages (< a href = "http://xmpp.org/extensions/xep-0245.html" target = "_blank" rel = "noopener" > XEP 245< / a > )< / li >
< li > XMPP Ping (< a href = "http://xmpp.org/extensions/xep-0199.html" target = "_blank" rel = "noopener" > XEP 199< / a > )< / li >
< li > Server-side archiving of messages (< a href = "http://xmpp.org/extensions/xep-0313.html" target = "_blank" rel = "noopener" > XEP 313< / a > )< / li >
< li > Client state indication (< a href = "http://xmpp.org/extensions/xep-0352.html" target = "_blank" rel = "noopener" > XEP 352< / a > )< / li >
2015-05-27 20:57:51 +02:00
< li > Off-the-record encryption< / li >
2017-07-05 13:02:36 +02:00
< li > Supports anonymous logins, see the < a href = "https://conversejs.org/demo/anonymous.html" target = "_blank" rel = "noopener" > anonymous login demo< / a > .< / li >
2015-05-29 10:07:40 +02:00
< li > Translated into 16 languages< / li >
2014-05-06 21:19:35 +02:00
< / ul >
2014-05-06 15:25:31 +02:00
< / div >
2014-05-06 21:19:35 +02:00
< div class = "col-lg-4" >
< section >
2014-05-07 08:04:32 +02:00
< span class = "feature-icon page-scroll" > < a class = "fa fa-video-camera" href = "#features" title = "Screencasts" > < / a > < / span >
2014-05-06 21:19:35 +02:00
< header >
< h2 > Screencasts< / h2 >
< / header >
< ul class = "screencasts" >
< li >
2017-07-05 13:02:36 +02:00
< a href = "https://opkode.com/blog/2012/07/30/instant-messaging-for-plone-with-javascript-and-xmpp" target = "_blank" rel = "noopener" >
2014-05-06 21:19:35 +02:00
In a Plone site
< / a >
< / li >
< li >
2017-07-05 13:02:36 +02:00
< a href = "http://opkode.com/media/blog/2013/04/02/converse.js-xmpp-instant-messaging-with-javascript" target = "_blank" rel = "noopener" >
2014-05-06 21:19:35 +02:00
Chatting with buddies from Jabber.org and Gmail
< / a >
< / li >
< li >
2017-07-05 13:02:36 +02:00
< a href = "https://opkode.com/media/blog/2013/11/11/conversejs-otr-support" target = "_blank" rel = "noopener" >
2014-05-06 21:19:35 +02:00
Off-the-record encryption
< / a >
< / li >
< / ul >
< / section >
< / div >
< / div >
< / div >
< / section >
2014-05-06 15:25:31 +02:00
2015-11-05 11:36:47 +01:00
< section class = "outro content-section text-center" id = "contact" >
2014-05-06 21:19:35 +02:00
< div class = "container" >
< div class = "row" >
< div class = "col-lg-8 col-lg-offset-2" >
2015-11-05 11:36:47 +01:00
< h2 > Contact< / h2 >
< ul class = "contact" >
2017-07-05 13:02:36 +02:00
< li > Follow me on < a href = "http://twitter.com/jcopkode" target = "_blank" rel = "noopener" > Twitter< / a > or chat with me via XMPP at < a href = "xmpp:jc@opkode.com" class = "xmpp JSnocheck" title = "XMPP/Jabber" > jc@opkode.com< / a > .< / li >
2016-12-08 13:02:24 +01:00
< li > For technical support, you can ask on < a href = "http://stackoverflow.com/questions/tagged/converse.js" > Stack Overflow< / a >
2017-07-06 17:32:27 +02:00
or if you have a more simple question you can ask in the Converse.js chat room:
< a href = "xmpp:discuss@conference.conversejs.org" class = "xmpp JSnocheck" title = "Converse.js chat room" > discuss@conference.conversejs.org< / a > .< / li >
< li > Please file bugs and feature requests on < a target = "_blank" rel = "noopener" href = "https://github.com/jcbrand/converse.js/issues" > Github< / a > .< / li >
2015-11-05 11:36:47 +01:00
< / ul >
2017-12-05 14:11:48 +01:00
< / div >
2017-07-06 17:32:27 +02:00
2017-12-05 14:11:48 +01:00
< div class = "col-lg-8 col-lg-offset-2" style = "margin-top: 4em; text-align: left" >
< h2 style = "text-align: center" > Professional support and custom development< / h2 >
2017-07-06 17:32:27 +02:00
< p >
I'm available for paid-for features, custom development and consulting.< br / >
However, please don't contact me personally for free support, use
the other channels mentioned above.< / br > < / br >
Here's my < a href = "http://opkode.com/contact" target = "_blank" rel = "noopener" > contact form< / a > .< / br >
< / p >
2014-05-06 21:19:35 +02:00
< / div >
2017-12-05 14:11:48 +01:00
< / div >
< / div >
< / section >
< section class = "outro content-section text-center" id = "sponsors" >
< div class = "container" >
< div class = "row" >
< div class = "col-lg-8 col-lg-offset-2" style = "margin-top: 3em" >
< div class = "sponsors" >
2018-01-02 15:02:31 +01:00
< h2 > Converse.js is supported by:< / h2 >
< ul >
< li > < a href = "https://www.keycdn.com/" target = "_blank" rel = "noopener" > < img style = "height: 2em" src = "/logo/keycdn.svg" alt = "KeyCDN" > < / a > < / li >
< li > < a href = "https://diasporing.ch" target = "_blank" rel = "noopener" > < img style = "height: 2em" src = "/logo/diasporing.svg" alt = "Diasporing.ch" > < / a > < / li >
< / ul >
2017-12-05 14:11:48 +01:00
< / div >
< p class = "sponsors-text" > Converse.js is a software commons; available at no cost to you and every other person on earth.
Sponsorships allow us to fund further development and improvements and are greatly appreciated.
2017-12-06 11:40:04 +01:00
If you'd like to sponsor this project, please visit < a href = "https://www.patreon.com/jcbrand" target = "_blank" rel = "noopener" > Patreon page< / a >
or < a href = "https://liberapay.com/jcbrand" target = "_blank" rel = "noopener" > Liberapay< / a >
< / p >
2016-05-23 21:21:42 +02:00
< / div >
2014-05-06 15:25:31 +02:00
< / div >
2014-05-06 21:19:35 +02:00
< / div >
< / section >
2014-05-06 15:25:31 +02:00
< / body >
2013-04-01 23:44:49 +02:00
2013-07-24 23:58:04 +02:00
< script >
2017-02-27 08:42:17 +01:00
converse.initialize({
// Please use this connection manager only for testing purposes
bosh_service_url: 'https://conversejs.org/http-bind/',
show_controlbox_by_default: true,
2013-07-24 23:58:04 +02:00
});
< / script >
2013-03-28 16:42:49 +01:00
< / html >