{"version":3,"file":"app.js","sources":["../../../frontend-src/src/pages/nomatchpage/NoMatchPage.js","../../../frontend-src/src/components/App.js","../../../frontend-src/src/helpers/htmlParserTransform.js","../../../frontend-src/src/components/common/BodyStyle.js","../../../frontend-src/src/components/common/spinner/LoadingSpinner.js","../../../frontend-src/src/components/common/Redirect.js","../../../frontend-src/src/components/common/newsletter/NewsletterItem.js","../../../frontend-src/src/components/common/newsletter/NewsletterList.js","../../../frontend-src/src/components/common/notification/Notification.js","../../../frontend-src/src/components/common/personalization/LegacyTheme.js","../../../frontend-src/src/api/endpoints.js","../../../frontend-src/src/api/WebMethodService.js","../../../frontend-src/src/api/personalization/PersonalizationAPI.js","../../../frontend-src/src/components/common/personalization/Personalization.js","../../../frontend-src/src/api/msg/MsgAPI.js","../../../frontend-src/src/api/publiccustom/PublicCustomAPI.js","../../../frontend-src/src/services/MapperService.js","../../../frontend-src/src/api/deepGetSet.js","../../../frontend-src/src/models/FrontendException.js","../../../frontend-src/src/hooks/useResizeObserver.js","../../../frontend-src/src/helpers/notifyParent.js","../../../frontend-src/src/hoc/withResizeObserver.js","../../../frontend-src/src/components/msg/AutoprofileMsg.js","../../../frontend-src/src/components/msg/ConfirmOptoutMsg.js","../../../frontend-src/src/components/msg/ListDeletedMsg.js","../../../frontend-src/src/components/msg/SubscriptionMsg.js","../../../frontend-src/src/components/msg/UnsubscriptionMsg.js","../../../frontend-src/src/api/preferencecenter/PreferenceCenterAPI.js","../../../frontend-src/src/components/common/Iframe.js","../../../frontend-src/src/components/preferencecenter/PreferenceCenterDatiPersonali.js","../../../frontend-src/src/components/preferencecenter/PreferenceCenterDatiPersonaliExport.js","../../../frontend-src/src/api/enums.js","../../../frontend-src/src/components/common/social/icon/FacebookIcon.js","../../../frontend-src/src/components/common/social/icon/GooglePlusIcon.js","../../../frontend-src/src/components/common/social/icon/InstagramIcon.js","../../../frontend-src/src/components/common/social/icon/LinkedInIcon.js","../../../frontend-src/src/components/common/social/icon/PinterestIcon.js","../../../frontend-src/src/components/common/social/icon/SnapchatIcon.js","../../../frontend-src/src/components/common/social/icon/TelegramIcon.js","../../../frontend-src/src/components/common/social/icon/TwitterIcon.js","../../../frontend-src/src/components/common/social/icon/YouTubeIcon.js","../../../frontend-src/src/components/preferencecenter/PreferenceCenterSocial.js","../../../frontend-src/src/components/common/FieldErrors.js","../../../frontend-src/src/components/common/DateField.js","../../../frontend-src/src/helpers/dates.js","../../../frontend-src/src/components/preferencecenter/PreferenceCenterSubscription.js","../../../frontend-src/src/components/preferencecenter/WelcomeMessage.js","../../../frontend-src/src/models/InvalidSubscriberDataException.js","../../../frontend-src/src/components/preferencecenter/PreferenceCenter.js","../../../frontend-src/src/components/common/button/Button.js","../../../frontend-src/src/components/common/icon/Icon.js","../../../frontend-src/src/components/common/tooltip/Tooltip.js","../../../frontend-src/src/components/common/messageFeedback/MessageFeedback.js","../../../frontend-src/src/pages/aggregateReport/apiWrapprer.js","../../../frontend-src/src/pages/aggregateReport/AggregateReportApi.js","../../../frontend-src/src/pages/aggregateReport/AggregateReportAskPassword.js","../../../frontend-src/src/components/common/cardsLayout/CardsLayout.js","../../../frontend-src/src/components/common/card/Card.js","../../../frontend-src/src/components/common/singleLoader/SingleLoader.js","../../../frontend-src/src/services/uuid.js","../../../frontend-src/src/components/common/gaugeChart/GaugeChart.js","../../../frontend-src/src/pages/aggregateReport/AggregateReportBox.js","../../../frontend-src/src/pages/aggregateReport/AggregateReportData.js","../../../frontend-src/src/services/DateStringFormat.js","../../../frontend-src/src/components/common/dataTable/DataTable.js","../../../frontend-src/src/components/common/dataTable/DataTableHeader.js","../../../frontend-src/src/components/common/dataTable/DataTableHeaderCol.js","../../../frontend-src/src/components/common/dataTable/DataTableRow.js","../../../frontend-src/src/components/common/dataTable/DataTableCol.js","../../../frontend-src/src/components/common/chosen/Chosen.js","../../../frontend-src/src/components/common/pager/Pager.js","../../../frontend-src/src/components/common/truncateAndTooltip/TruncateAndTooltip.js","../../../frontend-src/src/pages/aggregateReport/AggregateReportMessages.js","../../../frontend-src/src/services/chunk.js","../../../frontend-src/src/services/batchPromises.js","../../../frontend-src/src/services/SpecialLinks.js","../../../frontend-src/src/pages/aggregateReport/AggregateReportLinks.js","../../../frontend-src/src/pages/aggregateReport/AggregateReport.js","../../../frontend-src/src/components/common/dateMapper/DateMapper.js","../../../frontend-src/src/api/apiWrapprer.js","../../../frontend-src/src/api/beEmailMessageApi/BeEmailMessageApi.js","../../../frontend-src/src/api/beListApi/BeListApi.js","../../../frontend-src/src/api/beRecipientApi/BeRecipientApi.js","../../../frontend-src/src/api/statisticsApi/StatisticsApi.js","../../../frontend-src/src/pages/bounceLog/BounceLog.js","../../../frontend-src/src/components/common/emptyState/EmptyState.js","../../../frontend-src/src/api/beSendApi/BeSendApi.js","../../../frontend-src/src/pages/linkReport/LinkReport.js","../../../frontend-src/src/api/subscriber/SubscriberApi.js","../../../frontend-src/src/hooks/useLoadSubscriber.js","../../../frontend-src/src/pages/newSubscribers/NewSubscribers.jsx","../../../frontend-src/src/components/common/reportBox/ReportBox.js","../../../frontend-src/src/components/common/dropDownElement/DropDownElement.js","../../../frontend-src/src/components/common/datePickerContainer/DatePickerContainer.js","../../../frontend-src/src/components/common/link/Link.js","../../../frontend-src/src/components/common/dataRangeSelector/DataRangeSelector.js","../../../frontend-src/src/services/ChartService.js","../../../frontend-src/src/components/common/areaChart/AreaChart.js","../../../frontend-src/src/api/beAccount/BeAccount.js","../../../frontend-src/src/services/Constants.js","../../../frontend-src/src/pages/openClickViewReport/OpenClickViewReport.js","../../../frontend-src/src/components/common/modal/ModalWrapper.js","../../../frontend-src/src/components/common/buttonsGroup/ButtonsGroup.js","../../../frontend-src/src/components/common/modal/ModalBody.js","../../../frontend-src/src/components/common/modal/ModalFooter.js","../../../frontend-src/src/components/common/modal/ModalHeader.js","../../../frontend-src/src/components/common/selectedRecipientsModal/SelectedRecipientsModal.js","../../../frontend-src/src/api/beFilterApi/BeFilterApi.js","../../../frontend-src/src/pages/sendReport/SendReport.js","../../../frontend-src/src/components/common/elementSelected/ElementSelected.js","../../../frontend-src/src/components/common/inputContainer/InputContainer.js","../../../frontend-src/src/components/common/messageNoResult/MessageNoResult.js","../../../frontend-src/src/components/common/dataTable/OrderGrid.js","../../../frontend-src/src/components/common/messageBox/MessageBox.js","../../../frontend-src/src/pages/sendReport/SendReportDetails.js","../../../frontend-src/src/components/common/columnChart/ColumnChart.js","../../../frontend-src/src/pages/showMessageReports/ShowMessageReports.js","../../../frontend-src/src/pages/userViewReport/UserViewReport.js","../../../frontend-src/src/services/PendoTracking.js","../../../frontend-src/src/api/console/ConsoleAPI.js","../../../frontend-src/src/components/Root.js","../../../frontend-src/src/index.js"],"sourcesContent":["import React from 'react'\r\n\r\nimport { withRouter } from 'react-router-dom'\r\nimport { injectIntl } from 'react-intl'\r\n\r\nconst NoMatchPage = ({ match, history, location, intl }) => {\r\n return (\r\n
\r\n
\r\n
\r\n
\r\n

{intl.formatMessage({ id: 'Load.Common.PageNotFoundPubb' })}

\r\n

{intl.formatMessage({ id: 'Load.Common.PageNotFoundPubbDescr' })}

\r\n\r\n
\r\n
\r\n
\r\n )\r\n}\r\n\r\nexport default injectIntl(withRouter(NoMatchPage))\r\n","import React from 'react'\r\nimport { PropTypes } from 'prop-types'\r\n\r\nconst App = ({ children }) => {\r\n return (
{children}
)\r\n}\r\n\r\nApp.propTypes = {\r\n children: PropTypes.object.isRequired\r\n}\r\n\r\nexport default App\r\n","\r\n/*\r\ntype (string): The type of node (tag, text, style etc)\r\nname (string): The name of the node\r\nchildren (array): Array of children nodes\r\nnext (node): The node's next sibling\r\nprev (node): The node's previous sibling\r\nparent (node): The node's parent\r\ndata\r\n\r\n*/\r\n\r\nconst htmlParserTransform = (node) => {\r\n\r\n if (node.type === 'script') {\r\n return <>;\r\n }\r\n if (node.type === 'tag') {\r\n Object.keys(node.attribs).forEach(attrName => {\r\n if (attrName.startsWith('on')) {\r\n delete node.attribs[attrName];\r\n }\r\n\r\n if (attrName === 'href' || attrName === 'src') {\r\n try {\r\n const url = new URL(node.attribs[attrName]);\r\n if (url.protocol === 'javascript:') {\r\n node.attribs[attrName] = '#';\r\n }\r\n } catch {\r\n //\r\n }\r\n }\r\n });\r\n }\r\n};\r\n\r\nexport default htmlParserTransform;","// Applica al body una classe CSS custom\r\nimport React, { Component } from \"react\";\r\nimport {PropTypes} from 'prop-types';\r\n\r\nclass BodyStyle extends Component {\r\n constructor( props ){\r\n super();\r\n }\r\n componentWillMount(){\r\n if(this.props.customClass && !document.body.classList.contains(this.props.customClass) ) {\r\n document.body.classList.add(this.props.customClass);\r\n }\r\n }\r\n\r\n render(){\r\n return null;\r\n }\r\n}\r\n\r\nBodyStyle.propTypes = {\r\n customClass: PropTypes.string.isRequired\r\n};\r\n\r\nexport default BodyStyle;","//\r\nimport React from 'react'\r\n\r\nimport { Spinner } from 'spin.js'\r\n\r\nimport 'spin.js/spin.css'\r\n\r\nclass LoadingSpinner extends React.Component {\r\n constructor (props) {\r\n super(props)\r\n //\r\n this.spinner = null // riferimento a oggetto javascript Spinner\r\n this.spinnerRef = React.createRef()\r\n }\r\n\r\n componentDidMount () {\r\n //\r\n const config = {\r\n lines: 6,\r\n length: 0,\r\n width: 10,\r\n radius: 10,\r\n corners: 1,\r\n rotate: 0,\r\n direction: 1,\r\n color: '#4CBAD7',\r\n opacity: 0.1,\r\n speed: 1.4,\r\n trail: 100,\r\n shadow: false,\r\n hwaccel: true,\r\n className: 'spinner',\r\n zIndex: 200,\r\n top: '50%',\r\n left: '50%'\r\n }\r\n //\r\n if (this.spinnerRef && this.spinnerRef.current) {\r\n this.spinner = new Spinner(config).spin(this.spinnerRef.current)\r\n }\r\n }\r\n\r\n componentWillUnmount () {\r\n if (this.spinner && this.spinner.stop) {\r\n this.spinner.stop()\r\n }\r\n }\r\n\r\n render () {\r\n return (\r\n \r\n {this.props.children &&\r\n {this.props.children}}\r\n \r\n )\r\n }\r\n}\r\n\r\nexport default LoadingSpinner\r\n","//\r\nimport { PropTypes } from 'prop-types';\r\nimport React, { Component } from \"react\";\r\nimport { injectIntl } from 'react-intl';\r\nimport LoadingSpinner from '../common/spinner/LoadingSpinner';\r\n\r\nclass Redirect extends Component {\r\n constructor(props) {\r\n super();\r\n this.mounted = false;\r\n //\r\n this.state = {\r\n loading: false\r\n };\r\n }\r\n componentWillMount() {\r\n this.mounted = true;\r\n this.startLoader();\r\n window.location.assign(this.props.to);\r\n }\r\n\r\n componentWillUnmount() {\r\n this.stopLoader();\r\n this.mounted = false;\r\n }\r\n\r\n startLoader = () => {\r\n if (this.mounted) {\r\n this.setState({\r\n loading: true\r\n });\r\n }\r\n }\r\n\r\n stopLoader = () => {\r\n if (this.mounted) {\r\n this.setState({\r\n loading: false\r\n });\r\n }\r\n }\r\n\r\n render() {\r\n return (
{this.state.loading && }
);\r\n }\r\n}\r\n\r\nRedirect.propTypes = {\r\n to: PropTypes.string.isRequired\r\n};\r\n\r\nexport default injectIntl(Redirect);","//\nimport PropTypes from \"prop-types\";\nimport React from \"react\";\nimport { injectIntl } from 'react-intl';\n\nconst NewsletterItem = (props) => {\n const url = \"/frontend/nl_preview_window.aspx?idNL=\" + props.item.IdMessage;\n return (\n
  • \n {props.item.LastUpdated && \n

    {props.item.LastUpdated.StringValue.slice(0, 10)}

    \n }\n {props.item.Subject}\n
  • \n );\n};\n\nNewsletterItem.propTypes = {\n item: PropTypes.shape({\n IdMessage: PropTypes.number.isRequired,\n IdList: PropTypes.number.isRequired,\n Subject: PropTypes.string.isRequired,\n Notes: PropTypes.string,\n LastUpdated: PropTypes.object\n })\n};\n\nexport default injectIntl(NewsletterItem);\n","//\r\nimport React from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport NewletterItem from './NewsletterItem';\r\n\r\nconst NewsletterList = (props) => (\r\n \r\n);\r\n\r\nNewsletterList.propTypes = {\r\n list: PropTypes.arrayOf(PropTypes.shape({\r\n IdMessage: PropTypes.number.isRequired,\r\n IdList: PropTypes.number.isRequired,\r\n Subject: PropTypes.string.isRequired,\r\n Notes: PropTypes.string,\r\n LastUpdated: PropTypes.object\r\n }))\r\n};\r\n\r\nexport default NewsletterList;","// Molto in progress...\r\nimport React from 'react';\r\nimport {PropTypes} from 'prop-types';\r\n\r\nclass Notification extends React.Component {\r\n constructor() {\r\n super();\r\n //\r\n this.defaultTimeout = 5000;\r\n this.messageNodes = {}; // mappa msgId => nodo HTML del messaggio\r\n //\r\n this.state = {\r\n messages: [],\r\n\r\n };\r\n }\r\n\r\n /**\r\n * Do not call directly\r\n * \r\n */\r\n addMessage = (type, message, source, autoClose, closeButton) => {\r\n //\r\n const newMessage = {msgId: guid(), type, message, source, closeButton};\r\n //\r\n if(source == 'default') {\r\n // aggiungo messaggio\r\n this.setState((prevState) => {\r\n return {\r\n messages: [...prevState.messages, newMessage]\r\n };\r\n });\r\n } else {\r\n // stesso src: sovrascrivo messaggio\r\n this.setState((prevState) => {\r\n return {\r\n messages: [...prevState.messages.filter(o => o.source != source), newMessage]\r\n };\r\n });\r\n }\r\n //\r\n if (autoClose) {\r\n const timer = setTimeout(() => {\r\n this.removeMessage(newMessage.msgId);\r\n }, this.defaultTimeout);\r\n }\r\n\r\n }\r\n\r\n addInfo = (message, source='default', autoClose=true, closeButton=false) => {\r\n this.addMessage('info', message, source, autoClose, closeButton);\r\n }\r\n\r\n /**\r\n * @param {string} message\r\n * @param {string} source\r\n * @param {boolean} autoClose\r\n * @param {boolean} closeButton\r\n * \r\n */\r\n addSuccess = (message, source='default', autoClose=true, closeButton=false) => {\r\n this.addMessage('success', message, source, autoClose, closeButton);\r\n }\r\n\r\n addWarning = (message, source='default', autoClose=true, closeButton=false) => {\r\n this.addMessage('warning', message, source, autoClose, closeButton);\r\n }\r\n\r\n \r\n addError = (message, source='default', autoClose=true, closeButton=false) => {\r\n this.addMessage('error', message, source, autoClose, closeButton);\r\n }\r\n\r\n removeMessage = (msgId) => {\r\n const node = this.messageNodes[msgId];\r\n if (node) {\r\n node.classList.add(\"closing\");\r\n delete this.messageNodes[msgId];\r\n }\r\n\r\n setTimeout(() => {\r\n this.setState((prevState) => {\r\n return {\r\n messages: [...prevState.messages.filter(o => o.msgId != msgId)]\r\n };\r\n });\r\n }, 1000);\r\n }\r\n\r\n addMessageRef = (node) => {\r\n if (node && node.getAttribute('data-msgid')) {\r\n this.messageNodes[node.getAttribute('data-msgid')] = node;\r\n }\r\n }\r\n\r\n onCloseClick = (event) => {\r\n event.preventDefault();\r\n this.removeMessage(event.target.getAttribute('data-msgid'));\r\n }\r\n\r\n renderMessage = (o, idx) => {\r\n return(\r\n
    \r\n \r\n {o.message}\r\n {` `}\r\n {o.closeButton && }\r\n
    \r\n );\r\n }\r\n\r\n render() {\r\n return(\r\n
    \r\n {this.state.messages.map((o, idx) => this.renderMessage(o,idx))}\r\n
    \r\n );\r\n }\r\n\r\n}\r\n\r\nfunction guid() {\r\n return s4() + s4() + '-' + s4() + '-' + s4() + '-' + s4() + '-' + s4() + s4() + s4();\r\n}\r\n\r\nfunction s4() {\r\n return Math.floor((1 + Math.random()) * 0x10000)\r\n .toString(16)\r\n .substring(1);\r\n}\r\n\r\n\r\nexport default Notification;","// Carica \"vecchi\" CSS di personalizzazione di frontend (bt-3.2, default, blue|gark|grey|green)\r\nimport React, { Component} from \"react\";\r\nimport { PropTypes} from 'prop-types';\r\n\r\n\r\n\r\nclass LegacyTheme extends Component {\r\n constructor(props) {\r\n super();\r\n //\r\n this.elementsToRemove = ['#titles-font', '#paragraphs-font', '[href*=\"/frontend/static/frontend\"]'];\r\n }\r\n\r\n componentDidMount() {\r\n this.elementsToRemove.forEach((o) => {\r\n this.removeElement(o);\r\n });\r\n //\r\n\r\n const subpath = this.props.mode == 'subscription' ? 'new/' : '';\r\n\r\n // BT\r\n const btLink = document.createElement(\"link\");\r\n btLink.rel = \"stylesheet\";\r\n btLink.href = '/css/bt-3.2.css';\r\n btLink.id = 'legacy-bt-style';\r\n document.head.appendChild(btLink);\r\n //\r\n // default\r\n const defaultLink = document.createElement(\"link\");\r\n defaultLink.rel = \"stylesheet\";\r\n defaultLink.href = `/frontend/css/formBuilder/${subpath}Default.css`;\r\n defaultLink.id = 'legacy-frontend-style';\r\n document.head.appendChild(defaultLink);\r\n //\r\n // theme\r\n if (this.props.style !== 'Default') {\r\n const themeLink = document.createElement(\"link\");\r\n const style = this.props.style.charAt(0).toUpperCase() + this.props.style.substring(1);\r\n themeLink.rel = \"stylesheet\";\r\n themeLink.href = `/frontend/css/formBuilder/${subpath}${style}.css`;\r\n themeLink.id = 'legacy-custom-style';\r\n document.head.appendChild(themeLink);\r\n }\r\n\r\n }\r\n\r\n removeElement(selector) {\r\n const el = document.querySelector(selector);\r\n if (el) {\r\n el.parentNode.removeChild(el);\r\n }\r\n }\r\n\r\n render() {\r\n return null;\r\n }\r\n\r\n}\r\n\r\n\r\nLegacyTheme.propTypes = {\r\n style: PropTypes.oneOf(['default', 'blue', 'dark', 'gray', 'green']),\r\n mode: PropTypes.oneOf(['subscription', 'autoprofile']),\r\n};\r\n\r\nexport default LegacyTheme;","//\r\nexport default {\r\n console: {\r\n getLanguage: '/frontend/webMethods/Console.asmx/GetLanguage',\r\n getPendoSettings: '/frontend/webMethods/Console.asmx/GetPendoSettings'\r\n },\r\n languages: {\r\n da: '/App/lang/da_DA.json',\r\n de: '/App/lang/de_DE.json',\r\n en: '/App/lang/en_US.json',\r\n es: '/App/lang/es_ES.json',\r\n fr: '/App/lang/fr_FR.json',\r\n id: '/App/lang/id_ID.json',\r\n it: '/App/lang/it_IT.json',\r\n ja: '/App/lang/ja_JP.json',\r\n pt: '/App/lang/pt_PT.json',\r\n zh: '/App/lang/zh_CN.json',\r\n tr: '/App/lang/tr_TR.json',\r\n el: '/App/lang/el_GR.json'\r\n },\r\n preferencecenter: {\r\n getAutoprofileFormAvailability: '/frontend/webMethods/PreferenceCenter.asmx/GetAutoprofileFormAvailability',\r\n getDefaultListValues: '/frontend/webMethods/PreferenceCenter.asmx/GetDefaultListValues',\r\n getSubscriberEmail: '/frontend/webMethods/PreferenceCenter.asmx/GetSubscriberEmail',\r\n loadPrefCenterOptions: '/frontend/webMethods/PreferenceCenter.asmx/LoadPrefCenterOptions',\r\n loadSubscriberPreferences: '/frontend/webMethods/PreferenceCenter.asmx/LoadSubscriberPreferences',\r\n saveSubscriberPreferences: '/frontend/webMethods/PreferenceCenter.asmx/SaveSubscriberPreferences'\r\n },\r\n exportService: {\r\n exportAnagrData: '/frontend/webMethods/ExportServiceFrontend.asmx/PreferenceCenterExportAnagrData'\r\n },\r\n msg: {\r\n getDefaultListValues: '/frontend/webMethods/Msg.asmx/GetDefaultListValues',\r\n getNewsletterList: '/frontend/webMethods/Msg.asmx/GetNewsletterList',\r\n getSubscriberEmail: '/frontend/webMethods/Msg.asmx/GetSubscriberEmail',\r\n isOptin: '/frontend/webMethods/Msg.asmx/IsOptin',\r\n getSubscriberData: '/frontend/webMethods/Msg.asmx/GetSubscriberData'\r\n },\r\n personalization: {\r\n getListSettings: '/frontend/webMethods/Personalization.asmx/GetListSettings'\r\n },\r\n publicCustom: {\r\n getAction: '/frontend/webMethods/PublicCustom.asmx/GetAction',\r\n getActionForRecipient: '/frontend/webMethods/PublicCustom.asmx/GetActionForRecipient',\r\n getText: '/frontend/webMethods/PublicCustom.asmx/GetText',\r\n getSettings: '/frontend/webMethods/PublicCustom.asmx/GetSettings',\r\n getListGUID: '/frontend/webMethods/PublicCustom.asmx/GetListGUID',\r\n getClientIP: '/frontend/webMethods/PublicCustom.asmx/GetClientIP',\r\n getCustomFlowConfig: '/frontend/webMethods/PublicCustom.asmx/GetCustomFlowConfig'\r\n }\r\n\r\n}\r\n","//\r\nimport axios from 'axios'\r\n\r\nclass WebMethodService {\r\n static callWebMethod (url, params) {\r\n //\r\n const promise = new Promise((resolve, reject) => {\r\n let isLoading = true\r\n axios.post(url, params, {\r\n headers: {\r\n 'Content-Type': 'application/json; charset=UTF-8'\r\n }\r\n }).then((response) => {\r\n const payload = JSON.parse(response.data.d)\r\n // response is an application error\r\n if (payload.hasOwnProperty('type') && payload.type == 'FrontendException') {\r\n //\r\n reject(payload)\r\n } else {\r\n //\r\n resolve(payload)\r\n }\r\n }).catch((err) => {\r\n //\r\n reject(err)\r\n }).finally(() => {\r\n isLoading = false\r\n })\r\n })\r\n //\r\n return promise\r\n }\r\n}\r\n\r\nexport default WebMethodService\r\n","//\r\nimport endpoints from '../endpoints';\r\nimport WebMethodService from '../WebMethodService';\r\n\r\nclass PersonalizationAPI {\r\n\r\n /**\r\n * Restituisce impostazioni di customizzazione lista\r\n * @param {number} idList \r\n * @returns {Promise}\r\n * \r\n */\r\n static getListSettings(idList) {\r\n const params = {\r\n idList\r\n };\r\n return WebMethodService.callWebMethod(endpoints.personalization.getListSettings, params);\r\n }\r\n\r\n\r\n}\r\n\r\nexport default PersonalizationAPI;","// Applica personalizzazioni di frontend (logo, stili custom)\r\nimport React, { Component } from 'react'\r\nimport { PropTypes } from 'prop-types'\r\nimport cssVars from 'css-vars-ponyfill'\r\n\r\nimport PersonalizationAPI from '../../../api/personalization/PersonalizationAPI'\r\n\r\nclass Personalization extends Component {\r\n constructor (props) {\r\n super()\r\n //\r\n this.mounted = false\r\n //\r\n this.settings = {}\r\n //\r\n this.state = {\r\n showMainContent: false\r\n }\r\n }\r\n\r\n componentDidMount () {\r\n this.mounted = true\r\n //\r\n\r\n //\r\n if (this.props.showLogo || this.props.applyCustomCSS) {\r\n this.getListSettings().then(() => {\r\n if (this.mounted) {\r\n //\r\n this.applyCustomCSS()\r\n //\r\n this.setState({\r\n showMainContent: true\r\n })\r\n }\r\n })\r\n }\r\n }\r\n\r\n componentWillUnmount () {\r\n this.mounted = false\r\n }\r\n\r\n getListSettings () {\r\n return PersonalizationAPI.getListSettings(this.props.idList).then((settings) => {\r\n this.settings = settings\r\n })\r\n }\r\n\r\n applyCustomCSS () {\r\n if (this.props.applyCustomCSS && this.settings.Style) {\r\n const customCSS = JSON.parse(this.settings.Style)\r\n const fontProperties = ['--paragraphs-fonturl', '--titles-fonturl']\r\n //\r\n const properties = this.fixValues(this.toKeyValue('-', customCSS))\r\n\r\n // Aggiunta font\r\n fontProperties.forEach((key) => {\r\n if (properties.hasOwnProperty(key)) {\r\n if (!document.querySelector('link[href=\"' + properties[key] + '\"]')) {\r\n //\r\n const link = document.createElement('link')\r\n link.rel = 'stylesheet'\r\n link.href = properties[key]\r\n document.head.appendChild(link)\r\n }\r\n }\r\n })\r\n\r\n //\r\n Object.keys(properties).forEach((key) => {\r\n document.documentElement.style.setProperty(key, properties[key])\r\n })\r\n // polyfill\r\n cssVars({\r\n variables: properties\r\n })\r\n }\r\n }\r\n\r\n toKeyValue (prevkey, o, separator = '-') {\r\n let result = {}\r\n for (const k in o) {\r\n let newkey = k\r\n if (prevkey) {\r\n newkey = prevkey.toLowerCase() + separator + k.toLowerCase()\r\n }\r\n\r\n if (o.hasOwnProperty(k)) {\r\n const p = o[k]\r\n\r\n if (typeof p === 'object') {\r\n result = Object.assign(result, this.toKeyValue(newkey, p))\r\n } else {\r\n result[newkey] = p\r\n }\r\n }\r\n }\r\n return result\r\n }\r\n\r\n /**\r\n * Corregge variabili senza 'px' aggiungendo unità di misura\r\n * Crea variabili per colori da esprimere in rgb\r\n */\r\n fixValues (properties) {\r\n const missingPx = ['--paragraphs-fontsize', '--titles-fontsize']\r\n const numberOnlyRegEx = /^[0-9]+$/\r\n //\r\n const colorsToSplit = ['--paragraphs-color', '--link-color', '--social-backgroud']\r\n const colorRegEx = /^#[0-9a-fA-F]{6}$/\r\n const colorShortRegEx = /^#[0-9a-fA-F]{3}$/\r\n //\r\n missingPx.forEach((key) => {\r\n if (properties.hasOwnProperty(key) && numberOnlyRegEx.test(properties[key])) {\r\n properties[key] = properties[key] + 'px'\r\n }\r\n })\r\n //\r\n colorsToSplit.forEach((key) => {\r\n if (properties.hasOwnProperty(key)) {\r\n // gestione alpha channel\r\n if (properties[key] == 'transparent') {\r\n properties[key + '-A'] = '0'\r\n } else {\r\n properties[key + '-A'] = '1'\r\n }\r\n //\r\n if (colorShortRegEx.test(properties[key])) {\r\n properties[key + '-R'] = parseInt('' + properties[key].substring(1, 2) + properties[key].substring(1, 2), 16)\r\n properties[key + '-G'] = parseInt('' + properties[key].substring(2, 3) + properties[key].substring(2, 3), 16)\r\n properties[key + '-B'] = parseInt('' + properties[key].substring(3, 4) + properties[key].substring(3, 4), 16)\r\n } else if (colorRegEx.test(properties[key])) {\r\n properties[key + '-R'] = parseInt('' + properties[key].substring(1, 3), 16)\r\n properties[key + '-G'] = parseInt('' + properties[key].substring(3, 5), 16)\r\n properties[key + '-B'] = parseInt('' + properties[key].substring(5, 7), 16)\r\n }\r\n }\r\n })\r\n //\r\n return properties\r\n }\r\n\r\n render () {\r\n if (!this.props.showLogo) {\r\n return null\r\n }\r\n // se non si hanno nè CompanyLogo nè CompanyName non creare alcun elemento in DOM\r\n if (!this.settings.CompanyLogo && !this.settings.CompanyName) {\r\n return null\r\n }\r\n\r\n return (\r\n <>\r\n {this.state.showMainContent &&\r\n\r\n
    \r\n {this.settings.CompanyLogo &&\r\n <>\r\n {this.settings.CompanyURL &&\r\n }\r\n {!this.settings.CompanyURL &&\r\n

    }\r\n }\r\n\r\n {!this.settings.CompanyLogo && this.settings.CompanyName &&\r\n <>\r\n {this.settings.CompanyURL &&\r\n

    {this.settings.CompanyName}

    }\r\n {!this.settings.CompanyURL &&\r\n

    {this.settings.CompanyName}

    }\r\n }\r\n
    }\r\n \r\n )\r\n }\r\n}\r\n\r\nPersonalization.defaultProps = {\r\n showLogo: false,\r\n applyCustomCSS: false\r\n}\r\n\r\nPersonalization.propTypes = {\r\n // idList: PropTypes.string.isRequired,\r\n showLogo: PropTypes.bool,\r\n applyCustomCSS: PropTypes.bool\r\n}\r\n\r\nexport default Personalization\r\n","//\r\nimport endpoints from '../endpoints';\r\nimport WebMethodService from '../WebMethodService';\r\n\r\nclass MsgAPI {\r\n /**\r\n * Restituisce messaggi di default per eliminazione lista\r\n * @returns {Promise}\r\n */\r\n static getDefaultListValues() {\r\n const params = {};\r\n return WebMethodService.callWebMethod(endpoints.msg.getDefaultListValues, params);\r\n }\r\n \r\n /**\r\n * Restituisce elenco newsletter pubblicate\r\n * @param {number} idList \r\n * @returns {Promise}\r\n * \r\n */\r\n static getNewsletterList(idList) {\r\n const params = {\r\n idList\r\n };\r\n return WebMethodService.callWebMethod(endpoints.msg.getNewsletterList, params);\r\n }\r\n\r\n /**\r\n * Restituisce email del subscriber a partire da idUser e hash\r\n * @param {number} idUser \r\n * @param {string} hash \r\n * @returns {Promise}\r\n */\r\n static getSubscriberEmail(idUser, hash) {\r\n const params = {\r\n idUser,\r\n hash\r\n };\r\n\r\n return WebMethodService.callWebMethod(endpoints.msg.getSubscriberEmail, params);\r\n }\r\n\r\n /**\r\n * Restituisce true se subscriber è iscritto\r\n * @param {number} idList \r\n * @param {number} idUser \r\n * @param {string} hash \r\n * @returns {Promise}\r\n */\r\n static isOptin(idList, idUser, hash) {\r\n const params = {\r\n idList,\r\n idUser,\r\n hash\r\n };\r\n\r\n return WebMethodService.callWebMethod(endpoints.msg.isOptin, params);\r\n }\r\n\r\n \r\n /**\r\n * Restituisce dati di un subscriber\r\n * @param {number} idList \r\n * @param {number} idUser\r\n * @param {string} hash\r\n * @returns {Promise}\r\n * \r\n */\r\n static getSubscriberData(idList, idUser, hash) {\r\n const params = {\r\n idList,\r\n idUser,\r\n hash\r\n };\r\n return WebMethodService.callWebMethod(endpoints.msg.getSubscriberData, params);\r\n }\r\n\r\n\r\n}\r\n\r\nexport default MsgAPI;","//\r\nimport endpoints from '../endpoints';\r\nimport WebMethodService from '../WebMethodService';\r\n\r\nclass PublicCustomAPI {\r\n /**\r\n * Restituisce configurazione di azione per idList e actionCode\r\n * @param {number} idList \r\n * @param {string} actionCode \r\n * @returns {Promise}\r\n * \r\n */\r\n static getAction(idList, actionCode) {\r\n const params = {\r\n idList,\r\n actionCode\r\n };\r\n return WebMethodService.callWebMethod(endpoints.publicCustom.getAction, params);\r\n }\r\n\r\n /**\r\n * Restituisce configurazione di azione per idList e actionCode\r\n * @param {number} idList \r\n * @param {string} actionCode \r\n * @returns {Promise}\r\n * \r\n */\r\n static getActionForRecipient(idList, actionCode, email, preview) {\r\n const params = {\r\n idList,\r\n actionCode,\r\n email,\r\n preview\r\n };\r\n return WebMethodService.callWebMethod(endpoints.publicCustom.getActionForRecipient, params);\r\n }\r\n\r\n\r\n /**\r\n * Restituisce configurazione messaggio per idList e actionCode\r\n * @param {number} idList \r\n * @param {string} actionCode \r\n * @returns {Promise}\r\n * \r\n */\r\n static getText(idList, actionCode) {\r\n const params = {\r\n idList,\r\n actionCode\r\n };\r\n return WebMethodService.callWebMethod(endpoints.publicCustom.getText, params);\r\n }\r\n\r\n /**\r\n * Restituisce configurazione di lista dato idList\r\n * @param {number} idList \r\n * @returns {Promise}\r\n * \r\n */\r\n static getSettings(idList) {\r\n const params = {\r\n idList\r\n };\r\n return WebMethodService.callWebMethod(endpoints.publicCustom.getSettings, params);\r\n }\r\n\r\n /**\r\n * Restituisce GUID di lista dato idList\r\n * @param {number} idList \r\n * @returns {Promise}\r\n * \r\n */\r\n static getListGUID(idList) {\r\n const params = {\r\n idList\r\n };\r\n return WebMethodService.callWebMethod(endpoints.publicCustom.getListGUID, params);\r\n }\r\n\r\n /**\r\n * Restituisce IP del client\r\n * @returns {Promise}\r\n * \r\n */\r\n static getClientIP() {\r\n return WebMethodService.callWebMethod(endpoints.publicCustom.getClientIP, {});\r\n }\r\n\r\n static getCustomFlowConfig(idCustomFlowConfig) {\r\n return WebMethodService.callWebMethod(endpoints.publicCustom.getCustomFlowConfig, {\r\n idCustomFlowConfig\r\n });\r\n }\r\n\r\n}\r\n\r\nexport default PublicCustomAPI;","// servizio di mapping per label\r\n\r\nconst MapperService = {\r\n getPostEventDefaultMessage: function (actionCode) {\r\n switch (actionCode) {\r\n case 'PostSubscription_SubscriptionRequestCompleted':\r\n return 'Load.PostEventDefaultPage.PostSubscription_SubscriptionRequestCompletedDefaultMessage'\r\n case 'PostSubscription_SubscriptionCompleted':\r\n return 'Load.PostEventDefaultPage.PostSubscription_SubscriptionCompletedDefaultMessage'\r\n case 'PostSubscription_UnableToSendSubscriptionConfirmationRequestMessage':\r\n return 'Load.PostEventDefaultPage.PostSubscription_UnableToSendSubscriptionConfirmationRequestMessageDefaultMessage'\r\n case 'PostSubscription_RecipientAlreadySubscribed':\r\n return 'Load.PostEventDefaultPage.PostSubscription_RecipientAlreadySubscribedDefaultMessage'\r\n case 'PostSubscription_GenericError':\r\n return 'Load.PostEventDefaultPage.PostSubscription_GenericErrorDefaultMessage'\r\n case 'PostSubscription_RecipientDoesNotExist':\r\n return 'Load.PostEventDefaultPage.PostSubscription_RecipientDoesNotExistDefaultMessage'\r\n case 'PostSubscription_RecipientInactive':\r\n return 'Load.PostEventDefaultPage.PostSubscription_RecipientInactiveDefaultMessage'\r\n case 'PostUnsubscription_RecipientAlreadyUnsubscribed':\r\n return 'Load.PostEventDefaultPage.PostUnsubscription_RecipientAlreadyUnsubscribedDefaultMessage'\r\n case 'PostUnsubscription_UnsubscriptionCompleted':\r\n return 'Load.PostEventDefaultPage.PostUnsubscription_UnsubscriptionCompletedDefaultMessage'\r\n case 'PostUnsubscription_UpdateOK':\r\n return 'Load.PostEventDefaultPage.PostUnsubscription_UpdateOKDefaultMessage'\r\n case 'PostUnsubscription_RecipientDoesNotExist':\r\n return 'Load.PostEventDefaultPage.PostUnsubscription_RecipientDoesNotExistDefaultMessage'\r\n case 'PostUnsubscription_GenericError':\r\n return 'Load.PostEventDefaultPage.PostUnsubscription_GenericErrorDefaultMessage'\r\n case 'PostProfiling_ChangesSaved':\r\n return 'Load.PostEventDefaultPage.PostProfiling_ChangesSavedDefaultMessage'\r\n case 'PostProfiling_ConfirmSubscription':\r\n return 'Load.PostEventDefaultPage.PostProfiling_ConfirmSubscriptionDefaultMessage'\r\n case 'PostProfiling_Unsubscribed':\r\n return 'Load.PostEventDefaultPage.PostProfiling_UnsubscribedDefaultMessage'\r\n case 'PostProfiling_PrivateFormAccessEmailSent':\r\n return 'Load.PostEventDefaultPage.PostProfiling_PrivateFormAccessEmailSentDefaultMessage'\r\n case 'PostProfiling_RecipientDoesNotExist':\r\n return 'Load.PostEventDefaultPage.PostProfiling_RecipientDoesNotExistDefaultMessage'\r\n case 'PostProfiling_UpdateFailed':\r\n return 'Load.PostEventDefaultPage.PostProfiling_UpdateFailedDefaultMessage'\r\n case 'PostProfiling_FormNotActive':\r\n return 'Load.PostEventDefaultPage.PostProfiling_FormNotActiveDefaultMessage'\r\n case 'PostProfiling_FormAlreadyFilledOut':\r\n return 'Load.PostEventDefaultPage.PostProfiling_FormAlreadyFilledOutDefaultMessage'\r\n default:\r\n return ''\r\n }\r\n }\r\n\r\n}\r\n\r\nexport default MapperService\r\n","//\r\n\r\n\r\nfunction deepGetSet(obj, path, value) {\r\n if (arguments.length === 3) return deepSet.apply(null, arguments);\r\n return deepGet.apply(null, arguments);\r\n}\r\n\r\nfunction deepGet(obj, path) {\r\n const keys = Array.isArray(path) ? path : path.split('.');\r\n for (let i = 0; i < keys.length; i++) {\r\n const key = keys[i];\r\n if (!obj || !obj.hasOwnProperty(key)) {\r\n obj = undefined;\r\n break;\r\n }\r\n obj = obj[key];\r\n }\r\n return obj;\r\n}\r\n\r\nfunction deepSet(obj, path, value) {\r\n const keys = Array.isArray(path) ? path : path.split('.');\r\n let i = 0;\r\n for (; i < keys.length - 1; i++) {\r\n const key = keys[i];\r\n if (!obj.hasOwnProperty(key)) obj[key] = {};\r\n obj = obj[key];\r\n }\r\n obj[keys[i]] = value;\r\n return value;\r\n}\r\n\r\nexport default deepGetSet;","//\r\n\r\nclass FrontendException {\r\n constructor(label) {\r\n this.label = label;\r\n }\r\n}\r\n\r\nexport default FrontendException;","import { useEffect, useRef } from 'react'\r\n\r\nconst useResizeObserver = (element, onResize) => {\r\n const handleResize = entries => {\r\n if (Array.isArray(entries) && entries.length > 0) {\r\n const { width, height } = entries[0].contentRect\r\n\r\n typeof onResize === 'function' && onResize({ width, height })\r\n }\r\n }\r\n const { current: observer } = useRef(new ResizeObserver(handleResize))\r\n\r\n useEffect(() => {\r\n element && observer.observe(element)\r\n\r\n return () => {\r\n element && observer.unobserve(element)\r\n }\r\n }, [element])\r\n\r\n useEffect(() => {\r\n return () => {\r\n observer.disconnect()\r\n }\r\n }, [])\r\n}\r\n\r\nexport default useResizeObserver\r\n","\r\nconst notifyParent = (action, data, { parent, document } = window) => {\r\n if (process.env.NODE_ENV !== 'production') {\r\n console.log(\r\n `%cnotifyParent`,\r\n 'color: purple; font-weight:bold',\r\n action,\r\n data\r\n )\r\n }\r\n\r\n parent && parent.postMessage({ action, data }, getTargetOrigin(document))\r\n}\r\n\r\nconst getTargetOrigin = ({ location } = document) => {\r\n let origin = ''\r\n try {\r\n origin = location.ancestorOrigins[0]\r\n } catch (err) {\r\n origin = '*'\r\n }\r\n return origin !== undefined ? origin : '*'\r\n}\r\n\r\nexport default notifyParent\r\n","import React from 'react'\r\nimport useResizeObserver from \"../hooks/useResizeObserver\";\r\nimport notifyParent from \"../helpers/notifyParent\";\r\n\r\nconst withResizeObserver = (Component, pageName) => props => {\r\n const notifyResize = payload => {\r\n notifyParent('pageResize', [pageName, payload])\r\n }\r\n\r\n useResizeObserver(document.querySelector('body'), notifyResize)\r\n\r\n return \r\n}\r\n\r\nexport default withResizeObserver","//\r\nimport parse from 'html-react-parser';\r\nimport { PropTypes } from 'prop-types';\r\nimport queryString from 'query-string';\r\nimport React from 'react';\r\n\r\nimport { FormattedMessage, injectIntl, } from 'react-intl';\r\n\r\nimport htmlParserTransform from '../../helpers/htmlParserTransform';\r\n\r\nimport BodyStyle from '../common/BodyStyle';\r\nimport Redirect from '../common/Redirect';\r\nimport NewsletterList from '../common/newsletter/NewsletterList';\r\nimport Notification from '../common/notification/Notification';\r\nimport LegacyTheme from '../common/personalization/LegacyTheme';\r\nimport Personalization from '../common/personalization/Personalization';\r\nimport LoadingSpinner from '../common/spinner/LoadingSpinner';\r\n\r\nimport MsgAPI from '../../api/msg/MsgAPI';\r\nimport PublicCustomAPI from '../../api/publiccustom/PublicCustomAPI';\r\n\r\nimport MapperService from '../../services/MapperService';\r\n\r\nimport deepGetSet from '../../api/deepGetSet';\r\nimport FrontendException from '../../models/FrontendException';\r\n\r\nimport withResizeObserver from '../../hoc/withResizeObserver';\r\n\r\nconst escapeRegExp = (string) => {\r\n return string.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\"); // $& means the whole matched string\r\n};\r\n\r\nclass AutoprofileMsg extends React.Component {\r\n constructor() {\r\n super();\r\n //\r\n this.mounted = false;\r\n this.notificationRef = React.createRef();\r\n //\r\n this.actionSettings = {};\r\n this.textSettings = {};\r\n //\r\n this.msgSettings = {\r\n Content: '',\r\n RedirectURL: ''\r\n };\r\n this.listGUID = '';\r\n this.clientIP = '';\r\n this.subscriberData = {};\r\n this.newsletters = [];\r\n this.showNewsletterList = false;\r\n this.emailForPreview = 'test@test.com';\r\n this.styles = ['default', 'blue', 'dark', 'gray', 'green'];\r\n this.customClass = ''; // Default\r\n this.flowConfig = {\r\n UseCustomPages: false,\r\n CustomPages: {}\r\n };\r\n //\r\n this.state = {\r\n loading: false,\r\n showMainContent: false\r\n };\r\n }\r\n\r\n componentDidMount() {\r\n this.mounted = true;\r\n const params = this.props.match.params;\r\n\r\n if (!this.isUserParamsValid()) {\r\n // do not use setState directly in componentDidMount\r\n this.handleError(\"Load.Msg.ErrorUserParams\");\r\n } else {\r\n //\r\n const params = this.props.match.params;\r\n const actionCode = this.getActionCode(params.idMsg);\r\n const qsValues = queryString.parse(this.props.location.search);\r\n //\r\n Promise.all([\r\n this.getPublicCustomAction(params.idList, actionCode),\r\n this.getPublicCustomText(params.idList, actionCode),\r\n this.getPublicCustomSettings(params.idList),\r\n this.getListGUID(params.idList),\r\n this.getClientIP(),\r\n this.getSubscriberData(params.idList, params.idUser, params.hash),\r\n this.getNewsletterList(),\r\n this.getCustomFlowConfig(qsValues.cfc)\r\n ]).then(() => {\r\n if (this.flowConfig.UseCustomPages) {\r\n this.msgSettings.Content = this.flowConfig.CustomPages[actionCode].Text;\r\n } else if (deepGetSet(this.textSettings, 'Text')) {\r\n this.msgSettings.Content = this.textSettings.Text;\r\n } else {\r\n const msgLabel = MapperService.getPostEventDefaultMessage(actionCode);\r\n this.msgSettings.Content = this.props.intl.formatMessage({\r\n id: msgLabel,\r\n defaultMessage: msgLabel\r\n });\r\n }\r\n\r\n //\r\n if (this.flowConfig.UseCustomPages) {\r\n const { IdLandingPage, CustomUrl } = this.flowConfig.CustomPages[actionCode];\r\n\r\n this.actionSettings.IdLandingPage = IdLandingPage;\r\n this.actionSettings.CustomUrl = CustomUrl;\r\n }\r\n\r\n if (this.isTrue(params.preview)) {\r\n this.msgSettings.RedirectURL = '';\r\n //\r\n this.msgSettings.Content = this.replacePlaceholders(this.msgSettings.Content, {\r\n email: this.emailForPreview,\r\n IPaddress: this.clientIP\r\n }, false);\r\n } else {\r\n if (this.actionSettings.IdLandingPage) {\r\n this.msgSettings.RedirectURL = '/frontend/LandingPage.aspx?idList=' +\r\n encodeURIComponent(params.idList) + '&idLP=' + encodeURIComponent(this.actionSettings.IdLandingPage) +\r\n '&guid=' + encodeURIComponent(this.listGUID);\r\n this.msgSettings.Content = undefined;\r\n } else if (this.actionSettings.CustomUrl) {\r\n this.msgSettings.RedirectURL = this.actionSettings.CustomUrl;\r\n //\r\n this.msgSettings.RedirectURL = this.replacePlaceholders(this.msgSettings.RedirectURL, this.subscriberData, true);\r\n this.msgSettings.Content = undefined;\r\n } else {\r\n this.msgSettings.Content = this.replacePlaceholders(this.msgSettings.Content, this.subscriberData, false);\r\n }\r\n }\r\n //\r\n if (this.mounted) {\r\n this.setState({\r\n showMainContent: true\r\n });\r\n }\r\n }).catch((error) => {\r\n this.handleError(error, \"default\", true);\r\n })\r\n .finally(this.stopLoader);\r\n }\r\n }\r\n\r\n componentWillUnmount() {\r\n this.mounted = false;\r\n }\r\n\r\n isTrue(paramValue) {\r\n return ((paramValue == \"true\") || (paramValue == \"1\") || (paramValue == \"on\"));\r\n }\r\n\r\n isString(param) {\r\n return (typeof param === \"string\") || (param instanceof String);\r\n }\r\n\r\n /**\r\n * Verifica parametri idList, idMsg, email\r\n * se vuoti/nulli ritorna false\r\n */\r\n isUserParamsValid() {\r\n const params = this.props.match.params;\r\n const preview = this.isTrue(params.preview);\r\n const idUser = parseInt(params.idUser, 10);\r\n //\r\n // combinazioni accettate:\r\n // preview:1 - idUser:empty - hash:empty\r\n // preview:0 - idUser:0 - hash:_\r\n // preview:0 - idUser:valorizzato - hash:valorizzato\r\n return Boolean(params.idList && params.idMsg && ((!preview && idUser && params.hash) || (!preview && !idUser && params.hash == '_') || preview));\r\n }\r\n\r\n handleError = (error, source = \"default\", fatal = false) => {\r\n console.error(\"### AutoprofileMsg handleError\", error);\r\n let errorLabel = \"Load.Common.Error\";\r\n if (error instanceof FrontendException) {\r\n errorLabel = error.label;\r\n } else if (this.isString(error)) {\r\n errorLabel = error;\r\n }\r\n //\r\n this.notificationRef.current.addError(this.props.intl.formatMessage({\r\n id: errorLabel,\r\n defaultMessage: errorLabel\r\n }), source, false, !fatal);\r\n }\r\n\r\n getPublicCustomAction(idList, actionCode) {\r\n return PublicCustomAPI.getAction(idList, actionCode).then((actionSettings) => {\r\n this.actionSettings = actionSettings;\r\n });\r\n }\r\n\r\n getPublicCustomText(idList, actionCode) {\r\n return PublicCustomAPI.getText(idList, actionCode).then((textSettings) => {\r\n this.textSettings = textSettings;\r\n });\r\n }\r\n\r\n getPublicCustomSettings(idList) {\r\n return PublicCustomAPI.getSettings(idList).then((listSettings) => {\r\n this.showNewsletterList = listSettings.ShowPublicEmailMessagesProfilation;\r\n });\r\n }\r\n\r\n getListGUID(idList) {\r\n return PublicCustomAPI.getListGUID(idList).then((listGUID) => {\r\n this.listGUID = listGUID;\r\n });\r\n }\r\n\r\n getClientIP() {\r\n return PublicCustomAPI.getClientIP().then((clientIP) => {\r\n this.clientIP = clientIP;\r\n });\r\n }\r\n\r\n getCustomFlowConfig(idCustomFlowConfig) {\r\n return idCustomFlowConfig\r\n ? PublicCustomAPI.getCustomFlowConfig(idCustomFlowConfig).then(({\r\n UseCustomPages,\r\n CustomPages,\r\n CustomMsgs\r\n }) => {\r\n this.flowConfig = {\r\n UseCustomPages,\r\n CustomPages: CustomPages.reduce((acc, { Code, IdLandingPage, CustomUrl }) => ({\r\n ...acc,\r\n [Code]: {\r\n IdLandingPage,\r\n CustomUrl,\r\n Code,\r\n Text: (IdLandingPage === 0 && CustomUrl.length === 0)\r\n ? CustomMsgs.find(cm => cm.Code === Code).Text\r\n : ''\r\n }\r\n }), {})\r\n\r\n };\r\n })\r\n : Promise.resolve(true)\r\n ;\r\n }\r\n\r\n getSubscriberData(idList, idUser, hash) {\r\n if (!parseInt(idUser, 10)) {\r\n idUser = 0;\r\n }\r\n if (!hash || hash == '_') {\r\n hash = '';\r\n }\r\n\r\n return MsgAPI.getSubscriberData(idList, idUser, hash).then((subscriberData) => {\r\n this.subscriberData = subscriberData;\r\n //\r\n if (!idUser) {\r\n this.subscriberData.email = this.emailForPreview;\r\n }\r\n });\r\n }\r\n\r\n replacePlaceholders(content, map, uriEncode) {\r\n Object.keys(map).forEach((key) => {\r\n if (uriEncode) {\r\n content = content.replaceAll('[' + key + ']', encodeURIComponent(map[key]));\r\n } else {\r\n content = content.replaceAll('[' + key + ']', map[key]);\r\n }\r\n });\r\n return content;\r\n }\r\n\r\n getNewsletterList() {\r\n const params = this.props.match.params;\r\n return MsgAPI.getNewsletterList(params.idList).then((newsletters) => {\r\n this.newsletters = newsletters.MessagesItems;\r\n });\r\n }\r\n\r\n getActionCode(idMsg) {\r\n let result = \"\";\r\n switch (parseInt(idMsg, 10)) {\r\n case 1:\r\n result = \"PostProfiling_ChangesSaved\";\r\n break;\r\n case 2:\r\n result = \"PostProfiling_UpdateFailed\";\r\n break;\r\n\r\n case 3:\r\n case 4:\r\n result = \"PostProfiling_FormNotActive\";\r\n break;\r\n\r\n case 5:\r\n result = \"PostProfiling_FormAlreadyFilledOut\";\r\n break;\r\n\r\n case 6:\r\n result = \"PostProfiling_PrivateFormAccessEmailSent\";\r\n break;\r\n\r\n case 7:\r\n result = \"PostProfiling_Unsubscribed\";\r\n break;\r\n\r\n case 8:\r\n result = \"PostProfiling_RecipientDoesNotExist\";\r\n break;\r\n\r\n case 9:\r\n result = \"PostProfiling_ConfirmSubscription\";\r\n break;\r\n }\r\n return result;\r\n }\r\n\r\n startLoader = () => {\r\n if (this.mounted) {\r\n this.setState({\r\n loading: true\r\n });\r\n }\r\n }\r\n\r\n stopLoader = () => {\r\n if (this.mounted) {\r\n this.setState({\r\n loading: false\r\n });\r\n }\r\n }\r\n\r\n render() {\r\n const isEmbedded = this.isTrue(this.props.match.params.emb);\r\n const applyCustomCSS = (this.props.match.params.style == 'custom');\r\n //\r\n if (this.styles.indexOf(this.props.match.params.style) != -1) {\r\n this.customClass = this.props.match.params.style;\r\n }\r\n //\r\n return (\r\n
    \r\n \r\n {this.customClass &&\r\n \r\n }\r\n \r\n {this.state.loading && }\r\n\r\n {this.state.showMainContent && isEmbedded &&\r\n \r\n \r\n\r\n {this.msgSettings.Content &&\r\n

    {parse(this.msgSettings.Content, { replace: htmlParserTransform })}

    \r\n }\r\n\r\n {this.msgSettings.RedirectURL &&\r\n \r\n }\r\n
    \r\n }\r\n\r\n {this.state.showMainContent && !isEmbedded &&\r\n \r\n {this.msgSettings.RedirectURL &&\r\n \r\n }\r\n\r\n {this.msgSettings.Content &&\r\n
    \r\n \r\n
    \r\n
    {parse(this.msgSettings.Content, { replace: htmlParserTransform })}
    \r\n
    \r\n\r\n {this.newsletters.length > 0 && this.showNewsletterList && !this.msgSettings.RedirectURL &&\r\n
    \r\n

    \r\n \r\n
    \r\n }\r\n
    \r\n }\r\n
    \r\n }\r\n
    \r\n );\r\n }\r\n}\r\n\r\nAutoprofileMsg.propTypes = {\r\n match: PropTypes.shape({\r\n params: PropTypes.shape({\r\n preview: PropTypes.string.isRequired,\r\n idList: PropTypes.string,\r\n idMsg: PropTypes.string,\r\n style: PropTypes.string,\r\n idUser: PropTypes.string,\r\n hash: PropTypes.string,\r\n emb: PropTypes.string\r\n })\r\n }),\r\n\r\n location: PropTypes.object\r\n};\r\n\r\nexport default withResizeObserver(injectIntl(AutoprofileMsg), 'AutoprofileMsg');","//\r\nimport { PropTypes } from 'prop-types';\r\nimport React from 'react';\r\nimport { FormattedMessage, injectIntl } from 'react-intl';\r\n\r\nimport parse from 'html-react-parser';\r\n\r\n\r\nimport htmlParserTransform from '../../helpers/htmlParserTransform';\r\n\r\nimport Redirect from '../common/Redirect';\r\nimport Notification from '../common/notification/Notification';\r\nimport Personalization from '../common/personalization/Personalization';\r\nimport LoadingSpinner from '../common/spinner/LoadingSpinner';\r\n\r\nimport MsgAPI from '../../api/msg/MsgAPI';\r\nimport PersonalizationAPI from '../../api/personalization/PersonalizationAPI';\r\n\r\nimport FrontendException from '../../models/FrontendException';\r\n\r\nimport withResizeObserver from '../../hoc/withResizeObserver';\r\n\r\nclass ConfirmOptoutMsg extends React.Component {\r\n constructor() {\r\n super();\r\n //\r\n this.mounted = false;\r\n this.notificationRef = React.createRef();\r\n this.subscribed = false;\r\n this.email = '';\r\n this.description = \"\";\r\n this.btnText = \"\";\r\n\r\n //\r\n this.state = {\r\n loading: false,\r\n showMainContent: false\r\n };\r\n }\r\n\r\n componentDidMount() {\r\n this.mounted = true;\r\n const params = this.props.match.params;\r\n //\r\n if (!this.isUserParamsValid()) {\r\n // do not use setState directly in componentDidMount\r\n this.handleError(\"Load.Msg.ErrorUserParams\");\r\n } else {\r\n Promise.all([\r\n this.getSubscriberEmail(),\r\n this.isOptin(),\r\n this.getListSettings()\r\n ]).then(() => {\r\n if (this.mounted) {\r\n this.setState({\r\n showMainContent: true\r\n });\r\n }\r\n }).catch((error) => {\r\n this.handleError(error, \"default\", true);\r\n })\r\n .finally(this.stopLoader);\r\n }\r\n }\r\n\r\n componentWillUnmount() {\r\n this.mounted = false;\r\n }\r\n\r\n isTrue(paramValue) {\r\n return ((paramValue == \"true\") || (paramValue == \"1\") || (paramValue == \"on\"));\r\n }\r\n\r\n isString(param) {\r\n return (typeof param === \"string\") || (param instanceof String);\r\n }\r\n\r\n /**\r\n * Verifica parametri idList, idUser, hash, idNL\r\n * se vuoti/nulli ritorna false\r\n */\r\n isUserParamsValid() {\r\n const params = this.props.match.params;\r\n const preview = this.isTrue(params.preview);\r\n const idUser = parseInt(params.idUser, 10);\r\n const idNL = parseInt(params.idNL, 10);\r\n //\r\n // combinazioni accettate:\r\n // preview:1 - idUser:empty - hash:empty - idNL:empty\r\n // preview:0 - idUser:valorizzato - hash:valorizzato - idNL:valorizzato\r\n return Boolean(params.idList && ((!preview && idUser && params.hash && idNL) || preview));\r\n }\r\n\r\n handleError = (error, source = \"default\", fatal = false) => {\r\n // console.log(\"PreferenceCenter handleError\", error);\r\n let errorLabel = \"Load.Common.Error\";\r\n if (error instanceof FrontendException) {\r\n errorLabel = error.label;\r\n } else if (this.isString(error)) {\r\n errorLabel = error;\r\n }\r\n //\r\n this.notificationRef.current.addError(this.props.intl.formatMessage({ id: errorLabel, defaultMessage: errorLabel }), source, false, !fatal);\r\n }\r\n\r\n startLoader = () => {\r\n if (this.mounted) {\r\n this.setState({\r\n loading: true\r\n });\r\n }\r\n }\r\n\r\n stopLoader = () => {\r\n if (this.mounted) {\r\n this.setState({\r\n loading: false\r\n });\r\n }\r\n }\r\n\r\n getSubscriberEmail() {\r\n const params = this.props.match.params;\r\n let idUser = parseInt(params.idUser, 10);\r\n if (!idUser) {\r\n idUser = 0;\r\n }\r\n let hash = params.hash;\r\n if (!hash) {\r\n hash = '';\r\n }\r\n return MsgAPI.getSubscriberEmail(idUser, hash).then((email) => {\r\n this.email = email;\r\n });\r\n }\r\n\r\n getListSettings() {\r\n const params = this.props.match.params;\r\n return PersonalizationAPI.getListSettings(parseInt(params.idList)).then((resp) => {\r\n const obj = JSON.parse(resp.Style);\r\n\r\n if (obj.Message && obj.Message.BtnText) {\r\n this.btnText = obj.Message.BtnText;\r\n }\r\n\r\n if (obj.Message && obj.Message.Text) {\r\n this.description = obj.Message.Text;\r\n }\r\n });\r\n }\r\n\r\n isOptin() {\r\n const params = this.props.match.params;\r\n let idUser = parseInt(params.idUser, 10);\r\n if (!idUser) {\r\n idUser = 0;\r\n }\r\n let hash = params.hash;\r\n if (!hash) {\r\n hash = '';\r\n }\r\n return MsgAPI.isOptin(params.idList, idUser, hash).then((isOptin) => {\r\n this.subscribed = isOptin;\r\n });\r\n }\r\n\r\n render() {\r\n //\r\n const params = this.props.match.params;\r\n let optoutUrl = \"#\";\r\n const preview = this.isTrue(params.preview);\r\n if (!preview) {\r\n optoutUrl = \"/frontend/doubleoptout.aspx?id=\" + encodeURIComponent(params.idUser) + \"&idList=\" + encodeURIComponent(params.idList) + \"&idNL=\" + encodeURIComponent(params.idNL) + \"&HASH=\" + encodeURIComponent(params.hash);\r\n }\r\n //\r\n let unsubscribedMsgUrl = '';\r\n if (this.email) {\r\n unsubscribedMsgUrl = '/frontend/unsubscriptionmsg/0/' + encodeURIComponent(params.idList) + '/11/?email=' + encodeURIComponent(this.email);\r\n } else {\r\n unsubscribedMsgUrl = '/frontend/unsubscriptionmsg/0/' + encodeURIComponent(params.idList) + '/20/?email=' + encodeURIComponent(this.email);\r\n }\r\n //\r\n\r\n const wrapperClassName = preview ? 'frontend-wrapper frontend-wrapper--preview' : 'frontend-wrapper';\r\n\r\n return (\r\n
    \r\n \r\n {this.state.loading && }\r\n\r\n {this.state.showMainContent &&\r\n \r\n {!preview && !this.subscribed &&\r\n \r\n }\r\n\r\n {(preview || this.subscribed) &&\r\n
    \r\n \r\n
    \r\n\r\n
    \r\n

    \r\n {this.description\r\n ? parse(this.description, { replace: htmlParserTransform })\r\n : }\r\n

    \r\n
    \r\n\r\n
    \r\n
    \r\n \r\n \r\n \r\n \r\n\r\n \r\n
    \r\n
    \r\n\r\n
    \r\n
    \r\n }\r\n
    \r\n }\r\n
    \r\n );\r\n }\r\n}\r\n\r\nConfirmOptoutMsg.propTypes = {\r\n match: PropTypes.shape({\r\n params: PropTypes.shape({\r\n preview: PropTypes.string.isRequired,\r\n idList: PropTypes.string.isRequired,\r\n idUser: PropTypes.string,\r\n hash: PropTypes.string,\r\n idNL: PropTypes.string\r\n })\r\n }),\r\n\r\n};\r\n\r\nexport default withResizeObserver(injectIntl(ConfirmOptoutMsg), 'ConfirmOptoutMsg');","//\r\nimport React from 'react';\r\nimport { injectIntl } from 'react-intl';\r\n\r\nimport Notification from '../../components/common/notification/Notification';\r\nimport LoadingSpinner from '../common/spinner/LoadingSpinner';\r\n\r\nimport MsgAPI from '../../api/msg/MsgAPI';\r\n\r\nimport FrontendException from '../../models/FrontendException';\r\n\r\nclass ListDeletedMsg extends React.Component {\r\n constructor() {\r\n super();\r\n //\r\n this.mounted = false;\r\n this.notificationRef = React.createRef();\r\n this.defaultListValues = { 'optout_title': '' };\r\n //\r\n this.state = {\r\n loading: false,\r\n showMainContent: false\r\n };\r\n\r\n }\r\n\r\n componentDidMount() {\r\n this.mounted = true;\r\n //\r\n this.startLoader();\r\n //\r\n this.getDefaultListValues().then(() => {\r\n if (this.mounted) {\r\n this.setState({\r\n showMainContent: true\r\n });\r\n }\r\n }).catch((error) => {\r\n this.handleError(error, \"default\", true);\r\n })\r\n .finally(this.stopLoader);\r\n\r\n\r\n }\r\n\r\n\r\n\r\n componentWillUnmount() {\r\n this.mounted = false;\r\n }\r\n\r\n handleError = (error, source = \"default\", fatal = false) => {\r\n let errorLabel = \"Load.Common.Error\";\r\n if (error instanceof FrontendException) {\r\n errorLabel = error.label;\r\n } else if (this.isString(error)) {\r\n errorLabel = error;\r\n }\r\n //\r\n this.notificationRef.current.addError(this.props.intl.formatMessage({ id: errorLabel, defaultMessage: errorLabel }), source, false, !fatal);\r\n }\r\n\r\n getDefaultListValues() {\r\n return MsgAPI.getDefaultListValues().then((defaultListValues) => {\r\n this.defaultListValues = defaultListValues;\r\n });\r\n }\r\n\r\n isString(param) {\r\n return (typeof param === \"string\") || (param instanceof String);\r\n }\r\n\r\n startLoader = () => {\r\n if (this.mounted) {\r\n this.setState({\r\n loading: true\r\n });\r\n }\r\n }\r\n\r\n stopLoader = () => {\r\n if (this.mounted) {\r\n this.setState({\r\n loading: false\r\n });\r\n }\r\n }\r\n\r\n render() {\r\n return (\r\n
    \r\n \r\n {this.state.loading && }\r\n\r\n {this.state.showMainContent &&\r\n
    \r\n
    \r\n {this.defaultListValues.optout_title}\r\n
    \r\n
    \r\n }\r\n\r\n
    \r\n );\r\n }\r\n\r\n}\r\n\r\n\r\nexport default injectIntl(ListDeletedMsg);","// Componente di visualizzazione messaggio in seguito a iscrizione o disiscrizione\r\nimport parse from 'html-react-parser';\r\nimport { PropTypes } from 'prop-types';\r\nimport React from 'react';\r\nimport { FormattedMessage, injectIntl, } from 'react-intl';\r\n\r\nimport queryString from 'query-string';\r\n\r\nimport htmlParserTransform from '../../helpers/htmlParserTransform';\r\n\r\nimport BodyStyle from '../common/BodyStyle';\r\nimport Redirect from '../common/Redirect';\r\nimport NewsletterList from '../common/newsletter/NewsletterList';\r\nimport Notification from '../common/notification/Notification';\r\nimport LegacyTheme from '../common/personalization/LegacyTheme';\r\nimport Personalization from '../common/personalization/Personalization';\r\nimport LoadingSpinner from '../common/spinner/LoadingSpinner';\r\n\r\nimport MsgAPI from '../../api/msg/MsgAPI';\r\nimport PublicCustomAPI from '../../api/publiccustom/PublicCustomAPI';\r\n\r\nimport MapperService from '../../services/MapperService';\r\n\r\nimport deepGetSet from '../../api/deepGetSet';\r\nimport FrontendException from '../../models/FrontendException';\r\n\r\nimport withResizeObserver from '../../hoc/withResizeObserver';\r\nclass SubscriptionMsg extends React.Component {\r\n constructor() {\r\n super();\r\n //\r\n this.mounted = false;\r\n this.notificationRef = React.createRef();\r\n //\r\n this.actionSettings = {};\r\n this.textSettings = {};\r\n //\r\n this.msgSettings = {\r\n Content: '',\r\n RedirectURL: ''\r\n };\r\n this.listGUID = '';\r\n this.clientIP = '';\r\n this.newsletters = [];\r\n this.showNewsletterList = false;\r\n this.emailForPreview = 'test@test.com';\r\n this.styles = ['default', 'blue', 'dark', 'gray', 'green'];\r\n this.customClass = ''; // Default\r\n this.flowConfig = {\r\n UseCustomMsgs: false,\r\n CustomMsgs: {},\r\n UseCustomPages: false,\r\n CustomPages: {}\r\n };\r\n //\r\n this.state = {\r\n loading: false,\r\n showMainContent: false\r\n };\r\n }\r\n\r\n componentDidMount() {\r\n this.mounted = true;\r\n\r\n if (!this.isUserParamsValid()) {\r\n // do not use setState directly in componentDidMount\r\n this.handleError(\"Load.Msg.ErrorUserParams\");\r\n } else {\r\n //\r\n const params = this.props.match.params;\r\n\r\n const actionCode = this.getActionCode(params.idMsg);\r\n const qsValues = queryString.parse(this.props.location.search);\r\n //\r\n Promise.all([\r\n this.getPublicCustomAction(params.idList, actionCode),\r\n this.getPublicCustomText(params.idList, actionCode),\r\n this.getPublicCustomSettings(params.idList),\r\n this.getListGUID(params.idList),\r\n this.getClientIP(),\r\n this.getNewsletterList(params.idList),\r\n this.getCustomFlowConfig(qsValues.cfc)\r\n ]).then(() => {\r\n if (this.flowConfig.UseCustomMsgs) {\r\n this.msgSettings.Content = this.flowConfig.CustomMsgs[actionCode];\r\n } else if (deepGetSet(this.textSettings, 'Text')) {\r\n this.msgSettings.Content = this.textSettings.Text;\r\n } else {\r\n const msgLabel = MapperService.getPostEventDefaultMessage(actionCode);\r\n\r\n this.msgSettings.Content = this.props.intl.formatMessage({\r\n id: msgLabel,\r\n defaultMessage: msgLabel\r\n });\r\n }\r\n //\r\n if (this.flowConfig.UseCustomPages) {\r\n const { IdLandingPage, CustomUrl } = this.flowConfig.CustomPages[actionCode];\r\n\r\n this.actionSettings.IdLandingPage = IdLandingPage;\r\n this.actionSettings.CustomUrl = CustomUrl;\r\n }\r\n\r\n //\r\n if (this.isTrue(params.preview)) {\r\n this.msgSettings.RedirectURL = '';\r\n //\r\n this.msgSettings.Content = this.replacePlaceholders(this.msgSettings.Content, {\r\n email: this.emailForPreview,\r\n IPaddress: this.clientIP\r\n }, false);\r\n } else {\r\n if (this.actionSettings.IdLandingPage) {\r\n this.msgSettings.RedirectURL = '/frontend/LandingPage.aspx?idList=' +\r\n encodeURIComponent(params.idList) + '&idLP=' + encodeURIComponent(this.actionSettings.IdLandingPage) +\r\n '&guid=' + encodeURIComponent(this.listGUID);\r\n this.msgSettings.Content = undefined;\r\n } else if (this.actionSettings.CustomUrl) {\r\n this.msgSettings.RedirectURL = this.actionSettings.CustomUrl;\r\n //\r\n this.msgSettings.RedirectURL = this.replacePlaceholders(this.msgSettings.RedirectURL, {\r\n email: qsValues.email,\r\n IPaddress: this.clientIP\r\n }, true);\r\n this.msgSettings.Content = undefined;\r\n } else {\r\n this.msgSettings.Content = this.replacePlaceholders(this.msgSettings.Content, {\r\n email: qsValues.email,\r\n IPaddress: this.clientIP\r\n }, false);\r\n }\r\n }\r\n //\r\n if (this.mounted) {\r\n this.setState({\r\n showMainContent: true\r\n });\r\n }\r\n }).catch((error) => {\r\n this.handleError(error, \"default\", true);\r\n })\r\n .finally(this.stopLoader);\r\n }\r\n }\r\n\r\n componentWillUnmount() {\r\n this.mounted = false;\r\n }\r\n\r\n isTrue(paramValue) {\r\n return ((paramValue == \"true\") || (paramValue == \"1\") || (paramValue == \"on\"));\r\n }\r\n\r\n isString(param) {\r\n return (typeof param === \"string\") || (param instanceof String);\r\n }\r\n\r\n /**\r\n * Verifica parametri idList, idMsg, email\r\n * se vuoti/nulli ritorna false\r\n */\r\n isUserParamsValid() {\r\n const params = this.props.match.params;\r\n //\r\n return Boolean(params.idList && params.idMsg);\r\n }\r\n\r\n handleError = (error, source = \"default\", fatal = false) => {\r\n console.error('### error', error);\r\n let errorLabel = \"Load.Common.Error\";\r\n if (error instanceof FrontendException) {\r\n errorLabel = error.label;\r\n } else if (this.isString(error)) {\r\n errorLabel = error;\r\n }\r\n //\r\n this.notificationRef.current.addError(this.props.intl.formatMessage({ id: errorLabel, defaultMessage: errorLabel }), source, false, !fatal);\r\n }\r\n\r\n getPublicCustomAction(idList, actionCode) {\r\n return PublicCustomAPI.getAction(idList, actionCode).then((actionSettings) => {\r\n this.actionSettings = actionSettings;\r\n });\r\n }\r\n\r\n getPublicCustomText(idList, actionCode) {\r\n return PublicCustomAPI.getText(idList, actionCode).then((textSettings) => {\r\n this.textSettings = textSettings;\r\n });\r\n }\r\n\r\n getPublicCustomSettings(idList) {\r\n return PublicCustomAPI.getSettings(idList).then((listSettings) => {\r\n this.showNewsletterList = listSettings.ShowPublicEmailMessagesSubscription;\r\n });\r\n }\r\n\r\n getListGUID(idList) {\r\n return PublicCustomAPI.getListGUID(idList).then((listGUID) => {\r\n this.listGUID = listGUID;\r\n });\r\n }\r\n\r\n getClientIP() {\r\n return PublicCustomAPI.getClientIP().then((clientIP) => {\r\n this.clientIP = clientIP;\r\n });\r\n }\r\n\r\n getCustomFlowConfig(idCustomFlowConfig) {\r\n return idCustomFlowConfig\r\n ? PublicCustomAPI.getCustomFlowConfig(idCustomFlowConfig).then(({\r\n UseCustomMsgs,\r\n CustomMsgs,\r\n UseCustomPages,\r\n CustomPages\r\n }) => {\r\n this.flowConfig = {\r\n UseCustomMsgs,\r\n CustomMsgs: CustomMsgs.reduce((acc, { Code, Text }) => ({\r\n ...acc,\r\n [Code]: Text\r\n }), {}),\r\n UseCustomPages,\r\n CustomPages: CustomPages.reduce((acc, { Code, IdLandingPage, CustomUrl }) => ({\r\n ...acc,\r\n [Code]: { IdLandingPage, CustomUrl }\r\n }), {})\r\n\r\n };\r\n })\r\n : Promise.resolve(true)\r\n ;\r\n }\r\n\r\n replacePlaceholders(content, map, uriEncode) {\r\n Object.keys(map).forEach((key) => {\r\n if (uriEncode) {\r\n content = content.replaceAll('[' + key + ']', encodeURIComponent(map[key]));\r\n } else {\r\n content = content.replaceAll('[' + key + ']', map[key]);\r\n }\r\n });\r\n return content;\r\n }\r\n\r\n getNewsletterList(idList) {\r\n return MsgAPI.getNewsletterList(idList).then((newsletters) => {\r\n this.newsletters = newsletters.MessagesItems;\r\n });\r\n }\r\n\r\n getActionCode(idMsg) {\r\n let result = \"\";\r\n switch (parseInt(idMsg, 10)) {\r\n case 4:\r\n case 1:\r\n result = \"PostSubscription_GenericError\";\r\n break;\r\n\r\n case 2:\r\n result = \"PostSubscription_SubscriptionRequestCompleted\";\r\n break;\r\n\r\n case 3:\r\n case 6:\r\n result = \"PostSubscription_SubscriptionCompleted\";\r\n break;\r\n\r\n case 5:\r\n case 40:\r\n result = \"PostSubscription_RecipientAlreadySubscribed\";\r\n break;\r\n\r\n case 12:\r\n result = \"PostSubscription_RecipientInactive\";\r\n break;\r\n\r\n case 20:\r\n result = \"PostSubscription_RecipientDoesNotExist\";\r\n break;\r\n\r\n case 30:\r\n result = \"PostSubscription_UnableToSendSubscriptionConfirmationRequestMessage\";\r\n break;\r\n }\r\n return result;\r\n }\r\n\r\n startLoader = () => {\r\n if (this.mounted) {\r\n this.setState({\r\n loading: true\r\n });\r\n }\r\n }\r\n\r\n stopLoader = () => {\r\n if (this.mounted) {\r\n this.setState({\r\n loading: false\r\n });\r\n }\r\n }\r\n\r\n render() {\r\n if (this.styles.indexOf(this.props.match.params.style) != -1) {\r\n this.customClass = this.props.match.params.style;\r\n }\r\n const applyCustomCSS = (this.props.match.params.style == 'custom');\r\n //\r\n return (\r\n
    \r\n \r\n {this.customClass &&\r\n \r\n }\r\n \r\n {this.state.loading && }\r\n\r\n {this.state.showMainContent &&\r\n \r\n {this.msgSettings.RedirectURL &&\r\n \r\n }\r\n\r\n {this.msgSettings.Content &&\r\n
    \r\n \r\n\r\n
    \r\n
    {parse(this.msgSettings.Content, { replace: htmlParserTransform })}
    \r\n
    \r\n\r\n {this.newsletters.length > 0 && this.showNewsletterList && !this.msgSettings.RedirectURL &&\r\n
    \r\n

    \r\n \r\n
    \r\n }\r\n
    \r\n }\r\n
    \r\n }\r\n
    \r\n );\r\n }\r\n}\r\n\r\nSubscriptionMsg.propTypes = {\r\n match: PropTypes.shape({\r\n params: PropTypes.shape({\r\n preview: PropTypes.string.isRequired,\r\n idList: PropTypes.string.isRequired,\r\n idMsg: PropTypes.string.isRequired,\r\n email: PropTypes.string,\r\n style: PropTypes.string\r\n })\r\n }),\r\n location: PropTypes.object,\r\n\r\n};\r\n\r\nexport default withResizeObserver(injectIntl(SubscriptionMsg), 'SubscriptionMsg');","// Componente di visualizzazione messaggio in seguito a iscrizione o disiscrizione\r\nimport parse from 'html-react-parser';\r\nimport { PropTypes } from 'prop-types';\r\nimport React from 'react';\r\nimport { injectIntl } from 'react-intl';\r\n\r\nimport queryString from 'query-string';\r\n\r\nimport htmlParserTransform from '../../helpers/htmlParserTransform';\r\n\r\nimport Redirect from '../common/Redirect';\r\nimport Notification from '../common/notification/Notification';\r\nimport Personalization from '../common/personalization/Personalization';\r\nimport LoadingSpinner from '../common/spinner/LoadingSpinner';\r\n\r\nimport PublicCustomAPI from '../../api/publiccustom/PublicCustomAPI';\r\n\r\nimport MapperService from '../../services/MapperService';\r\n\r\nimport deepGetSet from '../../api/deepGetSet';\r\nimport FrontendException from '../../models/FrontendException';\r\n\r\nimport withResizeObserver from '../../hoc/withResizeObserver';\r\n\r\nclass UnsubscriptionMsg extends React.Component {\r\n constructor() {\r\n super();\r\n //\r\n this.mounted = false;\r\n this.notificationRef = React.createRef();\r\n //\r\n this.actionSettings = {};\r\n this.textSettings = {};\r\n //\r\n this.msgSettings = {\r\n Content: '',\r\n RedirectURL: ''\r\n };\r\n this.listGUID = '';\r\n this.clientIP = '';\r\n this.emailForPreview = 'test@test.com';\r\n //\r\n this.state = {\r\n loading: false,\r\n showMainContent: false\r\n };\r\n }\r\n\r\n componentDidMount() {\r\n this.mounted = true;\r\n\r\n if (!this.isUserParamsValid()) {\r\n // do not use setState directly in componentDidMount\r\n this.handleError(\"Load.Msg.ErrorUserParams\");\r\n } else {\r\n //\r\n const params = this.props.match.params;\r\n const actionCode = this.getActionCode(params.idMsg);\r\n const qsValues = queryString.parse(this.props.location.search);\r\n //\r\n Promise.all([\r\n this.getPublicCustomAction(params.idList, actionCode, qsValues.email, this.isTrue(params.preview)),\r\n this.getPublicCustomText(params.idList, actionCode),\r\n this.getListGUID(params.idList),\r\n this.getClientIP()\r\n ]).then(() => {\r\n if (deepGetSet(this.textSettings, 'Text')) {\r\n this.msgSettings.Content = this.textSettings.Text;\r\n } else {\r\n const msgLabel = MapperService.getPostEventDefaultMessage(actionCode);\r\n this.msgSettings.Content = this.props.intl.formatMessage({\r\n id: msgLabel,\r\n defaultMessage: msgLabel\r\n });\r\n }\r\n //\r\n if (this.isTrue(params.preview)) {\r\n this.msgSettings.RedirectURL = '';\r\n //\r\n this.msgSettings.Content = this.replacePlaceholders(this.msgSettings.Content, {\r\n email: this.emailForPreview,\r\n IPaddress: this.clientIP\r\n }, false);\r\n } else {\r\n if (this.actionSettings.IdLandingPage) {\r\n this.msgSettings.RedirectURL = '/frontend/LandingPage.aspx?idList=' +\r\n encodeURIComponent(params.idList) + '&idLP=' + encodeURIComponent(this.actionSettings.IdLandingPage) +\r\n '&guid=' + encodeURIComponent(this.listGUID);\r\n this.msgSettings.Content = undefined;\r\n } else if (this.actionSettings.CustomUrl) {\r\n this.msgSettings.RedirectURL = this.actionSettings.CustomUrl;\r\n //\r\n this.msgSettings.RedirectURL = this.replacePlaceholders(this.msgSettings.RedirectURL, {\r\n email: qsValues.email,\r\n IPaddress: this.clientIP\r\n }, true);\r\n this.msgSettings.Content = undefined;\r\n } else {\r\n this.msgSettings.Content = this.replacePlaceholders(this.msgSettings.Content, {\r\n email: qsValues.email,\r\n IPaddress: this.clientIP\r\n }, false);\r\n }\r\n }\r\n //\r\n if (this.mounted) {\r\n this.setState({\r\n showMainContent: true\r\n });\r\n }\r\n }).catch((error) => {\r\n this.handleError(error, \"default\", true);\r\n })\r\n .finally(this.stopLoader);\r\n }\r\n }\r\n\r\n componentWillUnmount() {\r\n this.mounted = false;\r\n }\r\n\r\n isTrue(paramValue) {\r\n return ((paramValue == \"true\") || (paramValue == \"1\") || (paramValue == \"on\"));\r\n }\r\n\r\n isString(param) {\r\n return (typeof param === \"string\") || (param instanceof String);\r\n }\r\n\r\n /**\r\n * Verifica parametri idList, idMsg, email\r\n * se vuoti/nulli ritorna false\r\n */\r\n isUserParamsValid() {\r\n const params = this.props.match.params;\r\n //\r\n return Boolean(params.idList && params.idMsg);\r\n }\r\n\r\n handleError = (error, source = \"default\", fatal = false) => {\r\n let errorLabel = \"Load.Common.Error\";\r\n if (error instanceof FrontendException) {\r\n errorLabel = error.label;\r\n } else if (this.isString(error)) {\r\n errorLabel = error;\r\n }\r\n //\r\n this.notificationRef.current.addError(this.props.intl.formatMessage({ id: errorLabel, defaultMessage: errorLabel }), source, false, !fatal);\r\n }\r\n\r\n getPublicCustomAction(idList, actionCode, email, preview) {\r\n return preview ? PublicCustomAPI.getAction(idList, actionCode).then((actionSettings) => {\r\n this.actionSettings = actionSettings;\r\n })\r\n : PublicCustomAPI.getActionForRecipient(idList, actionCode, email, preview).then((actionSettings) => {\r\n this.actionSettings = actionSettings;\r\n })\r\n ;\r\n }\r\n\r\n getPublicCustomText(idList, actionCode) {\r\n return PublicCustomAPI.getText(idList, actionCode).then((textSettings) => {\r\n this.textSettings = textSettings;\r\n });\r\n }\r\n\r\n getListGUID(idList) {\r\n return PublicCustomAPI.getListGUID(idList).then((listGUID) => {\r\n this.listGUID = listGUID;\r\n });\r\n }\r\n\r\n getClientIP() {\r\n return PublicCustomAPI.getClientIP().then((clientIP) => {\r\n this.clientIP = clientIP;\r\n });\r\n }\r\n\r\n replacePlaceholders(content, map, uriEncode) {\r\n Object.keys(map).forEach((key) => {\r\n if (uriEncode) {\r\n content = content.replaceAll('[' + key + ']', encodeURIComponent(map[key]));\r\n } else {\r\n content = content.replaceAll('[' + key + ']', map[key]);\r\n }\r\n });\r\n return content;\r\n }\r\n\r\n getActionCode(idMsg) {\r\n let result = \"\";\r\n switch (parseInt(idMsg, 10)) {\r\n case 11:\r\n result = \"PostUnsubscription_RecipientAlreadyUnsubscribed\";\r\n break;\r\n case 1:\r\n result = \"PostUnsubscription_GenericError\";\r\n break;\r\n case 7:\r\n result = \"PostUnsubscription_UnsubscriptionCompleted\";\r\n break;\r\n case 20:\r\n result = \"PostUnsubscription_RecipientDoesNotExist\";\r\n break;\r\n case 0:\r\n result = \"PostUnsubscription_UpdateOK\";\r\n break;\r\n }\r\n return result;\r\n }\r\n\r\n startLoader = () => {\r\n if (this.mounted) {\r\n this.setState({\r\n loading: true\r\n });\r\n }\r\n }\r\n\r\n stopLoader = () => {\r\n if (this.mounted) {\r\n this.setState({\r\n loading: false\r\n });\r\n }\r\n }\r\n\r\n render() {\r\n return (\r\n
    \r\n \r\n {this.state.loading && }\r\n\r\n {this.state.showMainContent &&\r\n \r\n {this.msgSettings.RedirectURL &&\r\n \r\n }\r\n\r\n {this.msgSettings.Content &&\r\n
    \r\n \r\n
    \r\n
    {parse(this.msgSettings.Content, { replace: htmlParserTransform })}
    \r\n
    \r\n
    \r\n }\r\n
    \r\n }\r\n
    \r\n );\r\n }\r\n}\r\n\r\nUnsubscriptionMsg.propTypes = {\r\n match: PropTypes.shape({\r\n params: PropTypes.shape({\r\n preview: PropTypes.string.isRequired,\r\n idList: PropTypes.string.isRequired,\r\n idMsg: PropTypes.string.isRequired,\r\n email: PropTypes.string\r\n })\r\n }),\r\n location: PropTypes.object,\r\n\r\n};\r\n\r\nexport default withResizeObserver(injectIntl(UnsubscriptionMsg), 'UnsubscriptionMsg');","//\r\nimport endpoints from '../endpoints';\r\nimport WebMethodService from '../WebMethodService';\r\n\r\nclass PreferenceCenterAPI {\r\n\r\n /**\r\n * Restituisce email del subscriber a partire da idOptIn e hash\r\n * @param {number} idOptIn \r\n * @param {string} hash \r\n * @returns {Promise}\r\n */\r\n static getSubscriberEmail(idOptIn, hash) {\r\n const params = {\r\n idOptIn: idOptIn,\r\n hash: hash\r\n };\r\n\r\n return WebMethodService.callWebMethod(endpoints.preferencecenter.getSubscriberEmail, params);\r\n }\r\n\r\n /**\r\n * \r\n * @param {number} idOptIn \r\n * @param {string} hash \r\n * @param {number} idList \r\n * @returns {Promise}\r\n */\r\n static loadPrefCenterOptions(idOptIn, hash, idList) {\r\n const params = {\r\n idOptIn: idOptIn,\r\n hash: hash,\r\n idList: idList\r\n };\r\n\r\n return WebMethodService.callWebMethod(endpoints.preferencecenter.loadPrefCenterOptions, params);\r\n }\r\n \r\n\r\n /**\r\n * \r\n * @param {number} idOptIn \r\n * @param {string} hash \r\n * @param {number} idList \r\n * @returns {Promise}\r\n */\r\n static loadSubscriberPreferences(idOptIn, hash, idList) {\r\n const params = {\r\n idOptIn: idOptIn,\r\n hash: hash,\r\n idList: idList\r\n };\r\n\r\n return WebMethodService.callWebMethod(endpoints.preferencecenter.loadSubscriberPreferences, params);\r\n }\r\n\r\n static exportAnagrData(idOptIn, hash, idList){\r\n const path = endpoints.exportService.exportAnagrData;\r\n window.location.href = path + '?hash=' + hash + '&idOptIn=' + idOptIn + '&idList=' + idList;\r\n }\r\n\r\n \r\n /**\r\n * \r\n * @param {number} idOptIn\r\n * @param {string} hash \r\n * @param {number} idList \r\n * @param {number} idNL \r\n * @param {array} subscription\r\n * @param {array} tracking\r\n * @returns {Promise}\r\n */\r\n static saveSubscriberPreferences(idOptIn, hash, idList, idNL, subscription, tracking) {\r\n const params = {\r\n idOptIn: idOptIn,\r\n hash: hash,\r\n idList: idList,\r\n idNL: idNL,\r\n subscription: subscription,\r\n tracking: tracking\r\n };\r\n\r\n return WebMethodService.callWebMethod(endpoints.preferencecenter.saveSubscriberPreferences, params);\r\n }\r\n\r\n /**\r\n * Restituisce messaggi di default per eliminazione lista\r\n * @param {number} idOptIn \r\n * @param {string} hash \r\n * @returns {Promise}\r\n */\r\n static getDefaultListValues(idOptIn, hash) {\r\n const params = {\r\n idOptIn: idOptIn,\r\n hash: hash\r\n };\r\n return WebMethodService.callWebMethod(endpoints.preferencecenter.getDefaultListValues, params);\r\n }\r\n\r\n\r\n \r\n /**\r\n * Restituisce messaggi di default per eliminazione lista\r\n * @param {number} idOptIn \r\n * @param {string} hash \r\n * @param {number} idList \r\n * @param {number} idForm \r\n * @returns {Promise}\r\n */\r\n static getAutoprofileFormAvailability(idOptIn, hash, idList, idForm) {\r\n const params = {\r\n idOptIn: idOptIn,\r\n hash: hash,\r\n idList: idList,\r\n idForm: idForm\r\n };\r\n return WebMethodService.callWebMethod(endpoints.preferencecenter.getAutoprofileFormAvailability, params);\r\n }\r\n\r\n}\r\n\r\nexport default PreferenceCenterAPI;","//\r\nimport React from 'react';\r\nimport {PropTypes} from 'prop-types';\r\n\r\nclass Iframe extends React.Component {\r\n constructor(props) {\r\n super(props);\r\n //\r\n this.elementRef = React.createRef();\r\n this.adjustTimeout = null;\r\n this.mutationObserver = null;\r\n }\r\n\r\n componentDidMount() {\r\n this.adjustHeight();\r\n }\r\n\r\n componentDidUpdate() {\r\n this.adjustHeight();\r\n }\r\n\r\n componentWillUnmount() {\r\n clearTimeout(this.adjustTimeout);\r\n //\r\n this.clearListeners();\r\n }\r\n\r\n onWindowResize = () => {\r\n this.adjustHeight();\r\n }\r\n\r\n adjustHeight = () => {\r\n if (this.props.autoAdjustHeight) {\r\n this.adjustTimeout = setTimeout(() => {\r\n const iframe = this.elementRef.current;\r\n //\r\n if (iframe && iframe.contentWindow &&\r\n iframe.contentWindow.document &&\r\n iframe.contentWindow.document.body) {\r\n\r\n let contentHeight = iframe.contentWindow.document.body.scrollHeight || 0;\r\n const collection = iframe.contentWindow.document.querySelectorAll(\"p, h1, h2, h3, h4, h5, h6, ol, ul, li, pre, address, blockquote, dl, div, fieldset, form, hr, table, iframe\");\r\n // IE11 non vede forEach su nodeList => conversione in array \r\n Array.prototype.slice.apply(collection).forEach(element => {\r\n if ((element.visibility !== 'hidden') && (element.scrollHeight > contentHeight)) {\r\n contentHeight = element.scrollHeight;\r\n }\r\n });\r\n\r\n if (iframe.height !== contentHeight) {\r\n iframe.height = contentHeight;\r\n setTimeout(function() {\r\n const h = iframe.contentWindow.document.querySelector('html');\r\n if (h && h.scrollHeight) {\r\n iframe.height = h.scrollHeight;\r\n }\r\n }, 200\r\n );\r\n \r\n }\r\n\r\n\r\n }\r\n }, 200);\r\n }\r\n // this.elementRef.current.height = this.elementRef.current.contentWindow.document.body.scrollHeight || 'auto';\r\n }\r\n\r\n clearListeners = () => {\r\n if (this.mutationObserver) {\r\n this.mutationObserver.disconnect();\r\n }\r\n //\r\n const iframe = this.elementRef.current;\r\n if (iframe && iframe.contentWindow) {\r\n iframe.contentWindow.removeEventListener(\"resize\", this.onWindowResize);\r\n }\r\n }\r\n\r\n initListeners = () => {\r\n this.clearListeners();\r\n //\r\n const iframe = this.elementRef.current;\r\n if (iframe && iframe.hasOwnProperty('height')) {\r\n iframe.height = 'auto';\r\n iframe.contentWindow.addEventListener(\"resize\", this.onWindowResize);\r\n }\r\n\r\n this.mutationObserver = new MutationObserver((mutations) => {\r\n this.adjustHeight();\r\n });\r\n \r\n this.mutationObserver.observe(iframe.contentDocument.body, { \r\n attributes: true,\r\n attributesFilter: ['style'],\r\n subtree: true,\r\n childList: true\r\n });\r\n //\r\n this.adjustHeight();\r\n }\r\n\r\n render() {\r\n const {src, scrolling, width, height} = this.props;\r\n\r\n return(\r\n