{"version":3,"sources":["components/images/white-on-blue.jpg","components/NavMenu.js","components/Layout.js","components/Home.js","components/SetUpAccount.js","App.js","registerServiceWorker.js","index.js"],"names":["module","exports","NavMenu","role","id","className","src","NHSLogo","width","height","alt","href","Component","displayName","name","Layout","tabIndex","this","props","children","Home","state","loading","a","fetch","then","response","text","data","setState","page","contents","parse","SetUpAccount","account_type_choice","replace","domNode","attribs","onchange","onChange","value","App","exact","path","component","window","location","isLocalhost","Boolean","hostname","match","registerValidSW","swUrl","navigator","serviceWorker","register","registration","onupdatefound","installingWorker","installing","onstatechange","controller","console","log","catch","error","baseUrl","document","getElementsByTagName","getAttribute","rootElement","getElementById","ReactDOM","render","basename","URL","process","origin","addEventListener","status","headers","get","indexOf","ready","unregister","reload","checkValidServiceWorker","registerServiceWorker"],"mappings":"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","file":"static/js/main.d3bbd44c.chunk.js","sourcesContent":["module.exports = \"\"","import React, { Component } from 'react';\r\nimport './css/govuk-template.css';\r\nimport './css/custom.css';\r\nimport NHSLogo from './images/white-on-blue.jpg';\r\n\r\nexport class NavMenu extends Component {\r\n static displayName = NavMenu.name;\r\n\r\n render() {\r\n return (\r\n <header role=\"banner\" id=\"global-header\" className=\"with-proposition\">\r\n <div className=\"header-wrapper\">\r\n <div className=\"header-global\">\r\n <div className=\"header-logo\">\r\n <img src={NHSLogo} width=\"113\" height=\"51\"className=\"content\" alt=\"NHS logo\"/>\r\n </div>\r\n </div>\r\n <div className=\"header-proposition\">\r\n <div className=\"content\">\r\n <nav id=\"proposition-menu\">\r\n <a href=\"/\" id=\"proposition-name\">\r\n Access recorded patient safety event data\r\n </a>\r\n </nav>\r\n </div>\r\n </div>\r\n </div>\r\n </header>\r\n );\r\n }\r\n}\r\n","import React, { Component } from 'react';\r\nimport { NavMenu } from './NavMenu';\r\n\r\nexport class Layout extends Component {\r\n static displayName = Layout.name;\r\n\r\n render() {\r\n return (\r\n <div>\r\n <NavMenu />\r\n <div id=\"global-header-bar\"></div>\r\n <main role=\"main\" id=\"content\" tabIndex=\"-1\">\r\n <div className=\"phase-banner\">\r\n <p>\r\n <strong className=\"phase-tag\">Beta</strong>\r\n <span> This is a new service - <a href=\"mailto:itservicedesk@england.nhs.uk\">email us your feedback</a> will help us to improve it.</span>\r\n </p>\r\n </div>\r\n {this.props.children}\r\n </main>\r\n <footer className=\"group js-footer\" id=\"footer\" role=\"contentinfo\">\r\n <div className=\"footer-wrapper\">\r\n <div className=\"footer-meta\">\r\n <p className=\"flat-menu\">\r\n <a href=\"https://improvement.nhs.uk/cookies/\" className=\"menu-padded\">Cookies</a>\r\n <a href=\"https://improvement.nhs.uk/accessibility/\">Accessibility</a>\r\n </p>\r\n </div>\r\n </div>\r\n </footer>\r\n </div>\r\n );\r\n }\r\n}\r\n","import React, { Component } from 'react';\r\nimport parse from 'html-react-parser';\r\nimport './css/base.css';\r\n\r\nexport class Home extends Component {\r\n static displayName = Home.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n this.state = { loading: true };\r\n\r\n (async () => fetch('api/Home/GetPage?pageName=Home')\r\n .then(response => response.text())\r\n .then(data => {\r\n this.setState({ page: data, loading: false });\r\n }))();\r\n }\r\n\r\n render() {\r\n let contents = this.state.loading\r\n ? ''\r\n : this.state.page;\r\n\r\n return (<div className=\"grid-row\">\r\n {parse(contents)}\r\n </div>);\r\n }\r\n}\r\n","import React, { Component } from 'react';\r\nimport parse from 'html-react-parser';\r\nimport './css/base.css';\r\nimport './css/custom.css';\r\n\r\nexport class SetUpAccount extends Component {\r\n constructor(props) {\r\n super(props);\r\n this.state = {\r\n account_type_choice: '',\r\n loading: true\r\n };\r\n\r\n (async () => fetch('api/Home/GetPage?pageName=SetUpAccount')\r\n .then(response => response.text())\r\n .then(data => {\r\n this.setState({ page: data, loading: false });\r\n }))();\r\n }\r\n\r\n render() {\r\n let contents = this.state.loading\r\n ? ''\r\n : this.state.page;\r\n\r\n return (\r\n <div className=\"grid-row\" id=\"actionForm\">\r\n <div className=\"column-full\">\r\n <a href=\"#\" className=\"link-back\" id=\"back\">Back</a>\r\n </div>\r\n <div className=\"column-two-thirds\">\r\n {parse(contents, {\r\n replace: domNode => {\r\n if (domNode.name === 'input') {\r\n delete domNode.attribs.onchange;\r\n return (\r\n <input\r\n {...domNode.attribs}\r\n onChange={() => {\r\n this.setState({\r\n account_type_choice: domNode.attribs.value\r\n })}}\r\n />\r\n );\r\n }\r\n }\r\n })}\r\n <div className=\"form-group\">\r\n <a href={this.state.account_type_choice === 'connect' ? '/connect' : '/create'} className=\"button\">Continue</a>\r\n </div>\r\n </div>\r\n </div>\r\n )\r\n }\r\n}","import React, { Component } from 'react';\r\nimport { Route } from 'react-router';\r\nimport { Layout } from './components/Layout';\r\nimport { Home } from './components/Home';\r\nimport { SetUpAccount } from './components/SetUpAccount';\r\n\r\nimport './custom.css'\r\n\r\nexport default class App extends Component {\r\n static displayName = App.name;\r\n\r\n render () {\r\n return (\r\n <Layout>\r\n <Route exact path='/' component={Home} />\r\n <Route exact path='/SetUpAccount' component={SetUpAccount} />\r\n <Route path='/connect' component={() => {\r\n window.location.href = 'https://apps.model.nhs.uk';\r\n return null;\r\n }} />\r\n <Route path='/create' component={() => {\r\n window.location.href = 'https://apps.model.nhs.uk/register';\r\n return null;\r\n }} />\r\n </Layout>\r\n );\r\n }\r\n}\r\n","// In production, we register a service worker to serve assets from local cache.\r\n\r\n// This lets the app load faster on subsequent visits in production, and gives\r\n// it offline capabilities. However, it also means that developers (and users)\r\n// will only see deployed updates on the \"N+1\" visit to a page, since previously\r\n// cached resources are updated in the background.\r\n\r\n// To learn more about the benefits of this model, read https://goo.gl/KwvDNy.\r\n// This link also includes instructions on opting out of this behavior.\r\n\r\nconst isLocalhost = Boolean(\r\n window.location.hostname === 'localhost' ||\r\n // [::1] is the IPv6 localhost address.\r\n window.location.hostname === '[::1]' ||\r\n // 127.0.0.1/8 is considered localhost for IPv4.\r\n window.location.hostname.match(\r\n /^127(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/\r\n )\r\n);\r\n\r\nexport default function register () {\r\n if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) {\r\n // The URL constructor is available in all browsers that support SW.\r\n const publicUrl = new URL(process.env.PUBLIC_URL, window.location);\r\n if (publicUrl.origin !== window.location.origin) {\r\n // Our service worker won't work if PUBLIC_URL is on a different origin\r\n // from what our page is served on. This might happen if a CDN is used to\r\n // serve assets; see https://github.com/facebookincubator/create-react-app/issues/2374\r\n return;\r\n }\r\n\r\n window.addEventListener('load', () => {\r\n const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`;\r\n\r\n if (isLocalhost) {\r\n // This is running on localhost. Lets check if a service worker still exists or not.\r\n checkValidServiceWorker(swUrl);\r\n } else {\r\n // Is not local host. Just register service worker\r\n registerValidSW(swUrl);\r\n }\r\n });\r\n }\r\n}\r\n\r\nfunction registerValidSW (swUrl) {\r\n navigator.serviceWorker\r\n .register(swUrl)\r\n .then(registration => {\r\n registration.onupdatefound = () => {\r\n const installingWorker = registration.installing;\r\n installingWorker.onstatechange = () => {\r\n if (installingWorker.state === 'installed') {\r\n if (navigator.serviceWorker.controller) {\r\n // At this point, the old content will have been purged and\r\n // the fresh content will have been added to the cache.\r\n // It's the perfect time to display a \"New content is\r\n // available; please refresh.\" message in your web app.\r\n console.log('New content is available; please refresh.');\r\n } else {\r\n // At this point, everything has been precached.\r\n // It's the perfect time to display a\r\n // \"Content is cached for offline use.\" message.\r\n console.log('Content is cached for offline use.');\r\n }\r\n }\r\n };\r\n };\r\n })\r\n .catch(error => {\r\n console.error('Error during service worker registration:', error);\r\n });\r\n}\r\n\r\nfunction checkValidServiceWorker (swUrl) {\r\n // Check if the service worker can be found. If it can't reload the page.\r\n fetch(swUrl)\r\n .then(response => {\r\n // Ensure service worker exists, and that we really are getting a JS file.\r\n if (\r\n response.status === 404 ||\r\n response.headers.get('content-type').indexOf('javascript') === -1\r\n ) {\r\n // No service worker found. Probably a different app. Reload the page.\r\n navigator.serviceWorker.ready.then(registration => {\r\n registration.unregister().then(() => {\r\n window.location.reload();\r\n });\r\n });\r\n } else {\r\n // Service worker found. Proceed as normal.\r\n registerValidSW(swUrl);\r\n }\r\n })\r\n .catch(() => {\r\n console.log(\r\n 'No internet connection found. App is running in offline mode.'\r\n );\r\n });\r\n}\r\n\r\nexport function unregister () {\r\n if ('serviceWorker' in navigator) {\r\n navigator.serviceWorker.ready.then(registration => {\r\n registration.unregister();\r\n });\r\n }\r\n}\r\n","import React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport { BrowserRouter } from 'react-router-dom';\r\nimport App from './App';\r\nimport registerServiceWorker from './registerServiceWorker';\r\n\r\nconst baseUrl = document.getElementsByTagName('base')[0].getAttribute('href');\r\nconst rootElement = document.getElementById('root');\r\n\r\nReactDOM.render(\r\n <BrowserRouter basename={baseUrl}>\r\n <App />\r\n </BrowserRouter>,\r\n rootElement);\r\n\r\nregisterServiceWorker();\r\n\r\n"],"sourceRoot":""}