{"version":3,"sources":["App.js","serviceWorker.js","index.js","logo.png","logo-main.png"],"names":["querystring","require","getPathFromUrl","url","split","getHostname","parsed","parse","window","location","search","console","log","hostname","fqdn","host","App","props","redirect","e","state","selectValue","value","show","document","URL","href","origins","getOrigins","bind","setOrigins","notify","createShowQueue","packageJSON","name","version","fetch","config","originsURL","then","response","json","catch","this","setState","options","originCount","Object","keys","length","defaultHostname","notifyColour","background","text","className","src","logo","alt","logoMain","onChange","onClick","Component","Boolean","match","ReactDOM","render","getElementById","navigator","serviceWorker","ready","registration","unregister","module","exports"],"mappings":"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","file":"static/js/main.e834f632.chunk.js","sourcesContent":["import React, { Component } from 'react';\r\n\r\n// import components\r\nimport VirtualizedSelect from 'react-virtualized-select';\r\nimport Notifications, {notify} from 'react-notify-toast';\r\nimport Favicon from 'react-favicon';\r\n\r\n// import image assets\r\nimport logo from './logo.png';\r\nimport logoMain from './logo-main.png';\r\n\r\n// import style sheets\r\nimport './App.css';\r\nimport 'react-select/dist/react-select.css';\r\nimport 'react-virtualized-select/styles.css';\r\n\r\n// import config json\r\nimport packageJSON from '../package.json';\r\nimport config from './App.js.config.json';\r\n\r\n//const originsURL = 'https://assets.asosservices.com/landingpage/origins.json'\r\n\r\n// Instantiate query-string package\r\nconst querystring = require('query-string');\r\n\r\n// Parse the full URL to strip off query string parameters and return just the path\r\nfunction getPathFromUrl(url) {\r\n return url.split(\"?\")[0];\r\n}\r\n\r\n// Parse the URL and return the hostname we're served under\r\nfunction getHostname(){\r\n const parsed = querystring.parse(window.location.search);\r\n if ('hostname' in parsed) {\r\n console.log('parsed query string:', window.location.search, 'to use a domain of:', parsed.hostname);\r\n return parsed.hostname;\r\n } else {\r\n const fqdn = window.location.host;\r\n //const arrFqdn = fqdn.split('.');\r\n //const topdomain = arrFqdn[0];\r\n console.log('Parsed:', window.location.host, 'to use domain of:', fqdn);\r\n //return topdomain;\r\n return fqdn;\r\n }\r\n}\r\n\r\nclass App extends Component {\r\n\r\n // Initialise state\r\n constructor(props) {\r\n super(props);\r\n this.state = {\r\n selectValue: '',\r\n origins : {}\r\n };\r\n\r\n // Bind Origins\r\n this.getOrigins = this.getOrigins.bind(this);\r\n this.setOrigins = this.setOrigins.bind(this);\r\n\r\n // Create Notification queue, where notification message are placed\r\n this.show = notify.createShowQueue();\r\n\r\n console.log(packageJSON.name, 'version', packageJSON.version);\r\n }\r\n\r\n // Issue HTTP GET request to external origins json resource\r\n getOrigins() {\r\n fetch(config.originsURL)\r\n .then(response => response.json())\r\n .then(origins => this.setOrigins(origins))\r\n .catch(e => console.log(e));\r\n }\r\n\r\n setOrigins(origins) {\r\n this.setState({ origins });\r\n }\r\n\r\n componentDidMount() {\r\n this.getOrigins();\r\n }\r\n\r\n // redirect the browser\r\n redirect = (e) => {\r\n console.log('button clicked', this.state.selectValue.value);\r\n\r\n if (this.state.selectValue === '') {\r\n console.log('No environment selected');\r\n } else {\r\n this.show('Opening: ' + getPathFromUrl(document.URL) + '?x-site-origin=' + this.state.selectValue.value, 'success', 4000);\r\n console.log('The following x-site-origin will be used:', this.state.selectValue.value);\r\n // window.location.href will reuse the same browser tab/window\r\n // window.location.href = getPathFromUrl(document.URL) + '?x-site-origin=' + this.state.selectValue.value;\r\n // window.open will open a new browser tab/window\r\n // window.open(getPathFromUrl(document.URL) + '?x-site-origin=' + this.state.selectValue.value);\r\n\r\n //Launch URL\r\n window.location.href = getPathFromUrl(document.URL) + '?x-site-origin=' + this.state.selectValue.value;\r\n }\r\n }\r\n\r\n render() {\r\n // Get the hostname portion of the FQDN being used\r\n var hostname = getHostname();\r\n // Return only the json array of origins for the hostname\r\n var options = {};\r\n\r\n\r\n // Check if our json contains origin entries for the hostname\r\n if (this.state.origins[hostname]) {\r\n // We've got something, so an array with the hostname exists. Now count its elements\r\n const originCount = Object.keys(this.state.origins[hostname]).length;\r\n console.log('There are ' + originCount + ' origins configured for ' + hostname);\r\n // Make sure we've got at least one entry in the hostname's array\r\n if (originCount > 0) {\r\n // Return only the json array of origins for the hostname\r\n options = this.state.origins[hostname];\r\n } else {\r\n // The origin array for the hostname is empty, so use the default hostname\r\n options = this.state.origins[config.defaultHostname];\r\n }\r\n } else {\r\n // An array for the hostname doesn't exist, so uae the default hostname\r\n options = this.state.origins[config.defaultHostname];\r\n }\r\n\r\n let notifyColour = { background: '#FFFFFF', text: \"#23b9e7\" };\r\n\r\n return (\r\n
\r\n \r\n \r\n
\r\n \"logo\"/\r\n \"main\r\n

Asos non-production [{ getHostname() }]

\r\n
\r\n

\r\n Select an environment, or start typing to filter the options\r\n\r\n

\r\n\r\n \r\n\r\n {\r\n this.setState({ selectValue });\r\n if (selectValue !== null){\r\n console.log('Origin selected:', selectValue.value);\r\n this.show('x-site-origin: ' + selectValue.value, 'custom', 5000, notifyColour);\r\n }\r\n }}\r\n value={this.state.selectValue}\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 App;","// This optional code is used to register a service worker.\n// register() is not called by default.\n\n// This lets the app load faster on subsequent visits in production, and gives\n// it offline capabilities. However, it also means that developers (and users)\n// will only see deployed updates on subsequent visits to a page, after all the\n// existing tabs open on the page have been closed, since previously cached\n// resources are updated in the background.\n\n// To learn more about the benefits of this model and instructions on how to\n// opt-in, read https://bit.ly/CRA-PWA\n\nconst isLocalhost = Boolean(\n window.location.hostname === 'localhost' ||\n // [::1] is the IPv6 localhost address.\n window.location.hostname === '[::1]' ||\n // 127.0.0.1/8 is considered localhost for IPv4.\n window.location.hostname.match(\n /^127(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/\n )\n);\n\nexport function register(config) {\n if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) {\n // The URL constructor is available in all browsers that support SW.\n const publicUrl = new URL(process.env.PUBLIC_URL, window.location.href);\n if (publicUrl.origin !== window.location.origin) {\n // Our service worker won't work if PUBLIC_URL is on a different origin\n // from what our page is served on. This might happen if a CDN is used to\n // serve assets; see https://github.com/facebook/create-react-app/issues/2374\n return;\n }\n\n window.addEventListener('load', () => {\n const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`;\n\n if (isLocalhost) {\n // This is running on localhost. Let's check if a service worker still exists or not.\n checkValidServiceWorker(swUrl, config);\n\n // Add some additional logging to localhost, pointing developers to the\n // service worker/PWA documentation.\n navigator.serviceWorker.ready.then(() => {\n console.log(\n 'This web app is being served cache-first by a service ' +\n 'worker. To learn more, visit https://bit.ly/CRA-PWA'\n );\n });\n } else {\n // Is not localhost. Just register service worker\n registerValidSW(swUrl, config);\n }\n });\n }\n}\n\nfunction registerValidSW(swUrl, config) {\n navigator.serviceWorker\n .register(swUrl)\n .then(registration => {\n registration.onupdatefound = () => {\n const installingWorker = registration.installing;\n if (installingWorker == null) {\n return;\n }\n installingWorker.onstatechange = () => {\n if (installingWorker.state === 'installed') {\n if (navigator.serviceWorker.controller) {\n // At this point, the updated precached content has been fetched,\n // but the previous service worker will still serve the older\n // content until all client tabs are closed.\n console.log(\n 'New content is available and will be used when all ' +\n 'tabs for this page are closed. See https://bit.ly/CRA-PWA.'\n );\n\n // Execute callback\n if (config && config.onUpdate) {\n config.onUpdate(registration);\n }\n } else {\n // At this point, everything has been precached.\n // It's the perfect time to display a\n // \"Content is cached for offline use.\" message.\n console.log('Content is cached for offline use.');\n\n // Execute callback\n if (config && config.onSuccess) {\n config.onSuccess(registration);\n }\n }\n }\n };\n };\n })\n .catch(error => {\n console.error('Error during service worker registration:', error);\n });\n}\n\nfunction checkValidServiceWorker(swUrl, config) {\n // Check if the service worker can be found. If it can't reload the page.\n fetch(swUrl)\n .then(response => {\n // Ensure service worker exists, and that we really are getting a JS file.\n const contentType = response.headers.get('content-type');\n if (\n response.status === 404 ||\n (contentType != null && contentType.indexOf('javascript') === -1)\n ) {\n // No service worker found. Probably a different app. Reload the page.\n navigator.serviceWorker.ready.then(registration => {\n registration.unregister().then(() => {\n window.location.reload();\n });\n });\n } else {\n // Service worker found. Proceed as normal.\n registerValidSW(swUrl, config);\n }\n })\n .catch(() => {\n console.log(\n 'No internet connection found. App is running in offline mode.'\n );\n });\n}\n\nexport function unregister() {\n if ('serviceWorker' in navigator) {\n navigator.serviceWorker.ready.then(registration => {\n registration.unregister();\n });\n }\n}\n","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport './index.css';\nimport App from './App';\nimport * as serviceWorker from './serviceWorker';\n\nReactDOM.render(, document.getElementById('root'));\n\n// If you want your app to work offline and load faster, you can change\n// unregister() to register() below. Note this comes with some pitfalls.\n// Learn more about service workers: https://bit.ly/CRA-PWA\nserviceWorker.unregister();\n","module.exports = \"\"","module.exports = \"\""],"sourceRoot":""}