No Description

JC Brand c9ab828bd0 Add converse-clickable-image component 5 years ago
.github c9830c91b2 Fix funding links 6 years ago
converse-logs d7a113e081 Fix transcripts code. 7 years ago
demo cd60614f88 Release 6.0.0 5 years ago
docs 2af93f4492 modtools: settings for which roles/affiliations may be queried or assigned 5 years ago
images 2d57f6c889 Make sure `webfonts` dir is copied over 5 years ago
locale ad4c6dd60c Generate new pot and po files 5 years ago
logo e691d858e3 Add version number and sized images to manifest.json 5 years ago
mockup a116a1ec8f Fix various website CSS issues. Re-add images 6 years ago
sass 366dee0aa5 Bugfix. Allow moderators to retract their own messages 5 years ago
sounds 1d2b4c4523 Add sound file credits 11 years ago
spec c9f29f76e5 Use lit-html to render URLs 5 years ago
src c9ab828bd0 Add converse-clickable-image component 5 years ago
tests a7f28cd61d When creating message objects, wait for confirmation from storage 5 years ago
.eslintrc.json 2ac33c77b3 Fix linting errors 5 years ago
.gitignore 9a7dd99889 Ensure python 3.7 is used for sphinx and bump lerna version 6 years ago
.nvmrc a8104d7498 Add Skeletor as dependency 5 years ago
.prettierrc 01fce55733 Add prettierx and tentatively use it for some formatting 6 years ago
.travis.yml 7b11d85503 Add support for XEP-0198 Stream Management 6 years ago
CHANGES.md a6aaf3f595 Update chat state notifications when message is edited. 5 years ago
COPYRIGHT cd60614f88 Release 6.0.0 5 years ago
LICENSE 9008a1d4d4 Move license to repo root 7 years ago
Makefile e691d858e3 Add version number and sized images to manifest.json 5 years ago
README.md 0082c0ce60 More visual README for users 5 years ago
RELEASE.md e866248227 Don't include vim temp-files in release tarball 5 years ago
buildout.cfg 1194467f82 Bump docutils to 0.15.2 6 years ago
composer.json b7ae9f212c Replace http: with https: in conversejs.org links 6 years ago
dev.html 17e9f5607d Set meta and noscript tags 5 years ago
fullscreen.html 17e9f5607d Set meta and noscript tags 5 years ago
index.html 17e9f5607d Set meta and noscript tags 5 years ago
jshintrc f353fe8611 Bugfix for headline messages. 9 years ago
jslicenses.html cd60614f88 Release 6.0.0 5 years ago
lerna.json 18024b8bd2 Store lerna packages in the `src` directory 6 years ago
manifest.json e691d858e3 Add version number and sized images to manifest.json 5 years ago
mobile.html cd60614f88 Release 6.0.0 5 years ago
package-lock.json e691d858e3 Add version number and sized images to manifest.json 5 years ago
package.json e691d858e3 Add version number and sized images to manifest.json 5 years ago
postcss.config.js 9ae71104c2 webpack: split css out into separate file 5 years ago
redirect.html 48adc04740 Fix path to converse.css and add some mockup fixes 6 years ago
requirements.txt fa2d6cca10 Update developer documentation and buildout dependencies 6 years ago
webpack.common.js bcbde04530 Copy sounds dir to dist and use `assets_path` for `sounds_path` 5 years ago
webpack.dev.js e691d858e3 Add version number and sized images to manifest.json 5 years ago
webpack.headless.js 916e300a79 Updates #1313 and #1793: Send button improvements 5 years ago
webpack.html 2af93f4492 modtools: settings for which roles/affiliations may be queried or assigned 5 years ago
webpack.nodeps.js 976c3d6006 Remove the formdata and promise polyfills 5 years ago
webpack.prod.js e691d858e3 Add version number and sized images to manifest.json 5 years ago
webpack.serve.js e6e23a1a82 Add initial support for custom emojis 5 years ago

README.md

Converse

XMPP Chat Travis Bountysource bounties Translation status

Converse is a web based XMPP/Jabber chat client.

You can either use it as a webchat app, or you can integrate it into your own website.

It's 100% client-side JavaScript, HTML and CSS and the only backend required is a modern XMPP server.

Please support this project via Patreon or Liberapay

Demo

Converse is hosted and can be used at https://conversejs.org.

A demo showing anonymous login is available at https://conversejs.org/demo/anonymous.html and a demo which shows how you can embed a single chat room into a page is avialable at https://conversejs.org/demo/embedded.html.

Documentation

The developer/integrator documentation can be found at https://conversejs.org/docs/html.

You'll probably want to begin with the quickstart guide, which shows you how to use the CDN (content delivery network) to quickly get a demo up and running.

Converse modes

Overlay

In overlay mode, Converse appears overlayed chats on top of the website.

Screenshot of Converse in overlay mode

Fullpage

In fullpage mode, Converse behaves like a single-page app that covers the whole browser viewport.

Screenshot of Converse in fullpage mode

Embedded

In embedded mode, Converse can be embedded into an element in the DOM.

Screenshot of Converse in embedded mode

Features

  • Available as overlayed chat boxes or as a fullscreen application. See inverse.chat for the fullscreen version.
  • Custom status messages
  • Desktop notifications
  • A plugin architecture based on pluggable.js
  • Multi-user chat rooms XEP 45
  • Chatroom bookmarks XEP 48
  • Direct invitations to chat rooms XEP 249
  • vCard support XEP 54
  • Service discovery XEP 30
  • In-band registration XEP 77
  • Roster item exchange XEP 144
  • Chat statuses (online, busy, away, offline)
  • Typing and state notifications XEP 85
  • File sharing / HTTP File Upload XEP 363
  • Messages appear in all connnected chat clients / Message Carbons XEP 280
  • Third person "/me" messages XEP 245
  • XMPP Ping XEP 199
  • Server-side archiving of messages XEP 313
  • Hidden Messages (aka Spoilers) XEP 382
  • Client state indication XEP 352
  • Last Message Correction XEP 308
  • OMEMO encrypted messaging XEP 384
  • Anonymous logins, see the anonymous login demo
  • Message Retractions XEP-424
  • Message Moderation XEP-425
  • Translated into over 30 languages

Integration into other servers and frameworks

Tests

We use behavior-driven tests written with jasmine.js.

Open tests.html in your browser, and the tests will run automatically.

Licence

Converse.js is released under the Mozilla Public License (MPL).

Attribution

Emoji images are courtesy of Twemoji.

Support

Issues can be logged on the Github issue tracker.

Donations

A heartfelt thanks for everyone who has supported this project over the years. Many people have contributed testing, bugfixes, features and corrections.

We accept donations via Patreon and Liberapay.