{"version":3,"sources":["components/CustomComponents/Backgrounds/BannerHome.js","components/CustomComponents/Backgrounds/BgPrimary.js","containers/HomePage/HomePage.js","containers/HomePage/images/hp-home-banner-mobile-@1x.jpg","containers/HomePage/images/hp-home-banner-mobile-@2x.jpg","containers/HomePage/images/hp-home-banner-tablet-@1x.jpg","containers/HomePage/images/hp-home-banner-tablet-@2x.jpg","containers/HomePage/images/hp-home-banner-@1x.jpg","containers/HomePage/images/hp-home-banner-@2x.jpg","_platform/src/components/MessageBox/MessageBox.js","../node_modules/memoize-one/dist/memoize-one.esm.js","_platform/src/utils/checkPermissions.js","_platform/src/utils/checkRoles.js","_platform/src/utils/PrivateComponent.js","_platform/src/components/SvgIcon/IconWrapper.js"],"names":["BannerWrapper","styled","div","_templateObject","BannerContainer","_templateObject2","props","bannerMobile","concat","thd","bannerMobile2x","up","css","_templateObject3","bannerTablet","bannerTablet2x","_templateObject4","bannerDesktop","bannerDesktop2x","BannerHome","react_default","a","createElement","className","smooth_ui_core_sc_es","alignItems","justifyContent","xs","md","pageTitle","pageText","BgPrimary","section","BgPrimary_templateObject","th","MastercardProvider","LoadAsync","__webpack_require__","e","then","bind","StatementMastercardBalance","Promise","all","AchieveContainer","HomePage_templateObject","PdsBanner","HomePage_templateObject2","withSettings","_ref","settings","Helmet_default","PrivateComponent","redirectOnError","pathname","settingsApp","loginPagePath","Backgrounds_BannerHome","Fragment","href","target","rel","Backgrounds_BgPrimary","fetch","endpoint","render","_ref2","mastercard","data","statement","LoadingAnimation","sm","lg","IconWrapper","SvgIcon","icon","scaleWidth","scaleHeight","width","height","fill","title","react_router_dom","to","module","exports","p","StyledAlert","Alert","Title","Multiline","MessageBox","children","_ref$title","undefined","_ref$variant","variant","react__WEBPACK_IMPORTED_MODULE_1___default","defaultProps","areInputsEqual","newInputs","lastInputs","length","i","__webpack_exports__","resultFn","isEqual","lastThis","lastResult","lastArgs","calledOnce","_len","arguments","newArgs","Array","_key","this","apply","checkPermissions","currentUser","requiredPermissions","isArray","permissions","some","item","indexOf","propTypes","PropTypes","object","isRequired","array","checkPermissionsMemoized","memoizeOne","checkRoles","requiredRoles","roles","checkRolesMemoized","_this$props","deniedPermissions","deniedRoles","displayError","errorMessage","publicOnly","tempAuthAllowed","user","_this$props2","currentUserTemp","UnauthorisedComponent","RedirectOnErrorComponent","react_router","push","userObject","token","userId","Component","mapStateToProps","createStructuredSelector","selectCurrentUser","selectCurrentUserTemp","connect","string"],"mappings":"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","file":"static/js/homepage.91f3919f.chunk.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\n\nimport { Grid, Row, Col, css, styled, thd, up } from '@smooth-ui/core-sc';\n\nconst BannerWrapper = styled.div`\n position: relative;\n z-index: -1;\n`;\n\nconst BannerContainer = styled.div`\n ${props =>\n props.bannerMobile\n ? `background-image: url(${props.bannerMobile});`\n : null};\n align-items: center;\n background-color: ${thd('primary', '#00A7AD')};\n background-position: center bottom;\n background-repeat: no-repeat;\n background-size: cover;\n display: flex;\n height: 540px;\n justify-content: flex-start;\n\n @media only screen and (min-device-pixel-ratio: 1.5),\n only screen and (min-resolution: 144dpi),\n only screen and (min-resolution: 1.5dppx) {\n ${props =>\n props.bannerMobile || props.bannerMobile2x\n ? `background-image: url(${props.bannerMobile2x ||\n props.bannerMobile});`\n : null};\n }\n\n .banner__title {\n color: #fff;\n font-size: 40px;\n font-weight: normal;\n line-height: 44px;\n position: relative;\n text-align: center;\n }\n\n .banner__text {\n color: #fff;\n font-weight: normal;\n font-size: 18px;\n line-height: 26px;\n position: relative;\n text-align: left;\n }\n\n .banner {\n height: 540px;\n }\n ${up(\n 'sm',\n css`\n ${props =>\n props.bannerTablet\n ? `background-image: url(${props.bannerTablet});`\n : null};\n background-position: left center;\n height: 540px;\n\n @media only screen and (min-device-pixel-ratio: 1.5),\n only screen and (min-resolution: 144dpi),\n only screen and (min-resolution: 1.5dppx) {\n ${props =>\n props.bannerTablet || props.bannerTablet2x\n ? `background-image: url(${props.bannerTablet2x ||\n props.bannerTablet});`\n : null};\n }\n\n .banner {\n height: 540px;\n }\n `\n )}\n ${up(\n 'lg',\n css`\n ${props =>\n props.bannerDesktop\n ? `background-image: url(${props.bannerDesktop});`\n : null};\n background-position: center center;\n height: 540px;\n\n @media only screen and (min-device-pixel-ratio: 1.5),\n only screen and (min-resolution: 144dpi),\n only screen and (min-resolution: 1.5dppx) {\n ${props =>\n props.bannerDesktop || props.bannerDesktop2x\n ? `background-image: url(${props.bannerDesktop2x ||\n props.bannerDesktop});`\n : null};\n }\n\n .banner {\n height: 500px;\n }\n `\n )}\n`;\n\nconst BannerHome = props => (\n \n \n \n \n \n

{props.pageTitle}

\n
{props.pageText}
\n \n
\n
\n
\n
\n);\n\nBannerHome.propTypes = {\n pageTitle: PropTypes.object.isRequired,\n pageText: PropTypes.object.isRequired,\n};\n\nexport default BannerHome;\n","import { styled, th } from '@smooth-ui/core-sc';\n\nconst BgPrimary = styled.section`\n align-items: center;\n background-color: ${th('primary')};\n color: #fff;\n display: flex;\n flex-direction: column;\n justify-content: center;\n padding: 0;\n width: 100%;\n`;\n\nexport default BgPrimary;\n","import React from 'react';\nimport PropTypes from 'prop-types';\n\n// Style and SEO\nimport { Col, Grid, Row, styled } from '@smooth-ui/core-sc';\nimport Helmet from 'react-helmet';\nimport { Link } from 'react-router-dom';\n\nimport { withSettings } from '../../containers/WebApp/SettingsContext';\nimport PrivateComponent from '_platform/src/utils/PrivateComponent';\n\nimport IconWrapper from '_platform/src/components/SvgIcon/IconWrapper';\nimport SvgIcon from '_platform/src/components/SvgIcon/SvgIcon';\nimport LoadingAnimation from '_platform/src/components/Loading/LoadingAnimation';\n\nimport BannerHome from '../../components/CustomComponents/Backgrounds/BannerHome';\nimport BgPrimary from '../../components/CustomComponents/Backgrounds/BgPrimary';\n\nimport bannerMobile from './images/hp-home-banner-mobile-@1x.jpg';\nimport bannerMobile2x from './images/hp-home-banner-mobile-@2x.jpg';\nimport bannerTablet from './images/hp-home-banner-tablet-@1x.jpg';\nimport bannerTablet2x from './images/hp-home-banner-tablet-@2x.jpg';\nimport bannerDesktop from './images/hp-home-banner-@1x.jpg';\nimport bannerDesktop2x from './images/hp-home-banner-@2x.jpg';\nimport LoadAsync from '_platform/src/utils/LoadAsync';\n\nconst MastercardProvider = LoadAsync(() =>\n import(\n /* webpackChunkName: \"MastercardProvider\" */ '../MastercardProvider/MastercardProvider'\n )\n);\nconst StatementMastercardBalance = LoadAsync(() =>\n import(\n /* webpackChunkName: \"statementLoyalty\" */ '../../components/StatementMastercard/StatementMastercardBalance'\n )\n);\n\nconst AchieveContainer = styled.section`\n background-color: rgba(43, 65, 90, 0.3);\n color: #2b415a;\n\n h2 {\n font-weight: bold;\n font-size: 36px;\n }\n\n h3 {\n font-weight: bold;\n font-size: 30px;\n }\n\n h4 {\n font-size: 24px;\n font-weight: normal;\n }\n\n .border {\n border-top: 1px solid #2b415a;\n }\n`;\n\nconst PdsBanner = styled.div`\n background-color: #1a2332;\n text-align: center;\n\n a {\n background-color: white;\n font-weight: bold;\n text-decoration: none;\n padding: 5px 10px;\n min-width: 200px;\n display: inline-block;\n }\n`;\n\nconst HomePage = ({ settings }) => {\n return (\n
\n \n {/* */}\n \n \n \n Welcome to\n
\n HP Commercial Club\n \n }\n pageText={\n \n

\n We are excited to launch HP Commercial Club – A new, streamlined\n way to reward our Partners for your sales. New look, new\n incentive agency, new incentives and overall smoother process\n for our Partners to be rewarded.\n

\n

\n Once registered to participate you will receive a HP reloadable\n Mastercard®. Sell HP products to earn reward dollars. Each\n fortnight sales are loaded to the website and your Company\n Allocator will award them to registered team members. Your\n Reward Dollars will then be automatically loaded onto your HP\n Mastercard®.\n

\n
\n }\n bannerMobile={bannerMobile}\n bannerMobile2x={bannerMobile2x}\n bannerTablet={bannerTablet}\n bannerTablet2x={bannerTablet2x}\n bannerDesktop={bannerDesktop}\n bannerDesktop2x={bannerDesktop2x}\n />\n \n \n \n \n

