{"version":3,"sources":["assets/via_logo.png","assets/download_app_store.png","assets/download_google_play.png","App.js","serviceWorker.js","index.js"],"names":["module","exports","styles","root","width","textAlign","container","display","alignContent","justifyContent","flexDirection","height","message","margin","downloadImageContainer","downloadImageAndroid","maxWidth","downloadImageIOS","App","useState","modalOpen","setModalOpen","redirectUrl","setRedirectUrl","DownloadButton","style","href","img","alt","src","useEffect","pathName","window","location","pathname","replace","Platform","OS","packageName","hostname","includes","some","os","handleClose","ViaLogo","title","rules","Dialog","open","onClose","aria-labelledby","aria-describedby","DialogTitle","id","DialogContent","DialogContentText","DialogActions","Button","onClick","color","Link","component","autoFocus","DownloadGoogleAppImage","DownloadAppStoreImage","Boolean","match","ReactDOM","render","StrictMode","document","getElementById","navigator","serviceWorker","ready","then","registration","unregister","catch","error","console"],"mappings":"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","file":"static/js/main.01b3ac9a.chunk.js","sourcesContent":["module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","import React, { useState, useEffect } from \"react\";\nimport Platform from \"react-platform-js\";\nimport ViaLogo from \"./assets/via_logo.png\";\nimport DownloadAppStoreImage from \"./assets/download_app_store.png\";\nimport DownloadGoogleAppImage from \"./assets/download_google_play.png\";\n\nimport Button from \"@material-ui/core/Button\";\nimport Link from \"@material-ui/core/Link\";\nimport Dialog from \"@material-ui/core/Dialog\";\nimport DialogActions from \"@material-ui/core/DialogActions\";\nimport DialogContent from \"@material-ui/core/DialogContent\";\nimport DialogContentText from \"@material-ui/core/DialogContentText\";\nimport DialogTitle from \"@material-ui/core/DialogTitle\";\n\nconst styles = {\n root: {\n width: \"100%\",\n textAlign: \"center\",\n },\n container: {\n display: \"flex\",\n alignContent: \"center\",\n justifyContent: \"center\",\n flexDirection: \"column\",\n height: \"100vh\",\n },\n message: {\n margin: \"40px\",\n },\n downloadImageContainer: {\n width: \"100%\",\n },\n downloadImageAndroid: {\n width: \"80%\",\n maxWidth: \"345px\",\n },\n downloadImageIOS: {\n width: \"80%\",\n maxWidth: \"300px\",\n },\n};\n\nfunction App() {\n const [modalOpen, setModalOpen] = useState(false);\n const [redirectUrl, setRedirectUrl] = useState(null);\n\n const DownloadButton = ({ style, href, img }) => {\n return (\n
\n \n \"Download\n \n
\n );\n };\n\n useEffect(() => {\n const scheme = \"viadrivethru\";\n const pathName = window.location.pathname.replace(/^\\/?(.+)\\/?$/, \"$1\");\n\n if (Platform.OS === \"iOS\") {\n setRedirectUrl(`${scheme}://${pathName}`);\n } else if (Platform.OS === \"Android\") {\n setModalOpen(true);\n\n let packageName = \"com.viaDriveThru\";\n\n if (window.location.hostname.includes(\"via-eg-staging.herokuapp.com\")) {\n packageName = `${packageName}Test`;\n }\n\n setRedirectUrl(\n `intent://${pathName}#Intent;scheme=${scheme};package=${packageName};end`\n );\n }\n }, []);\n\n useEffect(() => {\n if (redirectUrl) {\n window.location = redirectUrl;\n }\n }, [redirectUrl]);\n\n if (![\"Android\", \"iOS\"].some((os) => Platform.OS === os)) {\n window.location = \"https://via-eg.com\";\n return null;\n }\n\n const handleClose = () => {\n setModalOpen(false);\n };\n\n return (\n
\n
\n
\n
\n \"Via\"\n
\n\n

\n To use Via, you need the app. Please download it below.\n

\n\n {redirectUrl && (\n \n )}\n\n \n \n \n {\"Open in Via?\"}\n \n \n \n Open this page in Via application?\n \n \n \n \n\n \n Open\n \n \n \n\n \n \n\n \n \n \n
\n
\n
\n );\n}\n\nexport default App;\n","// 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.0/8 are 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 headers: { 'Service-Worker': 'script' },\n })\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\n .then(registration => {\n registration.unregister();\n })\n .catch(error => {\n console.error(error.message);\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(\n \n \n ,\n document.getElementById('root')\n);\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"],"sourceRoot":""}