Browse Source

sign in modal (but no tests for it yet)

Rafał Pitoń 9 years ago
parent
commit
867a036b88
45 changed files with 41725 additions and 282 deletions
  1. 2 1
      frontend/.babelrc
  2. 1 0
      frontend/.jshintrc
  3. 5 4
      frontend/gulpfile.js
  4. 5 0
      frontend/package.json
  5. 28 0
      frontend/src/components/avatar.js
  6. 49 0
      frontend/src/components/banned-page.js
  7. 7 4
      frontend/src/components/button.js
  8. 98 0
      frontend/src/components/form.js
  9. 2 4
      frontend/src/components/loader.js
  10. 2 2
      frontend/src/components/register/root.js
  11. 146 0
      frontend/src/components/sign-in.js
  12. 0 68
      frontend/src/components/sign-in/root.js
  13. 9 7
      frontend/src/components/snackbar.js
  14. 50 2
      frontend/src/components/user-menu/guest-nav.js
  15. 13 1
      frontend/src/components/user-menu/root.js
  16. 11 0
      frontend/src/initializers/ajax.js
  17. 15 0
      frontend/src/initializers/mobile-navbar-dropdown.js
  18. 11 0
      frontend/src/initializers/moment-locale.js
  19. 13 0
      frontend/src/initializers/tick-reducer.js
  20. 17 0
      frontend/src/initializers/tick-start.js
  21. 2 1
      frontend/src/initializers/user-menu-component.js
  22. 21 0
      frontend/src/reducers/tick.js
  23. 25 0
      frontend/src/services/mobile-navbar-dropdown.js
  24. 28 0
      frontend/src/services/snackbar.js
  25. 134 0
      frontend/src/test-setup.js
  26. 33 0
      frontend/src/utils/banned-page.js
  27. 100 0
      frontend/src/utils/validators.js
  28. 0 14
      frontend/src/vendor-tests.js
  29. 16 9
      frontend/style/misago/buttons.less
  30. 31 144
      frontend/style/misago/loaders.less
  31. 42 0
      frontend/tests/components/avatar.js
  32. 78 0
      frontend/tests/components/button.js
  33. 22 0
      frontend/tests/components/loader.js
  34. 1 6
      frontend/tests/components/snackbar.js
  35. 44 0
      frontend/tests/components/user-menu/guest-menu.js
  36. 105 0
      frontend/tests/modal.js
  37. 69 0
      frontend/tests/navbar-dropdown.js
  38. 96 0
      frontend/tests/validators.js
  39. 4612 1
      misago/static/misago/css/misago.css
  40. BIN
      misago/static/misago/img/site-icon.png
  41. BIN
      misago/static/misago/img/site-logo.png
  42. 2466 2
      misago/static/misago/js/misago.js
  43. 33312 10
      misago/static/misago/js/vendor.js
  44. 1 1
      misago/templates/misago/navbar.html
  45. 3 1
      misago/users/models/ban.py

+ 2 - 1
frontend/.babelrc

@@ -3,6 +3,7 @@
   "plugins": [
     ["babel-plugin-module-alias", [
       { "src": "./src", "expose": "misago" }
-    ]]
+    ]],
+    "transform-class-properties"
   ]
 }

+ 1 - 0
frontend/.jshintrc

@@ -2,6 +2,7 @@
   "undef": true,
   "unused": true,
   "esnext": true,
+  
   "predef": [
     "global",
     "console",

+ 5 - 4
frontend/gulpfile.js

@@ -51,8 +51,6 @@ function getSources() {
   };
 
   include('src/initializers/*.js');
-  include('src/components/*.js');
-  include('src/components/**/root.js');
 
   return sources.map(function(path) {
     return path;
@@ -70,6 +68,7 @@ gulp.task('fastsource', ['lintsource'], function() {
       entries: getSources(),
       debug: true
     })
+    .external('moment')
     .external('react')
     .external('react-dom')
     .external('redux')
@@ -88,6 +87,7 @@ gulp.task('source', ['lintsource'], function() {
       entries: getSources(),
       debug: false
     })
+    .external('moment')
     .external('react')
     .external('react-dom')
     .external('redux')
@@ -155,6 +155,7 @@ gulp.task('fastvendorsources', function() {
       debug: true
     })
     .transform('browserify-shim')
+    .require('moment')
     .require('react')
     .require('react-dom')
     .require('redux')
@@ -172,6 +173,7 @@ gulp.task('vendorsources', function() {
       entries: 'src/vendor.js',
       debug: false
     })
+    .require('moment')
     .require('react')
     .require('react-dom')
     .require('redux')
@@ -196,8 +198,7 @@ gulp.task('linttests', function() {
 
 gulp.task('test', ['linttests', 'lintsource'], function() {
   var mochify = require('mochify');
-  mochify('tests/**/*.js')
-    .add('src/vendor-tests.js')
+  mochify('src/test-setup.js tests/**/*.js')
     .transform(babelify)
     .bundle();
 });

+ 5 - 0
frontend/package.json

@@ -22,6 +22,7 @@
   "dependencies": {
     "babel": "^6.3.13",
     "babel-plugin-module-alias": "^1.0.0",
+    "babel-plugin-transform-class-properties": "^6.3.13",
     "babel-polyfill": "^6.3.14",
     "babel-preset-es2015": "^6.1.18",
     "babel-preset-react": "^6.1.18",
@@ -44,8 +45,12 @@
     "gulp-uglify": "^1.5.1",
     "jquery": "^2.1.4",
     "jquery-mockjax": "^2.0.1",
+    "moment": "^2.10.6",
     "react": "^0.14.3",
+    "react-addons-test-utils": "^0.14.5",
     "react-dom": "^0.14.3",
+    "react-redux": "^4.0.6",
+    "redux": "^3.0.5",
     "vinyl-buffer": "^1.0.0",
     "vinyl-source-stream": "^1.1.0"
   },

+ 28 - 0
frontend/src/components/avatar.js

@@ -0,0 +1,28 @@
+import React from 'react';
+
+const BASE_URL = $('base').attr('href') + 'user-avatar/';
+
+export default class extends React.Component {
+  getSrc() {
+    let size = this.props.size || 100; // jshint ignore:line
+    let url = BASE_URL;
+
+    if (this.props.user && this.props.user.id) {
+      // just avatar hash, size and user id
+      url += this.props.user.avatar_hash + '/' + size + '/' + this.props.user.id + '.png';
+    } else {
+      // just append avatar size to file to produce no-avatar placeholder
+      url += size + '.png';
+    }
+
+    return url;
+  }
+
+  render() {
+    /* jshint ignore:start */
+    return <img src={this.getSrc()}
+                className={this.props.className || 'user-avatar'}
+                title={gettext("User avatar")}/>;
+    /* jshint ignore:end */
+  }
+}

+ 49 - 0
frontend/src/components/banned-page.js

@@ -0,0 +1,49 @@
+import moment from 'moment';
+import React from 'react';
+
+export default class extends React.Component {
+  getReasonMessage() {
+    /* jshint ignore:start */
+    if (this.props.message.html) {
+      return <div className="lead"
+                  dangerouslySetInnerHTML={{__html: this.props.message.html}} />;
+    } else {
+      return <p className="lead">{this.props.message.plain}</p>;
+    }
+    /* jshint ignore:end */
+  }
+
+  getExpirationMessage() {
+    if (this.props.expires) {
+      if (this.props.expires.isAfter(moment())) {
+        return interpolate(
+          gettext('This ban expires %(expires_on)s.'),
+          {'expires_on': this.props.expires.fromNow()},
+          true);
+      } else {
+        return gettext('This ban has expired.');
+      }
+    } else {
+      return gettext('This ban is permanent.');
+    }
+  }
+
+  render() {
+    /* jshint ignore:start */
+    return <div className="page page-error page-error-baned">
+      <div className="container">
+        <div className="message-panel">
+
+          <div className="message-icon">
+            <span className="material-icon">highlight_off</span>
+          </div>
+          <div className="message-body">
+            {this.getReasonMessage()}
+            <p>{this.getExpirationMessage()}</p>
+          </div>
+        </div>
+      </div>
+    </div>;
+    /* jshint ignore:end */
+  }
+}

+ 7 - 4
frontend/src/components/button.js

@@ -4,20 +4,23 @@ import Loader from 'misago/components/loader'; // jshint ignore:line
 export default class Button extends React.Component {
   render() {
     let content = null;
+    let className = 'btn ' + this.props.className;
+    let disabled = this.props.disabled;
+
     if (this.props.loading) {
       /* jshint ignore:start */
       content = <Loader />;
       /* jshint ignore:end */
+      className += ' btn-loading';
+      disabled = true;
     } else {
       content = this.props.children;
     }
 
     /* jshint ignore:start */
-    let className = 'btn ' + this.props.className;
-
-    return <button type={this.props.type}
+    return <button type={this.props.onClick ? 'button' : 'submit'}
                    className={className}
-                   disabled={this.props.disabled}
+                   disabled={disabled}
                    onClick={this.props.onClick}>
       {content}
     </button>;

+ 98 - 0
frontend/src/components/form.js

@@ -0,0 +1,98 @@
+import React from 'react';
+import { required } from 'misago/utils/validators';
+
+export default class extends React.Component {
+  validate() {
+    let isValid = true;
+    let errors = {};
+
+    for (var key in this.state.validators) {
+      if (this.state.validators.hasOwnProperty(key)) {
+        let value = this.state[key];
+        errors[key] = this.validateField(value, this.state.validators[key]);
+        if (errors[key] !== null) {
+          isValid = false;
+        }
+      }
+    }
+
+    return isValid ? null : errors;
+  }
+
+  validateField(value, validators) {
+    let result = required()(value);
+    let errors = [];
+
+    if (result) {
+      return [result];
+    } else {
+      for (let i in validators) {
+        result = validators[i](value);
+        if (result) {
+          errors.push(result);
+        }
+      }
+    }
+
+    return errors.length ? errors : null;
+  }
+
+  changeValue(name, value) {
+    let errors = null;
+    if (this.state.validators.name) {
+      errors = this.validateField(name, value);
+    }
+  }
+
+  /* jshint ignore:start */
+  bindInput = (name) => {
+    return (event) => {
+      let newState = {};
+      newState[name] = event.target.value;
+      this.setState(newState);
+    }
+  }
+
+  clean() {
+    return true;
+  }
+
+  send() {
+    return null;
+  }
+
+  handleSuccess(success) {
+    return;
+  }
+
+  handleError(rejection) {
+    return;
+  }
+
+  handleSubmit = (event) => {
+    // we don't reload page on submissions
+    event.preventDefault();
+
+    if (this.state.isLoading) {
+      return;
+    }
+
+    if (this.clean()) {
+      this.setState({'isLoading': true});
+      let promise = this.send();
+
+      if (promise) {
+        promise.then((success) => {
+          this.handleSuccess(success);
+          this.setState({'isLoading': false});
+        }, (rejection) => {
+          this.handleError(rejection);
+          this.setState({'isLoading': false});
+        });
+      } else {
+        this.setState({'isLoading': false});
+      }
+    }
+  }
+  /* jshint ignore:end */
+}

+ 2 - 4
frontend/src/components/loader.js

@@ -1,12 +1,10 @@
 import React from 'react';
 
-export default class Loader extends React.Component {
+export default class extends React.Component {
   render() {
     /* jshint ignore:start */
     return <div className="loader-compact">
-      <div className="bounce1"></div>
-      <div className="bounce2"></div>
-      <div className="bounce3"></div>
+      <div className="loader-spinning-wheel"></div>
     </div>;
     /* jshint ignore:end */
   }

+ 2 - 2
frontend/src/components/register/root.js

@@ -1,9 +1,9 @@
 import React from 'react';
 
-export default class RegisterModal extends React.Component {
+export default class extends React.Component {
   render() {
     /* jshint ignore:start */
-    return <div className="modal-dialog">
+    return <div className="modal-dialog modal-register">
       <div className="modal-content">
         <div className="modal-header">
           <button type="button" className="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>

+ 146 - 0
frontend/src/components/sign-in.js

@@ -0,0 +1,146 @@
+import React from 'react'; // jshint ignore:line
+import misago from 'misago/index';
+import Button from 'misago/components/button'; // jshint ignore:line
+import Form from 'misago/components/form';
+import ajax from 'misago/services/ajax';
+import modal from 'misago/services/modal';
+import snackbar from 'misago/services/snackbar';
+import showBannedPage from 'misago/utils/banned-page';
+
+export default class extends Form {
+  constructor(props) {
+    super(props);
+
+    this.state = {
+      'isLoading': false,
+      'showActivation': false,
+
+      'username': '',
+      'password': '',
+
+      validators: {
+        'username': [],
+        'password': []
+      }
+    };
+  }
+
+  clean() {
+    if (this.validate()) {
+      snackbar.error(gettext("Fill out both fields."));
+      return false;
+    } else {
+      return true;
+    }
+  }
+
+  send() {
+    return ajax.post(misago.get('AUTH_API'), {
+      'username': this.state.username,
+      'password': this.state.password
+    });
+  }
+
+  handleSuccess() {
+    modal.hide();
+
+    let form = $('#hidden-login-form');
+
+    form.append('<input type="text" name="username" />');
+    form.append('<input type="password" name="password" />');
+
+    // fill out form with user credentials and submit it, this will tell
+    // Misago to redirect user back to right page, and will trigger browser's
+    // key ring feature
+    form.find('input[type="hidden"]').val(ajax.getCsrfToken());
+    form.find('input[name="redirect_to"]').val(window.location.pathname);
+    form.find('input[name="username"]').val(this.state.username);
+    form.find('input[name="password"]').val(this.state.password);
+    form.submit();
+  }
+
+  handleError(rejection) {
+    if (rejection.status === 400) {
+      if (rejection.code === 'inactive_admin') {
+        snackbar.info(rejection.detail);
+      } else if (rejection.code === 'inactive_user') {
+        snackbar.info(rejection.detail);
+        this.setState({
+          'showActivation': true
+        });
+      } else if (rejection.code === 'banned') {
+        showBannedPage(rejection.detail);
+        modal.hide();
+      } else {
+        snackbar.error(rejection.detail);
+      }
+    } else {
+      snackbar.apiError(rejection);
+    }
+  }
+
+  getActivationButton() {
+    if (this.state.showActivation) {
+      /* jshint ignore:start */
+      return <a href={misago.get('REQUEST_ACTIVATION_URL')}
+                className="btn btn-success btn-block">
+         {gettext("Activate account")}
+      </a>;
+      /* jshint ignore:end */
+    } else {
+      return null;
+    }
+  }
+
+  render() {
+    /* jshint ignore:start */
+    return <div className="modal-dialog modal-sm modal-sign-in">
+      <div className="modal-content">
+        <div className="modal-header">
+          <button type="button" className="close" data-dismiss="modal"
+                  aria-label={gettext("Close")}>
+            <span aria-hidden="true">&times;</span>
+          </button>
+          <h4 className="modal-title">{gettext("Sign in")}</h4>
+        </div>
+        <form onSubmit={this.handleSubmit}>
+          <div className="modal-body">
+
+            <div className="form-group">
+              <div className="control-input">
+                <input id="id_username" className="form-control" type="text"
+                       disabled={this.state.isLoading}
+                       placeholder={gettext("Username or e-mail")}
+                       onChange={this.bindInput('username')}
+                       value={this.state.username} />
+              </div>
+            </div>
+
+            <div className="form-group">
+              <div className="control-input">
+                <input id="id_password" className="form-control" type="password"
+                       disabled={this.state.isLoading}
+                       placeholder={gettext("Password")}
+                       onChange={this.bindInput('password')}
+                       value={this.state.password} />
+              </div>
+            </div>
+
+          </div>
+          <div className="modal-footer">
+            {this.getActivationButton()}
+            <Button className="btn-primary btn-block"
+                    loading={this.state.isLoading}>
+              {gettext("Sign in")}
+            </Button>
+            <a href={misago.get('FORGOTTEN_PASSWORD_URL')}
+               className="btn btn-default btn-block">
+               {gettext("Forgot password?")}
+            </a>
+          </div>
+        </form>
+      </div>
+    </div>;
+    /* jshint ignore:end */
+  }
+}

+ 0 - 68
frontend/src/components/sign-in/root.js

@@ -1,68 +0,0 @@
-import React from 'react';
-import snackbar from 'misago/services/snackbar';
-
-export default class SignInModal extends React.Component {
-  info() {
-    snackbar.info('Lorem ipsum dolor met');
-  }
-
-  success() {
-    snackbar.success('Lorem ipsum dolor met');
-  }
-
-  warning() {
-    snackbar.warning('Lorem ipsum dolor met');
-  }
-
-  error() {
-    snackbar.error('Lorem ipsum dolor met');
-  }
-
-  render() {
-    /* jshint ignore:start */
-    return <div className="modal-dialog">
-      <div className="modal-content">
-        <div className="modal-header">
-          <button type="button" className="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
-          <h4 className="modal-title">{gettext("Sign in")}</h4>
-        </div>
-        <div className="modal-body">
-          <p>This will be sign in form!</p>
-          <button type="button"
-                  className="btn btn-primary"
-                  onClick={this.info}>
-            Test info alert
-          </button>
-
-          <br />
-
-          <button type="button"
-                  className="btn btn-success"
-                  onClick={this.success}>
-            Test success alert
-          </button>
-
-          <br />
-
-          <button type="button"
-                  className="btn btn-warning"
-                  onClick={this.warning}>
-            Test warning alert
-          </button>
-
-          <br />
-
-          <button type="button"
-                  className="btn btn-danger"
-                  onClick={this.error}>
-            Test error alert
-          </button>
-        </div>
-        <div className="modal-footer">
-          <button type="button" className="btn btn-default" data-dismiss="modal">Close</button>
-        </div>
-      </div>
-    </div>;
-    /* jshint ignore:end */
-  }
-}

+ 9 - 7
frontend/src/components/snackbar.js

@@ -1,27 +1,29 @@
 import React from 'react';
 
+/* jshint ignore:start */
 const TYPES_CLASSES = {
   'info': 'alert-info',
   'success': 'alert-success',
   'warning': 'alert-warning',
   'error': 'alert-danger'
 };
+/* jshint ignore:end */
 
 export class Snackbar extends React.Component {
-  render() {
-    var typeClass = 'alert ' + TYPES_CLASSES[this.props.type]; // jshint ignore:line
-
-    var snackbarClass = 'alerts-snackbar';
-
+  getSnackbarClass() {
+    let snackbarClass = 'alerts-snackbar';
     if (this.props.isVisible) {
       snackbarClass += ' in';
     } else {
       snackbarClass += ' out';
     }
+    return snackbarClass;
+  }
 
+  render() {
     /* jshint ignore:start */
-    return <div className={snackbarClass}>
-      <p className={typeClass}>
+    return <div className={this.getSnackbarClass()}>
+      <p className={'alert ' + TYPES_CLASSES[this.props.type]}>
         {this.props.message}
       </p>
     </div>;

+ 50 - 2
frontend/src/components/user-menu/guest-nav.js

@@ -2,10 +2,12 @@ import React from 'react';
 import Button from 'misago/components/button'; // jshint ignore:line
 
 import modal from 'misago/services/modal';
-import SignInModal from 'misago/components/sign-in/root.js';
+import dropdown from 'misago/services/mobile-navbar-dropdown';
+import Avatar from 'misago/components/avatar'; // jshint ignore:line
+import SignInModal from 'misago/components/sign-in.js';
 import RegisterModal from 'misago/components/register/root.js';
 
-export default class GuestNav extends React.Component {
+export class GuestMenu extends React.Component {
   showSignInModal() {
     modal.show(SignInModal);
   }
@@ -16,6 +18,38 @@ export default class GuestNav extends React.Component {
 
   render() {
     /* jshint ignore:start */
+    return <ul className="dropdown-menu user-dropdown dropdown-menu-right"
+               role="menu">
+      <li className="guest-preview">
+        <h4>{gettext("You are browsing as guest.")}</h4>
+        <p>
+          {gettext('Sign in or register to start and participate in discussions.')}
+        </p>
+        <div className="row">
+
+          <div className="col-xs-6">
+            <button type="button" className="btn btn-default btn-block">
+              Thy Sign In
+            </button>
+
+          </div>
+          <div className="col-xs-6">
+
+            <button type="button" className="btn btn-primary btn-block">
+              Thy Registry
+            </button>
+
+          </div>
+        </div>
+      </li>
+    </ul>;
+    /* jshint ignore:end */
+  }
+}
+
+export class GuestNav extends GuestMenu {
+  render() {
+    /* jshint ignore:start */
     return <div className="nav nav-guest">
       <Button type="button"
               className="navbar-btn btn-default"
@@ -31,3 +65,17 @@ export default class GuestNav extends React.Component {
     /* jshint ignore:end */
   }
 }
+
+export class CompactGuestNav extends React.Component {
+  showGuestMenu() {
+    dropdown.show(GuestMenu);
+  }
+
+  render() {
+    /* jshint ignore:start */
+    return <button type="button" onClick={this.showGuestMenu}>
+      <Avatar size="64" />
+    </button>;
+    /* jshint ignore:end */
+  }
+}

+ 13 - 1
frontend/src/components/user-menu/root.js

@@ -1,5 +1,5 @@
 import React from 'react';
-import GuestNav from 'misago/components/user-menu/guest-nav'; // jshint ignore:line
+import { GuestNav, CompactGuestNav } from 'misago/components/user-menu/guest-nav'; // jshint ignore:line
 import UserNav from 'misago/components/user-menu/user-nav'; // jshint ignore:line
 
 export class UserMenu extends React.Component {
@@ -14,6 +14,18 @@ export class UserMenu extends React.Component {
   }
 }
 
+export class CompactUserMenu extends React.Component {
+  render() {
+    /* jshint ignore:start */
+    if (this.props.isAuthenticated) {
+      return <UserNav user={this.props.user} />;
+    } else {
+      return <CompactGuestNav />;
+    }
+    /* jshint ignore:end */
+  }
+}
+
 export function select(state) {
   return state.auth;
 }

+ 11 - 0
frontend/src/initializers/ajax.js

@@ -0,0 +1,11 @@
+import misago from 'misago/index';
+import ajax from 'misago/services/ajax';
+
+export default function initializer() {
+  ajax.init(misago.get('CSRF_COOKIE_NAME'));
+}
+
+misago.addInitializer({
+  name: 'ajax',
+  initializer: initializer
+});

+ 15 - 0
frontend/src/initializers/mobile-navbar-dropdown.js

@@ -0,0 +1,15 @@
+import misago from 'misago/index';
+import dropdown from 'misago/services/mobile-navbar-dropdown';
+
+export default function initializer() {
+  let element = document.getElementById('mobile-navbar-dropdown-mount');
+  if (element) {
+    dropdown.init(element);
+  }
+}
+
+misago.addInitializer({
+  name: 'dropdown',
+  initializer: initializer,
+  before: 'store'
+});

+ 11 - 0
frontend/src/initializers/moment-locale.js

@@ -0,0 +1,11 @@
+import moment from 'moment';
+import misago from 'misago/index';
+
+export default function initializer() {
+  moment.locale($('html').attr('lang'));
+}
+
+misago.addInitializer({
+  name: 'moment',
+  initializer: initializer
+});

+ 13 - 0
frontend/src/initializers/tick-reducer.js

@@ -0,0 +1,13 @@
+import misago from 'misago/index';
+import reducer, { initialState } from 'misago/reducers/tick';
+import store from 'misago/services/store';
+
+export default function initializer() {
+  store.addReducer('tick', reducer, initialState);
+}
+
+misago.addInitializer({
+  name: 'reducer:tick',
+  initializer: initializer,
+  before: 'store'
+});

+ 17 - 0
frontend/src/initializers/tick-start.js

@@ -0,0 +1,17 @@
+import misago from 'misago/index';
+import { doTick } from 'misago/reducers/tick';
+import store from 'misago/services/store';
+
+const TICK_PERIOD = 50 * 1000; //do the tick every 50s
+
+export default function initializer() {
+  window.setInterval(function() {
+    store.dispatch(doTick());
+  }, TICK_PERIOD);
+}
+
+misago.addInitializer({
+  name: 'tick-start',
+  initializer: initializer,
+  after: 'store'
+});

+ 2 - 1
frontend/src/initializers/user-menu-component.js

@@ -1,10 +1,11 @@
 import { connect } from 'react-redux';
 import misago from 'misago/index';
-import { UserMenu, select } from 'misago/components/user-menu/root';
+import { UserMenu, CompactUserMenu, select } from 'misago/components/user-menu/root';
 import mount from 'misago/utils/mount-component';
 
 export default function initializer() {
   mount(connect(select)(UserMenu), 'user-menu-mount');
+  mount(connect(select)(CompactUserMenu), 'user-menu-compact-mount');
 }
 
 misago.addInitializer({

+ 21 - 0
frontend/src/reducers/tick.js

@@ -0,0 +1,21 @@
+export var initialState = {
+  tick: 0
+};
+
+export const TICK = 'TICK';
+
+export function doTick() {
+  return {
+    type: TICK
+  };
+}
+
+export default function tick(state=initialState, action=null) {
+  if (action.type === TICK) {
+    return Object.assign({}, state, {
+        tick: state.tick + 1
+    });
+  } else {
+    return state;
+  }
+}

+ 25 - 0
frontend/src/services/mobile-navbar-dropdown.js

@@ -0,0 +1,25 @@
+import mount from 'misago/utils/mount-component';
+
+export class MobileNavbarDropdown {
+  init(element) {
+    this._element = element;
+    this._component = null;
+  }
+
+  show(component) {
+    if (this._component === component) {
+      this.hide();
+    } else {
+      this._component = component;
+      mount(component, this._element.id);
+      $(this._element).addClass('open');
+    }
+  }
+
+  hide() {
+    $(this._element).removeClass('open');
+    this._component = null;
+  }
+}
+
+export default new MobileNavbarDropdown();

+ 28 - 0
frontend/src/services/snackbar.js

@@ -28,6 +28,7 @@ export class Snackbar {
   }
 
   // shorthands for message types
+
   info(message) {
     this.alert(message, 'info');
   }
@@ -43,6 +44,33 @@ export class Snackbar {
   error(message) {
     this.alert(message, 'error');
   }
+
+  // shorthand for api errors
+  apiError(rejection) {
+    let message = gettext("Unknown error has occured.");
+
+    if (rejection.status === 0) {
+      message = gettext("Lost connection with application.");
+    }
+
+    if (rejection.status === 400 && rejection.detail) {
+      message = rejection.detail;
+    }
+
+    if (rejection.status === 403) {
+      message = rejection.detail;
+      if (message === "Permission denied") {
+        message = gettext(
+          "You don't have permission to perform this action.");
+      }
+    }
+
+    if (rejection.status === 404) {
+      message = gettext("Action link is invalid.");
+    }
+
+    this.error(message);
+  }
 }
 
 export default new Snackbar();

+ 134 - 0
frontend/src/test-setup.js

@@ -0,0 +1,134 @@
+var jQuery = require('jQuery'); // jshint ignore:line
+
+global.$ = jQuery;
+global.jQuery = jQuery;
+
+require('bootstrap-transition');
+require('bootstrap-affix');
+require('bootstrap-modal');
+require('bootstrap-dropdown');
+
+require('jquery-mockjax')(jQuery, window);
+$.mockjaxSettings.logging = false;
+
+require("babel-polyfill");
+
+// Mock base href element
+$('head').append('<base href="/test-runner/">');
+
+// Bootstrap's modal (we'll need it anyway for tests);
+$('body').append('<div class="modal fade" id="modal-mount" tabindex="-1" role="dialog" aria-labelledby="misago-modal-label"></div>');
+$('body').append('<div id="dropdown-mount"></div>');
+$('body').append('<div id="test-mount"></div>');
+
+// set global utility function for cleaning test containers
+var ReactDOM = require('react-dom');
+global.emptyTestContainers = function() {
+  ReactDOM.unmountComponentAtNode(document.getElementById('modal-mount'));
+  ReactDOM.unmountComponentAtNode(document.getElementById('dropdown-mount'));
+  ReactDOM.unmountComponentAtNode(document.getElementById('test-mount'));
+};
+
+// global utility function for store init
+global.initEmptyStore = function(store) {
+  store.constructor();
+  store.addReducer('test', function(state={}, action=null) { return {}; }, {}); // jshint ignore:line
+  store.init();
+};
+
+// global init function for modal and dropdown services
+global.initModal = function(modal) {
+  modal.init(document.getElementById('modal-mount'));
+};
+
+global.initDropdown = function(dropdown) {
+  dropdown.init(document.getElementById('dropdown-mount'));
+};
+
+// inlined gettext functions form Django
+// jshint ignore: start
+(function (globals) {
+
+  var django = globals.django || (globals.django = {});
+
+  django.pluralidx = function (count) { return (count == 1) ? 0 : 1; };
+
+  /* gettext identity library */
+
+  django.gettext = function (msgid) { return msgid; };
+  django.ngettext = function (singular, plural, count) { return (count == 1) ? singular : plural; };
+  django.gettext_noop = function (msgid) { return msgid; };
+  django.pgettext = function (context, msgid) { return msgid; };
+  django.npgettext = function (context, singular, plural, count) { return (count == 1) ? singular : plural; };
+
+
+  django.interpolate = function (fmt, obj, named) {
+    if (named) {
+      return fmt.replace(/%\(\w+\)s/g, function(match){return String(obj[match.slice(2,-2)])});
+    } else {
+      return fmt.replace(/%s/g, function(match){return String(obj.shift())});
+    }
+  };
+
+
+  /* formatting library */
+
+  django.formats = {
+    "DATETIME_FORMAT": "N j, Y, P",
+    "DATETIME_INPUT_FORMATS": [
+      "%Y-%m-%d %H:%M:%S",
+      "%Y-%m-%d %H:%M:%S.%f",
+      "%Y-%m-%d %H:%M",
+      "%Y-%m-%d",
+      "%m/%d/%Y %H:%M:%S",
+      "%m/%d/%Y %H:%M:%S.%f",
+      "%m/%d/%Y %H:%M",
+      "%m/%d/%Y",
+      "%m/%d/%y %H:%M:%S",
+      "%m/%d/%y %H:%M:%S.%f",
+      "%m/%d/%y %H:%M",
+      "%m/%d/%y"
+    ],
+    "DATE_FORMAT": "N j, Y",
+    "DATE_INPUT_FORMATS": [
+      "%Y-%m-%d",
+      "%m/%d/%Y",
+      "%m/%d/%y"
+    ],
+    "DECIMAL_SEPARATOR": ".",
+    "FIRST_DAY_OF_WEEK": "0",
+    "MONTH_DAY_FORMAT": "F j",
+    "NUMBER_GROUPING": "3",
+    "SHORT_DATETIME_FORMAT": "m/d/Y P",
+    "SHORT_DATE_FORMAT": "m/d/Y",
+    "THOUSAND_SEPARATOR": ",",
+    "TIME_FORMAT": "P",
+    "TIME_INPUT_FORMATS": [
+      "%H:%M:%S",
+      "%H:%M:%S.%f",
+      "%H:%M"
+    ],
+    "YEAR_MONTH_FORMAT": "F Y"
+  };
+
+  django.get_format = function (format_type) {
+    var value = django.formats[format_type];
+    if (typeof(value) == 'undefined') {
+      return format_type;
+    } else {
+      return value;
+    }
+  };
+
+  /* add to global namespace */
+  window.pluralidx = django.pluralidx;
+  window.gettext = django.gettext;
+  window.ngettext = django.ngettext;
+  window.gettext_noop = django.gettext_noop;
+  window.pgettext = django.pgettext;
+  window.npgettext = django.npgettext;
+  window.interpolate = django.interpolate;
+  window.get_format = django.get_format;
+
+}(global));
+// jshint ignore: end

+ 33 - 0
frontend/src/utils/banned-page.js

@@ -0,0 +1,33 @@
+import moment from 'moment'; // jshint ignore:line
+import React from 'react'; // jshint ignore:line
+import ReactDOM from 'react-dom';
+import { Provider, connect } from 'react-redux'; // jshint ignore:line
+import BannedPage from 'misago/components/banned-page'; // jshint ignore:line
+import misago from 'misago/index';
+import store from 'misago/services/store'; // jshint ignore:line
+
+/* jshint ignore:start */
+let select = function(state) {
+  return state.tick;
+};
+
+let RedrawedBannedPage = connect(select)(BannedPage);
+/* jshint ignore:end */
+
+export default function(ban, changeState) {
+  ReactDOM.render(
+    /* jshint ignore:start */
+    <Provider store={store.getStore()}>
+      <RedrawedBannedPage message={ban.message}
+                          expires={ban.expires_on ? moment(ban.expires_on) : null} />
+    </Provider>,
+    /* jshint ignore:end */
+    document.getElementById('page-mount')
+  );
+
+  if (typeof changeState === 'undefined' || !changeState) {
+    let forumName = misago.get('SETTINGS').forum_name;
+    document.title = gettext("You are banned") + ' | ' + forumName;
+    window.history.pushState({}, "", misago.get('BANNED_URL'));
+  }
+}

+ 100 - 0
frontend/src/utils/validators.js

@@ -0,0 +1,100 @@
+const EMAIL = /^(([^<>()[\]\.,;:\s@\"]+(\.[^<>()[\]\.,;:\s@\"]+)*)|(\".+\"))@(([^<>()[\]\.,;:\s@\"]+\.)+[^<>()[\]\.,;:\s@\"]{2,})$/i;
+const USERNAME = new RegExp('^[0-9a-z]+$', 'i');
+
+export function required() {
+  return function(value) {
+    if ($.trim(value).length === 0) {
+      return gettext("This field is required.");
+    }
+  };
+}
+
+export function email(message) {
+  return function(value) {
+    if (!EMAIL.test(value)) {
+      return message || gettext("Enter a valid email address.");
+    }
+  };
+}
+
+export function minLength(limitValue, message) {
+  return function(value) {
+    var returnMessage = '';
+    var length = $.trim(value).length;
+
+    if (length < limitValue) {
+      if (message) {
+        returnMessage = message(limitValue, length);
+      } else {
+        returnMessage = ngettext(
+          "Ensure this value has at least %(limit_value)s character (it has %(show_value)s).",
+          "Ensure this value has at least %(limit_value)s characters (it has %(show_value)s).",
+          limitValue);
+      }
+      return interpolate(returnMessage, {
+        limit_value: limitValue,
+        show_value: length
+      }, true);
+    }
+  };
+}
+
+export function maxLength(limitValue, message) {
+  return function(value) {
+    var returnMessage = '';
+    var length = $.trim(value).length;
+
+    if (length > limitValue) {
+      if (message) {
+        returnMessage = message(limitValue, length);
+      } else {
+        returnMessage = ngettext(
+          "Ensure this value has at most %(limit_value)s character (it has %(show_value)s).",
+          "Ensure this value has at most %(limit_value)s characters (it has %(show_value)s).",
+          limitValue);
+      }
+      return interpolate(returnMessage, {
+        limit_value: limitValue,
+        show_value: length
+      }, true);
+    }
+  };
+}
+
+export function usernameMinLength(settings) {
+  var message = function(limitValue) {
+    return ngettext(
+      "Username must be at least %(limit_value)s character long.",
+      "Username must be at least %(limit_value)s characters long.",
+      limitValue);
+  };
+  return this.minLength(settings.username_length_min, message);
+}
+
+export function usernameMaxLength(settings) {
+  var message = function(limitValue) {
+    return ngettext(
+      "Username cannot be longer than %(limit_value)s character.",
+      "Username cannot be longer than %(limit_value)s characters.",
+      limitValue);
+  };
+  return this.maxLength(settings.username_length_max, message);
+}
+
+export function usernameContent() {
+  return function(value) {
+    if (!USERNAME.test($.trim(value))) {
+      return gettext("Username can only contain latin alphabet letters and digits.");
+    }
+  };
+}
+
+export function passwordMinLength(settings) {
+  var message = function(limitValue) {
+    return ngettext(
+      "Valid password must be at least %(limit_value)s character long.",
+      "Valid password must be at least %(limit_value)s characters long.",
+      limitValue);
+  };
+  return this.minLength(settings.password_length_min, message);
+}

+ 0 - 14
frontend/src/vendor-tests.js

@@ -1,14 +0,0 @@
-var jQuery = require('jQuery'); // jshint ignore:line
-
-global.$ = jQuery;
-global.jQuery = jQuery;
-
-require('bootstrap-transition');
-require('bootstrap-affix');
-require('bootstrap-modal');
-require('bootstrap-dropdown');
-
-require('jquery-mockjax')(jQuery, window);
-$.mockjaxSettings.logging = false;
-
-require("babel-polyfill");

+ 16 - 9
frontend/style/misago/buttons.less

@@ -11,35 +11,42 @@
 
     // position loader over the text
     .loader-compact {
-      margin-top: @line-height-computed * -1;
       height: 20px;
 
-      position: relative;
-      top: 0px;
+      & > div {
+        width: 20px;
+        height: 20px;
+      }
     }
   }
 
   &.btn-default .loader-compact > div {
-    background-color: @btn-default-color;
+    border-top-color: @btn-default-color;
+    border-bottom-color: @btn-default-color;
   }
 
   &.btn-primary .loader-compact > div {
-    background-color: @btn-primary-color;
+    border-top-color: @btn-primary-color;
+    border-bottom-color: @btn-primary-color;
   }
 
   &.btn-success .loader-compact > div {
-    background-color: @btn-success-color;
+    border-top-color: @btn-success-color;
+    border-bottom-color: @btn-success-color;
   }
 
   &.btn-info .loader-compact > div {
-    background-color: @btn-info-color;
+    border-top-color: @btn-info-color;
+    border-bottom-color: @btn-info-color;
   }
 
   &.btn-warning .loader-compact > div {
-    background-color: @btn-warning-color;
+    border-top-color: @btn-warning-color;
+    border-bottom-color: @btn-warning-color;
   }
 
   &.btn-danger .loader-compact > div {
-    background-color: @btn-danger-color;
+    border-top-color: @btn-danger-color;
+    border-bottom-color: @btn-danger-color;
   }
 }

+ 31 - 144
frontend/style/misago/loaders.less

@@ -3,156 +3,43 @@
 // --------------------------------------------------
 
 
-.loader {
-  &.sk-folding-cube {
-    margin: @loader-vertical-margin auto;
-    width: @loader-size;
-    height: @loader-size;
-    position: relative;
-    -webkit-transform: rotateZ(45deg);
-            transform: rotateZ(45deg);
-  }
-
-  &.sk-folding-cube .sk-cube {
-    float: left;
-    width: 50%;
-    height: 50%;
-    position: relative;
-    -webkit-transform: scale(1.1);
-        -ms-transform: scale(1.1);
-            transform: scale(1.1);
-  }
-
-  &.sk-folding-cube .sk-cube:before {
-    content: '';
-    position: absolute;
-    top: 0;
-    left: 0;
-    width: 100%;
-    height: 100%;
-    background-color: @loader-color;
-    -webkit-animation: sk-foldCubeAngle 2.4s infinite linear both;
-            animation: sk-foldCubeAngle 2.4s infinite linear both;
-    -webkit-transform-origin: 100% 100%;
-        -ms-transform-origin: 100% 100%;
-            transform-origin: 100% 100%;
-  }
-
-  &.sk-folding-cube .sk-cube2 {
-    -webkit-transform: scale(1.1) rotateZ(90deg);
-            transform: scale(1.1) rotateZ(90deg);
-  }
-
-  &.sk-folding-cube .sk-cube3 {
-    -webkit-transform: scale(1.1) rotateZ(180deg);
-            transform: scale(1.1) rotateZ(180deg);
-  }
-
-  &.sk-folding-cube .sk-cube4 {
-    -webkit-transform: scale(1.1) rotateZ(270deg);
-            transform: scale(1.1) rotateZ(270deg);
-  }
-
-  &.sk-folding-cube .sk-cube2:before {
-    -webkit-animation-delay: 0.3s;
-            animation-delay: 0.3s;
-  }
-
-  &.sk-folding-cube .sk-cube3:before {
-    -webkit-animation-delay: 0.6s;
-            animation-delay: 0.6s;
-  }
-
-  &.sk-folding-cube .sk-cube4:before {
-    -webkit-animation-delay: 0.9s;
-            animation-delay: 0.9s;
-  }
-
-  @-webkit-keyframes sk-foldCubeAngle {
-    0%, 10% {
-      -webkit-transform: perspective(140px) rotateX(-180deg);
-              transform: perspective(140px) rotateX(-180deg);
-      opacity: 0;
-    } 25%, 75% {
-      -webkit-transform: perspective(140px) rotateX(0deg);
-              transform: perspective(140px) rotateX(0deg);
-      opacity: 1;
-    } 90%, 100% {
-      -webkit-transform: perspective(140px) rotateY(180deg);
-              transform: perspective(140px) rotateY(180deg);
-      opacity: 0;
-    }
-  }
-
-  @keyframes sk-foldCubeAngle {
-    0%, 10% {
-      -webkit-transform: perspective(140px) rotateX(-180deg);
-              transform: perspective(140px) rotateX(-180deg);
-      opacity: 0;
-    } 25%, 75% {
-      -webkit-transform: perspective(140px) rotateX(0deg);
-              transform: perspective(140px) rotateX(0deg);
-      opacity: 1;
-    } 90%, 100% {
-      -webkit-transform: perspective(140px) rotateY(180deg);
-              transform: perspective(140px) rotateY(180deg);
-      opacity: 0;
-    }
-  }
-}
-
-
 .loader-compact {
-  margin: 0px auto;
-  width: 50px;
+  width: 100%;
+  height: 49px;
   text-align: center;
+}
 
-  &>div {
-    width: @loader-compact-height;
-    height: @loader-compact-height;
-    background-color: #333;
-
-    border-radius: 100%;
-    display: inline-block;
-    -webkit-animation: sk-bouncedelay 1.4s infinite ease-in-out both;
-    animation: sk-bouncedelay 1.4s infinite ease-in-out both;
-  }
-
-  .bounce1 {
-    -webkit-animation-delay: -0.32s;
-    animation-delay: -0.32s;
-  }
-
-  .bounce2 {
-    margin: 0px 4px;
-    -webkit-animation-delay: -0.16s;
-    animation-delay: -0.16s;
-  }
-
-  @-webkit-keyframes sk-bouncedelay {
-    0%, 80%, 100% { -webkit-transform: scale(0.5) }
-    40% { -webkit-transform: scale(1.0) }
-  }
+.loader-spinning-wheel {
+  width: 49px;
+  height: 49px;
+  margin: 0 auto;
+  border: 3px solid rgb(0,0,0);
+  border-radius: 50%;
+  border-left-color: transparent;
+  border-right-color: transparent;
+  animation: cssload-spin 575ms infinite linear;
+    -o-animation: cssload-spin 575ms infinite linear;
+    -ms-animation: cssload-spin 575ms infinite linear;
+    -webkit-animation: cssload-spin 575ms infinite linear;
+    -moz-animation: cssload-spin 575ms infinite linear;
+}
 
-  @keyframes sk-bouncedelay {
-    0%, 80%, 100% {
-      -webkit-transform: scale(0.5);
-      transform: scale(0.5);
-    } 40% {
-      -webkit-transform: scale(1.0);
-      transform: scale(1.0);
-    }
-  }
+@keyframes cssload-spin {
+  100%{ transform: rotate(360deg); transform: rotate(360deg); }
 }
 
+@-o-keyframes cssload-spin {
+  100%{ -o-transform: rotate(360deg); transform: rotate(360deg); }
+}
 
-// Loading page extra styles
-.page-loading {
-  .lead {
-    margin-top: @loader-vertical-margin * -0.5;
-    margin-bottom: @loader-vertical-margin;
+@-ms-keyframes cssload-spin {
+  100%{ -ms-transform: rotate(360deg); transform: rotate(360deg); }
+}
 
-    color: @loader-text;
-    text-align: center;
-  }
+@-webkit-keyframes cssload-spin {
+  100%{ -webkit-transform: rotate(360deg); transform: rotate(360deg); }
 }
+
+@-moz-keyframes cssload-spin {
+  100%{ -moz-transform: rotate(360deg); transform: rotate(360deg); }
+}

+ 42 - 0
frontend/tests/components/avatar.js

@@ -0,0 +1,42 @@
+import assert from 'assert';
+import React from 'react'; // jshint ignore:line
+import ReactDOM from 'react-dom'; // jshint ignore:line
+import Avatar from 'misago/components/avatar'; // jshint ignore:line
+
+describe("Avatar", function() {
+  afterEach(function() {
+    window.emptyTestContainers();
+  });
+
+  it('renders guest avatar', function() {
+    /* jshint ignore:start */
+    ReactDOM.render(
+      <Avatar size="42" />,
+      document.getElementById('test-mount')
+    );
+    /* jshint ignore:end */
+
+    let element = $('#test-mount img.user-avatar');
+    assert.ok(element.length, "component renders for guest");
+    assert.equal(element.attr('src'), '/test-runner/user-avatar/42.png', "component builds valid avatar url");
+  });
+
+  it('renders user avatar', function() {
+    /* jshint ignore:start */
+    let user = {
+      id: 1234,
+      avatar_hash: 'aabbccddeeff'
+    };
+
+    ReactDOM.render(
+      <Avatar user={user} size="42" />,
+      document.getElementById('test-mount')
+    );
+    /* jshint ignore:end */
+
+    let element = $('#test-mount img.user-avatar');
+    assert.ok(element.length, "component renders for user");
+    assert.equal(element.attr('src'), '/test-runner/user-avatar/aabbccddeeff/42/1234.png',
+      "component builds valid avatar url for authenticated");
+  });
+});

+ 78 - 0
frontend/tests/components/button.js

@@ -0,0 +1,78 @@
+import assert from 'assert';
+import React from 'react'; // jshint ignore:line
+import ReactDOM from 'react-dom'; // jshint ignore:line
+import ReactTestUtils from 'react-addons-test-utils';
+import Button from 'misago/components/button'; // jshint ignore:line
+
+describe("Button", function() {
+  afterEach(function() {
+    window.emptyTestContainers();
+  });
+
+  it('renders', function() {
+    /* jshint ignore:start */
+    ReactDOM.render(
+      <Button>
+        Lorem ipsum
+      </Button>,
+      document.getElementById('test-mount')
+    );
+    /* jshint ignore:end */
+
+    let element = $('#test-mount button');
+    assert.ok(element.length, "component rendered");
+    assert.equal(element.attr('type'), 'submit', "component is submit button");
+    assert.equal(element.text().trim(), "Lorem ipsum", "component contains child");
+  });
+
+  it('handles clicks', function(done) { // jshint ignore:line
+    /* jshint ignore:start */
+    function click() {
+      assert.ok(true, "component called callback on click");
+      done();
+    }
+
+    ReactDOM.render(
+      <Button onClick={click}>
+        Lorem ipsum
+      </Button>,
+      document.getElementById('test-mount')
+    );
+    /* jshint ignore:end */
+
+    let element = $('#test-mount button');
+    assert.ok(element.length, "component rendered");
+    assert.equal(element.attr('type'), 'button', "component is regular button");
+    ReactTestUtils.Simulate.click(element.get(0));
+  });
+
+  it('renders disabled', function() {
+    /* jshint ignore:start */
+    ReactDOM.render(
+      <Button disabled={true}>
+        Lorem ipsum
+      </Button>,
+      document.getElementById('test-mount')
+    );
+    /* jshint ignore:end */
+
+    let element = $('#test-mount button');
+    assert.ok(element.length, "component rendered");
+    assert.equal(element.attr('disabled'), 'disabled', "component is disabled");
+  });
+
+  it('renders loading', function() {
+    /* jshint ignore:start */
+    ReactDOM.render(
+      <Button loading={true}>
+        Lorem ipsum
+      </Button>,
+      document.getElementById('test-mount')
+    );
+    /* jshint ignore:end */
+
+    let element = $('#test-mount button>.loader-compact');
+    assert.ok(element.length, "component rendered with loader");
+    assert.equal(element.parent().attr('disabled'), 'disabled', "component is disabled");
+  });
+});

+ 22 - 0
frontend/tests/components/loader.js

@@ -0,0 +1,22 @@
+import assert from 'assert';
+import React from 'react'; // jshint ignore:line
+import ReactDOM from 'react-dom'; // jshint ignore:line
+import Loader from 'misago/components/loader'; // jshint ignore:line
+
+describe("Snackbar", function() {
+  afterEach(function() {
+    window.emptyTestContainers();
+  });
+
+  it('renders', function() {
+    /* jshint ignore:start */
+    ReactDOM.render(
+      <Loader />,
+      document.getElementById('test-mount')
+    );
+    /* jshint ignore:end */
+
+    assert.ok($('#test-mount .loader-compact .loader-spinning-wheel').length,
+      "component renders");
+  });
+});

+ 1 - 6
frontend/tests/components/snackbar.js

@@ -4,13 +4,8 @@ import ReactDOM from 'react-dom'; // jshint ignore:line
 import { Snackbar } from 'misago/components/snackbar'; // jshint ignore:line
 
 describe("Snackbar", function() {
-  beforeEach(function() {
-    $('body').append('<div id="test-mount"></div>');
-  });
-
   afterEach(function() {
-    ReactDOM.unmountComponentAtNode(document.getElementById('test-mount'));
-    $('#test-mount').remove();
+    window.emptyTestContainers();
   });
 
   it('renders', function() {

+ 44 - 0
frontend/tests/components/user-menu/guest-menu.js

@@ -0,0 +1,44 @@
+import assert from 'assert';
+import React from 'react'; // jshint ignore:line
+import ReactDOM from 'react-dom'; // jshint ignore:line
+import ReactTestUtils from 'react-addons-test-utils';
+import { CompactGuestNav } from 'misago/components/user-menu/guest-nav'; // jshint ignore:line
+import dropdown from 'misago/services/mobile-navbar-dropdown';
+import store from 'misago/services/store';
+
+describe("CompactGuestNav", function() {
+  beforeEach(function() {
+    window.initEmptyStore(store);
+    window.initDropdown(dropdown);
+  });
+
+  afterEach(function() {
+    window.emptyTestContainers();
+  });
+
+  it('renders', function() {
+    /* jshint ignore:start */
+    ReactDOM.render(
+      <CompactGuestNav />,
+      document.getElementById('test-mount')
+    );
+    /* jshint ignore:end */
+
+    let element = $('#test-mount img.user-avatar');
+    assert.ok(element.length, "component renders");
+  });
+
+  it('opens dropdown on click', function() {
+    /* jshint ignore:start */
+    ReactDOM.render(
+      <CompactGuestNav />,
+      document.getElementById('test-mount')
+    );
+    /* jshint ignore:end */
+
+    ReactTestUtils.Simulate.click($('#test-mount button').get(0));
+
+    let element = $('#dropdown-mount>.dropdown-menu');
+    assert.ok(element.length, "component opened dropdown");
+  });
+});

+ 105 - 0
frontend/tests/modal.js

@@ -0,0 +1,105 @@
+import assert from 'assert';
+import React from 'react'; // jshint ignore:line
+import ReactDOM from 'react-dom'; // jshint ignore:line
+import store from 'misago/services/store';
+import { Modal } from 'misago/services/modal';
+
+var modal = null;
+
+class TestModalA extends React.Component {
+  render() {
+    /* jshint ignore:start */
+    return <div className="modal-dialog modal-a">
+      <div className="modal-content">
+        <div className="modal-header">
+          <button type="button" className="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
+          <h4 className="modal-title">Modal A</h4>
+        </div>
+        <div className="modal-body">
+          <p>This is first test modal!</p>
+        </div>
+        <div className="modal-footer">
+          <button type="button" className="btn btn-default" data-dismiss="modal">Close</button>
+        </div>
+      </div>
+    </div>;
+    /* jshint ignore:end */
+  }
+}
+
+class TestModalB extends React.Component {
+  render() {
+    /* jshint ignore:start */
+    return <div className="modal-dialog modal-b">
+      <div className="modal-content">
+        <div className="modal-header">
+          <button type="button" className="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
+          <h4 className="modal-title">Modal B</h4>
+        </div>
+        <div className="modal-body">
+          <p>This is second test modal!</p>
+        </div>
+        <div className="modal-footer">
+          <button type="button" className="btn btn-default" data-dismiss="modal">Close</button>
+        </div>
+      </div>
+    </div>;
+    /* jshint ignore:end */
+  }
+}
+
+describe("Modal", function() {
+  beforeEach(function() {
+    modal = new Modal();
+    modal.init(document.getElementById('modal-mount'));
+
+    window.initEmptyStore(store);
+  });
+
+  afterEach(function() {
+    window.emptyTestContainers();
+  });
+
+  it('shows component', function(done) {
+    modal.show(TestModalA);
+
+    window.setTimeout(function() {
+      let element = $('#modal-mount .modal-a');
+      assert.ok(element.length, "component was rendered");
+      done();
+    }, 400);
+  });
+
+  it('shows and cycles component', function(done) {
+    modal.show(TestModalA);
+
+    window.setTimeout(function() {
+      let element = $('#modal-mount .modal-a');
+      assert.ok(element.length, "component was rendered");
+
+      modal.show(TestModalB);
+    }, 400);
+
+    window.setTimeout(function() {
+      let element = $('#modal-mount .modal-b');
+      assert.ok(element.length, "component was toggled");
+      done();
+    }, 500);
+  });
+
+  it('hides component', function(done) {
+    modal.show(TestModalA);
+
+    window.setTimeout(function() {
+      let element = $('#modal-mount .modal-a');
+      assert.ok(element.length, "component was rendered");
+      modal.hide();
+    }, 400);
+
+    window.setTimeout(function() {
+      let element = $('#modal-mount');
+      assert.equal(element.children().length, 0, "modal was emptied");
+      done();
+    }, 1000);
+  });
+});

+ 69 - 0
frontend/tests/navbar-dropdown.js

@@ -0,0 +1,69 @@
+import assert from 'assert';
+import React from 'react'; // jshint ignore:line
+import ReactDOM from 'react-dom'; // jshint ignore:line
+import store from 'misago/services/store';
+import { MobileNavbarDropdown } from 'misago/services/mobile-navbar-dropdown';
+
+var dropdown = null;
+
+class TestComponentA extends React.Component {
+  render() {
+    /* jshint ignore:start */
+    return <div className="dropdown-a">
+      <p>This is first test dropdown!</p>
+    </div>;
+    /* jshint ignore:end */
+  }
+}
+
+class TestComponentB extends React.Component {
+  render() {
+    /* jshint ignore:start */
+    return <div className="dropdown-b">
+      <p>This is second test dropdown!</p>
+    </div>;
+    /* jshint ignore:end */
+  }
+}
+
+describe("dropdown", function() {
+  beforeEach(function() {
+    dropdown = new MobileNavbarDropdown();
+    dropdown.init(document.getElementById('dropdown-mount'));
+
+    store.constructor();
+    store.addReducer('test', function(state={}, action=null) { return {}; }, {}); // jshint ignore:line
+    store.init();
+  });
+
+  afterEach(function() {
+    window.emptyTestContainers();
+  });
+
+  it('shows component', function(done) {
+    dropdown.show(TestComponentA);
+
+    window.setTimeout(function() {
+      let element = $('#dropdown-mount .dropdown-a');
+      assert.ok(element.length, "component was rendered");
+      done();
+    }, 100);
+  });
+
+  it('shows and cycles component', function(done) {
+    dropdown.show(TestComponentA);
+
+    window.setTimeout(function() {
+      let element = $('#dropdown-mount .dropdown-a');
+      assert.ok(element.length, "component was rendered");
+
+      dropdown.show(TestComponentB);
+    }, 100);
+
+    window.setTimeout(function() {
+      let element = $('#dropdown-mount .dropdown-b');
+      assert.ok(element.length, "component was toggled");
+      done();
+    }, 300);
+  });
+});

+ 96 - 0
frontend/tests/validators.js

@@ -0,0 +1,96 @@
+import assert from 'assert';
+import * as validators from 'misago/utils/validators';
+
+describe("Validator", function() {
+  it("required validator", function() {
+    assert.equal(validators.required()('yup'), undefined,
+      "non-empty string passed validation.");
+    assert.equal(
+      validators.required()(' '), gettext("This field is required."),
+      "empty string failed validation.");
+  });
+
+  it("email validator", function() {
+    assert.equal(validators.email()('simple@email.com'), undefined,
+      "simple e-mail passed validation.");
+    assert.equal(validators.email()('si.mp.le@ema.il.com'), undefined,
+      "dotted e-mail passed validation.");
+    assert.equal(validators.email()('si-mp-le@ema-il.com'), undefined,
+      "hyphenated e-mail passed validation.");
+    assert.equal(validators.email()('si_mp_le@ema_il.com'), undefined,
+      "underscored e-mail passed validation.");
+    assert.equal(validators.email()('si+mp+le@email.com'), undefined,
+      "plused e-mail passed validation.");
+    assert.equal(validators.email('Nope!')('hh'), 'Nope!',
+      "non-email errored with message providen.");
+  });
+
+  it("minLength validator", function() {
+    assert.equal(validators.minLength(5)('yusss'), undefined,
+      "string of required length passed validation.");
+    assert.equal(
+      validators.minLength(5)('nope'),
+      "Ensure this value has at least 5 characters (it has 4).",
+      "too short string failed validation.");
+  });
+
+  it("maxLength validator", function() {
+    assert.equal(validators.maxLength(5)('yusss'), undefined,
+      "string of required length passed validation.");
+    assert.equal(
+      validators.maxLength(5)('too long!'),
+      "Ensure this value has at most 5 characters (it has 9).",
+      "too long string failed validation.");
+  });
+
+  it("usernameMinLength validator", function() {
+    var settings = {
+      username_length_min: 4
+    };
+
+    assert.equal(
+      validators.usernameMinLength(settings)('yusss'), undefined,
+      "username of required length passed validation.");
+    assert.equal(
+      validators.usernameMinLength(settings)('no'),
+      "Username must be at least 4 characters long.",
+      "too short username failed validation.");
+  });
+
+  it("usernameMaxLength validator", function() {
+    var settings = {
+      username_length_max: 4
+    };
+
+    assert.equal(
+      validators.usernameMaxLength(settings)('yuss'), undefined,
+      "username of required length passed validation.");
+    assert.equal(
+      validators.usernameMaxLength(settings)('too long!'),
+      "Username cannot be longer than 4 characters.",
+      "too long username failed validation.");
+  });
+
+  it("username validator", function() {
+    assert.equal(validators.usernameContent()('v4lid'), undefined,
+      "valid username passed validation.");
+    assert.equal(
+      validators.usernameContent()('++++'),
+      "Username can only contain latin alphabet letters and digits.",
+      "invalid username failed validation.");
+  });
+
+  it("passwordMinLength validator", function() {
+    var settings = {
+      password_length_min: 4
+    };
+
+    assert.equal(
+      validators.passwordMinLength(settings)('yusss'), undefined,
+      "password of required length passed validation.");
+    assert.equal(
+      validators.passwordMinLength(settings)('no'),
+      "Valid password must be at least 4 characters long.",
+      "too short password failed validation.");
+  });
+});

+ 4612 - 1
misago/static/misago/css/misago.css

@@ -1 +1,4612 @@
-/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */hr,img{border:0}body,figure{margin:0}.navbar-fixed-bottom .navbar-collapse,.navbar-fixed-top .navbar-collapse,.pre-scrollable{max-height:340px}.img-thumbnail,.table,label{max-width:100%}.alerts-snackbar,a.btn.disabled,fieldset[disabled] a.btn{pointer-events:none}html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary{display:block}audio,canvas,progress,video{display:inline-block;vertical-align:baseline}audio:not([controls]){display:none;height:0}[hidden],template{display:none}a{background-color:transparent}a:active,a:hover{outline:0}b,optgroup,strong{font-weight:700}dfn{font-style:italic}h1{margin:.67em 0}mark{background:#ff0;color:#000}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sup{top:-.5em}sub{bottom:-.25em}img{vertical-align:middle}svg:not(:root){overflow:hidden}hr{box-sizing:content-box;height:0}pre,textarea{overflow:auto}code,kbd,pre,samp{font-size:1em}button,input,optgroup,select,textarea{color:inherit;font:inherit;margin:0}button{overflow:visible}button,select{text-transform:none}button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer}button[disabled],html input[disabled]{cursor:default}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{height:auto}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}table{border-collapse:collapse;border-spacing:0}td,th{padding:0}/*! Source: https://github.com/h5bp/html5-boilerplate/blob/master/src/css/main.css */@media print{blockquote,img,pre,tr{page-break-inside:avoid}*,:after,:before{background:0 0!important;color:#000!important;box-shadow:none!important;text-shadow:none!important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}abbr[title]:after{content:" (" attr(title) ")"}a[href^="javascript:"]:after,a[href^="#"]:after{content:""}blockquote,pre{border:1px solid #999}thead{display:table-header-group}img{max-width:100%!important}h2,h3,p{orphans:3;widows:3}h2,h3{page-break-after:avoid}.navbar{display:none}.btn>.caret,.dropup>.btn>.caret{border-top-color:#000!important}.label{border:1px solid #000}.table{border-collapse:collapse!important}.table td,.table th{background-color:#fff!important}.table-bordered td,.table-bordered th{border:1px solid #ddd!important}}.btn,.btn-danger.active,.btn-danger:active,.btn-default.active,.btn-default:active,.btn-info.active,.btn-info:active,.btn-primary.active,.btn-primary:active,.btn-warning.active,.btn-warning:active,.btn.active,.btn:active,.dropdown-menu>.disabled>a:focus,.dropdown-menu>.disabled>a:hover,.form-control,.navbar-toggle,.open>.dropdown-toggle.btn-danger,.open>.dropdown-toggle.btn-default,.open>.dropdown-toggle.btn-info,.open>.dropdown-toggle.btn-primary,.open>.dropdown-toggle.btn-warning{background-image:none}.img-thumbnail,body{background-color:#fff}*,:after,:before{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}html{font-size:10px;-webkit-tap-highlight-color:transparent}body{font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:14px;line-height:1.42857143;color:#333}button,input,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit}a{color:#337ab7;text-decoration:none}a:focus,a:hover{color:#23527c;text-decoration:underline}a:focus{outline:dotted thin;outline:-webkit-focus-ring-color auto 5px;outline-offset:-2px}.img-responsive{display:block;max-width:100%;height:auto}.img-rounded{border-radius:6px}.img-thumbnail{padding:4px;line-height:1.42857143;border:1px solid #ddd;border-radius:4px;-webkit-transition:all .2s ease-in-out;-o-transition:all .2s ease-in-out;transition:all .2s ease-in-out;display:inline-block;height:auto}.dropdown-menu .divider,.nav .nav-divider,.sr-only{height:1px;overflow:hidden}.img-circle{border-radius:50%}hr{margin-top:20px;margin-bottom:20px;border-top:1px solid #eee}.sr-only{position:absolute;width:1px;margin:-1px;padding:0;clip:rect(0,0,0,0);border:0}.sr-only-focusable:active,.sr-only-focusable:focus{position:static;width:auto;height:auto;margin:0;overflow:visible;clip:auto}[role=button]{cursor:pointer}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{font-family:inherit;font-weight:500;line-height:1.1;color:inherit}.h1 .small,.h1 small,.h2 .small,.h2 small,.h3 .small,.h3 small,.h4 .small,.h4 small,.h5 .small,.h5 small,.h6 .small,.h6 small,h1 .small,h1 small,h2 .small,h2 small,h3 .small,h3 small,h4 .small,h4 small,h5 .small,h5 small,h6 .small,h6 small{font-weight:400;line-height:1;color:#777}.h1,.h2,.h3,h1,h2,h3{margin-top:20px;margin-bottom:10px}.h1 .small,.h1 small,.h2 .small,.h2 small,.h3 .small,.h3 small,h1 .small,h1 small,h2 .small,h2 small,h3 .small,h3 small{font-size:65%}.h4,.h5,.h6,h4,h5,h6{margin-top:10px;margin-bottom:10px}.h4 .small,.h4 small,.h5 .small,.h5 small,.h6 .small,.h6 small,h4 .small,h4 small,h5 .small,h5 small,h6 .small,h6 small{font-size:75%}.h1,h1{font-size:36px}.h2,h2{font-size:30px}.h3,h3{font-size:24px}.h4,h4{font-size:18px}.h5,h5{font-size:14px}.h6,h6{font-size:12px}p{margin:0 0 10px}.lead{margin-bottom:20px;font-size:16px;font-weight:300;line-height:1.4}dt,kbd kbd,label{font-weight:700}address,blockquote .small,blockquote footer,blockquote small,dd,dt,pre{line-height:1.42857143}@media (min-width:768px){.lead{font-size:21px}}.small,small{font-size:85%}.mark,mark{background-color:#fcf8e3;padding:.2em}.list-inline,.list-unstyled{padding-left:0;list-style:none}.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}.text-justify{text-align:justify}.text-nowrap{white-space:nowrap}.text-lowercase{text-transform:lowercase}.text-uppercase{text-transform:uppercase}.text-capitalize{text-transform:capitalize}.text-muted{color:#777}.text-primary{color:#337ab7}a.text-primary:focus,a.text-primary:hover{color:#286090}.text-success{color:#3c763d}a.text-success:focus,a.text-success:hover{color:#2b542c}.text-info{color:#31708f}a.text-info:focus,a.text-info:hover{color:#245269}.text-warning{color:#8a6d3b}a.text-warning:focus,a.text-warning:hover{color:#66512c}.text-danger{color:#a94442}a.text-danger:focus,a.text-danger:hover{color:#843534}.bg-primary{color:#fff;background-color:#337ab7}a.bg-primary:focus,a.bg-primary:hover{background-color:#286090}.bg-success{background-color:#dff0d8}a.bg-success:focus,a.bg-success:hover{background-color:#c1e2b3}.bg-info{background-color:#d9edf7}a.bg-info:focus,a.bg-info:hover{background-color:#afd9ee}.bg-warning{background-color:#fcf8e3}a.bg-warning:focus,a.bg-warning:hover{background-color:#f7ecb5}.bg-danger{background-color:#f2dede}a.bg-danger:focus,a.bg-danger:hover{background-color:#e4b9b9}pre code,table{background-color:transparent}.page-header{padding-bottom:9px;margin:40px 0 20px;border-bottom:1px solid #eee}dl,ol,ul{margin-top:0}blockquote ol:last-child,blockquote p:last-child,blockquote ul:last-child,ol ol,ol ul,ul ol,ul ul{margin-bottom:0}address,dl{margin-bottom:20px}ol,ul{margin-bottom:10px}.list-inline{margin-left:-5px}.list-inline>li{display:inline-block;padding-left:5px;padding-right:5px}dd{margin-left:0}@media (min-width:768px){.dl-horizontal dt{float:left;width:160px;clear:left;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dl-horizontal dd{margin-left:180px}.container{width:750px}}abbr[data-original-title],abbr[title]{cursor:help;border-bottom:1px dotted #777}.initialism{font-size:90%;text-transform:uppercase}blockquote{padding:10px 20px;margin:0 0 20px;font-size:17.5px;border-left:5px solid #eee}blockquote .small,blockquote footer,blockquote small{display:block;font-size:80%;color:#777}legend,pre{display:block;color:#333}blockquote .small:before,blockquote footer:before,blockquote small:before{content:'\2014 \00A0'}.blockquote-reverse,blockquote.pull-right{padding-right:15px;padding-left:0;border-right:5px solid #eee;border-left:0;text-align:right}code,kbd{padding:2px 4px;font-size:90%}caption,th{text-align:left}.blockquote-reverse .small:before,.blockquote-reverse footer:before,.blockquote-reverse small:before,blockquote.pull-right .small:before,blockquote.pull-right footer:before,blockquote.pull-right small:before{content:''}.blockquote-reverse .small:after,.blockquote-reverse footer:after,.blockquote-reverse small:after,blockquote.pull-right .small:after,blockquote.pull-right footer:after,blockquote.pull-right small:after{content:'\00A0 \2014'}address{font-style:normal}code,kbd,pre,samp{font-family:Menlo,Monaco,Consolas,"Courier New",monospace}code{color:#c7254e;background-color:#f9f2f4;border-radius:4px}kbd{color:#fff;background-color:#333;border-radius:3px;box-shadow:inset 0 -1px 0 rgba(0,0,0,.25)}kbd kbd{padding:0;font-size:100%;box-shadow:none}pre{padding:9.5px;margin:0 0 10px;font-size:13px;word-break:break-all;word-wrap:break-word;background-color:#f5f5f5;border:1px solid #ccc;border-radius:4px}.container,.container-fluid{margin-right:auto;margin-left:auto}pre code{padding:0;font-size:inherit;color:inherit;white-space:pre-wrap;border-radius:0}.container,.container-fluid{padding-left:15px;padding-right:15px}.pre-scrollable{overflow-y:scroll}@media (min-width:992px){.container{width:970px}}@media (min-width:1200px){.container{width:1170px}}.row{margin-left:-15px;margin-right:-15px}.col-lg-1,.col-lg-10,.col-lg-11,.col-lg-12,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9,.col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9,.col-sm-1,.col-sm-10,.col-sm-11,.col-sm-12,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9,.col-xs-1,.col-xs-10,.col-xs-11,.col-xs-12,.col-xs-2,.col-xs-3,.col-xs-4,.col-xs-5,.col-xs-6,.col-xs-7,.col-xs-8,.col-xs-9{position:relative;min-height:1px;padding-left:15px;padding-right:15px}.col-xs-1,.col-xs-10,.col-xs-11,.col-xs-12,.col-xs-2,.col-xs-3,.col-xs-4,.col-xs-5,.col-xs-6,.col-xs-7,.col-xs-8,.col-xs-9{float:left}.col-xs-12{width:100%}.col-xs-11{width:91.66666667%}.col-xs-10{width:83.33333333%}.col-xs-9{width:75%}.col-xs-8{width:66.66666667%}.col-xs-7{width:58.33333333%}.col-xs-6{width:50%}.col-xs-5{width:41.66666667%}.col-xs-4{width:33.33333333%}.col-xs-3{width:25%}.col-xs-2{width:16.66666667%}.col-xs-1{width:8.33333333%}.col-xs-pull-12{right:100%}.col-xs-pull-11{right:91.66666667%}.col-xs-pull-10{right:83.33333333%}.col-xs-pull-9{right:75%}.col-xs-pull-8{right:66.66666667%}.col-xs-pull-7{right:58.33333333%}.col-xs-pull-6{right:50%}.col-xs-pull-5{right:41.66666667%}.col-xs-pull-4{right:33.33333333%}.col-xs-pull-3{right:25%}.col-xs-pull-2{right:16.66666667%}.col-xs-pull-1{right:8.33333333%}.col-xs-pull-0{right:auto}.col-xs-push-12{left:100%}.col-xs-push-11{left:91.66666667%}.col-xs-push-10{left:83.33333333%}.col-xs-push-9{left:75%}.col-xs-push-8{left:66.66666667%}.col-xs-push-7{left:58.33333333%}.col-xs-push-6{left:50%}.col-xs-push-5{left:41.66666667%}.col-xs-push-4{left:33.33333333%}.col-xs-push-3{left:25%}.col-xs-push-2{left:16.66666667%}.col-xs-push-1{left:8.33333333%}.col-xs-push-0{left:auto}.col-xs-offset-12{margin-left:100%}.col-xs-offset-11{margin-left:91.66666667%}.col-xs-offset-10{margin-left:83.33333333%}.col-xs-offset-9{margin-left:75%}.col-xs-offset-8{margin-left:66.66666667%}.col-xs-offset-7{margin-left:58.33333333%}.col-xs-offset-6{margin-left:50%}.col-xs-offset-5{margin-left:41.66666667%}.col-xs-offset-4{margin-left:33.33333333%}.col-xs-offset-3{margin-left:25%}.col-xs-offset-2{margin-left:16.66666667%}.col-xs-offset-1{margin-left:8.33333333%}.col-xs-offset-0{margin-left:0}@media (min-width:768px){.col-sm-1,.col-sm-10,.col-sm-11,.col-sm-12,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9{float:left}.col-sm-12{width:100%}.col-sm-11{width:91.66666667%}.col-sm-10{width:83.33333333%}.col-sm-9{width:75%}.col-sm-8{width:66.66666667%}.col-sm-7{width:58.33333333%}.col-sm-6{width:50%}.col-sm-5{width:41.66666667%}.col-sm-4{width:33.33333333%}.col-sm-3{width:25%}.col-sm-2{width:16.66666667%}.col-sm-1{width:8.33333333%}.col-sm-pull-12{right:100%}.col-sm-pull-11{right:91.66666667%}.col-sm-pull-10{right:83.33333333%}.col-sm-pull-9{right:75%}.col-sm-pull-8{right:66.66666667%}.col-sm-pull-7{right:58.33333333%}.col-sm-pull-6{right:50%}.col-sm-pull-5{right:41.66666667%}.col-sm-pull-4{right:33.33333333%}.col-sm-pull-3{right:25%}.col-sm-pull-2{right:16.66666667%}.col-sm-pull-1{right:8.33333333%}.col-sm-pull-0{right:auto}.col-sm-push-12{left:100%}.col-sm-push-11{left:91.66666667%}.col-sm-push-10{left:83.33333333%}.col-sm-push-9{left:75%}.col-sm-push-8{left:66.66666667%}.col-sm-push-7{left:58.33333333%}.col-sm-push-6{left:50%}.col-sm-push-5{left:41.66666667%}.col-sm-push-4{left:33.33333333%}.col-sm-push-3{left:25%}.col-sm-push-2{left:16.66666667%}.col-sm-push-1{left:8.33333333%}.col-sm-push-0{left:auto}.col-sm-offset-12{margin-left:100%}.col-sm-offset-11{margin-left:91.66666667%}.col-sm-offset-10{margin-left:83.33333333%}.col-sm-offset-9{margin-left:75%}.col-sm-offset-8{margin-left:66.66666667%}.col-sm-offset-7{margin-left:58.33333333%}.col-sm-offset-6{margin-left:50%}.col-sm-offset-5{margin-left:41.66666667%}.col-sm-offset-4{margin-left:33.33333333%}.col-sm-offset-3{margin-left:25%}.col-sm-offset-2{margin-left:16.66666667%}.col-sm-offset-1{margin-left:8.33333333%}.col-sm-offset-0{margin-left:0}}@media (min-width:992px){.col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9{float:left}.col-md-12{width:100%}.col-md-11{width:91.66666667%}.col-md-10{width:83.33333333%}.col-md-9{width:75%}.col-md-8{width:66.66666667%}.col-md-7{width:58.33333333%}.col-md-6{width:50%}.col-md-5{width:41.66666667%}.col-md-4{width:33.33333333%}.col-md-3{width:25%}.col-md-2{width:16.66666667%}.col-md-1{width:8.33333333%}.col-md-pull-12{right:100%}.col-md-pull-11{right:91.66666667%}.col-md-pull-10{right:83.33333333%}.col-md-pull-9{right:75%}.col-md-pull-8{right:66.66666667%}.col-md-pull-7{right:58.33333333%}.col-md-pull-6{right:50%}.col-md-pull-5{right:41.66666667%}.col-md-pull-4{right:33.33333333%}.col-md-pull-3{right:25%}.col-md-pull-2{right:16.66666667%}.col-md-pull-1{right:8.33333333%}.col-md-pull-0{right:auto}.col-md-push-12{left:100%}.col-md-push-11{left:91.66666667%}.col-md-push-10{left:83.33333333%}.col-md-push-9{left:75%}.col-md-push-8{left:66.66666667%}.col-md-push-7{left:58.33333333%}.col-md-push-6{left:50%}.col-md-push-5{left:41.66666667%}.col-md-push-4{left:33.33333333%}.col-md-push-3{left:25%}.col-md-push-2{left:16.66666667%}.col-md-push-1{left:8.33333333%}.col-md-push-0{left:auto}.col-md-offset-12{margin-left:100%}.col-md-offset-11{margin-left:91.66666667%}.col-md-offset-10{margin-left:83.33333333%}.col-md-offset-9{margin-left:75%}.col-md-offset-8{margin-left:66.66666667%}.col-md-offset-7{margin-left:58.33333333%}.col-md-offset-6{margin-left:50%}.col-md-offset-5{margin-left:41.66666667%}.col-md-offset-4{margin-left:33.33333333%}.col-md-offset-3{margin-left:25%}.col-md-offset-2{margin-left:16.66666667%}.col-md-offset-1{margin-left:8.33333333%}.col-md-offset-0{margin-left:0}}@media (min-width:1200px){.col-lg-1,.col-lg-10,.col-lg-11,.col-lg-12,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9{float:left}.col-lg-12{width:100%}.col-lg-11{width:91.66666667%}.col-lg-10{width:83.33333333%}.col-lg-9{width:75%}.col-lg-8{width:66.66666667%}.col-lg-7{width:58.33333333%}.col-lg-6{width:50%}.col-lg-5{width:41.66666667%}.col-lg-4{width:33.33333333%}.col-lg-3{width:25%}.col-lg-2{width:16.66666667%}.col-lg-1{width:8.33333333%}.col-lg-pull-12{right:100%}.col-lg-pull-11{right:91.66666667%}.col-lg-pull-10{right:83.33333333%}.col-lg-pull-9{right:75%}.col-lg-pull-8{right:66.66666667%}.col-lg-pull-7{right:58.33333333%}.col-lg-pull-6{right:50%}.col-lg-pull-5{right:41.66666667%}.col-lg-pull-4{right:33.33333333%}.col-lg-pull-3{right:25%}.col-lg-pull-2{right:16.66666667%}.col-lg-pull-1{right:8.33333333%}.col-lg-pull-0{right:auto}.col-lg-push-12{left:100%}.col-lg-push-11{left:91.66666667%}.col-lg-push-10{left:83.33333333%}.col-lg-push-9{left:75%}.col-lg-push-8{left:66.66666667%}.col-lg-push-7{left:58.33333333%}.col-lg-push-6{left:50%}.col-lg-push-5{left:41.66666667%}.col-lg-push-4{left:33.33333333%}.col-lg-push-3{left:25%}.col-lg-push-2{left:16.66666667%}.col-lg-push-1{left:8.33333333%}.col-lg-push-0{left:auto}.col-lg-offset-12{margin-left:100%}.col-lg-offset-11{margin-left:91.66666667%}.col-lg-offset-10{margin-left:83.33333333%}.col-lg-offset-9{margin-left:75%}.col-lg-offset-8{margin-left:66.66666667%}.col-lg-offset-7{margin-left:58.33333333%}.col-lg-offset-6{margin-left:50%}.col-lg-offset-5{margin-left:41.66666667%}.col-lg-offset-4{margin-left:33.33333333%}.col-lg-offset-3{margin-left:25%}.col-lg-offset-2{margin-left:16.66666667%}.col-lg-offset-1{margin-left:8.33333333%}.col-lg-offset-0{margin-left:0}}caption{padding-top:8px;padding-bottom:8px;color:#777}.table{width:100%;margin-bottom:20px}.table>tbody>tr>td,.table>tbody>tr>th,.table>tfoot>tr>td,.table>tfoot>tr>th,.table>thead>tr>td,.table>thead>tr>th{padding:8px;line-height:1.42857143;vertical-align:top;border-top:1px solid #ddd}.table>thead>tr>th{vertical-align:bottom;border-bottom:2px solid #ddd}.btn,.caret{vertical-align:middle}.table>caption+thead>tr:first-child>td,.table>caption+thead>tr:first-child>th,.table>colgroup+thead>tr:first-child>td,.table>colgroup+thead>tr:first-child>th,.table>thead:first-child>tr:first-child>td,.table>thead:first-child>tr:first-child>th{border-top:0}.table>tbody+tbody{border-top:2px solid #ddd}.table .table{background-color:#fff}.table-condensed>tbody>tr>td,.table-condensed>tbody>tr>th,.table-condensed>tfoot>tr>td,.table-condensed>tfoot>tr>th,.table-condensed>thead>tr>td,.table-condensed>thead>tr>th{padding:5px}.table-bordered,.table-bordered>tbody>tr>td,.table-bordered>tbody>tr>th,.table-bordered>tfoot>tr>td,.table-bordered>tfoot>tr>th,.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border:1px solid #ddd}.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border-bottom-width:2px}.table-striped>tbody>tr:nth-of-type(odd){background-color:#f9f9f9}.table-hover>tbody>tr:hover,.table>tbody>tr.active>td,.table>tbody>tr.active>th,.table>tbody>tr>td.active,.table>tbody>tr>th.active,.table>tfoot>tr.active>td,.table>tfoot>tr.active>th,.table>tfoot>tr>td.active,.table>tfoot>tr>th.active,.table>thead>tr.active>td,.table>thead>tr.active>th,.table>thead>tr>td.active,.table>thead>tr>th.active{background-color:#f5f5f5}table col[class*=col-]{position:static;float:none;display:table-column}table td[class*=col-],table th[class*=col-]{position:static;float:none;display:table-cell}.table-hover>tbody>tr.active:hover>td,.table-hover>tbody>tr.active:hover>th,.table-hover>tbody>tr:hover>.active,.table-hover>tbody>tr>td.active:hover,.table-hover>tbody>tr>th.active:hover{background-color:#e8e8e8}.table>tbody>tr.success>td,.table>tbody>tr.success>th,.table>tbody>tr>td.success,.table>tbody>tr>th.success,.table>tfoot>tr.success>td,.table>tfoot>tr.success>th,.table>tfoot>tr>td.success,.table>tfoot>tr>th.success,.table>thead>tr.success>td,.table>thead>tr.success>th,.table>thead>tr>td.success,.table>thead>tr>th.success{background-color:#dff0d8}.table-hover>tbody>tr.success:hover>td,.table-hover>tbody>tr.success:hover>th,.table-hover>tbody>tr:hover>.success,.table-hover>tbody>tr>td.success:hover,.table-hover>tbody>tr>th.success:hover{background-color:#d0e9c6}.table>tbody>tr.info>td,.table>tbody>tr.info>th,.table>tbody>tr>td.info,.table>tbody>tr>th.info,.table>tfoot>tr.info>td,.table>tfoot>tr.info>th,.table>tfoot>tr>td.info,.table>tfoot>tr>th.info,.table>thead>tr.info>td,.table>thead>tr.info>th,.table>thead>tr>td.info,.table>thead>tr>th.info{background-color:#d9edf7}.table-hover>tbody>tr.info:hover>td,.table-hover>tbody>tr.info:hover>th,.table-hover>tbody>tr:hover>.info,.table-hover>tbody>tr>td.info:hover,.table-hover>tbody>tr>th.info:hover{background-color:#c4e3f3}.table>tbody>tr.warning>td,.table>tbody>tr.warning>th,.table>tbody>tr>td.warning,.table>tbody>tr>th.warning,.table>tfoot>tr.warning>td,.table>tfoot>tr.warning>th,.table>tfoot>tr>td.warning,.table>tfoot>tr>th.warning,.table>thead>tr.warning>td,.table>thead>tr.warning>th,.table>thead>tr>td.warning,.table>thead>tr>th.warning{background-color:#fcf8e3}.table-hover>tbody>tr.warning:hover>td,.table-hover>tbody>tr.warning:hover>th,.table-hover>tbody>tr:hover>.warning,.table-hover>tbody>tr>td.warning:hover,.table-hover>tbody>tr>th.warning:hover{background-color:#faf2cc}.table>tbody>tr.danger>td,.table>tbody>tr.danger>th,.table>tbody>tr>td.danger,.table>tbody>tr>th.danger,.table>tfoot>tr.danger>td,.table>tfoot>tr.danger>th,.table>tfoot>tr>td.danger,.table>tfoot>tr>th.danger,.table>thead>tr.danger>td,.table>thead>tr.danger>th,.table>thead>tr>td.danger,.table>thead>tr>th.danger{background-color:#f2dede}.table-hover>tbody>tr.danger:hover>td,.table-hover>tbody>tr.danger:hover>th,.table-hover>tbody>tr:hover>.danger,.table-hover>tbody>tr>td.danger:hover,.table-hover>tbody>tr>th.danger:hover{background-color:#ebcccc}.table-responsive{overflow-x:auto;min-height:.01%}@media screen and (max-width:767px){.table-responsive{width:100%;margin-bottom:15px;overflow-y:hidden;-ms-overflow-style:-ms-autohiding-scrollbar;border:1px solid #ddd}.table-responsive>.table{margin-bottom:0}.table-responsive>.table>tbody>tr>td,.table-responsive>.table>tbody>tr>th,.table-responsive>.table>tfoot>tr>td,.table-responsive>.table>tfoot>tr>th,.table-responsive>.table>thead>tr>td,.table-responsive>.table>thead>tr>th{white-space:nowrap}.table-responsive>.table-bordered{border:0}.table-responsive>.table-bordered>tbody>tr>td:first-child,.table-responsive>.table-bordered>tbody>tr>th:first-child,.table-responsive>.table-bordered>tfoot>tr>td:first-child,.table-responsive>.table-bordered>tfoot>tr>th:first-child,.table-responsive>.table-bordered>thead>tr>td:first-child,.table-responsive>.table-bordered>thead>tr>th:first-child{border-left:0}.table-responsive>.table-bordered>tbody>tr>td:last-child,.table-responsive>.table-bordered>tbody>tr>th:last-child,.table-responsive>.table-bordered>tfoot>tr>td:last-child,.table-responsive>.table-bordered>tfoot>tr>th:last-child,.table-responsive>.table-bordered>thead>tr>td:last-child,.table-responsive>.table-bordered>thead>tr>th:last-child{border-right:0}.table-responsive>.table-bordered>tbody>tr:last-child>td,.table-responsive>.table-bordered>tbody>tr:last-child>th,.table-responsive>.table-bordered>tfoot>tr:last-child>td,.table-responsive>.table-bordered>tfoot>tr:last-child>th{border-bottom:0}}fieldset,legend{padding:0;border:0}fieldset{margin:0;min-width:0}legend{width:100%;margin-bottom:20px;font-size:21px;line-height:inherit;border-bottom:1px solid #e5e5e5}label{display:inline-block;margin-bottom:5px}.media-object.img-thumbnail,.nav>li>a>img{max-width:none}input[type=search]{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;-webkit-appearance:none}input[type=checkbox],input[type=radio]{margin:4px 0 0;margin-top:1px\9;line-height:normal}.form-control,output{font-size:14px;line-height:1.42857143;color:#555;display:block}input[type=file]{display:block}input[type=range]{display:block;width:100%}select[multiple],select[size]{height:auto}input[type=file]:focus,input[type=checkbox]:focus,input[type=radio]:focus{outline:dotted thin;outline:-webkit-focus-ring-color auto 5px;outline-offset:-2px}output{padding-top:7px}.form-control{width:100%;height:34px;padding:6px 12px;background-color:#fff;border:1px solid #ccc;border-radius:4px;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075);box-shadow:inset 0 1px 1px rgba(0,0,0,.075);-webkit-transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s;-o-transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s;transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s}.form-control:focus{border-color:#66afe9;outline:0;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 8px rgba(102,175,233,.6);box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 8px rgba(102,175,233,.6)}.form-control::-moz-placeholder{color:#999;opacity:1}.form-control:-ms-input-placeholder{color:#999}.form-control::-webkit-input-placeholder{color:#999}.has-success .checkbox,.has-success .checkbox-inline,.has-success .control-label,.has-success .form-control-feedback,.has-success .help-block,.has-success .radio,.has-success .radio-inline,.has-success.checkbox label,.has-success.checkbox-inline label,.has-success.radio label,.has-success.radio-inline label{color:#3c763d}.form-control::-ms-expand{border:0;background-color:transparent}.form-control[disabled],.form-control[readonly],fieldset[disabled] .form-control{background-color:#eee;opacity:1}.form-control[disabled],fieldset[disabled] .form-control{cursor:not-allowed}textarea.form-control{height:auto}@media screen and (-webkit-min-device-pixel-ratio:0){input[type=date].form-control,input[type=time].form-control,input[type=datetime-local].form-control,input[type=month].form-control{line-height:34px}.input-group-sm input[type=date],.input-group-sm input[type=time],.input-group-sm input[type=datetime-local],.input-group-sm input[type=month],input[type=date].input-sm,input[type=time].input-sm,input[type=datetime-local].input-sm,input[type=month].input-sm{line-height:30px}.input-group-lg input[type=date],.input-group-lg input[type=time],.input-group-lg input[type=datetime-local],.input-group-lg input[type=month],input[type=date].input-lg,input[type=time].input-lg,input[type=datetime-local].input-lg,input[type=month].input-lg{line-height:46px}}.form-group{margin-bottom:15px}.checkbox,.radio{position:relative;display:block;margin-top:10px;margin-bottom:10px}.checkbox label,.radio label{min-height:20px;padding-left:20px;margin-bottom:0;font-weight:400;cursor:pointer}.checkbox input[type=checkbox],.checkbox-inline input[type=checkbox],.radio input[type=radio],.radio-inline input[type=radio]{position:absolute;margin-left:-20px;margin-top:4px\9}.checkbox+.checkbox,.radio+.radio{margin-top:-5px}.checkbox-inline,.radio-inline{position:relative;display:inline-block;padding-left:20px;margin-bottom:0;vertical-align:middle;font-weight:400;cursor:pointer}.checkbox-inline+.checkbox-inline,.radio-inline+.radio-inline{margin-top:0;margin-left:10px}.checkbox-inline.disabled,.checkbox.disabled label,.radio-inline.disabled,.radio.disabled label,fieldset[disabled] .checkbox label,fieldset[disabled] .checkbox-inline,fieldset[disabled] .radio label,fieldset[disabled] .radio-inline,fieldset[disabled] input[type=checkbox],fieldset[disabled] input[type=radio],input[type=checkbox].disabled,input[type=checkbox][disabled],input[type=radio].disabled,input[type=radio][disabled]{cursor:not-allowed}.form-control-static{padding-top:7px;padding-bottom:7px;margin-bottom:0;min-height:34px}.form-control-static.input-lg,.form-control-static.input-sm{padding-left:0;padding-right:0}.form-group-sm .form-control,.input-sm{padding:5px 10px;border-radius:3px;font-size:12px}.input-sm{height:30px;line-height:1.5}select.input-sm{height:30px;line-height:30px}select[multiple].input-sm,textarea.input-sm{height:auto}.form-group-sm .form-control{height:30px;line-height:1.5}.form-group-lg .form-control,.input-lg{border-radius:6px;padding:10px 16px;font-size:18px}.form-group-sm select.form-control{height:30px;line-height:30px}.form-group-sm select[multiple].form-control,.form-group-sm textarea.form-control{height:auto}.form-group-sm .form-control-static{height:30px;min-height:32px;padding:6px 10px;font-size:12px;line-height:1.5}.input-lg{height:46px;line-height:1.3333333}select.input-lg{height:46px;line-height:46px}select[multiple].input-lg,textarea.input-lg{height:auto}.form-group-lg .form-control{height:46px;line-height:1.3333333}.form-group-lg select.form-control{height:46px;line-height:46px}.form-group-lg select[multiple].form-control,.form-group-lg textarea.form-control{height:auto}.form-group-lg .form-control-static{height:46px;min-height:38px;padding:11px 16px;font-size:18px;line-height:1.3333333}.has-feedback{position:relative}.has-feedback .form-control{padding-right:42.5px}.form-control-feedback{position:absolute;top:0;right:0;z-index:2;display:block;width:34px;height:34px;line-height:34px;text-align:center;pointer-events:none}.collapsing,.dropdown,.dropup{position:relative}.form-group-lg .form-control+.form-control-feedback,.input-group-lg+.form-control-feedback,.input-lg+.form-control-feedback{width:46px;height:46px;line-height:46px}.form-group-sm .form-control+.form-control-feedback,.input-group-sm+.form-control-feedback,.input-sm+.form-control-feedback{width:30px;height:30px;line-height:30px}.has-success .form-control{border-color:#3c763d;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075);box-shadow:inset 0 1px 1px rgba(0,0,0,.075)}.has-success .form-control:focus{border-color:#2b542c;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #67b168;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #67b168}.has-success .input-group-addon{color:#3c763d;border-color:#3c763d;background-color:#dff0d8}.has-warning .checkbox,.has-warning .checkbox-inline,.has-warning .control-label,.has-warning .form-control-feedback,.has-warning .help-block,.has-warning .radio,.has-warning .radio-inline,.has-warning.checkbox label,.has-warning.checkbox-inline label,.has-warning.radio label,.has-warning.radio-inline label{color:#8a6d3b}.has-warning .form-control{border-color:#8a6d3b;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075);box-shadow:inset 0 1px 1px rgba(0,0,0,.075)}.has-warning .form-control:focus{border-color:#66512c;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #c0a16b;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #c0a16b}.has-warning .input-group-addon{color:#8a6d3b;border-color:#8a6d3b;background-color:#fcf8e3}.has-error .checkbox,.has-error .checkbox-inline,.has-error .control-label,.has-error .form-control-feedback,.has-error .help-block,.has-error .radio,.has-error .radio-inline,.has-error.checkbox label,.has-error.checkbox-inline label,.has-error.radio label,.has-error.radio-inline label{color:#a94442}.has-error .form-control{border-color:#a94442;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075);box-shadow:inset 0 1px 1px rgba(0,0,0,.075)}.has-error .form-control:focus{border-color:#843534;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #ce8483;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #ce8483}.has-error .input-group-addon{color:#a94442;border-color:#a94442;background-color:#f2dede}.has-feedback label~.form-control-feedback{top:25px}.has-feedback label.sr-only~.form-control-feedback{top:0}.help-block{display:block;margin-top:5px;margin-bottom:10px;color:#737373}@media (min-width:768px){.form-inline .form-control-static,.form-inline .form-group{display:inline-block}.form-inline .control-label,.form-inline .form-group{margin-bottom:0;vertical-align:middle}.form-inline .form-control{display:inline-block;width:auto;vertical-align:middle}.form-inline .input-group{display:inline-table;vertical-align:middle}.form-inline .input-group .form-control,.form-inline .input-group .input-group-addon,.form-inline .input-group .input-group-btn{width:auto}.form-inline .input-group>.form-control{width:100%}.form-inline .checkbox,.form-inline .radio{display:inline-block;margin-top:0;margin-bottom:0;vertical-align:middle}.form-inline .checkbox label,.form-inline .radio label{padding-left:0}.form-inline .checkbox input[type=checkbox],.form-inline .radio input[type=radio]{position:relative;margin-left:0}.form-inline .has-feedback .form-control-feedback{top:0}.form-horizontal .control-label{text-align:right;margin-bottom:0;padding-top:7px}}.btn-block,input[type=button].btn-block,input[type=reset].btn-block,input[type=submit].btn-block{width:100%}.form-horizontal .checkbox,.form-horizontal .checkbox-inline,.form-horizontal .radio,.form-horizontal .radio-inline{margin-top:0;margin-bottom:0;padding-top:7px}.form-horizontal .checkbox,.form-horizontal .radio{min-height:27px}.form-horizontal .form-group{margin-left:-15px;margin-right:-15px}.form-horizontal .has-feedback .form-control-feedback{right:15px}@media (min-width:768px){.form-horizontal .form-group-lg .control-label{padding-top:11px;font-size:18px}.form-horizontal .form-group-sm .control-label{padding-top:6px;font-size:12px}}.btn{display:inline-block;margin-bottom:0;font-weight:400;text-align:center;touch-action:manipulation;cursor:pointer;border:1px solid transparent;white-space:nowrap;padding:6px 12px;font-size:14px;line-height:1.42857143;border-radius:4px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.btn.active.focus,.btn.active:focus,.btn.focus,.btn:active.focus,.btn:active:focus,.btn:focus{outline:dotted thin;outline:-webkit-focus-ring-color auto 5px;outline-offset:-2px}.btn.active,.btn:active,.dropdown-toggle:focus,.modal,.modal-content,.navbar-toggle:focus,.open>a{outline:0}.btn.focus,.btn:focus,.btn:hover{color:#333;text-decoration:none}.btn.active,.btn:active{-webkit-box-shadow:inset 0 3px 5px rgba(0,0,0,.125);box-shadow:inset 0 3px 5px rgba(0,0,0,.125)}.btn.disabled,.btn[disabled],fieldset[disabled] .btn{cursor:not-allowed;opacity:.65;filter:alpha(opacity=65);-webkit-box-shadow:none;box-shadow:none}.btn-default{color:#333;background-color:#fff;border-color:#ccc}.btn-default.focus,.btn-default:focus{color:#333;background-color:#e6e6e6;border-color:#8c8c8c}.btn-default.active,.btn-default:active,.btn-default:hover,.open>.dropdown-toggle.btn-default{color:#333;background-color:#e6e6e6;border-color:#adadad}.btn-default.active.focus,.btn-default.active:focus,.btn-default.active:hover,.btn-default:active.focus,.btn-default:active:focus,.btn-default:active:hover,.open>.dropdown-toggle.btn-default.focus,.open>.dropdown-toggle.btn-default:focus,.open>.dropdown-toggle.btn-default:hover{color:#333;background-color:#d4d4d4;border-color:#8c8c8c}.btn-default.disabled.focus,.btn-default.disabled:focus,.btn-default.disabled:hover,.btn-default[disabled].focus,.btn-default[disabled]:focus,.btn-default[disabled]:hover,fieldset[disabled] .btn-default.focus,fieldset[disabled] .btn-default:focus,fieldset[disabled] .btn-default:hover{background-color:#fff;border-color:#ccc}.btn-default .badge{color:#fff;background-color:#333}.btn-primary{color:#fff;background-color:#337ab7;border-color:#2e6da4}.btn-primary.focus,.btn-primary:focus{color:#fff;background-color:#286090;border-color:#122b40}.btn-primary.active,.btn-primary:active,.btn-primary:hover,.open>.dropdown-toggle.btn-primary{color:#fff;background-color:#286090;border-color:#204d74}.btn-primary.active.focus,.btn-primary.active:focus,.btn-primary.active:hover,.btn-primary:active.focus,.btn-primary:active:focus,.btn-primary:active:hover,.open>.dropdown-toggle.btn-primary.focus,.open>.dropdown-toggle.btn-primary:focus,.open>.dropdown-toggle.btn-primary:hover{color:#fff;background-color:#204d74;border-color:#122b40}.btn-primary.disabled.focus,.btn-primary.disabled:focus,.btn-primary.disabled:hover,.btn-primary[disabled].focus,.btn-primary[disabled]:focus,.btn-primary[disabled]:hover,fieldset[disabled] .btn-primary.focus,fieldset[disabled] .btn-primary:focus,fieldset[disabled] .btn-primary:hover{background-color:#337ab7;border-color:#2e6da4}.btn-primary .badge{color:#337ab7;background-color:#fff}.btn-success{color:#fff;background-color:#5cb85c;border-color:#4cae4c}.btn-success.focus,.btn-success:focus{color:#fff;background-color:#449d44;border-color:#255625}.btn-success.active,.btn-success:active,.btn-success:hover,.open>.dropdown-toggle.btn-success{color:#fff;background-color:#449d44;border-color:#398439}.btn-success.active.focus,.btn-success.active:focus,.btn-success.active:hover,.btn-success:active.focus,.btn-success:active:focus,.btn-success:active:hover,.open>.dropdown-toggle.btn-success.focus,.open>.dropdown-toggle.btn-success:focus,.open>.dropdown-toggle.btn-success:hover{color:#fff;background-color:#398439;border-color:#255625}.btn-success.active,.btn-success:active,.open>.dropdown-toggle.btn-success{background-image:none}.btn-success.disabled.focus,.btn-success.disabled:focus,.btn-success.disabled:hover,.btn-success[disabled].focus,.btn-success[disabled]:focus,.btn-success[disabled]:hover,fieldset[disabled] .btn-success.focus,fieldset[disabled] .btn-success:focus,fieldset[disabled] .btn-success:hover{background-color:#5cb85c;border-color:#4cae4c}.btn-success .badge{color:#5cb85c;background-color:#fff}.btn-info{color:#fff;background-color:#5bc0de;border-color:#46b8da}.btn-info.focus,.btn-info:focus{color:#fff;background-color:#31b0d5;border-color:#1b6d85}.btn-info.active,.btn-info:active,.btn-info:hover,.open>.dropdown-toggle.btn-info{color:#fff;background-color:#31b0d5;border-color:#269abc}.btn-info.active.focus,.btn-info.active:focus,.btn-info.active:hover,.btn-info:active.focus,.btn-info:active:focus,.btn-info:active:hover,.open>.dropdown-toggle.btn-info.focus,.open>.dropdown-toggle.btn-info:focus,.open>.dropdown-toggle.btn-info:hover{color:#fff;background-color:#269abc;border-color:#1b6d85}.btn-info.disabled.focus,.btn-info.disabled:focus,.btn-info.disabled:hover,.btn-info[disabled].focus,.btn-info[disabled]:focus,.btn-info[disabled]:hover,fieldset[disabled] .btn-info.focus,fieldset[disabled] .btn-info:focus,fieldset[disabled] .btn-info:hover{background-color:#5bc0de;border-color:#46b8da}.btn-info .badge{color:#5bc0de;background-color:#fff}.btn-warning{color:#fff;background-color:#f0ad4e;border-color:#eea236}.btn-warning.focus,.btn-warning:focus{color:#fff;background-color:#ec971f;border-color:#985f0d}.btn-warning.active,.btn-warning:active,.btn-warning:hover,.open>.dropdown-toggle.btn-warning{color:#fff;background-color:#ec971f;border-color:#d58512}.btn-warning.active.focus,.btn-warning.active:focus,.btn-warning.active:hover,.btn-warning:active.focus,.btn-warning:active:focus,.btn-warning:active:hover,.open>.dropdown-toggle.btn-warning.focus,.open>.dropdown-toggle.btn-warning:focus,.open>.dropdown-toggle.btn-warning:hover{color:#fff;background-color:#d58512;border-color:#985f0d}.btn-warning.disabled.focus,.btn-warning.disabled:focus,.btn-warning.disabled:hover,.btn-warning[disabled].focus,.btn-warning[disabled]:focus,.btn-warning[disabled]:hover,fieldset[disabled] .btn-warning.focus,fieldset[disabled] .btn-warning:focus,fieldset[disabled] .btn-warning:hover{background-color:#f0ad4e;border-color:#eea236}.btn-warning .badge{color:#f0ad4e;background-color:#fff}.btn-danger{color:#fff;background-color:#d9534f;border-color:#d43f3a}.btn-danger.focus,.btn-danger:focus{color:#fff;background-color:#c9302c;border-color:#761c19}.btn-danger.active,.btn-danger:active,.btn-danger:hover,.open>.dropdown-toggle.btn-danger{color:#fff;background-color:#c9302c;border-color:#ac2925}.btn-danger.active.focus,.btn-danger.active:focus,.btn-danger.active:hover,.btn-danger:active.focus,.btn-danger:active:focus,.btn-danger:active:hover,.open>.dropdown-toggle.btn-danger.focus,.open>.dropdown-toggle.btn-danger:focus,.open>.dropdown-toggle.btn-danger:hover{color:#fff;background-color:#ac2925;border-color:#761c19}.btn-danger.disabled.focus,.btn-danger.disabled:focus,.btn-danger.disabled:hover,.btn-danger[disabled].focus,.btn-danger[disabled]:focus,.btn-danger[disabled]:hover,fieldset[disabled] .btn-danger.focus,fieldset[disabled] .btn-danger:focus,fieldset[disabled] .btn-danger:hover{background-color:#d9534f;border-color:#d43f3a}.btn-danger .badge{color:#d9534f;background-color:#fff}.btn-link{color:#337ab7;font-weight:400;border-radius:0}.alert .alert-link,.close{font-weight:700}.btn-link,.btn-link.active,.btn-link:active,.btn-link[disabled],fieldset[disabled] .btn-link{background-color:transparent;-webkit-box-shadow:none;box-shadow:none}.btn-link,.btn-link:active,.btn-link:focus,.btn-link:hover{border-color:transparent}.btn-link:focus,.btn-link:hover{color:#23527c;text-decoration:underline;background-color:transparent}.btn-link[disabled]:focus,.btn-link[disabled]:hover,fieldset[disabled] .btn-link:focus,fieldset[disabled] .btn-link:hover{color:#777;text-decoration:none}.btn-lg{padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}.btn-sm,.btn-xs{font-size:12px;line-height:1.5;border-radius:3px}.btn-sm{padding:5px 10px}.btn-xs{padding:1px 5px}.btn-block{display:block}.btn-block+.btn-block{margin-top:5px}.fade{opacity:0;-webkit-transition:opacity .15s linear;-o-transition:opacity .15s linear;transition:opacity .15s linear}.fade.in{opacity:1}.collapse{display:none}.collapse.in{display:block}tr.collapse.in{display:table-row}tbody.collapse.in{display:table-row-group}.collapsing{height:0;overflow:hidden;-webkit-transition-property:height,visibility;transition-property:height,visibility;-webkit-transition-duration:.35s;transition-duration:.35s;-webkit-transition-timing-function:ease;transition-timing-function:ease}.caret{display:inline-block;width:0;height:0;margin-left:2px;border-top:4px dashed;border-top:4px solid\9;border-right:4px solid transparent;border-left:4px solid transparent}.dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;display:none;float:left;min-width:160px;padding:5px 0;margin:2px 0 0;list-style:none;font-size:14px;text-align:left;background-color:#fff;border:1px solid #ccc;border:1px solid rgba(0,0,0,.15);border-radius:4px;-webkit-box-shadow:0 6px 12px rgba(0,0,0,.175);box-shadow:0 6px 12px rgba(0,0,0,.175);background-clip:padding-box}.dropdown-menu-right,.dropdown-menu.pull-right{left:auto;right:0}.nav>li,.nav>li>a,.open>.dropdown-menu{display:block}.dropdown-menu .divider{margin:9px 0;background-color:#e5e5e5}.dropdown-menu>li>a:focus,.dropdown-menu>li>a:hover{background-color:#f5f5f5}.dropdown-menu>.active>a,.dropdown-menu>.active>a:focus,.dropdown-menu>.active>a:hover{color:#fff;text-decoration:none;outline:0;background-color:#337ab7}.dropdown-header,.dropdown-menu>.disabled>a,.dropdown-menu>.disabled>a:focus,.dropdown-menu>.disabled>a:hover,.nav>li.disabled>a{color:#777}.dropdown-menu>.disabled>a:focus,.dropdown-menu>.disabled>a:hover{text-decoration:none;background-color:transparent;filter:progid:DXImageTransform.Microsoft.gradient(enabled=false);cursor:not-allowed}.dropdown-menu-left{left:0;right:auto}.dropdown-header{display:block;padding:3px 20px;font-size:12px;line-height:1.42857143;white-space:nowrap}.dropdown-backdrop{position:fixed;left:0;right:0;bottom:0;top:0;z-index:990}.nav>li,.nav>li>a,.navbar{position:relative}.pull-right>.dropdown-menu{right:0;left:auto}.dropup .caret,.navbar-fixed-bottom .dropdown .caret{border-top:0;border-bottom:4px dashed;border-bottom:4px solid\9;content:""}.dropup .dropdown-menu,.navbar-fixed-bottom .dropdown .dropdown-menu{top:auto;bottom:100%;margin-bottom:2px}@media (min-width:768px){.navbar-right .dropdown-menu{left:auto;right:0}.navbar-right .dropdown-menu-left{left:0;right:auto}}.nav-justified>.dropdown .dropdown-menu,.nav-tabs.nav-justified>.dropdown .dropdown-menu{top:auto;left:auto}.nav{margin-bottom:0;padding-left:0;list-style:none}.nav>li>a{padding:10px 15px}.nav>li>a:focus,.nav>li>a:hover{text-decoration:none;background-color:#eee}.nav>li.disabled>a:focus,.nav>li.disabled>a:hover{color:#777;text-decoration:none;background-color:transparent;cursor:not-allowed}.nav .open>a,.nav .open>a:focus,.nav .open>a:hover{background-color:#eee;border-color:#337ab7}.nav .nav-divider{margin:9px 0;background-color:#e5e5e5}.nav-tabs{border-bottom:1px solid #ddd}.nav-tabs>li{float:left;margin-bottom:-1px}.nav-tabs>li>a{margin-right:2px;line-height:1.42857143;border:1px solid transparent;border-radius:4px 4px 0 0}.nav-tabs>li>a:hover{border-color:#eee #eee #ddd}.nav-tabs>li.active>a,.nav-tabs>li.active>a:focus,.nav-tabs>li.active>a:hover{color:#555;background-color:#fff;border:1px solid #ddd;border-bottom-color:transparent;cursor:default}.nav-tabs.nav-justified{width:100%;border-bottom:0}.nav-tabs.nav-justified>li{float:none}.nav-tabs.nav-justified>li>a{text-align:center;margin-bottom:5px;margin-right:0;border-radius:4px}.nav-tabs.nav-justified>.active>a,.nav-tabs.nav-justified>.active>a:focus,.nav-tabs.nav-justified>.active>a:hover{border:1px solid #ddd}@media (min-width:768px){.nav-tabs.nav-justified>li{display:table-cell;width:1%}.nav-tabs.nav-justified>li>a{margin-bottom:0;border-bottom:1px solid #ddd;border-radius:4px 4px 0 0}.nav-tabs.nav-justified>.active>a,.nav-tabs.nav-justified>.active>a:focus,.nav-tabs.nav-justified>.active>a:hover{border-bottom-color:#fff}}.nav-pills>li{float:left}.nav-justified>li,.nav-stacked>li{float:none}.nav-pills>li>a{border-radius:4px}.nav-pills>li+li{margin-left:2px}.nav-pills>li.active>a,.nav-pills>li.active>a:focus,.nav-pills>li.active>a:hover{color:#fff;background-color:#337ab7}.nav-stacked>li+li{margin-top:2px;margin-left:0}.nav-justified{width:100%}.nav-justified>li>a{text-align:center;margin-bottom:5px}.nav-tabs-justified{border-bottom:0}.nav-tabs-justified>li>a{margin-right:0;border-radius:4px}.nav-tabs-justified>.active>a,.nav-tabs-justified>.active>a:focus,.nav-tabs-justified>.active>a:hover{border:1px solid #ddd}@media (min-width:768px){.nav-justified>li{display:table-cell;width:1%}.nav-justified>li>a{margin-bottom:0}.nav-tabs-justified>li>a{border-bottom:1px solid #ddd;border-radius:4px 4px 0 0}.nav-tabs-justified>.active>a,.nav-tabs-justified>.active>a:focus,.nav-tabs-justified>.active>a:hover{border-bottom-color:#fff}}.tab-content>.tab-pane{display:none}.tab-content>.active{display:block}.nav-tabs .dropdown-menu{margin-top:-1px;border-top-right-radius:0;border-top-left-radius:0}.navbar{min-height:50px;border:1px solid transparent}.navbar-collapse{overflow-x:visible;padding-right:15px;padding-left:15px;border-top:1px solid transparent;box-shadow:inset 0 1px 0 rgba(255,255,255,.1);-webkit-overflow-scrolling:touch}.navbar-collapse.in{overflow-y:auto}@media (min-width:768px){.navbar{border-radius:4px}.navbar-header{float:left}.navbar-collapse{width:auto;border-top:0;box-shadow:none}.navbar-collapse.collapse{display:block!important;height:auto!important;padding-bottom:0;overflow:visible!important}.navbar-collapse.in{overflow-y:visible}.navbar-fixed-bottom .navbar-collapse,.navbar-fixed-top .navbar-collapse,.navbar-static-top .navbar-collapse{padding-left:0;padding-right:0}}.modal,.modal-open,.progress{overflow:hidden}@media (max-device-width:480px) and (orientation:landscape){.navbar-fixed-bottom .navbar-collapse,.navbar-fixed-top .navbar-collapse{max-height:200px}}.container-fluid>.navbar-collapse,.container-fluid>.navbar-header,.container>.navbar-collapse,.container>.navbar-header{margin-right:-15px;margin-left:-15px}.navbar-static-top{z-index:1000;border-width:0 0 1px}.navbar-fixed-bottom,.navbar-fixed-top{position:fixed;right:0;left:0;z-index:1030}.navbar-fixed-top{top:0;border-width:0 0 1px}.navbar-fixed-bottom{bottom:0;margin-bottom:0;border-width:1px 0 0}.navbar-brand{float:left;padding:15px;font-size:18px;line-height:20px;height:50px}.navbar-brand:focus,.navbar-brand:hover{text-decoration:none}.navbar-brand>img{display:block}@media (min-width:768px){.container-fluid>.navbar-collapse,.container-fluid>.navbar-header,.container>.navbar-collapse,.container>.navbar-header{margin-right:0;margin-left:0}.navbar-fixed-bottom,.navbar-fixed-top,.navbar-static-top{border-radius:0}.navbar>.container .navbar-brand,.navbar>.container-fluid .navbar-brand{margin-left:-15px}}.navbar-toggle{position:relative;float:right;margin-right:15px;padding:9px 10px;margin-top:8px;margin-bottom:8px;background-color:transparent;border:1px solid transparent;border-radius:4px}.navbar-toggle .icon-bar{display:block;width:22px;height:2px;border-radius:1px}.navbar-toggle .icon-bar+.icon-bar{margin-top:4px}.navbar-nav{margin:7.5px -15px}.navbar-nav>li>a{padding-top:10px;padding-bottom:10px;line-height:20px}@media (max-width:767px){.navbar-nav .open .dropdown-menu{position:static;float:none;width:auto;margin-top:0;background-color:transparent;border:0;box-shadow:none}.navbar-nav .open .dropdown-menu .dropdown-header,.navbar-nav .open .dropdown-menu>li>a{padding:5px 15px 5px 25px}.navbar-nav .open .dropdown-menu>li>a{line-height:20px}.navbar-nav .open .dropdown-menu>li>a:focus,.navbar-nav .open .dropdown-menu>li>a:hover{background-image:none}}.progress-bar-striped,.progress-striped .progress-bar,.progress-striped .progress-bar-success{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}@media (min-width:768px){.navbar-toggle{display:none}.navbar-nav{float:left;margin:0}.navbar-nav>li{float:left}.navbar-nav>li>a{padding-top:15px;padding-bottom:15px}}.navbar-form{padding:10px 15px;border-top:1px solid transparent;border-bottom:1px solid transparent;-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 1px 0 rgba(255,255,255,.1);box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 1px 0 rgba(255,255,255,.1);margin:8px -15px}@media (min-width:768px){.navbar-form .form-control-static,.navbar-form .form-group{display:inline-block}.navbar-form .control-label,.navbar-form .form-group{margin-bottom:0;vertical-align:middle}.navbar-form .form-control{display:inline-block;width:auto;vertical-align:middle}.navbar-form .input-group{display:inline-table;vertical-align:middle}.navbar-form .input-group .form-control,.navbar-form .input-group .input-group-addon,.navbar-form .input-group .input-group-btn{width:auto}.navbar-form .input-group>.form-control{width:100%}.navbar-form .checkbox,.navbar-form .radio{display:inline-block;margin-top:0;margin-bottom:0;vertical-align:middle}.navbar-form .checkbox label,.navbar-form .radio label{padding-left:0}.navbar-form .checkbox input[type=checkbox],.navbar-form .radio input[type=radio]{position:relative;margin-left:0}.navbar-form .has-feedback .form-control-feedback{top:0}.navbar-form{width:auto;border:0;margin-left:0;margin-right:0;padding-top:0;padding-bottom:0;-webkit-box-shadow:none;box-shadow:none}}@media (max-width:767px){.navbar-form .form-group{margin-bottom:5px}.navbar-form .form-group:last-child{margin-bottom:0}}.navbar-nav>li>.dropdown-menu{margin-top:0;border-top-right-radius:0;border-top-left-radius:0}.navbar-fixed-bottom .navbar-nav>li>.dropdown-menu{margin-bottom:0;border-radius:4px 4px 0 0}.navbar-btn{margin-top:8px;margin-bottom:8px}.navbar-btn.btn-sm{margin-top:10px;margin-bottom:10px}.navbar-btn.btn-xs{margin-top:14px;margin-bottom:14px}.navbar-text{margin-top:15px;margin-bottom:15px}@media (min-width:768px){.navbar-text{float:left;margin-left:15px;margin-right:15px}.navbar-left{float:left!important}.navbar-right{float:right!important;margin-right:-15px}.navbar-right~.navbar-right{margin-right:0}}.navbar-default{background-color:#f8f8f8;border-color:#e7e7e7}.navbar-default .navbar-brand{color:#777}.navbar-default .navbar-brand:focus,.navbar-default .navbar-brand:hover{color:#5e5e5e;background-color:transparent}.navbar-default .navbar-nav>li>a,.navbar-default .navbar-text{color:#777}.navbar-default .navbar-nav>li>a:focus,.navbar-default .navbar-nav>li>a:hover{color:#333;background-color:transparent}.navbar-default .navbar-nav>.active>a,.navbar-default .navbar-nav>.active>a:focus,.navbar-default .navbar-nav>.active>a:hover{color:#555;background-color:#e7e7e7}.navbar-default .navbar-nav>.disabled>a,.navbar-default .navbar-nav>.disabled>a:focus,.navbar-default .navbar-nav>.disabled>a:hover{color:#ccc;background-color:transparent}.navbar-default .navbar-toggle{border-color:#ddd}.navbar-default .navbar-toggle:focus,.navbar-default .navbar-toggle:hover{background-color:#ddd}.navbar-default .navbar-toggle .icon-bar{background-color:#888}.navbar-default .navbar-collapse,.navbar-default .navbar-form{border-color:#e7e7e7}.navbar-default .navbar-nav>.open>a,.navbar-default .navbar-nav>.open>a:focus,.navbar-default .navbar-nav>.open>a:hover{background-color:#e7e7e7;color:#555}@media (max-width:767px){.navbar-default .navbar-nav .open .dropdown-menu>li>a{color:#777}.navbar-default .navbar-nav .open .dropdown-menu>li>a:focus,.navbar-default .navbar-nav .open .dropdown-menu>li>a:hover{color:#333;background-color:transparent}.navbar-default .navbar-nav .open .dropdown-menu>.active>a,.navbar-default .navbar-nav .open .dropdown-menu>.active>a:focus,.navbar-default .navbar-nav .open .dropdown-menu>.active>a:hover{color:#555;background-color:#e7e7e7}.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a,.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a:focus,.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a:hover{color:#ccc;background-color:transparent}}.navbar-default .navbar-link{color:#777}.navbar-default .navbar-link:hover{color:#333}.navbar-default .btn-link{color:#777}.navbar-default .btn-link:focus,.navbar-default .btn-link:hover{color:#333}.navbar-default .btn-link[disabled]:focus,.navbar-default .btn-link[disabled]:hover,fieldset[disabled] .navbar-default .btn-link:focus,fieldset[disabled] .navbar-default .btn-link:hover{color:#ccc}.navbar-inverse{background-color:#222;border-color:#080808}.navbar-inverse .navbar-brand{color:#9d9d9d}.navbar-inverse .navbar-brand:focus,.navbar-inverse .navbar-brand:hover{color:#fff;background-color:transparent}.navbar-inverse .navbar-nav>li>a,.navbar-inverse .navbar-text{color:#9d9d9d}.navbar-inverse .navbar-nav>li>a:focus,.navbar-inverse .navbar-nav>li>a:hover{color:#fff;background-color:transparent}.navbar-inverse .navbar-nav>.active>a,.navbar-inverse .navbar-nav>.active>a:focus,.navbar-inverse .navbar-nav>.active>a:hover{color:#fff;background-color:#080808}.navbar-inverse .navbar-nav>.disabled>a,.navbar-inverse .navbar-nav>.disabled>a:focus,.navbar-inverse .navbar-nav>.disabled>a:hover{color:#444;background-color:transparent}.navbar-inverse .navbar-toggle{border-color:#333}.navbar-inverse .navbar-toggle:focus,.navbar-inverse .navbar-toggle:hover{background-color:#333}.navbar-inverse .navbar-toggle .icon-bar{background-color:#fff}.navbar-inverse .navbar-collapse,.navbar-inverse .navbar-form{border-color:#101010}.navbar-inverse .navbar-nav>.open>a,.navbar-inverse .navbar-nav>.open>a:focus,.navbar-inverse .navbar-nav>.open>a:hover{background-color:#080808;color:#fff}@media (max-width:767px){.navbar-inverse .navbar-nav .open .dropdown-menu>.dropdown-header{border-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu .divider{background-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu>li>a{color:#9d9d9d}.navbar-inverse .navbar-nav .open .dropdown-menu>li>a:focus,.navbar-inverse .navbar-nav .open .dropdown-menu>li>a:hover{color:#fff;background-color:transparent}.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a,.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a:focus,.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a:hover{color:#fff;background-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a,.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a:focus,.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a:hover{color:#444;background-color:transparent}}.navbar-inverse .navbar-link{color:#9d9d9d}.navbar-inverse .navbar-link:hover{color:#fff}.navbar-inverse .btn-link{color:#9d9d9d}.navbar-inverse .btn-link:focus,.navbar-inverse .btn-link:hover{color:#fff}.navbar-inverse .btn-link[disabled]:focus,.navbar-inverse .btn-link[disabled]:hover,fieldset[disabled] .navbar-inverse .btn-link:focus,fieldset[disabled] .navbar-inverse .btn-link:hover{color:#444}.alert{padding:15px;margin-bottom:20px;border:1px solid transparent;border-radius:4px}.alert h4{margin-top:0;color:inherit}.alert>p,.alert>ul{margin-bottom:0}.alert>p+p{margin-top:5px}.alert-dismissable,.alert-dismissible{padding-right:35px}.alert-dismissable .close,.alert-dismissible .close{position:relative;top:-2px;right:-21px;color:inherit}.modal,.modal-backdrop{top:0;right:0;bottom:0;left:0}.alert-success{background-color:#dff0d8;border-color:#d6e9c6;color:#3c763d}.alert-success hr{border-top-color:#c9e2b3}.alert-success .alert-link{color:#2b542c}.alert-info{background-color:#d9edf7;border-color:#bce8f1;color:#31708f}.alert-info hr{border-top-color:#a6e1ec}.alert-info .alert-link{color:#245269}.alert-warning{background-color:#fcf8e3;border-color:#faebcc;color:#8a6d3b}.alert-warning hr{border-top-color:#f7e1b5}.alert-warning .alert-link{color:#66512c}.alert-danger{background-color:#f2dede;border-color:#ebccd1;color:#a94442}.alert-danger hr{border-top-color:#e4b9c0}.alert-danger .alert-link{color:#843534}@-webkit-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}.progress{height:20px;margin-bottom:20px;background-color:#f5f5f5;border-radius:4px;-webkit-box-shadow:inset 0 1px 2px rgba(0,0,0,.1);box-shadow:inset 0 1px 2px rgba(0,0,0,.1)}.progress-bar{float:left;width:0;height:100%;font-size:12px;line-height:20px;color:#fff;text-align:center;background-color:#337ab7;-webkit-box-shadow:inset 0 -1px 0 rgba(0,0,0,.15);box-shadow:inset 0 -1px 0 rgba(0,0,0,.15);-webkit-transition:width .6s ease;-o-transition:width .6s ease;transition:width .6s ease}.progress-bar-striped,.progress-striped .progress-bar{background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-size:40px 40px}.progress-bar.active,.progress.active .progress-bar{-webkit-animation:progress-bar-stripes 2s linear infinite;-o-animation:progress-bar-stripes 2s linear infinite;animation:progress-bar-stripes 2s linear infinite}.progress-bar-success{background-color:#5cb85c}.progress-striped .progress-bar-success{background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-striped .progress-bar-info,.progress-striped .progress-bar-warning{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-bar-info{background-color:#5bc0de}.progress-striped .progress-bar-info{background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-bar-warning{background-color:#f0ad4e}.progress-striped .progress-bar-warning{background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-bar-danger{background-color:#d9534f}.progress-striped .progress-bar-danger{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.media{margin-top:15px}.media:first-child{margin-top:0}.media,.media-body{zoom:1;overflow:hidden}.media-body{width:10000px}.media-object{display:block}.media-right,.media>.pull-right{padding-left:10px}.media-left,.media>.pull-left{padding-right:10px}.media-body,.media-left,.media-right{display:table-cell;vertical-align:top}.media-middle{vertical-align:middle}.media-bottom{vertical-align:bottom}.media-heading{margin-top:0;margin-bottom:5px}.media-list{padding-left:0;list-style:none}.well{min-height:20px;padding:19px;margin-bottom:20px;background-color:#f5f5f5;border:1px solid #e3e3e3;border-radius:4px;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.05);box-shadow:inset 0 1px 1px rgba(0,0,0,.05)}.well blockquote{border-color:#ddd;border-color:rgba(0,0,0,.15)}.well-lg{padding:24px;border-radius:6px}.well-sm{padding:9px;border-radius:3px}.close{float:right;font-size:21px;line-height:1;color:#000;text-shadow:0 1px 0 #fff;opacity:.2;filter:alpha(opacity=20)}.close:focus,.close:hover{color:#000;text-decoration:none;cursor:pointer;opacity:.5;filter:alpha(opacity=50)}button.close{padding:0;cursor:pointer;background:0 0;border:0;-webkit-appearance:none}.modal{display:none;position:fixed;z-index:1050;-webkit-overflow-scrolling:touch}.modal.fade .modal-dialog{-webkit-transform:translate(0,-25%);-ms-transform:translate(0,-25%);-o-transform:translate(0,-25%);transform:translate(0,-25%);-webkit-transition:-webkit-transform .3s ease-out;-moz-transition:-moz-transform .3s ease-out;-o-transition:-o-transform .3s ease-out;transition:transform .3s ease-out}.modal.in .modal-dialog{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);-o-transform:translate(0,0);transform:translate(0,0)}.modal-open .modal{overflow-x:hidden;overflow-y:auto}.modal-dialog{position:relative;width:auto;margin:10px}.modal-content{position:relative;background-color:#fff;border:1px solid #999;border:1px solid rgba(0,0,0,.2);border-radius:6px;-webkit-box-shadow:0 3px 9px rgba(0,0,0,.5);box-shadow:0 3px 9px rgba(0,0,0,.5);background-clip:padding-box}.modal-backdrop{position:fixed;z-index:1040;background-color:#000}.modal-backdrop.fade{opacity:0;filter:alpha(opacity=0)}.modal-backdrop.in{opacity:.5;filter:alpha(opacity=50)}.modal-header{padding:15px;border-bottom:1px solid #e5e5e5}.modal-header .close{margin-top:-2px}.modal-title{margin:0;line-height:1.42857143}.modal-body{position:relative;padding:15px}.modal-footer{padding:15px;text-align:right;border-top:1px solid #e5e5e5}.modal-footer .btn+.btn{margin-left:5px;margin-bottom:0}.modal-footer .btn-group .btn+.btn{margin-left:-1px}.modal-footer .btn-block+.btn-block{margin-left:0}.modal-scrollbar-measure{position:absolute;top:-9999px;width:50px;height:50px;overflow:scroll}@media (min-width:768px){.modal-dialog{width:600px;margin:30px auto}.modal-content{-webkit-box-shadow:0 5px 15px rgba(0,0,0,.5);box-shadow:0 5px 15px rgba(0,0,0,.5)}.modal-sm{width:300px}}@media (min-width:992px){.modal-lg{width:900px}}.clearfix:after,.clearfix:before,.container-fluid:after,.container-fluid:before,.container:after,.container:before,.dl-horizontal dd:after,.dl-horizontal dd:before,.form-horizontal .form-group:after,.form-horizontal .form-group:before,.modal-footer:after,.modal-footer:before,.modal-header:after,.modal-header:before,.nav:after,.nav:before,.navbar-collapse:after,.navbar-collapse:before,.navbar-header:after,.navbar-header:before,.navbar:after,.navbar:before,.row:after,.row:before{content:" ";display:table}.clearfix:after,.container-fluid:after,.container:after,.dl-horizontal dd:after,.form-horizontal .form-group:after,.modal-footer:after,.modal-header:after,.nav:after,.navbar-collapse:after,.navbar-header:after,.navbar:after,.row:after{clear:both}.center-block{display:block;margin-left:auto;margin-right:auto}.pull-right{float:right!important}.pull-left{float:left!important}.hide{display:none!important}.show{display:block!important}.hidden,.visible-lg,.visible-lg-block,.visible-lg-inline,.visible-lg-inline-block,.visible-md,.visible-md-block,.visible-md-inline,.visible-md-inline-block,.visible-sm,.visible-sm-block,.visible-sm-inline,.visible-sm-inline-block,.visible-xs,.visible-xs-block,.visible-xs-inline,.visible-xs-inline-block{display:none!important}.invisible{visibility:hidden}.text-hide{font:0/0 a;color:transparent;text-shadow:none;background-color:transparent;border:0}.material-icon,.user-dropdown .dropdown-header strong{font-weight:400}.affix{position:fixed}@-ms-viewport{width:device-width}@media (max-width:767px){.visible-xs{display:block!important}table.visible-xs{display:table!important}tr.visible-xs{display:table-row!important}td.visible-xs,th.visible-xs{display:table-cell!important}.visible-xs-block{display:block!important}.visible-xs-inline{display:inline!important}.visible-xs-inline-block{display:inline-block!important}}@media (min-width:768px) and (max-width:991px){.visible-sm{display:block!important}table.visible-sm{display:table!important}tr.visible-sm{display:table-row!important}td.visible-sm,th.visible-sm{display:table-cell!important}.visible-sm-block{display:block!important}.visible-sm-inline{display:inline!important}.visible-sm-inline-block{display:inline-block!important}}@media (min-width:992px) and (max-width:1199px){.visible-md{display:block!important}table.visible-md{display:table!important}tr.visible-md{display:table-row!important}td.visible-md,th.visible-md{display:table-cell!important}.visible-md-block{display:block!important}.visible-md-inline{display:inline!important}.visible-md-inline-block{display:inline-block!important}}@media (min-width:1200px){.visible-lg{display:block!important}table.visible-lg{display:table!important}tr.visible-lg{display:table-row!important}td.visible-lg,th.visible-lg{display:table-cell!important}.visible-lg-block{display:block!important}.visible-lg-inline{display:inline!important}.visible-lg-inline-block{display:inline-block!important}.hidden-lg{display:none!important}}@media (max-width:767px){.hidden-xs{display:none!important}.navbar.navbar-misago{min-height:auto}}@media (min-width:768px) and (max-width:991px){.hidden-sm{display:none!important}}@media (min-width:992px) and (max-width:1199px){.hidden-md{display:none!important}}.visible-print{display:none!important}@media print{.visible-print{display:block!important}table.visible-print{display:table!important}tr.visible-print{display:table-row!important}td.visible-print,th.visible-print{display:table-cell!important}}.visible-print-block{display:none!important}@media print{.visible-print-block{display:block!important}}.visible-print-inline{display:none!important}@media print{.visible-print-inline{display:inline!important}}.visible-print-inline-block{display:none!important}@media print{.visible-print-inline-block{display:inline-block!important}.hidden-print{display:none!important}}.alerts-snackbar p,.loader-compact>div,.navbar .navbar-full .navbar-brand>*{display:inline-block}.auth-changed-message{width:100%;position:fixed;top:0;left:0;z-index:1070;transition:top .3s ease}.auth-changed-message>div{position:absolute;bottom:0;width:100%;background-color:#eee;padding:20px 0}.auth-changed-message.show>div{top:0;bottom:auto}.auth-changed-message p{padding:10px 0;color:#222;font-size:18px}@media screen and (max-width:991px){.auth-changed-message{text-align:center}.auth-changed-message .btn{padding:10px 16px;font-size:18px}}.alerts-snackbar{position:fixed;top:-100%;width:100%;z-index:1060;text-align:center;font-size:18px;transition:top .3s ease}.alerts-snackbar.in{top:0;transition:top .2s ease}.alerts-snackbar p{border-radius:0 0 4px 4px;margin:0;pointer-events:all}.loader.sk-folding-cube{margin:80px auto;width:80px;height:80px;position:relative;-webkit-transform:rotateZ(45deg);transform:rotateZ(45deg)}.loader.sk-folding-cube .sk-cube{float:left;width:50%;height:50%;position:relative;-webkit-transform:scale(1.1);-ms-transform:scale(1.1);transform:scale(1.1)}.loader.sk-folding-cube .sk-cube:before{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background-color:#777;-webkit-animation:sk-foldCubeAngle 2.4s infinite linear both;animation:sk-foldCubeAngle 2.4s infinite linear both;-webkit-transform-origin:100% 100%;-ms-transform-origin:100% 100%;transform-origin:100% 100%}.loader.sk-folding-cube .sk-cube2{-webkit-transform:scale(1.1) rotateZ(90deg);transform:scale(1.1) rotateZ(90deg)}.loader.sk-folding-cube .sk-cube3{-webkit-transform:scale(1.1) rotateZ(180deg);transform:scale(1.1) rotateZ(180deg)}.loader.sk-folding-cube .sk-cube4{-webkit-transform:scale(1.1) rotateZ(270deg);transform:scale(1.1) rotateZ(270deg)}.loader.sk-folding-cube .sk-cube2:before{-webkit-animation-delay:.3s;animation-delay:.3s}.loader.sk-folding-cube .sk-cube3:before{-webkit-animation-delay:.6s;animation-delay:.6s}.loader.sk-folding-cube .sk-cube4:before{-webkit-animation-delay:.9s;animation-delay:.9s}@-webkit-keyframes sk-foldCubeAngle{0%,10%{-webkit-transform:perspective(140px) rotateX(-180deg);transform:perspective(140px) rotateX(-180deg);opacity:0}25%,75%{-webkit-transform:perspective(140px) rotateX(0);transform:perspective(140px) rotateX(0);opacity:1}100%,90%{-webkit-transform:perspective(140px) rotateY(180deg);transform:perspective(140px) rotateY(180deg);opacity:0}}@keyframes sk-foldCubeAngle{0%,10%{-webkit-transform:perspective(140px) rotateX(-180deg);transform:perspective(140px) rotateX(-180deg);opacity:0}25%,75%{-webkit-transform:perspective(140px) rotateX(0);transform:perspective(140px) rotateX(0);opacity:1}100%,90%{-webkit-transform:perspective(140px) rotateY(180deg);transform:perspective(140px) rotateY(180deg);opacity:0}}.loader-compact{margin:0 auto;width:50px;text-align:center}.loader-compact>div{width:10px;height:10px;background-color:#333;border-radius:100%;-webkit-animation:sk-bouncedelay 1.4s infinite ease-in-out both;animation:sk-bouncedelay 1.4s infinite ease-in-out both}.loader-compact .bounce1{-webkit-animation-delay:-.32s;animation-delay:-.32s}.loader-compact .bounce2{margin:0 4px;-webkit-animation-delay:-.16s;animation-delay:-.16s}@-webkit-keyframes sk-bouncedelay{0%,100%,80%{-webkit-transform:scale(.5)}40%{-webkit-transform:scale(1)}}@keyframes sk-bouncedelay{0%,100%,80%{-webkit-transform:scale(.5);transform:scale(.5)}40%{-webkit-transform:scale(1);transform:scale(1)}}.page-loading .lead{margin-top:-40px;margin-bottom:80px;color:#777;text-align:center}.navbar{margin-bottom:0}.navbar .navbar-full .navbar-brand img{height:16px}.navbar .navbar-full .nav-guest,.navbar .navbar-full .nav-user{float:right}.navbar .navbar-full .nav-guest .navbar-btn,.navbar .navbar-full .nav-user .navbar-btn{margin-left:15px}.navbar .navbar-full .nav-user .dropdown-toggle{padding:8px}.navbar .navbar-full .nav-user .dropdown-toggle img{width:34px;height:34px}.navbar ul.navbar-compact-nav{margin:0;display:table;width:100%}.navbar ul.navbar-compact-nav>li{display:table-cell}.navbar ul.navbar-compact-nav>li>a,.navbar ul.navbar-compact-nav>li>button{background:0 0;border:none;margin:0;padding-top:10px;padding-bottom:10px;width:100%;color:#777;text-align:center}.navbar ul.navbar-compact-nav>li>a:focus,.navbar ul.navbar-compact-nav>li>a:hover,.navbar ul.navbar-compact-nav>li>button:focus,.navbar ul.navbar-compact-nav>li>button:hover{color:#333;background-color:transparent}.navbar ul.navbar-compact-nav>li>a>img,.navbar ul.navbar-compact-nav>li>button>img{width:24px;height:24px}.navbar ul.navbar-compact-nav>li>button{padding-top:10px;padding-bottom:10px}.navbar ul.navbar-compact-nav>li>a>.material-icon{font-size:24px;line-height:24px}@font-face{font-family:'Material Icons';font-style:normal;font-weight:400;src:url(../fonts/MaterialIcons-Regular.eot);src:local('Material Icons'),local('MaterialIcons-Regular'),url(../fonts/MaterialIcons-Regular.woff2) format('woff2'),url(../fonts/MaterialIcons-Regular.woff) format('woff'),url(../fonts/MaterialIcons-Regular.ttf) format('truetype')}.material-icon{font-family:'Material Icons';font-style:normal;display:inline-block;width:1em;height:1em;line-height:1;text-align:center;text-transform:none;letter-spacing:normal;vertical-align:middle;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;-moz-osx-font-smoothing:grayscale;font-feature-settings:'liga'}@media screen and (max-width:991px){.modal-message{text-align:center}.modal-message .message-icon{margin:30px}.modal-message .message-icon .material-icon{font-size:160px}}@media screen and (min-width:992px){.modal-message .message-icon{float:left}.modal-message .message-icon .material-icon{font-size:80px}.modal-message .message-body{margin-left:100px}}@media screen and (max-width:991px){.modal-register .modal-footer{text-align:center}.modal-register .modal-footer a{display:block}.modal-register .modal-footer .btn{display:block;float:none;margin-top:10px;width:100%}}.material-icon.form-control-feedback{top:6px;right:24px;font-size:1.42857143;line-height:1.42857143}.well.well-form.well-done{font-size:18px;text-align:center}.well.well-form.well-done .message-icon{margin-bottom:10px;font-size:90px;line-height:90px}.well.well-form.well-done .message-body{margin-bottom:6.67px}.well.well-form.well-noscript{font-size:18px;text-align:center}.well.well-form.well-noscript .message-icon{margin-bottom:10px;font-size:90px;line-height:90px}.btn.btn-loading,.btn.btn-loading:active,.btn.btn-loading:focus,.btn.btn-loading:hover,.btn.btn-loading:link,.btn.btn-loading:visited{color:transparent}.btn.btn-loading .loader-compact,.btn.btn-loading:active .loader-compact,.btn.btn-loading:focus .loader-compact,.btn.btn-loading:hover .loader-compact,.btn.btn-loading:link .loader-compact,.btn.btn-loading:visited .loader-compact{margin-top:-20px;height:20px;position:relative;top:0}.btn.btn-loading.btn-default .loader-compact>div{background-color:#333}.btn.btn-loading.btn-danger .loader-compact>div,.btn.btn-loading.btn-info .loader-compact>div,.btn.btn-loading.btn-primary .loader-compact>div,.btn.btn-loading.btn-success .loader-compact>div,.btn.btn-loading.btn-warning .loader-compact>div{background-color:#fff}.dropdown-menu>li>.btn-link,.dropdown-menu>li>a{display:block;border:none;clear:both;float:none;padding:4px 20px;width:100%;color:#333;font-weight:400;line-height:1.42857143;text-align:left;white-space:nowrap}.dropdown-menu>li>.btn-link:focus,.dropdown-menu>li>.btn-link:hover,.dropdown-menu>li>a:focus,.dropdown-menu>li>a:hover{background-color:#f5f5f5;color:#262626;text-decoration:none}.dropdown-menu>li>.btn-link .material-icon,.dropdown-menu>li>a .material-icon{margin:-2px 7px -2px 0;position:relative;bottom:1px;font-size:18px}.dropdown-menu .dropdown-footer{padding:6px 20px}.mobile-dropdown{position:static;margin:0}.mobile-dropdown.open>.dropdown-menu{border:none;border-radius:0;-webkit-box-shadow:none;box-shadow:none;display:block;margin:0;width:100%;position:static}.user-dropdown .guest-preview{text-align:center}.user-dropdown .guest-preview .row{margin:0}.navbar .user-dropdown{width:240px}.user-dropdown .dropdown-header{padding:6px 20px;font-size:18px}.misago-footer{margin-top:30px;margin-bottom:50px}.misago-footer .footer-content{border-top:1px solid #eee;padding-top:30px}.misago-footer .noscript-message .material-icon{position:relative;bottom:1px;font-size:18px}@media screen and (max-width:991px){.page-error,.page-message{text-align:center}.page-error .message-icon,.page-message .message-icon{margin:30px}.page-error .message-icon .material-icon,.page-message .message-icon .material-icon{font-size:160px}}@media screen and (min-width:992px){.page-error .message-panel,.page-message .message-panel{margin:60px auto;max-width:779.35px;overflow:auto}.page-error .message-icon,.page-message .message-icon{float:left}.page-error .message-icon .material-icon,.page-message .message-icon .material-icon{font-size:80px}.page-error .message-body,.page-message .message-body{margin-left:100px}}
+/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */
+html {
+  font-family: sans-serif;
+  -ms-text-size-adjust: 100%;
+  -webkit-text-size-adjust: 100%;
+}
+body {
+  margin: 0;
+}
+article,
+aside,
+details,
+figcaption,
+figure,
+footer,
+header,
+hgroup,
+main,
+menu,
+nav,
+section,
+summary {
+  display: block;
+}
+audio,
+canvas,
+progress,
+video {
+  display: inline-block;
+  vertical-align: baseline;
+}
+audio:not([controls]) {
+  display: none;
+  height: 0;
+}
+[hidden],
+template {
+  display: none;
+}
+a {
+  background-color: transparent;
+}
+a:active,
+a:hover {
+  outline: 0;
+}
+abbr[title] {
+  border-bottom: 1px dotted;
+}
+b,
+strong {
+  font-weight: bold;
+}
+dfn {
+  font-style: italic;
+}
+h1 {
+  font-size: 2em;
+  margin: 0.67em 0;
+}
+mark {
+  background: #ff0;
+  color: #000;
+}
+small {
+  font-size: 80%;
+}
+sub,
+sup {
+  font-size: 75%;
+  line-height: 0;
+  position: relative;
+  vertical-align: baseline;
+}
+sup {
+  top: -0.5em;
+}
+sub {
+  bottom: -0.25em;
+}
+img {
+  border: 0;
+}
+svg:not(:root) {
+  overflow: hidden;
+}
+figure {
+  margin: 1em 40px;
+}
+hr {
+  box-sizing: content-box;
+  height: 0;
+}
+pre {
+  overflow: auto;
+}
+code,
+kbd,
+pre,
+samp {
+  font-family: monospace, monospace;
+  font-size: 1em;
+}
+button,
+input,
+optgroup,
+select,
+textarea {
+  color: inherit;
+  font: inherit;
+  margin: 0;
+}
+button {
+  overflow: visible;
+}
+button,
+select {
+  text-transform: none;
+}
+button,
+html input[type="button"],
+input[type="reset"],
+input[type="submit"] {
+  -webkit-appearance: button;
+  cursor: pointer;
+}
+button[disabled],
+html input[disabled] {
+  cursor: default;
+}
+button::-moz-focus-inner,
+input::-moz-focus-inner {
+  border: 0;
+  padding: 0;
+}
+input {
+  line-height: normal;
+}
+input[type="checkbox"],
+input[type="radio"] {
+  box-sizing: border-box;
+  padding: 0;
+}
+input[type="number"]::-webkit-inner-spin-button,
+input[type="number"]::-webkit-outer-spin-button {
+  height: auto;
+}
+input[type="search"] {
+  -webkit-appearance: textfield;
+  box-sizing: content-box;
+}
+input[type="search"]::-webkit-search-cancel-button,
+input[type="search"]::-webkit-search-decoration {
+  -webkit-appearance: none;
+}
+fieldset {
+  border: 1px solid #c0c0c0;
+  margin: 0 2px;
+  padding: 0.35em 0.625em 0.75em;
+}
+legend {
+  border: 0;
+  padding: 0;
+}
+textarea {
+  overflow: auto;
+}
+optgroup {
+  font-weight: bold;
+}
+table {
+  border-collapse: collapse;
+  border-spacing: 0;
+}
+td,
+th {
+  padding: 0;
+}
+/*! Source: https://github.com/h5bp/html5-boilerplate/blob/master/src/css/main.css */
+@media print {
+  *,
+  *:before,
+  *:after {
+    background: transparent !important;
+    color: #000 !important;
+    box-shadow: none !important;
+    text-shadow: none !important;
+  }
+  a,
+  a:visited {
+    text-decoration: underline;
+  }
+  a[href]:after {
+    content: " (" attr(href) ")";
+  }
+  abbr[title]:after {
+    content: " (" attr(title) ")";
+  }
+  a[href^="#"]:after,
+  a[href^="javascript:"]:after {
+    content: "";
+  }
+  pre,
+  blockquote {
+    border: 1px solid #999;
+    page-break-inside: avoid;
+  }
+  thead {
+    display: table-header-group;
+  }
+  tr,
+  img {
+    page-break-inside: avoid;
+  }
+  img {
+    max-width: 100% !important;
+  }
+  p,
+  h2,
+  h3 {
+    orphans: 3;
+    widows: 3;
+  }
+  h2,
+  h3 {
+    page-break-after: avoid;
+  }
+  .navbar {
+    display: none;
+  }
+  .btn > .caret,
+  .dropup > .btn > .caret {
+    border-top-color: #000 !important;
+  }
+  .label {
+    border: 1px solid #000;
+  }
+  .table {
+    border-collapse: collapse !important;
+  }
+  .table td,
+  .table th {
+    background-color: #fff !important;
+  }
+  .table-bordered th,
+  .table-bordered td {
+    border: 1px solid #ddd !important;
+  }
+}
+* {
+  -webkit-box-sizing: border-box;
+  -moz-box-sizing: border-box;
+  box-sizing: border-box;
+}
+*:before,
+*:after {
+  -webkit-box-sizing: border-box;
+  -moz-box-sizing: border-box;
+  box-sizing: border-box;
+}
+html {
+  font-size: 10px;
+  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
+}
+body {
+  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
+  font-size: 14px;
+  line-height: 1.42857143;
+  color: #333333;
+  background-color: #fff;
+}
+input,
+button,
+select,
+textarea {
+  font-family: inherit;
+  font-size: inherit;
+  line-height: inherit;
+}
+a {
+  color: #337ab7;
+  text-decoration: none;
+}
+a:hover,
+a:focus {
+  color: #23527c;
+  text-decoration: underline;
+}
+a:focus {
+  outline: thin dotted;
+  outline: 5px auto -webkit-focus-ring-color;
+  outline-offset: -2px;
+}
+figure {
+  margin: 0;
+}
+img {
+  vertical-align: middle;
+}
+.img-responsive {
+  display: block;
+  max-width: 100%;
+  height: auto;
+}
+.img-rounded {
+  border-radius: 6px;
+}
+.img-thumbnail {
+  padding: 4px;
+  line-height: 1.42857143;
+  background-color: #fff;
+  border: 1px solid #ddd;
+  border-radius: 4px;
+  -webkit-transition: all 0.2s ease-in-out;
+  -o-transition: all 0.2s ease-in-out;
+  transition: all 0.2s ease-in-out;
+  display: inline-block;
+  max-width: 100%;
+  height: auto;
+}
+.img-circle {
+  border-radius: 50%;
+}
+hr {
+  margin-top: 20px;
+  margin-bottom: 20px;
+  border: 0;
+  border-top: 1px solid #eeeeee;
+}
+.sr-only {
+  position: absolute;
+  width: 1px;
+  height: 1px;
+  margin: -1px;
+  padding: 0;
+  overflow: hidden;
+  clip: rect(0, 0, 0, 0);
+  border: 0;
+}
+.sr-only-focusable:active,
+.sr-only-focusable:focus {
+  position: static;
+  width: auto;
+  height: auto;
+  margin: 0;
+  overflow: visible;
+  clip: auto;
+}
+[role="button"] {
+  cursor: pointer;
+}
+h1,
+h2,
+h3,
+h4,
+h5,
+h6,
+.h1,
+.h2,
+.h3,
+.h4,
+.h5,
+.h6 {
+  font-family: inherit;
+  font-weight: 500;
+  line-height: 1.1;
+  color: inherit;
+}
+h1 small,
+h2 small,
+h3 small,
+h4 small,
+h5 small,
+h6 small,
+.h1 small,
+.h2 small,
+.h3 small,
+.h4 small,
+.h5 small,
+.h6 small,
+h1 .small,
+h2 .small,
+h3 .small,
+h4 .small,
+h5 .small,
+h6 .small,
+.h1 .small,
+.h2 .small,
+.h3 .small,
+.h4 .small,
+.h5 .small,
+.h6 .small {
+  font-weight: normal;
+  line-height: 1;
+  color: #777777;
+}
+h1,
+.h1,
+h2,
+.h2,
+h3,
+.h3 {
+  margin-top: 20px;
+  margin-bottom: 10px;
+}
+h1 small,
+.h1 small,
+h2 small,
+.h2 small,
+h3 small,
+.h3 small,
+h1 .small,
+.h1 .small,
+h2 .small,
+.h2 .small,
+h3 .small,
+.h3 .small {
+  font-size: 65%;
+}
+h4,
+.h4,
+h5,
+.h5,
+h6,
+.h6 {
+  margin-top: 10px;
+  margin-bottom: 10px;
+}
+h4 small,
+.h4 small,
+h5 small,
+.h5 small,
+h6 small,
+.h6 small,
+h4 .small,
+.h4 .small,
+h5 .small,
+.h5 .small,
+h6 .small,
+.h6 .small {
+  font-size: 75%;
+}
+h1,
+.h1 {
+  font-size: 36px;
+}
+h2,
+.h2 {
+  font-size: 30px;
+}
+h3,
+.h3 {
+  font-size: 24px;
+}
+h4,
+.h4 {
+  font-size: 18px;
+}
+h5,
+.h5 {
+  font-size: 14px;
+}
+h6,
+.h6 {
+  font-size: 12px;
+}
+p {
+  margin: 0 0 10px;
+}
+.lead {
+  margin-bottom: 20px;
+  font-size: 16px;
+  font-weight: 300;
+  line-height: 1.4;
+}
+@media (min-width: 768px) {
+  .lead {
+    font-size: 21px;
+  }
+}
+small,
+.small {
+  font-size: 85%;
+}
+mark,
+.mark {
+  background-color: #fcf8e3;
+  padding: .2em;
+}
+.text-left {
+  text-align: left;
+}
+.text-right {
+  text-align: right;
+}
+.text-center {
+  text-align: center;
+}
+.text-justify {
+  text-align: justify;
+}
+.text-nowrap {
+  white-space: nowrap;
+}
+.text-lowercase {
+  text-transform: lowercase;
+}
+.text-uppercase {
+  text-transform: uppercase;
+}
+.text-capitalize {
+  text-transform: capitalize;
+}
+.text-muted {
+  color: #777777;
+}
+.text-primary {
+  color: #337ab7;
+}
+a.text-primary:hover,
+a.text-primary:focus {
+  color: #286090;
+}
+.text-success {
+  color: #3c763d;
+}
+a.text-success:hover,
+a.text-success:focus {
+  color: #2b542c;
+}
+.text-info {
+  color: #31708f;
+}
+a.text-info:hover,
+a.text-info:focus {
+  color: #245269;
+}
+.text-warning {
+  color: #8a6d3b;
+}
+a.text-warning:hover,
+a.text-warning:focus {
+  color: #66512c;
+}
+.text-danger {
+  color: #a94442;
+}
+a.text-danger:hover,
+a.text-danger:focus {
+  color: #843534;
+}
+.bg-primary {
+  color: #fff;
+  background-color: #337ab7;
+}
+a.bg-primary:hover,
+a.bg-primary:focus {
+  background-color: #286090;
+}
+.bg-success {
+  background-color: #dff0d8;
+}
+a.bg-success:hover,
+a.bg-success:focus {
+  background-color: #c1e2b3;
+}
+.bg-info {
+  background-color: #d9edf7;
+}
+a.bg-info:hover,
+a.bg-info:focus {
+  background-color: #afd9ee;
+}
+.bg-warning {
+  background-color: #fcf8e3;
+}
+a.bg-warning:hover,
+a.bg-warning:focus {
+  background-color: #f7ecb5;
+}
+.bg-danger {
+  background-color: #f2dede;
+}
+a.bg-danger:hover,
+a.bg-danger:focus {
+  background-color: #e4b9b9;
+}
+.page-header {
+  padding-bottom: 9px;
+  margin: 40px 0 20px;
+  border-bottom: 1px solid #eeeeee;
+}
+ul,
+ol {
+  margin-top: 0;
+  margin-bottom: 10px;
+}
+ul ul,
+ol ul,
+ul ol,
+ol ol {
+  margin-bottom: 0;
+}
+.list-unstyled {
+  padding-left: 0;
+  list-style: none;
+}
+.list-inline {
+  padding-left: 0;
+  list-style: none;
+  margin-left: -5px;
+}
+.list-inline > li {
+  display: inline-block;
+  padding-left: 5px;
+  padding-right: 5px;
+}
+dl {
+  margin-top: 0;
+  margin-bottom: 20px;
+}
+dt,
+dd {
+  line-height: 1.42857143;
+}
+dt {
+  font-weight: bold;
+}
+dd {
+  margin-left: 0;
+}
+@media (min-width: 768px) {
+  .dl-horizontal dt {
+    float: left;
+    width: 160px;
+    clear: left;
+    text-align: right;
+    overflow: hidden;
+    text-overflow: ellipsis;
+    white-space: nowrap;
+  }
+  .dl-horizontal dd {
+    margin-left: 180px;
+  }
+}
+abbr[title],
+abbr[data-original-title] {
+  cursor: help;
+  border-bottom: 1px dotted #777777;
+}
+.initialism {
+  font-size: 90%;
+  text-transform: uppercase;
+}
+blockquote {
+  padding: 10px 20px;
+  margin: 0 0 20px;
+  font-size: 17.5px;
+  border-left: 5px solid #eeeeee;
+}
+blockquote p:last-child,
+blockquote ul:last-child,
+blockquote ol:last-child {
+  margin-bottom: 0;
+}
+blockquote footer,
+blockquote small,
+blockquote .small {
+  display: block;
+  font-size: 80%;
+  line-height: 1.42857143;
+  color: #777777;
+}
+blockquote footer:before,
+blockquote small:before,
+blockquote .small:before {
+  content: '\2014 \00A0';
+}
+.blockquote-reverse,
+blockquote.pull-right {
+  padding-right: 15px;
+  padding-left: 0;
+  border-right: 5px solid #eeeeee;
+  border-left: 0;
+  text-align: right;
+}
+.blockquote-reverse footer:before,
+blockquote.pull-right footer:before,
+.blockquote-reverse small:before,
+blockquote.pull-right small:before,
+.blockquote-reverse .small:before,
+blockquote.pull-right .small:before {
+  content: '';
+}
+.blockquote-reverse footer:after,
+blockquote.pull-right footer:after,
+.blockquote-reverse small:after,
+blockquote.pull-right small:after,
+.blockquote-reverse .small:after,
+blockquote.pull-right .small:after {
+  content: '\00A0 \2014';
+}
+address {
+  margin-bottom: 20px;
+  font-style: normal;
+  line-height: 1.42857143;
+}
+code,
+kbd,
+pre,
+samp {
+  font-family: Menlo, Monaco, Consolas, "Courier New", monospace;
+}
+code {
+  padding: 2px 4px;
+  font-size: 90%;
+  color: #c7254e;
+  background-color: #f9f2f4;
+  border-radius: 4px;
+}
+kbd {
+  padding: 2px 4px;
+  font-size: 90%;
+  color: #fff;
+  background-color: #333;
+  border-radius: 3px;
+  box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.25);
+}
+kbd kbd {
+  padding: 0;
+  font-size: 100%;
+  font-weight: bold;
+  box-shadow: none;
+}
+pre {
+  display: block;
+  padding: 9.5px;
+  margin: 0 0 10px;
+  font-size: 13px;
+  line-height: 1.42857143;
+  word-break: break-all;
+  word-wrap: break-word;
+  color: #333333;
+  background-color: #f5f5f5;
+  border: 1px solid #ccc;
+  border-radius: 4px;
+}
+pre code {
+  padding: 0;
+  font-size: inherit;
+  color: inherit;
+  white-space: pre-wrap;
+  background-color: transparent;
+  border-radius: 0;
+}
+.pre-scrollable {
+  max-height: 340px;
+  overflow-y: scroll;
+}
+.container {
+  margin-right: auto;
+  margin-left: auto;
+  padding-left: 15px;
+  padding-right: 15px;
+}
+@media (min-width: 768px) {
+  .container {
+    width: 750px;
+  }
+}
+@media (min-width: 992px) {
+  .container {
+    width: 970px;
+  }
+}
+@media (min-width: 1200px) {
+  .container {
+    width: 1170px;
+  }
+}
+.container-fluid {
+  margin-right: auto;
+  margin-left: auto;
+  padding-left: 15px;
+  padding-right: 15px;
+}
+.row {
+  margin-left: -15px;
+  margin-right: -15px;
+}
+.col-xs-1, .col-sm-1, .col-md-1, .col-lg-1, .col-xs-2, .col-sm-2, .col-md-2, .col-lg-2, .col-xs-3, .col-sm-3, .col-md-3, .col-lg-3, .col-xs-4, .col-sm-4, .col-md-4, .col-lg-4, .col-xs-5, .col-sm-5, .col-md-5, .col-lg-5, .col-xs-6, .col-sm-6, .col-md-6, .col-lg-6, .col-xs-7, .col-sm-7, .col-md-7, .col-lg-7, .col-xs-8, .col-sm-8, .col-md-8, .col-lg-8, .col-xs-9, .col-sm-9, .col-md-9, .col-lg-9, .col-xs-10, .col-sm-10, .col-md-10, .col-lg-10, .col-xs-11, .col-sm-11, .col-md-11, .col-lg-11, .col-xs-12, .col-sm-12, .col-md-12, .col-lg-12 {
+  position: relative;
+  min-height: 1px;
+  padding-left: 15px;
+  padding-right: 15px;
+}
+.col-xs-1, .col-xs-2, .col-xs-3, .col-xs-4, .col-xs-5, .col-xs-6, .col-xs-7, .col-xs-8, .col-xs-9, .col-xs-10, .col-xs-11, .col-xs-12 {
+  float: left;
+}
+.col-xs-12 {
+  width: 100%;
+}
+.col-xs-11 {
+  width: 91.66666667%;
+}
+.col-xs-10 {
+  width: 83.33333333%;
+}
+.col-xs-9 {
+  width: 75%;
+}
+.col-xs-8 {
+  width: 66.66666667%;
+}
+.col-xs-7 {
+  width: 58.33333333%;
+}
+.col-xs-6 {
+  width: 50%;
+}
+.col-xs-5 {
+  width: 41.66666667%;
+}
+.col-xs-4 {
+  width: 33.33333333%;
+}
+.col-xs-3 {
+  width: 25%;
+}
+.col-xs-2 {
+  width: 16.66666667%;
+}
+.col-xs-1 {
+  width: 8.33333333%;
+}
+.col-xs-pull-12 {
+  right: 100%;
+}
+.col-xs-pull-11 {
+  right: 91.66666667%;
+}
+.col-xs-pull-10 {
+  right: 83.33333333%;
+}
+.col-xs-pull-9 {
+  right: 75%;
+}
+.col-xs-pull-8 {
+  right: 66.66666667%;
+}
+.col-xs-pull-7 {
+  right: 58.33333333%;
+}
+.col-xs-pull-6 {
+  right: 50%;
+}
+.col-xs-pull-5 {
+  right: 41.66666667%;
+}
+.col-xs-pull-4 {
+  right: 33.33333333%;
+}
+.col-xs-pull-3 {
+  right: 25%;
+}
+.col-xs-pull-2 {
+  right: 16.66666667%;
+}
+.col-xs-pull-1 {
+  right: 8.33333333%;
+}
+.col-xs-pull-0 {
+  right: auto;
+}
+.col-xs-push-12 {
+  left: 100%;
+}
+.col-xs-push-11 {
+  left: 91.66666667%;
+}
+.col-xs-push-10 {
+  left: 83.33333333%;
+}
+.col-xs-push-9 {
+  left: 75%;
+}
+.col-xs-push-8 {
+  left: 66.66666667%;
+}
+.col-xs-push-7 {
+  left: 58.33333333%;
+}
+.col-xs-push-6 {
+  left: 50%;
+}
+.col-xs-push-5 {
+  left: 41.66666667%;
+}
+.col-xs-push-4 {
+  left: 33.33333333%;
+}
+.col-xs-push-3 {
+  left: 25%;
+}
+.col-xs-push-2 {
+  left: 16.66666667%;
+}
+.col-xs-push-1 {
+  left: 8.33333333%;
+}
+.col-xs-push-0 {
+  left: auto;
+}
+.col-xs-offset-12 {
+  margin-left: 100%;
+}
+.col-xs-offset-11 {
+  margin-left: 91.66666667%;
+}
+.col-xs-offset-10 {
+  margin-left: 83.33333333%;
+}
+.col-xs-offset-9 {
+  margin-left: 75%;
+}
+.col-xs-offset-8 {
+  margin-left: 66.66666667%;
+}
+.col-xs-offset-7 {
+  margin-left: 58.33333333%;
+}
+.col-xs-offset-6 {
+  margin-left: 50%;
+}
+.col-xs-offset-5 {
+  margin-left: 41.66666667%;
+}
+.col-xs-offset-4 {
+  margin-left: 33.33333333%;
+}
+.col-xs-offset-3 {
+  margin-left: 25%;
+}
+.col-xs-offset-2 {
+  margin-left: 16.66666667%;
+}
+.col-xs-offset-1 {
+  margin-left: 8.33333333%;
+}
+.col-xs-offset-0 {
+  margin-left: 0%;
+}
+@media (min-width: 768px) {
+  .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12 {
+    float: left;
+  }
+  .col-sm-12 {
+    width: 100%;
+  }
+  .col-sm-11 {
+    width: 91.66666667%;
+  }
+  .col-sm-10 {
+    width: 83.33333333%;
+  }
+  .col-sm-9 {
+    width: 75%;
+  }
+  .col-sm-8 {
+    width: 66.66666667%;
+  }
+  .col-sm-7 {
+    width: 58.33333333%;
+  }
+  .col-sm-6 {
+    width: 50%;
+  }
+  .col-sm-5 {
+    width: 41.66666667%;
+  }
+  .col-sm-4 {
+    width: 33.33333333%;
+  }
+  .col-sm-3 {
+    width: 25%;
+  }
+  .col-sm-2 {
+    width: 16.66666667%;
+  }
+  .col-sm-1 {
+    width: 8.33333333%;
+  }
+  .col-sm-pull-12 {
+    right: 100%;
+  }
+  .col-sm-pull-11 {
+    right: 91.66666667%;
+  }
+  .col-sm-pull-10 {
+    right: 83.33333333%;
+  }
+  .col-sm-pull-9 {
+    right: 75%;
+  }
+  .col-sm-pull-8 {
+    right: 66.66666667%;
+  }
+  .col-sm-pull-7 {
+    right: 58.33333333%;
+  }
+  .col-sm-pull-6 {
+    right: 50%;
+  }
+  .col-sm-pull-5 {
+    right: 41.66666667%;
+  }
+  .col-sm-pull-4 {
+    right: 33.33333333%;
+  }
+  .col-sm-pull-3 {
+    right: 25%;
+  }
+  .col-sm-pull-2 {
+    right: 16.66666667%;
+  }
+  .col-sm-pull-1 {
+    right: 8.33333333%;
+  }
+  .col-sm-pull-0 {
+    right: auto;
+  }
+  .col-sm-push-12 {
+    left: 100%;
+  }
+  .col-sm-push-11 {
+    left: 91.66666667%;
+  }
+  .col-sm-push-10 {
+    left: 83.33333333%;
+  }
+  .col-sm-push-9 {
+    left: 75%;
+  }
+  .col-sm-push-8 {
+    left: 66.66666667%;
+  }
+  .col-sm-push-7 {
+    left: 58.33333333%;
+  }
+  .col-sm-push-6 {
+    left: 50%;
+  }
+  .col-sm-push-5 {
+    left: 41.66666667%;
+  }
+  .col-sm-push-4 {
+    left: 33.33333333%;
+  }
+  .col-sm-push-3 {
+    left: 25%;
+  }
+  .col-sm-push-2 {
+    left: 16.66666667%;
+  }
+  .col-sm-push-1 {
+    left: 8.33333333%;
+  }
+  .col-sm-push-0 {
+    left: auto;
+  }
+  .col-sm-offset-12 {
+    margin-left: 100%;
+  }
+  .col-sm-offset-11 {
+    margin-left: 91.66666667%;
+  }
+  .col-sm-offset-10 {
+    margin-left: 83.33333333%;
+  }
+  .col-sm-offset-9 {
+    margin-left: 75%;
+  }
+  .col-sm-offset-8 {
+    margin-left: 66.66666667%;
+  }
+  .col-sm-offset-7 {
+    margin-left: 58.33333333%;
+  }
+  .col-sm-offset-6 {
+    margin-left: 50%;
+  }
+  .col-sm-offset-5 {
+    margin-left: 41.66666667%;
+  }
+  .col-sm-offset-4 {
+    margin-left: 33.33333333%;
+  }
+  .col-sm-offset-3 {
+    margin-left: 25%;
+  }
+  .col-sm-offset-2 {
+    margin-left: 16.66666667%;
+  }
+  .col-sm-offset-1 {
+    margin-left: 8.33333333%;
+  }
+  .col-sm-offset-0 {
+    margin-left: 0%;
+  }
+}
+@media (min-width: 992px) {
+  .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12 {
+    float: left;
+  }
+  .col-md-12 {
+    width: 100%;
+  }
+  .col-md-11 {
+    width: 91.66666667%;
+  }
+  .col-md-10 {
+    width: 83.33333333%;
+  }
+  .col-md-9 {
+    width: 75%;
+  }
+  .col-md-8 {
+    width: 66.66666667%;
+  }
+  .col-md-7 {
+    width: 58.33333333%;
+  }
+  .col-md-6 {
+    width: 50%;
+  }
+  .col-md-5 {
+    width: 41.66666667%;
+  }
+  .col-md-4 {
+    width: 33.33333333%;
+  }
+  .col-md-3 {
+    width: 25%;
+  }
+  .col-md-2 {
+    width: 16.66666667%;
+  }
+  .col-md-1 {
+    width: 8.33333333%;
+  }
+  .col-md-pull-12 {
+    right: 100%;
+  }
+  .col-md-pull-11 {
+    right: 91.66666667%;
+  }
+  .col-md-pull-10 {
+    right: 83.33333333%;
+  }
+  .col-md-pull-9 {
+    right: 75%;
+  }
+  .col-md-pull-8 {
+    right: 66.66666667%;
+  }
+  .col-md-pull-7 {
+    right: 58.33333333%;
+  }
+  .col-md-pull-6 {
+    right: 50%;
+  }
+  .col-md-pull-5 {
+    right: 41.66666667%;
+  }
+  .col-md-pull-4 {
+    right: 33.33333333%;
+  }
+  .col-md-pull-3 {
+    right: 25%;
+  }
+  .col-md-pull-2 {
+    right: 16.66666667%;
+  }
+  .col-md-pull-1 {
+    right: 8.33333333%;
+  }
+  .col-md-pull-0 {
+    right: auto;
+  }
+  .col-md-push-12 {
+    left: 100%;
+  }
+  .col-md-push-11 {
+    left: 91.66666667%;
+  }
+  .col-md-push-10 {
+    left: 83.33333333%;
+  }
+  .col-md-push-9 {
+    left: 75%;
+  }
+  .col-md-push-8 {
+    left: 66.66666667%;
+  }
+  .col-md-push-7 {
+    left: 58.33333333%;
+  }
+  .col-md-push-6 {
+    left: 50%;
+  }
+  .col-md-push-5 {
+    left: 41.66666667%;
+  }
+  .col-md-push-4 {
+    left: 33.33333333%;
+  }
+  .col-md-push-3 {
+    left: 25%;
+  }
+  .col-md-push-2 {
+    left: 16.66666667%;
+  }
+  .col-md-push-1 {
+    left: 8.33333333%;
+  }
+  .col-md-push-0 {
+    left: auto;
+  }
+  .col-md-offset-12 {
+    margin-left: 100%;
+  }
+  .col-md-offset-11 {
+    margin-left: 91.66666667%;
+  }
+  .col-md-offset-10 {
+    margin-left: 83.33333333%;
+  }
+  .col-md-offset-9 {
+    margin-left: 75%;
+  }
+  .col-md-offset-8 {
+    margin-left: 66.66666667%;
+  }
+  .col-md-offset-7 {
+    margin-left: 58.33333333%;
+  }
+  .col-md-offset-6 {
+    margin-left: 50%;
+  }
+  .col-md-offset-5 {
+    margin-left: 41.66666667%;
+  }
+  .col-md-offset-4 {
+    margin-left: 33.33333333%;
+  }
+  .col-md-offset-3 {
+    margin-left: 25%;
+  }
+  .col-md-offset-2 {
+    margin-left: 16.66666667%;
+  }
+  .col-md-offset-1 {
+    margin-left: 8.33333333%;
+  }
+  .col-md-offset-0 {
+    margin-left: 0%;
+  }
+}
+@media (min-width: 1200px) {
+  .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12 {
+    float: left;
+  }
+  .col-lg-12 {
+    width: 100%;
+  }
+  .col-lg-11 {
+    width: 91.66666667%;
+  }
+  .col-lg-10 {
+    width: 83.33333333%;
+  }
+  .col-lg-9 {
+    width: 75%;
+  }
+  .col-lg-8 {
+    width: 66.66666667%;
+  }
+  .col-lg-7 {
+    width: 58.33333333%;
+  }
+  .col-lg-6 {
+    width: 50%;
+  }
+  .col-lg-5 {
+    width: 41.66666667%;
+  }
+  .col-lg-4 {
+    width: 33.33333333%;
+  }
+  .col-lg-3 {
+    width: 25%;
+  }
+  .col-lg-2 {
+    width: 16.66666667%;
+  }
+  .col-lg-1 {
+    width: 8.33333333%;
+  }
+  .col-lg-pull-12 {
+    right: 100%;
+  }
+  .col-lg-pull-11 {
+    right: 91.66666667%;
+  }
+  .col-lg-pull-10 {
+    right: 83.33333333%;
+  }
+  .col-lg-pull-9 {
+    right: 75%;
+  }
+  .col-lg-pull-8 {
+    right: 66.66666667%;
+  }
+  .col-lg-pull-7 {
+    right: 58.33333333%;
+  }
+  .col-lg-pull-6 {
+    right: 50%;
+  }
+  .col-lg-pull-5 {
+    right: 41.66666667%;
+  }
+  .col-lg-pull-4 {
+    right: 33.33333333%;
+  }
+  .col-lg-pull-3 {
+    right: 25%;
+  }
+  .col-lg-pull-2 {
+    right: 16.66666667%;
+  }
+  .col-lg-pull-1 {
+    right: 8.33333333%;
+  }
+  .col-lg-pull-0 {
+    right: auto;
+  }
+  .col-lg-push-12 {
+    left: 100%;
+  }
+  .col-lg-push-11 {
+    left: 91.66666667%;
+  }
+  .col-lg-push-10 {
+    left: 83.33333333%;
+  }
+  .col-lg-push-9 {
+    left: 75%;
+  }
+  .col-lg-push-8 {
+    left: 66.66666667%;
+  }
+  .col-lg-push-7 {
+    left: 58.33333333%;
+  }
+  .col-lg-push-6 {
+    left: 50%;
+  }
+  .col-lg-push-5 {
+    left: 41.66666667%;
+  }
+  .col-lg-push-4 {
+    left: 33.33333333%;
+  }
+  .col-lg-push-3 {
+    left: 25%;
+  }
+  .col-lg-push-2 {
+    left: 16.66666667%;
+  }
+  .col-lg-push-1 {
+    left: 8.33333333%;
+  }
+  .col-lg-push-0 {
+    left: auto;
+  }
+  .col-lg-offset-12 {
+    margin-left: 100%;
+  }
+  .col-lg-offset-11 {
+    margin-left: 91.66666667%;
+  }
+  .col-lg-offset-10 {
+    margin-left: 83.33333333%;
+  }
+  .col-lg-offset-9 {
+    margin-left: 75%;
+  }
+  .col-lg-offset-8 {
+    margin-left: 66.66666667%;
+  }
+  .col-lg-offset-7 {
+    margin-left: 58.33333333%;
+  }
+  .col-lg-offset-6 {
+    margin-left: 50%;
+  }
+  .col-lg-offset-5 {
+    margin-left: 41.66666667%;
+  }
+  .col-lg-offset-4 {
+    margin-left: 33.33333333%;
+  }
+  .col-lg-offset-3 {
+    margin-left: 25%;
+  }
+  .col-lg-offset-2 {
+    margin-left: 16.66666667%;
+  }
+  .col-lg-offset-1 {
+    margin-left: 8.33333333%;
+  }
+  .col-lg-offset-0 {
+    margin-left: 0%;
+  }
+}
+table {
+  background-color: transparent;
+}
+caption {
+  padding-top: 8px;
+  padding-bottom: 8px;
+  color: #777777;
+  text-align: left;
+}
+th {
+  text-align: left;
+}
+.table {
+  width: 100%;
+  max-width: 100%;
+  margin-bottom: 20px;
+}
+.table > thead > tr > th,
+.table > tbody > tr > th,
+.table > tfoot > tr > th,
+.table > thead > tr > td,
+.table > tbody > tr > td,
+.table > tfoot > tr > td {
+  padding: 8px;
+  line-height: 1.42857143;
+  vertical-align: top;
+  border-top: 1px solid #ddd;
+}
+.table > thead > tr > th {
+  vertical-align: bottom;
+  border-bottom: 2px solid #ddd;
+}
+.table > caption + thead > tr:first-child > th,
+.table > colgroup + thead > tr:first-child > th,
+.table > thead:first-child > tr:first-child > th,
+.table > caption + thead > tr:first-child > td,
+.table > colgroup + thead > tr:first-child > td,
+.table > thead:first-child > tr:first-child > td {
+  border-top: 0;
+}
+.table > tbody + tbody {
+  border-top: 2px solid #ddd;
+}
+.table .table {
+  background-color: #fff;
+}
+.table-condensed > thead > tr > th,
+.table-condensed > tbody > tr > th,
+.table-condensed > tfoot > tr > th,
+.table-condensed > thead > tr > td,
+.table-condensed > tbody > tr > td,
+.table-condensed > tfoot > tr > td {
+  padding: 5px;
+}
+.table-bordered {
+  border: 1px solid #ddd;
+}
+.table-bordered > thead > tr > th,
+.table-bordered > tbody > tr > th,
+.table-bordered > tfoot > tr > th,
+.table-bordered > thead > tr > td,
+.table-bordered > tbody > tr > td,
+.table-bordered > tfoot > tr > td {
+  border: 1px solid #ddd;
+}
+.table-bordered > thead > tr > th,
+.table-bordered > thead > tr > td {
+  border-bottom-width: 2px;
+}
+.table-striped > tbody > tr:nth-of-type(odd) {
+  background-color: #f9f9f9;
+}
+.table-hover > tbody > tr:hover {
+  background-color: #f5f5f5;
+}
+table col[class*="col-"] {
+  position: static;
+  float: none;
+  display: table-column;
+}
+table td[class*="col-"],
+table th[class*="col-"] {
+  position: static;
+  float: none;
+  display: table-cell;
+}
+.table > thead > tr > td.active,
+.table > tbody > tr > td.active,
+.table > tfoot > tr > td.active,
+.table > thead > tr > th.active,
+.table > tbody > tr > th.active,
+.table > tfoot > tr > th.active,
+.table > thead > tr.active > td,
+.table > tbody > tr.active > td,
+.table > tfoot > tr.active > td,
+.table > thead > tr.active > th,
+.table > tbody > tr.active > th,
+.table > tfoot > tr.active > th {
+  background-color: #f5f5f5;
+}
+.table-hover > tbody > tr > td.active:hover,
+.table-hover > tbody > tr > th.active:hover,
+.table-hover > tbody > tr.active:hover > td,
+.table-hover > tbody > tr:hover > .active,
+.table-hover > tbody > tr.active:hover > th {
+  background-color: #e8e8e8;
+}
+.table > thead > tr > td.success,
+.table > tbody > tr > td.success,
+.table > tfoot > tr > td.success,
+.table > thead > tr > th.success,
+.table > tbody > tr > th.success,
+.table > tfoot > tr > th.success,
+.table > thead > tr.success > td,
+.table > tbody > tr.success > td,
+.table > tfoot > tr.success > td,
+.table > thead > tr.success > th,
+.table > tbody > tr.success > th,
+.table > tfoot > tr.success > th {
+  background-color: #dff0d8;
+}
+.table-hover > tbody > tr > td.success:hover,
+.table-hover > tbody > tr > th.success:hover,
+.table-hover > tbody > tr.success:hover > td,
+.table-hover > tbody > tr:hover > .success,
+.table-hover > tbody > tr.success:hover > th {
+  background-color: #d0e9c6;
+}
+.table > thead > tr > td.info,
+.table > tbody > tr > td.info,
+.table > tfoot > tr > td.info,
+.table > thead > tr > th.info,
+.table > tbody > tr > th.info,
+.table > tfoot > tr > th.info,
+.table > thead > tr.info > td,
+.table > tbody > tr.info > td,
+.table > tfoot > tr.info > td,
+.table > thead > tr.info > th,
+.table > tbody > tr.info > th,
+.table > tfoot > tr.info > th {
+  background-color: #d9edf7;
+}
+.table-hover > tbody > tr > td.info:hover,
+.table-hover > tbody > tr > th.info:hover,
+.table-hover > tbody > tr.info:hover > td,
+.table-hover > tbody > tr:hover > .info,
+.table-hover > tbody > tr.info:hover > th {
+  background-color: #c4e3f3;
+}
+.table > thead > tr > td.warning,
+.table > tbody > tr > td.warning,
+.table > tfoot > tr > td.warning,
+.table > thead > tr > th.warning,
+.table > tbody > tr > th.warning,
+.table > tfoot > tr > th.warning,
+.table > thead > tr.warning > td,
+.table > tbody > tr.warning > td,
+.table > tfoot > tr.warning > td,
+.table > thead > tr.warning > th,
+.table > tbody > tr.warning > th,
+.table > tfoot > tr.warning > th {
+  background-color: #fcf8e3;
+}
+.table-hover > tbody > tr > td.warning:hover,
+.table-hover > tbody > tr > th.warning:hover,
+.table-hover > tbody > tr.warning:hover > td,
+.table-hover > tbody > tr:hover > .warning,
+.table-hover > tbody > tr.warning:hover > th {
+  background-color: #faf2cc;
+}
+.table > thead > tr > td.danger,
+.table > tbody > tr > td.danger,
+.table > tfoot > tr > td.danger,
+.table > thead > tr > th.danger,
+.table > tbody > tr > th.danger,
+.table > tfoot > tr > th.danger,
+.table > thead > tr.danger > td,
+.table > tbody > tr.danger > td,
+.table > tfoot > tr.danger > td,
+.table > thead > tr.danger > th,
+.table > tbody > tr.danger > th,
+.table > tfoot > tr.danger > th {
+  background-color: #f2dede;
+}
+.table-hover > tbody > tr > td.danger:hover,
+.table-hover > tbody > tr > th.danger:hover,
+.table-hover > tbody > tr.danger:hover > td,
+.table-hover > tbody > tr:hover > .danger,
+.table-hover > tbody > tr.danger:hover > th {
+  background-color: #ebcccc;
+}
+.table-responsive {
+  overflow-x: auto;
+  min-height: 0.01%;
+}
+@media screen and (max-width: 767px) {
+  .table-responsive {
+    width: 100%;
+    margin-bottom: 15px;
+    overflow-y: hidden;
+    -ms-overflow-style: -ms-autohiding-scrollbar;
+    border: 1px solid #ddd;
+  }
+  .table-responsive > .table {
+    margin-bottom: 0;
+  }
+  .table-responsive > .table > thead > tr > th,
+  .table-responsive > .table > tbody > tr > th,
+  .table-responsive > .table > tfoot > tr > th,
+  .table-responsive > .table > thead > tr > td,
+  .table-responsive > .table > tbody > tr > td,
+  .table-responsive > .table > tfoot > tr > td {
+    white-space: nowrap;
+  }
+  .table-responsive > .table-bordered {
+    border: 0;
+  }
+  .table-responsive > .table-bordered > thead > tr > th:first-child,
+  .table-responsive > .table-bordered > tbody > tr > th:first-child,
+  .table-responsive > .table-bordered > tfoot > tr > th:first-child,
+  .table-responsive > .table-bordered > thead > tr > td:first-child,
+  .table-responsive > .table-bordered > tbody > tr > td:first-child,
+  .table-responsive > .table-bordered > tfoot > tr > td:first-child {
+    border-left: 0;
+  }
+  .table-responsive > .table-bordered > thead > tr > th:last-child,
+  .table-responsive > .table-bordered > tbody > tr > th:last-child,
+  .table-responsive > .table-bordered > tfoot > tr > th:last-child,
+  .table-responsive > .table-bordered > thead > tr > td:last-child,
+  .table-responsive > .table-bordered > tbody > tr > td:last-child,
+  .table-responsive > .table-bordered > tfoot > tr > td:last-child {
+    border-right: 0;
+  }
+  .table-responsive > .table-bordered > tbody > tr:last-child > th,
+  .table-responsive > .table-bordered > tfoot > tr:last-child > th,
+  .table-responsive > .table-bordered > tbody > tr:last-child > td,
+  .table-responsive > .table-bordered > tfoot > tr:last-child > td {
+    border-bottom: 0;
+  }
+}
+fieldset {
+  padding: 0;
+  margin: 0;
+  border: 0;
+  min-width: 0;
+}
+legend {
+  display: block;
+  width: 100%;
+  padding: 0;
+  margin-bottom: 20px;
+  font-size: 21px;
+  line-height: inherit;
+  color: #333333;
+  border: 0;
+  border-bottom: 1px solid #e5e5e5;
+}
+label {
+  display: inline-block;
+  max-width: 100%;
+  margin-bottom: 5px;
+  font-weight: bold;
+}
+input[type="search"] {
+  -webkit-box-sizing: border-box;
+  -moz-box-sizing: border-box;
+  box-sizing: border-box;
+}
+input[type="radio"],
+input[type="checkbox"] {
+  margin: 4px 0 0;
+  margin-top: 1px \9;
+  line-height: normal;
+}
+input[type="file"] {
+  display: block;
+}
+input[type="range"] {
+  display: block;
+  width: 100%;
+}
+select[multiple],
+select[size] {
+  height: auto;
+}
+input[type="file"]:focus,
+input[type="radio"]:focus,
+input[type="checkbox"]:focus {
+  outline: thin dotted;
+  outline: 5px auto -webkit-focus-ring-color;
+  outline-offset: -2px;
+}
+output {
+  display: block;
+  padding-top: 7px;
+  font-size: 14px;
+  line-height: 1.42857143;
+  color: #555555;
+}
+.form-control {
+  display: block;
+  width: 100%;
+  height: 34px;
+  padding: 6px 12px;
+  font-size: 14px;
+  line-height: 1.42857143;
+  color: #555555;
+  background-color: #fff;
+  background-image: none;
+  border: 1px solid #ccc;
+  border-radius: 4px;
+  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+  -webkit-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
+  -o-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
+  transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
+}
+.form-control:focus {
+  border-color: #66afe9;
+  outline: 0;
+  -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102, 175, 233, 0.6);
+  box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102, 175, 233, 0.6);
+}
+.form-control::-moz-placeholder {
+  color: #999;
+  opacity: 1;
+}
+.form-control:-ms-input-placeholder {
+  color: #999;
+}
+.form-control::-webkit-input-placeholder {
+  color: #999;
+}
+.form-control::-ms-expand {
+  border: 0;
+  background-color: transparent;
+}
+.form-control[disabled],
+.form-control[readonly],
+fieldset[disabled] .form-control {
+  background-color: #eeeeee;
+  opacity: 1;
+}
+.form-control[disabled],
+fieldset[disabled] .form-control {
+  cursor: not-allowed;
+}
+textarea.form-control {
+  height: auto;
+}
+input[type="search"] {
+  -webkit-appearance: none;
+}
+@media screen and (-webkit-min-device-pixel-ratio: 0) {
+  input[type="date"].form-control,
+  input[type="time"].form-control,
+  input[type="datetime-local"].form-control,
+  input[type="month"].form-control {
+    line-height: 34px;
+  }
+  input[type="date"].input-sm,
+  input[type="time"].input-sm,
+  input[type="datetime-local"].input-sm,
+  input[type="month"].input-sm,
+  .input-group-sm input[type="date"],
+  .input-group-sm input[type="time"],
+  .input-group-sm input[type="datetime-local"],
+  .input-group-sm input[type="month"] {
+    line-height: 30px;
+  }
+  input[type="date"].input-lg,
+  input[type="time"].input-lg,
+  input[type="datetime-local"].input-lg,
+  input[type="month"].input-lg,
+  .input-group-lg input[type="date"],
+  .input-group-lg input[type="time"],
+  .input-group-lg input[type="datetime-local"],
+  .input-group-lg input[type="month"] {
+    line-height: 46px;
+  }
+}
+.form-group {
+  margin-bottom: 15px;
+}
+.radio,
+.checkbox {
+  position: relative;
+  display: block;
+  margin-top: 10px;
+  margin-bottom: 10px;
+}
+.radio label,
+.checkbox label {
+  min-height: 20px;
+  padding-left: 20px;
+  margin-bottom: 0;
+  font-weight: normal;
+  cursor: pointer;
+}
+.radio input[type="radio"],
+.radio-inline input[type="radio"],
+.checkbox input[type="checkbox"],
+.checkbox-inline input[type="checkbox"] {
+  position: absolute;
+  margin-left: -20px;
+  margin-top: 4px \9;
+}
+.radio + .radio,
+.checkbox + .checkbox {
+  margin-top: -5px;
+}
+.radio-inline,
+.checkbox-inline {
+  position: relative;
+  display: inline-block;
+  padding-left: 20px;
+  margin-bottom: 0;
+  vertical-align: middle;
+  font-weight: normal;
+  cursor: pointer;
+}
+.radio-inline + .radio-inline,
+.checkbox-inline + .checkbox-inline {
+  margin-top: 0;
+  margin-left: 10px;
+}
+input[type="radio"][disabled],
+input[type="checkbox"][disabled],
+input[type="radio"].disabled,
+input[type="checkbox"].disabled,
+fieldset[disabled] input[type="radio"],
+fieldset[disabled] input[type="checkbox"] {
+  cursor: not-allowed;
+}
+.radio-inline.disabled,
+.checkbox-inline.disabled,
+fieldset[disabled] .radio-inline,
+fieldset[disabled] .checkbox-inline {
+  cursor: not-allowed;
+}
+.radio.disabled label,
+.checkbox.disabled label,
+fieldset[disabled] .radio label,
+fieldset[disabled] .checkbox label {
+  cursor: not-allowed;
+}
+.form-control-static {
+  padding-top: 7px;
+  padding-bottom: 7px;
+  margin-bottom: 0;
+  min-height: 34px;
+}
+.form-control-static.input-lg,
+.form-control-static.input-sm {
+  padding-left: 0;
+  padding-right: 0;
+}
+.input-sm {
+  height: 30px;
+  padding: 5px 10px;
+  font-size: 12px;
+  line-height: 1.5;
+  border-radius: 3px;
+}
+select.input-sm {
+  height: 30px;
+  line-height: 30px;
+}
+textarea.input-sm,
+select[multiple].input-sm {
+  height: auto;
+}
+.form-group-sm .form-control {
+  height: 30px;
+  padding: 5px 10px;
+  font-size: 12px;
+  line-height: 1.5;
+  border-radius: 3px;
+}
+.form-group-sm select.form-control {
+  height: 30px;
+  line-height: 30px;
+}
+.form-group-sm textarea.form-control,
+.form-group-sm select[multiple].form-control {
+  height: auto;
+}
+.form-group-sm .form-control-static {
+  height: 30px;
+  min-height: 32px;
+  padding: 6px 10px;
+  font-size: 12px;
+  line-height: 1.5;
+}
+.input-lg {
+  height: 46px;
+  padding: 10px 16px;
+  font-size: 18px;
+  line-height: 1.3333333;
+  border-radius: 6px;
+}
+select.input-lg {
+  height: 46px;
+  line-height: 46px;
+}
+textarea.input-lg,
+select[multiple].input-lg {
+  height: auto;
+}
+.form-group-lg .form-control {
+  height: 46px;
+  padding: 10px 16px;
+  font-size: 18px;
+  line-height: 1.3333333;
+  border-radius: 6px;
+}
+.form-group-lg select.form-control {
+  height: 46px;
+  line-height: 46px;
+}
+.form-group-lg textarea.form-control,
+.form-group-lg select[multiple].form-control {
+  height: auto;
+}
+.form-group-lg .form-control-static {
+  height: 46px;
+  min-height: 38px;
+  padding: 11px 16px;
+  font-size: 18px;
+  line-height: 1.3333333;
+}
+.has-feedback {
+  position: relative;
+}
+.has-feedback .form-control {
+  padding-right: 42.5px;
+}
+.form-control-feedback {
+  position: absolute;
+  top: 0;
+  right: 0;
+  z-index: 2;
+  display: block;
+  width: 34px;
+  height: 34px;
+  line-height: 34px;
+  text-align: center;
+  pointer-events: none;
+}
+.input-lg + .form-control-feedback,
+.input-group-lg + .form-control-feedback,
+.form-group-lg .form-control + .form-control-feedback {
+  width: 46px;
+  height: 46px;
+  line-height: 46px;
+}
+.input-sm + .form-control-feedback,
+.input-group-sm + .form-control-feedback,
+.form-group-sm .form-control + .form-control-feedback {
+  width: 30px;
+  height: 30px;
+  line-height: 30px;
+}
+.has-success .help-block,
+.has-success .control-label,
+.has-success .radio,
+.has-success .checkbox,
+.has-success .radio-inline,
+.has-success .checkbox-inline,
+.has-success.radio label,
+.has-success.checkbox label,
+.has-success.radio-inline label,
+.has-success.checkbox-inline label {
+  color: #3c763d;
+}
+.has-success .form-control {
+  border-color: #3c763d;
+  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+}
+.has-success .form-control:focus {
+  border-color: #2b542c;
+  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #67b168;
+  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #67b168;
+}
+.has-success .input-group-addon {
+  color: #3c763d;
+  border-color: #3c763d;
+  background-color: #dff0d8;
+}
+.has-success .form-control-feedback {
+  color: #3c763d;
+}
+.has-warning .help-block,
+.has-warning .control-label,
+.has-warning .radio,
+.has-warning .checkbox,
+.has-warning .radio-inline,
+.has-warning .checkbox-inline,
+.has-warning.radio label,
+.has-warning.checkbox label,
+.has-warning.radio-inline label,
+.has-warning.checkbox-inline label {
+  color: #8a6d3b;
+}
+.has-warning .form-control {
+  border-color: #8a6d3b;
+  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+}
+.has-warning .form-control:focus {
+  border-color: #66512c;
+  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #c0a16b;
+  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #c0a16b;
+}
+.has-warning .input-group-addon {
+  color: #8a6d3b;
+  border-color: #8a6d3b;
+  background-color: #fcf8e3;
+}
+.has-warning .form-control-feedback {
+  color: #8a6d3b;
+}
+.has-error .help-block,
+.has-error .control-label,
+.has-error .radio,
+.has-error .checkbox,
+.has-error .radio-inline,
+.has-error .checkbox-inline,
+.has-error.radio label,
+.has-error.checkbox label,
+.has-error.radio-inline label,
+.has-error.checkbox-inline label {
+  color: #a94442;
+}
+.has-error .form-control {
+  border-color: #a94442;
+  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+}
+.has-error .form-control:focus {
+  border-color: #843534;
+  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #ce8483;
+  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #ce8483;
+}
+.has-error .input-group-addon {
+  color: #a94442;
+  border-color: #a94442;
+  background-color: #f2dede;
+}
+.has-error .form-control-feedback {
+  color: #a94442;
+}
+.has-feedback label ~ .form-control-feedback {
+  top: 25px;
+}
+.has-feedback label.sr-only ~ .form-control-feedback {
+  top: 0;
+}
+.help-block {
+  display: block;
+  margin-top: 5px;
+  margin-bottom: 10px;
+  color: #737373;
+}
+@media (min-width: 768px) {
+  .form-inline .form-group {
+    display: inline-block;
+    margin-bottom: 0;
+    vertical-align: middle;
+  }
+  .form-inline .form-control {
+    display: inline-block;
+    width: auto;
+    vertical-align: middle;
+  }
+  .form-inline .form-control-static {
+    display: inline-block;
+  }
+  .form-inline .input-group {
+    display: inline-table;
+    vertical-align: middle;
+  }
+  .form-inline .input-group .input-group-addon,
+  .form-inline .input-group .input-group-btn,
+  .form-inline .input-group .form-control {
+    width: auto;
+  }
+  .form-inline .input-group > .form-control {
+    width: 100%;
+  }
+  .form-inline .control-label {
+    margin-bottom: 0;
+    vertical-align: middle;
+  }
+  .form-inline .radio,
+  .form-inline .checkbox {
+    display: inline-block;
+    margin-top: 0;
+    margin-bottom: 0;
+    vertical-align: middle;
+  }
+  .form-inline .radio label,
+  .form-inline .checkbox label {
+    padding-left: 0;
+  }
+  .form-inline .radio input[type="radio"],
+  .form-inline .checkbox input[type="checkbox"] {
+    position: relative;
+    margin-left: 0;
+  }
+  .form-inline .has-feedback .form-control-feedback {
+    top: 0;
+  }
+}
+.form-horizontal .radio,
+.form-horizontal .checkbox,
+.form-horizontal .radio-inline,
+.form-horizontal .checkbox-inline {
+  margin-top: 0;
+  margin-bottom: 0;
+  padding-top: 7px;
+}
+.form-horizontal .radio,
+.form-horizontal .checkbox {
+  min-height: 27px;
+}
+.form-horizontal .form-group {
+  margin-left: -15px;
+  margin-right: -15px;
+}
+@media (min-width: 768px) {
+  .form-horizontal .control-label {
+    text-align: right;
+    margin-bottom: 0;
+    padding-top: 7px;
+  }
+}
+.form-horizontal .has-feedback .form-control-feedback {
+  right: 15px;
+}
+@media (min-width: 768px) {
+  .form-horizontal .form-group-lg .control-label {
+    padding-top: 11px;
+    font-size: 18px;
+  }
+}
+@media (min-width: 768px) {
+  .form-horizontal .form-group-sm .control-label {
+    padding-top: 6px;
+    font-size: 12px;
+  }
+}
+.btn {
+  display: inline-block;
+  margin-bottom: 0;
+  font-weight: normal;
+  text-align: center;
+  vertical-align: middle;
+  touch-action: manipulation;
+  cursor: pointer;
+  background-image: none;
+  border: 1px solid transparent;
+  white-space: nowrap;
+  padding: 6px 12px;
+  font-size: 14px;
+  line-height: 1.42857143;
+  border-radius: 4px;
+  -webkit-user-select: none;
+  -moz-user-select: none;
+  -ms-user-select: none;
+  user-select: none;
+}
+.btn:focus,
+.btn:active:focus,
+.btn.active:focus,
+.btn.focus,
+.btn:active.focus,
+.btn.active.focus {
+  outline: thin dotted;
+  outline: 5px auto -webkit-focus-ring-color;
+  outline-offset: -2px;
+}
+.btn:hover,
+.btn:focus,
+.btn.focus {
+  color: #333;
+  text-decoration: none;
+}
+.btn:active,
+.btn.active {
+  outline: 0;
+  background-image: none;
+  -webkit-box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
+  box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
+}
+.btn.disabled,
+.btn[disabled],
+fieldset[disabled] .btn {
+  cursor: not-allowed;
+  opacity: 0.65;
+  filter: alpha(opacity=65);
+  -webkit-box-shadow: none;
+  box-shadow: none;
+}
+a.btn.disabled,
+fieldset[disabled] a.btn {
+  pointer-events: none;
+}
+.btn-default {
+  color: #333;
+  background-color: #fff;
+  border-color: #ccc;
+}
+.btn-default:focus,
+.btn-default.focus {
+  color: #333;
+  background-color: #e6e6e6;
+  border-color: #8c8c8c;
+}
+.btn-default:hover {
+  color: #333;
+  background-color: #e6e6e6;
+  border-color: #adadad;
+}
+.btn-default:active,
+.btn-default.active,
+.open > .dropdown-toggle.btn-default {
+  color: #333;
+  background-color: #e6e6e6;
+  border-color: #adadad;
+}
+.btn-default:active:hover,
+.btn-default.active:hover,
+.open > .dropdown-toggle.btn-default:hover,
+.btn-default:active:focus,
+.btn-default.active:focus,
+.open > .dropdown-toggle.btn-default:focus,
+.btn-default:active.focus,
+.btn-default.active.focus,
+.open > .dropdown-toggle.btn-default.focus {
+  color: #333;
+  background-color: #d4d4d4;
+  border-color: #8c8c8c;
+}
+.btn-default:active,
+.btn-default.active,
+.open > .dropdown-toggle.btn-default {
+  background-image: none;
+}
+.btn-default.disabled:hover,
+.btn-default[disabled]:hover,
+fieldset[disabled] .btn-default:hover,
+.btn-default.disabled:focus,
+.btn-default[disabled]:focus,
+fieldset[disabled] .btn-default:focus,
+.btn-default.disabled.focus,
+.btn-default[disabled].focus,
+fieldset[disabled] .btn-default.focus {
+  background-color: #fff;
+  border-color: #ccc;
+}
+.btn-default .badge {
+  color: #fff;
+  background-color: #333;
+}
+.btn-primary {
+  color: #fff;
+  background-color: #337ab7;
+  border-color: #2e6da4;
+}
+.btn-primary:focus,
+.btn-primary.focus {
+  color: #fff;
+  background-color: #286090;
+  border-color: #122b40;
+}
+.btn-primary:hover {
+  color: #fff;
+  background-color: #286090;
+  border-color: #204d74;
+}
+.btn-primary:active,
+.btn-primary.active,
+.open > .dropdown-toggle.btn-primary {
+  color: #fff;
+  background-color: #286090;
+  border-color: #204d74;
+}
+.btn-primary:active:hover,
+.btn-primary.active:hover,
+.open > .dropdown-toggle.btn-primary:hover,
+.btn-primary:active:focus,
+.btn-primary.active:focus,
+.open > .dropdown-toggle.btn-primary:focus,
+.btn-primary:active.focus,
+.btn-primary.active.focus,
+.open > .dropdown-toggle.btn-primary.focus {
+  color: #fff;
+  background-color: #204d74;
+  border-color: #122b40;
+}
+.btn-primary:active,
+.btn-primary.active,
+.open > .dropdown-toggle.btn-primary {
+  background-image: none;
+}
+.btn-primary.disabled:hover,
+.btn-primary[disabled]:hover,
+fieldset[disabled] .btn-primary:hover,
+.btn-primary.disabled:focus,
+.btn-primary[disabled]:focus,
+fieldset[disabled] .btn-primary:focus,
+.btn-primary.disabled.focus,
+.btn-primary[disabled].focus,
+fieldset[disabled] .btn-primary.focus {
+  background-color: #337ab7;
+  border-color: #2e6da4;
+}
+.btn-primary .badge {
+  color: #337ab7;
+  background-color: #fff;
+}
+.btn-success {
+  color: #fff;
+  background-color: #5cb85c;
+  border-color: #4cae4c;
+}
+.btn-success:focus,
+.btn-success.focus {
+  color: #fff;
+  background-color: #449d44;
+  border-color: #255625;
+}
+.btn-success:hover {
+  color: #fff;
+  background-color: #449d44;
+  border-color: #398439;
+}
+.btn-success:active,
+.btn-success.active,
+.open > .dropdown-toggle.btn-success {
+  color: #fff;
+  background-color: #449d44;
+  border-color: #398439;
+}
+.btn-success:active:hover,
+.btn-success.active:hover,
+.open > .dropdown-toggle.btn-success:hover,
+.btn-success:active:focus,
+.btn-success.active:focus,
+.open > .dropdown-toggle.btn-success:focus,
+.btn-success:active.focus,
+.btn-success.active.focus,
+.open > .dropdown-toggle.btn-success.focus {
+  color: #fff;
+  background-color: #398439;
+  border-color: #255625;
+}
+.btn-success:active,
+.btn-success.active,
+.open > .dropdown-toggle.btn-success {
+  background-image: none;
+}
+.btn-success.disabled:hover,
+.btn-success[disabled]:hover,
+fieldset[disabled] .btn-success:hover,
+.btn-success.disabled:focus,
+.btn-success[disabled]:focus,
+fieldset[disabled] .btn-success:focus,
+.btn-success.disabled.focus,
+.btn-success[disabled].focus,
+fieldset[disabled] .btn-success.focus {
+  background-color: #5cb85c;
+  border-color: #4cae4c;
+}
+.btn-success .badge {
+  color: #5cb85c;
+  background-color: #fff;
+}
+.btn-info {
+  color: #fff;
+  background-color: #5bc0de;
+  border-color: #46b8da;
+}
+.btn-info:focus,
+.btn-info.focus {
+  color: #fff;
+  background-color: #31b0d5;
+  border-color: #1b6d85;
+}
+.btn-info:hover {
+  color: #fff;
+  background-color: #31b0d5;
+  border-color: #269abc;
+}
+.btn-info:active,
+.btn-info.active,
+.open > .dropdown-toggle.btn-info {
+  color: #fff;
+  background-color: #31b0d5;
+  border-color: #269abc;
+}
+.btn-info:active:hover,
+.btn-info.active:hover,
+.open > .dropdown-toggle.btn-info:hover,
+.btn-info:active:focus,
+.btn-info.active:focus,
+.open > .dropdown-toggle.btn-info:focus,
+.btn-info:active.focus,
+.btn-info.active.focus,
+.open > .dropdown-toggle.btn-info.focus {
+  color: #fff;
+  background-color: #269abc;
+  border-color: #1b6d85;
+}
+.btn-info:active,
+.btn-info.active,
+.open > .dropdown-toggle.btn-info {
+  background-image: none;
+}
+.btn-info.disabled:hover,
+.btn-info[disabled]:hover,
+fieldset[disabled] .btn-info:hover,
+.btn-info.disabled:focus,
+.btn-info[disabled]:focus,
+fieldset[disabled] .btn-info:focus,
+.btn-info.disabled.focus,
+.btn-info[disabled].focus,
+fieldset[disabled] .btn-info.focus {
+  background-color: #5bc0de;
+  border-color: #46b8da;
+}
+.btn-info .badge {
+  color: #5bc0de;
+  background-color: #fff;
+}
+.btn-warning {
+  color: #fff;
+  background-color: #f0ad4e;
+  border-color: #eea236;
+}
+.btn-warning:focus,
+.btn-warning.focus {
+  color: #fff;
+  background-color: #ec971f;
+  border-color: #985f0d;
+}
+.btn-warning:hover {
+  color: #fff;
+  background-color: #ec971f;
+  border-color: #d58512;
+}
+.btn-warning:active,
+.btn-warning.active,
+.open > .dropdown-toggle.btn-warning {
+  color: #fff;
+  background-color: #ec971f;
+  border-color: #d58512;
+}
+.btn-warning:active:hover,
+.btn-warning.active:hover,
+.open > .dropdown-toggle.btn-warning:hover,
+.btn-warning:active:focus,
+.btn-warning.active:focus,
+.open > .dropdown-toggle.btn-warning:focus,
+.btn-warning:active.focus,
+.btn-warning.active.focus,
+.open > .dropdown-toggle.btn-warning.focus {
+  color: #fff;
+  background-color: #d58512;
+  border-color: #985f0d;
+}
+.btn-warning:active,
+.btn-warning.active,
+.open > .dropdown-toggle.btn-warning {
+  background-image: none;
+}
+.btn-warning.disabled:hover,
+.btn-warning[disabled]:hover,
+fieldset[disabled] .btn-warning:hover,
+.btn-warning.disabled:focus,
+.btn-warning[disabled]:focus,
+fieldset[disabled] .btn-warning:focus,
+.btn-warning.disabled.focus,
+.btn-warning[disabled].focus,
+fieldset[disabled] .btn-warning.focus {
+  background-color: #f0ad4e;
+  border-color: #eea236;
+}
+.btn-warning .badge {
+  color: #f0ad4e;
+  background-color: #fff;
+}
+.btn-danger {
+  color: #fff;
+  background-color: #d9534f;
+  border-color: #d43f3a;
+}
+.btn-danger:focus,
+.btn-danger.focus {
+  color: #fff;
+  background-color: #c9302c;
+  border-color: #761c19;
+}
+.btn-danger:hover {
+  color: #fff;
+  background-color: #c9302c;
+  border-color: #ac2925;
+}
+.btn-danger:active,
+.btn-danger.active,
+.open > .dropdown-toggle.btn-danger {
+  color: #fff;
+  background-color: #c9302c;
+  border-color: #ac2925;
+}
+.btn-danger:active:hover,
+.btn-danger.active:hover,
+.open > .dropdown-toggle.btn-danger:hover,
+.btn-danger:active:focus,
+.btn-danger.active:focus,
+.open > .dropdown-toggle.btn-danger:focus,
+.btn-danger:active.focus,
+.btn-danger.active.focus,
+.open > .dropdown-toggle.btn-danger.focus {
+  color: #fff;
+  background-color: #ac2925;
+  border-color: #761c19;
+}
+.btn-danger:active,
+.btn-danger.active,
+.open > .dropdown-toggle.btn-danger {
+  background-image: none;
+}
+.btn-danger.disabled:hover,
+.btn-danger[disabled]:hover,
+fieldset[disabled] .btn-danger:hover,
+.btn-danger.disabled:focus,
+.btn-danger[disabled]:focus,
+fieldset[disabled] .btn-danger:focus,
+.btn-danger.disabled.focus,
+.btn-danger[disabled].focus,
+fieldset[disabled] .btn-danger.focus {
+  background-color: #d9534f;
+  border-color: #d43f3a;
+}
+.btn-danger .badge {
+  color: #d9534f;
+  background-color: #fff;
+}
+.btn-link {
+  color: #337ab7;
+  font-weight: normal;
+  border-radius: 0;
+}
+.btn-link,
+.btn-link:active,
+.btn-link.active,
+.btn-link[disabled],
+fieldset[disabled] .btn-link {
+  background-color: transparent;
+  -webkit-box-shadow: none;
+  box-shadow: none;
+}
+.btn-link,
+.btn-link:hover,
+.btn-link:focus,
+.btn-link:active {
+  border-color: transparent;
+}
+.btn-link:hover,
+.btn-link:focus {
+  color: #23527c;
+  text-decoration: underline;
+  background-color: transparent;
+}
+.btn-link[disabled]:hover,
+fieldset[disabled] .btn-link:hover,
+.btn-link[disabled]:focus,
+fieldset[disabled] .btn-link:focus {
+  color: #777777;
+  text-decoration: none;
+}
+.btn-lg {
+  padding: 10px 16px;
+  font-size: 18px;
+  line-height: 1.3333333;
+  border-radius: 6px;
+}
+.btn-sm {
+  padding: 5px 10px;
+  font-size: 12px;
+  line-height: 1.5;
+  border-radius: 3px;
+}
+.btn-xs {
+  padding: 1px 5px;
+  font-size: 12px;
+  line-height: 1.5;
+  border-radius: 3px;
+}
+.btn-block {
+  display: block;
+  width: 100%;
+}
+.btn-block + .btn-block {
+  margin-top: 5px;
+}
+input[type="submit"].btn-block,
+input[type="reset"].btn-block,
+input[type="button"].btn-block {
+  width: 100%;
+}
+.fade {
+  opacity: 0;
+  -webkit-transition: opacity 0.15s linear;
+  -o-transition: opacity 0.15s linear;
+  transition: opacity 0.15s linear;
+}
+.fade.in {
+  opacity: 1;
+}
+.collapse {
+  display: none;
+}
+.collapse.in {
+  display: block;
+}
+tr.collapse.in {
+  display: table-row;
+}
+tbody.collapse.in {
+  display: table-row-group;
+}
+.collapsing {
+  position: relative;
+  height: 0;
+  overflow: hidden;
+  -webkit-transition-property: height, visibility;
+  transition-property: height, visibility;
+  -webkit-transition-duration: 0.35s;
+  transition-duration: 0.35s;
+  -webkit-transition-timing-function: ease;
+  transition-timing-function: ease;
+}
+.caret {
+  display: inline-block;
+  width: 0;
+  height: 0;
+  margin-left: 2px;
+  vertical-align: middle;
+  border-top: 4px dashed;
+  border-top: 4px solid \9;
+  border-right: 4px solid transparent;
+  border-left: 4px solid transparent;
+}
+.dropup,
+.dropdown {
+  position: relative;
+}
+.dropdown-toggle:focus {
+  outline: 0;
+}
+.dropdown-menu {
+  position: absolute;
+  top: 100%;
+  left: 0;
+  z-index: 1000;
+  display: none;
+  float: left;
+  min-width: 160px;
+  padding: 5px 0;
+  margin: 2px 0 0;
+  list-style: none;
+  font-size: 14px;
+  text-align: left;
+  background-color: #fff;
+  border: 1px solid #ccc;
+  border: 1px solid rgba(0, 0, 0, 0.15);
+  border-radius: 4px;
+  -webkit-box-shadow: 0 6px 12px rgba(0, 0, 0, 0.175);
+  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.175);
+  background-clip: padding-box;
+}
+.dropdown-menu.pull-right {
+  right: 0;
+  left: auto;
+}
+.dropdown-menu .divider {
+  height: 1px;
+  margin: 9px 0;
+  overflow: hidden;
+  background-color: #e5e5e5;
+}
+.dropdown-menu > li > a {
+  display: block;
+  padding: 3px 20px;
+  clear: both;
+  font-weight: normal;
+  line-height: 1.42857143;
+  color: #333333;
+  white-space: nowrap;
+}
+.dropdown-menu > li > a:hover,
+.dropdown-menu > li > a:focus {
+  text-decoration: none;
+  color: #262626;
+  background-color: #f5f5f5;
+}
+.dropdown-menu > .active > a,
+.dropdown-menu > .active > a:hover,
+.dropdown-menu > .active > a:focus {
+  color: #fff;
+  text-decoration: none;
+  outline: 0;
+  background-color: #337ab7;
+}
+.dropdown-menu > .disabled > a,
+.dropdown-menu > .disabled > a:hover,
+.dropdown-menu > .disabled > a:focus {
+  color: #777777;
+}
+.dropdown-menu > .disabled > a:hover,
+.dropdown-menu > .disabled > a:focus {
+  text-decoration: none;
+  background-color: transparent;
+  background-image: none;
+  filter: progid:DXImageTransform.Microsoft.gradient(enabled = false);
+  cursor: not-allowed;
+}
+.open > .dropdown-menu {
+  display: block;
+}
+.open > a {
+  outline: 0;
+}
+.dropdown-menu-right {
+  left: auto;
+  right: 0;
+}
+.dropdown-menu-left {
+  left: 0;
+  right: auto;
+}
+.dropdown-header {
+  display: block;
+  padding: 3px 20px;
+  font-size: 12px;
+  line-height: 1.42857143;
+  color: #777777;
+  white-space: nowrap;
+}
+.dropdown-backdrop {
+  position: fixed;
+  left: 0;
+  right: 0;
+  bottom: 0;
+  top: 0;
+  z-index: 990;
+}
+.pull-right > .dropdown-menu {
+  right: 0;
+  left: auto;
+}
+.dropup .caret,
+.navbar-fixed-bottom .dropdown .caret {
+  border-top: 0;
+  border-bottom: 4px dashed;
+  border-bottom: 4px solid \9;
+  content: "";
+}
+.dropup .dropdown-menu,
+.navbar-fixed-bottom .dropdown .dropdown-menu {
+  top: auto;
+  bottom: 100%;
+  margin-bottom: 2px;
+}
+@media (min-width: 768px) {
+  .navbar-right .dropdown-menu {
+    left: auto;
+    right: 0;
+  }
+  .navbar-right .dropdown-menu-left {
+    left: 0;
+    right: auto;
+  }
+}
+.nav {
+  margin-bottom: 0;
+  padding-left: 0;
+  list-style: none;
+}
+.nav > li {
+  position: relative;
+  display: block;
+}
+.nav > li > a {
+  position: relative;
+  display: block;
+  padding: 10px 15px;
+}
+.nav > li > a:hover,
+.nav > li > a:focus {
+  text-decoration: none;
+  background-color: #eeeeee;
+}
+.nav > li.disabled > a {
+  color: #777777;
+}
+.nav > li.disabled > a:hover,
+.nav > li.disabled > a:focus {
+  color: #777777;
+  text-decoration: none;
+  background-color: transparent;
+  cursor: not-allowed;
+}
+.nav .open > a,
+.nav .open > a:hover,
+.nav .open > a:focus {
+  background-color: #eeeeee;
+  border-color: #337ab7;
+}
+.nav .nav-divider {
+  height: 1px;
+  margin: 9px 0;
+  overflow: hidden;
+  background-color: #e5e5e5;
+}
+.nav > li > a > img {
+  max-width: none;
+}
+.nav-tabs {
+  border-bottom: 1px solid #ddd;
+}
+.nav-tabs > li {
+  float: left;
+  margin-bottom: -1px;
+}
+.nav-tabs > li > a {
+  margin-right: 2px;
+  line-height: 1.42857143;
+  border: 1px solid transparent;
+  border-radius: 4px 4px 0 0;
+}
+.nav-tabs > li > a:hover {
+  border-color: #eeeeee #eeeeee #ddd;
+}
+.nav-tabs > li.active > a,
+.nav-tabs > li.active > a:hover,
+.nav-tabs > li.active > a:focus {
+  color: #555555;
+  background-color: #fff;
+  border: 1px solid #ddd;
+  border-bottom-color: transparent;
+  cursor: default;
+}
+.nav-tabs.nav-justified {
+  width: 100%;
+  border-bottom: 0;
+}
+.nav-tabs.nav-justified > li {
+  float: none;
+}
+.nav-tabs.nav-justified > li > a {
+  text-align: center;
+  margin-bottom: 5px;
+}
+.nav-tabs.nav-justified > .dropdown .dropdown-menu {
+  top: auto;
+  left: auto;
+}
+@media (min-width: 768px) {
+  .nav-tabs.nav-justified > li {
+    display: table-cell;
+    width: 1%;
+  }
+  .nav-tabs.nav-justified > li > a {
+    margin-bottom: 0;
+  }
+}
+.nav-tabs.nav-justified > li > a {
+  margin-right: 0;
+  border-radius: 4px;
+}
+.nav-tabs.nav-justified > .active > a,
+.nav-tabs.nav-justified > .active > a:hover,
+.nav-tabs.nav-justified > .active > a:focus {
+  border: 1px solid #ddd;
+}
+@media (min-width: 768px) {
+  .nav-tabs.nav-justified > li > a {
+    border-bottom: 1px solid #ddd;
+    border-radius: 4px 4px 0 0;
+  }
+  .nav-tabs.nav-justified > .active > a,
+  .nav-tabs.nav-justified > .active > a:hover,
+  .nav-tabs.nav-justified > .active > a:focus {
+    border-bottom-color: #fff;
+  }
+}
+.nav-pills > li {
+  float: left;
+}
+.nav-pills > li > a {
+  border-radius: 4px;
+}
+.nav-pills > li + li {
+  margin-left: 2px;
+}
+.nav-pills > li.active > a,
+.nav-pills > li.active > a:hover,
+.nav-pills > li.active > a:focus {
+  color: #fff;
+  background-color: #337ab7;
+}
+.nav-stacked > li {
+  float: none;
+}
+.nav-stacked > li + li {
+  margin-top: 2px;
+  margin-left: 0;
+}
+.nav-justified {
+  width: 100%;
+}
+.nav-justified > li {
+  float: none;
+}
+.nav-justified > li > a {
+  text-align: center;
+  margin-bottom: 5px;
+}
+.nav-justified > .dropdown .dropdown-menu {
+  top: auto;
+  left: auto;
+}
+@media (min-width: 768px) {
+  .nav-justified > li {
+    display: table-cell;
+    width: 1%;
+  }
+  .nav-justified > li > a {
+    margin-bottom: 0;
+  }
+}
+.nav-tabs-justified {
+  border-bottom: 0;
+}
+.nav-tabs-justified > li > a {
+  margin-right: 0;
+  border-radius: 4px;
+}
+.nav-tabs-justified > .active > a,
+.nav-tabs-justified > .active > a:hover,
+.nav-tabs-justified > .active > a:focus {
+  border: 1px solid #ddd;
+}
+@media (min-width: 768px) {
+  .nav-tabs-justified > li > a {
+    border-bottom: 1px solid #ddd;
+    border-radius: 4px 4px 0 0;
+  }
+  .nav-tabs-justified > .active > a,
+  .nav-tabs-justified > .active > a:hover,
+  .nav-tabs-justified > .active > a:focus {
+    border-bottom-color: #fff;
+  }
+}
+.tab-content > .tab-pane {
+  display: none;
+}
+.tab-content > .active {
+  display: block;
+}
+.nav-tabs .dropdown-menu {
+  margin-top: -1px;
+  border-top-right-radius: 0;
+  border-top-left-radius: 0;
+}
+.navbar {
+  position: relative;
+  min-height: 50px;
+  margin-bottom: 20px;
+  border: 1px solid transparent;
+}
+@media (min-width: 768px) {
+  .navbar {
+    border-radius: 4px;
+  }
+}
+@media (min-width: 768px) {
+  .navbar-header {
+    float: left;
+  }
+}
+.navbar-collapse {
+  overflow-x: visible;
+  padding-right: 15px;
+  padding-left: 15px;
+  border-top: 1px solid transparent;
+  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1);
+  -webkit-overflow-scrolling: touch;
+}
+.navbar-collapse.in {
+  overflow-y: auto;
+}
+@media (min-width: 768px) {
+  .navbar-collapse {
+    width: auto;
+    border-top: 0;
+    box-shadow: none;
+  }
+  .navbar-collapse.collapse {
+    display: block !important;
+    height: auto !important;
+    padding-bottom: 0;
+    overflow: visible !important;
+  }
+  .navbar-collapse.in {
+    overflow-y: visible;
+  }
+  .navbar-fixed-top .navbar-collapse,
+  .navbar-static-top .navbar-collapse,
+  .navbar-fixed-bottom .navbar-collapse {
+    padding-left: 0;
+    padding-right: 0;
+  }
+}
+.navbar-fixed-top .navbar-collapse,
+.navbar-fixed-bottom .navbar-collapse {
+  max-height: 340px;
+}
+@media (max-device-width: 480px) and (orientation: landscape) {
+  .navbar-fixed-top .navbar-collapse,
+  .navbar-fixed-bottom .navbar-collapse {
+    max-height: 200px;
+  }
+}
+.container > .navbar-header,
+.container-fluid > .navbar-header,
+.container > .navbar-collapse,
+.container-fluid > .navbar-collapse {
+  margin-right: -15px;
+  margin-left: -15px;
+}
+@media (min-width: 768px) {
+  .container > .navbar-header,
+  .container-fluid > .navbar-header,
+  .container > .navbar-collapse,
+  .container-fluid > .navbar-collapse {
+    margin-right: 0;
+    margin-left: 0;
+  }
+}
+.navbar-static-top {
+  z-index: 1000;
+  border-width: 0 0 1px;
+}
+@media (min-width: 768px) {
+  .navbar-static-top {
+    border-radius: 0;
+  }
+}
+.navbar-fixed-top,
+.navbar-fixed-bottom {
+  position: fixed;
+  right: 0;
+  left: 0;
+  z-index: 1030;
+}
+@media (min-width: 768px) {
+  .navbar-fixed-top,
+  .navbar-fixed-bottom {
+    border-radius: 0;
+  }
+}
+.navbar-fixed-top {
+  top: 0;
+  border-width: 0 0 1px;
+}
+.navbar-fixed-bottom {
+  bottom: 0;
+  margin-bottom: 0;
+  border-width: 1px 0 0;
+}
+.navbar-brand {
+  float: left;
+  padding: 15px 15px;
+  font-size: 18px;
+  line-height: 20px;
+  height: 50px;
+}
+.navbar-brand:hover,
+.navbar-brand:focus {
+  text-decoration: none;
+}
+.navbar-brand > img {
+  display: block;
+}
+@media (min-width: 768px) {
+  .navbar > .container .navbar-brand,
+  .navbar > .container-fluid .navbar-brand {
+    margin-left: -15px;
+  }
+}
+.navbar-toggle {
+  position: relative;
+  float: right;
+  margin-right: 15px;
+  padding: 9px 10px;
+  margin-top: 8px;
+  margin-bottom: 8px;
+  background-color: transparent;
+  background-image: none;
+  border: 1px solid transparent;
+  border-radius: 4px;
+}
+.navbar-toggle:focus {
+  outline: 0;
+}
+.navbar-toggle .icon-bar {
+  display: block;
+  width: 22px;
+  height: 2px;
+  border-radius: 1px;
+}
+.navbar-toggle .icon-bar + .icon-bar {
+  margin-top: 4px;
+}
+@media (min-width: 768px) {
+  .navbar-toggle {
+    display: none;
+  }
+}
+.navbar-nav {
+  margin: 7.5px -15px;
+}
+.navbar-nav > li > a {
+  padding-top: 10px;
+  padding-bottom: 10px;
+  line-height: 20px;
+}
+@media (max-width: 767px) {
+  .navbar-nav .open .dropdown-menu {
+    position: static;
+    float: none;
+    width: auto;
+    margin-top: 0;
+    background-color: transparent;
+    border: 0;
+    box-shadow: none;
+  }
+  .navbar-nav .open .dropdown-menu > li > a,
+  .navbar-nav .open .dropdown-menu .dropdown-header {
+    padding: 5px 15px 5px 25px;
+  }
+  .navbar-nav .open .dropdown-menu > li > a {
+    line-height: 20px;
+  }
+  .navbar-nav .open .dropdown-menu > li > a:hover,
+  .navbar-nav .open .dropdown-menu > li > a:focus {
+    background-image: none;
+  }
+}
+@media (min-width: 768px) {
+  .navbar-nav {
+    float: left;
+    margin: 0;
+  }
+  .navbar-nav > li {
+    float: left;
+  }
+  .navbar-nav > li > a {
+    padding-top: 15px;
+    padding-bottom: 15px;
+  }
+}
+.navbar-form {
+  margin-left: -15px;
+  margin-right: -15px;
+  padding: 10px 15px;
+  border-top: 1px solid transparent;
+  border-bottom: 1px solid transparent;
+  -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 1px 0 rgba(255, 255, 255, 0.1);
+  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 1px 0 rgba(255, 255, 255, 0.1);
+  margin-top: 8px;
+  margin-bottom: 8px;
+}
+@media (min-width: 768px) {
+  .navbar-form .form-group {
+    display: inline-block;
+    margin-bottom: 0;
+    vertical-align: middle;
+  }
+  .navbar-form .form-control {
+    display: inline-block;
+    width: auto;
+    vertical-align: middle;
+  }
+  .navbar-form .form-control-static {
+    display: inline-block;
+  }
+  .navbar-form .input-group {
+    display: inline-table;
+    vertical-align: middle;
+  }
+  .navbar-form .input-group .input-group-addon,
+  .navbar-form .input-group .input-group-btn,
+  .navbar-form .input-group .form-control {
+    width: auto;
+  }
+  .navbar-form .input-group > .form-control {
+    width: 100%;
+  }
+  .navbar-form .control-label {
+    margin-bottom: 0;
+    vertical-align: middle;
+  }
+  .navbar-form .radio,
+  .navbar-form .checkbox {
+    display: inline-block;
+    margin-top: 0;
+    margin-bottom: 0;
+    vertical-align: middle;
+  }
+  .navbar-form .radio label,
+  .navbar-form .checkbox label {
+    padding-left: 0;
+  }
+  .navbar-form .radio input[type="radio"],
+  .navbar-form .checkbox input[type="checkbox"] {
+    position: relative;
+    margin-left: 0;
+  }
+  .navbar-form .has-feedback .form-control-feedback {
+    top: 0;
+  }
+}
+@media (max-width: 767px) {
+  .navbar-form .form-group {
+    margin-bottom: 5px;
+  }
+  .navbar-form .form-group:last-child {
+    margin-bottom: 0;
+  }
+}
+@media (min-width: 768px) {
+  .navbar-form {
+    width: auto;
+    border: 0;
+    margin-left: 0;
+    margin-right: 0;
+    padding-top: 0;
+    padding-bottom: 0;
+    -webkit-box-shadow: none;
+    box-shadow: none;
+  }
+}
+.navbar-nav > li > .dropdown-menu {
+  margin-top: 0;
+  border-top-right-radius: 0;
+  border-top-left-radius: 0;
+}
+.navbar-fixed-bottom .navbar-nav > li > .dropdown-menu {
+  margin-bottom: 0;
+  border-top-right-radius: 4px;
+  border-top-left-radius: 4px;
+  border-bottom-right-radius: 0;
+  border-bottom-left-radius: 0;
+}
+.navbar-btn {
+  margin-top: 8px;
+  margin-bottom: 8px;
+}
+.navbar-btn.btn-sm {
+  margin-top: 10px;
+  margin-bottom: 10px;
+}
+.navbar-btn.btn-xs {
+  margin-top: 14px;
+  margin-bottom: 14px;
+}
+.navbar-text {
+  margin-top: 15px;
+  margin-bottom: 15px;
+}
+@media (min-width: 768px) {
+  .navbar-text {
+    float: left;
+    margin-left: 15px;
+    margin-right: 15px;
+  }
+}
+@media (min-width: 768px) {
+  .navbar-left {
+    float: left !important;
+  }
+  .navbar-right {
+    float: right !important;
+    margin-right: -15px;
+  }
+  .navbar-right ~ .navbar-right {
+    margin-right: 0;
+  }
+}
+.navbar-default {
+  background-color: #f8f8f8;
+  border-color: #e7e7e7;
+}
+.navbar-default .navbar-brand {
+  color: #777;
+}
+.navbar-default .navbar-brand:hover,
+.navbar-default .navbar-brand:focus {
+  color: #5e5e5e;
+  background-color: transparent;
+}
+.navbar-default .navbar-text {
+  color: #777;
+}
+.navbar-default .navbar-nav > li > a {
+  color: #777;
+}
+.navbar-default .navbar-nav > li > a:hover,
+.navbar-default .navbar-nav > li > a:focus {
+  color: #333;
+  background-color: transparent;
+}
+.navbar-default .navbar-nav > .active > a,
+.navbar-default .navbar-nav > .active > a:hover,
+.navbar-default .navbar-nav > .active > a:focus {
+  color: #555;
+  background-color: #e7e7e7;
+}
+.navbar-default .navbar-nav > .disabled > a,
+.navbar-default .navbar-nav > .disabled > a:hover,
+.navbar-default .navbar-nav > .disabled > a:focus {
+  color: #ccc;
+  background-color: transparent;
+}
+.navbar-default .navbar-toggle {
+  border-color: #ddd;
+}
+.navbar-default .navbar-toggle:hover,
+.navbar-default .navbar-toggle:focus {
+  background-color: #ddd;
+}
+.navbar-default .navbar-toggle .icon-bar {
+  background-color: #888;
+}
+.navbar-default .navbar-collapse,
+.navbar-default .navbar-form {
+  border-color: #e7e7e7;
+}
+.navbar-default .navbar-nav > .open > a,
+.navbar-default .navbar-nav > .open > a:hover,
+.navbar-default .navbar-nav > .open > a:focus {
+  background-color: #e7e7e7;
+  color: #555;
+}
+@media (max-width: 767px) {
+  .navbar-default .navbar-nav .open .dropdown-menu > li > a {
+    color: #777;
+  }
+  .navbar-default .navbar-nav .open .dropdown-menu > li > a:hover,
+  .navbar-default .navbar-nav .open .dropdown-menu > li > a:focus {
+    color: #333;
+    background-color: transparent;
+  }
+  .navbar-default .navbar-nav .open .dropdown-menu > .active > a,
+  .navbar-default .navbar-nav .open .dropdown-menu > .active > a:hover,
+  .navbar-default .navbar-nav .open .dropdown-menu > .active > a:focus {
+    color: #555;
+    background-color: #e7e7e7;
+  }
+  .navbar-default .navbar-nav .open .dropdown-menu > .disabled > a,
+  .navbar-default .navbar-nav .open .dropdown-menu > .disabled > a:hover,
+  .navbar-default .navbar-nav .open .dropdown-menu > .disabled > a:focus {
+    color: #ccc;
+    background-color: transparent;
+  }
+}
+.navbar-default .navbar-link {
+  color: #777;
+}
+.navbar-default .navbar-link:hover {
+  color: #333;
+}
+.navbar-default .btn-link {
+  color: #777;
+}
+.navbar-default .btn-link:hover,
+.navbar-default .btn-link:focus {
+  color: #333;
+}
+.navbar-default .btn-link[disabled]:hover,
+fieldset[disabled] .navbar-default .btn-link:hover,
+.navbar-default .btn-link[disabled]:focus,
+fieldset[disabled] .navbar-default .btn-link:focus {
+  color: #ccc;
+}
+.navbar-inverse {
+  background-color: #222;
+  border-color: #080808;
+}
+.navbar-inverse .navbar-brand {
+  color: #9d9d9d;
+}
+.navbar-inverse .navbar-brand:hover,
+.navbar-inverse .navbar-brand:focus {
+  color: #fff;
+  background-color: transparent;
+}
+.navbar-inverse .navbar-text {
+  color: #9d9d9d;
+}
+.navbar-inverse .navbar-nav > li > a {
+  color: #9d9d9d;
+}
+.navbar-inverse .navbar-nav > li > a:hover,
+.navbar-inverse .navbar-nav > li > a:focus {
+  color: #fff;
+  background-color: transparent;
+}
+.navbar-inverse .navbar-nav > .active > a,
+.navbar-inverse .navbar-nav > .active > a:hover,
+.navbar-inverse .navbar-nav > .active > a:focus {
+  color: #fff;
+  background-color: #080808;
+}
+.navbar-inverse .navbar-nav > .disabled > a,
+.navbar-inverse .navbar-nav > .disabled > a:hover,
+.navbar-inverse .navbar-nav > .disabled > a:focus {
+  color: #444;
+  background-color: transparent;
+}
+.navbar-inverse .navbar-toggle {
+  border-color: #333;
+}
+.navbar-inverse .navbar-toggle:hover,
+.navbar-inverse .navbar-toggle:focus {
+  background-color: #333;
+}
+.navbar-inverse .navbar-toggle .icon-bar {
+  background-color: #fff;
+}
+.navbar-inverse .navbar-collapse,
+.navbar-inverse .navbar-form {
+  border-color: #101010;
+}
+.navbar-inverse .navbar-nav > .open > a,
+.navbar-inverse .navbar-nav > .open > a:hover,
+.navbar-inverse .navbar-nav > .open > a:focus {
+  background-color: #080808;
+  color: #fff;
+}
+@media (max-width: 767px) {
+  .navbar-inverse .navbar-nav .open .dropdown-menu > .dropdown-header {
+    border-color: #080808;
+  }
+  .navbar-inverse .navbar-nav .open .dropdown-menu .divider {
+    background-color: #080808;
+  }
+  .navbar-inverse .navbar-nav .open .dropdown-menu > li > a {
+    color: #9d9d9d;
+  }
+  .navbar-inverse .navbar-nav .open .dropdown-menu > li > a:hover,
+  .navbar-inverse .navbar-nav .open .dropdown-menu > li > a:focus {
+    color: #fff;
+    background-color: transparent;
+  }
+  .navbar-inverse .navbar-nav .open .dropdown-menu > .active > a,
+  .navbar-inverse .navbar-nav .open .dropdown-menu > .active > a:hover,
+  .navbar-inverse .navbar-nav .open .dropdown-menu > .active > a:focus {
+    color: #fff;
+    background-color: #080808;
+  }
+  .navbar-inverse .navbar-nav .open .dropdown-menu > .disabled > a,
+  .navbar-inverse .navbar-nav .open .dropdown-menu > .disabled > a:hover,
+  .navbar-inverse .navbar-nav .open .dropdown-menu > .disabled > a:focus {
+    color: #444;
+    background-color: transparent;
+  }
+}
+.navbar-inverse .navbar-link {
+  color: #9d9d9d;
+}
+.navbar-inverse .navbar-link:hover {
+  color: #fff;
+}
+.navbar-inverse .btn-link {
+  color: #9d9d9d;
+}
+.navbar-inverse .btn-link:hover,
+.navbar-inverse .btn-link:focus {
+  color: #fff;
+}
+.navbar-inverse .btn-link[disabled]:hover,
+fieldset[disabled] .navbar-inverse .btn-link:hover,
+.navbar-inverse .btn-link[disabled]:focus,
+fieldset[disabled] .navbar-inverse .btn-link:focus {
+  color: #444;
+}
+.alert {
+  padding: 15px;
+  margin-bottom: 20px;
+  border: 1px solid transparent;
+  border-radius: 4px;
+}
+.alert h4 {
+  margin-top: 0;
+  color: inherit;
+}
+.alert .alert-link {
+  font-weight: bold;
+}
+.alert > p,
+.alert > ul {
+  margin-bottom: 0;
+}
+.alert > p + p {
+  margin-top: 5px;
+}
+.alert-dismissable,
+.alert-dismissible {
+  padding-right: 35px;
+}
+.alert-dismissable .close,
+.alert-dismissible .close {
+  position: relative;
+  top: -2px;
+  right: -21px;
+  color: inherit;
+}
+.alert-success {
+  background-color: #dff0d8;
+  border-color: #d6e9c6;
+  color: #3c763d;
+}
+.alert-success hr {
+  border-top-color: #c9e2b3;
+}
+.alert-success .alert-link {
+  color: #2b542c;
+}
+.alert-info {
+  background-color: #d9edf7;
+  border-color: #bce8f1;
+  color: #31708f;
+}
+.alert-info hr {
+  border-top-color: #a6e1ec;
+}
+.alert-info .alert-link {
+  color: #245269;
+}
+.alert-warning {
+  background-color: #fcf8e3;
+  border-color: #faebcc;
+  color: #8a6d3b;
+}
+.alert-warning hr {
+  border-top-color: #f7e1b5;
+}
+.alert-warning .alert-link {
+  color: #66512c;
+}
+.alert-danger {
+  background-color: #f2dede;
+  border-color: #ebccd1;
+  color: #a94442;
+}
+.alert-danger hr {
+  border-top-color: #e4b9c0;
+}
+.alert-danger .alert-link {
+  color: #843534;
+}
+@-webkit-keyframes progress-bar-stripes {
+  from {
+    background-position: 40px 0;
+  }
+  to {
+    background-position: 0 0;
+  }
+}
+@keyframes progress-bar-stripes {
+  from {
+    background-position: 40px 0;
+  }
+  to {
+    background-position: 0 0;
+  }
+}
+.progress {
+  overflow: hidden;
+  height: 20px;
+  margin-bottom: 20px;
+  background-color: #f5f5f5;
+  border-radius: 4px;
+  -webkit-box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
+  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
+}
+.progress-bar {
+  float: left;
+  width: 0%;
+  height: 100%;
+  font-size: 12px;
+  line-height: 20px;
+  color: #fff;
+  text-align: center;
+  background-color: #337ab7;
+  -webkit-box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.15);
+  box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.15);
+  -webkit-transition: width 0.6s ease;
+  -o-transition: width 0.6s ease;
+  transition: width 0.6s ease;
+}
+.progress-striped .progress-bar,
+.progress-bar-striped {
+  background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+  background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+  background-size: 40px 40px;
+}
+.progress.active .progress-bar,
+.progress-bar.active {
+  -webkit-animation: progress-bar-stripes 2s linear infinite;
+  -o-animation: progress-bar-stripes 2s linear infinite;
+  animation: progress-bar-stripes 2s linear infinite;
+}
+.progress-bar-success {
+  background-color: #5cb85c;
+}
+.progress-striped .progress-bar-success {
+  background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+  background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+}
+.progress-bar-info {
+  background-color: #5bc0de;
+}
+.progress-striped .progress-bar-info {
+  background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+  background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+}
+.progress-bar-warning {
+  background-color: #f0ad4e;
+}
+.progress-striped .progress-bar-warning {
+  background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+  background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+}
+.progress-bar-danger {
+  background-color: #d9534f;
+}
+.progress-striped .progress-bar-danger {
+  background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+  background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+}
+.media {
+  margin-top: 15px;
+}
+.media:first-child {
+  margin-top: 0;
+}
+.media,
+.media-body {
+  zoom: 1;
+  overflow: hidden;
+}
+.media-body {
+  width: 10000px;
+}
+.media-object {
+  display: block;
+}
+.media-object.img-thumbnail {
+  max-width: none;
+}
+.media-right,
+.media > .pull-right {
+  padding-left: 10px;
+}
+.media-left,
+.media > .pull-left {
+  padding-right: 10px;
+}
+.media-left,
+.media-right,
+.media-body {
+  display: table-cell;
+  vertical-align: top;
+}
+.media-middle {
+  vertical-align: middle;
+}
+.media-bottom {
+  vertical-align: bottom;
+}
+.media-heading {
+  margin-top: 0;
+  margin-bottom: 5px;
+}
+.media-list {
+  padding-left: 0;
+  list-style: none;
+}
+.well {
+  min-height: 20px;
+  padding: 19px;
+  margin-bottom: 20px;
+  background-color: #f5f5f5;
+  border: 1px solid #e3e3e3;
+  border-radius: 4px;
+  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05);
+  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05);
+}
+.well blockquote {
+  border-color: #ddd;
+  border-color: rgba(0, 0, 0, 0.15);
+}
+.well-lg {
+  padding: 24px;
+  border-radius: 6px;
+}
+.well-sm {
+  padding: 9px;
+  border-radius: 3px;
+}
+.close {
+  float: right;
+  font-size: 21px;
+  font-weight: bold;
+  line-height: 1;
+  color: #000;
+  text-shadow: 0 1px 0 #fff;
+  opacity: 0.2;
+  filter: alpha(opacity=20);
+}
+.close:hover,
+.close:focus {
+  color: #000;
+  text-decoration: none;
+  cursor: pointer;
+  opacity: 0.5;
+  filter: alpha(opacity=50);
+}
+button.close {
+  padding: 0;
+  cursor: pointer;
+  background: transparent;
+  border: 0;
+  -webkit-appearance: none;
+}
+.modal-open {
+  overflow: hidden;
+}
+.modal {
+  display: none;
+  overflow: hidden;
+  position: fixed;
+  top: 0;
+  right: 0;
+  bottom: 0;
+  left: 0;
+  z-index: 1050;
+  -webkit-overflow-scrolling: touch;
+  outline: 0;
+}
+.modal.fade .modal-dialog {
+  -webkit-transform: translate(0, -25%);
+  -ms-transform: translate(0, -25%);
+  -o-transform: translate(0, -25%);
+  transform: translate(0, -25%);
+  -webkit-transition: -webkit-transform 0.3s ease-out;
+  -moz-transition: -moz-transform 0.3s ease-out;
+  -o-transition: -o-transform 0.3s ease-out;
+  transition: transform 0.3s ease-out;
+}
+.modal.in .modal-dialog {
+  -webkit-transform: translate(0, 0);
+  -ms-transform: translate(0, 0);
+  -o-transform: translate(0, 0);
+  transform: translate(0, 0);
+}
+.modal-open .modal {
+  overflow-x: hidden;
+  overflow-y: auto;
+}
+.modal-dialog {
+  position: relative;
+  width: auto;
+  margin: 10px;
+}
+.modal-content {
+  position: relative;
+  background-color: #fff;
+  border: 1px solid #999;
+  border: 1px solid rgba(0, 0, 0, 0.2);
+  border-radius: 6px;
+  -webkit-box-shadow: 0 3px 9px rgba(0, 0, 0, 0.5);
+  box-shadow: 0 3px 9px rgba(0, 0, 0, 0.5);
+  background-clip: padding-box;
+  outline: 0;
+}
+.modal-backdrop {
+  position: fixed;
+  top: 0;
+  right: 0;
+  bottom: 0;
+  left: 0;
+  z-index: 1040;
+  background-color: #000;
+}
+.modal-backdrop.fade {
+  opacity: 0;
+  filter: alpha(opacity=0);
+}
+.modal-backdrop.in {
+  opacity: 0.5;
+  filter: alpha(opacity=50);
+}
+.modal-header {
+  padding: 15px;
+  border-bottom: 1px solid #e5e5e5;
+}
+.modal-header .close {
+  margin-top: -2px;
+}
+.modal-title {
+  margin: 0;
+  line-height: 1.42857143;
+}
+.modal-body {
+  position: relative;
+  padding: 15px;
+}
+.modal-footer {
+  padding: 15px;
+  text-align: right;
+  border-top: 1px solid #e5e5e5;
+}
+.modal-footer .btn + .btn {
+  margin-left: 5px;
+  margin-bottom: 0;
+}
+.modal-footer .btn-group .btn + .btn {
+  margin-left: -1px;
+}
+.modal-footer .btn-block + .btn-block {
+  margin-left: 0;
+}
+.modal-scrollbar-measure {
+  position: absolute;
+  top: -9999px;
+  width: 50px;
+  height: 50px;
+  overflow: scroll;
+}
+@media (min-width: 768px) {
+  .modal-dialog {
+    width: 600px;
+    margin: 30px auto;
+  }
+  .modal-content {
+    -webkit-box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5);
+    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5);
+  }
+  .modal-sm {
+    width: 300px;
+  }
+}
+@media (min-width: 992px) {
+  .modal-lg {
+    width: 900px;
+  }
+}
+.clearfix:before,
+.clearfix:after,
+.dl-horizontal dd:before,
+.dl-horizontal dd:after,
+.container:before,
+.container:after,
+.container-fluid:before,
+.container-fluid:after,
+.row:before,
+.row:after,
+.form-horizontal .form-group:before,
+.form-horizontal .form-group:after,
+.nav:before,
+.nav:after,
+.navbar:before,
+.navbar:after,
+.navbar-header:before,
+.navbar-header:after,
+.navbar-collapse:before,
+.navbar-collapse:after,
+.modal-header:before,
+.modal-header:after,
+.modal-footer:before,
+.modal-footer:after {
+  content: " ";
+  display: table;
+}
+.clearfix:after,
+.dl-horizontal dd:after,
+.container:after,
+.container-fluid:after,
+.row:after,
+.form-horizontal .form-group:after,
+.nav:after,
+.navbar:after,
+.navbar-header:after,
+.navbar-collapse:after,
+.modal-header:after,
+.modal-footer:after {
+  clear: both;
+}
+.center-block {
+  display: block;
+  margin-left: auto;
+  margin-right: auto;
+}
+.pull-right {
+  float: right !important;
+}
+.pull-left {
+  float: left !important;
+}
+.hide {
+  display: none !important;
+}
+.show {
+  display: block !important;
+}
+.invisible {
+  visibility: hidden;
+}
+.text-hide {
+  font: 0/0 a;
+  color: transparent;
+  text-shadow: none;
+  background-color: transparent;
+  border: 0;
+}
+.hidden {
+  display: none !important;
+}
+.affix {
+  position: fixed;
+}
+@-ms-viewport {
+  width: device-width;
+}
+.visible-xs,
+.visible-sm,
+.visible-md,
+.visible-lg {
+  display: none !important;
+}
+.visible-xs-block,
+.visible-xs-inline,
+.visible-xs-inline-block,
+.visible-sm-block,
+.visible-sm-inline,
+.visible-sm-inline-block,
+.visible-md-block,
+.visible-md-inline,
+.visible-md-inline-block,
+.visible-lg-block,
+.visible-lg-inline,
+.visible-lg-inline-block {
+  display: none !important;
+}
+@media (max-width: 767px) {
+  .visible-xs {
+    display: block !important;
+  }
+  table.visible-xs {
+    display: table !important;
+  }
+  tr.visible-xs {
+    display: table-row !important;
+  }
+  th.visible-xs,
+  td.visible-xs {
+    display: table-cell !important;
+  }
+}
+@media (max-width: 767px) {
+  .visible-xs-block {
+    display: block !important;
+  }
+}
+@media (max-width: 767px) {
+  .visible-xs-inline {
+    display: inline !important;
+  }
+}
+@media (max-width: 767px) {
+  .visible-xs-inline-block {
+    display: inline-block !important;
+  }
+}
+@media (min-width: 768px) and (max-width: 991px) {
+  .visible-sm {
+    display: block !important;
+  }
+  table.visible-sm {
+    display: table !important;
+  }
+  tr.visible-sm {
+    display: table-row !important;
+  }
+  th.visible-sm,
+  td.visible-sm {
+    display: table-cell !important;
+  }
+}
+@media (min-width: 768px) and (max-width: 991px) {
+  .visible-sm-block {
+    display: block !important;
+  }
+}
+@media (min-width: 768px) and (max-width: 991px) {
+  .visible-sm-inline {
+    display: inline !important;
+  }
+}
+@media (min-width: 768px) and (max-width: 991px) {
+  .visible-sm-inline-block {
+    display: inline-block !important;
+  }
+}
+@media (min-width: 992px) and (max-width: 1199px) {
+  .visible-md {
+    display: block !important;
+  }
+  table.visible-md {
+    display: table !important;
+  }
+  tr.visible-md {
+    display: table-row !important;
+  }
+  th.visible-md,
+  td.visible-md {
+    display: table-cell !important;
+  }
+}
+@media (min-width: 992px) and (max-width: 1199px) {
+  .visible-md-block {
+    display: block !important;
+  }
+}
+@media (min-width: 992px) and (max-width: 1199px) {
+  .visible-md-inline {
+    display: inline !important;
+  }
+}
+@media (min-width: 992px) and (max-width: 1199px) {
+  .visible-md-inline-block {
+    display: inline-block !important;
+  }
+}
+@media (min-width: 1200px) {
+  .visible-lg {
+    display: block !important;
+  }
+  table.visible-lg {
+    display: table !important;
+  }
+  tr.visible-lg {
+    display: table-row !important;
+  }
+  th.visible-lg,
+  td.visible-lg {
+    display: table-cell !important;
+  }
+}
+@media (min-width: 1200px) {
+  .visible-lg-block {
+    display: block !important;
+  }
+}
+@media (min-width: 1200px) {
+  .visible-lg-inline {
+    display: inline !important;
+  }
+}
+@media (min-width: 1200px) {
+  .visible-lg-inline-block {
+    display: inline-block !important;
+  }
+}
+@media (max-width: 767px) {
+  .hidden-xs {
+    display: none !important;
+  }
+}
+@media (min-width: 768px) and (max-width: 991px) {
+  .hidden-sm {
+    display: none !important;
+  }
+}
+@media (min-width: 992px) and (max-width: 1199px) {
+  .hidden-md {
+    display: none !important;
+  }
+}
+@media (min-width: 1200px) {
+  .hidden-lg {
+    display: none !important;
+  }
+}
+.visible-print {
+  display: none !important;
+}
+@media print {
+  .visible-print {
+    display: block !important;
+  }
+  table.visible-print {
+    display: table !important;
+  }
+  tr.visible-print {
+    display: table-row !important;
+  }
+  th.visible-print,
+  td.visible-print {
+    display: table-cell !important;
+  }
+}
+.visible-print-block {
+  display: none !important;
+}
+@media print {
+  .visible-print-block {
+    display: block !important;
+  }
+}
+.visible-print-inline {
+  display: none !important;
+}
+@media print {
+  .visible-print-inline {
+    display: inline !important;
+  }
+}
+.visible-print-inline-block {
+  display: none !important;
+}
+@media print {
+  .visible-print-inline-block {
+    display: inline-block !important;
+  }
+}
+@media print {
+  .hidden-print {
+    display: none !important;
+  }
+}
+.auth-changed-message {
+  width: 100%;
+  position: fixed;
+  top: 0px;
+  left: 0px;
+  z-index: 1070;
+  transition: top 300ms ease;
+}
+.auth-changed-message > div {
+  position: absolute;
+  bottom: 0px;
+  width: 100%;
+  background-color: #eeeeee;
+  padding: 20px 0px;
+}
+.auth-changed-message.show > div {
+  top: 0px;
+  bottom: auto;
+}
+.auth-changed-message p {
+  padding: 10px 0px;
+  color: #222222;
+  font-size: 18px;
+}
+@media screen and (max-width: 991px) {
+  .auth-changed-message {
+    text-align: center;
+  }
+  .auth-changed-message .btn {
+    padding: 10px 16px;
+    font-size: 18px;
+  }
+}
+.alerts-snackbar {
+  position: fixed;
+  top: -100%;
+  width: 100%;
+  z-index: 1060;
+  text-align: center;
+  font-size: 18px;
+  transition: top 300ms ease;
+  pointer-events: none;
+}
+.alerts-snackbar.in {
+  top: 0px;
+  transition: top 200ms ease;
+}
+.alerts-snackbar p {
+  display: inline-block;
+  border-radius: 0px 0px 4px 4px;
+  margin: 0px;
+  pointer-events: all;
+}
+.loader-compact {
+  width: 100%;
+  height: 49px;
+  text-align: center;
+}
+.loader-spinning-wheel {
+  width: 49px;
+  height: 49px;
+  margin: 0 auto;
+  border: 3px solid #000000;
+  border-radius: 50%;
+  border-left-color: transparent;
+  border-right-color: transparent;
+  animation: cssload-spin 575ms infinite linear;
+  -o-animation: cssload-spin 575ms infinite linear;
+  -ms-animation: cssload-spin 575ms infinite linear;
+  -webkit-animation: cssload-spin 575ms infinite linear;
+  -moz-animation: cssload-spin 575ms infinite linear;
+}
+@keyframes cssload-spin {
+  100% {
+    transform: rotate(360deg);
+  }
+}
+@-o-keyframes cssload-spin {
+  100% {
+    -o-transform: rotate(360deg);
+    transform: rotate(360deg);
+  }
+}
+@-ms-keyframes cssload-spin {
+  100% {
+    -ms-transform: rotate(360deg);
+    transform: rotate(360deg);
+  }
+}
+@-webkit-keyframes cssload-spin {
+  100% {
+    -webkit-transform: rotate(360deg);
+    transform: rotate(360deg);
+  }
+}
+@-moz-keyframes cssload-spin {
+  100% {
+    -moz-transform: rotate(360deg);
+    transform: rotate(360deg);
+  }
+}
+.navbar {
+  margin-bottom: 0px;
+}
+.navbar .navbar-full .navbar-brand > * {
+  display: inline-block;
+}
+.navbar .navbar-full .navbar-brand img {
+  height: 16px;
+}
+.navbar .navbar-full .nav-guest,
+.navbar .navbar-full .nav-user {
+  float: right;
+}
+.navbar .navbar-full .nav-guest .navbar-btn,
+.navbar .navbar-full .nav-user .navbar-btn {
+  margin-left: 15px;
+}
+.navbar .navbar-full .nav-user .dropdown-toggle {
+  padding: 8px;
+}
+.navbar .navbar-full .nav-user .dropdown-toggle img {
+  width: 34px;
+  height: 34px;
+}
+.navbar ul.navbar-compact-nav {
+  margin: 0px;
+  display: table;
+  width: 100%;
+}
+.navbar ul.navbar-compact-nav > li {
+  display: table-cell;
+}
+.navbar ul.navbar-compact-nav > li > a,
+.navbar ul.navbar-compact-nav > li > button {
+  background: none;
+  border: none;
+  margin: 0px;
+  padding-top: 10px;
+  padding-bottom: 10px;
+  width: 100%;
+  color: #777;
+  text-align: center;
+}
+.navbar ul.navbar-compact-nav > li > a:hover,
+.navbar ul.navbar-compact-nav > li > button:hover,
+.navbar ul.navbar-compact-nav > li > a:focus,
+.navbar ul.navbar-compact-nav > li > button:focus {
+  color: #333;
+  background-color: transparent;
+}
+.navbar ul.navbar-compact-nav > li > a > img,
+.navbar ul.navbar-compact-nav > li > button > img {
+  width: 24px;
+  height: 24px;
+}
+.navbar ul.navbar-compact-nav > li > button {
+  padding-top: 10px;
+  padding-bottom: 10px;
+}
+.navbar ul.navbar-compact-nav > li > a > .material-icon {
+  font-size: 24px;
+  line-height: 24px;
+}
+@media (max-width: 767px) {
+  .navbar.navbar-misago {
+    min-height: auto;
+  }
+}
+@font-face {
+  font-family: 'Material Icons';
+  font-style: normal;
+  font-weight: 400;
+  src: url(../fonts/MaterialIcons-Regular.eot);
+  /* For IE6-8 */
+  src: local('Material Icons'), local('MaterialIcons-Regular'), url(../fonts/MaterialIcons-Regular.woff2) format('woff2'), url(../fonts/MaterialIcons-Regular.woff) format('woff'), url(../fonts/MaterialIcons-Regular.ttf) format('truetype');
+}
+.material-icon {
+  font-family: 'Material Icons';
+  font-weight: normal;
+  font-style: normal;
+  display: inline-block;
+  width: 1em;
+  height: 1em;
+  line-height: 1;
+  text-align: center;
+  text-transform: none;
+  letter-spacing: normal;
+  vertical-align: middle;
+  /* Support for all WebKit browsers. */
+  -webkit-font-smoothing: antialiased;
+  /* Support for Safari and Chrome. */
+  text-rendering: optimizeLegibility;
+  /* Support for Firefox. */
+  -moz-osx-font-smoothing: grayscale;
+  /* Support for IE. */
+  font-feature-settings: 'liga';
+}
+@media screen and (max-width: 991px) {
+  .modal-message {
+    text-align: center;
+  }
+  .modal-message .message-icon {
+    margin: 30px;
+  }
+  .modal-message .message-icon .material-icon {
+    font-size: 160px;
+  }
+}
+@media screen and (min-width: 992px) {
+  .modal-message .message-icon {
+    float: left;
+  }
+  .modal-message .message-icon .material-icon {
+    font-size: 80px;
+  }
+  .modal-message .message-body {
+    margin-left: 100px;
+  }
+}
+@media screen and (max-width: 991px) {
+  .modal-register .modal-footer {
+    text-align: center;
+  }
+  .modal-register .modal-footer a {
+    display: block;
+  }
+  .modal-register .modal-footer .btn {
+    display: block;
+    float: none;
+    margin-top: 10px;
+    width: 100%;
+  }
+}
+.material-icon.form-control-feedback {
+  top: 6px;
+  right: 24px;
+  font-size: 1.42857143;
+  line-height: 1.42857143;
+}
+.well.well-form.well-done {
+  font-size: 18px;
+  text-align: center;
+}
+.well.well-form.well-done .message-icon {
+  margin-bottom: 10px;
+  font-size: 90px;
+  line-height: 90px;
+}
+.well.well-form.well-done .message-body {
+  margin-bottom: 6.66666667px;
+}
+.well.well-form.well-noscript {
+  font-size: 18px;
+  text-align: center;
+}
+.well.well-form.well-noscript .message-icon {
+  margin-bottom: 10px;
+  font-size: 90px;
+  line-height: 90px;
+}
+.btn.btn-loading,
+.btn.btn-loading:link,
+.btn.btn-loading:active,
+.btn.btn-loading:visited,
+.btn.btn-loading:hover,
+.btn.btn-loading:focus {
+  color: transparent;
+}
+.btn.btn-loading .loader-compact,
+.btn.btn-loading:link .loader-compact,
+.btn.btn-loading:active .loader-compact,
+.btn.btn-loading:visited .loader-compact,
+.btn.btn-loading:hover .loader-compact,
+.btn.btn-loading:focus .loader-compact {
+  height: 20px;
+}
+.btn.btn-loading .loader-compact > div,
+.btn.btn-loading:link .loader-compact > div,
+.btn.btn-loading:active .loader-compact > div,
+.btn.btn-loading:visited .loader-compact > div,
+.btn.btn-loading:hover .loader-compact > div,
+.btn.btn-loading:focus .loader-compact > div {
+  width: 20px;
+  height: 20px;
+}
+.btn.btn-loading.btn-default .loader-compact > div {
+  border-top-color: #333;
+  border-bottom-color: #333;
+}
+.btn.btn-loading.btn-primary .loader-compact > div {
+  border-top-color: #fff;
+  border-bottom-color: #fff;
+}
+.btn.btn-loading.btn-success .loader-compact > div {
+  border-top-color: #fff;
+  border-bottom-color: #fff;
+}
+.btn.btn-loading.btn-info .loader-compact > div {
+  border-top-color: #fff;
+  border-bottom-color: #fff;
+}
+.btn.btn-loading.btn-warning .loader-compact > div {
+  border-top-color: #fff;
+  border-bottom-color: #fff;
+}
+.btn.btn-loading.btn-danger .loader-compact > div {
+  border-top-color: #fff;
+  border-bottom-color: #fff;
+}
+.dropdown-menu > li > a,
+.dropdown-menu > li > .btn-link {
+  display: block;
+  border: none;
+  clear: both;
+  float: none;
+  padding: 4px 20px;
+  width: 100%;
+  color: #333333;
+  font-weight: normal;
+  line-height: 1.42857143;
+  text-align: left;
+  white-space: nowrap;
+}
+.dropdown-menu > li > a:hover,
+.dropdown-menu > li > .btn-link:hover,
+.dropdown-menu > li > a:focus,
+.dropdown-menu > li > .btn-link:focus {
+  background-color: #f5f5f5;
+  color: #262626;
+  text-decoration: none;
+}
+.dropdown-menu > li > a .material-icon,
+.dropdown-menu > li > .btn-link .material-icon {
+  margin: -2px 0px;
+  margin-right: 7px;
+  position: relative;
+  bottom: 1px;
+  font-size: 18px;
+}
+.dropdown-menu .dropdown-footer {
+  padding: 6px 20px;
+}
+.mobile-dropdown {
+  position: static;
+  margin: 0px;
+}
+.mobile-dropdown.open > .dropdown-menu {
+  border: none;
+  border-radius: 0;
+  -webkit-box-shadow: none;
+  box-shadow: none;
+  display: block;
+  margin: 0px;
+  width: 100%;
+  position: static;
+}
+.user-dropdown .guest-preview {
+  text-align: center;
+}
+.user-dropdown .guest-preview .row {
+  margin: 0px;
+}
+.navbar .user-dropdown {
+  width: 240px;
+}
+.user-dropdown .dropdown-header {
+  padding: 6px 20px;
+  font-size: 18px;
+}
+.user-dropdown .dropdown-header strong {
+  font-weight: normal;
+}
+.misago-footer {
+  margin-top: 30px;
+  margin-bottom: 50px;
+}
+.misago-footer .footer-content {
+  border-top: 1px solid #eeeeee;
+  padding-top: 30px;
+}
+.misago-footer .noscript-message .material-icon {
+  position: relative;
+  bottom: 1px;
+  font-size: 18px;
+}
+@media screen and (max-width: 991px) {
+  .page-message,
+  .page-error {
+    text-align: center;
+  }
+  .page-message .message-icon,
+  .page-error .message-icon {
+    margin: 30px;
+  }
+  .page-message .message-icon .material-icon,
+  .page-error .message-icon .material-icon {
+    font-size: 160px;
+  }
+}
+@media screen and (min-width: 992px) {
+  .page-message .message-panel,
+  .page-error .message-panel {
+    margin: 60px auto;
+    max-width: 779.35px;
+    overflow: auto;
+  }
+  .page-message .message-icon,
+  .page-error .message-icon {
+    float: left;
+  }
+  .page-message .message-icon .material-icon,
+  .page-error .message-icon .material-icon {
+    font-size: 80px;
+  }
+  .page-message .message-body,
+  .page-error .message-body {
+    margin-left: 100px;
+  }
+}

BIN
misago/static/misago/img/site-icon.png


BIN
misago/static/misago/img/site-logo.png


+ 2466 - 2
misago/static/misago/js/misago.js

@@ -1,2 +1,2466 @@
-!function e(t,n,r){function o(u,i){if(!n[u]){if(!t[u]){var l="function"==typeof require&&require;if(!i&&l)return l(u,!0);if(a)return a(u,!0);var s=new Error("Cannot find module '"+u+"'");throw s.code="MODULE_NOT_FOUND",s}var c=n[u]={exports:{}};t[u][0].call(c.exports,function(e){var n=t[u][1][e];return o(n?n:e)},c,c.exports,e,t,n,r)}return n[u].exports}for(var a="function"==typeof require&&require,u=0;u<r.length;u++)o(r[u]);return o}({1:[function(e,t,n){"use strict";function r(e){return e&&e.__esModule?e:{"default":e}}function o(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function a(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function u(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}var i=function(){function e(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}return function(t,n,r){return n&&e(t.prototype,n),r&&e(t,r),t}}();Object.defineProperty(n,"__esModule",{value:!0});var l=e("react"),s=r(l),c=e("./loader"),f=r(c),d=function(e){function t(){return o(this,t),a(this,Object.getPrototypeOf(t).apply(this,arguments))}return u(t,e),i(t,[{key:"render",value:function(){var e=null;e=this.props.loading?s["default"].createElement(f["default"],null):this.props.children;var t="btn "+this.props.className;return s["default"].createElement("button",{type:this.props.type,className:t,disabled:this.props.disabled,onClick:this.props.onClick},e)}}]),t}(s["default"].Component);n["default"]=d,d.defaultProps={className:"btn-default",type:"submit",loading:!1,disabled:!1,onClick:null}},{"./loader":2,react:"react"}],2:[function(e,t,n){"use strict";function r(e){return e&&e.__esModule?e:{"default":e}}function o(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function a(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function u(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}var i=function(){function e(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}return function(t,n,r){return n&&e(t.prototype,n),r&&e(t,r),t}}();Object.defineProperty(n,"__esModule",{value:!0});var l=e("react"),s=r(l),c=function(e){function t(){return o(this,t),a(this,Object.getPrototypeOf(t).apply(this,arguments))}return u(t,e),i(t,[{key:"render",value:function(){return s["default"].createElement("div",{className:"loader-compact"},s["default"].createElement("div",{className:"bounce1"}),s["default"].createElement("div",{className:"bounce2"}),s["default"].createElement("div",{className:"bounce3"}))}}]),t}(s["default"].Component);n["default"]=c},{react:"react"}],3:[function(e,t,n){"use strict";function r(e){return e&&e.__esModule?e:{"default":e}}function o(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function a(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function u(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}Object.defineProperty(n,"__esModule",{value:!0});var i=e("./button"),l=r(i),s=function(e){function t(){return o(this,t),a(this,Object.getPrototypeOf(t).apply(this,arguments))}return u(t,e),t}(l["default"]);n["default"]=s},{"./button":1}],4:[function(e,t,n){"use strict";function r(e){return e&&e.__esModule?e:{"default":e}}function o(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function a(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function u(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}var i=function(){function e(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}return function(t,n,r){return n&&e(t.prototype,n),r&&e(t,r),t}}();Object.defineProperty(n,"__esModule",{value:!0});var l=e("react"),s=r(l),c=function(e){function t(){return o(this,t),a(this,Object.getPrototypeOf(t).apply(this,arguments))}return u(t,e),i(t,[{key:"render",value:function(){return s["default"].createElement("div",{className:"modal-dialog"},s["default"].createElement("div",{className:"modal-content"},s["default"].createElement("div",{className:"modal-header"},s["default"].createElement("button",{type:"button",className:"close","data-dismiss":"modal","aria-label":"Close"},s["default"].createElement("span",{"aria-hidden":"true"},"×")),s["default"].createElement("h4",{className:"modal-title"},gettext("Register"))),s["default"].createElement("div",{className:"modal-body"},s["default"].createElement("p",null,"This will be registration form!")),s["default"].createElement("div",{className:"modal-footer"},s["default"].createElement("button",{type:"button",className:"btn btn-default","data-dismiss":"modal"},"Close"))))}}]),t}(s["default"].Component);n["default"]=c},{react:"react"}],5:[function(e,t,n){"use strict";function r(e){return e&&e.__esModule?e:{"default":e}}function o(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function a(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function u(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}var i=function(){function e(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}return function(t,n,r){return n&&e(t.prototype,n),r&&e(t,r),t}}();Object.defineProperty(n,"__esModule",{value:!0});var l=e("react"),s=r(l),c=e("../../services/snackbar"),f=r(c),d=function(e){function t(){return o(this,t),a(this,Object.getPrototypeOf(t).apply(this,arguments))}return u(t,e),i(t,[{key:"info",value:function(){f["default"].info("Lorem ipsum dolor met")}},{key:"success",value:function(){f["default"].success("Lorem ipsum dolor met")}},{key:"warning",value:function(){f["default"].warning("Lorem ipsum dolor met")}},{key:"error",value:function(){f["default"].error("Lorem ipsum dolor met")}},{key:"render",value:function(){return s["default"].createElement("div",{className:"modal-dialog"},s["default"].createElement("div",{className:"modal-content"},s["default"].createElement("div",{className:"modal-header"},s["default"].createElement("button",{type:"button",className:"close","data-dismiss":"modal","aria-label":"Close"},s["default"].createElement("span",{"aria-hidden":"true"},"×")),s["default"].createElement("h4",{className:"modal-title"},gettext("Sign in"))),s["default"].createElement("div",{className:"modal-body"},s["default"].createElement("p",null,"This will be sign in form!"),s["default"].createElement("button",{type:"button",className:"btn btn-primary",onClick:this.info},"Test info alert"),s["default"].createElement("br",null),s["default"].createElement("button",{type:"button",className:"btn btn-success",onClick:this.success},"Test success alert"),s["default"].createElement("br",null),s["default"].createElement("button",{type:"button",className:"btn btn-warning",onClick:this.warning},"Test warning alert"),s["default"].createElement("br",null),s["default"].createElement("button",{type:"button",className:"btn btn-danger",onClick:this.error},"Test error alert")),s["default"].createElement("div",{className:"modal-footer"},s["default"].createElement("button",{type:"button",className:"btn btn-default","data-dismiss":"modal"},"Close"))))}}]),t}(s["default"].Component);n["default"]=d},{"../../services/snackbar":21,react:"react"}],6:[function(e,t,n){"use strict";function r(e){return e&&e.__esModule?e:{"default":e}}function o(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function a(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function u(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}function i(e){return e.snackbar}var l=function(){function e(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}return function(t,n,r){return n&&e(t.prototype,n),r&&e(t,r),t}}();Object.defineProperty(n,"__esModule",{value:!0}),n.Snackbar=void 0,n.select=i;var s=e("react"),c=r(s),f={info:"alert-info",success:"alert-success",warning:"alert-warning",error:"alert-danger"};n.Snackbar=function(e){function t(){return o(this,t),a(this,Object.getPrototypeOf(t).apply(this,arguments))}return u(t,e),l(t,[{key:"render",value:function(){var e="alert "+f[this.props.type],t="alerts-snackbar";return t+=this.props.isVisible?" in":" out",c["default"].createElement("div",{className:t},c["default"].createElement("p",{className:e},this.props.message))}}]),t}(c["default"].Component)},{react:"react"}],7:[function(e,t,n){"use strict";function r(e){return e&&e.__esModule?e:{"default":e}}function o(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function a(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function u(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}var i=function(){function e(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}return function(t,n,r){return n&&e(t.prototype,n),r&&e(t,r),t}}();Object.defineProperty(n,"__esModule",{value:!0});var l=e("react"),s=r(l),c=e("../button"),f=r(c),d=e("../../services/modal"),p=r(d),b=e("../sign-in/root.js"),m=r(b),y=e("../register/root.js"),h=r(y),v=function(e){function t(){return o(this,t),a(this,Object.getPrototypeOf(t).apply(this,arguments))}return u(t,e),i(t,[{key:"showSignInModal",value:function(){p["default"].show(m["default"])}},{key:"showRegisterModal",value:function(){p["default"].show(h["default"])}},{key:"render",value:function(){return s["default"].createElement("div",{className:"nav nav-guest"},s["default"].createElement(f["default"],{type:"button",className:"navbar-btn btn-default",onClick:this.showSignInModal},"Sign in"),s["default"].createElement(f["default"],{type:"button",className:"navbar-btn btn-primary",onClick:this.showRegisterModal},"Register"))}}]),t}(s["default"].Component);n["default"]=v},{"../../services/modal":20,"../button":1,"../register/root.js":4,"../sign-in/root.js":5,react:"react"}],8:[function(e,t,n){"use strict";function r(e){return e&&e.__esModule?e:{"default":e}}function o(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function a(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function u(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}function i(e){return e.auth}var l=function(){function e(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}return function(t,n,r){return n&&e(t.prototype,n),r&&e(t,r),t}}();Object.defineProperty(n,"__esModule",{value:!0}),n.UserMenu=void 0,n.select=i;var s=e("react"),c=r(s),f=e("./guest-nav"),d=r(f),p=e("./user-nav"),b=r(p);n.UserMenu=function(e){function t(){return o(this,t),a(this,Object.getPrototypeOf(t).apply(this,arguments))}return u(t,e),l(t,[{key:"render",value:function(){return this.props.isAuthenticated?c["default"].createElement(b["default"],{user:this.props.user}):c["default"].createElement(d["default"],null)}}]),t}(c["default"].Component)},{"./guest-nav":7,"./user-nav":9,react:"react"}],9:[function(e,t,n){"use strict";function r(e){return e&&e.__esModule?e:{"default":e}}function o(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function a(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function u(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}var i=function(){function e(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}return function(t,n,r){return n&&e(t.prototype,n),r&&e(t,r),t}}();Object.defineProperty(n,"__esModule",{value:!0});var l=e("react"),s=r(l),c=function(e){function t(){return o(this,t),a(this,Object.getPrototypeOf(t).apply(this,arguments))}return u(t,e),i(t,[{key:"render",value:function(){return s["default"].createElement("ul",{"class":"ul nav navbar-nav nav-user"})}}]),t}(s["default"].Component);n["default"]=c},{react:"react"}],10:[function(e,t,n){(function(t){"use strict";function r(e){return e&&e.__esModule?e:{"default":e}}function o(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}var a=function(){function e(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}return function(t,n,r){return n&&e(t.prototype,n),r&&e(t,r),t}}();Object.defineProperty(n,"__esModule",{value:!0}),n.Misago=void 0;var u=e("./utils/ordered-list"),i=r(u),l=n.Misago=function(){function e(){o(this,e),this._initializers=[],this._context={}}return a(e,[{key:"addInitializer",value:function(e){this._initializers.push({key:e.name,item:e.initializer,after:e.after,before:e.before})}},{key:"init",value:function(e){var t=this;this._context=e;var n=new i["default"](this._initializers).orderedValues();n.forEach(function(e){e(t)})}},{key:"has",value:function(e){return this._context.hasOwnProperty(e)}},{key:"get",value:function(e,t){return this.has(e)?this._context[e]:t||void 0}}]),e}(),s=new l;t.misago=s,n["default"]=s}).call(this,"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{})},{"./utils/ordered-list":24}],11:[function(e,t,n){"use strict";function r(e){return e&&e.__esModule?e:{"default":e}}function o(e){c["default"].addReducer("auth",l["default"],{isAuthenticated:e.get("isAuthenticated"),isAnonymous:!e.get("isAuthenticated"),user:e.get("user")})}Object.defineProperty(n,"__esModule",{value:!0}),n["default"]=o;var a=e("../index"),u=r(a),i=e("../reducers/auth"),l=r(i),s=e("../services/store"),c=r(s);u["default"].addInitializer({name:"reducer:auth",initializer:o,before:"store"})},{"../index":10,"../reducers/auth":18,"../services/store":22}],12:[function(e,t,n){"use strict";function r(e){return e&&e.__esModule?e:{"default":e}}function o(){var e=document.getElementById("modal-mount");e&&l["default"].init(e)}Object.defineProperty(n,"__esModule",{value:!0}),n["default"]=o;var a=e("../index"),u=r(a),i=e("../services/modal"),l=r(i);u["default"].addInitializer({name:"modal",initializer:o,before:"store"})},{"../index":10,"../services/modal":20}],13:[function(e,t,n){"use strict";function r(e){return e&&e.__esModule?e:{"default":e}}function o(){(0,c["default"])((0,a.connect)(l.select)(l.Snackbar),"snackbar-mount")}Object.defineProperty(n,"__esModule",{value:!0}),n["default"]=o;var a=e("react-redux"),u=e("../index"),i=r(u),l=e("../components/snackbar"),s=e("../utils/mount-component"),c=r(s);i["default"].addInitializer({name:"component:snackbar",initializer:o,after:"snackbar"})},{"../components/snackbar":6,"../index":10,"../utils/mount-component":23,"react-redux":"react-redux"}],14:[function(e,t,n){"use strict";function r(e){return e&&e.__esModule?e:{"default":e}}function o(){c["default"].addReducer("snackbar",l["default"],i.initialState)}Object.defineProperty(n,"__esModule",{value:!0}),n["default"]=o;var a=e("../index"),u=r(a),i=e("../reducers/snackbar"),l=r(i),s=e("../services/store"),c=r(s);u["default"].addInitializer({name:"reducer:snackbar",initializer:o,before:"store"})},{"../index":10,"../reducers/snackbar":19,"../services/store":22}],15:[function(e,t,n){"use strict";function r(e){return e&&e.__esModule?e:{"default":e}}function o(){l["default"].init(c["default"])}Object.defineProperty(n,"__esModule",{value:!0}),n["default"]=o;var a=e("../index"),u=r(a),i=e("../services/snackbar"),l=r(i),s=e("../services/store"),c=r(s);u["default"].addInitializer({name:"snackbar",initializer:o,after:"store"})},{"../index":10,"../services/snackbar":21,"../services/store":22}],16:[function(e,t,n){"use strict";function r(e){return e&&e.__esModule?e:{"default":e}}function o(){l["default"].init()}Object.defineProperty(n,"__esModule",{value:!0}),n["default"]=o;var a=e("../index"),u=r(a),i=e("../services/store"),l=r(i);u["default"].addInitializer({name:"store",initializer:o,before:"_end"})},{"../index":10,"../services/store":22}],17:[function(e,t,n){"use strict";function r(e){return e&&e.__esModule?e:{"default":e}}function o(){(0,c["default"])((0,a.connect)(l.select)(l.UserMenu),"user-menu-mount")}Object.defineProperty(n,"__esModule",{value:!0}),n["default"]=o;var a=e("react-redux"),u=e("../index"),i=r(u),l=e("../components/user-menu/root"),s=e("../utils/mount-component"),c=r(s);i["default"].addInitializer({name:"component:user-menu",initializer:o,after:"store"})},{"../components/user-menu/root":8,"../index":10,"../utils/mount-component":23,"react-redux":"react-redux"}],18:[function(e,t,n){"use strict";function r(){var e=arguments.length<=0||void 0===arguments[0]?{}:arguments[0];arguments.length<=1||void 0===arguments[1]?null:arguments[1];return e}Object.defineProperty(n,"__esModule",{value:!0}),n["default"]=r},{}],19:[function(e,t,n){"use strict";function r(e,t){return{type:i,message:e,messageType:t}}function o(){return{type:l}}function a(){var e=arguments.length<=0||void 0===arguments[0]?u:arguments[0],t=arguments.length<=1||void 0===arguments[1]?null:arguments[1];return t.type===i?{type:t.messageType,message:t.message,isVisible:!0}:t.type===l?Object.assign({},e,{isVisible:!1}):e}Object.defineProperty(n,"__esModule",{value:!0}),n.showSnackbar=r,n.hideSnackbar=o,n["default"]=a;var u=n.initialState={type:"info",message:"",isVisible:!1},i=n.SHOW_SNACKBAR="SHOW_SNACKBAR",l=n.HIDE_SNACKBAR="HIDE_SNACKBAR"},{}],20:[function(e,t,n){"use strict";function r(e){return e&&e.__esModule?e:{"default":e}}function o(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}var a=function(){function e(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}return function(t,n,r){return n&&e(t.prototype,n),r&&e(t,r),t}}();Object.defineProperty(n,"__esModule",{value:!0}),n.Modal=void 0;var u=e("react-dom"),i=r(u),l=e("../utils/mount-component"),s=r(l),c=n.Modal=function(){function e(){o(this,e)}return a(e,[{key:"init",value:function(e){var t=this;this._element=e,this._modal=$(e).modal({show:!1}),this._modal.on("hidden.bs.modal",function(){i["default"].unmountComponentAtNode(t._element)})}},{key:"show",value:function(e){(0,s["default"])(e,this._element.id),this._modal.modal("show")}},{key:"hide",value:function(){this._modal.modal("hide")}}]),e}();n["default"]=new c},{"../utils/mount-component":23,"react-dom":"react-dom"}],21:[function(e,t,n){"use strict";function r(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}var o=function(){function e(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}return function(t,n,r){return n&&e(t.prototype,n),r&&e(t,r),t}}();Object.defineProperty(n,"__esModule",{value:!0}),n.Snackbar=void 0;var a=e("../reducers/snackbar"),u=300,i=5e3,l=n.Snackbar=function(){function e(){r(this,e)}return o(e,[{key:"init",value:function(e){this._store=e,this._timeout=null}},{key:"alert",value:function(e,t){var n=this;this._timeout?(window.clearTimeout(this._timeout),this._store.dispatch((0,a.hideSnackbar)()),this._timeout=window.setTimeout(function(){n._timeout=null,n.alert(e,t)},u)):(this._store.dispatch((0,a.showSnackbar)(e,t)),this._timeout=window.setTimeout(function(){n._store.dispatch((0,a.hideSnackbar)()),n._timeout=null},i))}},{key:"info",value:function(e){this.alert(e,"info")}},{key:"success",value:function(e){this.alert(e,"success")}},{key:"warning",value:function(e){this.alert(e,"warning")}},{key:"error",value:function(e){this.alert(e,"error")}}]),e}();n["default"]=new l},{"../reducers/snackbar":19}],22:[function(e,t,n){"use strict";function r(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}var o=function(){function e(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}return function(t,n,r){return n&&e(t.prototype,n),r&&e(t,r),t}}();Object.defineProperty(n,"__esModule",{value:!0}),n.StoreWrapper=void 0;var a=e("redux"),u=n.StoreWrapper=function(){function e(){r(this,e),this._store=null,this._reducers={},this._initialState={}}return o(e,[{key:"addReducer",value:function(e,t,n){this._reducers[e]=t,this._initialState[e]=n}},{key:"init",value:function(){this._store=(0,a.createStore)((0,a.combineReducers)(this._reducers),this._initialState)}},{key:"getStore",value:function(){return this._store}},{key:"getState",value:function(){return this._store.getState()}},{key:"dispatch",value:function(e){return this._store.dispatch(e)}}]),e}();n["default"]=new u},{redux:"redux"}],23:[function(e,t,n){"use strict";function r(e){return e&&e.__esModule?e:{"default":e}}function o(e,t){var n=arguments.length<=2||void 0===arguments[2]?!0:arguments[2],r=document.getElementById(t);r&&(n?l["default"].render(u["default"].createElement(s.Provider,{store:f["default"].getStore()},u["default"].createElement(e,null)),r):l["default"].render(u["default"].createElement(e,null),r))}Object.defineProperty(n,"__esModule",{value:!0}),n["default"]=o;var a=e("react"),u=r(a),i=e("react-dom"),l=r(i),s=e("react-redux"),c=e("../services/store"),f=r(c)},{"../services/store":22,react:"react","react-dom":"react-dom","react-redux":"react-redux"}],24:[function(e,t,n){"use strict";function r(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}var o=function(){function e(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}return function(t,n,r){return n&&e(t.prototype,n),r&&e(t,r),t}}();Object.defineProperty(n,"__esModule",{value:!0});var a=function(){function e(t){r(this,e),this.isOrdered=!1,this._items=t||[]}return o(e,[{key:"add",value:function(e,t,n){this._items.push({key:e,item:t,after:n?n.after||null:null,before:n?n.before||null:null})}},{key:"get",value:function(e,t){for(var n=0;n<this._items.length;n++)if(this._items[n].key===e)return this._items[n].item;return t}},{key:"has",value:function(e){return void 0!==this.get(e)}},{key:"values",value:function t(){for(var t=[],e=0;e<this._items.length;e++)t.push(this._items[e].item);return t}},{key:"order",value:function(e){return this.isOrdered||(this._items=this._order(this._items),this.isOrdered=!0),e||"undefined"==typeof e?this.values():this._items}},{key:"orderedValues",value:function(){return this.order(!0)}},{key:"_order",value:function(e){function t(e){var t=-1;-1===o.indexOf(e.key)&&(e.after?(t=o.indexOf(e.after),-1!==t&&(t+=1)):e.before&&(t=o.indexOf(e.before)),-1!==t&&(r.splice(t,0,e),o.splice(t,0,e.key)))}var n=[];e.forEach(function(e){n.push(e.key)});var r=[],o=[];e.forEach(function(e){e.after||e.before||(r.push(e),o.push(e.key))}),e.forEach(function(e){"_end"===e.before&&(r.push(e),o.push(e.key))});for(var a=200;a>0&&n.length!==o.length;)a-=1,e.forEach(t);return r}}]),e}();n["default"]=a},{}]},{},[10,11,12,13,14,15,16,17,1,2,3,6,4,5,8]);
-//# sourceMappingURL=misago.js.map
+(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
+'use strict';
+
+var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+
+var _react = require('react');
+
+var _react2 = _interopRequireDefault(_react);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
+
+var BASE_URL = $('base').attr('href') + 'user-avatar/';
+
+var _class = (function (_React$Component) {
+  _inherits(_class, _React$Component);
+
+  function _class() {
+    _classCallCheck(this, _class);
+
+    return _possibleConstructorReturn(this, Object.getPrototypeOf(_class).apply(this, arguments));
+  }
+
+  _createClass(_class, [{
+    key: 'getSrc',
+    value: function getSrc() {
+      var size = this.props.size || 100; // jshint ignore:line
+      var url = BASE_URL;
+
+      if (this.props.user && this.props.user.id) {
+        // just avatar hash, size and user id
+        url += this.props.user.avatar_hash + '/' + size + '/' + this.props.user.id + '.png';
+      } else {
+        // just append avatar size to file to produce no-avatar placeholder
+        url += size + '.png';
+      }
+
+      return url;
+    }
+  }, {
+    key: 'render',
+    value: function render() {
+      /* jshint ignore:start */
+      return _react2.default.createElement('img', { src: this.getSrc(),
+        className: this.props.className || 'user-avatar',
+        title: gettext("User avatar") });
+      /* jshint ignore:end */
+    }
+  }]);
+
+  return _class;
+})(_react2.default.Component);
+
+exports.default = _class;
+
+},{"react":"react"}],2:[function(require,module,exports){
+'use strict';
+
+var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+
+var _moment = require('moment');
+
+var _moment2 = _interopRequireDefault(_moment);
+
+var _react = require('react');
+
+var _react2 = _interopRequireDefault(_react);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
+
+var _class = (function (_React$Component) {
+  _inherits(_class, _React$Component);
+
+  function _class() {
+    _classCallCheck(this, _class);
+
+    return _possibleConstructorReturn(this, Object.getPrototypeOf(_class).apply(this, arguments));
+  }
+
+  _createClass(_class, [{
+    key: 'getReasonMessage',
+    value: function getReasonMessage() {
+      /* jshint ignore:start */
+      if (this.props.message.html) {
+        return _react2.default.createElement('div', { className: 'lead',
+          dangerouslySetInnerHTML: { __html: this.props.message.html } });
+      } else {
+        return _react2.default.createElement(
+          'p',
+          { className: 'lead' },
+          this.props.message.plain
+        );
+      }
+      /* jshint ignore:end */
+    }
+  }, {
+    key: 'getExpirationMessage',
+    value: function getExpirationMessage() {
+      if (this.props.expires) {
+        if (this.props.expires.isAfter((0, _moment2.default)())) {
+          return interpolate(gettext('This ban expires %(expires_on)s.'), { 'expires_on': this.props.expires.fromNow() }, true);
+        } else {
+          return gettext('This ban has expired.');
+        }
+      } else {
+        return gettext('This ban is permanent.');
+      }
+    }
+  }, {
+    key: 'render',
+    value: function render() {
+      /* jshint ignore:start */
+      return _react2.default.createElement(
+        'div',
+        { className: 'page page-error page-error-baned' },
+        _react2.default.createElement(
+          'div',
+          { className: 'container' },
+          _react2.default.createElement(
+            'div',
+            { className: 'message-panel' },
+            _react2.default.createElement(
+              'div',
+              { className: 'message-icon' },
+              _react2.default.createElement(
+                'span',
+                { className: 'material-icon' },
+                'highlight_off'
+              )
+            ),
+            _react2.default.createElement(
+              'div',
+              { className: 'message-body' },
+              this.getReasonMessage(),
+              _react2.default.createElement(
+                'p',
+                null,
+                this.getExpirationMessage()
+              )
+            )
+          )
+        )
+      );
+      /* jshint ignore:end */
+    }
+  }]);
+
+  return _class;
+})(_react2.default.Component);
+
+exports.default = _class;
+
+},{"moment":"moment","react":"react"}],3:[function(require,module,exports){
+'use strict';
+
+var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+
+var _react = require('react');
+
+var _react2 = _interopRequireDefault(_react);
+
+var _loader = require('./loader');
+
+var _loader2 = _interopRequireDefault(_loader);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
+
+// jshint ignore:line
+
+var Button = (function (_React$Component) {
+  _inherits(Button, _React$Component);
+
+  function Button() {
+    _classCallCheck(this, Button);
+
+    return _possibleConstructorReturn(this, Object.getPrototypeOf(Button).apply(this, arguments));
+  }
+
+  _createClass(Button, [{
+    key: 'render',
+    value: function render() {
+      var content = null;
+      var className = 'btn ' + this.props.className;
+      var disabled = this.props.disabled;
+
+      if (this.props.loading) {
+        /* jshint ignore:start */
+        content = _react2.default.createElement(_loader2.default, null);
+        /* jshint ignore:end */
+        className += ' btn-loading';
+        disabled = true;
+      } else {
+        content = this.props.children;
+      }
+
+      /* jshint ignore:start */
+      return _react2.default.createElement(
+        'button',
+        { type: this.props.onClick ? 'button' : 'submit',
+          className: className,
+          disabled: disabled,
+          onClick: this.props.onClick },
+        content
+      );
+      /* jshint ignore:end */
+    }
+  }]);
+
+  return Button;
+})(_react2.default.Component);
+
+exports.default = Button;
+
+Button.defaultProps = {
+  className: "btn-default",
+
+  type: "submit",
+
+  loading: false,
+  disabled: false,
+
+  onClick: null
+};
+
+},{"./loader":5,"react":"react"}],4:[function(require,module,exports){
+'use strict';
+
+var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+
+var _react = require('react');
+
+var _react2 = _interopRequireDefault(_react);
+
+var _validators = require('../utils/validators');
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
+
+var _class = (function (_React$Component) {
+  _inherits(_class, _React$Component);
+
+  function _class() {
+    var _Object$getPrototypeO;
+
+    var _temp, _this, _ret;
+
+    _classCallCheck(this, _class);
+
+    for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
+      args[_key] = arguments[_key];
+    }
+
+    return _ret = (_temp = (_this = _possibleConstructorReturn(this, (_Object$getPrototypeO = Object.getPrototypeOf(_class)).call.apply(_Object$getPrototypeO, [this].concat(args))), _this), _this.bindInput = function (name) {
+      return function (event) {
+        var newState = {};
+        newState[name] = event.target.value;
+        _this.setState(newState);
+      };
+    }, _this.handleSubmit = function (event) {
+      // we don't reload page on submissions
+      event.preventDefault();
+
+      if (_this.state.isLoading) {
+        return;
+      }
+
+      if (_this.clean()) {
+        _this.setState({ 'isLoading': true });
+        var promise = _this.send();
+
+        if (promise) {
+          promise.then(function (success) {
+            _this.handleSuccess(success);
+            _this.setState({ 'isLoading': false });
+          }, function (rejection) {
+            _this.handleError(rejection);
+            _this.setState({ 'isLoading': false });
+          });
+        } else {
+          _this.setState({ 'isLoading': false });
+        }
+      }
+    }, _temp), _possibleConstructorReturn(_this, _ret);
+  }
+
+  _createClass(_class, [{
+    key: 'validate',
+    value: function validate() {
+      var isValid = true;
+      var errors = {};
+
+      for (var key in this.state.validators) {
+        if (this.state.validators.hasOwnProperty(key)) {
+          var value = this.state[key];
+          errors[key] = this.validateField(value, this.state.validators[key]);
+          if (errors[key] !== null) {
+            isValid = false;
+          }
+        }
+      }
+
+      return isValid ? null : errors;
+    }
+  }, {
+    key: 'validateField',
+    value: function validateField(value, validators) {
+      var result = (0, _validators.required)()(value);
+      var errors = [];
+
+      if (result) {
+        return [result];
+      } else {
+        for (var i in validators) {
+          result = validators[i](value);
+          if (result) {
+            errors.push(result);
+          }
+        }
+      }
+
+      return errors.length ? errors : null;
+    }
+  }, {
+    key: 'changeValue',
+    value: function changeValue(name, value) {
+      var errors = null;
+      if (this.state.validators.name) {
+        errors = this.validateField(name, value);
+      }
+    }
+
+    /* jshint ignore:start */
+
+  }, {
+    key: 'clean',
+    value: function clean() {
+      return true;
+    }
+  }, {
+    key: 'send',
+    value: function send() {
+      return null;
+    }
+  }, {
+    key: 'handleSuccess',
+    value: function handleSuccess(success) {
+      return;
+    }
+  }, {
+    key: 'handleError',
+
+    /* jshint ignore:end */
+    value: function handleError(rejection) {
+      return;
+    }
+  }]);
+
+  return _class;
+})(_react2.default.Component);
+
+exports.default = _class;
+
+},{"../utils/validators":36,"react":"react"}],5:[function(require,module,exports){
+"use strict";
+
+var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+
+var _react = require("react");
+
+var _react2 = _interopRequireDefault(_react);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
+
+var _class = (function (_React$Component) {
+  _inherits(_class, _React$Component);
+
+  function _class() {
+    _classCallCheck(this, _class);
+
+    return _possibleConstructorReturn(this, Object.getPrototypeOf(_class).apply(this, arguments));
+  }
+
+  _createClass(_class, [{
+    key: "render",
+    value: function render() {
+      /* jshint ignore:start */
+      return _react2.default.createElement(
+        "div",
+        { className: "loader-compact" },
+        _react2.default.createElement("div", { className: "loader-spinning-wheel" })
+      );
+      /* jshint ignore:end */
+    }
+  }]);
+
+  return _class;
+})(_react2.default.Component);
+
+exports.default = _class;
+
+},{"react":"react"}],6:[function(require,module,exports){
+"use strict";
+
+var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+
+var _react = require("react");
+
+var _react2 = _interopRequireDefault(_react);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
+
+var _class = (function (_React$Component) {
+  _inherits(_class, _React$Component);
+
+  function _class() {
+    _classCallCheck(this, _class);
+
+    return _possibleConstructorReturn(this, Object.getPrototypeOf(_class).apply(this, arguments));
+  }
+
+  _createClass(_class, [{
+    key: "render",
+    value: function render() {
+      /* jshint ignore:start */
+      return _react2.default.createElement(
+        "div",
+        { className: "modal-dialog modal-register" },
+        _react2.default.createElement(
+          "div",
+          { className: "modal-content" },
+          _react2.default.createElement(
+            "div",
+            { className: "modal-header" },
+            _react2.default.createElement(
+              "button",
+              { type: "button", className: "close", "data-dismiss": "modal", "aria-label": "Close" },
+              _react2.default.createElement(
+                "span",
+                { "aria-hidden": "true" },
+                "×"
+              )
+            ),
+            _react2.default.createElement(
+              "h4",
+              { className: "modal-title" },
+              gettext("Register")
+            )
+          ),
+          _react2.default.createElement(
+            "div",
+            { className: "modal-body" },
+            _react2.default.createElement(
+              "p",
+              null,
+              "This will be registration form!"
+            )
+          ),
+          _react2.default.createElement(
+            "div",
+            { className: "modal-footer" },
+            _react2.default.createElement(
+              "button",
+              { type: "button", className: "btn btn-default", "data-dismiss": "modal" },
+              "Close"
+            )
+          )
+        )
+      );
+      /* jshint ignore:end */
+    }
+  }]);
+
+  return _class;
+})(_react2.default.Component);
+
+exports.default = _class;
+
+},{"react":"react"}],7:[function(require,module,exports){
+'use strict';
+
+var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+
+var _react = require('react');
+
+var _react2 = _interopRequireDefault(_react);
+
+var _index = require('../index');
+
+var _index2 = _interopRequireDefault(_index);
+
+var _button = require('./button');
+
+var _button2 = _interopRequireDefault(_button);
+
+var _form = require('./form');
+
+var _form2 = _interopRequireDefault(_form);
+
+var _ajax = require('../services/ajax');
+
+var _ajax2 = _interopRequireDefault(_ajax);
+
+var _modal = require('../services/modal');
+
+var _modal2 = _interopRequireDefault(_modal);
+
+var _snackbar = require('../services/snackbar');
+
+var _snackbar2 = _interopRequireDefault(_snackbar);
+
+var _bannedPage = require('../utils/banned-page');
+
+var _bannedPage2 = _interopRequireDefault(_bannedPage);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } // jshint ignore:line
+// jshint ignore:line
+
+var _class = (function (_Form) {
+  _inherits(_class, _Form);
+
+  function _class(props) {
+    _classCallCheck(this, _class);
+
+    var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(_class).call(this, props));
+
+    _this.state = {
+      'isLoading': false,
+      'showActivation': false,
+
+      'username': '',
+      'password': '',
+
+      validators: {
+        'username': [],
+        'password': []
+      }
+    };
+    return _this;
+  }
+
+  _createClass(_class, [{
+    key: 'clean',
+    value: function clean() {
+      if (this.validate()) {
+        _snackbar2.default.error(gettext("Fill out both fields."));
+        return false;
+      } else {
+        return true;
+      }
+    }
+  }, {
+    key: 'send',
+    value: function send() {
+      return _ajax2.default.post(_index2.default.get('AUTH_API'), {
+        'username': this.state.username,
+        'password': this.state.password
+      });
+    }
+  }, {
+    key: 'handleSuccess',
+    value: function handleSuccess() {
+      _modal2.default.hide();
+
+      var form = $('#hidden-login-form');
+
+      form.append('<input type="text" name="username" />');
+      form.append('<input type="password" name="password" />');
+
+      // fill out form with user credentials and submit it, this will tell
+      // Misago to redirect user back to right page, and will trigger browser's
+      // key ring feature
+      form.find('input[type="hidden"]').val(_ajax2.default.getCsrfToken());
+      form.find('input[name="redirect_to"]').val(window.location.pathname);
+      form.find('input[name="username"]').val(this.state.username);
+      form.find('input[name="password"]').val(this.state.password);
+      form.submit();
+    }
+  }, {
+    key: 'handleError',
+    value: function handleError(rejection) {
+      if (rejection.status === 400) {
+        if (rejection.code === 'inactive_admin') {
+          _snackbar2.default.info(rejection.detail);
+        } else if (rejection.code === 'inactive_user') {
+          _snackbar2.default.info(rejection.detail);
+          this.setState({
+            'showActivation': true
+          });
+        } else if (rejection.code === 'banned') {
+          (0, _bannedPage2.default)(rejection.detail);
+          _modal2.default.hide();
+        } else {
+          _snackbar2.default.error(rejection.detail);
+        }
+      } else {
+        _snackbar2.default.apiError(rejection);
+      }
+    }
+  }, {
+    key: 'getActivationButton',
+    value: function getActivationButton() {
+      if (this.state.showActivation) {
+        /* jshint ignore:start */
+        return _react2.default.createElement(
+          'a',
+          { href: _index2.default.get('REQUEST_ACTIVATION_URL'),
+            className: 'btn btn-success btn-block' },
+          gettext("Activate account")
+        );
+        /* jshint ignore:end */
+      } else {
+          return null;
+        }
+    }
+  }, {
+    key: 'render',
+    value: function render() {
+      /* jshint ignore:start */
+      return _react2.default.createElement(
+        'div',
+        { className: 'modal-dialog modal-sm modal-sign-in' },
+        _react2.default.createElement(
+          'div',
+          { className: 'modal-content' },
+          _react2.default.createElement(
+            'div',
+            { className: 'modal-header' },
+            _react2.default.createElement(
+              'button',
+              { type: 'button', className: 'close', 'data-dismiss': 'modal',
+                'aria-label': gettext("Close") },
+              _react2.default.createElement(
+                'span',
+                { 'aria-hidden': 'true' },
+                '×'
+              )
+            ),
+            _react2.default.createElement(
+              'h4',
+              { className: 'modal-title' },
+              gettext("Sign in")
+            )
+          ),
+          _react2.default.createElement(
+            'form',
+            { onSubmit: this.handleSubmit },
+            _react2.default.createElement(
+              'div',
+              { className: 'modal-body' },
+              _react2.default.createElement(
+                'div',
+                { className: 'form-group' },
+                _react2.default.createElement(
+                  'div',
+                  { className: 'control-input' },
+                  _react2.default.createElement('input', { id: 'id_username', className: 'form-control', type: 'text',
+                    disabled: this.state.isLoading,
+                    placeholder: gettext("Username or e-mail"),
+                    onChange: this.bindInput('username'),
+                    value: this.state.username })
+                )
+              ),
+              _react2.default.createElement(
+                'div',
+                { className: 'form-group' },
+                _react2.default.createElement(
+                  'div',
+                  { className: 'control-input' },
+                  _react2.default.createElement('input', { id: 'id_password', className: 'form-control', type: 'password',
+                    disabled: this.state.isLoading,
+                    placeholder: gettext("Password"),
+                    onChange: this.bindInput('password'),
+                    value: this.state.password })
+                )
+              )
+            ),
+            _react2.default.createElement(
+              'div',
+              { className: 'modal-footer' },
+              this.getActivationButton(),
+              _react2.default.createElement(
+                _button2.default,
+                { className: 'btn-primary btn-block',
+                  loading: this.state.isLoading },
+                gettext("Sign in")
+              ),
+              _react2.default.createElement(
+                'a',
+                { href: _index2.default.get('FORGOTTEN_PASSWORD_URL'),
+                  className: 'btn btn-default btn-block' },
+                gettext("Forgot password?")
+              )
+            )
+          )
+        )
+      );
+      /* jshint ignore:end */
+    }
+  }]);
+
+  return _class;
+})(_form2.default);
+
+exports.default = _class;
+
+},{"../index":12,"../services/ajax":28,"../services/modal":30,"../services/snackbar":31,"../utils/banned-page":33,"./button":3,"./form":4,"react":"react"}],8:[function(require,module,exports){
+'use strict';
+
+var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.Snackbar = undefined;
+exports.select = select;
+
+var _react = require('react');
+
+var _react2 = _interopRequireDefault(_react);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
+
+/* jshint ignore:start */
+var TYPES_CLASSES = {
+  'info': 'alert-info',
+  'success': 'alert-success',
+  'warning': 'alert-warning',
+  'error': 'alert-danger'
+};
+/* jshint ignore:end */
+
+var Snackbar = exports.Snackbar = (function (_React$Component) {
+  _inherits(Snackbar, _React$Component);
+
+  function Snackbar() {
+    _classCallCheck(this, Snackbar);
+
+    return _possibleConstructorReturn(this, Object.getPrototypeOf(Snackbar).apply(this, arguments));
+  }
+
+  _createClass(Snackbar, [{
+    key: 'getSnackbarClass',
+    value: function getSnackbarClass() {
+      var snackbarClass = 'alerts-snackbar';
+      if (this.props.isVisible) {
+        snackbarClass += ' in';
+      } else {
+        snackbarClass += ' out';
+      }
+      return snackbarClass;
+    }
+  }, {
+    key: 'render',
+    value: function render() {
+      /* jshint ignore:start */
+      return _react2.default.createElement(
+        'div',
+        { className: this.getSnackbarClass() },
+        _react2.default.createElement(
+          'p',
+          { className: 'alert ' + TYPES_CLASSES[this.props.type] },
+          this.props.message
+        )
+      );
+      /* jshint ignore:end */
+    }
+  }]);
+
+  return Snackbar;
+})(_react2.default.Component);
+
+function select(state) {
+  return state.snackbar;
+}
+
+},{"react":"react"}],9:[function(require,module,exports){
+'use strict';
+
+var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.CompactGuestNav = exports.GuestNav = exports.GuestMenu = undefined;
+
+var _react = require('react');
+
+var _react2 = _interopRequireDefault(_react);
+
+var _button = require('../button');
+
+var _button2 = _interopRequireDefault(_button);
+
+var _modal = require('../../services/modal');
+
+var _modal2 = _interopRequireDefault(_modal);
+
+var _mobileNavbarDropdown = require('../../services/mobile-navbar-dropdown');
+
+var _mobileNavbarDropdown2 = _interopRequireDefault(_mobileNavbarDropdown);
+
+var _avatar = require('../avatar');
+
+var _avatar2 = _interopRequireDefault(_avatar);
+
+var _signIn = require('../sign-in.js');
+
+var _signIn2 = _interopRequireDefault(_signIn);
+
+var _root = require('../register/root.js');
+
+var _root2 = _interopRequireDefault(_root);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } // jshint ignore:line
+
+// jshint ignore:line
+
+var GuestMenu = exports.GuestMenu = (function (_React$Component) {
+  _inherits(GuestMenu, _React$Component);
+
+  function GuestMenu() {
+    _classCallCheck(this, GuestMenu);
+
+    return _possibleConstructorReturn(this, Object.getPrototypeOf(GuestMenu).apply(this, arguments));
+  }
+
+  _createClass(GuestMenu, [{
+    key: 'showSignInModal',
+    value: function showSignInModal() {
+      _modal2.default.show(_signIn2.default);
+    }
+  }, {
+    key: 'showRegisterModal',
+    value: function showRegisterModal() {
+      _modal2.default.show(_root2.default);
+    }
+  }, {
+    key: 'render',
+    value: function render() {
+      /* jshint ignore:start */
+      return _react2.default.createElement(
+        'ul',
+        { className: 'dropdown-menu user-dropdown dropdown-menu-right',
+          role: 'menu' },
+        _react2.default.createElement(
+          'li',
+          { className: 'guest-preview' },
+          _react2.default.createElement(
+            'h4',
+            null,
+            gettext("You are browsing as guest.")
+          ),
+          _react2.default.createElement(
+            'p',
+            null,
+            gettext('Sign in or register to start and participate in discussions.')
+          ),
+          _react2.default.createElement(
+            'div',
+            { className: 'row' },
+            _react2.default.createElement(
+              'div',
+              { className: 'col-xs-6' },
+              _react2.default.createElement(
+                'button',
+                { type: 'button', className: 'btn btn-default btn-block' },
+                'Thy Sign In'
+              )
+            ),
+            _react2.default.createElement(
+              'div',
+              { className: 'col-xs-6' },
+              _react2.default.createElement(
+                'button',
+                { type: 'button', className: 'btn btn-primary btn-block' },
+                'Thy Registry'
+              )
+            )
+          )
+        )
+      );
+      /* jshint ignore:end */
+    }
+  }]);
+
+  return GuestMenu;
+})(_react2.default.Component);
+
+var GuestNav = exports.GuestNav = (function (_GuestMenu) {
+  _inherits(GuestNav, _GuestMenu);
+
+  function GuestNav() {
+    _classCallCheck(this, GuestNav);
+
+    return _possibleConstructorReturn(this, Object.getPrototypeOf(GuestNav).apply(this, arguments));
+  }
+
+  _createClass(GuestNav, [{
+    key: 'render',
+    value: function render() {
+      /* jshint ignore:start */
+      return _react2.default.createElement(
+        'div',
+        { className: 'nav nav-guest' },
+        _react2.default.createElement(
+          _button2.default,
+          { type: 'button',
+            className: 'navbar-btn btn-default',
+            onClick: this.showSignInModal },
+          'Sign in'
+        ),
+        _react2.default.createElement(
+          _button2.default,
+          { type: 'button',
+            className: 'navbar-btn btn-primary',
+            onClick: this.showRegisterModal },
+          'Register'
+        )
+      );
+      /* jshint ignore:end */
+    }
+  }]);
+
+  return GuestNav;
+})(GuestMenu);
+
+var CompactGuestNav = exports.CompactGuestNav = (function (_React$Component2) {
+  _inherits(CompactGuestNav, _React$Component2);
+
+  function CompactGuestNav() {
+    _classCallCheck(this, CompactGuestNav);
+
+    return _possibleConstructorReturn(this, Object.getPrototypeOf(CompactGuestNav).apply(this, arguments));
+  }
+
+  _createClass(CompactGuestNav, [{
+    key: 'showGuestMenu',
+    value: function showGuestMenu() {
+      _mobileNavbarDropdown2.default.show(GuestMenu);
+    }
+  }, {
+    key: 'render',
+    value: function render() {
+      /* jshint ignore:start */
+      return _react2.default.createElement(
+        'button',
+        { type: 'button', onClick: this.showGuestMenu },
+        _react2.default.createElement(_avatar2.default, { size: '64' })
+      );
+      /* jshint ignore:end */
+    }
+  }]);
+
+  return CompactGuestNav;
+})(_react2.default.Component);
+
+},{"../../services/mobile-navbar-dropdown":29,"../../services/modal":30,"../avatar":1,"../button":3,"../register/root.js":6,"../sign-in.js":7,"react":"react"}],10:[function(require,module,exports){
+'use strict';
+
+var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.CompactUserMenu = exports.UserMenu = undefined;
+exports.select = select;
+
+var _react = require('react');
+
+var _react2 = _interopRequireDefault(_react);
+
+var _guestNav = require('./guest-nav');
+
+var _userNav = require('./user-nav');
+
+var _userNav2 = _interopRequireDefault(_userNav);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } // jshint ignore:line
+
+// jshint ignore:line
+
+var UserMenu = exports.UserMenu = (function (_React$Component) {
+  _inherits(UserMenu, _React$Component);
+
+  function UserMenu() {
+    _classCallCheck(this, UserMenu);
+
+    return _possibleConstructorReturn(this, Object.getPrototypeOf(UserMenu).apply(this, arguments));
+  }
+
+  _createClass(UserMenu, [{
+    key: 'render',
+    value: function render() {
+      /* jshint ignore:start */
+      if (this.props.isAuthenticated) {
+        return _react2.default.createElement(_userNav2.default, { user: this.props.user });
+      } else {
+        return _react2.default.createElement(_guestNav.GuestNav, null);
+      }
+      /* jshint ignore:end */
+    }
+  }]);
+
+  return UserMenu;
+})(_react2.default.Component);
+
+var CompactUserMenu = exports.CompactUserMenu = (function (_React$Component2) {
+  _inherits(CompactUserMenu, _React$Component2);
+
+  function CompactUserMenu() {
+    _classCallCheck(this, CompactUserMenu);
+
+    return _possibleConstructorReturn(this, Object.getPrototypeOf(CompactUserMenu).apply(this, arguments));
+  }
+
+  _createClass(CompactUserMenu, [{
+    key: 'render',
+    value: function render() {
+      /* jshint ignore:start */
+      if (this.props.isAuthenticated) {
+        return _react2.default.createElement(_userNav2.default, { user: this.props.user });
+      } else {
+        return _react2.default.createElement(_guestNav.CompactGuestNav, null);
+      }
+      /* jshint ignore:end */
+    }
+  }]);
+
+  return CompactUserMenu;
+})(_react2.default.Component);
+
+function select(state) {
+  return state.auth;
+}
+
+},{"./guest-nav":9,"./user-nav":11,"react":"react"}],11:[function(require,module,exports){
+"use strict";
+
+var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+
+var _react = require("react");
+
+var _react2 = _interopRequireDefault(_react);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
+
+var UserNav = (function (_React$Component) {
+  _inherits(UserNav, _React$Component);
+
+  function UserNav() {
+    _classCallCheck(this, UserNav);
+
+    return _possibleConstructorReturn(this, Object.getPrototypeOf(UserNav).apply(this, arguments));
+  }
+
+  _createClass(UserNav, [{
+    key: "render",
+    value: function render() {
+      /* jshint ignore:start */
+      return _react2.default.createElement("ul", { "class": "ul nav navbar-nav nav-user" });
+      /* jshint ignore:end */
+    }
+  }]);
+
+  return UserNav;
+})(_react2.default.Component);
+
+exports.default = UserNav;
+
+},{"react":"react"}],12:[function(require,module,exports){
+(function (global){
+'use strict';
+
+var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.Misago = undefined;
+
+var _orderedList = require('./utils/ordered-list');
+
+var _orderedList2 = _interopRequireDefault(_orderedList);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+var Misago = exports.Misago = (function () {
+  function Misago() {
+    _classCallCheck(this, Misago);
+
+    this._initializers = [];
+    this._context = {};
+  }
+
+  _createClass(Misago, [{
+    key: 'addInitializer',
+    value: function addInitializer(initializer) {
+      this._initializers.push({
+        key: initializer.name,
+
+        item: initializer.initializer,
+
+        after: initializer.after,
+        before: initializer.before
+      });
+    }
+  }, {
+    key: 'init',
+    value: function init(context) {
+      var _this = this;
+
+      this._context = context;
+
+      var initOrder = new _orderedList2.default(this._initializers).orderedValues();
+      initOrder.forEach(function (initializer) {
+        initializer(_this);
+      });
+    }
+
+    // context accessors
+
+  }, {
+    key: 'has',
+    value: function has(key) {
+      return this._context.hasOwnProperty(key);
+    }
+  }, {
+    key: 'get',
+    value: function get(key, fallback) {
+      if (this.has(key)) {
+        return this._context[key];
+      } else {
+        return fallback || undefined;
+      }
+    }
+  }]);
+
+  return Misago;
+})();
+
+// create  singleton
+
+var misago = new Misago();
+
+// expose it globally
+global.misago = misago;
+
+// and export it for tests and stuff
+exports.default = misago;
+
+}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
+
+},{"./utils/ordered-list":35}],13:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.default = initializer;
+
+var _index = require('../index');
+
+var _index2 = _interopRequireDefault(_index);
+
+var _ajax = require('../services/ajax');
+
+var _ajax2 = _interopRequireDefault(_ajax);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function initializer() {
+  _ajax2.default.init(_index2.default.get('CSRF_COOKIE_NAME'));
+}
+
+_index2.default.addInitializer({
+  name: 'ajax',
+  initializer: initializer
+});
+
+},{"../index":12,"../services/ajax":28}],14:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.default = initializer;
+
+var _index = require('../index');
+
+var _index2 = _interopRequireDefault(_index);
+
+var _auth = require('../reducers/auth');
+
+var _auth2 = _interopRequireDefault(_auth);
+
+var _store = require('../services/store');
+
+var _store2 = _interopRequireDefault(_store);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function initializer(context) {
+  _store2.default.addReducer('auth', _auth2.default, {
+    'isAuthenticated': context.get('isAuthenticated'),
+    'isAnonymous': !context.get('isAuthenticated'),
+
+    'user': context.get('user')
+  });
+}
+
+_index2.default.addInitializer({
+  name: 'reducer:auth',
+  initializer: initializer,
+  before: 'store'
+});
+
+},{"../index":12,"../reducers/auth":25,"../services/store":32}],15:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.default = initializer;
+
+var _index = require('../index');
+
+var _index2 = _interopRequireDefault(_index);
+
+var _mobileNavbarDropdown = require('../services/mobile-navbar-dropdown');
+
+var _mobileNavbarDropdown2 = _interopRequireDefault(_mobileNavbarDropdown);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function initializer() {
+  var element = document.getElementById('mobile-navbar-dropdown-mount');
+  if (element) {
+    _mobileNavbarDropdown2.default.init(element);
+  }
+}
+
+_index2.default.addInitializer({
+  name: 'dropdown',
+  initializer: initializer,
+  before: 'store'
+});
+
+},{"../index":12,"../services/mobile-navbar-dropdown":29}],16:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.default = initializer;
+
+var _index = require('../index');
+
+var _index2 = _interopRequireDefault(_index);
+
+var _modal = require('../services/modal');
+
+var _modal2 = _interopRequireDefault(_modal);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function initializer() {
+  var element = document.getElementById('modal-mount');
+  if (element) {
+    _modal2.default.init(element);
+  }
+}
+
+_index2.default.addInitializer({
+  name: 'modal',
+  initializer: initializer,
+  before: 'store'
+});
+
+},{"../index":12,"../services/modal":30}],17:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.default = initializer;
+
+var _moment = require('moment');
+
+var _moment2 = _interopRequireDefault(_moment);
+
+var _index = require('../index');
+
+var _index2 = _interopRequireDefault(_index);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function initializer() {
+  _moment2.default.locale($('html').attr('lang'));
+}
+
+_index2.default.addInitializer({
+  name: 'moment',
+  initializer: initializer
+});
+
+},{"../index":12,"moment":"moment"}],18:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.default = initializer;
+
+var _reactRedux = require('react-redux');
+
+var _index = require('../index');
+
+var _index2 = _interopRequireDefault(_index);
+
+var _snackbar = require('../components/snackbar');
+
+var _mountComponent = require('../utils/mount-component');
+
+var _mountComponent2 = _interopRequireDefault(_mountComponent);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function initializer() {
+  (0, _mountComponent2.default)((0, _reactRedux.connect)(_snackbar.select)(_snackbar.Snackbar), 'snackbar-mount');
+}
+
+_index2.default.addInitializer({
+  name: 'component:snackbar',
+  initializer: initializer,
+  after: 'snackbar'
+});
+
+},{"../components/snackbar":8,"../index":12,"../utils/mount-component":34,"react-redux":"react-redux"}],19:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.default = initializer;
+
+var _index = require('../index');
+
+var _index2 = _interopRequireDefault(_index);
+
+var _snackbar = require('../reducers/snackbar');
+
+var _snackbar2 = _interopRequireDefault(_snackbar);
+
+var _store = require('../services/store');
+
+var _store2 = _interopRequireDefault(_store);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function initializer() {
+  _store2.default.addReducer('snackbar', _snackbar2.default, _snackbar.initialState);
+}
+
+_index2.default.addInitializer({
+  name: 'reducer:snackbar',
+  initializer: initializer,
+  before: 'store'
+});
+
+},{"../index":12,"../reducers/snackbar":26,"../services/store":32}],20:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.default = initializer;
+
+var _index = require('../index');
+
+var _index2 = _interopRequireDefault(_index);
+
+var _snackbar = require('../services/snackbar');
+
+var _snackbar2 = _interopRequireDefault(_snackbar);
+
+var _store = require('../services/store');
+
+var _store2 = _interopRequireDefault(_store);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function initializer() {
+  _snackbar2.default.init(_store2.default);
+}
+
+_index2.default.addInitializer({
+  name: 'snackbar',
+  initializer: initializer,
+  after: 'store'
+});
+
+},{"../index":12,"../services/snackbar":31,"../services/store":32}],21:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.default = initializer;
+
+var _index = require('../index');
+
+var _index2 = _interopRequireDefault(_index);
+
+var _store = require('../services/store');
+
+var _store2 = _interopRequireDefault(_store);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function initializer() {
+  _store2.default.init();
+}
+
+_index2.default.addInitializer({
+  name: 'store',
+  initializer: initializer,
+  before: '_end'
+});
+
+},{"../index":12,"../services/store":32}],22:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.default = initializer;
+
+var _index = require('../index');
+
+var _index2 = _interopRequireDefault(_index);
+
+var _tick = require('../reducers/tick');
+
+var _tick2 = _interopRequireDefault(_tick);
+
+var _store = require('../services/store');
+
+var _store2 = _interopRequireDefault(_store);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function initializer() {
+  _store2.default.addReducer('tick', _tick2.default, _tick.initialState);
+}
+
+_index2.default.addInitializer({
+  name: 'reducer:tick',
+  initializer: initializer,
+  before: 'store'
+});
+
+},{"../index":12,"../reducers/tick":27,"../services/store":32}],23:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.default = initializer;
+
+var _index = require('../index');
+
+var _index2 = _interopRequireDefault(_index);
+
+var _tick = require('../reducers/tick');
+
+var _store = require('../services/store');
+
+var _store2 = _interopRequireDefault(_store);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var TICK_PERIOD = 50 * 1000; //do the tick every 50s
+
+function initializer() {
+  window.setInterval(function () {
+    _store2.default.dispatch((0, _tick.doTick)());
+  }, TICK_PERIOD);
+}
+
+_index2.default.addInitializer({
+  name: 'tick-start',
+  initializer: initializer,
+  after: 'store'
+});
+
+},{"../index":12,"../reducers/tick":27,"../services/store":32}],24:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.default = initializer;
+
+var _reactRedux = require('react-redux');
+
+var _index = require('../index');
+
+var _index2 = _interopRequireDefault(_index);
+
+var _root = require('../components/user-menu/root');
+
+var _mountComponent = require('../utils/mount-component');
+
+var _mountComponent2 = _interopRequireDefault(_mountComponent);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function initializer() {
+  (0, _mountComponent2.default)((0, _reactRedux.connect)(_root.select)(_root.UserMenu), 'user-menu-mount');
+  (0, _mountComponent2.default)((0, _reactRedux.connect)(_root.select)(_root.CompactUserMenu), 'user-menu-compact-mount');
+}
+
+_index2.default.addInitializer({
+  name: 'component:user-menu',
+  initializer: initializer,
+  after: 'store'
+});
+
+},{"../components/user-menu/root":10,"../index":12,"../utils/mount-component":34,"react-redux":"react-redux"}],25:[function(require,module,exports){
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.default = auth;
+function auth() {
+  var state = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0];
+  var action = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1];
+
+  return state;
+}
+
+},{}],26:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.showSnackbar = showSnackbar;
+exports.hideSnackbar = hideSnackbar;
+exports.default = snackbar;
+var initialState = exports.initialState = {
+  type: 'info',
+  message: '',
+  isVisible: false
+};
+
+var SHOW_SNACKBAR = exports.SHOW_SNACKBAR = 'SHOW_SNACKBAR';
+var HIDE_SNACKBAR = exports.HIDE_SNACKBAR = 'HIDE_SNACKBAR';
+
+function showSnackbar(message, type) {
+  return {
+    type: SHOW_SNACKBAR,
+    message: message,
+    messageType: type
+  };
+}
+
+function hideSnackbar() {
+  return {
+    type: HIDE_SNACKBAR
+  };
+}
+
+function snackbar() {
+  var state = arguments.length <= 0 || arguments[0] === undefined ? initialState : arguments[0];
+  var action = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1];
+
+  if (action.type === SHOW_SNACKBAR) {
+    return {
+      type: action.messageType,
+      message: action.message,
+      isVisible: true
+    };
+  } else if (action.type === HIDE_SNACKBAR) {
+    return Object.assign({}, state, {
+      isVisible: false
+    });
+  } else {
+    return state;
+  }
+}
+
+},{}],27:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.doTick = doTick;
+exports.default = tick;
+var initialState = exports.initialState = {
+  tick: 0
+};
+
+var TICK = exports.TICK = 'TICK';
+
+function doTick() {
+  return {
+    type: TICK
+  };
+}
+
+function tick() {
+  var state = arguments.length <= 0 || arguments[0] === undefined ? initialState : arguments[0];
+  var action = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1];
+
+  if (action.type === TICK) {
+    return Object.assign({}, state, {
+      tick: state.tick + 1
+    });
+  } else {
+    return state;
+  }
+}
+
+},{}],28:[function(require,module,exports){
+'use strict';
+
+var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+var Ajax = exports.Ajax = (function () {
+  function Ajax() {
+    _classCallCheck(this, Ajax);
+
+    this._cookieName = null;
+    this._csrfToken = null;
+  }
+
+  _createClass(Ajax, [{
+    key: 'init',
+    value: function init(cookieName) {
+      this._cookieName = cookieName;
+      this._csrfToken = this.getCsrfToken();
+    }
+  }, {
+    key: 'getCsrfToken',
+    value: function getCsrfToken() {
+      if (document.cookie.indexOf(this._cookieName) !== -1) {
+        var cookieRegex = new RegExp(this._cookieName + '\=([^;]*)');
+        var cookie = document.cookie.match(cookieRegex)[0];
+        return cookie ? cookie.split('=')[1] : null;
+      } else {
+        return null;
+      }
+    }
+  }, {
+    key: 'request',
+    value: function request(method, url, data) {
+      var self = this;
+      return new Promise(function (resolve, reject) {
+        var xhr = {
+          url: url,
+          method: method,
+          headers: {
+            'X-CSRFToken': self._csrfToken
+          },
+
+          data: data || {},
+          dataType: 'json',
+
+          success: function success(data) {
+            resolve(data);
+          },
+
+          error: function error(jqXHR) {
+            var rejection = jqXHR.responseJSON || {};
+
+            rejection.status = jqXHR.status;
+            rejection.statusText = jqXHR.statusText;
+
+            reject(rejection);
+          }
+        };
+
+        $.ajax(xhr);
+      });
+    }
+  }, {
+    key: 'get',
+    value: function get(url) {
+      return this.request('GET', url);
+    }
+  }, {
+    key: 'post',
+    value: function post(url, data) {
+      return this.request('POST', url, data);
+    }
+  }, {
+    key: 'patch',
+    value: function patch(url, data) {
+      return this.request('PATCH', url, data);
+    }
+  }, {
+    key: 'put',
+    value: function put(url, data) {
+      return this.request('PUT', url, data);
+    }
+  }, {
+    key: 'delete',
+    value: function _delete(url) {
+      return this.request('DELETE', url);
+    }
+  }]);
+
+  return Ajax;
+})();
+
+exports.default = new Ajax();
+
+},{}],29:[function(require,module,exports){
+'use strict';
+
+var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.MobileNavbarDropdown = undefined;
+
+var _mountComponent = require('../utils/mount-component');
+
+var _mountComponent2 = _interopRequireDefault(_mountComponent);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+var MobileNavbarDropdown = exports.MobileNavbarDropdown = (function () {
+  function MobileNavbarDropdown() {
+    _classCallCheck(this, MobileNavbarDropdown);
+  }
+
+  _createClass(MobileNavbarDropdown, [{
+    key: 'init',
+    value: function init(element) {
+      this._element = element;
+      this._component = null;
+    }
+  }, {
+    key: 'show',
+    value: function show(component) {
+      if (this._component === component) {
+        this.hide();
+      } else {
+        this._component = component;
+        (0, _mountComponent2.default)(component, this._element.id);
+        $(this._element).addClass('open');
+      }
+    }
+  }, {
+    key: 'hide',
+    value: function hide() {
+      $(this._element).removeClass('open');
+      this._component = null;
+    }
+  }]);
+
+  return MobileNavbarDropdown;
+})();
+
+exports.default = new MobileNavbarDropdown();
+
+},{"../utils/mount-component":34}],30:[function(require,module,exports){
+'use strict';
+
+var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.Modal = undefined;
+
+var _reactDom = require('react-dom');
+
+var _reactDom2 = _interopRequireDefault(_reactDom);
+
+var _mountComponent = require('../utils/mount-component');
+
+var _mountComponent2 = _interopRequireDefault(_mountComponent);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+var Modal = exports.Modal = (function () {
+  function Modal() {
+    _classCallCheck(this, Modal);
+  }
+
+  _createClass(Modal, [{
+    key: 'init',
+    value: function init(element) {
+      var _this = this;
+
+      this._element = element;
+
+      this._modal = $(element).modal({ show: false });
+
+      this._modal.on('hidden.bs.modal', function () {
+        _reactDom2.default.unmountComponentAtNode(_this._element);
+      });
+    }
+  }, {
+    key: 'show',
+    value: function show(component) {
+      (0, _mountComponent2.default)(component, this._element.id);
+      this._modal.modal('show');
+    }
+  }, {
+    key: 'hide',
+    value: function hide() {
+      this._modal.modal('hide');
+    }
+  }]);
+
+  return Modal;
+})();
+
+exports.default = new Modal();
+
+},{"../utils/mount-component":34,"react-dom":"react-dom"}],31:[function(require,module,exports){
+'use strict';
+
+var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.Snackbar = undefined;
+
+var _snackbar = require('../reducers/snackbar');
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+var HIDE_ANIMATION_LENGTH = 300;
+var MESSAGE_SHOW_LENGTH = 5000;
+
+var Snackbar = exports.Snackbar = (function () {
+  function Snackbar() {
+    _classCallCheck(this, Snackbar);
+  }
+
+  _createClass(Snackbar, [{
+    key: 'init',
+    value: function init(store) {
+      this._store = store;
+      this._timeout = null;
+    }
+  }, {
+    key: 'alert',
+    value: function alert(message, type) {
+      var _this = this;
+
+      if (this._timeout) {
+        window.clearTimeout(this._timeout);
+        this._store.dispatch((0, _snackbar.hideSnackbar)());
+
+        this._timeout = window.setTimeout(function () {
+          _this._timeout = null;
+          _this.alert(message, type);
+        }, HIDE_ANIMATION_LENGTH);
+      } else {
+        this._store.dispatch((0, _snackbar.showSnackbar)(message, type));
+        this._timeout = window.setTimeout(function () {
+          _this._store.dispatch((0, _snackbar.hideSnackbar)());
+          _this._timeout = null;
+        }, MESSAGE_SHOW_LENGTH);
+      }
+    }
+
+    // shorthands for message types
+
+  }, {
+    key: 'info',
+    value: function info(message) {
+      this.alert(message, 'info');
+    }
+  }, {
+    key: 'success',
+    value: function success(message) {
+      this.alert(message, 'success');
+    }
+  }, {
+    key: 'warning',
+    value: function warning(message) {
+      this.alert(message, 'warning');
+    }
+  }, {
+    key: 'error',
+    value: function error(message) {
+      this.alert(message, 'error');
+    }
+
+    // shorthand for api errors
+
+  }, {
+    key: 'apiError',
+    value: function apiError(rejection) {
+      var message = gettext("Unknown error has occured.");
+
+      if (rejection.status === 0) {
+        message = gettext("Lost connection with application.");
+      }
+
+      if (rejection.status === 400 && rejection.detail) {
+        message = rejection.detail;
+      }
+
+      if (rejection.status === 403) {
+        message = rejection.detail;
+        if (message === "Permission denied") {
+          message = gettext("You don't have permission to perform this action.");
+        }
+      }
+
+      if (rejection.status === 404) {
+        message = gettext("Action link is invalid.");
+      }
+
+      this.error(message);
+    }
+  }]);
+
+  return Snackbar;
+})();
+
+exports.default = new Snackbar();
+
+},{"../reducers/snackbar":26}],32:[function(require,module,exports){
+'use strict';
+
+var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.StoreWrapper = undefined;
+
+var _redux = require('redux');
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+var StoreWrapper = exports.StoreWrapper = (function () {
+  function StoreWrapper() {
+    _classCallCheck(this, StoreWrapper);
+
+    this._store = null;
+    this._reducers = {};
+    this._initialState = {};
+  }
+
+  _createClass(StoreWrapper, [{
+    key: 'addReducer',
+    value: function addReducer(name, reducer, initialState) {
+      this._reducers[name] = reducer;
+      this._initialState[name] = initialState;
+    }
+  }, {
+    key: 'init',
+    value: function init() {
+      this._store = (0, _redux.createStore)((0, _redux.combineReducers)(this._reducers), this._initialState);
+    }
+  }, {
+    key: 'getStore',
+    value: function getStore() {
+      return this._store;
+    }
+
+    // Store API
+
+  }, {
+    key: 'getState',
+    value: function getState() {
+      return this._store.getState();
+    }
+  }, {
+    key: 'dispatch',
+    value: function dispatch(action) {
+      return this._store.dispatch(action);
+    }
+  }]);
+
+  return StoreWrapper;
+})();
+
+exports.default = new StoreWrapper();
+
+},{"redux":"redux"}],33:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+
+exports.default = function (ban, changeState) {
+  _reactDom2.default.render(
+  /* jshint ignore:start */
+  _react2.default.createElement(
+    _reactRedux.Provider,
+    { store: _store2.default.getStore() },
+    _react2.default.createElement(RedrawedBannedPage, { message: ban.message,
+      expires: ban.expires_on ? (0, _moment2.default)(ban.expires_on) : null })
+  ),
+  /* jshint ignore:end */
+  document.getElementById('page-mount'));
+
+  if (typeof changeState === 'undefined' || !changeState) {
+    var forumName = _index2.default.get('SETTINGS').forum_name;
+    document.title = gettext("You are banned") + ' | ' + forumName;
+    window.history.pushState({}, "", _index2.default.get('BANNED_URL'));
+  }
+};
+
+var _moment = require('moment');
+
+var _moment2 = _interopRequireDefault(_moment);
+
+var _react = require('react');
+
+var _react2 = _interopRequireDefault(_react);
+
+var _reactDom = require('react-dom');
+
+var _reactDom2 = _interopRequireDefault(_reactDom);
+
+var _reactRedux = require('react-redux');
+
+var _bannedPage = require('../components/banned-page');
+
+var _bannedPage2 = _interopRequireDefault(_bannedPage);
+
+var _index = require('../index');
+
+var _index2 = _interopRequireDefault(_index);
+
+var _store = require('../services/store');
+
+var _store2 = _interopRequireDefault(_store);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+// jshint ignore:line
+
+/* jshint ignore:start */
+// jshint ignore:line
+// jshint ignore:line
+var select = function select(state) {
+  return state.tick;
+}; // jshint ignore:line
+// jshint ignore:line
+
+var RedrawedBannedPage = (0, _reactRedux.connect)(select)(_bannedPage2.default);
+/* jshint ignore:end */
+
+},{"../components/banned-page":2,"../index":12,"../services/store":32,"moment":"moment","react":"react","react-dom":"react-dom","react-redux":"react-redux"}],34:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.default = mount;
+
+var _react = require('react');
+
+var _react2 = _interopRequireDefault(_react);
+
+var _reactDom = require('react-dom');
+
+var _reactDom2 = _interopRequireDefault(_reactDom);
+
+var _reactRedux = require('react-redux');
+
+var _store = require('../services/store');
+
+var _store2 = _interopRequireDefault(_store);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+// jshint ignore:line
+
+function mount(Component, rootElementId) {
+  var connected = arguments.length <= 2 || arguments[2] === undefined ? true : arguments[2];
+
+  var rootElement = document.getElementById(rootElementId);
+
+  if (rootElement) {
+    if (connected) {
+      _reactDom2.default.render(
+      /* jshint ignore:start */
+      _react2.default.createElement(
+        _reactRedux.Provider,
+        { store: _store2.default.getStore() },
+        _react2.default.createElement(Component, null)
+      ),
+      /* jshint ignore:end */
+      rootElement);
+    } else {
+      _reactDom2.default.render(
+      /* jshint ignore:start */
+      _react2.default.createElement(Component, null),
+      /* jshint ignore:end */
+      rootElement);
+    }
+  }
+} // jshint ignore:line
+// jshint ignore:line
+
+},{"../services/store":32,"react":"react","react-dom":"react-dom","react-redux":"react-redux"}],35:[function(require,module,exports){
+"use strict";
+
+var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+var OrderedList = (function () {
+  function OrderedList(items) {
+    _classCallCheck(this, OrderedList);
+
+    this.isOrdered = false;
+    this._items = items || [];
+  }
+
+  _createClass(OrderedList, [{
+    key: "add",
+    value: function add(key, item, order) {
+      this._items.push({
+        key: key,
+        item: item,
+
+        after: order ? order.after || null : null,
+        before: order ? order.before || null : null
+      });
+    }
+  }, {
+    key: "get",
+    value: function get(key, value) {
+      for (var i = 0; i < this._items.length; i++) {
+        if (this._items[i].key === key) {
+          return this._items[i].item;
+        }
+      }
+
+      return value;
+    }
+  }, {
+    key: "has",
+    value: function has(key) {
+      return this.get(key) !== undefined;
+    }
+  }, {
+    key: "values",
+    value: function values() {
+      var values = [];
+      for (var i = 0; i < this._items.length; i++) {
+        values.push(this._items[i].item);
+      }
+      return values;
+    }
+  }, {
+    key: "order",
+    value: function order(values_only) {
+      if (!this.isOrdered) {
+        this._items = this._order(this._items);
+        this.isOrdered = true;
+      }
+
+      if (values_only || typeof values_only === 'undefined') {
+        return this.values();
+      } else {
+        return this._items;
+      }
+    }
+  }, {
+    key: "orderedValues",
+    value: function orderedValues() {
+      return this.order(true);
+    }
+  }, {
+    key: "_order",
+    value: function _order(unordered) {
+      // Index of unordered items
+      var index = [];
+      unordered.forEach(function (item) {
+        index.push(item.key);
+      });
+
+      // Ordered items
+      var ordered = [];
+      var ordering = [];
+
+      // First pass: register items that
+      // don't specify their order
+      unordered.forEach(function (item) {
+        if (!item.after && !item.before) {
+          ordered.push(item);
+          ordering.push(item.key);
+        }
+      });
+
+      // Second pass: register items that
+      // specify their before to "_end"
+      unordered.forEach(function (item) {
+        if (item.before === "_end") {
+          ordered.push(item);
+          ordering.push(item.key);
+        }
+      });
+
+      // Third pass: keep iterating items
+      // until we hit iterations limit or finish
+      // ordering list
+      function insertItem(item) {
+        var insertAt = -1;
+        if (ordering.indexOf(item.key) === -1) {
+          if (item.after) {
+            insertAt = ordering.indexOf(item.after);
+            if (insertAt !== -1) {
+              insertAt += 1;
+            }
+          } else if (item.before) {
+            insertAt = ordering.indexOf(item.before);
+          }
+
+          if (insertAt !== -1) {
+            ordered.splice(insertAt, 0, item);
+            ordering.splice(insertAt, 0, item.key);
+          }
+        }
+      }
+
+      var iterations = 200;
+      while (iterations > 0 && index.length !== ordering.length) {
+        iterations -= 1;
+        unordered.forEach(insertItem);
+      }
+
+      return ordered;
+    }
+  }]);
+
+  return OrderedList;
+})();
+
+exports.default = OrderedList;
+
+},{}],36:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.required = required;
+exports.email = email;
+exports.minLength = minLength;
+exports.maxLength = maxLength;
+exports.usernameMinLength = usernameMinLength;
+exports.usernameMaxLength = usernameMaxLength;
+exports.usernameContent = usernameContent;
+exports.passwordMinLength = passwordMinLength;
+var EMAIL = /^(([^<>()[\]\.,;:\s@\"]+(\.[^<>()[\]\.,;:\s@\"]+)*)|(\".+\"))@(([^<>()[\]\.,;:\s@\"]+\.)+[^<>()[\]\.,;:\s@\"]{2,})$/i;
+var USERNAME = new RegExp('^[0-9a-z]+$', 'i');
+
+function required() {
+  return function (value) {
+    if ($.trim(value).length === 0) {
+      return gettext("This field is required.");
+    }
+  };
+}
+
+function email(message) {
+  return function (value) {
+    if (!EMAIL.test(value)) {
+      return message || gettext("Enter a valid email address.");
+    }
+  };
+}
+
+function minLength(limitValue, message) {
+  return function (value) {
+    var returnMessage = '';
+    var length = $.trim(value).length;
+
+    if (length < limitValue) {
+      if (message) {
+        returnMessage = message(limitValue, length);
+      } else {
+        returnMessage = ngettext("Ensure this value has at least %(limit_value)s character (it has %(show_value)s).", "Ensure this value has at least %(limit_value)s characters (it has %(show_value)s).", limitValue);
+      }
+      return interpolate(returnMessage, {
+        limit_value: limitValue,
+        show_value: length
+      }, true);
+    }
+  };
+}
+
+function maxLength(limitValue, message) {
+  return function (value) {
+    var returnMessage = '';
+    var length = $.trim(value).length;
+
+    if (length > limitValue) {
+      if (message) {
+        returnMessage = message(limitValue, length);
+      } else {
+        returnMessage = ngettext("Ensure this value has at most %(limit_value)s character (it has %(show_value)s).", "Ensure this value has at most %(limit_value)s characters (it has %(show_value)s).", limitValue);
+      }
+      return interpolate(returnMessage, {
+        limit_value: limitValue,
+        show_value: length
+      }, true);
+    }
+  };
+}
+
+function usernameMinLength(settings) {
+  var message = function message(limitValue) {
+    return ngettext("Username must be at least %(limit_value)s character long.", "Username must be at least %(limit_value)s characters long.", limitValue);
+  };
+  return this.minLength(settings.username_length_min, message);
+}
+
+function usernameMaxLength(settings) {
+  var message = function message(limitValue) {
+    return ngettext("Username cannot be longer than %(limit_value)s character.", "Username cannot be longer than %(limit_value)s characters.", limitValue);
+  };
+  return this.maxLength(settings.username_length_max, message);
+}
+
+function usernameContent() {
+  return function (value) {
+    if (!USERNAME.test($.trim(value))) {
+      return gettext("Username can only contain latin alphabet letters and digits.");
+    }
+  };
+}
+
+function passwordMinLength(settings) {
+  var message = function message(limitValue) {
+    return ngettext("Valid password must be at least %(limit_value)s character long.", "Valid password must be at least %(limit_value)s characters long.", limitValue);
+  };
+  return this.minLength(settings.password_length_min, message);
+}
+
+},{}]},{},[12,13,14,15,16,17,18,19,20,21,22,23,24])
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","src/components/avatar.js","src/components/banned-page.js","src/components/button.js","src/components/form.js","src/components/loader.js","src/components/register/root.js","src/components/sign-in.js","src/components/snackbar.js","src/components/user-menu/guest-nav.js","src/components/user-menu/root.js","src/components/user-menu/user-nav.js","src/index.js","src/initializers/ajax.js","src/initializers/auth-reducer.js","src/initializers/mobile-navbar-dropdown.js","src/initializers/modal.js","src/initializers/moment-locale.js","src/initializers/snackbar-component.js","src/initializers/snackbar-reducer.js","src/initializers/snackbar.js","src/initializers/store.js","src/initializers/tick-reducer.js","src/initializers/tick-start.js","src/initializers/user-menu-component.js","src/reducers/auth.js","src/reducers/snackbar.js","src/reducers/tick.js","src/services/ajax.js","src/services/mobile-navbar-dropdown.js","src/services/modal.js","src/services/snackbar.js","src/services/store.js","src/utils/banned-page.js","src/utils/mount-component.js","src/utils/ordered-list.js","src/utils/validators.js"],"names":[],"mappings":"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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","import React from 'react';\n\nconst BASE_URL = $('base').attr('href') + 'user-avatar/';\n\nexport default class extends React.Component {\n  getSrc() {\n    let size = this.props.size || 100; // jshint ignore:line\n    let url = BASE_URL;\n\n    if (this.props.user && this.props.user.id) {\n      // just avatar hash, size and user id\n      url += this.props.user.avatar_hash + '/' + size + '/' + this.props.user.id + '.png';\n    } else {\n      // just append avatar size to file to produce no-avatar placeholder\n      url += size + '.png';\n    }\n\n    return url;\n  }\n\n  render() {\n    /* jshint ignore:start */\n    return <img src={this.getSrc()}\n                className={this.props.className || 'user-avatar'}\n                title={gettext(\"User avatar\")}/>;\n    /* jshint ignore:end */\n  }\n}\n","import moment from 'moment';\nimport React from 'react';\n\nexport default class extends React.Component {\n  getReasonMessage() {\n    /* jshint ignore:start */\n    if (this.props.message.html) {\n      return <div className=\"lead\"\n                  dangerouslySetInnerHTML={{__html: this.props.message.html}} />;\n    } else {\n      return <p className=\"lead\">{this.props.message.plain}</p>;\n    }\n    /* jshint ignore:end */\n  }\n\n  getExpirationMessage() {\n    if (this.props.expires) {\n      if (this.props.expires.isAfter(moment())) {\n        return interpolate(\n          gettext('This ban expires %(expires_on)s.'),\n          {'expires_on': this.props.expires.fromNow()},\n          true);\n      } else {\n        return gettext('This ban has expired.');\n      }\n    } else {\n      return gettext('This ban is permanent.');\n    }\n  }\n\n  render() {\n    /* jshint ignore:start */\n    return <div className=\"page page-error page-error-baned\">\n      <div className=\"container\">\n        <div className=\"message-panel\">\n\n          <div className=\"message-icon\">\n            <span className=\"material-icon\">highlight_off</span>\n          </div>\n          <div className=\"message-body\">\n            {this.getReasonMessage()}\n            <p>{this.getExpirationMessage()}</p>\n          </div>\n        </div>\n      </div>\n    </div>;\n    /* jshint ignore:end */\n  }\n}\n","import React from 'react';\nimport Loader from 'misago/components/loader'; // jshint ignore:line\n\nexport default class Button extends React.Component {\n  render() {\n    let content = null;\n    let className = 'btn ' + this.props.className;\n    let disabled = this.props.disabled;\n\n    if (this.props.loading) {\n      /* jshint ignore:start */\n      content = <Loader />;\n      /* jshint ignore:end */\n      className += ' btn-loading';\n      disabled = true;\n    } else {\n      content = this.props.children;\n    }\n\n    /* jshint ignore:start */\n    return <button type={this.props.onClick ? 'button' : 'submit'}\n                   className={className}\n                   disabled={disabled}\n                   onClick={this.props.onClick}>\n      {content}\n    </button>;\n    /* jshint ignore:end */\n  }\n}\n\n\nButton.defaultProps = {\n  className: \"btn-default\",\n\n  type: \"submit\",\n\n  loading: false,\n  disabled: false,\n\n  onClick: null\n};\n","import React from 'react';\nimport { required } from 'misago/utils/validators';\n\nexport default class extends React.Component {\n  validate() {\n    let isValid = true;\n    let errors = {};\n\n    for (var key in this.state.validators) {\n      if (this.state.validators.hasOwnProperty(key)) {\n        let value = this.state[key];\n        errors[key] = this.validateField(value, this.state.validators[key]);\n        if (errors[key] !== null) {\n          isValid = false;\n        }\n      }\n    }\n\n    return isValid ? null : errors;\n  }\n\n  validateField(value, validators) {\n    let result = required()(value);\n    let errors = [];\n\n    if (result) {\n      return [result];\n    } else {\n      for (let i in validators) {\n        result = validators[i](value);\n        if (result) {\n          errors.push(result);\n        }\n      }\n    }\n\n    return errors.length ? errors : null;\n  }\n\n  changeValue(name, value) {\n    let errors = null;\n    if (this.state.validators.name) {\n      errors = this.validateField(name, value);\n    }\n  }\n\n  /* jshint ignore:start */\n  bindInput = (name) => {\n    return (event) => {\n      let newState = {};\n      newState[name] = event.target.value;\n      this.setState(newState);\n    }\n  }\n\n  clean() {\n    return true;\n  }\n\n  send() {\n    return null;\n  }\n\n  handleSuccess(success) {\n    return;\n  }\n\n  handleError(rejection) {\n    return;\n  }\n\n  handleSubmit = (event) => {\n    // we don't reload page on submissions\n    event.preventDefault();\n\n    if (this.state.isLoading) {\n      return;\n    }\n\n    if (this.clean()) {\n      this.setState({'isLoading': true});\n      let promise = this.send();\n\n      if (promise) {\n        promise.then((success) => {\n          this.handleSuccess(success);\n          this.setState({'isLoading': false});\n        }, (rejection) => {\n          this.handleError(rejection);\n          this.setState({'isLoading': false});\n        });\n      } else {\n        this.setState({'isLoading': false});\n      }\n    }\n  }\n  /* jshint ignore:end */\n}","import React from 'react';\n\nexport default class extends React.Component {\n  render() {\n    /* jshint ignore:start */\n    return <div className=\"loader-compact\">\n      <div className=\"loader-spinning-wheel\"></div>\n    </div>;\n    /* jshint ignore:end */\n  }\n}\n","import React from 'react';\n\nexport default class extends React.Component {\n  render() {\n    /* jshint ignore:start */\n    return <div className=\"modal-dialog modal-register\">\n      <div className=\"modal-content\">\n        <div className=\"modal-header\">\n          <button type=\"button\" className=\"close\" data-dismiss=\"modal\" aria-label=\"Close\"><span aria-hidden=\"true\">&times;</span></button>\n          <h4 className=\"modal-title\">{gettext(\"Register\")}</h4>\n        </div>\n        <div className=\"modal-body\">\n          <p>This will be registration form!</p>\n        </div>\n        <div className=\"modal-footer\">\n          <button type=\"button\" className=\"btn btn-default\" data-dismiss=\"modal\">Close</button>\n        </div>\n      </div>\n    </div>;\n    /* jshint ignore:end */\n  }\n}\n","import React from 'react'; // jshint ignore:line\nimport misago from 'misago/index';\nimport Button from 'misago/components/button'; // jshint ignore:line\nimport Form from 'misago/components/form';\nimport ajax from 'misago/services/ajax';\nimport modal from 'misago/services/modal';\nimport snackbar from 'misago/services/snackbar';\nimport showBannedPage from 'misago/utils/banned-page';\n\nexport default class extends Form {\n  constructor(props) {\n    super(props);\n\n    this.state = {\n      'isLoading': false,\n      'showActivation': false,\n\n      'username': '',\n      'password': '',\n\n      validators: {\n        'username': [],\n        'password': []\n      }\n    };\n  }\n\n  clean() {\n    if (this.validate()) {\n      snackbar.error(gettext(\"Fill out both fields.\"));\n      return false;\n    } else {\n      return true;\n    }\n  }\n\n  send() {\n    return ajax.post(misago.get('AUTH_API'), {\n      'username': this.state.username,\n      'password': this.state.password\n    });\n  }\n\n  handleSuccess() {\n    modal.hide();\n\n    let form = $('#hidden-login-form');\n\n    form.append('<input type=\"text\" name=\"username\" />');\n    form.append('<input type=\"password\" name=\"password\" />');\n\n    // fill out form with user credentials and submit it, this will tell\n    // Misago to redirect user back to right page, and will trigger browser's\n    // key ring feature\n    form.find('input[type=\"hidden\"]').val(ajax.getCsrfToken());\n    form.find('input[name=\"redirect_to\"]').val(window.location.pathname);\n    form.find('input[name=\"username\"]').val(this.state.username);\n    form.find('input[name=\"password\"]').val(this.state.password);\n    form.submit();\n  }\n\n  handleError(rejection) {\n    if (rejection.status === 400) {\n      if (rejection.code === 'inactive_admin') {\n        snackbar.info(rejection.detail);\n      } else if (rejection.code === 'inactive_user') {\n        snackbar.info(rejection.detail);\n        this.setState({\n          'showActivation': true\n        });\n      } else if (rejection.code === 'banned') {\n        showBannedPage(rejection.detail);\n        modal.hide();\n      } else {\n        snackbar.error(rejection.detail);\n      }\n    } else {\n      snackbar.apiError(rejection);\n    }\n  }\n\n  getActivationButton() {\n    if (this.state.showActivation) {\n      /* jshint ignore:start */\n      return <a href={misago.get('REQUEST_ACTIVATION_URL')}\n                className=\"btn btn-success btn-block\">\n         {gettext(\"Activate account\")}\n      </a>;\n      /* jshint ignore:end */\n    } else {\n      return null;\n    }\n  }\n\n  render() {\n    /* jshint ignore:start */\n    return <div className=\"modal-dialog modal-sm modal-sign-in\">\n      <div className=\"modal-content\">\n        <div className=\"modal-header\">\n          <button type=\"button\" className=\"close\" data-dismiss=\"modal\"\n                  aria-label={gettext(\"Close\")}>\n            <span aria-hidden=\"true\">&times;</span>\n          </button>\n          <h4 className=\"modal-title\">{gettext(\"Sign in\")}</h4>\n        </div>\n        <form onSubmit={this.handleSubmit}>\n          <div className=\"modal-body\">\n\n            <div className=\"form-group\">\n              <div className=\"control-input\">\n                <input id=\"id_username\" className=\"form-control\" type=\"text\"\n                       disabled={this.state.isLoading}\n                       placeholder={gettext(\"Username or e-mail\")}\n                       onChange={this.bindInput('username')}\n                       value={this.state.username} />\n              </div>\n            </div>\n\n            <div className=\"form-group\">\n              <div className=\"control-input\">\n                <input id=\"id_password\" className=\"form-control\" type=\"password\"\n                       disabled={this.state.isLoading}\n                       placeholder={gettext(\"Password\")}\n                       onChange={this.bindInput('password')}\n                       value={this.state.password} />\n              </div>\n            </div>\n\n          </div>\n          <div className=\"modal-footer\">\n            {this.getActivationButton()}\n            <Button className=\"btn-primary btn-block\"\n                    loading={this.state.isLoading}>\n              {gettext(\"Sign in\")}\n            </Button>\n            <a href={misago.get('FORGOTTEN_PASSWORD_URL')}\n               className=\"btn btn-default btn-block\">\n               {gettext(\"Forgot password?\")}\n            </a>\n          </div>\n        </form>\n      </div>\n    </div>;\n    /* jshint ignore:end */\n  }\n}\n","import React from 'react';\n\n/* jshint ignore:start */\nconst TYPES_CLASSES = {\n  'info': 'alert-info',\n  'success': 'alert-success',\n  'warning': 'alert-warning',\n  'error': 'alert-danger'\n};\n/* jshint ignore:end */\n\nexport class Snackbar extends React.Component {\n  getSnackbarClass() {\n    let snackbarClass = 'alerts-snackbar';\n    if (this.props.isVisible) {\n      snackbarClass += ' in';\n    } else {\n      snackbarClass += ' out';\n    }\n    return snackbarClass;\n  }\n\n  render() {\n    /* jshint ignore:start */\n    return <div className={this.getSnackbarClass()}>\n      <p className={'alert ' + TYPES_CLASSES[this.props.type]}>\n        {this.props.message}\n      </p>\n    </div>;\n    /* jshint ignore:end */\n  }\n}\n\nexport function select(state) {\n  return state.snackbar;\n}\n","import React from 'react';\nimport Button from 'misago/components/button'; // jshint ignore:line\n\nimport modal from 'misago/services/modal';\nimport dropdown from 'misago/services/mobile-navbar-dropdown';\nimport Avatar from 'misago/components/avatar'; // jshint ignore:line\nimport SignInModal from 'misago/components/sign-in.js';\nimport RegisterModal from 'misago/components/register/root.js';\n\nexport class GuestMenu extends React.Component {\n  showSignInModal() {\n    modal.show(SignInModal);\n  }\n\n  showRegisterModal() {\n    modal.show(RegisterModal);\n  }\n\n  render() {\n    /* jshint ignore:start */\n    return <ul className=\"dropdown-menu user-dropdown dropdown-menu-right\"\n               role=\"menu\">\n      <li className=\"guest-preview\">\n        <h4>{gettext(\"You are browsing as guest.\")}</h4>\n        <p>\n          {gettext('Sign in or register to start and participate in discussions.')}\n        </p>\n        <div className=\"row\">\n\n          <div className=\"col-xs-6\">\n            <button type=\"button\" className=\"btn btn-default btn-block\">\n              Thy Sign In\n            </button>\n\n          </div>\n          <div className=\"col-xs-6\">\n\n            <button type=\"button\" className=\"btn btn-primary btn-block\">\n              Thy Registry\n            </button>\n\n          </div>\n        </div>\n      </li>\n    </ul>;\n    /* jshint ignore:end */\n  }\n}\n\nexport class GuestNav extends GuestMenu {\n  render() {\n    /* jshint ignore:start */\n    return <div className=\"nav nav-guest\">\n      <Button type=\"button\"\n              className=\"navbar-btn btn-default\"\n              onClick={this.showSignInModal}>\n        Sign in\n      </Button>\n      <Button type=\"button\"\n              className=\"navbar-btn btn-primary\"\n              onClick={this.showRegisterModal}>\n        Register\n      </Button>\n    </div>;\n    /* jshint ignore:end */\n  }\n}\n\nexport class CompactGuestNav extends React.Component {\n  showGuestMenu() {\n    dropdown.show(GuestMenu);\n  }\n\n  render() {\n    /* jshint ignore:start */\n    return <button type=\"button\" onClick={this.showGuestMenu}>\n      <Avatar size=\"64\" />\n    </button>;\n    /* jshint ignore:end */\n  }\n}\n","import React from 'react';\nimport { GuestNav, CompactGuestNav } from 'misago/components/user-menu/guest-nav'; // jshint ignore:line\nimport UserNav from 'misago/components/user-menu/user-nav'; // jshint ignore:line\n\nexport class UserMenu extends React.Component {\n  render() {\n    /* jshint ignore:start */\n    if (this.props.isAuthenticated) {\n      return <UserNav user={this.props.user} />;\n    } else {\n      return <GuestNav />;\n    }\n    /* jshint ignore:end */\n  }\n}\n\nexport class CompactUserMenu extends React.Component {\n  render() {\n    /* jshint ignore:start */\n    if (this.props.isAuthenticated) {\n      return <UserNav user={this.props.user} />;\n    } else {\n      return <CompactGuestNav />;\n    }\n    /* jshint ignore:end */\n  }\n}\n\nexport function select(state) {\n  return state.auth;\n}\n","import React from 'react';\n\nexport default class UserNav extends React.Component {\n  render() {\n    /* jshint ignore:start */\n    return <ul class=\"ul nav navbar-nav nav-user\">\n\n    </ul>;\n    /* jshint ignore:end */\n  }\n}\n","import OrderedList from 'misago/utils/ordered-list';\n\nexport class Misago {\n  constructor() {\n    this._initializers = [];\n    this._context = {};\n  }\n\n  addInitializer(initializer) {\n    this._initializers.push({\n      key: initializer.name,\n\n      item: initializer.initializer,\n\n      after: initializer.after,\n      before: initializer.before\n    });\n  }\n\n  init(context) {\n    this._context = context;\n\n    var initOrder = new OrderedList(this._initializers).orderedValues();\n    initOrder.forEach(initializer => {\n      initializer(this);\n    });\n  }\n\n  // context accessors\n  has(key) {\n    return this._context.hasOwnProperty(key);\n  }\n\n  get(key, fallback) {\n    if (this.has(key)) {\n      return this._context[key];\n    } else {\n      return fallback || undefined;\n    }\n  }\n}\n\n// create  singleton\nvar misago = new Misago();\n\n// expose it globally\nglobal.misago = misago;\n\n// and export it for tests and stuff\nexport default misago;\n","import misago from 'misago/index';\nimport ajax from 'misago/services/ajax';\n\nexport default function initializer() {\n  ajax.init(misago.get('CSRF_COOKIE_NAME'));\n}\n\nmisago.addInitializer({\n  name: 'ajax',\n  initializer: initializer\n});\n","import misago from 'misago/index';\nimport reducer from 'misago/reducers/auth';\nimport store from 'misago/services/store';\n\nexport default function initializer(context) {\n  store.addReducer('auth', reducer, {\n    'isAuthenticated': context.get('isAuthenticated'),\n    'isAnonymous': !context.get('isAuthenticated'),\n\n    'user': context.get('user')\n  });\n}\n\nmisago.addInitializer({\n  name: 'reducer:auth',\n  initializer: initializer,\n  before: 'store'\n});\n","import misago from 'misago/index';\nimport dropdown from 'misago/services/mobile-navbar-dropdown';\n\nexport default function initializer() {\n  let element = document.getElementById('mobile-navbar-dropdown-mount');\n  if (element) {\n    dropdown.init(element);\n  }\n}\n\nmisago.addInitializer({\n  name: 'dropdown',\n  initializer: initializer,\n  before: 'store'\n});\n","import misago from 'misago/index';\nimport modal from 'misago/services/modal';\n\nexport default function initializer() {\n  let element = document.getElementById('modal-mount');\n  if (element) {\n    modal.init(element);\n  }\n}\n\nmisago.addInitializer({\n  name: 'modal',\n  initializer: initializer,\n  before: 'store'\n});\n","import moment from 'moment';\nimport misago from 'misago/index';\n\nexport default function initializer() {\n  moment.locale($('html').attr('lang'));\n}\n\nmisago.addInitializer({\n  name: 'moment',\n  initializer: initializer\n});\n","import { connect } from 'react-redux';\nimport misago from 'misago/index';\nimport { Snackbar, select } from 'misago/components/snackbar';\nimport mount from 'misago/utils/mount-component';\n\nexport default function initializer() {\n  mount(connect(select)(Snackbar), 'snackbar-mount');\n}\n\nmisago.addInitializer({\n  name: 'component:snackbar',\n  initializer: initializer,\n  after: 'snackbar'\n});\n","import misago from 'misago/index';\nimport reducer, { initialState } from 'misago/reducers/snackbar';\nimport store from 'misago/services/store';\n\nexport default function initializer() {\n  store.addReducer('snackbar', reducer, initialState);\n}\n\nmisago.addInitializer({\n  name: 'reducer:snackbar',\n  initializer: initializer,\n  before: 'store'\n});\n","import misago from 'misago/index';\nimport snackbar from 'misago/services/snackbar';\nimport store from 'misago/services/store';\n\nexport default function initializer() {\n  snackbar.init(store);\n}\n\nmisago.addInitializer({\n  name: 'snackbar',\n  initializer: initializer,\n  after: 'store'\n});\n","import misago from 'misago/index';\nimport store from 'misago/services/store';\n\nexport default function initializer() {\n  store.init();\n}\n\nmisago.addInitializer({\n  name: 'store',\n  initializer: initializer,\n  before: '_end'\n});\n","import misago from 'misago/index';\nimport reducer, { initialState } from 'misago/reducers/tick';\nimport store from 'misago/services/store';\n\nexport default function initializer() {\n  store.addReducer('tick', reducer, initialState);\n}\n\nmisago.addInitializer({\n  name: 'reducer:tick',\n  initializer: initializer,\n  before: 'store'\n});\n","import misago from 'misago/index';\nimport { doTick } from 'misago/reducers/tick';\nimport store from 'misago/services/store';\n\nconst TICK_PERIOD = 50 * 1000; //do the tick every 50s\n\nexport default function initializer() {\n  window.setInterval(function() {\n    store.dispatch(doTick());\n  }, TICK_PERIOD);\n}\n\nmisago.addInitializer({\n  name: 'tick-start',\n  initializer: initializer,\n  after: 'store'\n});\n","import { connect } from 'react-redux';\nimport misago from 'misago/index';\nimport { UserMenu, CompactUserMenu, select } from 'misago/components/user-menu/root';\nimport mount from 'misago/utils/mount-component';\n\nexport default function initializer() {\n  mount(connect(select)(UserMenu), 'user-menu-mount');\n  mount(connect(select)(CompactUserMenu), 'user-menu-compact-mount');\n}\n\nmisago.addInitializer({\n  name: 'component:user-menu',\n  initializer: initializer,\n  after: 'store'\n});\n","export default function auth(state={}, action=null) {\n  return state;\n}\n","export var initialState = {\n  type: 'info',\n  message: '',\n  isVisible: false\n};\n\nexport const SHOW_SNACKBAR = 'SHOW_SNACKBAR';\nexport const HIDE_SNACKBAR = 'HIDE_SNACKBAR';\n\nexport function showSnackbar(message, type) {\n  return {\n    type: SHOW_SNACKBAR,\n    message,\n    messageType: type\n  };\n}\n\nexport function hideSnackbar() {\n  return {\n    type: HIDE_SNACKBAR\n  };\n}\n\nexport default function snackbar(state=initialState, action=null) {\n  if (action.type === SHOW_SNACKBAR) {\n    return {\n      type: action.messageType,\n      message: action.message,\n      isVisible: true\n    };\n  } else if (action.type === HIDE_SNACKBAR) {\n    return Object.assign({}, state, {\n        isVisible: false\n    });\n  } else {\n    return state;\n  }\n}\n","export var initialState = {\n  tick: 0\n};\n\nexport const TICK = 'TICK';\n\nexport function doTick() {\n  return {\n    type: TICK\n  };\n}\n\nexport default function tick(state=initialState, action=null) {\n  if (action.type === TICK) {\n    return Object.assign({}, state, {\n        tick: state.tick + 1\n    });\n  } else {\n    return state;\n  }\n}\n","export class Ajax {\n  constructor() {\n    this._cookieName = null;\n    this._csrfToken = null;\n  }\n\n  init(cookieName) {\n    this._cookieName = cookieName;\n    this._csrfToken = this.getCsrfToken();\n  }\n\n  getCsrfToken() {\n    if (document.cookie.indexOf(this._cookieName) !== -1) {\n      var cookieRegex = new RegExp(this._cookieName + '\\=([^;]*)');\n      var cookie = document.cookie.match(cookieRegex)[0];\n      return cookie ? cookie.split('=')[1] : null;\n    } else {\n      return null;\n    }\n  }\n\n  request(method, url, data) {\n    var self = this;\n    return new Promise(function(resolve, reject) {\n      var xhr = {\n        url: url,\n        method: method,\n        headers: {\n          'X-CSRFToken': self._csrfToken\n        },\n\n        data: data || {},\n        dataType: 'json',\n\n        success: function(data) {\n          resolve(data);\n        },\n\n        error: function(jqXHR) {\n          var rejection = jqXHR.responseJSON || {};\n\n          rejection.status = jqXHR.status;\n          rejection.statusText = jqXHR.statusText;\n\n          reject(rejection);\n        }\n      };\n\n      $.ajax(xhr);\n    });\n  }\n\n  get(url) {\n    return this.request('GET', url);\n  }\n\n  post(url, data) {\n    return this.request('POST', url, data);\n  }\n\n  patch(url, data) {\n    return this.request('PATCH', url, data);\n  }\n\n  put(url, data) {\n    return this.request('PUT', url, data);\n  }\n\n  delete(url) {\n    return this.request('DELETE', url);\n  }\n}\n\nexport default new Ajax();\n","import mount from 'misago/utils/mount-component';\n\nexport class MobileNavbarDropdown {\n  init(element) {\n    this._element = element;\n    this._component = null;\n  }\n\n  show(component) {\n    if (this._component === component) {\n      this.hide();\n    } else {\n      this._component = component;\n      mount(component, this._element.id);\n      $(this._element).addClass('open');\n    }\n  }\n\n  hide() {\n    $(this._element).removeClass('open');\n    this._component = null;\n  }\n}\n\nexport default new MobileNavbarDropdown();\n","import ReactDOM from 'react-dom';\nimport mount from 'misago/utils/mount-component';\n\nexport class Modal {\n  init(element) {\n    this._element = element;\n\n    this._modal = $(element).modal({show: false});\n\n    this._modal.on('hidden.bs.modal', () => {\n      ReactDOM.unmountComponentAtNode(this._element);\n    });\n  }\n\n  show(component) {\n    mount(component, this._element.id);\n    this._modal.modal('show');\n  }\n\n  hide() {\n    this._modal.modal('hide');\n  }\n}\n\nexport default new Modal();\n","import { showSnackbar, hideSnackbar } from 'misago/reducers/snackbar';\n\nconst HIDE_ANIMATION_LENGTH = 300;\nconst MESSAGE_SHOW_LENGTH = 5000;\n\nexport class Snackbar {\n  init(store) {\n    this._store = store;\n    this._timeout = null;\n  }\n\n  alert(message, type) {\n    if (this._timeout) {\n      window.clearTimeout(this._timeout);\n      this._store.dispatch(hideSnackbar());\n\n      this._timeout = window.setTimeout(() => {\n        this._timeout = null;\n        this.alert(message, type);\n      }, HIDE_ANIMATION_LENGTH);\n    } else {\n      this._store.dispatch(showSnackbar(message, type));\n      this._timeout = window.setTimeout(() => {\n        this._store.dispatch(hideSnackbar());\n        this._timeout = null;\n      }, MESSAGE_SHOW_LENGTH);\n    }\n  }\n\n  // shorthands for message types\n\n  info(message) {\n    this.alert(message, 'info');\n  }\n\n  success(message) {\n    this.alert(message, 'success');\n  }\n\n  warning(message) {\n    this.alert(message, 'warning');\n  }\n\n  error(message) {\n    this.alert(message, 'error');\n  }\n\n  // shorthand for api errors\n  apiError(rejection) {\n    let message = gettext(\"Unknown error has occured.\");\n\n    if (rejection.status === 0) {\n      message = gettext(\"Lost connection with application.\");\n    }\n\n    if (rejection.status === 400 && rejection.detail) {\n      message = rejection.detail;\n    }\n\n    if (rejection.status === 403) {\n      message = rejection.detail;\n      if (message === \"Permission denied\") {\n        message = gettext(\n          \"You don't have permission to perform this action.\");\n      }\n    }\n\n    if (rejection.status === 404) {\n      message = gettext(\"Action link is invalid.\");\n    }\n\n    this.error(message);\n  }\n}\n\nexport default new Snackbar();\n","import { combineReducers, createStore } from 'redux';\n\nexport class StoreWrapper {\n  constructor() {\n    this._store = null;\n    this._reducers = {};\n    this._initialState = {};\n  }\n\n  addReducer(name, reducer, initialState) {\n    this._reducers[name] = reducer;\n    this._initialState[name] = initialState;\n  }\n\n  init() {\n    this._store = createStore(\n      combineReducers(this._reducers), this._initialState);\n  }\n\n  getStore() {\n    return this._store;\n  }\n\n  // Store API\n\n  getState() {\n    return this._store.getState();\n  }\n\n  dispatch(action) {\n    return this._store.dispatch(action);\n  }\n}\n\nexport default new StoreWrapper();\n","import moment from 'moment'; // jshint ignore:line\nimport React from 'react'; // jshint ignore:line\nimport ReactDOM from 'react-dom';\nimport { Provider, connect } from 'react-redux'; // jshint ignore:line\nimport BannedPage from 'misago/components/banned-page'; // jshint ignore:line\nimport misago from 'misago/index';\nimport store from 'misago/services/store'; // jshint ignore:line\n\n/* jshint ignore:start */\nlet select = function(state) {\n  return state.tick;\n};\n\nlet RedrawedBannedPage = connect(select)(BannedPage);\n/* jshint ignore:end */\n\nexport default function(ban, changeState) {\n  ReactDOM.render(\n    /* jshint ignore:start */\n    <Provider store={store.getStore()}>\n      <RedrawedBannedPage message={ban.message}\n                          expires={ban.expires_on ? moment(ban.expires_on) : null} />\n    </Provider>,\n    /* jshint ignore:end */\n    document.getElementById('page-mount')\n  );\n\n  if (typeof changeState === 'undefined' || !changeState) {\n    let forumName = misago.get('SETTINGS').forum_name;\n    document.title = gettext(\"You are banned\") + ' | ' + forumName;\n    window.history.pushState({}, \"\", misago.get('BANNED_URL'));\n  }\n}","import React from 'react'; // jshint ignore:line\nimport ReactDOM from 'react-dom';\nimport { Provider } from 'react-redux'; // jshint ignore:line\nimport store from 'misago/services/store'; // jshint ignore:line\n\nexport default function mount(Component, rootElementId, connected=true) {\n  let rootElement = document.getElementById(rootElementId);\n\n  if (rootElement) {\n    if (connected) {\n      ReactDOM.render(\n        /* jshint ignore:start */\n        <Provider store={store.getStore()}>\n          <Component />\n        </Provider>,\n        /* jshint ignore:end */\n        rootElement\n      );\n    } else {\n      ReactDOM.render(\n        /* jshint ignore:start */\n        <Component />,\n        /* jshint ignore:end */\n        rootElement\n      );\n    }\n  }\n}\n","class OrderedList {\n    constructor(items) {\n      this.isOrdered = false;\n      this._items = items || [];\n    }\n\n    add(key, item, order) {\n      this._items.push({\n        key: key,\n        item: item,\n\n        after: order ? order.after || null : null,\n        before: order ? order.before || null : null\n      });\n    }\n\n    get(key, value) {\n      for (var i = 0; i < this._items.length; i++) {\n        if (this._items[i].key === key) {\n          return this._items[i].item;\n        }\n      }\n\n      return value;\n    }\n\n    has(key) {\n      return this.get(key) !== undefined;\n    }\n\n    values() {\n      var values = [];\n      for (var i = 0; i < this._items.length; i++) {\n        values.push(this._items[i].item);\n      }\n      return values;\n    }\n\n    order(values_only) {\n      if (!this.isOrdered) {\n        this._items = this._order(this._items);\n        this.isOrdered = true;\n      }\n\n      if (values_only || typeof values_only === 'undefined') {\n        return this.values();\n      } else {\n        return this._items;\n      }\n    }\n\n    orderedValues() {\n      return this.order(true);\n    }\n\n    _order(unordered) {\n      // Index of unordered items\n      var index = [];\n      unordered.forEach(function (item) {\n        index.push(item.key);\n      });\n\n      // Ordered items\n      var ordered = [];\n      var ordering = [];\n\n      // First pass: register items that\n      // don't specify their order\n      unordered.forEach(function (item) {\n        if (!item.after && !item.before) {\n          ordered.push(item);\n          ordering.push(item.key);\n        }\n      });\n\n      // Second pass: register items that\n      // specify their before to \"_end\"\n      unordered.forEach(function (item) {\n        if (item.before === \"_end\") {\n          ordered.push(item);\n          ordering.push(item.key);\n        }\n      });\n\n      // Third pass: keep iterating items\n      // until we hit iterations limit or finish\n      // ordering list\n      function insertItem(item) {\n        var insertAt = -1;\n        if (ordering.indexOf(item.key) === -1) {\n          if (item.after) {\n            insertAt = ordering.indexOf(item.after);\n            if (insertAt !== -1) {\n              insertAt += 1;\n            }\n          } else if (item.before) {\n            insertAt = ordering.indexOf(item.before);\n          }\n\n          if (insertAt !== -1) {\n            ordered.splice(insertAt, 0, item);\n            ordering.splice(insertAt, 0, item.key);\n          }\n        }\n      }\n\n      var iterations = 200;\n      while (iterations > 0 && index.length !== ordering.length) {\n        iterations -= 1;\n        unordered.forEach(insertItem);\n      }\n\n      return ordered;\n    }\n  }\n\n  export default OrderedList;\n","const EMAIL = /^(([^<>()[\\]\\.,;:\\s@\\\"]+(\\.[^<>()[\\]\\.,;:\\s@\\\"]+)*)|(\\\".+\\\"))@(([^<>()[\\]\\.,;:\\s@\\\"]+\\.)+[^<>()[\\]\\.,;:\\s@\\\"]{2,})$/i;\nconst USERNAME = new RegExp('^[0-9a-z]+$', 'i');\n\nexport function required() {\n  return function(value) {\n    if ($.trim(value).length === 0) {\n      return gettext(\"This field is required.\");\n    }\n  };\n}\n\nexport function email(message) {\n  return function(value) {\n    if (!EMAIL.test(value)) {\n      return message || gettext(\"Enter a valid email address.\");\n    }\n  };\n}\n\nexport function minLength(limitValue, message) {\n  return function(value) {\n    var returnMessage = '';\n    var length = $.trim(value).length;\n\n    if (length < limitValue) {\n      if (message) {\n        returnMessage = message(limitValue, length);\n      } else {\n        returnMessage = ngettext(\n          \"Ensure this value has at least %(limit_value)s character (it has %(show_value)s).\",\n          \"Ensure this value has at least %(limit_value)s characters (it has %(show_value)s).\",\n          limitValue);\n      }\n      return interpolate(returnMessage, {\n        limit_value: limitValue,\n        show_value: length\n      }, true);\n    }\n  };\n}\n\nexport function maxLength(limitValue, message) {\n  return function(value) {\n    var returnMessage = '';\n    var length = $.trim(value).length;\n\n    if (length > limitValue) {\n      if (message) {\n        returnMessage = message(limitValue, length);\n      } else {\n        returnMessage = ngettext(\n          \"Ensure this value has at most %(limit_value)s character (it has %(show_value)s).\",\n          \"Ensure this value has at most %(limit_value)s characters (it has %(show_value)s).\",\n          limitValue);\n      }\n      return interpolate(returnMessage, {\n        limit_value: limitValue,\n        show_value: length\n      }, true);\n    }\n  };\n}\n\nexport function usernameMinLength(settings) {\n  var message = function(limitValue) {\n    return ngettext(\n      \"Username must be at least %(limit_value)s character long.\",\n      \"Username must be at least %(limit_value)s characters long.\",\n      limitValue);\n  };\n  return this.minLength(settings.username_length_min, message);\n}\n\nexport function usernameMaxLength(settings) {\n  var message = function(limitValue) {\n    return ngettext(\n      \"Username cannot be longer than %(limit_value)s character.\",\n      \"Username cannot be longer than %(limit_value)s characters.\",\n      limitValue);\n  };\n  return this.maxLength(settings.username_length_max, message);\n}\n\nexport function usernameContent() {\n  return function(value) {\n    if (!USERNAME.test($.trim(value))) {\n      return gettext(\"Username can only contain latin alphabet letters and digits.\");\n    }\n  };\n}\n\nexport function passwordMinLength(settings) {\n  var message = function(limitValue) {\n    return ngettext(\n      \"Valid password must be at least %(limit_value)s character long.\",\n      \"Valid password must be at least %(limit_value)s characters long.\",\n      limitValue);\n  };\n  return this.minLength(settings.password_length_min, message);\n}"]}

File diff suppressed because it is too large
+ 33312 - 10
misago/static/misago/js/vendor.js


+ 1 - 1
misago/templates/misago/navbar.html

@@ -64,4 +64,4 @@
   </ul>
   <!-- /compact navbar -->
 </nav>
-<div id="navbar-dropdown-mount" class="mobile-dropdown"></div>
+<div id="mobile-navbar-dropdown-mount" class="mobile-dropdown"></div>

+ 3 - 1
misago/users/models/ban.py

@@ -61,7 +61,9 @@ class BansManager(models.Manager):
             queryset = queryset.filter(check_type__in=checks)
 
         for ban in queryset.order_by('-id').iterator():
-            if (ban.check_type == BAN_USERNAME and username and
+            if ban.is_expired:
+                continue
+            elif (ban.check_type == BAN_USERNAME and username and
                     ban.check_value(username)):
                 return ban
             elif (ban.check_type == BAN_EMAIL and email and

Some files were not shown because too many files changed in this diff