From 893b498335b3456a1e6af550cd8fc22ba548cc60 Mon Sep 17 00:00:00 2001 From: sabrina-bongiovanni <116291154+sabrina-bongiovanni@users.noreply.github.com> Date: Tue, 24 Sep 2024 09:56:34 +0200 Subject: [PATCH] fix: added condition for spid user link redirect (#776) * fix: added condition for spid user link redirect * chore: added customization info --- RELEASE.md | 20 +++++ .../volto/components/theme/View/LinkView.jsx | 75 +++++++++++++++++++ 2 files changed, 95 insertions(+) create mode 100644 src/customizations/volto/components/theme/View/LinkView.jsx diff --git a/RELEASE.md b/RELEASE.md index db4fccf61..835a2b24c 100644 --- a/RELEASE.md +++ b/RELEASE.md @@ -45,6 +45,26 @@ ### Migliorie +- Gli utenti SPID vengono ora direttamente rediretti al link finale quando viene utilizzato un CT di tipo Collegamento + +### Novità + +- ... + +### Fix + +- ... + +## Versione 11.23.1 (19/09/2024) + +### Migliorie + +- Il colore del focus da tastiera sugli elementi della pagina è ora bianco e nero per garantire sempre un contrasto ottimale su tutti gli sfondi. + +## Versione 11.23.0 (19/09/2024) + +### Migliorie + - Migliorato il layout della galleria immagini nei CT. - Il colore del focus da tastiera sugli elementi della pagina è ora bianco e nero per garantire sempre un contrasto ottimale su tutti gli sfondi. - Nel blocco Cerca Evento, nel caso di un Evento Rassegna, tra i risultati vengono ora visualizzati solo gli appuntamenti della rassegna e non l'evento contenitore. diff --git a/src/customizations/volto/components/theme/View/LinkView.jsx b/src/customizations/volto/components/theme/View/LinkView.jsx new file mode 100644 index 000000000..53b938691 --- /dev/null +++ b/src/customizations/volto/components/theme/View/LinkView.jsx @@ -0,0 +1,75 @@ +// CUSTOMIZATION: +// - Added condition to check if user is SPID user (16-18 and 21) + +import { useEffect } from 'react'; +import { useSelector } from 'react-redux'; +import PropTypes from 'prop-types'; +import { useHistory } from 'react-router-dom'; +import { isInternalURL, flattenToAppURL } from '@plone/volto/helpers'; +import { Container as SemanticContainer } from 'semantic-ui-react'; +import { UniversalLink } from '@plone/volto/components'; +import { FormattedMessage } from 'react-intl'; +import config from '@plone/volto/registry'; + +const LinkView = ({ token, content }) => { + const history = useHistory(); + const userIsSpidUser = useSelector( + (state) => state.users.user.roles.length === 0, + ); + + useEffect(() => { + if (!token || userIsSpidUser) { + const { remoteUrl } = content; + if (isInternalURL(remoteUrl)) { + history.replace(flattenToAppURL(remoteUrl)); + } else if (!__SERVER__) { + window.location.href = flattenToAppURL(remoteUrl); + } + } + }, [content, history, token, userIsSpidUser]); + const { title, description, remoteUrl } = content; + const { openExternalLinkInNewTab } = config.settings; + const Container = + config.getComponent({ name: 'Container' }).component || SemanticContainer; + + return ( + +

{title}

+ {content.description && ( +

{description}

+ )} + {remoteUrl && ( +

+ {' '} + + {flattenToAppURL(remoteUrl)} + +

+ )} +
+ ); +}; + +LinkView.propTypes = { + content: PropTypes.shape({ + title: PropTypes.string, + description: PropTypes.string, + remoteUrl: PropTypes.string, + }), + token: PropTypes.string, +}; + +LinkView.defaultProps = { + content: null, + token: null, +}; + +export default LinkView;