{"version":3,"file":"static/js/main.d209a1c0.chunk.js","sources":["animations/timerEnd.js","components/ClientContentStyles.module.scss","animations/potatoDraw.js","animations/potatoWrite.js","animations/tickCard.js","animations/hourglass.js","components/HostStyles.module.scss","components/PlayerStyles.module.scss","components/Layout.js","services/logging.js","components/Loading.js","constants/avatars.js","images/Avatars/potato-0.png","images/Avatars/potato-1.png","images/Avatars/potato-2.png","images/Avatars/potato-3.png","images/Avatars/potato-4.png","images/Avatars/potato-5.png","images/Avatars/potato-6.png","images/Avatars/potato-7.png","images/Avatars/potato-8.png","images/Avatars/potato-9.png","images/Avatars/potato-10.png","images/Avatars/potato-11.png","images/Avatars/potato-12.png","images/Avatars/potato-13.png","images/Avatars/potato-14.png","images/Avatars/potato-15.png","images/Avatars/potato-16.png","images/Avatars/potato-17.png","images/Avatars/potato-18.png","images/Avatars/potato-19.png","images/Avatars/potato-20.png","images/Avatars/potato-21.png","images/Avatars/potato-22.png","images/Avatars/potato-23.png","images/Avatars/potato-24.png","components/Player.js","components/Menu.js","images/scrawl-logo.png","images/scrawl-logo-17.png","images/frame.png","images/scrawl_muted.png","images/scrawl_unmuted.png","images/scrawl_fullscreen.png","images/scrawl_help.png","images/cards-img.png","images/banner.png","images/Family Icon.png","images/Adults Icon.png","components/Tutorial.js","audio/playing-bg-music.mp3","audio/gallery-reveal-music.mp3","audio/big-reveal.mp3","audio/favourite-chosen-background.mp3","audio/favourite-chosen-sound.mp3","audio/player-ready.mp3","audio/player-ready-2.mp3","audio/player-ready-3.mp3","audio/player-ready-4.mp3","audio/player-ready-5.mp3","audio/player-ready-6.mp3","audio/reveal-one.mp3","audio/round-start-drawing.mp3","audio/round-start-writing.mp3","audio/winner.mp3","audio/player-joined.mp3","audio/hover-click.mp3","components/Utility/FormPage.js","components/Utility/ErrorModal.js","images/background.png","images/background-green.png","images/bucket.png","images/cards-img-old.png","images/eraser.png","images/painter.png","images/pen.png","images/undo.png","constants/constants.js","images/muted.png","images/potato.png","images/unmuted.png","components/Home.js","components/ClientContent.js","components/Client.js","helpers/cookies.js","App.js","index.js","components/MenuStyles.module.scss","components/LoadingStyles.module.scss","components/ClientStyles.module.scss","components/TutorialStyles.module.scss","animations/timerTurning.js","components/Utility/FormStyles.module.scss","components/Utility/LobbyStyles.module.scss"],"sourceRoot":"","sourcesContent":["const animation = require(\"./timerEnd.json\");\r\n\r\nmodule.exports = {\r\n loop: false,\r\n autoplay: true,\r\n animationData: animation,\r\n rendererSettings: {\r\n preserveAspectRatio: 'xMidYMid'\r\n },\r\n}","// extracted by mini-css-extract-plugin\nmodule.exports = {\"defaultSection\":\"ClientContentStyles_defaultSection__1Ypij\",\"logoBox\":\"ClientContentStyles_logoBox__3wq8o\",\"logo\":\"ClientContentStyles_logo__24Bq9\",\"primary\":\"ClientContentStyles_primary__Se2vt\",\"logo17\":\"ClientContentStyles_logo17__3MvCs\",\"show\":\"ClientContentStyles_show__2rvMS\",\"title\":\"ClientContentStyles_title__3tdGM\",\"content\":\"ClientContentStyles_content__m05mh\",\"playerSection\":\"ClientContentStyles_playerSection__3J13w\",\"potato\":\"ClientContentStyles_potato__Q0TZi\",\"text\":\"ClientContentStyles_text__K_UDk\",\"doodleSection\":\"ClientContentStyles_doodleSection__2e7Cu\",\"doodleTitle\":\"ClientContentStyles_doodleTitle__1mmJi\",\"doodleCanvasContainer\":\"ClientContentStyles_doodleCanvasContainer__3hIad\",\"doodleText\":\"ClientContentStyles_doodleText__14g5X\",\"doodleBacker\":\"ClientContentStyles_doodleBacker__2DxLq\",\"sendButtonWrapper\":\"ClientContentStyles_sendButtonWrapper__27Bil\",\"contentSection\":\"ClientContentStyles_contentSection__2MLhC\",\"buttons\":\"ClientContentStyles_buttons__2n0SP\",\"skipBox\":\"ClientContentStyles_skipBox__1rdev\",\"contentFilter\":\"ClientContentStyles_contentFilter__1mUqa\",\"bar\":\"ClientContentStyles_bar__118Aw\",\"icons\":\"ClientContentStyles_icons__3CZc7\",\"button\":\"ClientContentStyles_button__3Jsns\",\"controls\":\"ClientContentStyles_controls__1O3Tb\",\"disabled\":\"ClientContentStyles_disabled__2f2eH\",\"loading\":\"ClientContentStyles_loading__3Tof0\",\"spin\":\"ClientContentStyles_spin__39wzb\"};","const animation = require(\"./potatoDraw.json\");\r\n\r\nmodule.exports = {\r\n loop: true,\r\n autoplay: true,\r\n animationData: animation,\r\n rendererSettings: {\r\n preserveAspectRatio: 'xMidYMid'\r\n },\r\n}","const animation = require(\"./potatoWrite.json\");\r\n\r\nmodule.exports = {\r\n loop: true,\r\n autoplay: true,\r\n animationData: animation,\r\n rendererSettings: {\r\n preserveAspectRatio: 'xMidYMid'\r\n },\r\n}","const animation = require(\"./tickCard.json\");\r\n\r\nmodule.exports = {\r\n loop: false,\r\n autoplay: false,\r\n animationData: animation,\r\n rendererSettings: {\r\n preserveAspectRatio: 'none'\r\n },\r\n}","const animation = require(\"./hourglass.json\");\r\n\r\nmodule.exports = {\r\n loop: true,\r\n autoplay: true,\r\n prerender: true,\r\n renderer: \"svg\",\r\n animationData: animation,\r\n rendererSettings: {\r\n preserveAspectRatio: 'xMidyMid'\r\n },\r\n}","// extracted by mini-css-extract-plugin\nmodule.exports = {\"logoSection\":\"HostStyles_logoSection__1k_xj\",\"topLeft\":\"HostStyles_topLeft__2yeyS\",\"logo\":\"HostStyles_logo__2cvN9\",\"logo17\":\"HostStyles_logo17__1oHZb\",\"show\":\"HostStyles_show___tSGb\",\"gameContainer\":\"HostStyles_gameContainer__n_394\",\"adults\":\"HostStyles_adults__1OnYs\",\"loadingContainer\":\"HostStyles_loadingContainer__siqMN\",\"doodleSection\":\"HostStyles_doodleSection__32CgU\",\"doodle\":\"HostStyles_doodle__20PfY\",\"right\":\"HostStyles_right__BCBon\",\"bannerContainer\":\"HostStyles_bannerContainer__3RwWp\",\"play\":\"HostStyles_play__1B40N\",\"bannerBg\":\"HostStyles_bannerBg__5o4Qy\",\"bannerAnim\":\"HostStyles_bannerAnim__2Ri4P\",\"bannerInfo\":\"HostStyles_bannerInfo__1Rx1Q\",\"bannerTextAnim\":\"HostStyles_bannerTextAnim__1HBvZ\",\"bannerTitle\":\"HostStyles_bannerTitle__3n_L3\",\"counterSection\":\"HostStyles_counterSection__uRE2I\",\"hidden\":\"HostStyles_hidden__1JQg1\",\"counterText\":\"HostStyles_counterText__2HL1_\",\"tickList\":\"HostStyles_tickList__3BjDB\",\"roomCode\":\"HostStyles_roomCode___uLy7\",\"textBox\":\"HostStyles_textBox__bjhet\",\"text\":\"HostStyles_text__1CtL9\",\"code\":\"HostStyles_code__1Bcww\",\"iconsBox\":\"HostStyles_iconsBox__353UO\",\"muteToggle\":\"HostStyles_muteToggle__2LSIn\",\"muteIcon\":\"HostStyles_muteIcon__2zj1t\",\"qrCodeBox\":\"HostStyles_qrCodeBox__1RhT_\",\"qrCode\":\"HostStyles_qrCode__1iv3s\",\"playerColumn\":\"HostStyles_playerColumn__aSdi3\",\"playerRow\":\"HostStyles_playerRow__29UVo\",\"hide\":\"HostStyles_hide__2ixd2\",\"middleColumn\":\"HostStyles_middleColumn__2hmgI\",\"awardSection\":\"HostStyles_awardSection__2N2-5\",\"dissapear\":\"HostStyles_dissapear__1mROM\",\"frameSection\":\"HostStyles_frameSection__ez4IN\",\"frameItem\":\"HostStyles_frameItem__1Ql-K\",\"itemContent\":\"HostStyles_itemContent__1SLjT\",\"frame\":\"HostStyles_frame__3Am2l\",\"playerSection\":\"HostStyles_playerSection__2anb4\",\"potato\":\"HostStyles_potato__3TF0I\",\"popout\":\"HostStyles_popout__26CVK\",\"potName\":\"HostStyles_potName__33Jc-\",\"revealContainer\":\"HostStyles_revealContainer__MAVdX\",\"ogSection\":\"HostStyles_ogSection__342WO\",\"ogTitle\":\"HostStyles_ogTitle__2d9RB\",\"ogCard\":\"HostStyles_ogCard__15Po1\",\"revealingPotato\":\"HostStyles_revealingPotato__1k5fm\",\"revealingName\":\"HostStyles_revealingName__2Hsmq\",\"revealList\":\"HostStyles_revealList__3-y0P\",\"revealItem\":\"HostStyles_revealItem__L0VDe\",\"reveal\":\"HostStyles_reveal__16l4x\",\"empty\":\"HostStyles_empty__V2krq\",\"storyList\":\"HostStyles_storyList__1RfJZ\",\"bigger\":\"HostStyles_bigger__2XfxR\",\"backdrop\":\"HostStyles_backdrop__2V_wR\",\"listItem\":\"HostStyles_listItem__rLgzo\",\"smaller\":\"HostStyles_smaller__dBJLx\",\"mask\":\"HostStyles_mask__nfBur\",\"maskLogo\":\"HostStyles_maskLogo__1wFJJ\",\"timerSection\":\"HostStyles_timerSection__BSPrN\",\"timerBg\":\"HostStyles_timerBg__2Etev\",\"timer\":\"HostStyles_timer__1x61g\",\"hideTimer\":\"HostStyles_hideTimer__2zY4s\",\"roundSection\":\"HostStyles_roundSection__15rEP\",\"draw\":\"HostStyles_draw__9bzWb\",\"write\":\"HostStyles_write__2Wc0P\",\"cards\":\"HostStyles_cards__dMkN7\",\"roundTitle\":\"HostStyles_roundTitle__108TS\",\"cardSection\":\"HostStyles_cardSection__1yX2A\",\"sampleCard\":\"HostStyles_sampleCard__2Alib\",\"one\":\"HostStyles_one__1T1Ne\",\"two\":\"HostStyles_two__2LNmI\",\"half\":\"HostStyles_half__1qh7I\",\"top\":\"HostStyles_top__1TEgY\",\"bottom\":\"HostStyles_bottom__g4Yo7\",\"painters\":\"HostStyles_painters__3zdJ6\",\"winnersSection\":\"HostStyles_winnersSection__3xw7j\",\"winnersText\":\"HostStyles_winnersText__25Nrm\",\"winnersBox\":\"HostStyles_winnersBox__3bpBA\",\"winner\":\"HostStyles_winner__2sANr\",\"winnerName\":\"HostStyles_winnerName__2QNwG\",\"large\":\"HostStyles_large__29OoC\",\"medium\":\"HostStyles_medium__2krrA\",\"small\":\"HostStyles_small__1k_mJ\",\"number\":\"HostStyles_number__oBz6o\",\"left\":\"HostStyles_left__3fCqo\",\"startGameSection\":\"HostStyles_startGameSection__3ye4i\",\"button\":\"HostStyles_button__33T5v\",\"skipBox\":\"HostStyles_skipBox__1Z2Ol\",\"contentFilter\":\"HostStyles_contentFilter__2vmHf\",\"bar\":\"HostStyles_bar__3ZsxA\",\"icons\":\"HostStyles_icons__3lApU\",\"playAgainSection\":\"HostStyles_playAgainSection__kyEEF\",\"buttonsSection\":\"HostStyles_buttonsSection__1c98R\",\"leaderboardSection\":\"HostStyles_leaderboardSection__1HA7Q\",\"boardRow\":\"HostStyles_boardRow__214pM\",\"numberBox\":\"HostStyles_numberBox__1RlnZ\",\"positionText\":\"HostStyles_positionText__siGAx\",\"nameBox\":\"HostStyles_nameBox__3oZ9E\",\"scoreBox\":\"HostStyles_scoreBox__1VrLS\",\"title\":\"HostStyles_title__e7NeF\",\"playerSpot\":\"HostStyles_playerSpot__1xRH6\",\"votesSection\":\"HostStyles_votesSection__1FvF8\",\"voteContainer\":\"HostStyles_voteContainer__11EYt\",\"voteTitle\":\"HostStyles_voteTitle__32I-A\",\"voteList\":\"HostStyles_voteList__16O-y\",\"voteSpot\":\"HostStyles_voteSpot__zxVGk\",\"name\":\"HostStyles_name__3ljBE\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"player\":\"PlayerStyles_player__2zL4g\",\"shrink\":\"PlayerStyles_shrink__1z1dE\",\"hidden\":\"PlayerStyles_hidden__3q-gK\",\"winner\":\"PlayerStyles_winner__3Q7f8\",\"playerSection\":\"PlayerStyles_playerSection__3X83N\",\"winnerName\":\"PlayerStyles_winnerName__1BrSo\",\"large\":\"PlayerStyles_large__1OmuT\",\"medium\":\"PlayerStyles_medium__2FV8w\",\"small\":\"PlayerStyles_small__1tX9L\",\"number\":\"PlayerStyles_number__1UFbw\",\"potato\":\"PlayerStyles_potato__2IfIo\",\"left\":\"PlayerStyles_left__ZC9De\",\"right\":\"PlayerStyles_right__32Eiy\",\"reverse\":\"PlayerStyles_reverse__ABX4_\",\"spectatingText\":\"PlayerStyles_spectatingText__3QXOI\",\"fade\":\"PlayerStyles_fade__1jsGP\",\"countdownContainer\":\"PlayerStyles_countdownContainer__1Jk34\",\"textSection\":\"PlayerStyles_textSection__3yz82\",\"nameText\":\"PlayerStyles_nameText__1xyF4\",\"answeredText\":\"PlayerStyles_answeredText__3RWx3\",\"show\":\"PlayerStyles_show__3WX1d\"};","import React, { Component } from 'react';\r\nimport { Container } from 'reactstrap';\r\n\r\nexport class Layout extends Component {\r\n static displayName = Layout.name;\r\n\r\n render () {\r\n return (\r\n
\r\n \r\n {this.props.children}\r\n \r\n
\r\n );\r\n }\r\n}\r\n","import axios from \"axios\";\r\nconst API_URL = process.env.REACT_APP_API_URL;\r\n\r\nconst instance = axios.create({\r\n baseURL: process.env.REACT_APP_API_URL\r\n});\r\n\r\nconst logError = (message, error) => {\r\n var configLogError = {\r\n method: 'post',\r\n url: API_URL + 'api/logging/log-error',\r\n headers: {\r\n 'Content-Type': 'application/json'\r\n },\r\n data: {\r\n message,\r\n error\r\n }\r\n };\r\n\r\n return instance(configLogError)\r\n .then(function (response) {\r\n return response.data;\r\n\r\n }).catch(function (error) {\r\n console.log(error);\r\n return error;\r\n });\r\n};\r\n\r\nexport default {\r\n logError\r\n};\r\n","import React, { Component } from 'react';\r\nimport Lottie from 'react-lottie';\r\n\r\nimport styles from 'components/LoadingStyles.module.scss';\r\nimport loadingAnim from 'animations/hourglass.js';\r\n\r\nexport default class Loading extends Component {\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n };\r\n }\r\n\r\n render() {\r\n return (\r\n
\r\n
\r\n \r\n
\r\n
{this.props.loadingText}
\r\n {\r\n this.props.progress >= 0 &&\r\n
\r\n
\r\n
\r\n {Math.round(this.props.progress)}%\r\n
\r\n }\r\n
\r\n )\r\n }\r\n\r\n}","import potato0 from \"images/Avatars/potato-0.png\";\r\nimport potato1 from \"images/Avatars/potato-1.png\";\r\nimport potato2 from \"images/Avatars/potato-2.png\";\r\nimport potato3 from \"images/Avatars/potato-3.png\";\r\nimport potato4 from \"images/Avatars/potato-4.png\";\r\nimport potato5 from \"images/Avatars/potato-5.png\";\r\nimport potato6 from \"images/Avatars/potato-6.png\";\r\nimport potato7 from \"images/Avatars/potato-7.png\";\r\nimport potato8 from \"images/Avatars/potato-8.png\";\r\nimport potato9 from \"images/Avatars/potato-9.png\";\r\nimport potato10 from \"images/Avatars/potato-10.png\";\r\nimport potato11 from \"images/Avatars/potato-11.png\";\r\nimport potato12 from \"images/Avatars/potato-12.png\";\r\nimport potato13 from \"images/Avatars/potato-13.png\";\r\nimport potato14 from \"images/Avatars/potato-14.png\";\r\nimport potato15 from \"images/Avatars/potato-15.png\";\r\nimport potato16 from \"images/Avatars/potato-16.png\";\r\nimport potato17 from \"images/Avatars/potato-17.png\";\r\nimport potato18 from \"images/Avatars/potato-18.png\";\r\nimport potato19 from \"images/Avatars/potato-19.png\";\r\nimport potato20 from \"images/Avatars/potato-20.png\";\r\nimport potato21 from \"images/Avatars/potato-21.png\";\r\nimport potato22 from \"images/Avatars/potato-22.png\";\r\nimport potato23 from \"images/Avatars/potato-23.png\";\r\nimport potato24 from \"images/Avatars/potato-24.png\";\r\n\r\nimport potato0Anim from \"animations/avatars/potato-0.json\";\r\nimport potato1Anim from \"animations/avatars/potato-1.json\";\r\nimport potato2Anim from \"animations/avatars/potato-2.json\";\r\nimport potato3Anim from \"animations/avatars/potato-3.json\";\r\nimport potato4Anim from \"animations/avatars/potato-4.json\";\r\nimport potato5Anim from \"animations/avatars/potato-5.json\";\r\nimport potato6Anim from \"animations/avatars/potato-6.json\";\r\nimport potato7Anim from \"animations/avatars/potato-7.json\";\r\nimport potato8Anim from \"animations/avatars/potato-8.json\";\r\nimport potato9Anim from \"animations/avatars/potato-9.json\";\r\nimport potato10Anim from \"animations/avatars/potato-10.json\";\r\nimport potato11Anim from \"animations/avatars/potato-11.json\";\r\nimport potato12Anim from \"animations/avatars/potato-12.json\";\r\nimport potato13Anim from \"animations/avatars/potato-13.json\";\r\nimport potato14Anim from \"animations/avatars/potato-14.json\";\r\nimport potato15Anim from \"animations/avatars/potato-15.json\";\r\nimport potato16Anim from \"animations/avatars/potato-16.json\";\r\nimport potato17Anim from \"animations/avatars/potato-17.json\";\r\nimport potato18Anim from \"animations/avatars/potato-18.json\";\r\nimport potato19Anim from \"animations/avatars/potato-19.json\";\r\nimport potato20Anim from \"animations/avatars/potato-20.json\";\r\nimport potato21Anim from \"animations/avatars/potato-21.json\";\r\nimport potato22Anim from \"animations/avatars/potato-22.json\";\r\nimport potato23Anim from \"animations/avatars/potato-23.json\";\r\nimport potato24Anim from \"animations/avatars/potato-24.json\";\r\n\r\nfunction getOptions(animData) {\r\n return {\r\n loop: true,\r\n autoplay: true,\r\n prerender: true,\r\n renderer: \"svg\",\r\n animationData: animData,\r\n rendererSettings: {\r\n preserveAspectRatio: 'xMidYMid'\r\n },\r\n }\r\n}\r\n\r\nfunction getAvatarById(avId) {\r\n return avatars.find(x => x.id == avId);\r\n}\r\n\r\nconst avatars = [\r\n { id: 0, src: potato0, idleAnim: getOptions(potato0Anim), },\r\n { id: 1, src: potato1, idleAnim: getOptions(potato1Anim), },\r\n { id: 2, src: potato2, idleAnim: getOptions(potato2Anim), },\r\n { id: 3, src: potato3, idleAnim: getOptions(potato3Anim), },\r\n { id: 4, src: potato4, idleAnim: getOptions(potato4Anim), },\r\n { id: 5, src: potato5, idleAnim: getOptions(potato5Anim), },\r\n { id: 6, src: potato6, idleAnim: getOptions(potato6Anim), },\r\n { id: 7, src: potato7, idleAnim: getOptions(potato7Anim), },\r\n { id: 8, src: potato8, idleAnim: getOptions(potato8Anim), },\r\n { id: 9, src: potato9, idleAnim: getOptions(potato9Anim), },\r\n { id: 10, src: potato10, idleAnim: getOptions(potato10Anim), },\r\n { id: 11, src: potato11, idleAnim: getOptions(potato11Anim), },\r\n { id: 12, src: potato12, idleAnim: getOptions(potato12Anim), },\r\n { id: 13, src: potato13, idleAnim: getOptions(potato13Anim), },\r\n { id: 14, src: potato14, idleAnim: getOptions(potato14Anim), },\r\n { id: 15, src: potato15, idleAnim: getOptions(potato15Anim), },\r\n { id: 16, src: potato16, idleAnim: getOptions(potato16Anim), },\r\n { id: 17, src: potato17, idleAnim: getOptions(potato17Anim), },\r\n { id: 18, src: potato18, idleAnim: getOptions(potato18Anim), },\r\n { id: 19, src: potato19, idleAnim: getOptions(potato19Anim), },\r\n { id: 20, src: potato20, idleAnim: getOptions(potato20Anim), },\r\n { id: 21, src: potato21, idleAnim: getOptions(potato21Anim), },\r\n { id: 22, src: potato22, idleAnim: getOptions(potato22Anim), },\r\n { id: 23, src: potato23, idleAnim: getOptions(potato23Anim), },\r\n { id: 24, src: potato24, idleAnim: getOptions(potato24Anim), },\r\n];\r\n\r\nexport default getAvatarById;","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","import React, { Component } from 'react';\r\nimport Lottie from 'react-lottie';\r\n\r\nimport getAvatarById from \"constants/avatars\";\r\nimport styles from \"components/PlayerStyles.module.scss\";\r\n\r\n\r\nexport default class Player extends Component {\r\n\r\n constructor(props) {\r\n super(props);\r\n let fontSize = this.getFontSize(props.player);\r\n this.state = {\r\n fontSize: fontSize,\r\n }\r\n }\r\n\r\n componentWillReceiveProps(nextProps) {\r\n this.setState({ fontSize: this.getFontSize(nextProps.player), });\r\n }\r\n\r\n\r\n getFontSize(player) {\r\n if (player) {\r\n let name = player.name;\r\n let fontSize = \"\";\r\n if (name.length <= 3) {\r\n fontSize = \"large\";\r\n } else if (name.length <= 6) {\r\n fontSize = \"medium\";\r\n } else {\r\n fontSize = \"small\";\r\n }\r\n return fontSize;\r\n } else {\r\n return \"medium\";\r\n }\r\n }\r\n\r\n render() {\r\n return (\r\n this.props.isEmpty ?\r\n
\r\n :\r\n
\r\n {\r\n this.props.player.scrawlData.isPlaying ?\r\n null\r\n :\r\n
Spectating...
\r\n }\r\n
\r\n
{this.props.player.scrawlData.score}
\r\n {/*
{this.props.number}
*/}\r\n {\r\n this.props.winner ?\r\n
{this.props.player.name}
\r\n :\r\n null\r\n }\r\n \r\n \r\n
\r\n
\r\n {\r\n this.props.winner ?\r\n null\r\n :\r\n
\r\n
{this.props.player.name}
\r\n {/*
{this.props.player.scrawlData.score}
*/}\r\n
\r\n }\r\n
Ready
\r\n
\r\n )\r\n }\r\n}","import React, { Component } from 'react';\r\n\r\nimport styles from 'components/MenuStyles.module.scss';\r\n\r\nexport default class Menu extends Component {\r\n\r\n constructor(props) {\r\n super(props);\r\n this.state = {\r\n open: false,\r\n };\r\n }\r\n\r\n toggleMenu = () => {\r\n this.setState({ open: !this.state.open });\r\n }\r\n\r\n goToLobby = () => {\r\n this.props.room.send(\"change_game\", { });\r\n }\r\n\r\n render() {\r\n return (\r\n
\r\n
\r\n {/*
{this.state.open ? \"Close\" : \"Open\"} Menu
*/}\r\n
\r\n
this.props.toggleMute()}>{this.props.muted ? \"Unmute\" : \"Mute\"}
\r\n
\r\n
Go To Lobby
\r\n
\r\n
this.props.toggleMenu()}>Close
\r\n
\r\n
\r\n
\r\n )\r\n }\r\n\r\n}","export default __webpack_public_path__ + \"static/media/scrawl-logo.2d8f75e2.png\";","export default __webpack_public_path__ + \"static/media/scrawl-logo-17.a8279860.png\";","export default __webpack_public_path__ + \"static/media/frame.05408554.png\";","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/banner.f4d80b5c.png\";","export default __webpack_public_path__ + \"static/media/Family Icon.581a707f.png\";","export default __webpack_public_path__ + \"static/media/Adults Icon.7356f748.png\";","import React, { Component } from 'react';\r\nimport ReactPlayer from 'react-player'\r\n\r\nimport styles from 'components/TutorialStyles.module.scss';\r\n\r\nexport default class Tutorial extends Component {\r\n\r\n constructor(props) {\r\n super(props);\r\n //console.log(\"TUTORIAL LOGGING: \" + JSON.stringify(props));\r\n this.state = {\r\n source: \"https://youtu.be/GKV1Q7qSC0Y\",\r\n }\r\n\r\n this.tutorialInterval = null;\r\n }\r\n\r\n componentWillReceiveProps(nextProps) {\r\n }\r\n\r\n componentDidMount() {\r\n\r\n }\r\n\r\n componentWillUnmount() {\r\n if (this.tutorialInterval) clearInterval(this.tutorialInterval);\r\n }\r\n\r\n\r\n endTutorial() {\r\n this.props.room.send(\"end_tutorial\");\r\n }\r\n\r\n render() {\r\n return (\r\n
\r\n
\r\n { this.endTutorial() }}\r\n />\r\n
\r\n
Skip vote: {this.props.skipCount}/{this.props.playerCount}
\r\n
\r\n )\r\n }\r\n\r\n}","export default __webpack_public_path__ + \"static/media/playing-bg-music.96c9696f.mp3\";","export default __webpack_public_path__ + \"static/media/gallery-reveal-music.04564f24.mp3\";","export default __webpack_public_path__ + \"static/media/big-reveal.13eed7b9.mp3\";","export default __webpack_public_path__ + \"static/media/favourite-chosen-background.d29511fe.mp3\";","export default __webpack_public_path__ + \"static/media/favourite-chosen-sound.c4a50b59.mp3\";","export default __webpack_public_path__ + \"static/media/player-ready.d753f2d5.mp3\";","export default __webpack_public_path__ + \"static/media/player-ready-2.a36d211f.mp3\";","export default __webpack_public_path__ + \"static/media/player-ready-3.00c81e50.mp3\";","export default __webpack_public_path__ + \"static/media/player-ready-4.90046596.mp3\";","export default __webpack_public_path__ + \"static/media/player-ready-5.f20240f6.mp3\";","export default __webpack_public_path__ + \"static/media/player-ready-6.e4ae4144.mp3\";","export default __webpack_public_path__ + \"static/media/reveal-one.7d4991f5.mp3\";","export default __webpack_public_path__ + \"static/media/round-start-drawing.3fb00b7d.mp3\";","export default __webpack_public_path__ + \"static/media/round-start-writing.2237d429.mp3\";","export default __webpack_public_path__ + \"static/media/winner.8b5b4f8a.mp3\";","export default __webpack_public_path__ + \"static/media/player-joined.7316b801.mp3\";","export default __webpack_public_path__ + \"static/media/hover-click.261c64da.mp3\";","import React, { Component } from 'react';\r\nimport styles from './FormStyles.module.scss'\r\n\r\nclass FormPage extends Component {\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n\r\n };\r\n }\r\n\r\n render() {\r\n return (\r\n
\r\n
\r\n {this.props.children}\r\n
\r\n
\r\n );\r\n }\r\n}\r\n\r\nexport default FormPage;\r\n","import React, { Component } from 'react';\r\n\r\nimport styles from './LobbyStyles.module.scss';\r\nimport formStyles from \"./FormStyles.module.scss\";\r\n\r\nimport FormPage from './FormPage';\r\n\r\nclass ErrorModal extends Component {\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n\r\n };\r\n }\r\n\r\n render() {\r\n return (\r\n
\r\n
\r\n \r\n

