diff --git a/client/dist/bundle.js b/client/dist/bundle.js index 3af789d..b6a6b68 100644 --- a/client/dist/bundle.js +++ b/client/dist/bundle.js @@ -94,7 +94,7 @@ /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _react = __webpack_require__(/*! react */ \"./node_modules/react/index.js\");\n\nvar _react2 = _interopRequireDefault(_react);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar Brick = function Brick(props) {\n return _react2.default.createElement(\n \"div\",\n { className: \"brick\" },\n _react2.default.createElement(\n \"p\",\n null,\n props.word\n )\n );\n};\n\nexports.default = Brick;//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9jbGllbnQvc3JjL2NvbXBvbmVudHMvQnJpY2suanN4LmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vL2NsaWVudC9zcmMvY29tcG9uZW50cy9Ccmljay5qc3g/MDI3NyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuXG5jb25zdCBCcmljayA9IChwcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPVwiYnJpY2tcIj5cbiAgICAgIDxwPntwcm9wcy53b3JkfTwvcD5cbiAgICA8L2Rpdj5cbiAgKVxufVxuXG5leHBvcnQgZGVmYXVsdCBCcmljazsiXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBO0FBQ0E7Ozs7O0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBREE7QUFJQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./client/src/components/Brick.jsx\n"); +eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _react = __webpack_require__(/*! react */ \"./node_modules/react/index.js\");\n\nvar _react2 = _interopRequireDefault(_react);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar Brick = function Brick(props) {\n return _react2.default.createElement(\n 'div',\n { className: 'brick ' + props.powerup },\n _react2.default.createElement(\n 'p',\n null,\n props.word\n )\n );\n};\n\nexports.default = Brick;//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9jbGllbnQvc3JjL2NvbXBvbmVudHMvQnJpY2suanN4LmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vL2NsaWVudC9zcmMvY29tcG9uZW50cy9Ccmljay5qc3g/MDI3NyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuXG5jb25zdCBCcmljayA9IChwcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtgYnJpY2sgJHtwcm9wcy5wb3dlcnVwfWB9PlxuICAgICAgPHA+e3Byb3BzLndvcmR9PC9wPlxuICAgIDwvZGl2PlxuICApXG59XG5cbmV4cG9ydCBkZWZhdWx0IEJyaWNrOyJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUE7QUFDQTs7Ozs7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFEQTtBQUlBO0FBQ0E7QUFDQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./client/src/components/Brick.jsx\n"); /***/ }), @@ -106,7 +106,19 @@ eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("/* WEBPACK VAR INJECTION */(function(process) {\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = __webpack_require__(/*! react */ \"./node_modules/react/index.js\");\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _Brick = __webpack_require__(/*! ./Brick.jsx */ \"./client/src/components/Brick.jsx\");\n\nvar _Brick2 = _interopRequireDefault(_Brick);\n\nvar _axios = __webpack_require__(/*! axios */ \"./node_modules/axios/index.js\");\n\nvar _axios2 = _interopRequireDefault(_axios);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar io = __webpack_require__(/*! socket.io-client */ \"./node_modules/socket.io-client/lib/index.js\");\nvar socket = io();\n\nvar Game = function (_React$Component) {\n _inherits(Game, _React$Component);\n\n function Game(props) {\n _classCallCheck(this, Game);\n\n var _this = _possibleConstructorReturn(this, (Game.__proto__ || Object.getPrototypeOf(Game)).call(this, props));\n\n _this.state = {\n userInput: '',\n dictionary: {},\n words: [],\n theirWords: [],\n time: 0,\n timeInterval: 1000,\n round: 'all',\n instructions: [\"Humpty Dumpty sat on a wall,\", \"Humpty Dumpty had a great fall.\", \"All the king's horses and all the king's men\", \"Couldn't put Humpty together again.\", \"HURRY - KEEP TYPING TO PREVENT HIS DEMISE!\"],\n prompt: 'START GAME',\n opponentTime: 0\n };\n\n _this.getReady = _this.getReady.bind(_this);\n _this.startGame = _this.startGame.bind(_this);\n _this.addWord = _this.addWord.bind(_this);\n _this.updateOpponentWordList = _this.updateOpponentWordList.bind(_this);\n _this.handleChange = _this.handleChange.bind(_this);\n _this.handleSubmit = _this.handleSubmit.bind(_this);\n _this.sendScore = _this.sendScore.bind(_this);\n _this.stopGame = _this.stopGame.bind(_this);\n\n var c = io.connect(process.env.PORT, { query: _this.state.time });\n console.log('c', c);\n\n socket.on('receive words from opponent', function (words) {\n _this.updateOpponentWordList(words);\n });\n socket.on('startGame', function () {\n _this.startGame();\n });\n socket.on('they lost', function (score) {\n // this is bad, eventually put a red x over their bricks or something\n _this.setState({\n opponentTime: score\n });\n document.getElementById('their-game').style.backgroundColor = \"red\";\n });\n return _this;\n }\n\n // get words from dictionary and join socket\n\n\n _createClass(Game, [{\n key: 'componentDidMount',\n value: function componentDidMount() {\n var _this2 = this;\n\n _axios2.default.get('/dictionary').then(function (results) {\n _this2.setState({\n dictionary: results.data\n });\n }).catch(function (err) {\n console.error(err);\n });\n socket.emit('entering room', {\n room: this.props.room,\n username: this.props.username\n });\n }\n\n // sends your words to opponent\n\n }, {\n key: 'componentDidUpdate',\n value: function componentDidUpdate(prevProps, prevState) {\n if (this.state.words.length !== prevState.words.length) {\n socket.emit('send words to opponent', {\n room: this.props.room,\n newWords: this.state.words\n });\n }\n }\n\n // leave socket\n\n }, {\n key: 'componentWillUnmount',\n value: function componentWillUnmount() {\n socket.emit('leaving room', {\n room: this.props.room,\n username: this.props.username\n });\n }\n\n // hides starter form and user input, waits for another player to start game\n\n }, {\n key: 'getReady',\n value: function getReady(e) {\n e.preventDefault();\n document.getElementById('starter-form').disabled = true;\n document.getElementById('user-input').disabled = true;\n this.setState({\n prompt: 'WAITING...'\n });\n socket.emit('ready', {\n room: this.props.room,\n username: this.props.username\n });\n }\n }, {\n key: 'startGame',\n value: function startGame() {\n var _this3 = this;\n\n document.getElementById('typing-input').disabled = false;\n document.getElementById('typing-input').focus();\n document.getElementById('overlay').style.display = \"none\";\n document.getElementById('their-game').style.backgroundColor = \"transparent\";\n document.getElementById('gudetama').style = {\n display: \"inline-block\",\n backgroundColor: \"none\"\n };\n document.getElementById('their-gudetama').style = {\n display: \"inline-block\",\n backgroundColor: \"none\"\n };\n\n // long function to define what happens at every interval\n var go = function go() {\n // creates a loop by calling itself:\n var step = setTimeout(function () {\n go();\n }, _this3.state.timeInterval);\n\n // adds a brick:\n _this3.addWord();\n\n // ends game or changes background color of gudetama based on length of \"words\" array\n // (as bricks build up, background turns a darker red to signify danger)\n if (_this3.state.words.length >= 20) {\n clearTimeout(step);\n //console.log('opponent time',this.state.time)\n socket.emit('i lost', {\n room: _this3.props.room,\n username: _this3.props.username,\n score: _this3.state.time\n });\n _this3.stopGame();\n } else if (_this3.state.words.length > 15) {\n document.getElementById('gudetama').style.backgroundColor = \"rgba(255, 0, 0, 1)\";\n } else if (_this3.state.words.length > 10) {\n document.getElementById('gudetama').style.backgroundColor = \"rgba(255, 0, 0, 0.5)\";\n }\n\n // updates the time and speeds up the game accordingly \n // (as timeInterval decreases, words appear at a faster rate)\n var newTime = _this3.state.time + 1;\n if (newTime > 20) {\n _this3.setState({\n time: newTime,\n timeInterval: 600\n //round: 'roundThree', // uncomment these to only serve short words at beginning, long words at end\n });\n } else if (newTime > 8) {\n _this3.setState({\n time: newTime,\n timeInterval: 800\n //round: 'roundTwo',\n });\n } else {\n _this3.setState({\n time: newTime\n //round: 'roundOne',\n });\n }\n };\n\n // blank slate, then start!\n this.setState({\n words: [],\n time: 0,\n timeInterval: 1000,\n userInput: ''\n }, function () {\n return go();\n });\n }\n\n // pulls random word from dictionary obj and adds it to words state\n\n }, {\n key: 'addWord',\n value: function addWord() {\n var availableWords = this.state.dictionary[this.state.round];\n var newWord = availableWords[Math.floor(Math.random() * availableWords.length)];\n this.setState({\n words: [].concat(_toConsumableArray(this.state.words), [newWord])\n });\n }\n\n // updates your view of opponent's words\n\n }, {\n key: 'updateOpponentWordList',\n value: function updateOpponentWordList(words) {\n this.setState({\n theirWords: words\n });\n }\n\n // updates userInput with what user is currently typing\n\n }, {\n key: 'handleChange',\n value: function handleChange(e) {\n this.setState({\n userInput: e.target.value\n });\n }\n\n // when the user hits \"enter\"\n\n }, {\n key: 'handleSubmit',\n value: function handleSubmit(e) {\n e.preventDefault();\n var submittedWord = this.state.userInput;\n var index = this.state.words.indexOf(submittedWord);\n\n // check if what they typed is in our \"words\" array\n // flash green for a correctly typed word and remove word from \"words\" array\n if (index !== -1) {\n document.getElementById('typing-input').style.backgroundColor = \"green\";\n var newWords = this.state.words.slice();\n newWords.splice(index, 1);\n playCorrect();\n this.setState({\n words: newWords\n });\n } else {\n // else flash red for a mistyped word\n playWrong();\n document.getElementById('typing-input').style.backgroundColor = \"red\";\n }\n\n setTimeout(function () {\n document.getElementById('typing-input').style.backgroundColor = \"white\";\n }, 100);\n\n this.setState({\n userInput: ''\n });\n }\n\n // upon game over, sends username and score to database to be added/updated\n\n }, {\n key: 'sendScore',\n value: function sendScore(username, score) {\n _axios2.default.post('/wordgame', {\n \"username\": username,\n \"high_score\": score\n }).then(function (result) {\n console.log(result);\n }).catch(function (err) {\n console.error(err);\n });\n }\n }, {\n key: 'stopGame',\n value: function stopGame() {\n document.getElementById('typing-input').disabled = true;\n document.getElementById('overlay').style.display = \"block\";\n document.getElementById('gudetama').style.display = \"none\";\n document.getElementById('their-gudetama').style.display = \"none\";\n document.getElementById('starter-form').disabled = false;\n document.getElementById('user-input').disabled = false;\n\n // enables user to hit \"enter\" after 2 seconds to restart game\n setTimeout(function () {\n if (document.getElementById('overlay').display !== \"none\") {\n document.getElementById('user-input').focus();\n }\n }, 2000);\n\n this.sendScore(this.props.username, this.state.time);\n\n // audio effect\n playGameOver();\n\n this.setState({\n // maybe find a way to compare your score vs opponent's score and show YOU WIN/YOU LOSE\n instructions: ['GAME OVER', 'YOU SCORED: ' + this.state.time, 'YOUR OPPONENT SCORED: ' + this.state.opponentTime],\n prompt: 'REPLAY'\n });\n }\n }, {\n key: 'render',\n value: function render() {\n return _react2.default.createElement(\n 'div',\n { className: 'game' },\n _react2.default.createElement(\n 'div',\n { id: 'overlay' },\n _react2.default.createElement(\n 'div',\n null,\n this.state.instructions.map(function (line, index) {\n // audio effect:\n playStart();\n return _react2.default.createElement(\n 'span',\n { key: index },\n line,\n _react2.default.createElement('br', null)\n );\n })\n ),\n _react2.default.createElement('div', { id: 'crackedegg' }),\n _react2.default.createElement(\n 'div',\n null,\n _react2.default.createElement(\n 'form',\n { id: 'starter-form', onSubmit: this.getReady, autoComplete: 'off' },\n _react2.default.createElement('input', { id: 'user-input', placeholder: 'Who are you?', value: this.props.username, onChange: this.props.handleUserNameChange, autoFocus: true })\n )\n ),\n _react2.default.createElement(\n 'div',\n { id: 'overlay-start', onClick: this.startGame, className: 'blinking' },\n this.state.prompt\n )\n ),\n _react2.default.createElement(\n 'div',\n { className: 'timer' },\n _react2.default.createElement(\n 'h1',\n null,\n this.state.time\n )\n ),\n _react2.default.createElement(\n 'div',\n { className: 'board' },\n _react2.default.createElement(\n 'div',\n { className: 'play' },\n this.state.words.map(function (word, index) {\n return _react2.default.createElement(_Brick2.default, { word: word, key: index });\n }),\n _react2.default.createElement('div', { id: 'gudetama' }),\n _react2.default.createElement(\n 'form',\n { onSubmit: this.handleSubmit, autoComplete: 'off' },\n _react2.default.createElement('input', { id: 'typing-input', value: this.state.userInput, onChange: this.handleChange })\n )\n ),\n _react2.default.createElement(\n 'div',\n { className: 'play', id: 'their-game' },\n this.state.theirWords.map(function (word, index) {\n return _react2.default.createElement(_Brick2.default, { word: word, key: index });\n }),\n _react2.default.createElement('div', { id: 'their-gudetama' }),\n _react2.default.createElement(\n 'form',\n { autoComplete: 'off' },\n _react2.default.createElement('input', { value: 'OPPONENT' })\n )\n )\n )\n );\n }\n }]);\n\n return Game;\n}(_react2.default.Component);\n\nexports.default = Game;\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./../../../node_modules/process/browser.js */ \"./node_modules/process/browser.js\")))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./client/src/components/Game.jsx.js","sources":["webpack:///client/src/components/Game.jsx?16eb"],"sourcesContent":["import React from 'react';\nimport Brick from './Brick.jsx';\nimport axios from 'axios';\nconst io = require('socket.io-client'); \nconst socket = io();\n\nclass Game extends React.Component {\n  constructor(props) {\n    super(props);\n    this.state = {\n      userInput: '',\n      dictionary: {},\n      words: [],\n      theirWords: [],\n      time: 0,\n      timeInterval: 1000,\n      round: 'all',\n      instructions: [\"Humpty Dumpty sat on a wall,\", \"Humpty Dumpty had a great fall.\", \"All the king's horses and all the king's men\", \"Couldn't put Humpty together again.\", \"HURRY - KEEP TYPING TO PREVENT HIS DEMISE!\"],\n      prompt: 'START GAME',\n      opponentTime: 0\n    }\n    \n    this.getReady = this.getReady.bind(this);\n    this.startGame = this.startGame.bind(this);\n    this.addWord = this.addWord.bind(this);\n    this.updateOpponentWordList = this.updateOpponentWordList.bind(this);\n    this.handleChange = this.handleChange.bind(this);\n    this.handleSubmit = this.handleSubmit.bind(this);\n    this.sendScore = this.sendScore.bind(this);\n    this.stopGame = this.stopGame.bind(this);\n\n    var c = io.connect(process.env.PORT, {query: this.state.time})\n    console.log('c', c)\n\n    socket.on('receive words from opponent', (words) => {\n      this.updateOpponentWordList(words);\n    });\n    socket.on('startGame', () => {\n      this.startGame();\n    });\n    socket.on('they lost', (score) => {\n      // this is bad, eventually put a red x over their bricks or something\n      this.setState({\n        opponentTime: score,\n      })\n      document.getElementById('their-game').style.backgroundColor = \"red\";\n    });\n  }\n\n  // get words from dictionary and join socket\n  componentDidMount() {\n    axios.get('/dictionary')\n    .then(results => {\n      this.setState({\n        dictionary: results.data,\n      })\n    }).catch(err => {\n      console.error(err);\n    });\n    socket.emit('entering room', {\n      room: this.props.room, \n      username: this.props.username\n    });\n  }\n\n  // sends your words to opponent\n  componentDidUpdate(prevProps, prevState) {\n    if (this.state.words.length !== prevState.words.length) {\n      socket.emit('send words to opponent', {\n        room: this.props.room,\n        newWords: this.state.words,\n      }); \n    }\n  }\n\n  // leave socket\n  componentWillUnmount() {  \n    socket.emit('leaving room', {\n      room: this.props.room,\n      username: this.props.username,\n    });\n  }\n\n  // hides starter form and user input, waits for another player to start game\n  getReady(e) {\n    e.preventDefault();\n    document.getElementById('starter-form').disabled = true;\n    document.getElementById('user-input').disabled = true;\n    this.setState({\n      prompt: 'WAITING...',\n    });\n    socket.emit('ready', {\n      room: this.props.room, \n      username: this.props.username\n    });\n  }\n\n  startGame() {\n    document.getElementById('typing-input').disabled = false;\n    document.getElementById('typing-input').focus();\n    document.getElementById('overlay').style.display = \"none\";\n    document.getElementById('their-game').style.backgroundColor = \"transparent\";\n    document.getElementById('gudetama').style = {\n      display: \"inline-block\",\n      backgroundColor: \"none\",\n    };\n    document.getElementById('their-gudetama').style = {\n      display: \"inline-block\",\n      backgroundColor: \"none\",\n    };\n\n    // long function to define what happens at every interval\n    var go = () => {\n      // creates a loop by calling itself:\n      var step = setTimeout(() => {\n        go();\n      }, this.state.timeInterval);\n\n      // adds a brick:\n      this.addWord();\n\n      // ends game or changes background color of gudetama based on length of \"words\" array\n      // (as bricks build up, background turns a darker red to signify danger)\n      if (this.state.words.length >= 20) {\n        clearTimeout(step);\n        //console.log('opponent time',this.state.time)\n        socket.emit('i lost', {\n          room: this.props.room, \n          username: this.props.username, \n          score: this.state.time\n        });\n        this.stopGame();\n      } else if (this.state.words.length > 15) {\n        document.getElementById('gudetama').style.backgroundColor = \"rgba(255, 0, 0, 1)\";\n      } else if (this.state.words.length > 10) {\n        document.getElementById('gudetama').style.backgroundColor = \"rgba(255, 0, 0, 0.5)\";\n      }\n\n      // updates the time and speeds up the game accordingly \n      // (as timeInterval decreases, words appear at a faster rate)\n      var newTime = this.state.time + 1;\n      if (newTime > 20) {\n        this.setState({\n          time: newTime,\n          timeInterval: 600,\n          //round: 'roundThree', // uncomment these to only serve short words at beginning, long words at end\n        });\n      } else if (newTime > 8) { \n        this.setState({\n          time: newTime,\n          timeInterval: 800,\n          //round: 'roundTwo',\n        });\n      } else {\n        this.setState({\n          time: newTime,\n          //round: 'roundOne',\n        });\n      }\n    }\n\n    // blank slate, then start!\n    this.setState({\n      words: [],\n      time: 0,\n      timeInterval: 1000,\n      userInput: '',\n    }, () => go());\n  \n  }\n\n  // pulls random word from dictionary obj and adds it to words state\n  addWord() {\n    var availableWords = this.state.dictionary[this.state.round];\n    var newWord = availableWords[Math.floor(Math.random() * availableWords.length)];\n    this.setState({\n      words: [...this.state.words, newWord]\n    });\n  }\n\n  // updates your view of opponent's words\n  updateOpponentWordList(words) {\n    this.setState({\n      theirWords: words\n    })\n  }\n\n  // updates userInput with what user is currently typing\n  handleChange(e) {\n    this.setState({\n      userInput: e.target.value,\n    })\n  }\n\n  // when the user hits \"enter\"\n  handleSubmit(e) {\n    e.preventDefault();\n    var submittedWord = this.state.userInput;\n    var index = this.state.words.indexOf(submittedWord);\n    \n    // check if what they typed is in our \"words\" array\n    // flash green for a correctly typed word and remove word from \"words\" array\n    if (index !== -1) {\n      document.getElementById('typing-input').style.backgroundColor = \"green\";\n      var newWords = this.state.words.slice();\n      newWords.splice(index, 1);\n      playCorrect(); \n      this.setState({\n        words: newWords,\n      });\n    } else {\n      // else flash red for a mistyped word\n      playWrong(); \n      document.getElementById('typing-input').style.backgroundColor = \"red\";\n    }\n\n    setTimeout(() => {\n      document.getElementById('typing-input').style.backgroundColor = \"white\";\n    }, 100);\n\n    this.setState({\n      userInput: '',\n    });\n  }\n\n  // upon game over, sends username and score to database to be added/updated\n  sendScore(username, score) {\n    axios.post('/wordgame', {\n      \"username\": username,\n      \"high_score\": score\n    })\n    .then(result => {\n      console.log(result);\n    }).catch(err => {\n      console.error(err);\n    })\n  }\n\n  stopGame() {\n    document.getElementById('typing-input').disabled = true;\n    document.getElementById('overlay').style.display = \"block\";\n    document.getElementById('gudetama').style.display = \"none\";\n    document.getElementById('their-gudetama').style.display = \"none\";\n    document.getElementById('starter-form').disabled = false;\n    document.getElementById('user-input').disabled = false;\n\n    // enables user to hit \"enter\" after 2 seconds to restart game\n    setTimeout(() => {\n      if (document.getElementById('overlay').display !== \"none\") {\n        document.getElementById('user-input').focus();\n      }\n    }, 2000);\n    \n    this.sendScore(this.props.username, this.state.time);\n \n    // audio effect\n    playGameOver();\n    \n    this.setState({\n      // maybe find a way to compare your score vs opponent's score and show YOU WIN/YOU LOSE\n      instructions: ['GAME OVER', `YOU SCORED: ${this.state.time}`, `YOUR OPPONENT SCORED: ${this.state.opponentTime}`],\n      prompt: 'REPLAY',\n    });\n  }\n\n  render() {\n    return (\n      <div className=\"game\">\n        <div id=\"overlay\">\n          <div>{this.state.instructions.map((line, index) => {\n            // audio effect:\n            playStart();\n            return (<span key={index}>{line}<br></br></span>)\n          })}</div>\n          <div id=\"crackedegg\"></div>\n          <div>\n            {/* \"getReady\" waits for 2 players, \"startGame\" (on click) is 1 player */}\n            <form id=\"starter-form\" onSubmit={this.getReady} autoComplete=\"off\">\n              <input id=\"user-input\" placeholder=\"Who are you?\" value={this.props.username} onChange={this.props.handleUserNameChange} autoFocus/>\n            </form>\n          </div>\n          <div id=\"overlay-start\" onClick={this.startGame} className=\"blinking\">{this.state.prompt}</div>\n        </div>\n    \n        <div className=\"timer\">\n          <h1>{this.state.time}</h1>\n        </div>\n\n        <div className=\"board\">\n          {/* your game: */}\n          <div className=\"play\"> \n            {this.state.words.map((word, index) => {\n              return <Brick word={word} key={index} />\n            })}\n            <div id=\"gudetama\"></div>\n            <form onSubmit={this.handleSubmit} autoComplete=\"off\">\n              <input id=\"typing-input\" value={this.state.userInput} onChange={this.handleChange} />\n            </form>\n          </div>\n\n          {/* their game: */}\n          <div className=\"play\" id=\"their-game\"> \n            {this.state.theirWords.map((word, index) => {\n              return <Brick word={word} key={index} />\n            })}\n            <div id=\"their-gudetama\"></div>\n            <form autoComplete=\"off\">\n              <input value=\"OPPONENT\" />\n            </form>\n          </div>\n        </div>\n      </div>\n    )\n  }\n}\n\nexport default Game;"],"mappings":";;;;;;;;AAAA;AACA;;;AAAA;AACA;;;AAAA;AACA;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;;;AACA;AAAA;AACA;AADA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAVA;AACA;AAYA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AADA;AAGA;AACA;AAvCA;AAwCA;AACA;AACA;AACA;AACA;;;AADA;AAAA;AACA;AAAA;AAEA;AACA;AADA;AAGA;AACA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;;;AAAA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;AACA;;;AAAA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;;;AAAA;AACA;AACA;AACA;AACA;AACA;AADA;AAGA;AACA;AACA;AAFA;AAIA;;;AAEA;AAAA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AAFA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAJA;AAKA;AAAA;AAEA;AACA;AACA;AACA;;;AAAA;AACA;AACA;AACA;AACA;AADA;AAGA;AACA;AACA;AACA;;;AAAA;AACA;AACA;AADA;AAGA;AACA;AACA;AACA;;;AAAA;AACA;AACA;AADA;AAGA;AACA;AACA;AACA;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AADA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AADA;AAGA;AACA;AACA;AACA;;;AAAA;AACA;AACA;AACA;AAFA;AAKA;AACA;AACA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;;;AAEA;AACA;AACA;AAAA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AAJA;AAKA;AACA;AAAA;AAAA;AAEA;AAAA;AAAA;AACA;AADA;AAFA;AAMA;AAAA;AAAA;AAAA;AAAA;AAbA;AAgBA;AAAA;AAAA;AACA;AAAA;AAAA;AAAA;AAAA;AADA;AAIA;AAAA;AAAA;AAEA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AADA;AALA;AAWA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AADA;AALA;AAbA;AArBA;AA8CA;;;;AAnTA;AACA;AAqTA;A","sourceRoot":""}\n//# sourceURL=webpack-internal:///./client/src/components/Game.jsx\n"); +eval("/* WEBPACK VAR INJECTION */(function(process) {\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = __webpack_require__(/*! react */ \"./node_modules/react/index.js\");\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _Brick = __webpack_require__(/*! ./Brick.jsx */ \"./client/src/components/Brick.jsx\");\n\nvar _Brick2 = _interopRequireDefault(_Brick);\n\nvar _axios = __webpack_require__(/*! axios */ \"./node_modules/axios/index.js\");\n\nvar _axios2 = _interopRequireDefault(_axios);\n\nvar _PowerBank = __webpack_require__(/*! ./PowerBank.jsx */ \"./client/src/components/PowerBank.jsx\");\n\nvar _PowerBank2 = _interopRequireDefault(_PowerBank);\n\nvar _constants = __webpack_require__(/*! constants */ \"./node_modules/constants-browserify/constants.json\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar io = __webpack_require__(/*! socket.io-client */ \"./node_modules/socket.io-client/lib/index.js\");\nvar socket = io();\n\nvar Game = function (_React$Component) {\n _inherits(Game, _React$Component);\n\n function Game(props) {\n _classCallCheck(this, Game);\n\n var _this = _possibleConstructorReturn(this, (Game.__proto__ || Object.getPrototypeOf(Game)).call(this, props));\n\n _this.state = {\n userInput: '',\n dictionary: {},\n words: [],\n theirWords: [],\n time: 0,\n timeInterval: 1000,\n round: 'all',\n instructions: [\"Humpty Dumpty sat on a wall,\", \"Humpty Dumpty had a great fall.\", \"All the king's horses and all the king's men\", \"Couldn't put Humpty together again.\", \"HURRY - KEEP TYPING TO PREVENT HIS DEMISE!\"],\n prompt: 'START GAME',\n opponentTime: 0,\n powerups: {},\n bankedPowers: []\n };\n\n _this.getReady = _this.getReady.bind(_this);\n _this.startGame = _this.startGame.bind(_this);\n _this.addWord = _this.addWord.bind(_this);\n _this.updateOpponentWordList = _this.updateOpponentWordList.bind(_this);\n _this.handleChange = _this.handleChange.bind(_this);\n _this.handleSubmit = _this.handleSubmit.bind(_this);\n _this.sendScore = _this.sendScore.bind(_this);\n _this.stopGame = _this.stopGame.bind(_this);\n\n _this.pauseGame = _this.pauseGame.bind(_this);\n _this.removeWords = _this.removeWords.bind(_this);\n _this.shuffleArray = _this.shuffleArray.bind(_this);\n _this.switchWords = _this.switchWords.bind(_this);\n\n _this.removeAllWords = _this.removeAllWords.bind(_this);\n _this.stopAll = _this.stopAll.bind(_this);\n _this.usePower = _this.usePower.bind(_this);\n _this.addPower = _this.addPower.bind(_this);\n var c = io.connect(process.env.PORT, { query: _this.state.time });\n console.log('c', c);\n\n socket.on('receive words from opponent', function (words) {\n _this.updateOpponentWordList(words);\n });\n socket.on('startGame', function () {\n _this.startGame();\n });\n socket.on('they lost', function (score) {\n // this is bad, eventually put a red x over their bricks or something\n _this.setState({\n opponentTime: score\n });\n document.getElementById('their-game').style.backgroundColor = \"red\";\n });\n return _this;\n }\n\n // get words from dictionary and join socket\n\n\n _createClass(Game, [{\n key: 'componentDidMount',\n value: function componentDidMount() {\n var _this2 = this;\n\n _axios2.default.get('/dictionary').then(function (results) {\n _this2.setState({\n dictionary: results.data\n });\n }).catch(function (err) {\n console.error(err);\n });\n socket.emit('entering room', {\n room: this.props.room,\n username: this.props.username\n });\n }\n\n // sends your words to opponent\n\n }, {\n key: 'componentDidUpdate',\n value: function componentDidUpdate(prevProps, prevState) {\n if (this.state.words.length !== prevState.words.length) {\n socket.emit('send words to opponent', {\n room: this.props.room,\n newWords: this.state.words\n });\n }\n }\n\n // leave socket\n\n }, {\n key: 'componentWillUnmount',\n value: function componentWillUnmount() {\n socket.emit('leaving room', {\n room: this.props.room,\n username: this.props.username\n });\n }\n\n // hides starter form and user input, waits for another player to start game\n\n }, {\n key: 'getReady',\n value: function getReady(e) {\n e.preventDefault();\n document.getElementById('starter-form').disabled = true;\n document.getElementById('user-input').disabled = true;\n this.setState({\n prompt: 'WAITING...'\n });\n socket.emit('ready', {\n room: this.props.room,\n username: this.props.username\n });\n }\n }, {\n key: 'startGame',\n value: function startGame() {\n var _this3 = this;\n\n document.getElementById('typing-input').disabled = false;\n document.getElementById('typing-input').focus();\n document.getElementById('overlay').style.display = \"none\";\n document.getElementById('their-game').style.backgroundColor = \"transparent\";\n document.getElementById('gudetama').style = {\n display: \"inline-block\",\n backgroundColor: \"none\"\n };\n document.getElementById('their-gudetama').style = {\n display: \"inline-block\",\n backgroundColor: \"none\"\n };\n\n // long function to define what happens at every interval\n var go = function go() {\n // creates a loop by calling itself:\n var step = setTimeout(function () {\n go();\n }, _this3.state.timeInterval);\n\n // adds a brick:\n _this3.addWord();\n\n // ends game or changes background color of gudetama based on length of \"words\" array\n // (as bricks build up, background turns a darker red to signify danger)\n if (_this3.state.words.length >= 20) {\n clearTimeout(step);\n //console.log('opponent time',this.state.time)\n socket.emit('i lost', {\n room: _this3.props.room,\n username: _this3.props.username,\n score: _this3.state.time\n });\n _this3.stopGame();\n } else if (_this3.state.words.length > 15) {\n document.getElementById('gudetama').style.backgroundColor = \"rgba(255, 0, 0, 1)\";\n } else if (_this3.state.words.length > 10) {\n document.getElementById('gudetama').style.backgroundColor = \"rgba(255, 0, 0, 0.5)\";\n }\n\n // updates the time and speeds up the game accordingly \n // (as timeInterval decreases, words appear at a faster rate)\n var newTime = _this3.state.time + 1;\n if (newTime > 20) {\n _this3.setState({\n time: newTime,\n timeInterval: 600\n //round: 'roundThree', // uncomment these to only serve short words at beginning, long words at end\n });\n } else if (newTime > 8) {\n _this3.setState({\n time: newTime,\n timeInterval: 800\n //round: 'roundTwo',\n });\n } else {\n _this3.setState({\n time: newTime\n //round: 'roundOne',\n });\n }\n };\n\n // blank slate, then start!\n this.setState({\n words: [],\n time: 0,\n timeInterval: 1000,\n userInput: ''\n }, function () {\n return go();\n });\n }\n\n // pulls random word from dictionary obj and adds it to words state\n\n }, {\n key: 'addWord',\n value: function addWord() {\n var availableWords = this.state.dictionary[this.state.round];\n var newWord = availableWords[Math.floor(Math.random() * availableWords.length)];\n this.addPower(newWord);\n this.setState({\n words: [].concat(_toConsumableArray(this.state.words), [newWord])\n });\n }\n\n // updates your view of opponent's words\n\n }, {\n key: 'updateOpponentWordList',\n value: function updateOpponentWordList(words) {\n this.setState({\n theirWords: words\n });\n }\n\n // updates userInput with what user is currently typing\n\n }, {\n key: 'handleChange',\n value: function handleChange(e) {\n this.setState({\n userInput: e.target.value\n });\n }\n\n // when the user hits \"enter\"\n\n }, {\n key: 'handleSubmit',\n value: function handleSubmit(e) {\n e.preventDefault();\n var submittedWord = this.state.userInput;\n var index = this.state.words.indexOf(submittedWord);\n var powerups;\n var deposit;\n // check if what they typed is in our \"words\" array\n // flash green for a correctly typed word and remove word from \"words\" array\n if (index !== -1) {\n\n document.getElementById('typing-input').style.backgroundColor = \"green\";\n var newWords = this.state.words.slice();\n newWords.splice(index, 1);\n playCorrect();\n\n if (this.state.powerups[submittedWord] != undefined) {\n powerups = Object.assign({}, this.state.powerups);\n deposit = powerups[submittedWord];\n delete powerups[submittedWord];\n\n if (this.state.bankedPowers.length != 0) {\n deposit = [].concat(_toConsumableArray(this.state.bankedPowers), [deposit]);\n } else {\n deposit = [deposit];\n }\n\n this.setState({\n words: newWords,\n bankedPowers: deposit,\n powerups: powerups\n });\n } else {\n this.setState({\n words: newWords\n });\n }\n } else {\n // else flash red for a mistyped word\n playWrong();\n document.getElementById('typing-input').style.backgroundColor = \"red\";\n }\n\n setTimeout(function () {\n document.getElementById('typing-input').style.backgroundColor = \"white\";\n }, 100);\n\n this.setState({\n userInput: ''\n });\n }\n\n // upon game over, sends username and score to database to be added/updated\n\n }, {\n key: 'sendScore',\n value: function sendScore(username, score) {\n _axios2.default.post('/wordgame', {\n \"username\": username,\n \"high_score\": score\n }).then(function (result) {\n console.log(result);\n }).catch(function (err) {\n console.error(err);\n });\n }\n }, {\n key: 'stopGame',\n value: function stopGame() {\n document.getElementById('typing-input').disabled = true;\n document.getElementById('overlay').style.display = \"block\";\n document.getElementById('gudetama').style.display = \"none\";\n document.getElementById('their-gudetama').style.display = \"none\";\n document.getElementById('starter-form').disabled = false;\n document.getElementById('user-input').disabled = false;\n\n // enables user to hit \"enter\" after 2 seconds to restart game\n setTimeout(function () {\n if (document.getElementById('overlay').display !== \"none\") {\n document.getElementById('user-input').focus();\n }\n }, 2000);\n\n this.sendScore(this.props.username, this.state.time);\n\n // audio effect\n playGameOver();\n\n this.setState({\n // maybe find a way to compare your score vs opponent's score and show YOU WIN/YOU LOSE\n instructions: ['GAME OVER', 'YOU SCORED: ' + this.state.time, 'YOUR OPPONENT SCORED: ' + this.state.opponentTime],\n prompt: 'REPLAY'\n });\n }\n\n //ADDED FOR POWERUPS\n\n }, {\n key: 'pauseGame',\n value: function pauseGame() {\n var _this4 = this;\n\n var previousInterval = this.state.timeInterval;\n setInterval(function () {\n _this4.setState({\n timeInterval: previousInterval\n });\n }, 5000);\n this.setState({\n timeInterval: 5000\n });\n }\n }, {\n key: 'shuffleArray',\n value: function shuffleArray(arr) {\n var current = arr.length;\n var temp;\n var rand;\n\n while (current !== 0) {\n rand = Math.floor(Math.random() * current);\n current--;\n temp = arr[current];\n arr[current] = arr[rand];\n arr[rand] = temp;\n }\n return arr;\n }\n }, {\n key: 'removeWords',\n value: function removeWords(num) {\n var removeWords = this.state.words.slice();\n var half = Math.floor(removeWords.length / 2);\n removeWords = this.shuffleArray(removeWords);\n removeWords = removeWords.slice(0, half);\n this.setState({\n words: removeWords\n });\n }\n }, {\n key: 'switchWords',\n value: function switchWords() {\n var list = this.state.words.slice();\n list.pop();\n list.push(\"aaa\");\n this.setState({\n words: list\n });\n }\n }, {\n key: 'removeAllWords',\n value: function removeAllWords(num) {\n this.setState({\n words: []\n });\n }\n }, {\n key: 'usePower',\n value: function usePower(e) {\n var temp;\n var banked;\n if (e.keyCode === 32) {\n temp = e.target.value;\n temp = temp.substring(0, temp.length - 1);\n\n if (this.state.bankedPowers[0] != undefined) {\n if (this.state.bankedPowers[0] === 'power0') {\n this.removeAllWords();\n } else if (this.state.bankedPowers[0] === 'power1') {\n this.pauseGame();\n } else if (this.state.bankedPowers[0] === 'power2') {\n this.removeWords();\n }\n banked = this.state.bankedPowers.slice();\n banked.shift();\n }\n this.setState({\n userInput: temp,\n bankedPowers: banked\n });\n }\n }\n }, {\n key: 'addPower',\n value: function addPower(word) {\n var chance = 4;\n var rand = Math.floor(Math.random() * chance) + 1;\n var current;\n if (rand === 1) {\n if (Object.keys(this.state.powerups).length === 0) {\n current = {};\n } else {\n current = this.state.powerups;\n }\n current[word] = \"power\" + Math.floor(Math.random() * 3);\n this.setState({\n powerups: current\n });\n }\n }\n }, {\n key: 'stopAll',\n value: function stopAll() {\n this.setState({\n timeInterval: 100000\n });\n }\n //END OF POWERUPS\n\n }, {\n key: 'render',\n value: function render() {\n var _this5 = this;\n\n return _react2.default.createElement(\n 'div',\n { className: 'game' },\n _react2.default.createElement(\n 'div',\n { id: 'overlay' },\n _react2.default.createElement(\n 'div',\n null,\n this.state.instructions.map(function (line, index) {\n // audio effect:\n playStart();\n return _react2.default.createElement(\n 'span',\n { key: index },\n line,\n _react2.default.createElement('br', null)\n );\n })\n ),\n _react2.default.createElement('div', { id: 'crackedegg' }),\n _react2.default.createElement(\n 'div',\n null,\n _react2.default.createElement(\n 'form',\n { id: 'starter-form', onSubmit: this.getReady, autoComplete: 'off' },\n _react2.default.createElement('input', { id: 'user-input', placeholder: 'Who are you?', value: this.props.username, onChange: this.props.handleUserNameChange, autoFocus: true })\n )\n ),\n _react2.default.createElement(\n 'div',\n { id: 'overlay-start', onClick: this.startGame, className: 'blinking' },\n this.state.prompt\n )\n ),\n _react2.default.createElement(\n 'div',\n { className: 'timer' },\n _react2.default.createElement(\n 'h1',\n null,\n this.state.time\n )\n ),\n _react2.default.createElement(\n 'div',\n { className: 'board' },\n _react2.default.createElement(\n 'div',\n { className: 'play' },\n this.state.words.map(function (word, index) {\n return _react2.default.createElement(_Brick2.default, { word: word, key: index, powerup: _this5.state.powerups[word] ? _this5.state.powerups[word] : \"\" });\n }),\n _react2.default.createElement('div', { id: 'gudetama' }),\n _react2.default.createElement(\n 'form',\n { onSubmit: this.handleSubmit, autoComplete: 'off' },\n _react2.default.createElement('input', { id: 'typing-input', type: 'text', value: this.state.userInput, onChange: this.handleChange, onKeyUp: this.usePower })\n )\n ),\n _react2.default.createElement(\n 'div',\n { id: 'power-bank' },\n _react2.default.createElement(\n 'h5',\n null,\n 'Powers:'\n ),\n this.state.bankedPowers.map(function (powerup, index) {\n return _react2.default.createElement(_PowerBank2.default, { key: index, powerup: powerup });\n }),\n _react2.default.createElement(\n 'div',\n { id: 'legend' },\n _react2.default.createElement(\n 'div',\n { className: 'power1' },\n 'Pause (5s)'\n ),\n _react2.default.createElement(\n 'div',\n { className: 'power2' },\n 'Remove 1/2'\n ),\n _react2.default.createElement(\n 'div',\n { className: 'power0' },\n 'Remove All'\n )\n )\n ),\n _react2.default.createElement(\n 'div',\n { className: 'play', id: 'their-game' },\n this.state.theirWords.map(function (word, index) {\n return _react2.default.createElement(_Brick2.default, { word: word, key: index });\n }),\n _react2.default.createElement('div', { id: 'their-gudetama' }),\n _react2.default.createElement(\n 'form',\n { autoComplete: 'off' },\n _react2.default.createElement('input', { value: 'OPPONENT' })\n )\n )\n )\n );\n }\n }]);\n\n return Game;\n}(_react2.default.Component);\n\nexports.default = Game;\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./../../../node_modules/process/browser.js */ \"./node_modules/process/browser.js\")))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./client/src/components/Game.jsx.js","sources":["webpack:///client/src/components/Game.jsx?16eb"],"sourcesContent":["import React from 'react';\nimport Brick from './Brick.jsx';\nimport axios from 'axios';\nimport PowerBank from './PowerBank.jsx';\n\nimport { EEXIST } from 'constants';\nconst io = require('socket.io-client'); \nconst socket = io();\n\nclass Game extends React.Component {\n  constructor(props) {\n    super(props);\n    this.state = {\n      userInput: '',\n      dictionary: {},\n      words: [],\n      theirWords: [],\n      time: 0,\n      timeInterval: 1000,\n      round: 'all',\n      instructions: [\"Humpty Dumpty sat on a wall,\", \"Humpty Dumpty had a great fall.\", \"All the king's horses and all the king's men\", \"Couldn't put Humpty together again.\", \"HURRY - KEEP TYPING TO PREVENT HIS DEMISE!\"],\n      prompt: 'START GAME',\n      opponentTime: 0,\n      powerups: {},\n      bankedPowers: []\n    }\n    \n    this.getReady = this.getReady.bind(this);\n    this.startGame = this.startGame.bind(this);\n    this.addWord = this.addWord.bind(this);\n    this.updateOpponentWordList = this.updateOpponentWordList.bind(this);\n    this.handleChange = this.handleChange.bind(this);\n    this.handleSubmit = this.handleSubmit.bind(this);\n    this.sendScore = this.sendScore.bind(this);\n    this.stopGame = this.stopGame.bind(this);\n\n    this.pauseGame = this.pauseGame.bind(this);\n    this.removeWords = this.removeWords.bind(this);\n    this.shuffleArray = this.shuffleArray.bind(this);\n    this.switchWords = this.switchWords.bind(this);\n\n    this.removeAllWords = this.removeAllWords.bind(this);\n    this.stopAll = this.stopAll.bind(this);\n    this.usePower = this.usePower.bind(this);\n    this.addPower = this.addPower.bind(this);\n    var c = io.connect(process.env.PORT, {query: this.state.time})\n    console.log('c', c)\n\n    socket.on('receive words from opponent', (words) => {\n      this.updateOpponentWordList(words);\n    });\n    socket.on('startGame', () => {\n      this.startGame();\n    });\n    socket.on('they lost', (score) => {\n      // this is bad, eventually put a red x over their bricks or something\n      this.setState({\n        opponentTime: score,\n      })\n      document.getElementById('their-game').style.backgroundColor = \"red\";\n    });\n  }\n\n  // get words from dictionary and join socket\n  componentDidMount() {\n    axios.get('/dictionary')\n    .then(results => {\n      this.setState({\n        dictionary: results.data,\n      })\n    }).catch(err => {\n      console.error(err);\n    });\n    socket.emit('entering room', {\n      room: this.props.room, \n      username: this.props.username\n    });\n  }\n\n  // sends your words to opponent\n  componentDidUpdate(prevProps, prevState) {\n    if (this.state.words.length !== prevState.words.length) {\n      socket.emit('send words to opponent', {\n        room: this.props.room,\n        newWords: this.state.words,\n      }); \n    }\n  }\n\n  // leave socket\n  componentWillUnmount() {  \n    socket.emit('leaving room', {\n      room: this.props.room,\n      username: this.props.username,\n    });\n  }\n\n  // hides starter form and user input, waits for another player to start game\n  getReady(e) {\n    e.preventDefault();\n    document.getElementById('starter-form').disabled = true;\n    document.getElementById('user-input').disabled = true;\n    this.setState({\n      prompt: 'WAITING...',\n    });\n    socket.emit('ready', {\n      room: this.props.room, \n      username: this.props.username\n    });\n  }\n\n  startGame() {\n    document.getElementById('typing-input').disabled = false;\n    document.getElementById('typing-input').focus();\n    document.getElementById('overlay').style.display = \"none\";\n    document.getElementById('their-game').style.backgroundColor = \"transparent\";\n    document.getElementById('gudetama').style = {\n      display: \"inline-block\",\n      backgroundColor: \"none\",\n    };\n    document.getElementById('their-gudetama').style = {\n      display: \"inline-block\",\n      backgroundColor: \"none\",\n    };\n\n    // long function to define what happens at every interval\n    var go = () => {\n      // creates a loop by calling itself:\n      var step = setTimeout(() => {\n        go();\n      }, this.state.timeInterval);\n\n      // adds a brick:\n      this.addWord();\n\n      // ends game or changes background color of gudetama based on length of \"words\" array\n      // (as bricks build up, background turns a darker red to signify danger)\n      if (this.state.words.length >= 20) {\n        clearTimeout(step);\n        //console.log('opponent time',this.state.time)\n        socket.emit('i lost', {\n          room: this.props.room, \n          username: this.props.username, \n          score: this.state.time\n        });\n        this.stopGame();\n      } else if (this.state.words.length > 15) {\n        document.getElementById('gudetama').style.backgroundColor = \"rgba(255, 0, 0, 1)\";\n      } else if (this.state.words.length > 10) {\n        document.getElementById('gudetama').style.backgroundColor = \"rgba(255, 0, 0, 0.5)\";\n      }\n\n      // updates the time and speeds up the game accordingly \n      // (as timeInterval decreases, words appear at a faster rate)\n      var newTime = this.state.time + 1;\n      if (newTime > 20) {\n        this.setState({\n          time: newTime,\n          timeInterval: 600,\n          //round: 'roundThree', // uncomment these to only serve short words at beginning, long words at end\n        });\n      } else if (newTime > 8) { \n        this.setState({\n          time: newTime,\n          timeInterval: 800,\n          //round: 'roundTwo',\n        });\n      } else {\n        this.setState({\n          time: newTime,\n          //round: 'roundOne',\n        });\n      }\n    }\n\n    // blank slate, then start!\n    this.setState({\n      words: [],\n      time: 0,\n      timeInterval: 1000,\n      userInput: '',\n    }, () => go());\n  \n  }\n\n  // pulls random word from dictionary obj and adds it to words state\n  addWord() {\n    var availableWords = this.state.dictionary[this.state.round];\n    var newWord = availableWords[Math.floor(Math.random() * availableWords.length)];\n    this.addPower(newWord);\n    this.setState({\n      words: [...this.state.words, newWord]\n    });\n  }\n\n  // updates your view of opponent's words\n  updateOpponentWordList(words) {\n    this.setState({\n      theirWords: words\n    })\n  }\n\n  // updates userInput with what user is currently typing\n  handleChange(e) {\n    this.setState({\n      userInput: e.target.value,\n    })\n  }\n\n  // when the user hits \"enter\"\n  handleSubmit(e) {\n    e.preventDefault();\n    var submittedWord = this.state.userInput;\n    var index = this.state.words.indexOf(submittedWord);\n    var powerups;\n    var deposit;\n    // check if what they typed is in our \"words\" array\n    // flash green for a correctly typed word and remove word from \"words\" array\n    if (index !== -1) {\n    \n      document.getElementById('typing-input').style.backgroundColor = \"green\";\n      var newWords = this.state.words.slice();\n      newWords.splice(index, 1);\n      playCorrect();\n\n      if(this.state.powerups[submittedWord] != undefined){\n        powerups = Object.assign({}, this.state.powerups);\n        deposit = powerups[submittedWord];\n        delete powerups[submittedWord];\n    \n        if(this.state.bankedPowers.length != 0){\n          deposit = [...this.state.bankedPowers, deposit]\n        } else {\n          deposit = [deposit];\n        }\n\n        this.setState({\n          words: newWords,\n          bankedPowers: deposit,\n          powerups: powerups\n        });\n\n      } else { \n        this.setState({\n          words: newWords,\n        });\n      }\n    } else {\n      // else flash red for a mistyped word\n      playWrong(); \n      document.getElementById('typing-input').style.backgroundColor = \"red\";\n    }\n\n    setTimeout(() => {\n      document.getElementById('typing-input').style.backgroundColor = \"white\";\n    }, 100);\n\n    this.setState({\n      userInput: '',\n    });\n  }\n\n  // upon game over, sends username and score to database to be added/updated\n  sendScore(username, score) {\n    axios.post('/wordgame', {\n      \"username\": username,\n      \"high_score\": score\n    })\n    .then(result => {\n      console.log(result);\n    }).catch(err => {\n      console.error(err);\n    })\n  }\n\n  stopGame() {\n    document.getElementById('typing-input').disabled = true;\n    document.getElementById('overlay').style.display = \"block\";\n    document.getElementById('gudetama').style.display = \"none\";\n    document.getElementById('their-gudetama').style.display = \"none\";\n    document.getElementById('starter-form').disabled = false;\n    document.getElementById('user-input').disabled = false;\n\n    // enables user to hit \"enter\" after 2 seconds to restart game\n    setTimeout(() => {\n      if (document.getElementById('overlay').display !== \"none\") {\n        document.getElementById('user-input').focus();\n      }\n    }, 2000);\n    \n    this.sendScore(this.props.username, this.state.time);\n \n    // audio effect\n    playGameOver();\n    \n    this.setState({\n      // maybe find a way to compare your score vs opponent's score and show YOU WIN/YOU LOSE\n      instructions: ['GAME OVER', `YOU SCORED: ${this.state.time}`, `YOUR OPPONENT SCORED: ${this.state.opponentTime}`],\n      prompt: 'REPLAY',\n    });\n  }\n  \n  //ADDED FOR POWERUPS\n  pauseGame(){\n    var previousInterval = this.state.timeInterval;\n    setInterval(()=>{\n      this.setState({\n        timeInterval: previousInterval\n      });\n    },5000);\n    this.setState({\n      timeInterval: 5000\n    });\n  }\n\n  shuffleArray(arr){\n    var current = arr.length;\n    var temp;\n    var rand;\n\n    while(current !== 0){\n      rand = Math.floor(Math.random() * current);\n      current--;\n      temp = arr[current];\n      arr[current] = arr[rand];\n      arr[rand] = temp;\n    }  \n    return arr;\n  }\n\n  removeWords(num){\n    var removeWords = this.state.words.slice();\n    var half = Math.floor(removeWords.length/2);\n    removeWords = this.shuffleArray(removeWords);\n    removeWords = removeWords.slice(0, half);\n    this.setState({\n      words: removeWords\n    });\n  }\n\n  switchWords(){\n    var list = this.state.words.slice();\n    list.pop();\n    list.push(\"aaa\");\n    this.setState({\n      words: list\n    });\n  }\n  removeAllWords(num){\n    this.setState({\n      words: []\n    });\n  }\n  usePower(e){\n    var temp;\n    var banked;\n    if(e.keyCode === 32){\n      temp = e.target.value;\n      temp = temp.substring(0, temp.length-1);\n     \n      if(this.state.bankedPowers[0] != undefined){\n        if(this.state.bankedPowers[0] === 'power0'){\n          this.removeAllWords();\n        } else if(this.state.bankedPowers[0] === 'power1'){\n          this.pauseGame();\n        } else if(this.state.bankedPowers[0] === 'power2'){\n          this.removeWords();\n        }\n        banked = this.state.bankedPowers.slice();\n        banked.shift(); \n      }\n      this.setState({\n        userInput: temp,\n        bankedPowers: banked\n      })\n    }\n  }\n\n  addPower(word){\n    var chance = 4;\n    var rand = Math.floor(Math.random() * chance) + 1;\n    var current;\n    if(rand === 1){\n      if(Object.keys(this.state.powerups).length === 0){\n        current = {};\n      } else {\n        current = this.state.powerups;\n      }\n      current[word] = \"power\" + Math.floor(Math.random() * 3);\n      this.setState({\n        powerups: current\n      })\n    }\n  }\n\n  stopAll(){\n    this.setState({\n      timeInterval: 100000\n    });\n  }\n  //END OF POWERUPS\n\n  render() {\n    return (\n      <div className=\"game\">\n        <div id=\"overlay\">\n          <div>{this.state.instructions.map((line, index) => {\n            // audio effect:\n            playStart();\n            return (<span key={index}>{line}<br></br></span>)\n          })}</div>\n          <div id=\"crackedegg\"></div>\n          <div>\n            {/* \"getReady\" waits for 2 players, \"startGame\" (on click) is 1 player */}\n            <form id=\"starter-form\" onSubmit={this.getReady} autoComplete=\"off\">\n              <input id=\"user-input\" placeholder=\"Who are you?\" value={this.props.username} onChange={this.props.handleUserNameChange} autoFocus/>\n            </form>\n          </div>\n          <div id=\"overlay-start\" onClick={this.startGame} className=\"blinking\">{this.state.prompt}</div>\n        </div>\n    \n        <div className=\"timer\">\n          <h1>{this.state.time}</h1>\n          {/*<button id='button-stopall' onClick={this.stopAll}>STOPALL</button>\n          <button id='button-pause' onClick={this.pauseGame}>PAUSE</button>\n          <button id='button-removeWords' onClick={()=>this.removeWords(3)}>REMOVE</button>\n        <button id='button-switchWords' onClick={this.switchWords}>SWITCH</button>*/}\n        </div>\n\n        <div className=\"board\">\n          {/* your game: */}\n          <div className=\"play\"> \n            {this.state.words.map((word, index) => {\n              return <Brick word={word} key={index} powerup={this.state.powerups[word] ? this.state.powerups[word] : \"\"}/>\n            })}\n            <div id=\"gudetama\"></div>\n            <form onSubmit={this.handleSubmit} autoComplete=\"off\">\n              <input id=\"typing-input\" type='text' value={this.state.userInput} onChange={this.handleChange} onKeyUp={this.usePower}/>\n            </form>\n          </div>\n\n          <div id=\"power-bank\">\n            <h5>Powers:</h5>\n            {this.state.bankedPowers.map((powerup, index)=>{\n              return <PowerBank key={index} powerup={powerup} />\n            })}\n            <div id='legend'>\n              <div className='power1'>Pause (5s)</div>\n              <div className='power2'>Remove 1/2</div>\n              <div className='power0'>Remove All</div>\n            </div>\n          </div>\n        \n\n          {/* their game: */}\n          <div className=\"play\" id=\"their-game\"> \n            {this.state.theirWords.map((word, index) => {\n              return <Brick word={word} key={index} />\n            })}\n            <div id=\"their-gudetama\"></div>\n            <form autoComplete=\"off\">\n              <input value=\"OPPONENT\" />\n            </form>\n          </div>\n        </div>\n      </div>\n    )\n  }\n}\n\nexport default Game;"],"mappings":";;;;;;;;AAAA;AACA;;;AAAA;AACA;;;AAAA;AACA;;;AAAA;AACA;;;AACA;AACA;;;;;;;;;;;AAAA;AACA;AACA;AACA;;;AACA;AAAA;AACA;AADA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAZA;AACA;AAcA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AADA;AAGA;AACA;AAlDA;AAmDA;AACA;AACA;AACA;AACA;;;AADA;AAAA;AACA;AAAA;AAEA;AACA;AADA;AAGA;AACA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;;;AAAA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;AACA;;;AAAA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;;;AAAA;AACA;AACA;AACA;AACA;AACA;AADA;AAGA;AACA;AACA;AAFA;AAIA;;;AAEA;AAAA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AAFA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAJA;AAKA;AAAA;AAEA;AACA;AACA;AACA;;;AAAA;AACA;AACA;AACA;AACA;AACA;AADA;AAGA;AACA;AACA;AACA;;;AAAA;AACA;AACA;AADA;AAGA;AACA;AACA;AACA;;;AAAA;AACA;AACA;AADA;AAGA;AACA;AACA;AACA;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AAMA;AACA;AACA;AADA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AADA;AAGA;AACA;AACA;AACA;;;AAAA;AACA;AACA;AACA;AAFA;AAKA;AACA;AACA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;;;AAAA;AAAA;AACA;AAAA;AACA;AACA;AACA;AADA;AAGA;AACA;AACA;AADA;AAGA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AADA;AAGA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AADA;AAGA;;;AACA;AACA;AACA;AADA;AAGA;;;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AADA;AAGA;AACA;;;AAEA;AACA;AACA;AADA;AAGA;AACA;AACA;;;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AAJA;AAKA;AACA;AAAA;AAAA;AAEA;AAAA;AAAA;AACA;AADA;AAFA;AAMA;AAAA;AAAA;AAAA;AAAA;AAbA;AAgBA;AAAA;AAAA;AACA;AAAA;AAAA;AAAA;AAAA;AADA;AAQA;AAAA;AAAA;AAEA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AADA;AALA;AAUA;AAAA;AAAA;AACA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AAAA;AAAA;AACA;AAAA;AAAA;AAAA;AAAA;AACA;AAAA;AAAA;AAAA;AAAA;AAHA;AALA;AAcA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AADA;AALA;AA1BA;AAzBA;AA+DA;;;;AA1cA;AACA;AA4cA;A","sourceRoot":""}\n//# sourceURL=webpack-internal:///./client/src/components/Game.jsx\n"); + +/***/ }), + +/***/ "./client/src/components/PowerBank.jsx": +/*!*********************************************!*\ + !*** ./client/src/components/PowerBank.jsx ***! + \*********************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _react = __webpack_require__(/*! react */ \"./node_modules/react/index.js\");\n\nvar _react2 = _interopRequireDefault(_react);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar PowerBank = function PowerBank(props) {\n return _react2.default.createElement('div', { className: 'powerup ' + props.powerup });\n};\n\nexports.default = PowerBank;//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9jbGllbnQvc3JjL2NvbXBvbmVudHMvUG93ZXJCYW5rLmpzeC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy9jbGllbnQvc3JjL2NvbXBvbmVudHMvUG93ZXJCYW5rLmpzeD8yMDIwIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5cbmNvbnN0IFBvd2VyQmFuayA9IChwcm9wcykgPT4ge1xuICAgIHJldHVybiAoXG4gICAgICAgIDxkaXYgY2xhc3NOYW1lPXtgcG93ZXJ1cCAke3Byb3BzLnBvd2VydXB9YH0+PC9kaXY+XG4gICAgKVxufVxuXG5leHBvcnQgZGVmYXVsdCBQb3dlckJhbms7XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBO0FBQ0E7Ozs7O0FBQ0E7QUFDQTtBQUdBO0FBQ0E7QUFDQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./client/src/components/PowerBank.jsx\n"); /***/ }), @@ -545,6 +557,17 @@ eval("\nmodule.exports = function(a, b){\n var fn = function(){};\n fn.prototy /***/ }), +/***/ "./node_modules/constants-browserify/constants.json": +/*!**********************************************************!*\ + !*** ./node_modules/constants-browserify/constants.json ***! + \**********************************************************/ +/*! exports provided: O_RDONLY, O_WRONLY, O_RDWR, S_IFMT, S_IFREG, S_IFDIR, S_IFCHR, S_IFBLK, S_IFIFO, S_IFLNK, S_IFSOCK, O_CREAT, O_EXCL, O_NOCTTY, O_TRUNC, O_APPEND, O_DIRECTORY, O_NOFOLLOW, O_SYNC, O_SYMLINK, O_NONBLOCK, S_IRWXU, S_IRUSR, S_IWUSR, S_IXUSR, S_IRWXG, S_IRGRP, S_IWGRP, S_IXGRP, S_IRWXO, S_IROTH, S_IWOTH, S_IXOTH, E2BIG, EACCES, EADDRINUSE, EADDRNOTAVAIL, EAFNOSUPPORT, EAGAIN, EALREADY, EBADF, EBADMSG, EBUSY, ECANCELED, ECHILD, ECONNABORTED, ECONNREFUSED, ECONNRESET, EDEADLK, EDESTADDRREQ, EDOM, EDQUOT, EEXIST, EFAULT, EFBIG, EHOSTUNREACH, EIDRM, EILSEQ, EINPROGRESS, EINTR, EINVAL, EIO, EISCONN, EISDIR, ELOOP, EMFILE, EMLINK, EMSGSIZE, EMULTIHOP, ENAMETOOLONG, ENETDOWN, ENETRESET, ENETUNREACH, ENFILE, ENOBUFS, ENODATA, ENODEV, ENOENT, ENOEXEC, ENOLCK, ENOLINK, ENOMEM, ENOMSG, ENOPROTOOPT, ENOSPC, ENOSR, ENOSTR, ENOSYS, ENOTCONN, ENOTDIR, ENOTEMPTY, ENOTSOCK, ENOTSUP, ENOTTY, ENXIO, EOPNOTSUPP, EOVERFLOW, EPERM, EPIPE, EPROTO, EPROTONOSUPPORT, EPROTOTYPE, ERANGE, EROFS, ESPIPE, ESRCH, ESTALE, ETIME, ETIMEDOUT, ETXTBSY, EWOULDBLOCK, EXDEV, SIGHUP, SIGINT, SIGQUIT, SIGILL, SIGTRAP, SIGABRT, SIGIOT, SIGBUS, SIGFPE, SIGKILL, SIGUSR1, SIGSEGV, SIGUSR2, SIGPIPE, SIGALRM, SIGTERM, SIGCHLD, SIGCONT, SIGSTOP, SIGTSTP, SIGTTIN, SIGTTOU, SIGURG, SIGXCPU, SIGXFSZ, SIGVTALRM, SIGPROF, SIGWINCH, SIGIO, SIGSYS, SSL_OP_ALL, SSL_OP_ALLOW_UNSAFE_LEGACY_RENEGOTIATION, SSL_OP_CIPHER_SERVER_PREFERENCE, SSL_OP_CISCO_ANYCONNECT, SSL_OP_COOKIE_EXCHANGE, SSL_OP_CRYPTOPRO_TLSEXT_BUG, SSL_OP_DONT_INSERT_EMPTY_FRAGMENTS, SSL_OP_EPHEMERAL_RSA, SSL_OP_LEGACY_SERVER_CONNECT, SSL_OP_MICROSOFT_BIG_SSLV3_BUFFER, SSL_OP_MICROSOFT_SESS_ID_BUG, SSL_OP_MSIE_SSLV2_RSA_PADDING, SSL_OP_NETSCAPE_CA_DN_BUG, SSL_OP_NETSCAPE_CHALLENGE_BUG, SSL_OP_NETSCAPE_DEMO_CIPHER_CHANGE_BUG, SSL_OP_NETSCAPE_REUSE_CIPHER_CHANGE_BUG, SSL_OP_NO_COMPRESSION, SSL_OP_NO_QUERY_MTU, SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION, SSL_OP_NO_SSLv2, SSL_OP_NO_SSLv3, SSL_OP_NO_TICKET, SSL_OP_NO_TLSv1, SSL_OP_NO_TLSv1_1, SSL_OP_NO_TLSv1_2, SSL_OP_PKCS1_CHECK_1, SSL_OP_PKCS1_CHECK_2, SSL_OP_SINGLE_DH_USE, SSL_OP_SINGLE_ECDH_USE, SSL_OP_SSLEAY_080_CLIENT_DH_BUG, SSL_OP_SSLREF2_REUSE_CERT_TYPE_BUG, SSL_OP_TLS_BLOCK_PADDING_BUG, SSL_OP_TLS_D5_BUG, SSL_OP_TLS_ROLLBACK_BUG, ENGINE_METHOD_DSA, ENGINE_METHOD_DH, ENGINE_METHOD_RAND, ENGINE_METHOD_ECDH, ENGINE_METHOD_ECDSA, ENGINE_METHOD_CIPHERS, ENGINE_METHOD_DIGESTS, ENGINE_METHOD_STORE, ENGINE_METHOD_PKEY_METHS, ENGINE_METHOD_PKEY_ASN1_METHS, ENGINE_METHOD_ALL, ENGINE_METHOD_NONE, DH_CHECK_P_NOT_SAFE_PRIME, DH_CHECK_P_NOT_PRIME, DH_UNABLE_TO_CHECK_GENERATOR, DH_NOT_SUITABLE_GENERATOR, NPN_ENABLED, RSA_PKCS1_PADDING, RSA_SSLV23_PADDING, RSA_NO_PADDING, RSA_PKCS1_OAEP_PADDING, RSA_X931_PADDING, RSA_PKCS1_PSS_PADDING, POINT_CONVERSION_COMPRESSED, POINT_CONVERSION_UNCOMPRESSED, POINT_CONVERSION_HYBRID, F_OK, R_OK, W_OK, X_OK, UV_UDP_REUSEADDR, default */ +/***/ (function(module) { + +eval("module.exports = {\"O_RDONLY\":0,\"O_WRONLY\":1,\"O_RDWR\":2,\"S_IFMT\":61440,\"S_IFREG\":32768,\"S_IFDIR\":16384,\"S_IFCHR\":8192,\"S_IFBLK\":24576,\"S_IFIFO\":4096,\"S_IFLNK\":40960,\"S_IFSOCK\":49152,\"O_CREAT\":512,\"O_EXCL\":2048,\"O_NOCTTY\":131072,\"O_TRUNC\":1024,\"O_APPEND\":8,\"O_DIRECTORY\":1048576,\"O_NOFOLLOW\":256,\"O_SYNC\":128,\"O_SYMLINK\":2097152,\"O_NONBLOCK\":4,\"S_IRWXU\":448,\"S_IRUSR\":256,\"S_IWUSR\":128,\"S_IXUSR\":64,\"S_IRWXG\":56,\"S_IRGRP\":32,\"S_IWGRP\":16,\"S_IXGRP\":8,\"S_IRWXO\":7,\"S_IROTH\":4,\"S_IWOTH\":2,\"S_IXOTH\":1,\"E2BIG\":7,\"EACCES\":13,\"EADDRINUSE\":48,\"EADDRNOTAVAIL\":49,\"EAFNOSUPPORT\":47,\"EAGAIN\":35,\"EALREADY\":37,\"EBADF\":9,\"EBADMSG\":94,\"EBUSY\":16,\"ECANCELED\":89,\"ECHILD\":10,\"ECONNABORTED\":53,\"ECONNREFUSED\":61,\"ECONNRESET\":54,\"EDEADLK\":11,\"EDESTADDRREQ\":39,\"EDOM\":33,\"EDQUOT\":69,\"EEXIST\":17,\"EFAULT\":14,\"EFBIG\":27,\"EHOSTUNREACH\":65,\"EIDRM\":90,\"EILSEQ\":92,\"EINPROGRESS\":36,\"EINTR\":4,\"EINVAL\":22,\"EIO\":5,\"EISCONN\":56,\"EISDIR\":21,\"ELOOP\":62,\"EMFILE\":24,\"EMLINK\":31,\"EMSGSIZE\":40,\"EMULTIHOP\":95,\"ENAMETOOLONG\":63,\"ENETDOWN\":50,\"ENETRESET\":52,\"ENETUNREACH\":51,\"ENFILE\":23,\"ENOBUFS\":55,\"ENODATA\":96,\"ENODEV\":19,\"ENOENT\":2,\"ENOEXEC\":8,\"ENOLCK\":77,\"ENOLINK\":97,\"ENOMEM\":12,\"ENOMSG\":91,\"ENOPROTOOPT\":42,\"ENOSPC\":28,\"ENOSR\":98,\"ENOSTR\":99,\"ENOSYS\":78,\"ENOTCONN\":57,\"ENOTDIR\":20,\"ENOTEMPTY\":66,\"ENOTSOCK\":38,\"ENOTSUP\":45,\"ENOTTY\":25,\"ENXIO\":6,\"EOPNOTSUPP\":102,\"EOVERFLOW\":84,\"EPERM\":1,\"EPIPE\":32,\"EPROTO\":100,\"EPROTONOSUPPORT\":43,\"EPROTOTYPE\":41,\"ERANGE\":34,\"EROFS\":30,\"ESPIPE\":29,\"ESRCH\":3,\"ESTALE\":70,\"ETIME\":101,\"ETIMEDOUT\":60,\"ETXTBSY\":26,\"EWOULDBLOCK\":35,\"EXDEV\":18,\"SIGHUP\":1,\"SIGINT\":2,\"SIGQUIT\":3,\"SIGILL\":4,\"SIGTRAP\":5,\"SIGABRT\":6,\"SIGIOT\":6,\"SIGBUS\":10,\"SIGFPE\":8,\"SIGKILL\":9,\"SIGUSR1\":30,\"SIGSEGV\":11,\"SIGUSR2\":31,\"SIGPIPE\":13,\"SIGALRM\":14,\"SIGTERM\":15,\"SIGCHLD\":20,\"SIGCONT\":19,\"SIGSTOP\":17,\"SIGTSTP\":18,\"SIGTTIN\":21,\"SIGTTOU\":22,\"SIGURG\":16,\"SIGXCPU\":24,\"SIGXFSZ\":25,\"SIGVTALRM\":26,\"SIGPROF\":27,\"SIGWINCH\":28,\"SIGIO\":23,\"SIGSYS\":12,\"SSL_OP_ALL\":2147486719,\"SSL_OP_ALLOW_UNSAFE_LEGACY_RENEGOTIATION\":262144,\"SSL_OP_CIPHER_SERVER_PREFERENCE\":4194304,\"SSL_OP_CISCO_ANYCONNECT\":32768,\"SSL_OP_COOKIE_EXCHANGE\":8192,\"SSL_OP_CRYPTOPRO_TLSEXT_BUG\":2147483648,\"SSL_OP_DONT_INSERT_EMPTY_FRAGMENTS\":2048,\"SSL_OP_EPHEMERAL_RSA\":0,\"SSL_OP_LEGACY_SERVER_CONNECT\":4,\"SSL_OP_MICROSOFT_BIG_SSLV3_BUFFER\":32,\"SSL_OP_MICROSOFT_SESS_ID_BUG\":1,\"SSL_OP_MSIE_SSLV2_RSA_PADDING\":0,\"SSL_OP_NETSCAPE_CA_DN_BUG\":536870912,\"SSL_OP_NETSCAPE_CHALLENGE_BUG\":2,\"SSL_OP_NETSCAPE_DEMO_CIPHER_CHANGE_BUG\":1073741824,\"SSL_OP_NETSCAPE_REUSE_CIPHER_CHANGE_BUG\":8,\"SSL_OP_NO_COMPRESSION\":131072,\"SSL_OP_NO_QUERY_MTU\":4096,\"SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION\":65536,\"SSL_OP_NO_SSLv2\":16777216,\"SSL_OP_NO_SSLv3\":33554432,\"SSL_OP_NO_TICKET\":16384,\"SSL_OP_NO_TLSv1\":67108864,\"SSL_OP_NO_TLSv1_1\":268435456,\"SSL_OP_NO_TLSv1_2\":134217728,\"SSL_OP_PKCS1_CHECK_1\":0,\"SSL_OP_PKCS1_CHECK_2\":0,\"SSL_OP_SINGLE_DH_USE\":1048576,\"SSL_OP_SINGLE_ECDH_USE\":524288,\"SSL_OP_SSLEAY_080_CLIENT_DH_BUG\":128,\"SSL_OP_SSLREF2_REUSE_CERT_TYPE_BUG\":0,\"SSL_OP_TLS_BLOCK_PADDING_BUG\":512,\"SSL_OP_TLS_D5_BUG\":256,\"SSL_OP_TLS_ROLLBACK_BUG\":8388608,\"ENGINE_METHOD_DSA\":2,\"ENGINE_METHOD_DH\":4,\"ENGINE_METHOD_RAND\":8,\"ENGINE_METHOD_ECDH\":16,\"ENGINE_METHOD_ECDSA\":32,\"ENGINE_METHOD_CIPHERS\":64,\"ENGINE_METHOD_DIGESTS\":128,\"ENGINE_METHOD_STORE\":256,\"ENGINE_METHOD_PKEY_METHS\":512,\"ENGINE_METHOD_PKEY_ASN1_METHS\":1024,\"ENGINE_METHOD_ALL\":65535,\"ENGINE_METHOD_NONE\":0,\"DH_CHECK_P_NOT_SAFE_PRIME\":2,\"DH_CHECK_P_NOT_PRIME\":1,\"DH_UNABLE_TO_CHECK_GENERATOR\":4,\"DH_NOT_SUITABLE_GENERATOR\":8,\"NPN_ENABLED\":1,\"RSA_PKCS1_PADDING\":1,\"RSA_SSLV23_PADDING\":2,\"RSA_NO_PADDING\":3,\"RSA_PKCS1_OAEP_PADDING\":4,\"RSA_X931_PADDING\":5,\"RSA_PKCS1_PSS_PADDING\":6,\"POINT_CONVERSION_COMPRESSED\":2,\"POINT_CONVERSION_UNCOMPRESSED\":4,\"POINT_CONVERSION_HYBRID\":6,\"F_OK\":0,\"R_OK\":4,\"W_OK\":2,\"X_OK\":1,\"UV_UDP_REUSEADDR\":4};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9ub2RlX21vZHVsZXMvY29uc3RhbnRzLWJyb3dzZXJpZnkvY29uc3RhbnRzLmpzb24uanMiLCJzb3VyY2VzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./node_modules/constants-browserify/constants.json\n"); + +/***/ }), + /***/ "./node_modules/debug/src/browser.js": /*!*******************************************!*\ !*** ./node_modules/debug/src/browser.js ***! @@ -1223,7 +1246,7 @@ eval("\n\nvar alphabet = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqr /*! no static exports found */ /***/ (function(module, exports) { -eval("/* (ignored) *///# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy93cyAoaWdub3JlZCk/NTMwNSJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiAoaWdub3JlZCkgKi8iXSwibWFwcGluZ3MiOiJBQUFBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///0\n"); +eval("/* (ignored) *///# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy93cyAoaWdub3JlZCk/Y2JjOSJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiAoaWdub3JlZCkgKi8iXSwibWFwcGluZ3MiOiJBQUFBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///0\n"); /***/ }) diff --git a/client/dist/style.css b/client/dist/style.css index f9f6a20..9dea6fa 100644 --- a/client/dist/style.css +++ b/client/dist/style.css @@ -180,3 +180,58 @@ input { .sbHeader{ margin-left: 70px } + +.power0 { + color: green; +} + +.power1 { + color: red; +} + +.power2 { + color: blue; +} + +.powerup { + display: inline-block; + width: 15px; + height: 15px; + border: 1px solid black; + margin: 2px; +} + +#power-bank { + width: 125px; +} +#power-bank .power0{ + background-color: green; +} + +#power-bank .power1 { + background-color: red; +} + +#power-bank .power2 { + background-color: blue; +} + +#power-bank #legend .power0{ + background-color: green; + +} +#power-bank #legend .power1 { + background-color: red; + +} +#power-bank #legend .power2 { + background-color: blue; + +} + +#power-bank #legend div{ + width: 120px; + padding: 1px; + color: white; + font-size: 9px; +} \ No newline at end of file diff --git a/client/src/components/Brick.jsx b/client/src/components/Brick.jsx index ed35854..6ca2404 100644 --- a/client/src/components/Brick.jsx +++ b/client/src/components/Brick.jsx @@ -2,7 +2,7 @@ import React from 'react'; const Brick = (props) => { return ( -
+

