{"version":3,"sources":["assets/musicBar.png","assets/tetris.png","assets/email_icon.png","assets/github_icon.png","assets/linkedin_icon.png","assets/twitter_icon.png","assets/profile2.png","data/projects.js","components/Projects.js","data/socialProfiles.js","components/SocialProfiles.js","components/Title.js","components/App.js","components/Docs.js","components/Header.js","projects/evenoddgame/actions/types.js","projects/evenoddgame/reducers/fetchStates.js","projects/evenoddgame/components/Instructions.js","projects/evenoddgame/actions/settings.js","projects/evenoddgame/components/DrawCard.js","projects/evenoddgame/actions/deck.js","projects/evenoddgame/components/Card.js","projects/evenoddgame/components/Guess.js","projects/evenoddgame/actions/guess.js","projects/evenoddgame/components/GameState.js","projects/evenoddgame/components/App.js","projects/evenoddgame/reducers/settings.js","projects/evenoddgame/reducers/deck.js","projects/evenoddgame/reducers/gameState.js","projects/evenoddgame/reducers/index.js","projects/evenoddgame/index.js","index.js","assets/project1.png","assets/project2.png"],"names":["module","exports","PROJECTS","id","title","description","link","GitHub","image","project1","musicBar","project2","tetris","Project","props","project","style","display","width","margin","src","alt","height","href","target","Projects","map","PROJECT","key","SOCIAL_PROFILES","emailIcon","gitHubIcon","linkedinIcon","twitterIcon","SocialProfile","socialProfile","SocialProfiles","PROFILE","TITLES","Title","state","titleIndex","fadeIn","animateTitles","titleInterval","setInterval","length","setState","timeout","setTimeout","this","clearInterval","className","Component","App","displayBio","toggleDisplay","profilePic","onClick","Docs","doc","fetch","then","response","json","catch","error","alert","message","url","explanation","Header","marginBottom","Link","to","children","DECK","DECK_DRAW","componentConnector","connect","instructionsExpanded","settings","dispatch","expandInstructions","type","collapseInstructions","deck_id","deck","fetchDrawCard","console","log","status","Error","success","cards","remaining","value","suit","guess","gameState","setGuessEven","setGuessOdd","border","correctGuesses","guessText","record","Number","localStorage","getItem","setItem","isNewRecord","checkRecord","recordLabel","startGame","fetchNewDeck","fetchState","fetchStates","gameStarted","cancelGame","deckJson","fetchDeckSuccess","fetchDeckError","DEFAULT_SETTINGS","settingsReducer","action","DEFAULT_DECK","deckReducer","DEFAULT_GAME_STATE","EVENS","ODDS","gameStateReducer","includes","combineReducers","store","createStore","rootReducer","applyMiddleware","thunk","subscribe","getState","EvenOrOdds","ReactDOM","render","Switch","Route","exact","path","document","getElementById"],"mappings":"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","file":"static/js/main.a81add83.chunk.js","sourcesContent":["module.exports = \"\"","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/email_icon.fd99f8e3.png\";","module.exports = __webpack_public_path__ + \"static/media/github_icon.e2a62886.png\";","module.exports = __webpack_public_path__ + \"static/media/linkedin_icon.56ab00e8.png\";","module.exports = __webpack_public_path__ + \"static/media/twitter_icon.512536cb.png\";","module.exports = __webpack_public_path__ + \"static/media/profile2.42e9abe3.png\";","import project1 from \"../assets/project1.png\";\r\nimport project2 from \"../assets/project2.png\";\r\n// import project3 from \"../assets/project3.png\";\r\n// import project4 from \"../assets/project4.png\";\r\nimport musicBar from \"../assets/musicBar.png\";\r\nimport tetris from \"../assets/tetris.png\";\r\n\r\nconst PROJECTS = [\r\n {\r\n id: 1,\r\n title: \"Travel Blog\",\r\n description: \"My First React Application developed in 2018\",\r\n link: \"http://enrichingtravels.com/\",\r\n GitHub: \"Private Repo\",\r\n image: project1,\r\n },\r\n {\r\n id: 32,\r\n title: \"Music Bar\",\r\n description: \"Application built in React only in 2021\",\r\n link: \"http://musicbar.s3-website-us-east-1.amazonaws.com/\",\r\n image: musicBar,\r\n },\r\n\r\n {\r\n id: 3,\r\n title: \"Guess Odd or Even Game\",\r\n description: \"Application built in Redux in 2020\",\r\n link: \"/evenoddgame\",\r\n image: project2,\r\n },\r\n {\r\n id: 4,\r\n title: \"Tetris Game\",\r\n description: \"Tetris Game - React and Custom Hooks in 2020\",\r\n link: \"http://react-tetrisgame.s3-website-us-east-1.amazonaws.com/\",\r\n image: tetris,\r\n },\r\n /* ,\r\n {\r\n id: 3,\r\n title: \"Interactive tic-tac-toe game\",\r\n description: 'React Application built in 2020 - In Progress',\r\n link: \"https://github.com/vanishtachangea/react-portfolio\",\r\n image: project3\r\n },\r\n {\r\n id: 3,\r\n title: \"Musical\",\r\n description: 'App build using React in 2020 - In Progress',\r\n link: \"https://github.com/vanishtachangea/react-portfolio\",\r\n image: project4\r\n } */\r\n];\r\nexport default PROJECTS;\r\n","import React, { Component } from 'react';\r\nimport PROJECTS from '../data/projects';\r\nconst Project = (props) => {\r\n\r\n //console.log('this.proprs', props);\r\n const { id, title, description, link, image } = props.project;\r\n return (\r\n //
{this.props.project.title}
\r\n
\r\n

{title}

\r\n profile\r\n \r\n

{description}

\r\n \r\n
\r\n )\r\n\r\n}\r\n\r\nconst Projects = () => (\r\n
\r\n

Highlighed Projects

\r\n
\r\n {\r\n PROJECTS.map(PROJECT => (\r\n \r\n )\r\n )\r\n }\r\n
\r\n
\r\n)\r\n\r\n\r\nexport default Projects;","import emailIcon from '../assets/email_icon.png';\r\nimport gitHubIcon from '../assets/github_icon.png';\r\nimport linkedinIcon from '../assets/linkedin_icon.png';\r\nimport twitterIcon from '../assets/twitter_icon.png';\r\n\r\nconst SOCIAL_PROFILES = [\r\n {\r\n id:1,\r\n link: 'mailto:vanishta.changea@gmail.com',\r\n image: emailIcon\r\n },\r\n {\r\n id:2,\r\n link: 'https://github.com/vanishtachangea',\r\n image: gitHubIcon\r\n },\r\n {\r\n id:3,\r\n link: 'https://www.linkedin.com/in/vanishtachangea/',\r\n image: linkedinIcon\r\n },\r\n {\r\n id:4,\r\n link: 'https://twitter.com/VanishtaChangea',\r\n image: twitterIcon\r\n }\r\n\r\n];\r\nexport default SOCIAL_PROFILES; \r\n","import React, { Component } from 'react';\r\nimport SOCIAL_PROFILES from '../data/socialProfiles';\r\nimport { blockStatement } from '@babel/types';\r\nconst SocialProfile = props => {\r\n\r\n const { link, image } = props.socialProfile;\r\n return (\r\n \r\n\r\n profile\r\n \r\n )\r\n\r\n}\r\nconst SocialProfiles = () => (\r\n
\r\n

Connect with Me

\r\n
\r\n {\r\n SOCIAL_PROFILES.map(PROFILE => {\r\n return (\r\n \r\n );\r\n })\r\n }\r\n
\r\n
\r\n);\r\n\r\n\r\nexport default SocialProfiles;","import React, { Component } from 'react';\r\nconst url ='https://www.womentech.net/women-tech-conference?join=MTM1Mw==';\r\nconst TITLES = [\r\n 'I am A FullStack Software Developer',\r\n 'I have previously been Project Manager for 5 years',\r\n 'Since 2019, I took a full dive back into coding',\r\n 'I am an Aspiring Solution Architect and DevOps Engineer, ultimately an expert of experts and leader in this industry',\r\n/* 'I am a Nature and Forest Lover',\r\n 'I am Gym Lover',\r\n 'I am DIY Hobbyist',\r\n 'I am Gardening Hobbyist',\r\n 'One day I want to have enough power to change how things work in this world',\r\n 'I want to give some people the push and help they need to reach and exceed their potential', */\r\n 'I believe in KISS - Keep It Short and Simple',\r\n 'I am a Global Ambassador on WomentechNetwork. I personally invite you to join our conference and network by clicking here' \r\n \r\n]\r\nclass Title extends Component {\r\n state = { titleIndex: 0, fadeIn: true };\r\n componentDidMount() {\r\n //console.log('Title Component has mounted');\r\n this.timeout = setTimeout(() => this.setState({ fadeIn: false }), 2000);\r\n this.animateTitles();\r\n }\r\n componentWillUnmount() {\r\n //console.log('Title component will unmount');\r\n clearInterval(this.titleInterval);\r\n clearInterval(this.timeout);\r\n }\r\n animateTitles = () => {\r\n this.titleInterval = setInterval(() => {\r\n const titleIndex = (this.state.titleIndex + 1) % TITLES.length;\r\n //const fadeIn = true;\r\n this.setState({ titleIndex, fadeIn: true });\r\n this.timeout = setTimeout(() => { this.setState({ fadeIn: false }) }, 2000);\r\n }, 4000);\r\n //console.log(this.titleInterval);\r\n }\r\n render() {\r\n\r\n const { titleIndex, fadeIn } = this.state;\r\n const title = TITLES[titleIndex];// const title = TITLES[this.state.titleIndex];\r\n \r\n if(titleIndex == TITLES.length-1)\r\n {\r\n return (

{title}

)\r\n }\r\n\t\t\t\r\n else\r\n {\r\n return (

{title}

)\r\n }\r\n \r\n \r\n }\r\n\r\n}\r\nexport default Title;","import React, { Component } from 'react';\r\nimport Projects from './Projects';\r\nimport SocialProfiles from './SocialProfiles';\r\nimport profilePic from '../assets/profile2.png';\r\nimport Title from './Title';\r\n// import Docs from '../components/Docs';\r\n// import Header from './Header';\r\n\r\nclass App extends Component {\r\n state = { displayBio: false};\r\n\r\n toggleDisplay = () => {\r\n this.setState({ displayBio: !this.state.displayBio });\r\n }\r\n render() {\r\n return (\r\n
\r\n {/*
*/}\r\n profile\r\n

