{"version":3,"sources":["components/CustomComponents/Banners/HomeBanner.js","containers/HomePage/HomePage.js","containers/HomePage/images/Icon1@2x.png","containers/HomePage/images/Icon2@2x.png","containers/HomePage/images/Icon3@2x.png","containers/HomePage/images/Icon4@2x.png","containers/HomePage/images/Icon5@2x.png","../node_modules/memoize-one/dist/memoize-one.esm.js","_platform/src/components/MessageBox/MessageBox.js","_platform/src/utils/checkPermissions.js","_platform/src/utils/checkRoles.js","_platform/src/utils/PrivateComponent.js","components/CustomComponents/Banners/images/HomeHeader-bg-mobile-@1x.png","components/CustomComponents/Banners/images/HomeHeader-bg-mobile-@2x.png","components/CustomComponents/Banners/images/Header-bg-tablet-@1x.png","components/CustomComponents/Banners/images/Header-bg-tablet-@2x.png","components/CustomComponents/Banners/images/Header-BG@1x.jpg","components/CustomComponents/Banners/images/Header-BG@2x.jpg"],"names":["BannerWrapper","styled","div","_templateObject","BannerContainer","_templateObject2","bannerMobile","thd","bannerMobile2x","up","css","_templateObject3","bannerTablet","bannerTablet2x","_templateObject4","bannerDesktop","bannerDesktop2x","HomeBanner","props","react_default","a","createElement","className","smooth_ui_core_sc_es","justifyContent","alignItems","xs","pageTitle","StatementProvider","LoadAsync","__webpack_require__","e","then","bind","GatewayGraph","Promise","all","StatementStyles","HomePage_templateObject","fetchStatements","endpoint","section","HomePage","_ref","settings","userProfile","Helmet_default","PrivateComponent","redirectOnError","pathname","settingsApp","loginPagePath","Banners_HomeBanner","Fragment","data","firstName","md","displayError","fetch","render","_ref2","statement","incentive","gatewayTarget","LoadingAnimation","lg","src","Icon1","alt","width","Icon2","Icon3","Icon4","Icon5","defaultProps","undefined","mapStateToProps","createStructuredSelector","selectUserProfile","withConnect","connect","dispatch","onUserProfileRequest","userProfileRequest","compose","withSettings","module","exports","p","safeIsNaN","Number","isNaN","value","areInputsEqual","newInputs","lastInputs","length","i","first","second","__webpack_exports__","resultFn","isEqual","lastThis","lastResult","lastArgs","calledOnce","newArgs","_i","arguments","this","apply","StyledAlert","Alert","Title","Multiline","MessageBox","children","_ref$title","title","_ref$variant","variant","react__WEBPACK_IMPORTED_MODULE_1___default","checkPermissions","currentUser","requiredPermissions","Array","isArray","permissions","some","item","indexOf","propTypes","PropTypes","object","isRequired","array","checkPermissionsMemoized","memoizeOne","checkRoles","requiredRoles","roles","checkRolesMemoized","_this$props","deniedPermissions","deniedRoles","errorMessage","publicOnly","tempAuthAllowed","user","_this$props2","currentUserTemp","UnauthorisedComponent","RedirectOnErrorComponent","react_router","push","to","userObject","token","userId","Component","selectCurrentUser","selectCurrentUserTemp"],"mappings":"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","file":"static/js/homepage.513d5752.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\nimport bannerMobile from './images/HomeHeader-bg-mobile-@1x.png';\nimport bannerMobile2x from './images/HomeHeader-bg-mobile-@2x.png';\nimport bannerTablet from './images/Header-bg-tablet-@1x.png';\nimport bannerTablet2x from './images/Header-bg-tablet-@2x.png';\nimport bannerDesktop from './images/Header-BG@1x.jpg';\nimport bannerDesktop2x from './images/Header-BG@2x.jpg';\n\nconst BannerWrapper = styled.div`\n position: relative;\n z-index: -1;\n`;\n\nconst BannerContainer = styled.div`\n background-image: url(${bannerMobile});\n align-items: center;\n background-color: ${thd('secondary', '#00A7AD')};\n background-position: center bottom;\n background-repeat: no-repeat;\n background-size: cover;\n display: flex;\n min-height: 435px;\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 background-image: url(${bannerMobile2x});\n }\n\n .banner__title {\n color: #fff;\n margin: 0;\n padding: 0;\n position: relative;\n text-align: center;\n }\n .banner {\n min-height: 400px;\n }\n ${up(\n 'sm',\n css`\n background-image: url(${bannerTablet});\n background-position: left center;\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 background-image: url(${bannerTablet2x});\n }\n `\n )}\n ${up(\n 'lg',\n css`\n background-image: url(${bannerDesktop});\n background-position: center center;\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 background-image: url(${bannerDesktop2x});\n }\n `\n )}\n`;\n\nconst HomeBanner = props => (\n \n \n \n \n \n
{props.pageTitle}
\n \n
\n
\n
\n
\n);\n\nHomeBanner.propTypes = {\n pageTitle: PropTypes.object.isRequired,\n};\n\nexport default HomeBanner;\n","import React from 'react';\nimport PropTypes from 'prop-types';\n\n// Style and SEO\nimport { Col, Grid, Row, styled, thd } from '@smooth-ui/core-sc';\nimport Helmet from 'react-helmet';\nimport { userProfileRequest } from '_platform/src/containers/App/actions';\nimport { selectUserProfile } from '_platform/src/containers/App/selectors';\nimport { compose } from 'redux';\nimport { connect } from 'react-redux';\nimport { createStructuredSelector } from 'reselect';\nimport LoadingAnimation from '_platform/src/components/Loading/LoadingAnimation';\n\nimport { withSettings } from '../../containers/WebApp/SettingsContext';\nimport PrivateComponent from '_platform/src/utils/PrivateComponent';\nimport HomeBanner from 'components/CustomComponents/Banners/HomeBanner';\n\nimport Icon1 from './images/Icon1@2x.png';\nimport Icon2 from './images/Icon2@2x.png';\nimport Icon3 from './images/Icon3@2x.png';\nimport Icon4 from './images/Icon4@2x.png';\nimport Icon5 from './images/Icon5@2x.png';\nimport LoadAsync from '_platform/src/utils/LoadAsync';\nconst StatementProvider = LoadAsync(() =>\n import(\n /* webpackChunkName: \"statementProvider\" */ '../StatementProvider/StatementProvider'\n )\n);\nconst GatewayGraph = LoadAsync(() =>\n import(\n /* webpackChunkName: \"gatewayGraph\" */ '../../components/StatementGateway/GatewayGraph'\n )\n);\n\nconst StatementStyles = styled.div`\n text-align: center;\n\n section:not(:last-of-type) {\n border-bottom: 1px solid ${thd('statementHighlightColor', '#f4bd19')};\n padding-bottom: 1.25rem;\n }\n\n .incentive-tiers {\n border: 2px solid ${thd('primary', '#000')};\n margin-top: 1em;\n padding: 0.5em;\n }\n\n .incentive-tiers-targets {\n display: flex;\n justify-content: space-around;\n }\n\n .statement-legend {\n margin-bottom: 2em;\n }\n\n .client-target-container {\n margin: 1em 0;\n }\n\n .client-buying-period {\n background-color: ${thd('primary', '#000')};\n color: #fff;\n margin: 0.5em 0;\n padding: 0.5em 0.25em;\n }\n\n .client-target-selection {\n margin: 0 auto;\n max-width: 420px;\n }\n`;\n\nconst fetchStatements = [\n {\n endpoint: '/Statement/v1/Loyalty/Pending',\n section: 'loyalty',\n },\n {\n endpoint: '/Statement/v1/Epson/Gateway/',\n section: 'incentive',\n },\n];\n\nconst HomePage = ({ settings, userProfile }) => {\n return (\n
\n \n {/* */}\n \n\n \n \n

