forked from friendica/friendica-addons
Merge pull request #334 from annando/1601-converse-update
XMPP: Update to Converse 0.10.0
This commit is contained in:
commit
0249534f5d
7 changed files with 2115 additions and 1205 deletions
37
xmpp/converse/CONTRIBUTING.rst
Normal file
37
xmpp/converse/CONTRIBUTING.rst
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
=======================
|
||||||
|
Contribution Guidelines
|
||||||
|
=======================
|
||||||
|
|
||||||
|
Thanks for contributing to `Converse.js <http://conversejs.org>`_.
|
||||||
|
|
||||||
|
Support questions
|
||||||
|
=================
|
||||||
|
Please ask support and setup questions on the mailing list: conversejs@librelist.com
|
||||||
|
|
||||||
|
The issue tracker is only for bugs (i.e. issues) and feature requests.
|
||||||
|
|
||||||
|
Contributing Code
|
||||||
|
=================
|
||||||
|
Please follow the usual github workflow. Create your own local fork of this repository,
|
||||||
|
make your changes and then submit a pull request.
|
||||||
|
|
||||||
|
Before submitting a pull request
|
||||||
|
--------------------------------
|
||||||
|
|
||||||
|
Please read the `style guide <https://conversejs.org/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.
|
110
xmpp/converse/README.rst
Normal file
110
xmpp/converse/README.rst
Normal file
|
@ -0,0 +1,110 @@
|
||||||
|
===========
|
||||||
|
converse.js
|
||||||
|
===========
|
||||||
|
|
||||||
|
.. figure:: https://api.travis-ci.org/jcbrand/converse.js.png?branch=master
|
||||||
|
:alt: Build Status
|
||||||
|
|
||||||
|
`Converse.js <https://conversejs.org>`_ is a web based `XMPP/Jabber <http://xmpp.org>`_
|
||||||
|
instant messaging client.
|
||||||
|
|
||||||
|
It enables you to add chat functionality to your website, independent of any
|
||||||
|
specific backend. You will however need an XMPP server to connect to, either
|
||||||
|
your own, or a public one.
|
||||||
|
|
||||||
|
--------
|
||||||
|
Features
|
||||||
|
--------
|
||||||
|
|
||||||
|
It has the following features:
|
||||||
|
|
||||||
|
* Single-user chat
|
||||||
|
* Multi-user chat rooms `XEP 45 <http://xmpp.org/extensions/xep-0045.html>`_
|
||||||
|
* Direct invitations to chat rooms `XEP 249 <http://xmpp.org/extensions/xep-0249.html>`_
|
||||||
|
* vCard support `XEP 54 <http://xmpp.org/extensions/xep-0054.html>`_
|
||||||
|
* Service discovery `XEP 30 <http://xmpp.org/extensions/xep-0030.html>`_
|
||||||
|
* In-band registration `XEP 77 <http://xmpp.org/extensions/xep-0077.html>`_
|
||||||
|
* Contact rosters and groups
|
||||||
|
* Contact subscriptions
|
||||||
|
* Roster item exchange `XEP 144 <http://xmpp.org/extensions/tmp/xep-0144-1.1.html>`_
|
||||||
|
* Chat statuses (online, busy, away, offline)
|
||||||
|
* Custom status messages
|
||||||
|
* Typing and state notifications `XEP 85 <http://xmpp.org/extensions/xep-0085.html>`_
|
||||||
|
* Messages appear in all connnected chat clients `XEP 280 <http://xmpp.org/extensions/xep-0280.html>`_
|
||||||
|
* Third person "/me" messages `XEP 245 <http://xmpp.org/extensions/xep-0245.html>`_
|
||||||
|
* XMPP Ping `XEP 199 <http://xmpp.org/extensions/xep-0199.html>`_
|
||||||
|
* Server-side archiving of messages `XEP 313 <http://xmpp.org/extensions/xep-0313.html>`_
|
||||||
|
* Client state indication `XEP 352 <http://xmpp.org/extensions/xep-0352.html>`_
|
||||||
|
* Off-the-record encryption
|
||||||
|
* Translated into 16 languages
|
||||||
|
|
||||||
|
-----------
|
||||||
|
Screencasts
|
||||||
|
-----------
|
||||||
|
|
||||||
|
* `In a static HTML page`_. Here we chat to external XMPP accounts on Jabber.org and Gmail.
|
||||||
|
* `Integrated into a Plone site`_ via collective.xmpp.chat.
|
||||||
|
* `Off-the-record encryption <https://opkode.com/media/blog/2013/11/11/conversejs-otr-support>`_ in Converse 0.7.
|
||||||
|
|
||||||
|
Integration into other frameworks
|
||||||
|
---------------------------------
|
||||||
|
|
||||||
|
* `Plone <http://plone.org>`_:
|
||||||
|
`collective.xmpp.chat <http://github.com/collective/collective.xmpp.chat>`_ is an add-on for Plone that uses *Converse.js*. Together with `collective.xmpp.core <http://github.com/collective/collective.xmpp.core>`_, it provides for single-signon-support (SSO) and also enables you to manually or automatically register your Plone users onto your XMPP server.
|
||||||
|
* `Django <http://www.djangoproject.com>`_:
|
||||||
|
`django-conversejs <https://pypi.python.org/pypi/django-conversejs>`_ is an app that makes it easer to integrate *Converse.js* into Django.
|
||||||
|
`django-xmpp <https://github.com/fpytloun/django-xmpp>`_ adds XMPP chat integration with converse.js by letting Ejabberd authenticate against your Django site.
|
||||||
|
* `Roundcube <http://roundcube.net>`_:
|
||||||
|
`roundcube-converse.js-xmpp-plugin <https://github.com/priyadi/roundcube-converse.js-xmpp-plugin>`_ is a plugin for Roundcube Webmail.
|
||||||
|
* `Wordpress <http://wordpress.org>`_:
|
||||||
|
`ConverseJS <http://wordpress.org/plugins/conversejs>`_
|
||||||
|
* `Patternslib <http://patternslib.com>`_:
|
||||||
|
`patterns.converse <https://github.com/jcbrand/patterns.converse>`_ provides a Patternslib pattern for Converse.js
|
||||||
|
* `Alfresco <http://www.alfresco.com>`_:
|
||||||
|
`alfresco-js-chat-share`_: `alfresco-js-chat-share <https://github.com/keensoft/alfresco-js-chat-share>`_
|
||||||
|
|
||||||
|
----
|
||||||
|
Demo
|
||||||
|
----
|
||||||
|
|
||||||
|
A live demo is available at `<https://conversejs.org>`_
|
||||||
|
|
||||||
|
-----
|
||||||
|
Tests
|
||||||
|
-----
|
||||||
|
|
||||||
|
We use behavior-driven tests written with `jasmine.js <http://pivotal.github.io/jasmine>`_.
|
||||||
|
|
||||||
|
Open `tests.html <https://github.com/jcbrand/converse.js/blob/master/tests.html>`_
|
||||||
|
in your browser, and the tests will run automatically.
|
||||||
|
|
||||||
|
-------------
|
||||||
|
Documentation
|
||||||
|
-------------
|
||||||
|
|
||||||
|
The developer/integrator documentation can be found at `<https://conversejs.org/docs/html>`_.
|
||||||
|
|
||||||
|
-------
|
||||||
|
Licence
|
||||||
|
-------
|
||||||
|
|
||||||
|
``Converse.js`` is released under the `Mozilla Public License (MPL) <https://www.mozilla.org/MPL/2.0/index.txt>`_.
|
||||||
|
|
||||||
|
-------
|
||||||
|
Support
|
||||||
|
-------
|
||||||
|
|
||||||
|
For support queries and discussions, please join the mailing list: conversejs@librelist.com
|
||||||
|
|
||||||
|
Also take a look at the `mailing list archives <http://librelist.com/browser/conversejs>`_.
|
||||||
|
|
||||||
|
Issues can be logged on the `Github issue tracker <https://github.com/jcbrand/converse.js/issues>`_.
|
||||||
|
|
||||||
|
----------------------------------
|
||||||
|
Donations and tips are appreciated
|
||||||
|
----------------------------------
|
||||||
|
|
||||||
|
* Bitcoin: 16FsPqE9DhFTryxrUenpsGX4LJ1TPu8GqS
|
||||||
|
|
||||||
|
.. _`Integrated into a Plone site`: http://opkode.com/media/blog/instant-messaging-for-plone-with-javascript-and-xmpp
|
||||||
|
.. _`In a static HTML page`: http://opkode.com/media/blog/2013/04/02/converse.js-xmpp-instant-messaging-with-javascript
|
13
xmpp/converse/builds/converse.min.js
vendored
13
xmpp/converse/builds/converse.min.js
vendored
File diff suppressed because one or more lines are too long
|
@ -8,13 +8,13 @@ __p += '<div class="chat-message ' +
|
||||||
((__t = (extra_classes)) == null ? '' : __t) +
|
((__t = (extra_classes)) == null ? '' : __t) +
|
||||||
'" data-isodate="' +
|
'" data-isodate="' +
|
||||||
((__t = (isodate)) == null ? '' : __t) +
|
((__t = (isodate)) == null ? '' : __t) +
|
||||||
'">\n <span class="chat-message-' +
|
'">\n <span class="chat-msg-author chat-msg-' +
|
||||||
((__t = (sender)) == null ? '' : __t) +
|
((__t = (sender)) == null ? '' : __t) +
|
||||||
'">' +
|
'">' +
|
||||||
((__t = (time)) == null ? '' : __t) +
|
((__t = (time)) == null ? '' : __t) +
|
||||||
' **' +
|
' **' +
|
||||||
((__t = (username)) == null ? '' : __t) +
|
((__t = (username)) == null ? '' : __t) +
|
||||||
' </span>\n <span class="chat-message-content">' +
|
' </span>\n <span class="chat-msg-content">' +
|
||||||
((__t = (message)) == null ? '' : __t) +
|
((__t = (message)) == null ? '' : __t) +
|
||||||
'</span>\n</div>\n';
|
'</span>\n</div>\n';
|
||||||
|
|
||||||
|
@ -26,9 +26,9 @@ this["templates"]["add_contact_dropdown"] = function(obj) {
|
||||||
obj || (obj = {});
|
obj || (obj = {});
|
||||||
var __t, __p = '', __e = _.escape;
|
var __t, __p = '', __e = _.escape;
|
||||||
with (obj) {
|
with (obj) {
|
||||||
__p += '<dl class="add-converse-contact dropdown">\n <dt id="xmpp-contact-search" class="fancy-dropdown">\n <a class="toggle-xmpp-contact-form" href="#"\n title="' +
|
__p += '<dl class="add-converse-contact dropdown">\n <dt id="xmpp-contact-search" class="fancy-dropdown">\n <a class="toggle-xmpp-contact-form icon-plus" href="#" title="' +
|
||||||
((__t = (label_click_to_chat)) == null ? '' : __t) +
|
((__t = (label_click_to_chat)) == null ? '' : __t) +
|
||||||
'">\n <span class="icon-plus"></span>' +
|
'"> ' +
|
||||||
((__t = (label_add_contact)) == null ? '' : __t) +
|
((__t = (label_add_contact)) == null ? '' : __t) +
|
||||||
'</a>\n </dt>\n <dd class="search-xmpp" style="display:none"><ul></ul></dd>\n</dl>\n';
|
'</a>\n </dt>\n <dd class="search-xmpp" style="display:none"><ul></ul></dd>\n</dl>\n';
|
||||||
|
|
||||||
|
@ -40,9 +40,9 @@ this["templates"]["add_contact_form"] = function(obj) {
|
||||||
obj || (obj = {});
|
obj || (obj = {});
|
||||||
var __t, __p = '', __e = _.escape;
|
var __t, __p = '', __e = _.escape;
|
||||||
with (obj) {
|
with (obj) {
|
||||||
__p += '<li>\n <form class="add-xmpp-contact">\n <input type="text"\n name="identifier"\n class="username"\n placeholder="' +
|
__p += '<li>\n <form class="pure-form add-xmpp-contact">\n <input type="text"\n name="identifier"\n class="username"\n placeholder="' +
|
||||||
((__t = (label_contact_username)) == null ? '' : __t) +
|
((__t = (label_contact_username)) == null ? '' : __t) +
|
||||||
'"/>\n <button type="submit">' +
|
'"/>\n <button class="pure-button button-primary" type="submit">' +
|
||||||
((__t = (label_add)) == null ? '' : __t) +
|
((__t = (label_add)) == null ? '' : __t) +
|
||||||
'</button>\n </form>\n</li>\n';
|
'</button>\n </form>\n</li>\n';
|
||||||
|
|
||||||
|
@ -54,13 +54,13 @@ this["templates"]["change_status_message"] = function(obj) {
|
||||||
obj || (obj = {});
|
obj || (obj = {});
|
||||||
var __t, __p = '', __e = _.escape;
|
var __t, __p = '', __e = _.escape;
|
||||||
with (obj) {
|
with (obj) {
|
||||||
__p += '<form id="set-custom-xmpp-status">\n <span class="input-button-group">\n <input type="text" class="custom-xmpp-status" ' +
|
__p += '<form id="set-custom-xmpp-status" class="pure-form">\n<fieldset>\n <span class="input-button-group">\n <input type="text" class="custom-xmpp-status" ' +
|
||||||
((__t = (status_message)) == null ? '' : __t) +
|
((__t = (status_message)) == null ? '' : __t) +
|
||||||
'\n placeholder="' +
|
' placeholder="' +
|
||||||
((__t = (label_custom_status)) == null ? '' : __t) +
|
((__t = (label_custom_status)) == null ? '' : __t) +
|
||||||
'"/>\n <button type="submit">' +
|
'"/>\n <input type="submit" class="pure-button button-primary" value="' +
|
||||||
((__t = (label_save)) == null ? '' : __t) +
|
((__t = (label_save)) == null ? '' : __t) +
|
||||||
'</button>\n </span>\n</form>\n';
|
'"/>\n </span>\n</fieldset>\n</form>\n';
|
||||||
|
|
||||||
}
|
}
|
||||||
return __p
|
return __p
|
||||||
|
@ -72,15 +72,15 @@ var __t, __p = '', __e = _.escape;
|
||||||
with (obj) {
|
with (obj) {
|
||||||
__p += '<div class="xmpp-status">\n <a class="choose-xmpp-status ' +
|
__p += '<div class="xmpp-status">\n <a class="choose-xmpp-status ' +
|
||||||
((__t = (chat_status)) == null ? '' : __t) +
|
((__t = (chat_status)) == null ? '' : __t) +
|
||||||
'"\n data-value="' +
|
' icon-' +
|
||||||
((__t = (status_message)) == null ? '' : __t) +
|
|
||||||
'"\n href="#" title="' +
|
|
||||||
((__t = (desc_change_status)) == null ? '' : __t) +
|
|
||||||
'">\n\n <span class="icon-' +
|
|
||||||
((__t = (chat_status)) == null ? '' : __t) +
|
((__t = (chat_status)) == null ? '' : __t) +
|
||||||
'"></span>' +
|
'" data-value="' +
|
||||||
((__t = (status_message)) == null ? '' : __t) +
|
((__t = (status_message)) == null ? '' : __t) +
|
||||||
'\n </a>\n <a class="change-xmpp-status-message icon-pencil"\n href="#"\n title="' +
|
'" href="#" title="' +
|
||||||
|
((__t = (desc_change_status)) == null ? '' : __t) +
|
||||||
|
'">\n ' +
|
||||||
|
((__t = (status_message)) == null ? '' : __t) +
|
||||||
|
'\n </a>\n <a class="change-xmpp-status-message icon-pencil" href="#" title="' +
|
||||||
((__t = (desc_custom_status)) == null ? '' : __t) +
|
((__t = (desc_custom_status)) == null ? '' : __t) +
|
||||||
'"></a>\n</div>\n';
|
'"></a>\n</div>\n';
|
||||||
|
|
||||||
|
@ -110,13 +110,11 @@ obj || (obj = {});
|
||||||
var __t, __p = '', __e = _.escape, __j = Array.prototype.join;
|
var __t, __p = '', __e = _.escape, __j = Array.prototype.join;
|
||||||
function print() { __p += __j.call(arguments, '') }
|
function print() { __p += __j.call(arguments, '') }
|
||||||
with (obj) {
|
with (obj) {
|
||||||
__p += '<div class="box-flyout" ';
|
__p += '<div class="flyout box-flyout">\n <div class="dragresize dragresize-top"></div>\n <div class="dragresize dragresize-topleft"></div>\n <div class="dragresize dragresize-left"></div>\n <div class="chat-head chat-head-chatbox">\n <a class="chatbox-btn close-chatbox-button icon-close" title="' +
|
||||||
if (height) { ;
|
((__t = (info_close)) == null ? '' : __t) +
|
||||||
__p += ' style="height: ' +
|
'"></a>\n <a class="chatbox-btn toggle-chatbox-button icon-minus" title="' +
|
||||||
((__t = (height)) == null ? '' : __t) +
|
((__t = (info_minimize)) == null ? '' : __t) +
|
||||||
'px" ';
|
'"></a>\n <div class="chat-title">\n ';
|
||||||
} ;
|
|
||||||
__p += '>\n <div class="dragresize"></div>\n <div class="chat-head chat-head-chatbox">\n <a class="close-chatbox-button icon-close"></a>\n <a class="toggle-chatbox-button icon-minus"></a>\n <div class="chat-title">\n ';
|
|
||||||
if (url) { ;
|
if (url) { ;
|
||||||
__p += '\n <a href="' +
|
__p += '\n <a href="' +
|
||||||
((__t = (url)) == null ? '' : __t) +
|
((__t = (url)) == null ? '' : __t) +
|
||||||
|
@ -142,18 +140,21 @@ return __p
|
||||||
|
|
||||||
this["templates"]["chatroom"] = function(obj) {
|
this["templates"]["chatroom"] = function(obj) {
|
||||||
obj || (obj = {});
|
obj || (obj = {});
|
||||||
var __t, __p = '', __e = _.escape, __j = Array.prototype.join;
|
var __t, __p = '', __e = _.escape;
|
||||||
function print() { __p += __j.call(arguments, '') }
|
|
||||||
with (obj) {
|
with (obj) {
|
||||||
__p += '<div class="box-flyout" ';
|
__p += '<div class="flyout box-flyout">\n <div class="dragresize dragresize-top"></div>\n <div class="dragresize dragresize-topleft"></div>\n <div class="dragresize dragresize-left"></div>\n <div class="chat-head chat-head-chatroom">\n <a class="chatbox-btn close-chatbox-button icon-close"></a>\n <a class="chatbox-btn toggle-chatbox-button icon-minus"></a>\n <a class="chatbox-btn configure-chatroom-button icon-wrench" style="display:none"></a>\n <div class="chat-title"> ' +
|
||||||
if (height) { ;
|
|
||||||
__p += ' style="height: ' +
|
|
||||||
((__t = (height)) == null ? '' : __t) +
|
|
||||||
'px" ';
|
|
||||||
} ;
|
|
||||||
__p += '>\n <div class="dragresize"></div>\n <div class="chat-head chat-head-chatroom">\n <a class="close-chatbox-button icon-close"></a>\n <a class="toggle-chatbox-button icon-minus"></a>\n <a class="configure-chatroom-button icon-wrench" style="display:none"></a>\n <div class="chat-title"> ' +
|
|
||||||
((__t = ( _.escape(name) )) == null ? '' : __t) +
|
((__t = ( _.escape(name) )) == null ? '' : __t) +
|
||||||
' </div>\n <p class="chatroom-topic"><p/>\n </div>\n <div class="chat-body"><span class="spinner centered"/></div>\n</div>\n';
|
' </div>\n <p class="chatroom-topic"><p/>\n </div>\n <div class="chat-body chatroom-body"><span class="spinner centered"/></div>\n</div>\n';
|
||||||
|
|
||||||
|
}
|
||||||
|
return __p
|
||||||
|
};
|
||||||
|
|
||||||
|
this["templates"]["chatroom_form"] = function(obj) {
|
||||||
|
obj || (obj = {});
|
||||||
|
var __t, __p = '', __e = _.escape;
|
||||||
|
with (obj) {
|
||||||
|
__p += '<div class="chatroom-form-container">\n <form class="pure-form pure-form-stacked converse-form chatroom-form">\n <fieldset>\n <span class="spinner centered"/>\n </fieldset>\n </form>\n</div>\n';
|
||||||
|
|
||||||
}
|
}
|
||||||
return __p
|
return __p
|
||||||
|
@ -163,13 +164,13 @@ this["templates"]["chatroom_password_form"] = function(obj) {
|
||||||
obj || (obj = {});
|
obj || (obj = {});
|
||||||
var __t, __p = '', __e = _.escape;
|
var __t, __p = '', __e = _.escape;
|
||||||
with (obj) {
|
with (obj) {
|
||||||
__p += '<div class="chatroom-form-container">\n <form class="chatroom-form">\n <legend>' +
|
__p += '<div class="chatroom-form-container">\n <form class="pure-form converse-form chatroom-form">\n <fieldset>\n <legend>' +
|
||||||
((__t = (heading)) == null ? '' : __t) +
|
((__t = (heading)) == null ? '' : __t) +
|
||||||
'</legend>\n <label>' +
|
'</legend>\n <label>' +
|
||||||
((__t = (label_password)) == null ? '' : __t) +
|
((__t = (label_password)) == null ? '' : __t) +
|
||||||
'</label>\n <input type="password" name="password"/>\n <input type="submit" value="' +
|
'</label>\n <input type="password" name="password"/>\n </fieldset>\n <fieldset>\n <input class="pure-button button-primary" type="submit" value="' +
|
||||||
((__t = (label_submit)) == null ? '' : __t) +
|
((__t = (label_submit)) == null ? '' : __t) +
|
||||||
'"/>\n </form>\n</div>\n';
|
'"/>\n </fieldset>\n </form>\n</div>\n';
|
||||||
|
|
||||||
}
|
}
|
||||||
return __p
|
return __p
|
||||||
|
@ -179,11 +180,11 @@ this["templates"]["chatroom_sidebar"] = function(obj) {
|
||||||
obj || (obj = {});
|
obj || (obj = {});
|
||||||
var __t, __p = '', __e = _.escape;
|
var __t, __p = '', __e = _.escape;
|
||||||
with (obj) {
|
with (obj) {
|
||||||
__p += '<!-- <div class="participants"> -->\n<form class="room-invite">\n <input class="invited-contact" placeholder="' +
|
__p += '<!-- <div class="occupants"> -->\n<form class="pure-form room-invite">\n <input class="invited-contact" placeholder="' +
|
||||||
((__t = (label_invitation)) == null ? '' : __t) +
|
((__t = (label_invitation)) == null ? '' : __t) +
|
||||||
'" type="text"/>\n</form>\n<label>' +
|
'" type="text"/>\n</form>\n<p class="occupants-heading">' +
|
||||||
((__t = (label_occupants)) == null ? '' : __t) +
|
((__t = (label_occupants)) == null ? '' : __t) +
|
||||||
':</label>\n<ul class="participant-list"></ul>\n<!-- </div> -->\n';
|
':</p>\n<ul class="occupant-list"></ul>\n<!-- </div> -->\n';
|
||||||
|
|
||||||
}
|
}
|
||||||
return __p
|
return __p
|
||||||
|
@ -205,7 +206,7 @@ this["templates"]["chats_panel"] = function(obj) {
|
||||||
obj || (obj = {});
|
obj || (obj = {});
|
||||||
var __t, __p = '', __e = _.escape;
|
var __t, __p = '', __e = _.escape;
|
||||||
with (obj) {
|
with (obj) {
|
||||||
__p += '<div id="minimized-chats">\n <a id="toggle-minimized-chats" href="#"></a>\n <div class="minimized-chats-flyout"></div>\n</div>\n';
|
__p += '<div id="minimized-chats">\n <a id="toggle-minimized-chats" href="#"></a>\n <div class="flyout minimized-chats-flyout"></div>\n</div>\n';
|
||||||
|
|
||||||
}
|
}
|
||||||
return __p
|
return __p
|
||||||
|
@ -226,7 +227,7 @@ obj || (obj = {});
|
||||||
var __t, __p = '', __e = _.escape, __j = Array.prototype.join;
|
var __t, __p = '', __e = _.escape, __j = Array.prototype.join;
|
||||||
function print() { __p += __j.call(arguments, '') }
|
function print() { __p += __j.call(arguments, '') }
|
||||||
with (obj) {
|
with (obj) {
|
||||||
__p += '<form class="set-xmpp-status" action="" method="post">\n <span id="xmpp-status-holder">\n <select id="select-xmpp-status" style="display:none">\n <option value="online">' +
|
__p += '<form class="pure-form set-xmpp-status" action="" method="post">\n <span id="xmpp-status-holder">\n <select id="select-xmpp-status" style="display:none">\n <option value="online">' +
|
||||||
((__t = (label_online)) == null ? '' : __t) +
|
((__t = (label_online)) == null ? '' : __t) +
|
||||||
'</option>\n <option value="dnd">' +
|
'</option>\n <option value="dnd">' +
|
||||||
((__t = (label_busy)) == null ? '' : __t) +
|
((__t = (label_busy)) == null ? '' : __t) +
|
||||||
|
@ -260,16 +261,9 @@ return __p
|
||||||
|
|
||||||
this["templates"]["controlbox"] = function(obj) {
|
this["templates"]["controlbox"] = function(obj) {
|
||||||
obj || (obj = {});
|
obj || (obj = {});
|
||||||
var __t, __p = '', __e = _.escape, __j = Array.prototype.join;
|
var __t, __p = '', __e = _.escape;
|
||||||
function print() { __p += __j.call(arguments, '') }
|
|
||||||
with (obj) {
|
with (obj) {
|
||||||
__p += '<div class="box-flyout" ';
|
__p += '<div class="flyout box-flyout">\n <div class="dragresize dragresize-top"></div>\n <div class="dragresize dragresize-topleft"></div>\n <div class="dragresize dragresize-left"></div>\n <div class="chat-head controlbox-head">\n <ul id="controlbox-tabs"></ul>\n <a class="chatbox-btn close-chatbox-button icon-close"></a>\n </div>\n <div class="controlbox-panes"></div>\n</div>\n';
|
||||||
if (height) { ;
|
|
||||||
__p += ' style="height: ' +
|
|
||||||
((__t = (height)) == null ? '' : __t) +
|
|
||||||
'px" ';
|
|
||||||
} ;
|
|
||||||
__p += '>\n <div class="dragresize"></div>\n <div class="chat-head controlbox-head">\n <ul id="controlbox-tabs"></ul>\n <a class="close-chatbox-button icon-close"></a>\n </div>\n <div class="controlbox-panes"></div>\n</div>\n';
|
|
||||||
|
|
||||||
}
|
}
|
||||||
return __p
|
return __p
|
||||||
|
@ -495,7 +489,7 @@ obj || (obj = {});
|
||||||
var __t, __p = '', __e = _.escape, __j = Array.prototype.join;
|
var __t, __p = '', __e = _.escape, __j = Array.prototype.join;
|
||||||
function print() { __p += __j.call(arguments, '') }
|
function print() { __p += __j.call(arguments, '') }
|
||||||
with (obj) {
|
with (obj) {
|
||||||
__p += '<form id="converse-login" method="post">\n ';
|
__p += '<form class="pure-form pure-form-stacked converse-form" id="converse-login" method="post">\n ';
|
||||||
if (auto_login) { ;
|
if (auto_login) { ;
|
||||||
__p += '\n <span class="spinner login-submit"/>\n ';
|
__p += '\n <span class="spinner login-submit"/>\n ';
|
||||||
} ;
|
} ;
|
||||||
|
@ -505,19 +499,19 @@ __p += '\n ';
|
||||||
if (authentication == LOGIN) { ;
|
if (authentication == LOGIN) { ;
|
||||||
__p += '\n <label>' +
|
__p += '\n <label>' +
|
||||||
((__t = (label_username)) == null ? '' : __t) +
|
((__t = (label_username)) == null ? '' : __t) +
|
||||||
'</label>\n <input name="jid" placeholder="' +
|
'</label>\n <input type="text" name="jid" placeholder="' +
|
||||||
((__t = (placeholder_username)) == null ? '' : __t) +
|
((__t = (placeholder_username)) == null ? '' : __t) +
|
||||||
'">\n <label>' +
|
'">\n <label>' +
|
||||||
((__t = (label_password)) == null ? '' : __t) +
|
((__t = (label_password)) == null ? '' : __t) +
|
||||||
'</label>\n <input type="password" name="password" placeholder="' +
|
'</label>\n <input type="password" name="password" placeholder="' +
|
||||||
((__t = (placeholder_password)) == null ? '' : __t) +
|
((__t = (placeholder_password)) == null ? '' : __t) +
|
||||||
'">\n <input class="submit" type="submit" value="' +
|
'">\n <input class="pure-button button-primary" type="submit" value="' +
|
||||||
((__t = (label_login)) == null ? '' : __t) +
|
((__t = (label_login)) == null ? '' : __t) +
|
||||||
'">\n <span class="conn-feedback"></span>\n ';
|
'">\n <span class="conn-feedback"></span>\n ';
|
||||||
} ;
|
} ;
|
||||||
__p += '\n ';
|
__p += '\n ';
|
||||||
if (authentication == ANONYMOUS) { ;
|
if (authentication == ANONYMOUS) { ;
|
||||||
__p += '\n <input type="submit" class="submit login-anon" value="' +
|
__p += '\n <input type="pure-button button-primary" class="submit login-anon" value="' +
|
||||||
((__t = (label_anon_login)) == null ? '' : __t) +
|
((__t = (label_anon_login)) == null ? '' : __t) +
|
||||||
'"/>\n ';
|
'"/>\n ';
|
||||||
} ;
|
} ;
|
||||||
|
@ -555,13 +549,13 @@ __p += '<div class="chat-message ' +
|
||||||
((__t = (isodate)) == null ? '' : __t) +
|
((__t = (isodate)) == null ? '' : __t) +
|
||||||
'" data-msgid="' +
|
'" data-msgid="' +
|
||||||
((__t = (msgid)) == null ? '' : __t) +
|
((__t = (msgid)) == null ? '' : __t) +
|
||||||
'">\n <span class="chat-message-' +
|
'">\n <span class="chat-msg-author chat-msg-' +
|
||||||
((__t = (sender)) == null ? '' : __t) +
|
((__t = (sender)) == null ? '' : __t) +
|
||||||
'">' +
|
'">' +
|
||||||
((__t = (time)) == null ? '' : __t) +
|
((__t = (time)) == null ? '' : __t) +
|
||||||
' ' +
|
' ' +
|
||||||
((__t = (username)) == null ? '' : __t) +
|
((__t = (username)) == null ? '' : __t) +
|
||||||
': </span>\n <span class="chat-message-content">' +
|
': </span>\n <span class="chat-msg-content">' +
|
||||||
((__t = (message)) == null ? '' : __t) +
|
((__t = (message)) == null ? '' : __t) +
|
||||||
'</span>\n</div>\n';
|
'</span>\n</div>\n';
|
||||||
|
|
||||||
|
@ -573,7 +567,7 @@ this["templates"]["new_day"] = function(obj) {
|
||||||
obj || (obj = {});
|
obj || (obj = {});
|
||||||
var __t, __p = '', __e = _.escape;
|
var __t, __p = '', __e = _.escape;
|
||||||
with (obj) {
|
with (obj) {
|
||||||
__p += '<time class="chat-date" data-isodate="' +
|
__p += '<time class="chat-info chat-date" data-isodate="' +
|
||||||
((__t = (isodate)) == null ? '' : __t) +
|
((__t = (isodate)) == null ? '' : __t) +
|
||||||
'">' +
|
'">' +
|
||||||
((__t = (datestring)) == null ? '' : __t) +
|
((__t = (datestring)) == null ? '' : __t) +
|
||||||
|
@ -597,9 +591,9 @@ __p += '\n title="' +
|
||||||
'"\n ';
|
'"\n ';
|
||||||
} ;
|
} ;
|
||||||
__p += '\n ';
|
__p += '\n ';
|
||||||
if (role === "participant") { ;
|
if (role === "occupant") { ;
|
||||||
__p += '\n title="' +
|
__p += '\n title="' +
|
||||||
((__t = (desc_participant)) == null ? '' : __t) +
|
((__t = (desc_occupant)) == null ? '' : __t) +
|
||||||
'"\n ';
|
'"\n ';
|
||||||
} ;
|
} ;
|
||||||
__p += '\n ';
|
__p += '\n ';
|
||||||
|
@ -647,7 +641,7 @@ this["templates"]["pending_contacts"] = function(obj) {
|
||||||
obj || (obj = {});
|
obj || (obj = {});
|
||||||
var __t, __p = '', __e = _.escape;
|
var __t, __p = '', __e = _.escape;
|
||||||
with (obj) {
|
with (obj) {
|
||||||
__p += '<dt id="pending-xmpp-contacts"><a href="#" class="group-toggle icon-' +
|
__p += '<dt class="roster-group" id="pending-xmpp-contacts"><a href="#" class="group-toggle icon-' +
|
||||||
((__t = (toggle_state)) == null ? '' : __t) +
|
((__t = (toggle_state)) == null ? '' : __t) +
|
||||||
'" title="' +
|
'" title="' +
|
||||||
((__t = (desc_group_toggle)) == null ? '' : __t) +
|
((__t = (desc_group_toggle)) == null ? '' : __t) +
|
||||||
|
@ -663,7 +657,7 @@ this["templates"]["register_panel"] = function(obj) {
|
||||||
obj || (obj = {});
|
obj || (obj = {});
|
||||||
var __t, __p = '', __e = _.escape;
|
var __t, __p = '', __e = _.escape;
|
||||||
with (obj) {
|
with (obj) {
|
||||||
__p += '<form id="converse-register">\n <span class="reg-feedback"></span>\n <label>' +
|
__p += '<form id="converse-register" class="pure-form converse-form">\n <span class="reg-feedback"></span>\n <label>' +
|
||||||
((__t = (label_domain)) == null ? '' : __t) +
|
((__t = (label_domain)) == null ? '' : __t) +
|
||||||
'</label>\n <input type="text" name="domain" placeholder="' +
|
'</label>\n <input type="text" name="domain" placeholder="' +
|
||||||
((__t = (domain_placeholder)) == null ? '' : __t) +
|
((__t = (domain_placeholder)) == null ? '' : __t) +
|
||||||
|
@ -673,7 +667,7 @@ __p += '<form id="converse-register">\n <span class="reg-feedback"></span>\n
|
||||||
((__t = (href_providers)) == null ? '' : __t) +
|
((__t = (href_providers)) == null ? '' : __t) +
|
||||||
'" class="url" target="_blank">' +
|
'" class="url" target="_blank">' +
|
||||||
((__t = (help_providers_link)) == null ? '' : __t) +
|
((__t = (help_providers_link)) == null ? '' : __t) +
|
||||||
'</a>.</p>\n <input class="submit" type="submit" value="' +
|
'</a>.</p>\n <input class="pure-button button-primary" type="submit" value="' +
|
||||||
((__t = (label_register)) == null ? '' : __t) +
|
((__t = (label_register)) == null ? '' : __t) +
|
||||||
'">\n</form>\n';
|
'">\n</form>\n';
|
||||||
|
|
||||||
|
@ -719,7 +713,7 @@ var __t, __p = '', __e = _.escape;
|
||||||
with (obj) {
|
with (obj) {
|
||||||
__p += '<span class="spinner login-submit"/>\n<p class="info">' +
|
__p += '<span class="spinner login-submit"/>\n<p class="info">' +
|
||||||
((__t = (info_message)) == null ? '' : __t) +
|
((__t = (info_message)) == null ? '' : __t) +
|
||||||
'</p>\n<button class="cancel hor_centered">' +
|
'</p>\n<button class="pure-button button-cancel hor_centered">' +
|
||||||
((__t = (cancel)) == null ? '' : __t) +
|
((__t = (cancel)) == null ? '' : __t) +
|
||||||
'</button>\n';
|
'</button>\n';
|
||||||
|
|
||||||
|
@ -760,7 +754,7 @@ this["templates"]["requesting_contacts"] = function(obj) {
|
||||||
obj || (obj = {});
|
obj || (obj = {});
|
||||||
var __t, __p = '', __e = _.escape;
|
var __t, __p = '', __e = _.escape;
|
||||||
with (obj) {
|
with (obj) {
|
||||||
__p += '<dt id="xmpp-contact-requests"><a href="#" class="group-toggle icon-' +
|
__p += '<dt class="roster-group" id="xmpp-contact-requests"><a href="#" class="group-toggle icon-' +
|
||||||
((__t = (toggle_state)) == null ? '' : __t) +
|
((__t = (toggle_state)) == null ? '' : __t) +
|
||||||
'" title="' +
|
'" title="' +
|
||||||
((__t = (desc_group_toggle)) == null ? '' : __t) +
|
((__t = (desc_group_toggle)) == null ? '' : __t) +
|
||||||
|
@ -884,15 +878,17 @@ obj || (obj = {});
|
||||||
var __t, __p = '', __e = _.escape, __j = Array.prototype.join;
|
var __t, __p = '', __e = _.escape, __j = Array.prototype.join;
|
||||||
function print() { __p += __j.call(arguments, '') }
|
function print() { __p += __j.call(arguments, '') }
|
||||||
with (obj) {
|
with (obj) {
|
||||||
__p += '<form class="add-chatroom" action="" method="post">\n <label>' +
|
__p += '<form class="pure-form pure-form-stacked converse-form add-chatroom" action="" method="post">\n <fieldset>\n <label>' +
|
||||||
((__t = (label_room_name)) == null ? '' : __t) +
|
((__t = (label_room_name)) == null ? '' : __t) +
|
||||||
'</label>\n <input type="text" name="chatroom" class="new-chatroom-name"\n placeholder="' +
|
'</label>\n <input type="text" name="chatroom" class="new-chatroom-name" placeholder="' +
|
||||||
((__t = (label_room_name)) == null ? '' : __t) +
|
((__t = (label_room_name)) == null ? '' : __t) +
|
||||||
'"/>\n <label>' +
|
'"/>\n <label>' +
|
||||||
((__t = (label_nickname)) == null ? '' : __t) +
|
((__t = (label_nickname)) == null ? '' : __t) +
|
||||||
'</label>\n <input type="text" name="nick" class="new-chatroom-nick"\n placeholder="' +
|
'</label> <input type="text" name="nick" class="new-chatroom-nick" placeholder="' +
|
||||||
((__t = (label_nickname)) == null ? '' : __t) +
|
((__t = (label_nickname)) == null ? '' : __t) +
|
||||||
'"/>\n ';
|
'"/>\n <input type="submit" class="pure-button button-primary" name="join" value="' +
|
||||||
|
((__t = (label_join)) == null ? '' : __t) +
|
||||||
|
'"/>\n </fieldset>\n <fieldset>\n ';
|
||||||
if (server_input_type != 'hidden') { ;
|
if (server_input_type != 'hidden') { ;
|
||||||
__p += '\n <label' +
|
__p += '\n <label' +
|
||||||
((__t = (server_label_global_attr)) == null ? '' : __t) +
|
((__t = (server_label_global_attr)) == null ? '' : __t) +
|
||||||
|
@ -902,13 +898,11 @@ __p += '\n <label' +
|
||||||
} ;
|
} ;
|
||||||
__p += '\n <input type="' +
|
__p += '\n <input type="' +
|
||||||
((__t = (server_input_type)) == null ? '' : __t) +
|
((__t = (server_input_type)) == null ? '' : __t) +
|
||||||
'" name="server" class="new-chatroom-server"\n placeholder="' +
|
'" name="server" class="new-chatroom-server" placeholder="' +
|
||||||
((__t = (label_server)) == null ? '' : __t) +
|
((__t = (label_server)) == null ? '' : __t) +
|
||||||
'"/>\n <div class="button-group">\n <input type="submit" class="left" name="join" value="' +
|
'"/>\n <input type="button" class="pure-button button-secondary" name="show" id="show-rooms" value="' +
|
||||||
((__t = (label_join)) == null ? '' : __t) +
|
|
||||||
'"/>\n <input type="button" class="right" name="show" id="show-rooms" value="' +
|
|
||||||
((__t = (label_show_rooms)) == null ? '' : __t) +
|
((__t = (label_show_rooms)) == null ? '' : __t) +
|
||||||
'"/>\n </div>\n</form>\n<dl id="available-chatrooms"></dl>\n';
|
'"/>\n </fieldset>\n</form>\n<dl id="available-chatrooms"></dl>\n';
|
||||||
|
|
||||||
}
|
}
|
||||||
return __p
|
return __p
|
||||||
|
@ -918,13 +912,13 @@ this["templates"]["roster"] = function(obj) {
|
||||||
obj || (obj = {});
|
obj || (obj = {});
|
||||||
var __t, __p = '', __e = _.escape;
|
var __t, __p = '', __e = _.escape;
|
||||||
with (obj) {
|
with (obj) {
|
||||||
__p += '<span class="input-button-group">\n <input style="display: none;" class="roster-filter" placeholder="' +
|
__p += '<form class="pure-form roster-filter-group input-button-group">\n <input style="display: none;" class="roster-filter" placeholder="' +
|
||||||
((__t = (placeholder)) == null ? '' : __t) +
|
((__t = (placeholder)) == null ? '' : __t) +
|
||||||
'">\n <select style="display: none;" class="filter-type">\n <option value="contacts">' +
|
'">\n <select style="display: none;" class="filter-type">\n <option value="contacts">' +
|
||||||
((__t = (label_contacts)) == null ? '' : __t) +
|
((__t = (label_contacts)) == null ? '' : __t) +
|
||||||
'</option>\n <option value="groups">' +
|
'</option>\n <option value="groups">' +
|
||||||
((__t = (label_groups)) == null ? '' : __t) +
|
((__t = (label_groups)) == null ? '' : __t) +
|
||||||
'</option>\n </select>\n</span>\n';
|
'</option>\n </select>\n</form>\n';
|
||||||
|
|
||||||
}
|
}
|
||||||
return __p
|
return __p
|
||||||
|
@ -1051,9 +1045,9 @@ __p += '\n<li class="toggle-call"><a class="icon-phone" title="' +
|
||||||
'"></a></li>\n';
|
'"></a></li>\n';
|
||||||
} ;
|
} ;
|
||||||
__p += '\n';
|
__p += '\n';
|
||||||
if (show_participants_toggle) { ;
|
if (show_occupants_toggle) { ;
|
||||||
__p += '\n<li class="toggle-participants"><a class="icon-hide-users" title="' +
|
__p += '\n<li class="toggle-occupants"><a class="icon-hide-users" title="' +
|
||||||
((__t = (label_hide_participants)) == null ? '' : __t) +
|
((__t = (label_hide_occupants)) == null ? '' : __t) +
|
||||||
'"></a></li>\n';
|
'"></a></li>\n';
|
||||||
} ;
|
} ;
|
||||||
__p += '\n';
|
__p += '\n';
|
||||||
|
@ -1123,7 +1117,7 @@ obj || (obj = {});
|
||||||
var __t, __p = '', __e = _.escape, __j = Array.prototype.join;
|
var __t, __p = '', __e = _.escape, __j = Array.prototype.join;
|
||||||
function print() { __p += __j.call(arguments, '') }
|
function print() { __p += __j.call(arguments, '') }
|
||||||
with (obj) {
|
with (obj) {
|
||||||
__p += '<a class="close-chatbox-button icon-close"></a>\n<a class="chat-head-message-count" \n ';
|
__p += '<a class="chatbox-btn close-chatbox-button icon-close"></a>\n<a class="chat-head-message-count" \n ';
|
||||||
if (!num_unread) { ;
|
if (!num_unread) { ;
|
||||||
__p += ' style="display: none" ';
|
__p += ' style="display: none" ';
|
||||||
} ;
|
} ;
|
||||||
|
@ -1138,3 +1132,19 @@ __p += '\n href="#">' +
|
||||||
}
|
}
|
||||||
return __p
|
return __p
|
||||||
};
|
};
|
||||||
|
|
||||||
|
this["templates"]["vcard"] = function(obj) {
|
||||||
|
obj || (obj = {});
|
||||||
|
var __t, __p = '', __e = _.escape;
|
||||||
|
with (obj) {
|
||||||
|
__p += '<form class="pure-form converse-form vcard-info">\n <fieldset>\n <legend>The VCard info gets rendered here</legend>\n <label>Full name:</label>\n ' +
|
||||||
|
((__t = (fullname)) == null ? '' : __t) +
|
||||||
|
'\n <label>URL:</label>\n ' +
|
||||||
|
((__t = (url)) == null ? '' : __t) +
|
||||||
|
'\n </fieldset>\n <fieldset>\n <input type="button" class="pure-button button-cancel" value="' +
|
||||||
|
((__t = (label_return)) == null ? '' : __t) +
|
||||||
|
'"/>\n </fieldset>\n</form>\n';
|
||||||
|
|
||||||
|
}
|
||||||
|
return __p
|
||||||
|
};
|
File diff suppressed because it is too large
Load diff
24
xmpp/converse/css/converse.min.css
vendored
24
xmpp/converse/css/converse.min.css
vendored
File diff suppressed because one or more lines are too long
|
@ -103,12 +103,17 @@ a:focus {
|
||||||
border-bottom: 1px solid rgba(255, 255, 255, 0.3);
|
border-bottom: 1px solid rgba(255, 255, 255, 0.3);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@media (max-width: 480px) {
|
||||||
|
.navbar {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
.features-section,
|
.features-section,
|
||||||
.outro,
|
.outro,
|
||||||
.intro {
|
.intro {
|
||||||
display: table;
|
|
||||||
width: 100%;
|
width: 100%;
|
||||||
height: 100%;
|
|
||||||
padding: 100px 0;
|
padding: 100px 0;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
color: #fff;
|
color: #fff;
|
||||||
|
@ -130,12 +135,10 @@ a:focus {
|
||||||
.outro {
|
.outro {
|
||||||
background: url('images/bgtr.svg') top right no-repeat, url('images/bgbl.svg') bottom left no-repeat, url('images/overlay.png'), linear-gradient(45deg, #384955, #655361, #85505f);
|
background: url('images/bgtr.svg') top right no-repeat, url('images/bgbl.svg') bottom left no-repeat, url('images/overlay.png'), linear-gradient(45deg, #384955, #655361, #85505f);
|
||||||
}
|
}
|
||||||
.intro-body {
|
|
||||||
display: table-cell;
|
|
||||||
vertical-align: middle;
|
|
||||||
}
|
|
||||||
.brand-heading {
|
.brand-heading {
|
||||||
font-size: 40px;
|
font-size: 2em;
|
||||||
|
text-align: center;
|
||||||
|
margin-top: 3em;
|
||||||
}
|
}
|
||||||
.intro-text {
|
.intro-text {
|
||||||
font-size: 18px;
|
font-size: 18px;
|
||||||
|
@ -146,7 +149,7 @@ a:focus {
|
||||||
padding: 0;
|
padding: 0;
|
||||||
}
|
}
|
||||||
.brand-heading {
|
.brand-heading {
|
||||||
font-size: 100px;
|
font-size: 80px;
|
||||||
}
|
}
|
||||||
.intro-text {
|
.intro-text {
|
||||||
font-size: 25px;
|
font-size: 25px;
|
||||||
|
@ -264,24 +267,7 @@ a:focus {
|
||||||
font-size: 26px;
|
font-size: 26px;
|
||||||
}
|
}
|
||||||
.banner-social-buttons {
|
.banner-social-buttons {
|
||||||
position: absolute;
|
padding-top: 7em;
|
||||||
bottom: 4em;
|
|
||||||
left: 0;
|
|
||||||
}
|
|
||||||
@media (max-width: 1199px) {
|
|
||||||
ul.banner-social-buttons {
|
|
||||||
margin-top: 15px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@media (max-width: 767px) {
|
|
||||||
ul.banner-social-buttons > li {
|
|
||||||
display: block;
|
|
||||||
margin-bottom: 20px;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
ul.banner-social-buttons > li:last-child {
|
|
||||||
margin-bottom: 0;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
::-moz-selection {
|
::-moz-selection {
|
||||||
text-shadow: none;
|
text-shadow: none;
|
||||||
|
@ -349,3 +335,7 @@ ul.features {
|
||||||
background: white;
|
background: white;
|
||||||
margin-left: -0.5px;
|
margin-left: -0.5px;
|
||||||
}
|
}
|
||||||
|
.row {
|
||||||
|
margin-left: 0;
|
||||||
|
margin-right: 0;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue