keycloak register
This commit is contained in:
parent
3dce0b5ce5
commit
59cb564dac
@ -28,18 +28,22 @@ const ButtonLinkStyle = styled(Label)`
|
|||||||
|
|
||||||
const ButtonLink = (props) => {
|
const ButtonLink = (props) => {
|
||||||
return (
|
return (
|
||||||
<ButtonLinkStyle>
|
<ButtonLinkStyle as={props.as} onClick={props.onClick}>
|
||||||
{props.children}
|
{props.children}
|
||||||
</ButtonLinkStyle>
|
</ButtonLinkStyle>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
ButtonLink.propTypes = {
|
ButtonLink.propTypes = {
|
||||||
|
as: PropsTypes.string,
|
||||||
|
onClick: PropsTypes.func,
|
||||||
children: PropsTypes.node,
|
children: PropsTypes.node,
|
||||||
};
|
};
|
||||||
|
|
||||||
ButtonLink.defaultProps = {
|
ButtonLink.defaultProps = {
|
||||||
children: '',
|
children: '',
|
||||||
|
as: 'div',
|
||||||
|
onClick: null,
|
||||||
};
|
};
|
||||||
|
|
||||||
export default ButtonLink;
|
export default ButtonLink;
|
@ -58,12 +58,13 @@ const MobileNavMenu = (props) => {
|
|||||||
Challenges
|
Challenges
|
||||||
</Menu>
|
</Menu>
|
||||||
</FlexRow>
|
</FlexRow>
|
||||||
<FlexRow as={Link} to='/register' gap='16px'>
|
{!KeyCloakService.isLoggedIn() ?
|
||||||
|
<FlexRow as='button' onClick={KeyCloakService.doRegister} gap='16px'>
|
||||||
<Svg width='16px' height='16px' src={registerIco}/>
|
<Svg width='16px' height='16px' src={registerIco}/>
|
||||||
<Menu as='li'>
|
<Menu as='li'>
|
||||||
Register
|
Register
|
||||||
</Menu>
|
</Menu>
|
||||||
</FlexRow>
|
</FlexRow> : ''}
|
||||||
{KeyCloakService.isLoggedIn() ?
|
{KeyCloakService.isLoggedIn() ?
|
||||||
<FlexRow as='button' onClick={KeyCloakService.doLogout} gap='16px'>
|
<FlexRow as='button' onClick={KeyCloakService.doLogout} gap='16px'>
|
||||||
<Svg width='16px' height='16px' src={loginIco} rotate='180deg'/>
|
<Svg width='16px' height='16px' src={loginIco} rotate='180deg'/>
|
||||||
@ -76,8 +77,7 @@ const MobileNavMenu = (props) => {
|
|||||||
<Menu as='li'>
|
<Menu as='li'>
|
||||||
Sign in
|
Sign in
|
||||||
</Menu>
|
</Menu>
|
||||||
</FlexRow>
|
</FlexRow>}
|
||||||
}
|
|
||||||
</MobileNavMenuStyle>
|
</MobileNavMenuStyle>
|
||||||
</TransBack>
|
</TransBack>
|
||||||
);
|
);
|
||||||
|
@ -50,12 +50,13 @@ const NavBar = () => {
|
|||||||
Challenges
|
Challenges
|
||||||
</Menu>
|
</Menu>
|
||||||
</FlexRow>
|
</FlexRow>
|
||||||
<FlexRow as={Link} to='/register' gap='16px'>
|
{!KeyCloakService.isLoggedIn() ?
|
||||||
|
<FlexRow as='button' onClick={KeyCloakService.doRegister} gap='16px'>
|
||||||
<Svg width='16px' height='16px' src={registerIco}/>
|
<Svg width='16px' height='16px' src={registerIco}/>
|
||||||
<Menu as='li'>
|
<Menu as='li'>
|
||||||
Register
|
Register
|
||||||
</Menu>
|
</Menu>
|
||||||
</FlexRow>
|
</FlexRow> : ''}
|
||||||
{KeyCloakService.isLoggedIn() ?
|
{KeyCloakService.isLoggedIn() ?
|
||||||
<FlexRow as='button' onClick={KeyCloakService.doLogout} gap='16px'>
|
<FlexRow as='button' onClick={KeyCloakService.doLogout} gap='16px'>
|
||||||
<Svg width='16px' height='16px' src={loginIco} rotate='180deg'/>
|
<Svg width='16px' height='16px' src={loginIco} rotate='180deg'/>
|
||||||
@ -68,8 +69,7 @@ const NavBar = () => {
|
|||||||
<Menu as='li'>
|
<Menu as='li'>
|
||||||
Sign in
|
Sign in
|
||||||
</Menu>
|
</Menu>
|
||||||
</FlexRow>
|
</FlexRow>}
|
||||||
}
|
|
||||||
</FlexRow>
|
</FlexRow>
|
||||||
</FlexRow>
|
</FlexRow>
|
||||||
<MobileNavMenu translateY={navMenuTranslateY} toggleNavMenu={toggleNavMenu}/>
|
<MobileNavMenu translateY={navMenuTranslateY} toggleNavMenu={toggleNavMenu}/>
|
||||||
|
@ -3,10 +3,10 @@ import {Body, H1, Medium} from '../../utils/fonts';
|
|||||||
import {Container, FlexColumn, FlexRow, Svg} from '../../utils/containers';
|
import {Container, FlexColumn, FlexRow, Svg} from '../../utils/containers';
|
||||||
import theme from '../../utils/theme';
|
import theme from '../../utils/theme';
|
||||||
import ButtonLink from '../elements/ButtonLink';
|
import ButtonLink from '../elements/ButtonLink';
|
||||||
import {Link} from 'react-router-dom';
|
|
||||||
import Media from 'react-media';
|
import Media from 'react-media';
|
||||||
import codepenIco from '../../assets/codepen_ico.svg';
|
import codepenIco from '../../assets/codepen_ico.svg';
|
||||||
import styled from 'styled-components';
|
import styled from 'styled-components';
|
||||||
|
import KeyCloakService from '../../services/KeyCloakService';
|
||||||
|
|
||||||
const TitleParagraph = styled(Medium)`
|
const TitleParagraph = styled(Medium)`
|
||||||
font-size: 20px;
|
font-size: 20px;
|
||||||
@ -26,7 +26,7 @@ const mobileRender = () => {
|
|||||||
A data challenge platform for machine learning research,
|
A data challenge platform for machine learning research,
|
||||||
competition, cooperation and reproducibility.
|
competition, cooperation and reproducibility.
|
||||||
</Body>
|
</Body>
|
||||||
<ButtonLink as={Link} to='/'>
|
<ButtonLink as='button' onClick={KeyCloakService.doRegister}>
|
||||||
Join us!
|
Join us!
|
||||||
</ButtonLink>
|
</ButtonLink>
|
||||||
</FlexColumn>
|
</FlexColumn>
|
||||||
@ -48,7 +48,7 @@ const desktopRender = () => {
|
|||||||
A data challenge platform for machine learning research,
|
A data challenge platform for machine learning research,
|
||||||
competition, cooperation and reproducibility.
|
competition, cooperation and reproducibility.
|
||||||
</TitleParagraph>
|
</TitleParagraph>
|
||||||
<ButtonLink as={Link} to='/'>
|
<ButtonLink as='button' onClick={KeyCloakService.doRegister}>
|
||||||
Join us!
|
Join us!
|
||||||
</ButtonLink>
|
</ButtonLink>
|
||||||
</Container>
|
</Container>
|
||||||
|
@ -27,6 +27,8 @@ const doLogout = _kc.logout;
|
|||||||
|
|
||||||
const getToken = () => _kc.token;
|
const getToken = () => _kc.token;
|
||||||
|
|
||||||
|
const doRegister = _kc.register;
|
||||||
|
|
||||||
const isLoggedIn = () => {
|
const isLoggedIn = () => {
|
||||||
return _kc.authenticated;
|
return _kc.authenticated;
|
||||||
};
|
};
|
||||||
@ -49,6 +51,7 @@ const KeyCloakService = {
|
|||||||
updateToken,
|
updateToken,
|
||||||
getUsername,
|
getUsername,
|
||||||
hasRole,
|
hasRole,
|
||||||
|
doRegister
|
||||||
};
|
};
|
||||||
|
|
||||||
export default KeyCloakService;
|
export default KeyCloakService;
|
Loading…
Reference in New Issue
Block a user