\n Welcome{' '}\n {userProfile && userProfile.data && userProfile.data.firstName}{' '}\n to\n
\n Epson Premium Partner Rewards\n

\n \n }\n />\n\n \n \n \n

\n Here at Epson, we value your contribution to our business and\n have created Premium Partner Rewards to ensure that you are\n rewarded for your loyalty and on-going commitment!\n

\n
\n \n
\n \n \n \n \n {\n return !statement ||\n !statement.data ||\n !statement.data.incentive ? (\n // Loader instead of `null`?\n ) : (\n \n );\n }}\n />\n \n \n \n \n \n \n
\n

How it works

\n

\n The more you sell the quicker you will reach your target to\n unlock your rewards!\n

\n

\n Simply sell any eligible Epson product, submit your sale via the\n “Claims” page, and hit your “Gateway Target”, to unlock points\n that you can redeem in our rewards catalogue.\n

\n

\n Claims are approved once your sale has been validated. Every\n eligible Epson product sold earns points. So, start selling and\n watch your points accumulate towards your Gateway Target today!\n

\n \n
\n \n \n \"SALES\"\n

SALES

\n

\n Sell eligible\n
\n Epson products\n

\n \n \n \"CLAIM\"\n

CLAIM

\n

\n Submit your\n
\n sales claim\n

\n \n \n \"EARN\"\n

EARN

\n

\n Watch your\n
\n points Add up\n

\n \n \n \"Gateway\"\n

Gateway

\n

\n Hit your\n
\n Gateway Target\n

\n \n \n \"REDEEM\"\n

REDEEM

\n

\n Redeem your\n
\n points for rewards!\n

\n \n
\n
\n \n
\n );\n};\n\nHomePage.propTypes = {\n onUserProfileRequest: PropTypes.func.isRequired,\n settings: PropTypes.object.isRequired,\n userProfile: PropTypes.object,\n};\n\nHomePage.defaultProps = {\n userProfile: undefined,\n};\n\nconst mapStateToProps = createStructuredSelector({\n userProfile: selectUserProfile(),\n});\n\nfunction mapDispatchToProps(dispatch) {\n return {\n dispatch,\n onUserProfileRequest: () => dispatch(userProfileRequest()),\n };\n}\n\nconst withConnect = connect(mapStateToProps, mapDispatchToProps);\n\nexport default compose(withSettings, withConnect)(HomePage);\n","module.exports = \"\"","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/Icon3@2x.5ebb403d.png\";","module.exports = __webpack_public_path__ + \"static/media/Icon4@2x.23d449a6.png\";","module.exports = __webpack_public_path__ + \"static/media/Icon5@2x.d8736b77.png\";","var safeIsNaN = Number.isNaN || function ponyfill(value) {\n return typeof value === 'number' && value !== value;\n};\n\nfunction isEqual(first, second) {\n if (first === second) {\n return true;\n }\n\n if (safeIsNaN(first) && safeIsNaN(second)) {\n return true;\n }\n\n return false;\n}\n\nfunction 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 (!isEqual(newInputs[i], lastInputs[i])) {\n return false;\n }\n }\n\n return true;\n}\n\nfunction memoizeOne(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 function memoized() {\n var newArgs = [];\n\n for (var _i = 0; _i < arguments.length; _i++) {\n newArgs[_i] = arguments[_i];\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 memoized;\n}\n\nexport default memoizeOne;","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","/**\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","module.exports = __webpack_public_path__ + \"static/media/HomeHeader-bg-mobile-@1x.fcdb455f.png\";","module.exports = __webpack_public_path__ + \"static/media/HomeHeader-bg-mobile-@2x.c274d563.png\";","module.exports = __webpack_public_path__ + \"static/media/Header-bg-tablet-@1x.94a1e208.png\";","module.exports = __webpack_public_path__ + \"static/media/Header-bg-tablet-@2x.443e8a68.png\";","module.exports = __webpack_public_path__ + \"static/media/Header-BG@1x.b6416825.jpg\";","module.exports = __webpack_public_path__ + \"static/media/Header-BG@2x.bd591820.jpg\";"],"sourceRoot":""}