Ich bin Vanishta. Ich wohne in München

\r\n \r\n <p>This is my REACT Portfolio</p>\r\n {\r\n this.state.displayBio ? (<div>\r\n <p>I plan to document my journey towards becoming a developer in React here.</p>\r\n <p>I will tell about the courses which I have followed.</p>\r\n <p>I will showcase live version of those projects in React and React Native which are worth showing. Else the others can stay in GitHub.</p>\r\n <p>I will also try to write small articles or tips based on knowledge gathered on React and React Native.</p>\r\n <p>Maybe I will later extend the small articles or tips on other IT areas too.</p>\r\n <p><button onClick={this.toggleDisplay}>Show Less</button></p>\r\n </div>) : (<div>\r\n <button onClick={this.toggleDisplay}> Read More</button>\r\n </div>)\r\n }\r\n <hr />\r\n <Projects/>\r\n <hr />\r\n <SocialProfiles/>\r\n{/* <hr/>\r\n <Docs/> */}\r\n \r\n </div>\r\n\r\n )\r\n }\r\n}\r\n/* const AppWithHeader=()=>\r\n{\r\n return(<Header Component={App}/>)\r\n} */\r\nexport default App; \r\n","import React, { Component } from 'react';\r\n// import Header from '../components/Header';\r\n\r\nclass Docs extends Component {\r\n state = { doc: {} };\r\n\r\n componentDidMount() {\r\n fetch('https://api.nasa.gov/planetary/apod?api_key=GSdgcdkPaBA5Pj1SWDqoXEVzERt69FvEalMClAqe').then(\r\n response => response.json())\r\n .then(json => this.setState({ doc: json }))\r\n .catch(error => alert(error.message));\r\n\r\n }\r\n render() {\r\n const { title, explanation, url } = this.state.doc;\r\n return (<div>\r\n {/* <Header/> */}\r\n <h2>Concepts Learned</h2>\r\n <div className='docs'>\r\n <h3>React</h3>\r\n <ul>\r\n <li>components</li>\r\n <li>Props</li>\r\n <li>State</li>\r\n <li>Router - BrowserRouter</li>\r\n <li>Header Component - Props.Children</li>\r\n <li>Fetch - API</li>\r\n\t\t\t\t\t<li>React Developer Tool</li>\r\n\t\t\t\t\t\r\n </ul>\r\n <h3>Redux</h3>\r\n <ul>\r\n <li>Store</li>\r\n <li>Reducer</li>\r\n <li>Action</li>\r\n <li>Component</li>\r\n\t\t\t\t\t<li>Provider</li>\r\n\t\t\t\t\t<li>Redux Middleware - Thunk</li>\r\n\t\t\t\t\t<li>Split and Combine Reducers</li>\r\n </ul>\r\n\t\t\t\t<h3>Others</h3>\r\n\t\t\t\t<ul>\r\n\t\t\t\t<li>Javascript Spread Operator</li>\r\n\t\t\t\t</ul>\r\n <hr />\r\n <h2>Resources</h2>\r\n <p><a href=\"https://reacttraining.com/react-router/web/example/basic\" target=\"_blank\">https://reacttraining.com/react-router/web/example/basic</a> </p>\r\n <p><a href=\"https://reactjs.org/docs/render-props.html#gatsby-focus-wrapper\" target=\"_blank\">https://reactjs.org/docs/render-props.html#gatsby-focus-wrapper</a> </p>\r\n <p><a href=\"https://redux.js.org/introduction/getting-started\" target=\"_blank\">https://redux.js.org/introduction/getting-started</a> </p>\r\n <img src={url} alt={title} />\r\n </div>\r\n </div>)\r\n\r\n }\r\n}\r\nexport default Docs;","import React from 'react';\r\nimport { Link } from 'react-router-dom';\r\nconst Header = props => {\r\n //const { Component } = props;\r\n\r\n const style = {\r\n display: 'inline-block',\r\n margin: 10,\r\n marginBottom: 30\r\n }\r\n return (\r\n <div>\r\n <div>\r\n <h3 style={style}><Link to='/'>Home</Link></h3> \r\n <h3 style={style}><Link to='/evenoddgame'>Even Or Odds</Link></h3>\r\n <h3 style={style}><Link to='/docs'>Docs</Link></h3>\r\n </div>\r\n\r\n {props.children}\r\n </div>\r\n )\r\n}\r\nexport default Header;","export const SET_GAME_STARTED = 'SET_GAME_STARTED';\r\nexport const SET_INSTRUCTIONS_EXPANDED = 'SET_INSTRUCTIONS_EXPANDED';\r\nexport const FETCH_DECK_RESULT='FETCH_DECK_RESULT';\r\nexport const FETCH_DECK_ERROR = 'FETCH_DECK_ERROR';\r\nexport const SET_GUESS ='SET_GUESS';\r\n\r\nexport const DECK = {\r\n FETCH_SUCCESS:'DECK_FETCH_SUCCESS',\r\n FETCH_ERROR: 'DECK_FETCH_ERROR'\r\n};\r\nexport const DECK_DRAW = {\r\n FETCH_SUCCESS: 'DECK_DRAW_FETCH_SUCCESS',\r\n FETCH_ERROR: 'DECK_DRAW_FETCH_ERROR',\r\n FETCH_GAME_END :'FETCH_GAME_END'\r\n}","export default{\r\n success:'success',\r\n error:'error',\r\n gameEnd:'gameEnd'\r\n};","import React, { Component } from 'react';\r\nimport {connect} from 'react-redux';\r\nimport {expandInstructions,collapseInstructions} from '../actions/settings';\r\nconst Instructions = props =>{\r\n const{instructionsExpanded,expandInstructions,collapseInstructions}=props;\r\n if(instructionsExpanded){\r\n return(\r\n <div>\r\n <h3>Instructions</h3>\r\n <div>Welcome to Guess Game. YOu have to guess whether the next card will be even or Odd</div>\r\n <div>Face Cards do not count</div>\r\n <br/>\r\n <button onClick={collapseInstructions}>Show Less</button>\r\n </div>\r\n );\r\n }\r\n return(\r\n <div>\r\n <h3>Instructions</h3>\r\n <div>Welcome to Guess Game...</div>\r\n <br/>\r\n <button onClick={expandInstructions}>Read More</button>\r\n </div>\r\n )\r\n\r\n}\r\nconst mapStateToProps = state=>{\r\n return {instructionsExpanded: state.settings.instructionsExpanded \r\n };\r\n}\r\nconst mapDispatchToProps = dispatch =>{\r\n return {\r\n expandInstructions:()=> dispatch(expandInstructions()),\r\n collapseInstructions:()=>dispatch(collapseInstructions())\r\n }\r\n}\r\nconst componentConnector = connect(mapStateToProps,mapDispatchToProps);\r\n\r\nexport default componentConnector(Instructions);","import {SET_GAME_STARTED,SET_INSTRUCTIONS_EXPANDED} from './types';\r\nexport const startGame = () => {\r\n return { type: SET_GAME_STARTED, gameStarted: true };\r\n}\r\nexport const cancelGame = () => {\r\n return { type: SET_GAME_STARTED, gameStarted: false };\r\n}\r\nexport const expandInstructions = () => {\r\n return { type: SET_INSTRUCTIONS_EXPANDED, instructionsExpanded: true };\r\n}\r\nexport const collapseInstructions = () => {\r\n return { type: SET_INSTRUCTIONS_EXPANDED, instructionsExpanded: false };\r\n}","import React from 'react';\r\nimport { connect } from 'react-redux';\r\nimport {fetchDrawCard} from '../actions/deck';\r\n\r\nconst DrawCard = ({deck_id,fetchDrawCard}) => {\r\n //console.log('drawcard props', props);\r\n //const {deck_id,fetchDrawCard}=props;\r\n return (\r\n <div>\r\n <button onClick={fetchDrawCard(deck_id)}>Draw the next card!</button>\r\n </div>\r\n )\r\n}\r\nconst mapDispatchToProps= dispatch =>{\r\n return{ fetchDrawCard: deck_id =>() => dispatch(fetchDrawCard(deck_id))};\r\n}\r\nexport default connect(\r\n ({deck: {deck_id}}) =>( {deck_id}),mapDispatchToProps\r\n)(DrawCard);","import {DECK, DECK_DRAW} from './types';\r\n\r\nconst API_ADDRESS ='https://deckofcardsapi.com/api';\r\nexport const fetchDeckSuccess =deckJson=>{\r\n const {remaining, deck_id}=deckJson;\r\n return {type: DECK.FETCH_SUCCESS, remaining, deck_id};\r\n}\r\nexport const fetchDeckError = error =>{\r\n return {type:DECK.FETCH_ERROR, message:error.message};\r\n}\r\n\r\nexport const fetchNewDeck =()=> dispatch=>{\r\n return fetch(`${API_ADDRESS}/deck/new/shuffle/`)\r\n .then(//response => response.json()\r\n response=>{\r\n if(response.status !=200)\r\n {\r\n throw new Error('Unsuccessful request to deckofcardsapi.com');\r\n }\r\n return response.json();\r\n } \r\n )\r\n .then(json =>\r\n {\r\n dispatch(fetchDeckSuccess(json))\r\n })\r\n .catch(error => dispatch(fetchDeckError(error)));\r\n}\r\nexport const fetchDrawCard = deck_id => dispatch=>{\r\n console.log(\"deckid\"+deck_id);\r\n //return fetch('https://deckofcardsapi.com/api/deck/'+deck_id+'/draw/') //https://deckofcardsapi.com/api/deck/v70eqt1fb3tg/draw/\r\n return fetch(`${API_ADDRESS}/deck/${deck_id}/draw/`)\r\n .then (response =>{\r\n if(response.status !=200)\r\n {\r\n throw new Error('Unsuccessful request to deckofcardsapi.com');\r\n }\r\n return response.json();\r\n\r\n })\r\n .then(json => {\r\n if(json.success == true)\r\n {\r\n dispatch({\r\n type:DECK_DRAW.FETCH_SUCCESS,\r\n cards: json.cards,\r\n remaining:json.remaining\r\n })\r\n }\r\n else\r\n {\r\n dispatch({\r\n type:DECK_DRAW.FETCH_GAME_END,\r\n remaining:json.remaining\r\n })\r\n }\r\n\r\n })\r\n .catch(error => dispatch({type:DECK_DRAW.FETCH_ERROR, message:error.message}));\r\n}","import React from 'react';\r\nimport {connect} from 'react-redux';\r\nconst Card =({cards})=>{\r\n if(!cards[0]) return null;\r\n const {value, suit, image} = cards[0];\r\n return (\r\n <div>\r\n <h3>{value} of {suit}</h3>\r\n <img src={image} alt='card-image'/>\r\n </div>\r\n )\r\n}\r\nexport default connect(({deck:{cards}})=>({cards}))(Card)","import React from 'react';\r\nimport {connect} from 'react-redux';\r\nimport {setGuessEven, setGuessOdd} from '../actions/guess';\r\n\r\nconst Guess = ({guess, setGuessEven,setGuessOdd})=>{\r\n return (\r\n <div>\r\n <h3>Will it be even or Odd?</h3>\r\n <div>\r\n <button onClick={setGuessEven}\r\n style={guess==='even'? {border:'2px solid #79d70f'}:null}\r\n >Even</button>\r\n {' '}\r\n <button onClick={setGuessOdd} \r\n style={guess==='odd'? {border:'2px solid #79d70f'}:null}\r\n >Odd</button>\r\n </div>\r\n </div>\r\n )\r\n\r\n}\r\nexport default connect(\r\n ({gameState:{guess}})=>({guess}), \r\n {setGuessEven,setGuessOdd}\r\n)(Guess)","import {SET_GUESS} from './types';\r\nexport const setGuessEven =()=>{\r\n return {type:SET_GUESS, guess : 'even'}\r\n}\r\nexport const setGuessOdd =()=>{\r\n return {type:SET_GUESS, guess : 'odd'}\r\n}","import React from 'react';\r\nimport { connect } from 'react-redux';\r\n\r\nconst correctGuessesRecordKey = 'CORRECT_GUESSES_RECORD_VC123';\r\nconst checkRecord = correctGuesses => {\r\n const record = Number(localStorage.getItem(correctGuessesRecordKey));\r\n if (correctGuesses > record) {\r\n localStorage.setItem(correctGuessesRecordKey, correctGuesses);\r\n return { record: correctGuesses, isNewRecord: true };\r\n }\r\n return { record, isNewRecord: false }\r\n\r\n}\r\n\r\nconst GameState = ({ remaining, correctGuesses }) => {\r\n const guessText = correctGuesses === 1 ? 'guess' : 'guesses';\r\n const { record, isNewRecord } = checkRecord(correctGuesses);\r\n const recordLabel = isNewRecord ? ' 🎉 New Record' : 'Record';\r\n return (\r\n <div>\r\n <h3>{recordLabel}: {record}</h3>\r\n <p>{remaining} cards remaining - {correctGuesses} correct {guessText} </p>\r\n </div>\r\n )\r\n}\r\nexport default connect(\r\n (\r\n {\r\n deck: { remaining },\r\n gameState: { correctGuesses }\r\n }\r\n ) => ({ remaining, correctGuesses })\r\n)(GameState);","import React, { Component } from 'react';\r\nimport { connect } from 'react-redux';\r\nimport { startGame, cancelGame } from '../actions/settings';\r\nimport { fetchNewDeck } from '../actions/deck';\r\nimport fetchStates from '../reducers/fetchStates';\r\nimport Instructions from './Instructions';\r\nimport DrawCard from './DrawCard';\r\nimport Card from './Card';\r\nimport Guess from './Guess';\r\nimport GameState from './GameState';\r\n\r\nclass App extends Component {\r\n startGame = () => {\r\n this.props.startGame();\r\n this.props.fetchNewDeck();\r\n\r\n }\r\n render() {\r\n console.log('this!!', this);\r\n if (this.props.fetchState == fetchStates.error) {\r\n return (\r\n <div>\r\n <p>An error has occurred. Please try reloading the app.</p>\r\n <p>{this.props.message}</p>\r\n </div>\r\n )\r\n }\r\n else if (this.props.fetchState == fetchStates.gameEnd) {\r\n\r\n return (<div>\r\n\r\n <div>♣️ ♥️ Guess Even or Odds Cards ♠️ ♦️</div>\r\n <h3>Game is Over!</h3>\r\n <GameState />\r\n <br/>\r\n <button onClick={this.startGame}>Start Game</button>\r\n </div>)\r\n\r\n\r\n }\r\n return (\r\n <div>\r\n <div>♣️ ♥️ Guess Even or Odds Cards ♠️ ♦️</div>{\r\n\r\n this.props.gameStarted ? (\r\n <div>\r\n <h3>Game started!</h3>\r\n <GameState />\r\n {/* <br/> */}\r\n <Guess />\r\n <br />\r\n <DrawCard /><hr />\r\n <Card />\r\n <hr />\r\n <button onClick={this.props.cancelGame}>Cancel Game</button>\r\n </div>) : (\r\n <div>\r\n <h3>New Game!</h3>\r\n <br />\r\n\r\n <hr />\r\n <button onClick={this.startGame}>Start Game</button>\r\n <hr />\r\n <Instructions />\r\n </div>\r\n\r\n )\r\n }\r\n </div>\r\n )\r\n\r\n\r\n\r\n\r\n\r\n\r\n }\r\n}\r\nconst mapStateToProps = state => {\r\n /* console.log('state*: ', state);\r\n const { gameStarted, fetchState, message } = state.settings;\r\n const {fetchState,message} = state.deck;\r\n */\r\n const {\r\n settings: { gameStarted },\r\n deck: { fetchState, message }\r\n } = state;\r\n return { gameStarted, fetchState, message };\r\n}\r\n/* const mapDispatchToProps = dispatch => {\r\n return {\r\n startGame: () => dispatch(startGame()),\r\n cancelGame: () => dispatch(cancelGame()),\r\n fetchNewDeck: () => dispatch(fetchNewDeck())\r\n\r\n };\r\n} */\r\n\r\n//const componentConnector = connect(mapStateToProps, mapDispatchToProps);\r\nconst componentConnector = connect(mapStateToProps, { startGame, cancelGame, fetchNewDeck });\r\n\r\nexport default componentConnector(App);\r\n","import {\r\n SET_GAME_STARTED,\r\n SET_INSTRUCTIONS_EXPANDED} from '../actions/types';\r\n import fetchStates from './fetchStates';\r\n \r\n export const DEFAULT_SETTINGS = {\r\n gameStarted: false,\r\n instructionsExpanded: false\r\n }\r\n \r\n export const settingsReducer = (state = DEFAULT_SETTINGS, action) => {\r\n switch (action.type) {\r\n case SET_GAME_STARTED:\r\n return {\r\n ...state, gameStarted: action.gameStarted \r\n };\r\n \r\n case SET_INSTRUCTIONS_EXPANDED:\r\n return {\r\n ...state, instructionsExpanded: action.instructionsExpanded\r\n }\r\n \r\n default:\r\n return state;\r\n break;\r\n }\r\n \r\n };\r\n export default settingsReducer;","import {DECK, DECK_DRAW} from '../actions/types';\r\n import fetchStates from './fetchStates';\r\n \r\n export const DEFAULT_DECK = {\r\n deck_id: '',\r\n remaining: 0,\r\n fetchState:'',\r\n message:'', \r\n cards : []\r\n }\r\n \r\n export const deckReducer = (state = DEFAULT_DECK, action) => {\r\n let remaining, deck_id, cards; \r\n \r\n switch (action.type) { \r\n case DECK.FETCH_SUCCESS:\r\n //const {remaining, deck_id}=action;\r\n ( {remaining, deck_id}=action);\r\n return{ \r\n ...state,remaining,deck_id, fetchState:fetchStates.success\r\n }\r\n case DECK.FETCH_ERROR:\r\n return {...state,message:action.message, fetchState:fetchStates.error}\r\n\r\n case DECK_DRAW.FETCH_SUCCESS:\r\n //( {cards, remaining}=action);\r\n ( {remaining, cards}=action);\r\n return {...state, cards, remaining,fetchState:fetchStates.success}\r\n case DECK_DRAW.FETCH_ERROR:\r\n return {...state, message:action.message, fetchState:fetchStates.error}\r\n case DECK_DRAW.FETCH_GAME_END:\r\n return {...state, message:action.message, fetchState:fetchStates.gameEnd}\r\n default:\r\n return state;\r\n break;\r\n }\r\n \r\n };\r\n export default deckReducer;","import {SET_GUESS,SET_GAME_STARTED, DECK_DRAW} from '../actions/types';\r\nconst DEFAULT_GAME_STATE ={guess:'', correctGuesses:0};\r\nconst EVENS=['2','4','6','8','0','10'];\r\nconst ODDS=['ACE','3','5','7','9'];\r\nconst gameStateReducer =(state=DEFAULT_GAME_STATE, action)=>{\r\n switch(action.type)\r\n {\r\n case SET_GUESS:\r\n return {...state,guess:action.guess};\r\n case SET_GAME_STARTED:\r\n return DEFAULT_GAME_STATE;\r\n case DECK_DRAW.FETCH_SUCCESS:\r\n const {value} = action.cards[0];\r\n const {guess, correctGuesses}=state;\r\n if(\r\n (guess ==='even' && EVENS.includes(value))||\r\n (guess ==='odd' && ODDS.includes(value))\r\n ){\r\n return {...state,correctGuesses:correctGuesses+1};\r\n }\r\n return state;\r\n default:\r\n return state;\r\n }\r\n}\r\nexport default gameStateReducer;","import {combineReducers} from 'redux';\r\nimport settingsReducer from './settings';\r\nimport deckReducer from './deck';\r\nimport gameStateReducer from './gameState';\r\n\r\nexport default combineReducers({\r\n settings:settingsReducer,\r\n deck:deckReducer,\r\n gameState : gameStateReducer\r\n});","import React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport './index.css';\r\nimport App from './components/App';\r\n//import store from './app/store';\r\nimport { Provider } from 'react-redux';\r\nimport thunk from 'redux-thunk';\r\nimport { createStore, applyMiddleware } from 'redux';\r\n\r\nimport rootReducer from './reducers';\r\n//import startGame from './actions/settings';\r\n\r\n\r\nconst store = createStore(rootReducer, applyMiddleware(thunk));\r\nconsole.log('store:',{store}); \r\n//console.log('store state 1:',store.getState()); \r\nstore.subscribe(() => console.log('store.getstate', store.getState()));\r\n\r\nconst EvenOrOdds =()=>{\r\n return(\r\n <Provider store={store}>\r\n <App/>\r\n </Provider>\r\n )\r\n}\r\nexport default EvenOrOdds;\r\n\r\n\r\n","import React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport {BrowserRouter as Router,Switch,Route} from \"react-router-dom\";\r\nimport App from './components/App';\r\nimport Docs from './components/Docs';\r\nimport Header from './components/Header';\r\nimport EvensOrOdds from './projects/evenoddgame';\r\nimport './index.css';\r\n\r\nReactDOM.render(\r\n <Router>\r\n <Switch>\r\n <Route exact path=\"/\" render={()=><Header><App/></Header>}>\r\n </Route>\r\n <Route path=\"/docs\" render={()=><Header><Docs/></Header>}>\r\n </Route>\r\n <Route path=\"/evenoddgame\" render={()=><Header><EvensOrOdds/></Header>}>\r\n </Route>\r\n </Switch>\r\n </Router>,\r\n document.getElementById('root'));\r\n","module.exports = __webpack_public_path__ + \"static/media/project1.bf56edc6.png\";","module.exports = \"\""],"sourceRoot":""}