{"version":3,"sources":["logo.svg","features/counter/counterAPI.js","features/counter/counterSlice.js","features/car/carSlice.js","components/Header.js","components/Section.js","components/Home.js","App.js","app/store.js","serviceWorker.js","index.js","features/counter/Counter.module.css"],"names":["fetchCount","amount","Promise","resolve","setTimeout","data","incrementAsync","createAsyncThunk","a","response","counterSlice","createSlice","name","initialState","value","status","reducers","increment","state","decrement","incrementByAmount","action","payload","extraReducers","builder","addCase","pending","fulfilled","actions","carSlice","cars","selectCars","car","Header","useState","burgerStatus","setBurgerStatus","useSelector","console","log","Container","src","alt","map","index","href","RightMenu","CustomMenu","onClick","BurgerNav","show","right","CloseWrapper","CustomClose","styled","div","Menu","MenuIcon","props","CloseIcon","Section","title","description","backgroundImage","leftButtonText","rightButtonText","Wrap","bgImage","bottom","ItemText","Buttons","ButtonGroup","LeftButton","RightButton","DownArrow","img","Home","App","className","store","configureStore","reducer","carReducer","Boolean","window","location","hostname","match","ReactDOM","render","StrictMode","document","getElementById","navigator","serviceWorker","ready","then","registration","unregister","module","exports"],"mappings":"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","file":"static/js/main.5a7dd32f.chunk.js","sourcesContent":["export default __webpack_public_path__ + \"static/media/logo.b2e5a01e.svg\";","// A mock function to mimic making an async request for data\nexport function fetchCount(amount = 1) {\n return new Promise((resolve) =>\n setTimeout(() => resolve({ data: amount }), 500)\n );\n}\n","import { createAsyncThunk, createSlice } from '@reduxjs/toolkit';\nimport { fetchCount } from './counterAPI';\n\nconst initialState = {\n value: 0,\n status: 'idle',\n};\n\n// The function below is called a thunk and allows us to perform async logic. It\n// can be dispatched like a regular action: `dispatch(incrementAsync(10))`. This\n// will call the thunk with the `dispatch` function as the first argument. Async\n// code can then be executed and other actions can be dispatched. Thunks are\n// typically used to make async requests.\nexport const incrementAsync = createAsyncThunk(\n 'counter/fetchCount',\n async (amount) => {\n const response = await fetchCount(amount);\n // The value we return becomes the `fulfilled` action payload\n return response.data;\n }\n);\n\nexport const counterSlice = createSlice({\n name: 'counter',\n initialState,\n // The `reducers` field lets us define reducers and generate associated actions\n reducers: {\n increment: (state) => {\n // Redux Toolkit allows us to write \"mutating\" logic in reducers. It\n // doesn't actually mutate the state because it uses the Immer library,\n // which detects changes to a \"draft state\" and produces a brand new\n // immutable state based off those changes\n state.value += 1;\n },\n decrement: (state) => {\n state.value -= 1;\n },\n // Use the PayloadAction type to declare the contents of `action.payload`\n incrementByAmount: (state, action) => {\n state.value += action.payload;\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(incrementAsync.pending, (state) => {\n state.status = 'loading';\n })\n .addCase(incrementAsync.fulfilled, (state, action) => {\n state.status = 'idle';\n state.value += action.payload;\n });\n },\n});\n\nexport const { increment, decrement, incrementByAmount } = counterSlice.actions;\n\n// The function below is called a selector and allows us to select a value from\n// the state. Selectors can also be defined inline where they're used instead of\n// in the slice file. For example: `useSelector((state: RootState) => state.counter.value)`\nexport const selectCount = (state) => state.counter.value;\n\n// We can also write thunks by hand, which may contain both sync and async logic.\n// Here's an example of conditionally dispatching actions based on current state.\nexport const incrementIfOdd = (amount) => (dispatch, getState) => {\n const currentValue = selectCount(getState());\n if (currentValue % 2 === 1) {\n dispatch(incrementByAmount(amount));\n }\n};\n\nexport default counterSlice.reducer;\n","import { createSlice } from \"@reduxjs/toolkit\"\n\nconst initialState = { // state\n cars: [ \"Model S\", \"Model 3\", \"Model X\", \"Model Y\" ]\n}\n\nconst carSlice = createSlice({ // action\n name: \"car\", // slice name\n initialState, // car name\n reducers: {} // ?\n})\n\nexport const selectCars = state => state.car.cars\n\nexport default carSlice.reducer // new state (state, action)\n","import React, { useState } from 'react'\nimport styled from 'styled-components'\nimport MenuIcon from '@mui/icons-material/Menu';\nimport CloseIcon from '@mui/icons-material/Close';\nimport Fade from 'react-reveal/Fade'\nimport { selectCars } from '../features/car/carSlice';\nimport { useSelector } from 'react-redux';\n\nfunction Header() {\n const [burgerStatus, setBurgerStatus] = useState(false);\n const cars = useSelector(selectCars);\n console.log(cars);\n return (\n { description }\n \n\n \n\n
{ title }
\n