{"version":3,"sources":["features/UtilityComponents/UtilityComponent.module.scss","features/Workflows/Workflows.module.scss","features/Form/Form.module.css","features/Form/FormAPI.js","features/Form/FormSlice.js","features/RecommendedProducts/RecommendedProductsAPI.js","features/RecommendedProducts/RecommendedProductsSlice.js","app/store.js","features/UtilityComponents/Spinner.js","features/SingleQuestion/SingleQuestion.js","features/Form/Form.js","features/UtilityComponents/FailView.js","features/RecommendedProducts/RecommendedProducts.js","app/helpers.js","features/Workflows/WorkflowSelection.js","features/WrapperComponent/WrapperComponent.js","App.js","serviceWorker.js","index.js","features/SingleQuestion/SingleQuestion.module.scss","features/RecommendedProducts/RecommendedProducts.module.scss"],"names":["module","exports","getWorkFlowData","flowName","a","process","token","fetch","join","method","then","data","json","submitWorkflowAnswers","payload","headers","body","JSON","stringify","fetchQuestionsAsync","createAsyncThunk","workFlowName","response","submitQuestionsAsync","FormSlice","createSlice","name","initialState","status","step","currentFlowName","productCategory","questions","answers","error","productRecommendations","reducers","setWorkflowName","state","action","flow_name","addAnswer","existingAnswer","find","answer","question_key","value","push","editAnswer","nextStep","previousStep","extraReducers","builder","addCase","pending","fulfilled","parsedConfigFile","parse","JsonConfig","product_category","rejected","products","selectQuestions","form","selectRecommendations","selectWorkflow","actions","getBigCommerceProductsGraphQL","productIdsArray","query","credentials","res","fetchProductsInfoAsync","productsIds","rejectWithValue","productRecommendationSlice","productsBigCommerce","site","edges","selectBigCommerceRecommendations","big_commerce_products","selectBigCommerceRecommendationsStatus","store","configureStore","reducer","questionsReducer","Spinner","id","styles","loading","SingleQuestion","params","dispatch","useDispatch","useState","setInputValue","selectedOption","setSelectedOption","announcement","setAnnouncementValue","questionsCount","getState","length","question","questionNum","onInputChange","e","announcementValue","target","Object","entries","key","announce_text","announce_link","className","post_excerpt","text","values","map","thisValue","inputContainer","radio","htmlFor","type","onChange","checked","nanoid","button","onClick","renderBackButton","inputValue","isDisabled","disabled","workFlowAnswers","onSubmit","renderButton","Form","useSelector","formStatus","useEffect","FailView","fail","Recommendations","productsBigCommerceStatus","productStatus","productIDs","product_id","showProductRatingTag","ratedProducts","rating","filter","el","recommendations","product","i","recommendation","ratingTag","node","entityId","src","defaultImage","alt","plainTextDescription","price","prices","href","addToCartUrl","addToCart","path","learnMoreBtn","renderRecommendations","renderView","WorkflowSelection","allWorkFlows","thisStoreWorkflows","split","flows","currentFlow","toLocaleUpperCase","getWorkflows","projects","workflows","each","image","title","WrapperComponent","hasProductRecommendations","hasSelectedWorkflow","App","Boolean","window","location","hostname","match","ReactDOM","render","StrictMode","document","getElementById","navigator","serviceWorker","ready","registration","unregister"],"mappings":"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","file":"static/js/main.425c6763.chunk.js","sourcesContent":["// extracted by mini-css-extract-plugin\nmodule.exports = {\"loading\":\"UtilityComponent_loading__2epsU\",\"spin\":\"UtilityComponent_spin__hIyFH\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"workflows\":\"Workflows_workflows__3Et42\",\"projects\":\"Workflows_projects__3DKHH\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"form\":\"Form_form__2HhZM\"};","export const getWorkFlowData = async (flowName) => {\n \n const storeHash = process.env.REACT_APP_STORE_HASH;\n const token = process.env[\"REACT_APP_STORE_FRONT_API_TOKEN_\" + storeHash] \n\n return fetch([process.env.REACT_APP_API_BASE, 'workflows/names', flowName ].join('/'), {\n \"headers\": {\n \"signed-payload\": token\n },\n method: 'GET'\n })\n .then(data => data.json() );\n}\n\n\nexport const submitWorkflowAnswers = async (payload) => {\n\n const storeHash = process.env.REACT_APP_STORE_HASH;\n const token = process.env[\"REACT_APP_STORE_FRONT_API_TOKEN_\" + storeHash] \n\n return fetch([process.env.REACT_APP_API_BASE, 'products/recommendations'].join('/'), {\n headers: {\n 'Content-Type': 'application/json',\n \"signed-payload\": token\n },\n method: 'POST',\n body: JSON.stringify(payload)\n }).then(data => data.json());\n}","import { createAsyncThunk, createSlice } from '@reduxjs/toolkit';\nimport { getWorkFlowData, submitWorkflowAnswers } from './FormAPI';\n\n\nconst initialState = {\n status: 'idle',\n step: 1,\n currentFlowName: \"\",\n productCategory: \"\",\n questions: [],\n answers: [],\n error: null,\n productRecommendations: null\n};\n\nexport const fetchQuestionsAsync = createAsyncThunk(\n 'form/loadQuestions',\n async (workFlowName) => {\n const response = await getWorkFlowData(workFlowName);\n return response;\n }\n);\n\nexport const submitQuestionsAsync = createAsyncThunk(\n 'form/submitQuestions',\n async (data) => {\n const response = await submitWorkflowAnswers(data);\n return response;\n }\n);\n\nexport const FormSlice = createSlice({\n name: 'form',\n initialState,\n reducers: {\n setWorkflowName: (state, action) => {\n state.currentFlowName = action.payload.flow_name\n },\n addAnswer: (state, action) => {\n const existingAnswer = state.answers.find(answer => answer.question_key === action.payload.question_key)\n if (existingAnswer) {\n existingAnswer.question_key = action.payload.question_key\n existingAnswer.value = action.payload.value\n } else {\n state.answers.push(action.payload)\n }\n },\n editAnswer: (state, action) => {\n const existingAnswer = state.answers.find(answer => answer.question_key === action.payload.question_key)\n if (existingAnswer) {\n existingAnswer.question_key = action.payload.question_key\n existingAnswer.value = action.payload.value\n }\n },\n nextStep: (state, action) => {\n state.step += 1\n },\n previousStep: (state) => {\n state.step -= 1\n }\n },\n // The `extraReducers` field lets the slice handle actions defined elsewhere,\n // including actions generated by createAsyncThunk or in other slices.\n extraReducers: (builder) => {\n builder\n .addCase(fetchQuestionsAsync.pending, (state) => {\n state.status = 'loading';\n })\n .addCase(fetchQuestionsAsync.fulfilled, (state, action) => {\n const parsedConfigFile = JSON.parse(action.payload.JsonConfig);\n state.questions = parsedConfigFile.questions;\n state.status = 'succeeded';\n state.productCategory = parsedConfigFile.product_category;\n })\n .addCase(fetchQuestionsAsync.rejected, (state, action) => {\n state.status = 'failed'\n state.error = \"Sorry, there has been an error loading questions.\"\n })\n .addCase(submitQuestionsAsync.pending, (state) => {\n state.status = 'loading';\n })\n .addCase(submitQuestionsAsync.fulfilled, (state, action) => {\n state.status = 'succeeded';\n state.productRecommendations = action.payload.products;\n })\n .addCase(submitQuestionsAsync.rejected, (state, action) => {\n state.status = 'failed'\n state.error = \"Sorry, there has been an error getting product recommendations.\"\n })\n },\n});\n\nexport const selectQuestions = state => state.form.questions;\nexport const selectRecommendations = state => state.form.productRecommendations;\nexport const selectWorkflow = state => state.form.currentFlowName;\n\nexport const { setWorkflowName, addAnswer, editAnswer, nextStep, previousStep } = FormSlice.actions;\n\nexport default FormSlice.reducer;","export function getBigCommerceProductsGraphQL(productIdsArray) {\n \n const token = process.env[\"REACT_APP_STORE_FRONT_API_TOKEN_\" + process.env.REACT_APP_STORE_HASH];\n const bcURL = process.env.REACT_APP_API_BIG_COMMERCE_BASE;\n \n const query = `\n query SingleProduct {\n site {\n products (entityIds: [${productIdsArray}]) {\n edges {\n node {\n path\n addToCartUrl\n id\n entityId\n name\n description\n plainTextDescription\n defaultImage {\n urlOriginal\n }\n prices {\n price {\n value\n currencyCode\n }\n }\n }\n }\n }\n }\n }\n `\n\n return fetch([bcURL, \"graphql\"].join('/'), {\n method: 'POST',\n credentials: 'include',\n headers: {\n 'Content-Type': 'application/json',\n 'Authorization': `Bearer ${token}`\n },\n body: JSON.stringify({ query: query})\n })\n .then(res => res.json())\n //.then(res => res.data);\n}","import { createAsyncThunk, createSlice } from '@reduxjs/toolkit';\nimport { getBigCommerceProductsGraphQL } from './RecommendedProductsAPI';\n\n\nconst initialState = {\n status: 'idle',\n error: null,\n productsBigCommerce: []\n};\n\nexport const fetchProductsInfoAsync = createAsyncThunk(\n 'form/loadProducts',\n async (productsIds, { rejectWithValue }) => {\n\n try {\n const response = await getBigCommerceProductsGraphQL(productsIds);\n return response;\n } catch(err){\n return rejectWithValue(err.response.data)\n }\n }\n);\n\n\nexport const productRecommendationSlice = createSlice({\n name: 'products',\n initialState,\n extraReducers: (builder) => {\n builder\n .addCase(fetchProductsInfoAsync.pending, (state) => {\n state.status = 'loading';\n })\n .addCase(fetchProductsInfoAsync.fulfilled, (state, action) => {\n state.status = 'succeeded';\n state.productsBigCommerce = action.payload.data.site.products.edges;\n })\n .addCase(fetchProductsInfoAsync.rejected, (state, action) => {\n state.status = 'failed'\n state.error = \"Sorry, there has been an error retrieveing product recommendations.\"\n })\n },\n});\n\nexport const selectBigCommerceRecommendations = state => state.big_commerce_products.productsBigCommerce;\nexport const selectBigCommerceRecommendationsStatus = state => state.big_commerce_products.status;\n\nexport default productRecommendationSlice.reducer;","import { configureStore } from '@reduxjs/toolkit';\nimport questionsReducer from '../features/Form/FormSlice';\nimport productRecommendationSlice from '../features/RecommendedProducts/RecommendedProductsSlice';\n\nexport const store = configureStore({\n reducer: {\n form: questionsReducer,\n big_commerce_products: productRecommendationSlice\n },\n});\n","import styles from './UtilityComponent.module.scss';\n\nexport function Spinner() {\n return (\n
\n )\n}","import React, { useState } from 'react';\nimport { useDispatch } from 'react-redux';\nimport { addAnswer } from '../Form/FormSlice';\nimport { nanoid } from '@reduxjs/toolkit';\nimport { store } from '../../app/store';\nimport { nextStep, submitQuestionsAsync, previousStep } from '../Form/FormSlice';\nimport { Spinner } from '../UtilityComponents/Spinner';\nimport styles from './SingleQuestion.module.scss';\n\nexport const SingleQuestion = (params) => {\n\n const dispatch = useDispatch();\n\n const [ value, setInputValue] = useState('');\n const [ selectedOption, setSelectedOption ] = useState('');\n const [ announcement, setAnnouncementValue] = useState('');\n\n const questionsCount = (store.getState()).form.questions.length;\n const question = (store.getState()).form.questions[params.questionNum - 1];\n\n\n const onPreviousClick = () => {\n dispatch(\n previousStep()\n )\n setInputValue(null);\n setSelectedOption(null);\n setAnnouncementValue(null);\n }\n\n const onNextClick = () => {\n if(params.questionNum < questionsCount){\n dispatch(\n nextStep()\n )\n setInputValue(null);\n setAnnouncementValue(null);\n setSelectedOption(null);\n }\n }\n\n const onInputChange = (e, question_key) => {\n\n setInputValue(e.target.value);\n setSelectedOption(e.target.value);\n\n let announcementValue;\n\n for (const [key, value] of Object.entries(question.actions)) {\n if(e.target.value === key){\n if(value.announcement) announcementValue = value.announcement;\n }\n }\n\n if(announcementValue){\n setAnnouncementValue(announcementValue.announce_text + \" \" + announcementValue.announce_link);\n } else {\n setAnnouncementValue(null);\n }\n\n if(e.target.value){\n dispatch(\n addAnswer({\n question_key: question_key,\n value: e.target.value\n })\n )\n }\n }\n\n const onSubmit = () => {\n\n const workFlowAnswers = store.getState().form.answers;\n const flow_name = store.getState().form.currentFlowName;\n const product_category = store.getState().form.productCategory;\n\n dispatch(\n submitQuestionsAsync({\n \"flow_name\": flow_name,\n \"product_category\" : product_category,\n \"responses\": workFlowAnswers\n })\n )\n }\n\n if (!question) {\n return (\n \n )\n }\n\n const renderBackButton = () => {\n if(params.questionNum !== 1){\n return \n }\n }\n\n const renderButton = (question_key, inputValue) => {\n let isDisabled = inputValue ? false : true;\n\n if(params.questionNum === questionsCount){\n return \n } else {\n return \n }\n }\n\n return (\n
\n
\n

{question.text}

\n
\n {question.values.map((thisValue) => {\n if(thisValue.text && thisValue.value){\n return
\n \n
\n } else {\n return
\n \n
\n }\n })}\n
\n { announcement\n ?
{announcement}
\n : null\n }\n { renderBackButton() }\n { renderButton(question.question_key, value) }\n
\n
\n )\n}","import React, { useEffect } from 'react';\nimport { useSelector, useDispatch } from 'react-redux';\nimport styles from './Form.module.css';\nimport { selectQuestions, fetchQuestionsAsync, selectWorkflow } from './FormSlice';\nimport { SingleQuestion } from '../SingleQuestion/SingleQuestion';\nimport { Spinner } from '../UtilityComponents/Spinner';\n\n\nexport function Form() {\n\n const dispatch = useDispatch();\n const questions = useSelector(selectQuestions);\n const workFlowName = useSelector(selectWorkflow);\n\n const step = useSelector(state => state.form.step);\n const formStatus = useSelector(state => state.form.status);\n\n useEffect(() => {\n if (formStatus === 'idle') {\n dispatch(fetchQuestionsAsync(workFlowName))\n }\n }, [dispatch]);\n \n return (\n
\n { questions.length > 0 \n ?
\n

Get Qualified

\n

Step { step } out of { questions.length }

\n \n
\n : \n }\n
\n );\n}","import styles from './UtilityComponent.module.scss';\n\nexport function FailView() {\n return (\n
Sorry, we were unable to retrieve product recommendations.
\n )\n}","import React, { useEffect } from 'react';\nimport { useSelector, useDispatch } from 'react-redux';\nimport { fetchProductsInfoAsync } from './RecommendedProductsSlice';\nimport { selectBigCommerceRecommendations, selectBigCommerceRecommendationsStatus } from './RecommendedProductsSlice';\nimport { Spinner } from '../UtilityComponents/Spinner';\nimport { FailView } from '../UtilityComponents/FailView';\nimport { DefaultView } from '../UtilityComponents/DefaultView';\nimport styles from './RecommendedProducts.module.scss';\n\n\nexport function Recommendations() {\n\n const dispatch = useDispatch();\n const productsBigCommerce = useSelector(selectBigCommerceRecommendations);\n const productsBigCommerceStatus = useSelector(selectBigCommerceRecommendationsStatus);\n\n const productRecommendations = useSelector((state) => state.form.productRecommendations);\n const productStatus = useSelector(state => state.big_commerce_products.status);\n const productIDs = productRecommendations.map(({product_id}) => product_id);\n\n\n const showProductRatingTag = ( id ) => {\n\n let ratedProducts = [];\n\n if(productRecommendations[0]){\n ratedProducts.push({\n rating: 1,\n product_id: productRecommendations[0].product_id,\n text: \"BEST\"\n })\n }\n\n if(productRecommendations[1]){\n ratedProducts.push({\n rating: 2,\n product_id: productRecommendations[1].product_id,\n text: \"GOOD\"\n })\n }\n\n if(productRecommendations[2]){\n ratedProducts.push({\n rating: 3,\n product_id: productRecommendations[2].product_id,\n text: \"BETTER\"\n })\n }\n\n const ratedProduct = ratedProducts.filter( ( el ) => {\n if(el.product_id === id){\n return el\n }\n }\n ) \n\n return ratedProduct[0].text;\n }\n\n useEffect(() => {\n if (productStatus === 'idle') {\n if(productIDs.length > 0){\n dispatch(fetchProductsInfoAsync(productIDs))\n }\n }\n }, [dispatch]);\n\n const renderRecommendations = (productsBigCommerce) => {\n if(!productsBigCommerce || productsBigCommerce.length === 0){\n return

Sorry No Product Recommendations Found.

\n } else {\n return productsBigCommerce.map((product, i) =>\n
\n
{ showProductRatingTag(product.node.entityId) }
\n

{product.node.name}

\n \"#\"/\n

{ product.node.plainTextDescription }

\n $ { product.node.prices.price.value }\n Add To Cart\n Learn More\n
\n )\n }\n }\n\n const renderView = (status) => {\n\n switch(status){\n case 'loading':\n return \n case 'failed':\n return \n case 'succeeded':\n return renderRecommendations(productsBigCommerce);\n }\n }\n\n return (\n
\n { renderView(productsBigCommerceStatus) }\n
\n );\n}","const getEnv = () => {\n if (window.location.hostname === 'localhost') {\n return 'DEV';\n } else {\n return 'PROD';\n }\n}\n\nconst getWorkflows = () => {\n\n const thisStoreWorkflows = process.env.REACT_APP_WORKFLOW_OFFERED.split(',');\n let flows = [];\n for(let i = 0; i < thisStoreWorkflows.length; i ++){\n let currentFlow = thisStoreWorkflows[i].toLocaleUpperCase();\n\n if(process.env[\"REACT_APP_WORKFLOW_NAME_\" + currentFlow] &&\n process.env[\"REACT_APP_WORKFLOW_IMAGE_\" + currentFlow] &&\n process.env[\"REACT_APP_WORKFLOW_TITLE_\" + currentFlow]){\n \n flows.push({\n \"name\": process.env[\"REACT_APP_WORKFLOW_NAME_\" + currentFlow],\n \"image\": process.env[\"REACT_APP_WORKFLOW_IMAGE_\" + currentFlow],\n \"title\": process.env[\"REACT_APP_WORKFLOW_TITLE_\" + currentFlow]\n })\n }\n }\n return flows;\n}\n\nexport { getEnv, getWorkflows }","import React from 'react';\nimport { useDispatch } from 'react-redux';\nimport { getWorkflows } from '../../app/helpers';\nimport { setWorkflowName } from '../Form/FormSlice';\nimport styles from './Workflows.module.scss';\n\nexport function WorkflowSelection() {\n\n const dispatch = useDispatch();\n const allWorkFlows = getWorkflows();\n\n const selectWorkflow = (name) => {\n dispatch(\n setWorkflowName({\n flow_name: name\n })\n )\n }\n\n return (\n
\n

Projects

\n

Looking for help with your next energy-saving home improvement prject? Browse our integrated solutions for tailored products, rebates, installation services, financing and more!

\n
\n {allWorkFlows.map((each, i) => (\n
\n \n
\n ))\n }\n
\n
\n )\n}","import React from 'react';\nimport { useSelector } from 'react-redux';\nimport { Form } from '../Form/Form';\nimport { Recommendations } from '../RecommendedProducts/RecommendedProducts';\nimport { selectRecommendations, selectWorkflow } from '../Form/FormSlice';\nimport { WorkflowSelection } from '../Workflows/WorkflowSelection';\n\n\nexport function WrapperComponent() {\n \n const hasProductRecommendations = useSelector(selectRecommendations);\n const hasSelectedWorkflow = useSelector(selectWorkflow);\n\n const renderView = () => {\n\n // Select workflow\n if (!hasSelectedWorkflow){\n return \n\n // Workflow Selected\n } else if ( hasSelectedWorkflow && !hasProductRecommendations){\n return
\n\n // Form submitted\n } else if ( hasSelectedWorkflow && hasProductRecommendations){\n return \n\n } else {\n return
Sorry, something went wrong, try to reload the page.
\n }\n }\n\n return (\n renderView()\n );\n}","import React from 'react';\nimport { WrapperComponent } from './features/WrapperComponent/WrapperComponent';\nimport './App.scss';\n\nfunction App() {\n\n return (\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.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 { store } from './app/store';\nimport { Provider } from 'react-redux';\nimport * as serviceWorker from './serviceWorker';\nimport { BrowserRouter as Router } from 'react-router-dom';\n\nReactDOM.render(\n \n \n \n \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","// extracted by mini-css-extract-plugin\nmodule.exports = {\"post_excerpt\":\"SingleQuestion_post_excerpt__bQaFl\",\"button\":\"SingleQuestion_button__wEQcY\",\"announcement\":\"SingleQuestion_announcement__HT_G1\",\"radio\":\"SingleQuestion_radio__1TJ-F\",\"inputContainer\":\"SingleQuestion_inputContainer__5IZqt\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"recommendations\":\"RecommendedProducts_recommendations__wp9Mr\",\"recommendation\":\"RecommendedProducts_recommendation__2jyR_\",\"ratingTag\":\"RecommendedProducts_ratingTag__308nF\",\"price\":\"RecommendedProducts_price__1iTzF\",\"addToCart\":\"RecommendedProducts_addToCart__2eNtE\",\"learnMoreBtn\":\"RecommendedProducts_learnMoreBtn__1fhUW\"};"],"sourceRoot":""}