{"version":3,"sources":["_platform/src/utils/getReturnUrlPath.js","containers/LoginPage/LoginPage.js","containers/LoginPage/images/HP-LoginImage-@1x.png","containers/LoginPage/images/HP-LoginImage-@2x.png","containers/LoginPage/images/HP-LoginImage-Mobile-@1x.png","containers/LoginPage/images/HP-LoginImage-Mobile-@2x.png","_platform/src/components/MessageBox/MessageBox.js","../node_modules/memoize-one/dist/memoize-one.esm.js","_platform/src/utils/checkRoles.js","_platform/src/utils/checkPermissions.js","_platform/src/utils/PrivateComponent.js","_platform/src/components/Button/Button.js","_platform/src/utils/PublicComponent.js"],"names":["pageQueryString","qs","parse","history","location","search","replace","ignoreQueryPrefix","LoginProvider","LoadAsync","__webpack_require__","e","then","bind","LoginForm","Promise","all","PageContainer","styled","section","_templateObject","thd","up","css","_templateObject2","_templateObject3","BgDesktop","BgDesktop2x","_templateObject4","LoginLogo","h1","_templateObject5","_templateObject6","IntroContainer","div","_templateObject7","_templateObject8","down","_templateObject9","BgMobile","BgMobile2x","LoginContainer","_templateObject10","_templateObject11","RegisterButton","Button","_templateObject12","_templateObject13","_templateObject14","withTheme","withSettings","_ref","settings","react_default","a","createElement","PublicComponent","redirectOnError","getReturnUrlPath","settingsApp","loginPagePath","Helmet_default","smooth_ui_core_sc_es","className","justifyContent","SvgIcon","icon","scaleWidth","scaleHeight","width","height","fill","title","xs","sm","osm","lg","olg","as","Link","to","disableMeta","formLabels","labelUserName","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","memoize_one__WEBPACK_IMPORTED_MODULE_0__","prop_types__WEBPACK_IMPORTED_MODULE_1__","prop_types__WEBPACK_IMPORTED_MODULE_1___default","n","checkRoles","currentUser","requiredRoles","isArray","roles","some","item","indexOf","propTypes","PropTypes","object","isRequired","array","checkRolesMemoized","memoizeOne","checkPermissions","requiredPermissions","permissions","checkPermissionsMemoized","PrivateComponent","_this$props","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","ButtonBlock","Box","theme","buttonBlockSpacerTop","buttonBlockSpacerBottom","buttonBlockHasSeparator","concat","buttonBlockSpacerInner","buttonSeparatorColor","StyledButton","disabled","customInputBtnFontWeight","minWidth","inputBtnMinWidth","controlFocus","th","bool","string","react__WEBPACK_IMPORTED_MODULE_0__","react__WEBPACK_IMPORTED_MODULE_0___default","_PrivateComponent__WEBPACK_IMPORTED_MODULE_1__","Object","assign"],"mappings":"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","file":"static/js/loginPage.27aac200.chunk.js","sourcesContent":["import qs from 'qs';\nimport history from '_platform/src/utils/history';\n\nconst pageQueryString = qs.parse(\n // Normalise key\n history.location.search.replace(/returnUrl/gi, 'returnUrl'),\n {\n ignoreQueryPrefix: true,\n }\n);\n\nexport default pageQueryString.returnUrl;\n","/**\n * Login Page\n */\n\n// Core imports\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { Link } from 'react-router-dom';\n\n// Style, SEO and settings\nimport Helmet from 'react-helmet';\nimport {\n Col,\n css,\n Grid,\n Row,\n up,\n down,\n styled,\n thd,\n withTheme,\n} from '@smooth-ui/core-sc';\n\n// Additional Components/Containers\nimport Button from '_platform/src/components/Button/Button';\nimport LoadAsync from '_platform/src/utils/LoadAsync';\nimport PublicComponent from '_platform/src/utils/PublicComponent';\nimport getReturnUrlPath from '_platform/src/utils/getReturnUrlPath';\n\nimport { withSettings } from 'containers/WebApp/SettingsContext';\nimport SvgIcon from '../../components/CustomComponents/SvgIcon/SvgIcon';\n\nimport BgDesktop from './images/HP-LoginImage-@1x.png';\nimport BgDesktop2x from './images/HP-LoginImage-@2x.png';\nimport BgMobile from './images/HP-LoginImage-Mobile-@1x.png';\nimport BgMobile2x from './images/HP-LoginImage-Mobile-@2x.png';\n\nconst LoginProvider = LoadAsync(() =>\n import(\n /* webpackChunkName: \"loginProvider\" */ '_platform/src/containers/LoginProvider/LoginProvider'\n )\n);\nconst LoginForm = LoadAsync(() =>\n import(\n /* webpackChunkName: \"loginForm\" */ '_platform/src/components/LoginForm/LoginForm'\n )\n);\n\nconst PageContainer = styled.section`\n align-items: center;\n background-color: ${thd('black', '#0d0d0d')};\n display: flex;\n flex: 1 0 auto;\n flex-direction: row;\n justify-content: flex-start;\n\n ${up(\n 'lg',\n css`\n flex-direction: column;\n justify-content: center;\n flex-basis: 200px;\n `\n )};\n\n ${up(\n 'lg',\n css`\n background-image: url('${BgDesktop}');\n background-repeat: no-repeat;\n background-attachment: fixed;\n background-position: top right;\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('${BgDesktop2x}');\n }\n `\n )};\n\n padding: 10px 0;\n\n .page-container {\n ${up(\n 'md',\n css`\n margin-left: 10px;\n `\n )};\n }\n`;\n\nconst LoginLogo = styled.h1`\n margin-bottom: 0;\n margin-top: 0;\n padding-top: 0;\n padding-bottom: 0;\n ${up(\n 'lg',\n css`\n padding-bottom: 1rem;\n `\n )};\n\n img {\n height: 72px;\n height: auto;\n width: 192px;\n }\n`;\n\nconst IntroContainer = styled.div`\n background-color: rgba(35, 31, 32, 0.85);\n box-sizing: border-box;\n color: #fff;\n margin-bottom: 0.5rem;\n margin-top: 0.5rem;\n\n ${up(\n 'lg',\n css`\n padding: 2rem;\n `\n )};\n\n h2 {\n font-size: 30px;\n }\n p {\n color: #fff;\n }\n a {\n color: #000;\n &:hover {\n text-decoration: none;\n }\n &:visited {\n color: #000;\n }\n }\n\n .content-row {\n margin: 0;\n padding: 0;\n ${down(\n 'md',\n css`\n background-image: url('${BgMobile}');\n background-repeat: no-repeat;\n background-position: top left;\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('${BgMobile2x}');\n }\n `\n )};\n }\n`;\n\nconst LoginContainer = styled.div`\n max-width: 500px;\n\n button {\n min-width: 175px;\n }\n\n .reset-password {\n a {\n color: #fff;\n font-size: 14px;\n font-weight: normal;\n }\n }\n\n ${up(\n 'lg',\n css`\n padding-left: 2rem;\n min-width: 300px;\n `\n )};\n`;\n\nconst RegisterButton = styled(Button)`\n background-color: ${thd('primary', '#D19C45')};\n color: #000;\n font-size: 16px;\n font-weight: bold;\n letter-spacing: 2px;\n margin-bottom: 1rem;\n min-width: 225px;\n padding-bottom: 0.7rem;\n padding-top: 0.7rem;\n text-align: center;\n width: 100%;\n\n ${up(\n 'md',\n css`\n width: 44%;\n `\n )};\n\n &.jbhifi {\n min-width: 160px;\n\n ${up(\n 'md',\n css`\n float: right;\n `\n )};\n }\n`;\n\nconst LoginPage = ({ settings }) => (\n \n \n Login\n {/**/}\n \n\n \n \n \n \n \n \n \n \n \n \n \n \n \n

\n Welcome to the{' '}\n \n HP Platinum Club\n \n

\n

\n The HP Platinum Club is designed to reward you for your sales\n of selected HP products and for completing training. The more\n products you sell, the more points you earn and the more\n rewards you receive, plus complete training to earn even more\n points.\n

\n

\n Register below to participate in the HP Platinum Club.\n

\n \n Harvey Norman\n
\n Registration\n \n \n JB Hi-Fi\n
\n Registration\n \n \n \n \n

\n Already registered?\n

\n \n \n \n
\n \n
\n
\n
\n
\n
\n \n);\n\nLoginPage.propTypes = {\n settings: PropTypes.object.isRequired,\n};\n\nexport default withTheme(withSettings(LoginPage));\n","module.exports = __webpack_public_path__ + \"static/media/HP-LoginImage-@1x.b10f3a0e.png\";","module.exports = __webpack_public_path__ + \"static/media/HP-LoginImage-@2x.60e02bc5.png\";","module.exports = __webpack_public_path__ + \"static/media/HP-LoginImage-Mobile-@1x.e78063eb.png\";","module.exports = __webpack_public_path__ + \"static/media/HP-LoginImage-Mobile-@2x.ef28219f.png\";","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 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","/**\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","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","/**\n * Button\n */\nimport PropTypes from 'prop-types';\nimport { Box, Button, controlFocus, styled, th } from '@smooth-ui/core-sc';\n\n// Button Block\nexport const ButtonBlock = styled(Box)`\n margin-top: ${props => props.theme.buttonBlockSpacerTop || '2rem'};\n margin-bottom: ${props => props.theme.buttonBlockSpacerBottom || '1rem'};\n\n ${props =>\n !!props.theme.buttonBlockHasSeparator\n ? `\n padding-top: ${props.theme.buttonBlockSpacerInner || '1.5rem'};\n border-top: 1px solid ${props.theme.buttonSeparatorColor || '#dee2e6'};\n `\n : null};\n`;\n\nconst StyledButton = styled(Button)`\n ${props => props.disabled && `cursor: not-allowed;`}\n ${props =>\n props.theme.customInputBtnFontWeight &&\n `font-weight: ${props.theme.customInputBtnFontWeight};`}\n margin-top: 1px;\n min-width: ${props => props.minWidth || props.theme.inputBtnMinWidth};\n text-align: center;\n\n &:focus {\n ${p => controlFocus(th(p.variant)(p))(p)}\n }\n`;\n\nStyledButton.propTypes = {\n disabled: PropTypes.bool,\n minWidth: PropTypes.string,\n theme: PropTypes.object,\n};\nexport default StyledButton;\n","/**\n * Public Component - Wrapper for PrivateComponent with the publicOnly flag\n */\n\nimport React from 'react';\nimport PrivateComponent from './PrivateComponent';\n\nconst PublicComponent = props => ;\n\nexport default PublicComponent;\n"],"sourceRoot":""}