\n \n UPDATE: Please note, your Mastercard PDS has been updated.\n
\n Please click the button below to view the latest PDS.\n
\n

\n \n View PDS\n \n \n
\n
\n
\n \n \n !mastercard || !mastercard.data ? (\n // Loader instead of `null`?\n ) : (\n \n )\n }\n />\n \n \n \n \n \n

How to Achieve

\n \n
\n \n \n \n \n \n

Step 1

\n

Register

\n \n \n \n \n \n

Step 2

\n

\n Receive HP Reloadable Mastercard ®\n

\n \n \n \n \n \n

Step 3

\n

\n Sell HP Products to earn Reward Dollars\n

\n \n \n \n \n \n

Step 4

\n

\n Reward Dollars loaded to your Mastercard®\n

\n \n
\n \n \n

Participating Products

\n

\n The range of core products can be{' '}\n \n viewed here\n \n .\n

\n \n
\n
\n
\n \n
\n );\n};\n\nHomePage.propTypes = {\n settings: PropTypes.object.isRequired,\n};\n\nexport default withSettings(HomePage);\n","module.exports = __webpack_public_path__ + \"static/media/hp-home-banner-mobile-@1x.ae4aca2d.jpg\";","module.exports = __webpack_public_path__ + \"static/media/hp-home-banner-mobile-@2x.f3b027cc.jpg\";","module.exports = __webpack_public_path__ + \"static/media/hp-home-banner-tablet-@1x.5edf9d59.jpg\";","module.exports = __webpack_public_path__ + \"static/media/hp-home-banner-tablet-@2x.39574b7e.jpg\";","module.exports = __webpack_public_path__ + \"static/media/hp-home-banner-@1x.9b89fee4.jpg\";","module.exports = __webpack_public_path__ + \"static/media/hp-home-banner-@2x.35cdff1c.jpg\";","import React from 'react';\nimport PropTypes from 'prop-types';\nimport { Alert, styled } from '@smooth-ui/core-sc';\n\nconst StyledAlert = styled(Alert)`\n margin-top: 1rem;\n`;\n\nexport const Title = styled.div`\n font-weight: bold;\n`;\n\nexport const Multiline = styled.div`\n white-space: pre-line;\n`;\n\nconst MessageBox = ({ children, title = undefined, variant = 'primary' }) => {\n return (\n \n {title ? {title} : null}\n {children}\n \n );\n};\n\nMessageBox.propTypes = {\n children: PropTypes.node.isRequired,\n title: PropTypes.string,\n variant: PropTypes.string,\n};\n\nMessageBox.defaultProps = {\n title: undefined,\n variant: 'primary',\n};\n\nexport default MessageBox;\n","function areInputsEqual(newInputs, lastInputs) {\n if (newInputs.length !== lastInputs.length) {\n return false;\n }\n\n for (var i = 0; i < newInputs.length; i++) {\n if (newInputs[i] !== lastInputs[i]) {\n return false;\n }\n }\n\n return true;\n}\n\nfunction index(resultFn, isEqual) {\n if (isEqual === void 0) {\n isEqual = areInputsEqual;\n }\n\n var lastThis;\n var lastArgs = [];\n var lastResult;\n var calledOnce = false;\n\n var result = function result() {\n for (var _len = arguments.length, newArgs = new Array(_len), _key = 0; _key < _len; _key++) {\n newArgs[_key] = arguments[_key];\n }\n\n if (calledOnce && lastThis === this && isEqual(newArgs, lastArgs)) {\n return lastResult;\n }\n\n lastResult = resultFn.apply(this, newArgs);\n calledOnce = true;\n lastThis = this;\n lastArgs = newArgs;\n return lastResult;\n };\n\n return result;\n}\n\nexport default index;","/**\n * Check Permissions - Check if the user has ANY of the required permissions\n *\n * @param {object} currentUser The user object containing the permissions property\n * @param {array} requiredPermissions The array of required permissions\n *\n */\n\nimport memoizeOne from 'memoize-one';\nimport PropTypes from 'prop-types';\n\nconst checkPermissions = (currentUser, requiredPermissions) => {\n if (\n !requiredPermissions ||\n !Array.isArray(requiredPermissions) ||\n !currentUser ||\n !currentUser.permissions ||\n !Array.isArray(currentUser.permissions)\n )\n return false;\n\n return currentUser.permissions.some(\n item => requiredPermissions.indexOf(item) >= 0\n );\n};\n\ncheckPermissions.propTypes = {\n currentUser: PropTypes.object.isRequired,\n requiredPermissions: PropTypes.array.isRequired,\n};\n\nconst checkPermissionsMemoized = memoizeOne(checkPermissions);\n\nexport default checkPermissionsMemoized;\n","/**\n * Check Roles - Check if the user has ANY of the required roles\n *\n * @param {object} currentUser The user object containing the roles property\n * @param {array} requiredRoles The array of required roles\n *\n */\n\nimport memoizeOne from 'memoize-one';\nimport PropTypes from 'prop-types';\n\nconst checkRoles = (currentUser, requiredRoles) => {\n if (\n !requiredRoles ||\n !Array.isArray(requiredRoles) ||\n !currentUser ||\n !currentUser.roles ||\n !Array.isArray(currentUser.roles)\n )\n return false;\n\n return currentUser.roles.some(item => requiredRoles.indexOf(item) >= 0);\n};\n\ncheckRoles.propTypes = {\n currentUser: PropTypes.object.isRequired,\n requiredRoles: PropTypes.array.isRequired,\n};\n\nconst checkRolesMemoized = memoizeOne(checkRoles);\n\nexport default checkRolesMemoized;\n","import React, { Component } from 'react';\nimport PropTypes from 'prop-types';\nimport { connect } from 'react-redux';\nimport { createStructuredSelector } from 'reselect';\nimport { Redirect } from 'react-router-dom';\nimport {\n selectCurrentUser,\n selectCurrentUserTemp,\n} from '../containers/App/selectors'; // _platform\nimport checkPermissions from '../utils/checkPermissions'; // _platform\nimport checkRoles from '../utils/checkRoles'; // _platform\nimport MessageBox from '../components/MessageBox/MessageBox'; // _platform\n\n/**\n * Private Component - HoC to determine whether a component should be displayed\n * based on authentication, permissions and/or roles\n *\n * TODO: Extend with prop to supply function to determine permission `verifyFn` similar to LoadAsync\n *\n * The `user` prop can be either currentUser or currentUserTemp, depending on what the parent component determines is applicable.\n * If the `user` prop is not supplied, then this component will retrieve the user data via the App selectors.\n * The `tempAuthAllowed` prop determines whether currentUserTemp can be used\n *\n * `publicOnly` prop inverts the check so that the child component is only displayed to unauthenticated users (use `PublicComponent`)\n *\n * `deniedPermissions` and `deniedRoles` props take precedence over `requiredPermissions` and `requiredRoles`.\n * For example, if the props are `requiredRoles={['Administrator']} deniedRoles={['Administrator']}`,\n * users with the `Administrator` role will be denied access to the child component.\n *\n * If the checks determine that the access should be denied to the child component:\n * - By default the child component is skipped silently\n * - If the `redirectOnError` prop is supplied, the user will be redirected to the supplied local path\n * - Otherwise, if the `displayError` prop is supplied, the user will be shown an error\n * which can be customised via the `errorMessage` prop\n */\n\nclass PrivateComponent extends Component {\n render() {\n const {\n deniedPermissions,\n deniedRoles,\n displayError,\n errorMessage,\n publicOnly,\n redirectOnError,\n requiredPermissions,\n requiredRoles,\n tempAuthAllowed,\n user,\n } = this.props;\n const { currentUser, currentUserTemp } = this.props;\n\n const UnauthorisedComponent = displayError ? (\n \n {errorMessage || 'Unauthorised'}\n \n ) : null;\n\n const RedirectOnErrorComponent = redirectOnError ? (\n \n ) : null;\n\n // Determine which user object to use\n // 1. Use `user` prop if supplied\n // 2. If `tempAuthAllowed` prop:\n // 1. Is true: use `currentUserTemp` if available, if not use currentUser\n // 3. Is false: use currentUser\n //\n // Check for user.token and currentUserTemp.token to ensure they're not the\n // default empty objects. Cleaner than using Object.keys\n let userObject = {};\n if (user && user.token && user.userId) {\n userObject = user;\n } else if (tempAuthAllowed && currentUserTemp && currentUserTemp.token) {\n userObject = currentUserTemp;\n } else {\n userObject = currentUser;\n }\n\n // Invert the check if the publicOnly prop is supplied - used in PublicComponent\n if (publicOnly) {\n return !userObject.token\n ? this.props.children\n : RedirectOnErrorComponent || UnauthorisedComponent;\n }\n\n // Check granular permissions if supplied\n if (\n !!userObject.token &&\n ((deniedPermissions && checkPermissions(userObject, deniedPermissions)) ||\n (requiredPermissions &&\n !checkPermissions(userObject, requiredPermissions)))\n ) {\n return RedirectOnErrorComponent || UnauthorisedComponent;\n }\n\n // Check granular roles if supplied\n if (\n !!userObject.token &&\n ((deniedRoles && checkRoles(userObject, deniedRoles)) ||\n (requiredRoles && !checkRoles(userObject, requiredRoles)))\n ) {\n return RedirectOnErrorComponent || UnauthorisedComponent;\n }\n\n return !!userObject.token\n ? this.props.children\n : RedirectOnErrorComponent || UnauthorisedComponent;\n }\n}\n\nPrivateComponent.propTypes = {\n children: PropTypes.node.isRequired,\n currentUser: PropTypes.object.isRequired,\n currentUserTemp: PropTypes.object.isRequired,\n deniedPermissions: PropTypes.array,\n deniedRoles: PropTypes.array,\n displayError: PropTypes.bool,\n errorMessage: PropTypes.string,\n publicOnly: PropTypes.bool, // Inverts PrivateComponent - displays component to unauthenticated users only. Used by PublicComponent wrapper\n redirectOnError: PropTypes.oneOfType([PropTypes.string, PropTypes.object]),\n requiredPermissions: PropTypes.array,\n requiredRoles: PropTypes.array,\n tempAuthAllowed: PropTypes.bool,\n user: PropTypes.object,\n};\n\nPrivateComponent.defaultProps = {\n deniedPermissions: undefined,\n deniedRoles: undefined,\n displayError: false,\n errorMessage: undefined,\n publicOnly: false,\n redirectOnError: undefined,\n requiredPermissions: undefined,\n requiredRoles: undefined,\n tempAuthAllowed: false,\n user: {},\n};\n\nconst mapStateToProps = createStructuredSelector({\n currentUser: selectCurrentUser(),\n currentUserTemp: selectCurrentUserTemp(),\n});\n\nexport default connect(\n mapStateToProps,\n null\n)(PrivateComponent);\n","import { styled } from '@smooth-ui/core-sc';\nimport PropTypes from 'prop-types';\n\nconst IconWrapper = styled.div`\n align-items: center;\n display: flex;\n height: ${p => (p.height ? p.height : '190px')};\n justify-content: center;\n margin-left: auto;\n margin-right: auto;\n width: ${p => (p.width ? p.width : '190px')};\n`;\n\nIconWrapper.propTypes = {\n height: PropTypes.string,\n width: PropTypes.string,\n};\n\nIconWrapper.defaultProps = {\n height: undefined,\n width: undefined,\n};\n\nexport default IconWrapper;\n"],"sourceRoot":""}