summaryrefslogtreecommitdiff
path: root/web-ui/src/common/logout
diff options
context:
space:
mode:
authorSriram Viswanathan <sriramv@thoughtworks.com>2017-03-22 16:26:50 -0300
committerSriram Viswanathan <sriramv@thoughtworks.com>2017-03-23 17:16:40 -0300
commitc56bf133feddfcfed9487c16229138fcdb046983 (patch)
tree44ebc2038d66c81b7b5a6911c3cd429cb7ef3ee1 /web-ui/src/common/logout
parentfc074ea9f9b7cd6708a5a878a7b56a4d76a9124e (diff)
|#973| Thais + Sriram | Adds logout component to be shown on the header
Diffstat (limited to 'web-ui/src/common/logout')
-rw-r--r--web-ui/src/common/logout/logout.js48
-rw-r--r--web-ui/src/common/logout/logout.spec.js49
2 files changed, 97 insertions, 0 deletions
diff --git a/web-ui/src/common/logout/logout.js b/web-ui/src/common/logout/logout.js
new file mode 100644
index 00000000..12db1067
--- /dev/null
+++ b/web-ui/src/common/logout/logout.js
@@ -0,0 +1,48 @@
+/*
+ * Copyright (c) 2017 ThoughtWorks, Inc.
+ *
+ * Pixelated is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * Pixelated is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with Pixelated. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+import React from 'react';
+import { translate } from 'react-i18next';
+import browser from 'helpers/browser';
+
+import SubmitFlatButton from 'src/common/flat_button/flat_button';
+
+export class Logout extends React.Component {
+
+ constructor(props) {
+ super(props);
+ this.state = { csrf_token: browser.getCookie('XSRF-TOKEN') };
+ }
+
+ render() {
+ const t = this.props.t;
+ return (
+ <div className='logout-container'>
+ <form id='logout-form' method='POST' action='logout'>
+ <input type='hidden' name='csrftoken' value={this.state.csrf_token} />
+ <SubmitFlatButton buttonText={t('logout')} fontIconClass='fa fa-sign-out' />
+ </form>
+ </div>
+ );
+ }
+}
+
+Logout.propTypes = {
+ t: React.PropTypes.func.isRequired
+};
+
+export default translate('', { wait: true })(Logout);
diff --git a/web-ui/src/common/logout/logout.spec.js b/web-ui/src/common/logout/logout.spec.js
new file mode 100644
index 00000000..ba228e61
--- /dev/null
+++ b/web-ui/src/common/logout/logout.spec.js
@@ -0,0 +1,49 @@
+import { shallow } from 'enzyme';
+import expect from 'expect';
+import React from 'react';
+import { Logout } from 'src/common/logout/logout';
+
+describe('Logout', () => {
+ let logout;
+
+ beforeEach(() => {
+ const mockTranslations = key => key;
+ logout = shallow(<Logout t={mockTranslations} fontIconClass='fa fa-sign-out' />);
+ });
+
+ it('renders the logout container', () => {
+ expect(logout.find('div.logout-container')).toExist();
+ });
+
+ describe('logout form', () => {
+ let logoutForm;
+
+ beforeEach(() => {
+ logoutForm = logout.find('form#logout-form');
+ });
+
+ it('renders logout form', () => {
+ expect(logoutForm).toExist();
+ });
+
+ it('renders logout form with POST method', () => {
+ expect(logoutForm.props().method).toEqual('POST');
+ });
+
+ it('renders logout form with action as logout', () => {
+ expect(logoutForm.props().action).toEqual('logout');
+ });
+
+ it('renders csrf hidden input', () => {
+ expect(logoutForm.find('input[name="csrftoken"]')).toExist();
+ });
+
+ it('renders SubmitFlatButton for logout', () => {
+ expect(logoutForm.find('SubmitFlatButton').props().buttonText).toEqual('logout');
+ });
+
+ it('renders SubmitFlatButton for logout with fontIcon', () => {
+ expect(logoutForm.find('SubmitFlatButton').props().fontIconClass).toEqual('fa fa-sign-out');
+ });
+ });
+});