Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[BT-151] AppHeader #42

Merged
merged 8 commits into from
Nov 24, 2015
184 changes: 108 additions & 76 deletions dist/css/dist.css
Original file line number Diff line number Diff line change
Expand Up @@ -240,28 +240,27 @@ textarea {
transform: rotate(-135deg);
}

.dropdownArrow {
height: 10px;
width: 10px;
.dropdownArrow,
.dropdownArrow--reverse {
display: inline-block;
vertical-align: top;
position: relative;
text-align: center;
}
.dropdownArrow:after {
position: absolute;
width: 6px;
height: 6px;
top: 0;
left: 2px;
display: block;
content: '';
border-bottom: 1px solid #ffffff;
border-right: 1px solid #ffffff;
height: 7px;
width: 7px;
border: solid #ffffff;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}

.dropdownArrow {
border-width: 0 1px 1px 0;
top: -2.47487px;
}

.dropdownArrow--reverse {
border-width: 1px 0 0 1px;
top: 2.47487px;
}

.prevArrow {
height: 10px;
width: 10px;
Expand Down Expand Up @@ -3366,96 +3365,125 @@ body {
height: 14px;
}

.mainNavBar {
box-shadow: 0 42px 0 #2799c4;
.appHeader {
background: #354a53;
text-align: center;
display: -webkit-flex;
display: -ms-flexbox;
display: flex;
-webkit-justify-content: center;
-ms-flex-pack: center;
justify-content: center;
height: 45px;
}

.mainNavBar__liner {
.appHeader__liner {
display: -webkit-flex;
display: -ms-flexbox;
display: flex;
-webkit-align-items: center;
-ms-flex-align: center;
align-items: center;
-webkit-justify-content: space-between;
-ms-flex-pack: justify;
justify-content: space-between;
height: inherit;
-webkit-flex: 1;
-ms-flex: 1;
flex: 1;
max-width: 1200px;
margin: 0 auto;
}

.mainNavBar__logo {
text-indent: -999em;
float: left;
width: 76px;
height: 17px;
margin: 13px 0 15px;
background-image: url("");
background-size: 76px 17px;
background-position: right top;
background-repeat: no-repeat;
}

.mainNavBar__account {
.accountNav {
display: -webkit-flex;
display: -ms-flexbox;
display: flex;
-webkit-align-items: center;
-ms-flex-align: center;
align-items: center;
color: #ffffff;
float: right;
line-height: 22px;
height: 22px;
padding: 2px 8px 3px 4px;
margin: 8px 0 9px;
padding: 2px 8px 2px 2px;
border-radius: 20px;
font-size: 12px;
cursor: pointer;
overflow: hidden;
}
.mainNavBar__account label {
overflow: hidden;
.accountNav:hover {
background: #2e4048;
transition: 0.1s all ease-in-out;
}

.accountNav__email {
display: inline-block;
margin: 0 3px;
cursor: pointer;
}
.mainNavBar__account .dropdownArrow {
margin-top: 6px;
}
.mainNavBar__account .icon {

.accountPicture {
display: -webkit-flex;
display: -ms-flexbox;
display: flex;
-webkit-align-items: center;
-ms-flex-align: center;
align-items: center;
-webkit-justify-content: center;
-ms-flex-pack: center;
justify-content: center;
width: 22px;
height: 22px;
line-height: 22px;
margin-right: 2px;
position: relative;
display: inline-block;
vertical-align: top;
background: #445e6a;
border-radius: 22px;
overflow: hidden;
background: #445e6a;
}
.mainNavBar__account .icon:before {
.accountPicture:before {
font-size: 11px;
left: 5px;
line-height: 0;
color: #ffffff;
opacity: 0.6;
position: static;
}
.mainNavBar__account:hover {
background: #2e4048;
transition: 0.1s all ease-in-out;

.appLogo {
display: block;
text-indent: -999em;
width: 76px;
height: 17px;
background-image: url("");
background-size: 76px 17px;
background-position: right top;
background-repeat: no-repeat;
}

.mainNavBar__links__container {
display: inline-block;
.appNav {
display: -webkit-flex;
display: -ms-flexbox;
display: flex;
height: inherit;
}

.mainNavBar__link {
float: left;
.appNav__link {
display: -webkit-flex;
display: -ms-flexbox;
display: flex;
}
.mainNavBar__link a {
.appNav__link a {
color: #ffffff;
display: block;
line-height: 45px;
display: -webkit-flex;
display: -ms-flexbox;
display: flex;
-webkit-align-items: center;
-ms-flex-align: center;
align-items: center;
text-transform: uppercase;
font-size: 13px;
padding: 0 24px;
font-weight: 400;
transition: 0.2s padding ease-in-out, 0.06s background ease-in-out;
}
.mainNavBar__link:hover {
.appNav__link a:hover {
background: #3c545e;
}
.mainNavBar__link.selected {
background: #2799c4;
}
.mainNavBar__link.selected a {
.appNav__link a.selected {
cursor: default;
background: #2799c4;
}

.secondaryNavBar {
Expand Down Expand Up @@ -3889,6 +3917,10 @@ body {
background: transparent;
}

.exampleContainer--dark {
background: #aaaaaa;
}

.examplePageTitle {
margin-bottom: 16px;
font-size: 26px;
Expand All @@ -3907,22 +3939,22 @@ body {
}

@media (max-width: 1320px){
.mainNavBar__liner{
padding: 0 8px 0 15px;
.appHeader__liner{
padding: 0 15px;
}
.secondaryNavBar__liner{
padding: 0 15px;
}
}

@media (max-width: 800px){
.mainNavBar__logo{
width: 17px;
}
.mainNavBar__account label{
.accountNav__email{
display: none;
}
.mainNavBar__link a{
.appLogo{
width: 17px;
}
.appNav__link a{
padding: 0 14px;
font-size: 12px;
}
Expand Down
4 changes: 2 additions & 2 deletions dist/css/dist.css.map

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion src/framework/_index.scss
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
@import 'checkBox/index';
@import 'grid/index';
@import 'icon/index';
@import 'mainNav/index';
@import 'appHeader/index';
@import 'secondaryNav/index';
@import 'spinner/index';
@import 'titleBar/index';
53 changes: 53 additions & 0 deletions src/framework/appHeader/AccountNav.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@

import React, {
Component,
PropTypes,
} from 'react';

import AccountPicture from './AccountPicture.jsx';

export default class AccountNav extends Component {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think this could be made into a pure functional component. It will make the code shorter and reduce memory usage (a miniscule amount). Unless we anticipate needing to optimize this component with lifecycle hooks, I think it would be good to make it a pure functional component.


constructor(props) {
super(props);
this.state = {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think we should move this into props. Here's a conversation over at the Redux GitHub which specifically mentions dropdown state several times: reduxjs/redux#159

In short, I don't think it hurts anything to move this into the props, and it gives us the option of reacting to or acting upon this state globally.

isOpen: false,
};
}

onClick() {
this.setState({
isOpen: !this.state.isOpen,
});
}

render() {
const dropdownClass = !this.state.isOpen ?
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let's use classnames here, and change up the class name to reflect a BEM "state" class (see the .btn.is-collapsed example here):

const dropdownClass = classNames('accountDropdownArrow', {
  'is-account-dropdown-arrow-open': this.props.isOpen,
});

'dropdownArrow' :
'dropdownArrow--reverse';

return (
<a
className="accountNav"
onClick={this.onClick.bind(this)}
>
<AccountPicture
url={this.props.pictureUrl}
title={this.props.email}
/>
<span className="accountNav__email">
{this.props.email}
</span>
<span className={dropdownClass}></span>
</a>
);
}

}

AccountNav.propTypes = {
email: PropTypes.string.isRequired,
pictureUrl: AccountPicture.propTypes.url,
};

export default AccountNav;
30 changes: 30 additions & 0 deletions src/framework/appHeader/AccountPicture.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@

import React, {
Component,
PropTypes,
} from 'react';

export default class AccountPicture extends Component {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think this could be made into a pure functional component.


constructor(props) {
super(props);
}

render() {
const picture = this.props.url ? <img src={this.props.url} /> : null;

return (
<span className="icon glyphicons-user accountPicture">
{picture}
</span>
);
}

}

AccountPicture.propTypes = {
url: PropTypes.string,
title: PropTypes.string,
};

export default AccountPicture;
Loading