{props.word}

) diff --git a/client/src/components/Game.jsx b/client/src/components/Game.jsx index 2982790..c775887 100644 --- a/client/src/components/Game.jsx +++ b/client/src/components/Game.jsx @@ -1,6 +1,9 @@ import React from 'react'; import Brick from './Brick.jsx'; import axios from 'axios'; +import PowerBank from './PowerBank.jsx'; + +import { EEXIST } from 'constants'; const io = require('socket.io-client'); const socket = io(); @@ -17,7 +20,9 @@ class Game extends React.Component { round: 'all', instructions: ["Humpty Dumpty sat on a wall,", "Humpty Dumpty had a great fall.", "All the king's horses and all the king's men", "Couldn't put Humpty together again.", "HURRY - KEEP TYPING TO PREVENT HIS DEMISE!"], prompt: 'START GAME', - opponentTime: 0 + opponentTime: 0, + powerups: {}, + bankedPowers: [] } this.getReady = this.getReady.bind(this); @@ -29,6 +34,15 @@ class Game extends React.Component { this.sendScore = this.sendScore.bind(this); this.stopGame = this.stopGame.bind(this); + this.pauseGame = this.pauseGame.bind(this); + this.removeWords = this.removeWords.bind(this); + this.shuffleArray = this.shuffleArray.bind(this); + this.switchWords = this.switchWords.bind(this); + + this.removeAllWords = this.removeAllWords.bind(this); + this.stopAll = this.stopAll.bind(this); + this.usePower = this.usePower.bind(this); + this.addPower = this.addPower.bind(this); var c = io.connect(process.env.PORT, {query: this.state.time}) console.log('c', c) @@ -173,6 +187,7 @@ class Game extends React.Component { addWord() { var availableWords = this.state.dictionary[this.state.round]; var newWord = availableWords[Math.floor(Math.random() * availableWords.length)]; + this.addPower(newWord); this.setState({ words: [...this.state.words, newWord] }); @@ -197,17 +212,39 @@ class Game extends React.Component { e.preventDefault(); var submittedWord = this.state.userInput; var index = this.state.words.indexOf(submittedWord); - + var powerups; + var deposit; // check if what they typed is in our "words" array // flash green for a correctly typed word and remove word from "words" array if (index !== -1) { + document.getElementById('typing-input').style.backgroundColor = "green"; var newWords = this.state.words.slice(); newWords.splice(index, 1); - playCorrect(); - this.setState({ - words: newWords, - }); + playCorrect(); + + if(this.state.powerups[submittedWord] != undefined){ + powerups = Object.assign({}, this.state.powerups); + deposit = powerups[submittedWord]; + delete powerups[submittedWord]; + + if(this.state.bankedPowers.length != 0){ + deposit = [...this.state.bankedPowers, deposit] + } else { + deposit = [deposit]; + } + + this.setState({ + words: newWords, + bankedPowers: deposit, + powerups: powerups + }); + + } else { + this.setState({ + words: newWords, + }); + } } else { // else flash red for a mistyped word playWrong(); @@ -262,6 +299,106 @@ class Game extends React.Component { prompt: 'REPLAY', }); } + + //ADDED FOR POWERUPS + pauseGame(){ + var previousInterval = this.state.timeInterval; + setInterval(()=>{ + this.setState({ + timeInterval: previousInterval + }); + },5000); + this.setState({ + timeInterval: 5000 + }); + } + + shuffleArray(arr){ + var current = arr.length; + var temp; + var rand; + + while(current !== 0){ + rand = Math.floor(Math.random() * current); + current--; + temp = arr[current]; + arr[current] = arr[rand]; + arr[rand] = temp; + } + return arr; + } + + removeWords(num){ + var removeWords = this.state.words.slice(); + var half = Math.floor(removeWords.length/2); + removeWords = this.shuffleArray(removeWords); + removeWords = removeWords.slice(0, half); + this.setState({ + words: removeWords + }); + } + + switchWords(){ + var list = this.state.words.slice(); + list.pop(); + list.push("aaa"); + this.setState({ + words: list + }); + } + removeAllWords(num){ + this.setState({ + words: [] + }); + } + usePower(e){ + var temp; + var banked; + if(e.keyCode === 32){ + temp = e.target.value; + temp = temp.substring(0, temp.length-1); + + if(this.state.bankedPowers[0] != undefined){ + if(this.state.bankedPowers[0] === 'power0'){ + this.removeAllWords(); + } else if(this.state.bankedPowers[0] === 'power1'){ + this.pauseGame(); + } else if(this.state.bankedPowers[0] === 'power2'){ + this.removeWords(); + } + banked = this.state.bankedPowers.slice(); + banked.shift(); + } + this.setState({ + userInput: temp, + bankedPowers: banked + }) + } + } + + addPower(word){ + var chance = 4; + var rand = Math.floor(Math.random() * chance) + 1; + var current; + if(rand === 1){ + if(Object.keys(this.state.powerups).length === 0){ + current = {}; + } else { + current = this.state.powerups; + } + current[word] = "power" + Math.floor(Math.random() * 3); + this.setState({ + powerups: current + }) + } + } + + stopAll(){ + this.setState({ + timeInterval: 100000 + }); + } + //END OF POWERUPS render() { return ( @@ -284,20 +421,37 @@ class Game extends React.Component {

{this.state.time}

+ {/* + + + */}
{/* your game: */}
{this.state.words.map((word, index) => { - return + return })}
- +
+
+
Powers:
+ {this.state.bankedPowers.map((powerup, index)=>{ + return + })} +
+
Pause (5s)
+
Remove 1/2
+
Remove All
+
+
+ + {/* their game: */}
{this.state.theirWords.map((word, index) => { diff --git a/client/src/components/PowerBank.jsx b/client/src/components/PowerBank.jsx new file mode 100644 index 0000000..175472a --- /dev/null +++ b/client/src/components/PowerBank.jsx @@ -0,0 +1,9 @@ +import React from 'react'; + +const PowerBank = (props) => { + return ( +
+ ) +} + +export default PowerBank;