{"version":3,"sources":["_platform/src/utils/getReturnUrlPath.js","containers/LoginPage/LoginPage.js","containers/LoginPage/images/login-bg-@1x.jpg","containers/LoginPage/images/login-bg-@2x.jpg","containers/LoginPage/images/login-bg-mobile-@1x.jpg","containers/LoginPage/images/login-bg-mobile-@2x.jpg","containers/LoginPage/images/login-bg-tablet-@1x.jpg","containers/LoginPage/images/login-bg-tablet-@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","theme/Logo-2025@2x.png","components/CustomComponents/Banners/RexelBanners.js","_platform/src/utils/PublicComponent.js","components/CustomComponents/Banners/images/Rexel-Logo@2x.png","components/CustomComponents/Banners/images/JohnRTurk-Logo@2x.png","components/CustomComponents/Banners/images/ideal-Logo@2x.png","components/CustomComponents/Banners/images/LearSmith-Logo@2x.png","components/CustomComponents/Banners/images/Login-JohnRTurk-Logo@2x.png","components/CustomComponents/Banners/images/Login-ideal-Logo@2x.png","components/CustomComponents/Banners/images/Login-LearSmith-Logo@2x.png"],"names":["pageQueryString","qs","parse","history","location","search","replace","ignoreQueryPrefix","LoginProvider","LoadAsync","__webpack_require__","e","then","bind","LoginForm","Promise","all","PageContainer","styled","div","_templateObject","th","bgMobile1x","bgMobile2x","up","css","_templateObject2","bgTablet1x","bgTablet2x","_templateObject3","bgDesktop1x","bgDesktop2x","LoginLogo","h1","_templateObject4","_templateObject5","_templateObject6","IntroContainer","_templateObject7","_templateObject8","LoginContainer","_templateObject9","thd","_templateObject10","NewPageContainer","_templateObject11","_templateObject12","withTheme","withSettings","_ref","settings","react_default","a","createElement","PublicComponent","redirectOnError","getReturnUrlPath","settingsApp","loginPagePath","Helmet_default","RexelBanners","onWhite","smooth_ui_core_sc_es","className","src","logo","alt","xs","sm","osm","lg","olg","href","disableMeta","formLabels","labelUserName","labelPassword","module","exports","p","StyledAlert","Alert","Title","Multiline","MessageBox","children","_ref$title","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","PrivateComponent","_this$props","props","deniedPermissions","deniedRoles","displayError","errorMessage","publicOnly","tempAuthAllowed","user","_this$props2","currentUserTemp","UnauthorisedComponent","RedirectOnErrorComponent","react_router","push","to","userObject","token","userId","Component","mapStateToProps","createStructuredSelector","selectCurrentUser","selectCurrentUserTemp","connect","BannerContainer","_smooth_ui_core_sc__WEBPACK_IMPORTED_MODULE_3__","justifyContent","RexelLogo","JRTLogoOnWhite","JRTLogo","IdealLogoOnWhite","IdealLogo","LSLogoOnWhite","LSLogo","react__WEBPACK_IMPORTED_MODULE_0__","react__WEBPACK_IMPORTED_MODULE_0___default","n","_PrivateComponent__WEBPACK_IMPORTED_MODULE_1__","Object","assign"],"mappings":"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","file":"static/js/loginPage.6d8dd835.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';\n\n// Style, SEO and settings\nimport Helmet from 'react-helmet';\nimport {\n Col,\n css,\n Grid,\n Row,\n up,\n styled,\n th,\n thd,\n withTheme,\n} from '@smooth-ui/core-sc';\n\n// Additional Components/Containers\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 bgDesktop1x from './images/login-bg-@1x.jpg';\nimport bgDesktop2x from './images/login-bg-@2x.jpg';\nimport bgMobile1x from './images/login-bg-mobile-@1x.jpg';\nimport bgMobile2x from './images/login-bg-mobile-@2x.jpg';\nimport bgTablet1x from './images/login-bg-tablet-@1x.jpg';\nimport bgTablet2x from './images/login-bg-tablet-@2x.jpg';\nimport logo from '../../theme/Logo-2025@2x.png';\n\nimport RexelBanners from '../../components/CustomComponents/Banners/RexelBanners';\n\nconst LoginProvider = LoadAsync(() =>\n import(/* webpackChunkName: \"loginProvider\" */ '../RexelLogin/LoginProvider')\n);\nconst LoginForm = LoadAsync(() =>\n import(/* webpackChunkName: \"loginForm\" */ '../RexelLogin/LoginForm')\n);\n\nconst PageContainer = styled.div`\n align-items: center;\n background-color: ${th('primary')};\n background-image: url(${bgMobile1x});\n background-position: center center;\n background-repeat: no-repeat;\n background-size: cover;\n display: flex;\n flex: 1 0 auto;\n flex-direction: column;\n justify-content: center;\n padding-bottom: 40px;\n padding-top: 40px;\n\n h4 {\n margin-top: 0;\n }\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 ${up(\n 'sm',\n css`\n background-image: url(${bgTablet1x});\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(${bgTablet2x});\n }\n `\n )}\n ${up(\n 'lg',\n css`\n background-image: url(${bgDesktop1x});\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 background-color: ${th('primary')};\n }\n `\n )}\n`;\n\nconst LoginLogo = styled.h1`\n margin-bottom: 0;\n margin-top: 0;\n padding-bottom: 1rem;\n padding-top: 0;\n color: white;\n display: flex;\n justify-self: center;\n align-items: center;\n flex-direction: column;\n ${up(\n 'md',\n css`\n flex-direction: row;\n font-size: 45px;\n `\n )};\n img {\n max-height: 200px;\n width: auto;\n padding: 10px;\n\n ${up(\n 'md',\n css`\n max-height: 300px;\n `\n )};\n }\n`;\n\nconst IntroContainer = styled.div`\n background-color: rgba(0, 0, 0, 0.2);\n box-sizing: border-box;\n color: #fff;\n margin-bottom: 0.5rem;\n margin-top: 0.5rem;\n padding: 1rem 0.5rem;\n border-radius: 20px;\n ${up(\n 'md',\n css`\n padding: 3rem 2rem;\n border-radius: 60px;\n `\n )};\n p {\n color: #fff;\n }\n a {\n color: #fff;\n &:hover {\n text-decoration: none;\n }\n &:visited {\n color: #fff;\n }\n }\n\n .warning {\n color: #dc3545;\n font-weight: bold;\n text-align: center;\n }\n\n .link-button-container {\n padding-top: 0;\n text-align: right;\n\n .forgot-username-button,\n .forgot-password-button,\n .registration-button {\n padding: 0 !important;\n color: #fff;\n text-decoration: underline;\n cursor: pointer;\n &:hover {\n text-decoration: none;\n }\n }\n }\n`;\n\nconst LoginContainer = styled.div`\n max-width: 500px;\n margin: 0 auto;\n\n label[for='username'],\n label[for='password'] {\n clip: rect(0 0 0 0);\n clip-path: inset(50%);\n height: 1px;\n overflow: hidden;\n position: absolute;\n white-space: nowrap;\n width: 1px;\n }\n\n .link-button-container {\n margin-bottom: 1em;\n }\n\n .reset-password {\n a {\n font-size: 14px;\n font-weight: normal;\n }\n }\n\n button {\n width: 170px;\n background-color: white;\n border: 1px solid white;\n color: ${thd('primary', '#0154C4')};\n &:hover,\n &:focus {\n color: white;\n background-color: ${thd('primary', '#0154C4')};\n }\n }\n\n ${up(\n 'lg',\n css`\n min-width: 300px;\n `\n )};\n`;\n\nconst NewPageContainer = styled.div`\n font-size: 16px;\n\n h2 {\n font-size: 16px;\n\n ${up(\n 'lg',\n css`\n margin-top: 0px;\n `\n )};\n }\n\n h4 {\n margin-bottom: 0;\n }\n\n h4 + p {\n margin-top: 0;\n }\n`;\n\nconst LoginPage = ({ settings }) => (\n \n \n Login\n {/**/}\n \n\n \n \n \n \n \n \"\"\n \n Welcome to\n
\n Rexel Online Advantage\n
\n
\n\n \n \n \n \n

The Program

\n

\n Promotion Period: 1 March - 30 November 2025\n

\n\n

\n Spend $500 + GST Online, on one order with the\n participating vendor(s) and earn a $50 e-gift card.\n

\n

\n You can earn gift cards on multiple purchases, as long as\n each order achieves the spend requirement.{' '}\n Limited to 4 e-gift cards per month.\n

\n

\n Plus for every e-giftcard received earn an entry into the{' '}\n Mega Cash Draw.\n

\n

Terms and conditions apply, log in for more details.

\n\n

\n For program queries phone:{' '}\n \n 1800 845 034\n {' '}\n or email{' '}\n \n info@rexelonlineadvantage.com.au\n \n

\n

\n For log in queries email{' '}\n \n marketing@rexelha.com.au\n \n

\n \n \n \n

Login

\n

Please login below using your webstore details.

\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/login-bg-@1x.bf862a15.jpg\";","module.exports = __webpack_public_path__ + \"static/media/login-bg-@2x.5f6232a8.jpg\";","module.exports = __webpack_public_path__ + \"static/media/login-bg-mobile-@1x.e8533749.jpg\";","module.exports = __webpack_public_path__ + \"static/media/login-bg-mobile-@2x.8dc3aee8.jpg\";","module.exports = __webpack_public_path__ + \"static/media/login-bg-tablet-@1x.940361f9.jpg\";","module.exports = __webpack_public_path__ + \"static/media/login-bg-tablet-@2x.b44bf93e.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","module.exports = __webpack_public_path__ + \"static/media/Logo-2025@2x.2f759219.png\";","import React from 'react';\nimport PropTypes from 'prop-types';\n\n// Style and SEO\nimport { styled, Grid, Col, Row, up, css } from '@smooth-ui/core-sc';\nimport RexelLogo from './images/Rexel-Logo@2x.png';\nimport JRTLogo from './images/JohnRTurk-Logo@2x.png';\nimport IdealLogo from './images/ideal-Logo@2x.png';\nimport LSLogo from './images/LearSmith-Logo@2x.png';\n\nimport JRTLogoOnWhite from './images/Login-JohnRTurk-Logo@2x.png';\nimport IdealLogoOnWhite from './images/Login-ideal-Logo@2x.png';\nimport LSLogoOnWhite from './images/Login-LearSmith-Logo@2x.png';\n\nimport { withSettings } from 'containers/WebApp/SettingsContext';\n\nconst BannerContainer = styled.div`\n margin: 10px 0 20px;\n\n ${up(\n 'sm',\n css`\n margin: 2em;\n `\n )}\n\n .align__logo {\n text-align: center;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n\n img {\n width: 80%;\n height: auto;\n max-width: 150px;\n margin: 10px 0;\n\n &.turk__logo {\n max-width: none;\n }\n }\n`;\n\nconst RexelBanners = props => (\n \n \n \n \n \n \n \n \"Rexel\"\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n);\n\nRexelBanners.propTypes = {\n onWhite: PropTypes.bool,\n};\n\nexport default withSettings(RexelBanners);\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","module.exports = \"\"","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/ideal-Logo@2x.2d0545b3.png\";","module.exports = __webpack_public_path__ + \"static/media/LearSmith-Logo@2x.2be112c8.png\";","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/Login-ideal-Logo@2x.26ceefbb.png\";","module.exports = __webpack_public_path__ + \"static/media/Login-LearSmith-Logo@2x.107d2c37.png\";"],"sourceRoot":""}