(this["webpackJsonptype-for-speed"]=this["webpackJsonptype-for-speed"]||[]).push([[0],{39:function(e,t,n){e.exports=n(67)},44:function(e,t,n){},45:function(e,t,n){},67:function(e,t,n){"use strict";n.r(t);var a=n(0),s=n.n(a),i=n(11),r=n.n(i),o=(n(44),n(37)),c=n(87),p=n(12),u=n(13),l=n(24),m=n(23),h=(n(45),n(88)),d=n(89),g=n(25),f=n.n(g),v=function(){function e(){Object(p.a)(this,e)}return Object(u.a)(e,[{key:"getUserName",value:function(){return this.request("getUserName",{}).then((function(e){return null!=e&&"username"in e?e.username:""}))}},{key:"setUserName",value:function(e){this.request("setUserName",{username:e})}},{key:"getScore",value:function(e){return this.request("getScore",{snippetID:e}).then((function(e){return null!=e&&"score"in e?e.score:""}))}},{key:"setScore",value:function(e,t){this.request("setScore",{snippetID:e,score:t})}},{key:"getNextSnippet",value:function(e){return this.request("getNextSnippet",{snippetID:e})}},{key:"request",value:function(e,t){return f.a.post("https://type-fast-293505-go-server-dot-type-fast-293505.wm.r.appspot.com/"+e,{Token:localStorage.getItem("token"),JSON:JSON.stringify(t)},{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":"*"}}).then((function(e){return JSON.parse(e.data)})).catch((function(e){console.log(e)}))}}]),e}(),y="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890!@#$%^&*()`~-_=+[{]}\\|;:'\",<.>/? ",N=function(e){Object(l.a)(n,e);var t=Object(m.a)(n);function n(e){var a;return Object(p.a)(this,n),(a=t.call(this,e)).onFocus=function(e){a.setState({isFocused:!0})},a.onLoseFocus=function(e){new Promise((function(e){return setTimeout(e,300)})).then((function(){a.paper!==document.activeElement&&a.setState({isFocused:!1})}))},a.getTypedText=function(e){return a.state.typedText},a.onKeyDown=function(e){e.preventDefault();var t=e.key;if(e.ctrlKey){if("r"===t)return void a.onReset();if("f"===t)return void a.getNext()}if("Backspace"===t){var n=a.state.wrongText,s=a.state.typedText;n?a.setState({wrongText:n.slice(0,n.length-1)}):s&&a.setState({typedText:s.slice(0,s.length-1)})}else if(a.allowed(t)||"Enter"===t||"Tab"===t){"Enter"===t?t="\n":"Tab"===t&&(t="\t"),a.state.typedText||a.state.wrongText||a.start();var i=a.state.typedText,r=a.state.wrongText;a.doesNextCharMatch(r,i,t)?(i+=t,i=a.typeTabs(i),a.setState({typedText:i})):(r+=t,a.setState({wrongText:r})),a.updateWpm(r,i)}},a.state={text:"",typedText:"",wrongText:"",startTime:0,currentWpm:"",isFocused:!1},a}return Object(u.a)(n,[{key:"componentDidMount",value:function(){}},{key:"render",value:function(){var e=this;return s.a.createElement("div",{className:"typing primary-light"},s.a.createElement("div",{className:"paper paper-shadow "+this.displayHighlight(),onKeyDown:this.onKeyDown,onBlur:this.onLoseFocus,onFocus:this.onFocus,tabIndex:"-1",ref:function(t){return e.paper=t}},s.a.createElement("div",{className:"typingcontainer"},s.a.createElement("div",{className:"instructions "+this.displayInstructions()},s.a.createElement("div",{className:"innerInstructions"},"Click the paper and start typing!")),s.a.createElement("div",{className:"typingtext"},this.props.text),s.a.createElement("div",{className:"typingtextfront"},this.getTypedText(),s.a.createElement("span",{className:"typingtextbadspan"},this.getWrongText()),s.a.createElement("span",{className:"green"},this.displayEnter()),s.a.createElement("span",{className:"next"},this.getNextChar(this.state.typedText.length,this.state.wrongText))),s.a.createElement("div",{className:"current"}))))}},{key:"displayHighlight",value:function(){return this.state.isFocused?"highlight-off":"highlight-on"}},{key:"displayInstructions",value:function(){return this.state.isFocused?"hidden":""}},{key:"displayEnter",value:function(){return this.getWrongText()||"\n"!==this.getNextChar(this.state.typedText.length,this.state.wrongText)?"":" Hit Enter! "}},{key:"componentDidUpdate",value:function(e){0!==e.restart&&(e.restart===this.props.restart&&e.textId===this.props.textId||(this.onReset(),this.paper.focus()))}},{key:"allowed",value:function(e){return y.includes(e)}},{key:"typeTabs",value:function(e){for(;e.length=this.props.text.length?"":this.props.text.slice(e,e+1):""}},{key:"doesNextCharMatch",value:function(e,t,n){return!e&&this.getNextChar(t.length,e)===n}},{key:"isFinished",value:function(e,t){return!this.state.wrongText&&this.props.text===t}},{key:"getWrongText",value:function(){return this.state.wrongText}}]),n}(s.a.Component),x=function(e){Object(l.a)(n,e);var t=Object(m.a)(n);function n(e){var a;return Object(p.a)(this,n),(a=t.call(this,e)).onMouseEnterName=function(e){a.setState({showEditName:!0})},a.onMouseLeaveName=function(e){a.setState({showEditName:!1}),a.setUserName(e)},a.handleWpmChange=function(e,t){a.setState({currentWpm:e}),t&&(!a.state.bestWpm||a.state.bestWpm