UNPKG

@plone/volto

Version:
56 lines (50 loc) 1.47 kB
import PropTypes from 'prop-types'; import { Link } from 'react-router-dom'; import { Menu } from 'semantic-ui-react'; import { FormattedMessage } from 'react-intl'; import { flattenToAppURL } from '@plone/volto/helpers/Url/Url'; import config from '@plone/volto/registry'; import { useSelector, shallowEqual } from 'react-redux'; const Anontools = () => { const token = useSelector((state) => state.userSession.token, shallowEqual); const content = useSelector((state) => state.content.data, shallowEqual); const { settings } = config; return ( !token && ( <Menu pointing secondary floated="right"> <Menu.Item> <Link aria-label="login" to={`/login${ content?.['@id'] ? `?return_url=${flattenToAppURL(content['@id'])}` : '' }`} > <FormattedMessage id="Log in" defaultMessage="Log in" /> </Link> </Menu.Item> {settings.showSelfRegistration && ( <Menu.Item> <Link aria-label="register" to="/register"> <FormattedMessage id="Register" defaultMessage="Register" /> </Link> </Menu.Item> )} </Menu> ) ); }; export default Anontools; Anontools.propTypes = { token: PropTypes.string, content: PropTypes.shape({ '@id': PropTypes.string, }), }; Anontools.defaultProps = { token: null, content: { '@id': null, }, };