adding .wrong css class to display errors
This commit is contained in:
		
							parent
							
								
									f888a553e1
								
							
						
					
					
						commit
						567f85f5f3
					
				| @ -1,7 +1,7 @@ | |||||||
| <template> | <template> | ||||||
|   <div class='container'> |   <div class='container'> | ||||||
|     <div id="prompt-screen"> |     <div id="prompt-screen"> | ||||||
|       <span v-for="(letter, index) in letters" :key="index" :class="[isActive(index) ? 'active' : '']">{{ letter }}</span> |       <span v-for="(letter, index) in letters" :key="index" :class="getSpanClasses(index)">{{ letter }}</span> | ||||||
|     </div> |     </div> | ||||||
| 
 | 
 | ||||||
|     <div id="user-input"> |     <div id="user-input"> | ||||||
| @ -21,7 +21,8 @@ export default { | |||||||
|       letters: [], |       letters: [], | ||||||
|       number: 50, |       number: 50, | ||||||
|       userText: "", |       userText: "", | ||||||
|       activeIndex: 0 |       activeIndex: 0, | ||||||
|  |       isWrong: false | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
|   async mounted() { |   async mounted() { | ||||||
| @ -44,16 +45,37 @@ export default { | |||||||
|     compareStrings(a, b) { |     compareStrings(a, b) { | ||||||
|       let count = 0 |       let count = 0 | ||||||
|       a.split("").forEach((aLetter, index) => { |       a.split("").forEach((aLetter, index) => { | ||||||
|         if(b.split("")[index] != aLetter) { return count} |         if(b.split("")[index] != aLetter) { | ||||||
|  |           this.setWrong() | ||||||
|  |           return count | ||||||
|  |         } | ||||||
|         count ++ |         count ++ | ||||||
|       }) |       }) | ||||||
|       return count |       return count | ||||||
|  |     }, | ||||||
|  |     getSpanClasses(index) { | ||||||
|  |       let classes = "" | ||||||
|  |       if(index === this.cursor) { | ||||||
|  |         classes += "active" | ||||||
|  |         if(this.isWrong) classes += " wrong" | ||||||
|  |       } | ||||||
|  |       return classes | ||||||
|  |     }, | ||||||
|  |     setWrong() { | ||||||
|  |       if(!this.isWrong) this.isWrong = true | ||||||
|  |     }, | ||||||
|  |     setNotWrong() { | ||||||
|  |       if(this.isWrong) this.isWrong = false | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
|   computed: { |   computed: { | ||||||
|     cursor() { |     cursor() { | ||||||
|       return this.compareStrings(this.userText, this.letters.join("")) |       let c = this.compareStrings(this.userText, this.letters.join("")) | ||||||
|     } |       if(c == this.userText.length) { | ||||||
|  |         this.setNotWrong() | ||||||
|  |       } | ||||||
|  |       return c | ||||||
|  |     }, | ||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -86,4 +108,8 @@ span.active { | |||||||
|   width: 500px; |   width: 500px; | ||||||
|   font-size: 2em; |   font-size: 2em; | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | span.wrong { | ||||||
|  |   background-color: red; | ||||||
|  | } | ||||||
| </style> | </style> | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user