feat(navigation): add user dropdown
This commit is contained in:
parent
495af5702d
commit
cac551beaf
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "my-joy-navigation",
|
"name": "my-joy-navigation",
|
||||||
"version": "2.5.1",
|
"version": "2.6.0",
|
||||||
"private": true,
|
"private": true,
|
||||||
"license": "MPL-2.0",
|
"license": "MPL-2.0",
|
||||||
"main": "lib/index.js",
|
"main": "lib/index.js",
|
||||||
|
@ -1,9 +1,10 @@
|
|||||||
import emotion from 'preact-emotion';
|
import emotion from 'preact-emotion';
|
||||||
|
import remcalc from 'remcalc';
|
||||||
|
|
||||||
export default emotion('a')`
|
export default emotion('a')`
|
||||||
font-weight: 600;
|
font-weight: 600;
|
||||||
line-height: 24px;
|
line-height: ${remcalc(24)};
|
||||||
font-size: 15px;
|
font-size: ${remcalc(15)};
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
color: ${props => props.theme.text};
|
color: ${props => props.theme.text};
|
||||||
|
|
||||||
|
@ -4,11 +4,7 @@ import remcalc from 'remcalc';
|
|||||||
|
|
||||||
const Img = emotion('img')`
|
const Img = emotion('img')`
|
||||||
width: ${remcalc(24)};
|
width: ${remcalc(24)};
|
||||||
|
border-radius: 50%;
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export default props => (
|
export default props => <Img {...props} />;
|
||||||
<Img
|
|
||||||
{...props}
|
|
||||||
src=""
|
|
||||||
/>
|
|
||||||
);
|
|
||||||
|
@ -33,4 +33,5 @@ export {
|
|||||||
|
|
||||||
export { default as Overlay } from './overlay';
|
export { default as Overlay } from './overlay';
|
||||||
export { default as Anchor } from './anchor';
|
export { default as Anchor } from './anchor';
|
||||||
|
export { default as Popover } from './popover';
|
||||||
export { default as Sup } from './sup';
|
export { default as Sup } from './sup';
|
||||||
|
44
packages/my-joy-navigation/src/components/popover.js
Normal file
44
packages/my-joy-navigation/src/components/popover.js
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
import emotion from 'preact-emotion';
|
||||||
|
import remcalc from 'remcalc';
|
||||||
|
|
||||||
|
export default emotion('div')`
|
||||||
|
min-width: ${remcalc(180)};
|
||||||
|
right: ${remcalc(12)};
|
||||||
|
top: ${remcalc(46)};
|
||||||
|
display: flex;
|
||||||
|
justify-content: start;
|
||||||
|
position: absolute;
|
||||||
|
padding: ${remcalc(12)};
|
||||||
|
z-index: 20;
|
||||||
|
border-radius: ${remcalc(4)};
|
||||||
|
background: ${props => props.theme.white};
|
||||||
|
border: ${remcalc(1)} solid ${props => props.theme.grey};
|
||||||
|
box-sizing: border-box;
|
||||||
|
box-shadow: 0 ${remcalc(2)} ${remcalc(4)} rgba(0, 0, 0, 0.05);
|
||||||
|
|
||||||
|
&:after {
|
||||||
|
position: absolute;
|
||||||
|
content: '';
|
||||||
|
top: ${remcalc(-6)};
|
||||||
|
right: ${remcalc(12)};
|
||||||
|
width: 0;
|
||||||
|
height: 0;
|
||||||
|
border-style: solid;
|
||||||
|
border-width: 0 ${remcalc(4.5)} ${remcalc(6)} ${remcalc(4.5)};
|
||||||
|
border-color: transparent transparent ${props =>
|
||||||
|
props.theme.white} transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
&:before {
|
||||||
|
position: absolute;
|
||||||
|
content: '';
|
||||||
|
top: ${remcalc(-7)};
|
||||||
|
right: ${remcalc(11)};
|
||||||
|
width: 0;
|
||||||
|
height: 0;
|
||||||
|
border-style: solid;
|
||||||
|
border-width: 0 ${remcalc(5.5)} ${remcalc(7)} ${remcalc(5.5)};
|
||||||
|
border-color: transparent transparent ${props =>
|
||||||
|
props.theme.grey} transparent;
|
||||||
|
}
|
||||||
|
`;
|
11
packages/my-joy-navigation/src/containers/account.js
Normal file
11
packages/my-joy-navigation/src/containers/account.js
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
import React from 'react';
|
||||||
|
import { Anchor, Popover } from '../components';
|
||||||
|
|
||||||
|
const Account = ({ expanded }) =>
|
||||||
|
expanded ? (
|
||||||
|
<Popover>
|
||||||
|
<Anchor href="/navigation/signout">Log Out</Anchor>
|
||||||
|
</Popover>
|
||||||
|
) : null;
|
||||||
|
|
||||||
|
export default Account;
|
@ -1,2 +1,3 @@
|
|||||||
export { default as Services } from './services';
|
export { default as Services } from './services';
|
||||||
export { default as Datacenter } from './datacenter';
|
export { default as Datacenter } from './datacenter';
|
||||||
|
export { default as Account } from './account';
|
||||||
|
@ -40,13 +40,14 @@ const GetAccount = gql`
|
|||||||
}
|
}
|
||||||
account {
|
account {
|
||||||
login
|
login
|
||||||
|
emailHash
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
`;
|
`;
|
||||||
|
|
||||||
const Navigation = ({
|
const Navigation = ({
|
||||||
account = {},
|
user = {},
|
||||||
datacenter = true,
|
datacenter,
|
||||||
toggleSectionOpen,
|
toggleSectionOpen,
|
||||||
isOpen,
|
isOpen,
|
||||||
activePanel
|
activePanel
|
||||||
@ -85,15 +86,18 @@ const Navigation = ({
|
|||||||
</HeaderItem>
|
</HeaderItem>
|
||||||
) : null}
|
) : null}
|
||||||
{datacenter ? <HeaderDividerItem /> : null}
|
{datacenter ? <HeaderDividerItem /> : null}
|
||||||
{account.login ? (
|
{user.login ? (
|
||||||
<HeaderItem>
|
<HeaderItem
|
||||||
|
onClick={() => toggleSectionOpen('account')}
|
||||||
|
active={isOpen && activePanel === 'account'}
|
||||||
|
>
|
||||||
<HeaderItemContent>
|
<HeaderItemContent>
|
||||||
<HeaderItemSubContent>Account:</HeaderItemSubContent>
|
<HeaderItemSubContent>Account:</HeaderItemSubContent>
|
||||||
<HeaderSpace />
|
<HeaderSpace />
|
||||||
{`${account.login}`}
|
{`${user.login}`}
|
||||||
</HeaderItemContent>
|
</HeaderItemContent>
|
||||||
<HeaderItemIcon>
|
<HeaderItemIcon>
|
||||||
<Avatar />
|
<Avatar src={user.image} />
|
||||||
</HeaderItemIcon>
|
</HeaderItemIcon>
|
||||||
</HeaderItem>
|
</HeaderItem>
|
||||||
) : null}
|
) : null}
|
||||||
@ -121,7 +125,12 @@ export default compose(
|
|||||||
|
|
||||||
const { name } = datacenter;
|
const { name } = datacenter;
|
||||||
|
|
||||||
return { account, datacenter: name, loading, error };
|
const user = {
|
||||||
|
...account,
|
||||||
|
image: `https://www.gravatar.com/avatar/${account.emailHash}`
|
||||||
|
};
|
||||||
|
|
||||||
|
return { user, datacenter: name, loading, error };
|
||||||
}
|
}
|
||||||
}),
|
}),
|
||||||
graphql(GetHeader, {
|
graphql(GetHeader, {
|
||||||
|
Loading…
Reference in New Issue
Block a user