{this.props.title}

\r\n

{this.props.message}

\r\n
\r\n \r\n {\r\n this.props.callbackText2 &&\r\n \r\n }\r\n
\r\n
\r\n
\r\n );\r\n }\r\n}\r\n\r\n\r\nexport default (ErrorModal);\r\n","export default __webpack_public_path__ + \"static/media/background.4979bada.png\";","export default __webpack_public_path__ + \"static/media/background-green.0f5c6b41.png\";","export default \"\"","export default __webpack_public_path__ + \"static/media/cards-img-old.d3dc0584.png\";","export default \"\"","export default __webpack_public_path__ + \"static/media/painter.00ca5410.png\";","export default \"\"","export default \"\"","import background from \"../images/background.png\";\r\nimport backgroundGreen from \"../images/background-green.png\";\r\nimport banner from \"../images/banner.png\";\r\nimport bucket from \"../images/bucket.png\";\r\nimport cardsImg from \"../images/cards-img.png\";\r\nimport cardsImgOld from \"../images/cards-img-old.png\";\r\nimport eraser from \"../images/eraser.png\";\r\nimport frame from \"../images/frame.png\";\r\nimport muted from \"../images/muted.png\";\r\nimport painter from \"../images/painter.png\";\r\nimport pen from \"../images/pen.png\";\r\nimport potato from \"../images/potato.png\";\r\nimport scrawlFullscreen from \"../images/scrawl_fullscreen.png\";\r\nimport scrawlHelp from \"../images/scrawl_help.png\";\r\nimport scrawlMuted from \"../images/scrawl_muted.png\";\r\nimport scrawlUnmuted from \"../images/scrawl_unmuted.png\";\r\nimport scrawlLogo from \"../images/scrawl-logo.png\";\r\nimport scrawlLogo17 from \"../images/scrawl-logo-17.png\";\r\nimport undo from \"../images/undo.png\";\r\nimport unmuted from \"../images/unmuted.png\";\r\nimport familyIcon from \"images/Family Icon.png\"\r\nimport adultsIcon from \"images/Adults Icon.png\"\r\n\r\n\r\nconst images = [\r\nbackground,\r\n banner,\r\n bucket,\r\n cardsImg,\r\n cardsImgOld,\r\n eraser,\r\n frame,\r\n muted,\r\n painter,\r\n pen,\r\n potato,\r\n scrawlFullscreen,\r\n scrawlHelp,\r\n scrawlMuted,\r\n scrawlUnmuted,\r\n scrawlLogo,\r\n undo,\r\n unmuted,\r\n familyIcon,\r\n adultsIcon,\r\n backgroundGreen,\r\n scrawlLogo17\r\n];\r\n\r\nconst fonts = [\r\n { font: \"Gagalin\", path: `https://${window.location.host}/Assets/gagalin.ttf`},\r\n { font: \"Helenita\", path: `https://${window.location.host}/Assets/HelenitaBookRough.otf`},\r\n { font: \"Interstate\", path: `https://${window.location.host}/Assets/Interstate-Regular.otf`},\r\n { font: \"MyriadPro\", path: `https://${window.location.host}/Assets/MyriadPro-Regular.otf`},\r\n];\r\n\r\n\r\nconst WSErrorCodes = {\r\n 1001: \"Browser Tab Closing\",\r\n 1002: \"Malformed framce received\",\r\n 1003: \"Unsupported frame received\",\r\n 1006: \"GS ungraceful shutdown / connection refused\",\r\n 1011: \"Internal Error\",\r\n 1012: \"Server Restarting\",\r\n 1013: \"Try again later, server capacity full\",\r\n 1014: \"Bad Gateway\",\r\n 4000: \"Gameserver graceful shutdown\",\r\n 4050: \"Player removed\"\r\n};\r\n\r\nexport default {\r\n images,\r\n fonts,\r\n WSErrorCodes\r\n};","export default \"\"","export default \"\"","export default \"\"","import React, { Component } from 'react';\r\nimport * as Colyseus from \"colyseus.js\";\r\nimport { Route } from 'react-router';\r\nimport QRCode from 'qrcode.react';\r\nimport Lottie from 'react-lottie';\r\nimport * as gifShot from \"gifshot\";\r\nimport { Howl, Howler } from \"howler\";\r\nimport Confetti from 'react-confetti';\r\nimport LoggingService from \"services/logging\";\r\n//import { datadogRum } from '@datadog/browser-rum';\r\n\r\nimport timerTurning from \"animations/timerTurning.js\";\r\nimport timerEnd from \"animations/timerEnd.js\";\r\nimport potatoDraw from \"animations/potatoDraw.js\";\r\nimport potatoWrite from \"animations/potatoWrite.js\";\r\nimport tickCard from 'animations/tickCard.js';\r\n//import chooseCards from 'animations/titles/chooseCards.js';\r\n//import bigRevealAnim from 'animations/titles/bigReveal.js';\r\n//import howToPlayAnim from 'animations/titles/howToPlay.js';\r\n//import winnerIsAnim from 'animations/titles/winnerIs.js';\r\n\r\nimport Loading from \"components/Loading\";\r\nimport Player from \"components/Player\";\r\nimport Menu from \"components/Menu\";\r\nimport getAvatarById from \"constants/avatars\";\r\n\r\nimport logo from \"images/scrawl-logo.png\";\r\nimport logo17 from \"images/scrawl-logo-17.png\";\r\nimport frame from \"images/frame.png\";\r\nimport mutedIcon from \"images/scrawl_muted.png\";\r\nimport unmutedIcon from \"images/scrawl_unmuted.png\";\r\nimport fullscreenIcon from \"images/scrawl_fullscreen.png\";\r\nimport helpIcon from \"images/scrawl_help.png\";\r\nimport cardsImg from \"images/cards-img.png\";\r\nimport bannerImg from \"images/banner.png\";\r\nimport familyIcon from \"images/Family Icon.png\"\r\nimport adultsIcon from \"images/Adults Icon.png\"\r\n\r\nimport Tutorial from \"components/Tutorial\";\r\n\r\nimport playingBgMusic from \"audio/playing-bg-music.mp3\";\r\nimport galleryMusic from \"audio/gallery-reveal-music.mp3\";\r\nimport bigRevealSFX from \"audio/big-reveal.mp3\";\r\nimport favouriteChosenBackgroundSFX from \"audio/favourite-chosen-background.mp3\";\r\nimport favouriteChosenSFX from \"audio/favourite-chosen-sound.mp3\";\r\nimport playerReadySFX from \"audio/player-ready.mp3\";\r\nimport playerReady2SFX from \"audio/player-ready-2.mp3\";\r\nimport playerReady3SFX from \"audio/player-ready-3.mp3\";\r\nimport playerReady4SFX from \"audio/player-ready-4.mp3\";\r\nimport playerReady5SFX from \"audio/player-ready-5.mp3\";\r\nimport playerReady6SFX from \"audio/player-ready-6.mp3\";\r\nimport revealOneSFX from \"audio/reveal-one.mp3\";\r\nimport roundStartDrawingSFX from \"audio/round-start-drawing.mp3\";\r\nimport roundStartWritingSFX from \"audio/round-start-writing.mp3\";\r\nimport winnerSFX from \"audio/winner.mp3\";\r\nimport joinedSFX from \"audio/player-joined.mp3\";\r\nimport hoverOrClickSFX from \"audio/hover-click.mp3\";\r\n\r\nimport ErrorModal from 'components/Utility/ErrorModal';\r\n\r\nimport * as Sentry from \"@sentry/react\";\r\nimport constants from \"constants/constants\";\r\n\r\nimport \"animate.css\";\r\nimport styles from 'components/HostStyles.module.scss';\r\n\r\n\r\nconst fullscreenAvailable = document.fullscreenEnabled || document.mozFullscreenEnabled || document.webkitFullscreenEnabled ? true : false;\r\n\r\nconst readySFX = [\r\n playerReady5SFX,\r\n playerReady3SFX,\r\n playerReadySFX,\r\n playerReady2SFX,\r\n playerReady6SFX,\r\n playerReady4SFX,\r\n]\r\n\r\nconst GameStates = {\r\n Loading: \"loading\",\r\n Tutorial: \"tutorial\",\r\n ChoosingCards: \"choosing_cards\",\r\n Playing: \"playing\",\r\n Revealing: \"revealing\",\r\n Awarding: \"awarding\",\r\n Idle: \"idle\",\r\n Results: \"results\",\r\n EndGame: \"end_game\",\r\n};\r\n\r\nconst gameId = \"scrawl\";\r\n\r\nconst PlayerColours = [\r\n \"#35A8E0\",\r\n \"#37B4AA\",\r\n \"#93C01F\",\r\n \"#FFEC00\",\r\n \"#FAB900\",\r\n \"#E74E0F\",\r\n \"#E40076\",\r\n \"#633587\",\r\n];\r\n\r\n\r\n\r\nexport class Home extends Component {\r\n static displayName = Home.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.client = new Colyseus.Client(process.env.REACT_APP_GAME_SERVER_URL);\r\n this.state = {\r\n roomId: 0,\r\n room: null,\r\n myId: null,\r\n roomState: null,\r\n redirect: null,\r\n reconnectTries: 0,\r\n connected: false,\r\n //connected: true, //debug\r\n muted: false,\r\n menuOpen: false,\r\n gameBegun: false,\r\n reconnectionToken: \"\",\r\n contentFilter: 0,\r\n availableAddons: [],\r\n\r\n isGame: false,\r\n //isGame: true, //debug\r\n showRoundNumbers: false,\r\n roundNumber: 0,\r\n totalRounds: 0,\r\n players: [],\r\n //players: [ //debug\r\n // {\r\n // name: \"SCOTT\",\r\n // id: \"test-id-1\",\r\n // avatar: 2,\r\n // showPlayer: true,\r\n // scrawlData: {\r\n // isPlaying: true,\r\n // score: 0,\r\n // }\r\n // },\r\n // {\r\n // name: \"WWWWWWWWWW\",\r\n // id: \"test-id-2\",\r\n // avatar: 2,\r\n // showPlayer: true,\r\n // isPlaying: true,\r\n // scrawlData: {\r\n // isPlaying: true,\r\n // score: 0,\r\n // }\r\n // },\r\n // {\r\n // name: \"WWWWWWWWWW\",\r\n // id: \"test-id-3\",\r\n // avatar: 2,\r\n // showPlayer: true,\r\n // isPlaying: true,\r\n // scrawlData: {\r\n // isPlaying: true,\r\n // score: 0,\r\n // }\r\n // }],\r\n playersRequired: 3,\r\n gameState: GameStates.Loading,\r\n isDrawing: false,\r\n isWriting: false,\r\n roundTitle: \"\",\r\n isRevealing: false,\r\n isCards: false,\r\n playerRevealing: {},\r\n storyList: [],\r\n ogCard: \"\",\r\n revealTitle: \"\",\r\n choosingBest: false,\r\n highlightBest: false,\r\n hideStory: false,\r\n popOutPotato: false,\r\n bestItem: null,\r\n bestItemPlayer: {},\r\n showWinners: false,\r\n winners: [],\r\n winnersText: \"\",\r\n showPlayAgain: false,\r\n showTimer: false,\r\n timer: 10,\r\n timerOptions: timerTurning,\r\n shrinkLogo: false,\r\n //shrinkLogo: true, //debug\r\n doodlesOne: [],\r\n doodlesTwo: [],\r\n doingTutorial: false,\r\n showTutorial: false,\r\n\r\n maxVoteCount: 0,\r\n skipTutorialCount: 0,\r\n allRevealed: false,\r\n revealCount: 0,\r\n\r\n animContext: \"\",\r\n showPlayers: false,\r\n //showPlayers: true, //debug\r\n dissapearBest: false,\r\n showStartGame: false,\r\n //showStartGame: true, //debug\r\n\r\n readySFXIndex: 0,\r\n readySFXArray: readySFX,\r\n\r\n tickedSkipTutorial: false,\r\n leaderboardPlayers: [],\r\n doConfetti: false,\r\n\r\n playTitle: false,\r\n titleText: \"\",\r\n\r\n gotLocationPing: true,\r\n connectionIssue: false,\r\n\r\n joinError: false,\r\n isSmartTV: false,\r\n\r\n showStartWarning: false,\r\n showContentWarning: false,\r\n playerConnections: {},\r\n };\r\n this.titleRefs = {\r\n \"Cards\": React.createRef(),\r\n \"BigReveal\": React.createRef(),\r\n \"Tutorial\": React.createRef(),\r\n \"WinnersAre\": React.createRef(),\r\n }\r\n this.titleAnimRef = React.createRef();\r\n this.toggleMute = this.toggleMute.bind(this);\r\n this.toggleMenu = this.toggleMenu.bind(this);\r\n\r\n\r\n this.gameBgAudio = new Howl({\r\n src: playingBgMusic,\r\n loop: true,\r\n volume: 0.2,\r\n });\r\n this.galleryBgAudio = new Howl({\r\n src: galleryMusic,\r\n loop: true,\r\n volume: 0.7,\r\n });\r\n }\r\n\r\n async componentDidMount() {\r\n this.setTags();\r\n this.doReconnect();\r\n\r\n this.toggleMute(true, false);\r\n this.preloadAudio([\r\n bigRevealSFX,\r\n favouriteChosenBackgroundSFX,\r\n favouriteChosenSFX,\r\n revealOneSFX,\r\n roundStartDrawingSFX,\r\n roundStartWritingSFX,\r\n winnerSFX,\r\n joinedSFX,\r\n hoverOrClickSFX,\r\n ...readySFX\r\n ]);\r\n //this.playAudio(playingBgMusic, true, 0.2);\r\n Howler.volume(0.6);\r\n this.gameBgAudio.play();\r\n this.preloadImage(frame);\r\n }\r\n\r\n setTags() {\r\n const token = this.getQueryStringValue('token');\r\n Sentry.setTag('isHost', true);\r\n\r\n if (token) {\r\n const [ roomId, reconnectToken ] = token.split(':');\r\n Sentry.setTag('roomId', roomId);\r\n Sentry.setTag('reconnectToken', reconnectToken);\r\n }\r\n }\r\n\r\n preloadImage(src) {\r\n const startDate = new Date();\r\n\r\n const img = new Image();\r\n img.onload = () => {\r\n const endDate = new Date();\r\n const seconds = (endDate.getTime() - startDate.getTime()) / 1000;\r\n console.log(`Images loaded in ${seconds} seconds!`);\r\n }\r\n img.src = src; // by setting an src, you trigger browser download\r\n }\r\n\r\n toggleFullScreen() {\r\n if (fullscreenAvailable) {\r\n if (!document.fullscreenElement && !document.webkitIsFullScreen && !document.mozFullScreen && !document.msFullscreenElement) {\r\n let elem = document.documentElement\r\n if (elem.requestFullscreen) {\r\n elem.requestFullscreen();\r\n } else if (elem.webkitRequestFullscreen) {\r\n elem.webkitRequestFullscreen();\r\n } else if (elem.mozRequestFullScreen) {\r\n elem.mozRequestFullScreen();\r\n } else if (elem.msRequestFullscreen) {\r\n elem.msRequestFullscreen();\r\n }\r\n } else {\r\n if (document.exitFullscreen) {\r\n document.exitFullscreen();\r\n } else if (document.webkitExitFullscreen) {\r\n document.webkitExitFullscreen();\r\n } else if (document.mozExitFullscreen) {\r\n document.mozExitFullscreen();\r\n } else if (document.msExitFullscreen) {\r\n document.msExitFullscreen();\r\n }\r\n }\r\n }\r\n }\r\n\r\n createGIF = (images) => {\r\n gifShot.createGIF({\r\n images,\r\n interval: .8,\r\n gifWidth: 1200,\r\n gifHeight: 800,\r\n }, function (obj) {\r\n if (!obj.error) {\r\n var image = obj.image;\r\n\r\n var link = document.createElement(\"a\");\r\n link.download = \"gifTest.gif\";\r\n link.href = image;\r\n document.body.appendChild(link);\r\n link.click();\r\n document.body.removeChild(link);\r\n //delete link;\r\n }\r\n })\r\n };\r\n\r\n getQueryStringValue(key) {\r\n return decodeURIComponent(window.location.search.replace(new RegExp(\"^(?:.*[&\\\\?]\" + encodeURIComponent(key).replace(/[\\.\\+\\*]/g, \"\\\\$&\") + \"(?:\\\\=([^&]*))?)?.*$\", \"i\"), \"$1\"));\r\n }\r\n\r\n animatePotato(id, animation) {\r\n if (document.getElementById(`potato-${id}`)) {\r\n this.animateCSS(`#potato-${id}`, animation);\r\n }\r\n }\r\n\r\n animateCSS = (element, animation, prefix = 'animate__') =>\r\n // We create a Promise and return it\r\n new Promise((resolve, reject) => {\r\n const animationName = `${prefix}${animation}`;\r\n let node;\r\n if (typeof element === `string`) {\r\n node = document.querySelector(element);\r\n } else {\r\n node = element;\r\n }\r\n node.classList.add(`${prefix}animated`, animationName);\r\n\r\n // When the animation ends, we clean the classes and resolve the Promise\r\n function handleAnimationEnd(event) {\r\n event.stopPropagation();\r\n node.classList.remove(`${prefix}animated`, animationName);\r\n resolve('Animation ended');\r\n }\r\n\r\n node.addEventListener('animationend', handleAnimationEnd, { once: true });\r\n });\r\n\r\n preloadAudio(audioFiles) {\r\n for (let i = 0; i < audioFiles.length; i++) {\r\n let audio = new Howl({\r\n src: [audioFiles[i]],\r\n preload: true\r\n });\r\n }\r\n }\r\n\r\n playAudio(audioFile, loop = false, volume = 1) {\r\n //let audio = new Audio(audioFile);\r\n //audio.play();\r\n let audio = new Howl({\r\n src: [audioFile],\r\n loop: loop,\r\n volume: volume,\r\n });\r\n audio.play();\r\n }\r\n\r\n toggleMenu() {\r\n console.log(\"toggle menu\");\r\n let newVal = this.state.menuOpen == true ? false : true;\r\n this.setState({ menuOpen: newVal });\r\n }\r\n\r\n toggleMute(force = false, value = false) {\r\n let newVal;\r\n if (force) {\r\n newVal = value;\r\n } else {\r\n newVal = this.state.muted == true ? false : true;\r\n }\r\n\r\n Howler.mute(newVal);\r\n this.setState({ muted: newVal, });\r\n }\r\n\r\n removePlayer(id) {\r\n this.setState((prevState) => {\r\n return { players: prevState.players.filter(x => x.id != id), }\r\n });\r\n }\r\n\r\n addPlayer(player) {\r\n if (!this.state.players.find(elem => elem.id == player.id)) {\r\n this.setState((prevState) => {\r\n return { players: [...prevState.players, player] }\r\n });\r\n }\r\n }\r\n\r\n populateLeftColumn() {\r\n let players = [];\r\n for (let i = 0; i < 4; i++) {\r\n if (this.state.players[i]) {\r\n players.push();\r\n } else {\r\n players.push();\r\n }\r\n }\r\n return players;\r\n }\r\n\r\n populateRightColumn() {\r\n let players = [];\r\n for (let i = 4; i < 8; i++) {\r\n if (this.state.players[i]) {\r\n players.push();\r\n } else {\r\n players.push();\r\n }\r\n }\r\n return players;\r\n }\r\n\r\n populatePlayers() {\r\n let players = [];\r\n for (let i = 0; i < this.state.players.length; i++) {\r\n if (this.state.players[i]) {\r\n players.push();\r\n } else {\r\n players.push();\r\n }\r\n }\r\n return players;\r\n }\r\n\r\n isWinner(id) {\r\n let match = false;\r\n for (let i = 0; i < this.state.winners.length; i++) {\r\n console.log(\"looking for match : \" + id);\r\n console.log(\"comparing to: \" + this.state.winners[i].id);\r\n if (this.state.winners[i].id === id) {\r\n console.log(\"found a match!\");\r\n match = true;\r\n }\r\n }\r\n return match;\r\n }\r\n\r\n getRandomElement(array) {\r\n return array[Math.random() * array.length >> 0];\r\n }\r\n\r\n shuffleArray(array) {\r\n for (let i = array.length - 1; i > 0; i--) {\r\n const j = Math.floor(Math.random() * (i + 1));\r\n [array[i], array[j]] = [array[j], array[i]];\r\n }\r\n return array;\r\n }\r\n\r\n getReadySFX() {\r\n let sfx = \"\";\r\n if (this.state.readySFXIndex >= this.state.readySFXArray.length) {\r\n this.setState(prevState => {\r\n return {\r\n readySFXArray: this.shuffleArray(prevState.readySFXArray),\r\n readySFXIndex: 0\r\n }\r\n }, () => {\r\n sfx = this.state.readySFXArray[this.state.readySFXIndex];\r\n });\r\n\r\n } else {\r\n sfx = this.state.readySFXArray[this.state.readySFXIndex];\r\n\r\n this.setState(prevState => {\r\n return {\r\n readySFXIndex: prevState.readySFXIndex + 1,\r\n }\r\n });\r\n\r\n }\r\n\r\n return sfx;\r\n }\r\n\r\n setPlayerReady(id) {\r\n this.playAudio(this.getReadySFX(), false, 0.2);\r\n let players = [...this.state.players];\r\n\r\n let pos = players.map(function (e) { return e.id; }).indexOf(id);\r\n let player = { ...players[pos] };\r\n\r\n player.scrawlData.ready = true;\r\n\r\n players[pos] = player;\r\n\r\n this.setState({ players });\r\n }\r\n\r\n startRevealing(player) {\r\n let revealCount = this.state.revealCount;\r\n revealCount++;\r\n this.unreadyAll();\r\n let timeoutTime = 0;\r\n this.toggleTimer(false);\r\n if (revealCount <= 1) {\r\n\r\n\r\n this.playAudio(bigRevealSFX, false, 0.6);\r\n this.doTitleAnim(\"BigReveal\");\r\n }\r\n else {\r\n this.playAudio(roundStartWritingSFX, false, 0.6);\r\n timeoutTime = 1000;\r\n this.setState({ dissapearBest: true, });\r\n }\r\n this.setState({ playerRevealing: player, storyList: player.scrawlData.story, ogCard: player.scrawlData.cardText, allRevealed: false, });\r\n setTimeout(() => {\r\n this.setState({ revealCount, showRoundNumbers: false, dissapearBest: false, showPlayers: false, isRevealing: true, highlightBest: false, hideStory: false, popOutPotato: false, choosingBest: false, bestItem: null, revealTitle: `Reveal each image using your device!`, });\r\n\r\n }, timeoutTime);\r\n }\r\n\r\n revealNext(story) {\r\n //console.log(\"story: \" + JSON.stringify(story));\r\n this.playAudio(revealOneSFX, false, 0.25);\r\n let index = null;\r\n for (let i = 0; i < story.length; i++) {\r\n if (story[i].revealed) {\r\n if (story[i + 1]) {\r\n if (story[i + 1].revealed) story[i].hide = true;\r\n }\r\n index = i;\r\n }\r\n }\r\n this.setState({ storyList: story, });\r\n }\r\n\r\n allRevealed() {\r\n setTimeout(() => {\r\n let story = [...this.state.storyList];\r\n story.forEach(x => {\r\n x.hide = true;\r\n });\r\n this.setState({ choosingBest: true, storyList: story, /*allRevealed: true,*/ });\r\n }, 3000);\r\n //this.setState({ revealTitle: `Choose your favourite addition to award a point!`, });\r\n }\r\n\r\n chooseBest(item, player) {\r\n this.setState({ highlightBest: true, allRevealed: true, bestItem: item, bestItemPlayer: player, choosingBest: false, revealTitle: `The best addition was by: ${item.byName}!`, });\r\n this.playAudio(favouriteChosenBackgroundSFX, false, 0.35);\r\n this.playAudio(favouriteChosenSFX, false, 0.35);\r\n setTimeout(() => {\r\n this.setState({ popOutPotato: true, })\r\n }, 750);\r\n\r\n setTimeout(() => {\r\n this.setState({ storyList: [], });\r\n }, 2000);\r\n setTimeout(() => {\r\n this.state.room.send(\"finish_awarding\");\r\n }, 4000);\r\n }\r\n\r\n noBest() {\r\n setTimeout(() => {\r\n let story = [...this.state.storyList];\r\n story.forEach(x => {\r\n x.hide = true;\r\n });\r\n this.setState({ choosingBest: true, storyList: story, allRevealed: true, });\r\n\r\n setTimeout(() => {\r\n this.setState({ hideStory: true, });\r\n setTimeout(() => {\r\n this.setState({ storyList: [], });\r\n this.state.room.send(\"finish_awarding\");\r\n }, 1500);\r\n }, 2000);\r\n }, 3000);\r\n }\r\n\r\n\r\n updateScores(players) {\r\n let statePlayers = [...this.state.players];\r\n for (const [key, value] of Object.entries(players)) {\r\n let pos = statePlayers.map(function (e) { return e.id; }).indexOf(value.id);\r\n let player = { ...statePlayers[pos] };\r\n player.scrawlData.score = value.scrawlData.score;\r\n statePlayers[pos] = player;\r\n }\r\n this.setState({ revealTitle: ``, players: statePlayers, });\r\n }\r\n\r\n doGameOver(winners, players) {\r\n this.setState({ dissapearBest: true, });\r\n this.galleryBgAudio.pause();\r\n this.gameBgAudio.play();\r\n\r\n this.getLeaderboardList(players);\r\n\r\n setTimeout(() => {\r\n //this.setState({ showPlayers: true, });\r\n setTimeout(() => {\r\n let winnersText = ``;\r\n if (winners.length > 1) {\r\n winnersText = \"Winners!\";\r\n } else {\r\n winnersText = \"Winner!\";\r\n }\r\n this.setState({ isRevealing: false, highlightBest: false, hideStory: false, popOutPotato: false, choosingBest: false, storyList: [], bestItem: null, winners, winnersText, });\r\n this.playAudio(bigRevealSFX, false, 0.6);\r\n this.doTitleAnim(\"WinnersAre\");\r\n }, 1000);\r\n }, 2000);\r\n }\r\n\r\n showPlayAgain() {\r\n let stateWinners = [...this.state.winners];\r\n for (let i = 0; i < stateWinners.length; i++) {\r\n setTimeout(() => {\r\n let player = { ...stateWinners[i] };\r\n player.showSelf = false;\r\n stateWinners[i] = player;\r\n this.setState({ winners: stateWinners });\r\n }, (i * 300));\r\n }\r\n setTimeout(() => {\r\n this.state.room.send(\"reached_end\", {});\r\n this.setState({ showWinners: false, winners: [], winnersText: \"\", showPlayAgain: true, });\r\n }, 3000);\r\n }\r\n\r\n hidePlayAgain() {\r\n this.setState({ showPlayAgain: false, showPlayers: true, });\r\n }\r\n\r\n playAgain = (confirm = false) => {\r\n //this.hidePlayAgain();\r\n let allConnected = true;\r\n console.log(\"Player Connections : \", this.state.playerConnections);\r\n for (const [key, value] of Object.entries(this.state.playerConnections)) {\r\n console.log(`key : `, value);\r\n if (value === false) allConnected = false;\r\n }\r\n\r\n console.log(\"confirm : \", confirm);\r\n console.log(\"all connected : \", allConnected);\r\n\r\n if (!confirm && !allConnected) {\r\n console.log(\"Show Start Warning\");\r\n this.setState({ showStartWarning: true });\r\n } else {\r\n console.log(\"Play Again\");\r\n this.playAudio(hoverOrClickSFX, false, 0.6);\r\n this.setState({ showStartWarning: false });\r\n this.state.room.send(\"new_game\", {});\r\n }\r\n }\r\n\r\n differentGame = () => {\r\n this.playAudio(hoverOrClickSFX, false, 0.6);\r\n this.hidePlayAgain();\r\n this.state.room.send(\"change_game\", {});\r\n }\r\n\r\n resetRound() {\r\n this.setState({ isRevealing: false, highlightBest: false, hideStory: false, popOutPotato: false, });\r\n }\r\n\r\n resetGame(players) {\r\n this.hidePlayAgain();\r\n let statePlayers = [...this.state.players];\r\n statePlayers.forEach(x => {\r\n x.scrawlData = players[x.id].scrawlData;\r\n });\r\n this.setState({ showWinners: false, players: statePlayers, revealCount: 0, });\r\n setTimeout(() => {\r\n setTimeout(() => {\r\n this.playAudio(roundStartDrawingSFX, false, 0.6);\r\n }, 500)\r\n setTimeout(() => {\r\n this.playAudio(roundStartDrawingSFX, false, 0.6);\r\n }, 3000)\r\n this.doTitleAnim(\"Cards\");\r\n }, 3000);\r\n }\r\n\r\n unreadyAll() {\r\n let players = [...this.state.players];\r\n players.forEach(x => {\r\n x.scrawlData.ready = false;\r\n })\r\n this.setState({ players });\r\n }\r\n\r\n setConnected(id, connected) {\r\n let players = [...this.state.players];\r\n let pos = players.map(function (e) { return e.id; }).indexOf(id);\r\n let player = { ...players[pos] };\r\n\r\n player.connected = connected;\r\n\r\n players[pos] = player;\r\n\r\n this.setState({ players });\r\n }\r\n\r\n updateConnectTimer(id, timer) {\r\n let players = [...this.state.players];\r\n let pos = players.map(function (e) { return e.id; }).indexOf(id);\r\n let player = { ...players[pos] };\r\n\r\n player.connectingTimer = timer;\r\n\r\n players[pos] = player;\r\n\r\n this.setState({ players });\r\n }\r\n\r\n updateRoundNums(totalRounds, roundNumber) {\r\n //if (totalRounds < roundNumber) {\r\n // totalRounds = roundNumber;\r\n //}\r\n this.setState({ roundNumber, totalRounds, showRoundNumbers: true, });\r\n }\r\n\r\n getTickList() {\r\n let list = [];\r\n for (let i = 1; i <= this.state.totalRounds; i++) {\r\n let stopped = true;\r\n if (i <= this.state.roundNumber) stopped = false;\r\n list.push(\r\n \r\n );\r\n }\r\n return list;\r\n }\r\n\r\n\r\n handleNextTurn(message) {\r\n this.unreadyAll();\r\n this.updateRoundNums(message.totalRounds, message.roundNumber);\r\n this.toggleTimer(false);\r\n this.setState({ isCards: false, });\r\n\r\n if (this.state.roundNumber % 2 === 0) {\r\n this.setState({ isDrawing: false, isWriting: true, roundTitle: \"WRITE WHAT YOU SEE!\" });\r\n setTimeout(() => {\r\n this.playAudio(roundStartWritingSFX, false, 1);\r\n setTimeout(() => {\r\n this.toggleTimer(true);\r\n }, 1000);\r\n }, 500);\r\n } else {\r\n this.setState({ isDrawing: true, isWriting: false, roundTitle: \"DRAW THE DESCRIPTION ON YOUR DEVICES!\" });\r\n setTimeout(() => {\r\n this.playAudio(roundStartDrawingSFX, false, 1);\r\n setTimeout(() => {\r\n this.toggleTimer(true);\r\n }, 1000);\r\n }, 500);\r\n \r\n }\r\n //this.setState({ isDrawing: true, isWriting: false, roundTitle: \"DRAW or WRITE what's on your devices!\" });\r\n }\r\n\r\n showDoodle(doodle) {\r\n if (this.state.doodlesOne.length > this.state.doodlesTwo.length) {\r\n let doodlesTwo = [...this.state.doodlesTwo];\r\n doodlesTwo.push(doodle);\r\n this.setState({ doodlesTwo, });\r\n setTimeout(() => {\r\n this.setState((prevState) => {\r\n prevState.doodlesTwo.shift();\r\n return { doodlesTwo: prevState.doodlesTwo }\r\n });\r\n }, 5000);\r\n } else {\r\n let doodlesOne = [...this.state.doodlesOne];\r\n doodlesOne.push(doodle);\r\n this.setState({ doodlesOne, });\r\n setTimeout(() => {\r\n this.setState((prevState) => {\r\n prevState.doodlesOne.shift();\r\n return { doodlesOne: prevState.doodlesOne }\r\n });\r\n }, 5000);\r\n }\r\n }\r\n\r\n doTitleAnim(context) {\r\n //let titles = [...this.state.titles];\r\n //let titleIndex = titles.map(x => x.context).indexOf(context);\r\n //let title = titles[titleIndex];\r\n\r\n //title.isPaused = false;\r\n //titles[titleIndex] = title;\r\n //this.setState({ titles });\r\n\r\n //this.titleRefs[context].play();\r\n switch (context) {\r\n case \"Tutorial\":\r\n this.setState({ playTitle: true, titleText: \"HOW TO PLAY\" });\r\n break;\r\n case \"Cards\":\r\n this.setState({ playTitle: true, titleText: \"CHOOSE YOUR CARD\" });\r\n break;\r\n case \"WinnersAre\":\r\n this.setState({ playTitle: true, titleText: \"THE WINNER IS...\" });\r\n break;\r\n case \"BigReveal\":\r\n this.setState({ playTitle: true, titleText: \"TIME FOR THE BIG REVEAL\" });\r\n break;\r\n }\r\n\r\n setTimeout(() => {\r\n this.doTitleComplete(context);\r\n }, 5500);\r\n }\r\n\r\n doTitleComplete(context) {\r\n //let titles = [...this.state.titles];\r\n //let titleIndex = titles.map(x => x.context).indexOf(context);\r\n //let title = titles[titleIndex];\r\n\r\n //title.isPaused = true;\r\n //titles[titleIndex] = title;\r\n //this.setState({ titles });\r\n\r\n //this.titleRefs[context].stop();\r\n\r\n this.setState({ playTitle: false, titleText: \"\" });\r\n \r\n switch (context) {\r\n case \"Tutorial\":\r\n this.setState({ doingTutorial: true, });\r\n setTimeout(() => {\r\n this.gameBgAudio.volume(0.05);\r\n this.state.room.send(\"show_tutorial\", {});\r\n this.setState({ showTutorial: true, });\r\n }, 500);\r\n break;\r\n case \"Cards\":\r\n this.state.room.send(\"start_game\", {});\r\n break;\r\n case \"WinnersAre\":\r\n this.setState({ showWinners: true, doConfetti: true, });\r\n let stateWinners = [...this.state.winners];\r\n this.playAudio(winnerSFX, false, 0.6);\r\n for (let i = 0; i < stateWinners.length; i++) {\r\n setTimeout(() => {\r\n let player = { ...stateWinners[i] };\r\n player.showSelf = true;\r\n stateWinners[i] = player;\r\n this.setState({ winners: stateWinners });\r\n }, (i * 300));\r\n }\r\n setTimeout(() => {\r\n this.showPlayAgain();\r\n }, 8000);\r\n break;\r\n case \"BigReveal\":\r\n this.gameBgAudio.pause();\r\n this.galleryBgAudio.play();\r\n break;\r\n default:\r\n this.toggleTimer(true);\r\n break;\r\n }\r\n }\r\n\r\n toggleTimer(show) {\r\n this.setState({ showTimer: show, });\r\n }\r\n\r\n startGame = (confirm = false, confirmContentWarning = false) => {\r\n let allConnected = true;\r\n for (const [key, value] of Object.entries(this.state.playerConnections)) {\r\n if (value === false) allConnected = false;\r\n }\r\n\r\n if (!confirmContentWarning && this.state.contentFilter === 1) {\r\n this.setState({ showContentWarning: true });\r\n }\r\n else if (!confirm && !allConnected) {\r\n this.setState({ showStartWarning: true });\r\n } else {\r\n this.playAudio(hoverOrClickSFX, false, 0.6);\r\n this.state.room.send(\"begin_game\", { skipTutorial: this.state.tickedSkipTutorial, });\r\n this.setState({ showStartGame: false, showStartWarning: false, });\r\n }\r\n }\r\n\r\n closeStartWarning = () => {\r\n this.setState({ showStartWarning: false });\r\n }\r\n\r\n confirmNewGame = () => {\r\n this.playAgain(true);\r\n }\r\n\r\n confirmStartGame = () => {\r\n this.startGame(true);\r\n }\r\n\r\n closeContentWarning = () => {\r\n this.setState({ showContentWarning: false });\r\n }\r\n\r\n confirmContentWarning = () => {\r\n this.startGame(false, true);\r\n this.setState({ showContentWarning: false });\r\n }\r\n\r\n toggleSkipTutorial = (e) => {\r\n if (this.state.showStartGame) {\r\n console.log(\"cb value: \" + e.target.checked);\r\n this.setState({ tickedSkipTutorial: e.target.checked });\r\n }\r\n }\r\n\r\n getLeaderboardList(players) {\r\n let statePlayers = [...this.state.players];\r\n statePlayers.forEach(x => {\r\n x.scrawlData = players[x.id].scrawlData;\r\n });\r\n\r\n let leaderboardPlayers = [];\r\n statePlayers.forEach((x, index) => {\r\n let boardPlayer = {\r\n name: x.name,\r\n score: x.scrawlData.score,\r\n bgColor: PlayerColours[index],\r\n avatar: x.avatar,\r\n };\r\n leaderboardPlayers.push(boardPlayer);\r\n });\r\n leaderboardPlayers = leaderboardPlayers.sort((a, b) => {\r\n return b.score - a.score;\r\n });\r\n\r\n for (let i = 0; i < leaderboardPlayers.length; i++) {\r\n leaderboardPlayers[i].position = this.getPosition(leaderboardPlayers[i], i, leaderboardPlayers);\r\n }\r\n\r\n this.setState({ leaderboardPlayers, });\r\n }\r\n\r\n getPosition(player, index, leaderboardPlayers) {\r\n let position = 1;\r\n if (index > 0) {\r\n const playerAbove = leaderboardPlayers[index - 1];\r\n if (playerAbove != null) {\r\n if (player.score == playerAbove.score) return playerAbove.position;\r\n else return playerAbove.position + 1;\r\n }\r\n }\r\n return position;\r\n }\r\n\r\n getRedirectURL(display = false) {\r\n let url = display ? process.env.REACT_APP_GAME_CITY_URL_DISPLAY : process.env.REACT_APP_GAME_CITY_URL;\r\n if (this.state.room) {\r\n if (this.state.room.name != \"game_city_room\") {\r\n url = display ? process.env.REACT_APP_HOME_URL_DISPLAY : process.env.REACT_APP_HOME_URL;\r\n }\r\n }\r\n return url;\r\n }\r\n\r\n\r\n updateToken(token) {\r\n var url = new URL(window.location.href);\r\n\r\n try {\r\n window.history.replaceState(null, null, (url.pathname) + (`?token=${token}`));\r\n } catch (e) {\r\n console.warn(e)\r\n }\r\n }\r\n\r\n startLocationChecks() {\r\n this.state.room.send(\"location_check\", { gameId, });\r\n this.locationCheckInterval = setInterval(() => {\r\n if (this.state.gotLocationPing) {\r\n this.setState({ gotLocationPing: false, connectionIssue: false, });\r\n } else {\r\n console.log(\"Host Connection Issue detected\");\r\n this.setState({ connectionIssue: true, });\r\n this.hostLostConnectionBug();\r\n }\r\n this.state.room.send(\"location_check\", { gameId, });\r\n }, 10000);\r\n }\r\n\r\n doReconnect = () => {\r\n\r\n\r\n if (this.state.reconnectTries < 5) {\r\n\r\n //const roomId = this.getQueryStringValue(\"roomId\");\r\n //const sessionId = this.getQueryStringValue(\"sessionId\");\r\n const token = this.getQueryStringValue(\"token\");\r\n //console.log(roomId);\r\n if (this.state.connected == false) {\r\n this.client.reconnect(token).then(room => {\r\n console.log(room.sessionId, \"joined\", room.name);\r\n\r\n this.setState({ room: room, roomId: room.id, myId: room.sessionId, connected: true, reconnectionToken: room.reconnectionToken});\r\n this.updateToken(room.reconnectionToken);\r\n room.send(\"update_host_token\", { reconnectionToken: room.reconnectionToken });\r\n\r\n room.onStateChange.once((state) => {\r\n console.log(\"this is the first room state!\", state);\r\n const deviceInfo = JSON.parse(state.host.deviceDetailsJson);\r\n if (deviceInfo.device.type === 'smarttv' || deviceInfo.ua.toLowerCase().includes('smarttv')) {\r\n this.setState({ isSmartTV: true });\r\n }\r\n\r\n if (state.host.id != room.sessionId) window.location = this.getRedirectURL();\r\n Sentry.setUser({ id: state.host.uniqueId });\r\n \r\n this.setState({ roomState: state, maxVoteCount: state.players.size });\r\n\r\n if (state.scrawlData.gameState == GameStates.Loading) {\r\n room.send(\"host_joined_game\", { gameId });\r\n this.setState({ isGame: true, });\r\n setTimeout(() => {\r\n this.setState({ showStartGame: true, shrinkLogo: true, });\r\n }, 1000);\r\n\r\n this.startLocationChecks();\r\n } else {\r\n room.send(\"change_game\", {});\r\n }\r\n });\r\n room.onStateChange((state) => {\r\n console.log(room.name, \"has new state:\", state);\r\n \r\n this.setState({ roomState: state, maxVoteCount: state.players.size, });\r\n });\r\n\r\n room.state.availableAddons.onAdd((addon, key) => {\r\n let availableAddons = [...this.state.availableAddons];\r\n availableAddons.push(addon);\r\n this.setState({ availableAddons });\r\n });\r\n\r\n room.state.scrawlData.listen(\"gameState\", (currentValue, previousValue) => {\r\n if (currentValue != GameStates.Loading && currentValue != GameStates.EndGame && this.state.showStartWarning) {\r\n this.setState({ showStartWarning: false });\r\n }\r\n this.setState({ gameState: currentValue });\r\n });\r\n\r\n room.state.players.onAdd((player, key) => {\r\n player.listen(\"connected\", (currentValue, previousValue) => {\r\n let playerConnections = { ...this.state.playerConnections };\r\n playerConnections[key] = currentValue;\r\n this.setState({ playerConnections });\r\n });\r\n });\r\n\r\n room.onMessage(\"location_confirmed\", (message) => {\r\n console.log(\"location_confirmed\", \"received on\", room.name, message);\r\n this.setState({ gotLocationPing: true, });\r\n });\r\n\r\n room.state.scrawlData.listen(\"contentFilter\", (currentValue) => { this.setState({ contentFilter: currentValue }) });\r\n\r\n //room.onMessage(\"all_connected\", (message) => {\r\n // console.log(\"all_connected\", \"received on\", room.name, message);\r\n // if (room.state.scrawlData.gameState == GameStates.Loading) {\r\n // this.setState({ isGame: true, });\r\n // for (const [key, value] of Object.entries(message.players)) {\r\n // this.addPlayer(value);\r\n // }\r\n // room.send(\"start_game\", {});\r\n // }\r\n // if (Object.keys(message.players).length < this.state.playersRequired) {\r\n // room.send(\"change_game\", {});\r\n // }\r\n //});\r\n room.onMessage(\"show_players\", (message) => {\r\n console.log(\"show_players\", \"received on\", room.name, message);\r\n for (const [key, value] of Object.entries(message.players)) {\r\n this.addPlayer(value);\r\n }\r\n setTimeout(() => {\r\n this.setState({ showPlayers: true, shrinkLogo: true, });\r\n }, 2000);\r\n });\r\n room.onMessage(\"clicked_begin_game\", (message) => {\r\n this.setState({ showStartGame: false, })\r\n });\r\n room.onMessage(\"begin_game\", (message) => {\r\n console.log(\"begin_game\", \"received on\", room.name, message);\r\n console.log(\"game state... \", this.state.roomState.scrawlData.gameState);\r\n if ((this.state.roomState.scrawlData.gameState == GameStates.Loading || this.state.roomState.scrawlData.gameState == GameStates.Idle) && !this.state.gameBegun) {\r\n this.setState({ showTutorial: false, gameBegun: true, showStartGame: false, });\r\n this.gameBgAudio.volume(0.2);\r\n setTimeout(() => {\r\n this.setState({ doingTutorial: false, });\r\n }, 500);\r\n\r\n room.send(\"start_playing\", {});\r\n setTimeout(() => {\r\n setTimeout(() => {\r\n this.playAudio(roundStartDrawingSFX, false, 0.6);\r\n }, 500)\r\n setTimeout(() => {\r\n this.playAudio(roundStartDrawingSFX, false, 0.6);\r\n }, 3000)\r\n this.doTitleAnim(\"Cards\");\r\n }, 2000);\r\n }\r\n });\r\n room.onMessage(\"player_leave\", (message) => {\r\n console.log(\"player_leave\", \"received on\", room.name, message);\r\n this.removePlayer(message.sessionId);\r\n });\r\n room.onMessage(\"player_joined\", (message) => {\r\n console.log(\"player_joined\", \"received on\", room.name, message);\r\n this.playAudio(joinedSFX, false, 0.6);\r\n this.addPlayer(message.player);\r\n });\r\n room.onMessage(\"animate_potato\", (message) => {\r\n console.log(\"animate_potato\", \"received on\", room.name, message);\r\n this.animatePotato(message.id, message.animation);\r\n });\r\n room.onMessage(\"start_game\", (message) => {\r\n console.log(\"start_game\", \"received on\", room.name, message);\r\n this.setState({ isCards: true, });\r\n this.toggleTimer(true);\r\n });\r\n room.onMessage(\"player_ready\", (message) => {\r\n console.log(\"player_ready\", \"received on\", room.name, message);\r\n this.setPlayerReady(message.id);\r\n });\r\n room.onMessage(\"start_round\", (message) => {\r\n console.log(\"start_round\", \"received on\", room.name, message);\r\n // start potato animation in center here\r\n this.unreadyAll();\r\n });\r\n room.onMessage(\"next_turn\", (message) => {\r\n console.log(\"next_turn\", \"received on\", room.name, message);\r\n this.handleNextTurn(message);\r\n });\r\n room.onMessage(\"round_over\", (message) => {\r\n console.log(\"round_over\", \"received on\", room.name, message);\r\n // end potato animation in center here\r\n this.setState({ isDrawing: false, isWriting: false, });\r\n this.unreadyAll();\r\n });\r\n room.onMessage(\"start_reveal\", (message) => {\r\n console.log(\"start_reveal\", \"received on\", room.name, message);\r\n this.startRevealing(message.player);\r\n });\r\n room.onMessage(\"reveal_next\", (message) => {\r\n console.log(\"reveal_next\", \"received on\", room.name, message);\r\n this.revealNext(message.story);\r\n });\r\n room.onMessage(\"all_revealed\", (message) => {\r\n console.log(\"all_revealed\", \"received on\", room.name, message);\r\n this.allRevealed();\r\n });\r\n room.onMessage(\"choose_best\", (message) => {\r\n console.log(\"choose_best\", \"received on\", room.name, message);\r\n this.chooseBest(message.item, message.player);\r\n });\r\n room.onMessage(\"no_best\", (message) => {\r\n console.log(\"no_best\", \"received on\", room.name, message);\r\n this.noBest();\r\n });\r\n room.onMessage(\"update_scores\", (message) => {\r\n console.log(\"update_scores\", \"received on\", room.name, message);\r\n this.updateScores(message.players);\r\n });\r\n room.onMessage(\"game_over\", (message) => {\r\n console.log(\"game_over\", \"received on\", room.name, message);\r\n this.doGameOver(message.winners, message.players);\r\n });\r\n room.onMessage(\"reset_round\", (message) => {\r\n console.log(\"reset_round\", \"received on\", room.name, message);\r\n this.resetRound();\r\n });\r\n room.onMessage(\"show_doodle\", (message) => {\r\n console.log(\"show_doodle\", \"received on\", room.name, message);\r\n this.showDoodle(message.doodle);\r\n });\r\n\r\n room.onMessage(\"change_game\", (message) => {\r\n console.log(\"change_game\", \"received on\", room.name, message);\r\n this.setState({ redirect: `${this.getRedirectURL()}/lobby/?token=${this.state.reconnectionToken}` });\r\n if (this.locationCheckInterval) clearInterval(this.locationCheckInterval);\r\n this.state.room.leave(false);\r\n });\r\n\r\n room.onMessage(\"new_game\", (message) => {\r\n console.log(\"new_game\", \"received on\", room.name, message);\r\n this.hidePlayAgain();\r\n this.resetGame(message.players);\r\n });\r\n //room.onMessage(\"set_player_connected\", (message) => {\r\n // console.log(\"set_player_connected\", \"received on\", room.name, message);\r\n // this.setConnected(message.id, message.connected);\r\n //});\r\n room.onMessage(\"update_connect_timer\", (message) => {\r\n console.log(\"update_connect_timer\", \"received on\", room.name, message);\r\n this.updateConnectTimer(message.id, message.timer);\r\n });\r\n //room.onMessage(\"test_gif\", (message) => {\r\n // console.log(\"test_gif\", \"received on\", room.name, message);\r\n // this.createGIF(message.images);\r\n //});\r\n room.onMessage(\"update_timer\", (message) => {\r\n console.log(\"update_timer\", \"received on\", room.name, message);\r\n if (message.count <= 5) {\r\n if (message.count <= 0) {\r\n }\r\n this.setState({ timerOptions: timerEnd });\r\n } else {\r\n this.setState({ timerOptions: timerTurning });\r\n }\r\n this.setState({ timer: message.count, });\r\n });\r\n room.onMessage(\"begin_tutorial\", (message) => {\r\n console.log(\"begin_tutorial\", \"received on\", room.name, message);\r\n this.setState({ showStartGame: false, });\r\n setTimeout(() => {\r\n setTimeout(() => {\r\n this.playAudio(roundStartDrawingSFX, false, 0.6);\r\n }, 500)\r\n this.doTitleAnim(\"Tutorial\");\r\n }, 3000);\r\n });\r\n room.onMessage(\"update_skip_vote\", (message) => {\r\n console.log(\"update_skip_vote\", \"received on\", room.name, message);\r\n this.setState({ skipTutorialCount: message.voteCount });\r\n });\r\n\r\n room.onError((code, message) => {\r\n Sentry.captureMessage(`WS Received: onError`);\r\n console.log(this.client.id, \"couldn't join\", room.name);\r\n\r\n this.setState({ joinError : true});\r\n //LoggingService.logError(message, code);\r\n });\r\n room.onLeave((code) => {\r\n console.log(this.client.id, \"left\", room.name);\r\n // Sentry.captureMessage('Websocket disconnected: ' + (typeof constants.WSErrorCodes[code] !== 'undefined' ? constants.WSErrorCodes[code] : code), 'error');\r\n if (!this.state.redirect) {\r\n this.setState({ connected: false, reconnectTries: this.state.reconnectTries + 1 });\r\n setTimeout(() => {\r\n this.doReconnect();\r\n }, 1000);\r\n }\r\n });\r\n }).catch(e => {\r\n console.log(\"JOIN ERROR\", e);\r\n this.setState({ connected: false, reconnectTries: this.state.reconnectTries + 1 });\r\n const message = e.message ? e.message : \"An error occured Hosting Scrawl.\";\r\n Sentry.captureMessage(`doReconnect Error: ${message}`);\r\n //LoggingService.logError(message, e);\r\n setTimeout(() => {\r\n this.doReconnect();\r\n }, 1000);\r\n });\r\n }\r\n } else {\r\n this.setState({ redirect: `${this.getRedirectURL()}/lobby` });\r\n if (this.locationCheckInterval) clearInterval(this.locationCheckInterval);\r\n }\r\n }\r\n\r\n changeContentFilter(value) {\r\n this.setState({ contentFilter: value });\r\n this.state.room.send(\"toggle_content_filter\", { value: value });\r\n const userFriendlyValues = [\"Family\", \"Adult\"]\r\n console.log(\"changed content filter to: \" + userFriendlyValues[value]);\r\n }\r\n\r\n render() {\r\n\r\n if (this.state.redirect) {\r\n return (\r\n \r\n
\r\n
\r\n \r\n
\r\n
\r\n
\r\n (window.location = this.state.redirect)} />\r\n
'\r\n
\r\n )\r\n }\r\n return (\r\n
\r\n