generated from jlumbroso/react-ts-starter
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathhelpers.tsx
132 lines (116 loc) · 3.22 KB
/
helpers.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
import wordBank from "./wordle-nytimes-bank.txt"
export enum LetterStatus {
Unknown = 0,
Letter = 2,
LetterAndPosition = 4,
Disabled = 1,
}
export function computeGuessStatus(
guess: string,
correctWord: string
): Array<LetterStatus> {
// normalize inputs
guess = guess.toLocaleUpperCase()
correctWord = correctWord.toLocaleUpperCase()
let remainder = correctWord
let status = new Array(5).fill(LetterStatus.Unknown)
// NOTE: to ensure proper coloring of the letters, it is impossible
// to first identify correctly located letters, otherwise an incorrectly
// located letter could be orange, and the subsequent correctly located
// letter could be grey.
// FIRST PASS: find all letters properly located
for (let i = 0; i < guess.length; i++) {
const c = guess.charAt(i)
if (c === correctWord.charAt(i)) {
// remove the first occurrence (important to color repetitions accurately)
remainder = remainder.replace(c, "")
// record that this matches both letter and position
status[i] = LetterStatus.LetterAndPosition
}
}
// SECOND PASS: find letters incorrectly located
for (let i = 0; i < guess.length; i++) {
const c = guess.charAt(i)
// skip properly positioned letters
if (c === correctWord.charAt(i)) continue
// EITHER: the letter is in the word
if (remainder.includes(c)) {
remainder = remainder.replace(c, "")
// since we have located correctly positioned letters, we know this is incorrectly positioned
status[i] = LetterStatus.Letter
}
// OR: there are no more occurrences of the letter to be found
else {
status[i] = LetterStatus.Disabled
}
}
return status
}
export const boardDefault = [
["", "", "", "", ""],
["", "", "", "", ""],
["", "", "", "", ""],
["", "", "", "", ""],
["", "", "", "", ""],
["", "", "", "", ""],
]
export const boardStatusDefault = [
[
LetterStatus.Unknown,
LetterStatus.Unknown,
LetterStatus.Unknown,
LetterStatus.Unknown,
LetterStatus.Unknown,
],
[
LetterStatus.Unknown,
LetterStatus.Unknown,
LetterStatus.Unknown,
LetterStatus.Unknown,
LetterStatus.Unknown,
],
[
LetterStatus.Unknown,
LetterStatus.Unknown,
LetterStatus.Unknown,
LetterStatus.Unknown,
LetterStatus.Unknown,
],
[
LetterStatus.Unknown,
LetterStatus.Unknown,
LetterStatus.Unknown,
LetterStatus.Unknown,
LetterStatus.Unknown,
],
[
LetterStatus.Unknown,
LetterStatus.Unknown,
LetterStatus.Unknown,
LetterStatus.Unknown,
LetterStatus.Unknown,
],
[
LetterStatus.Unknown,
LetterStatus.Unknown,
LetterStatus.Unknown,
LetterStatus.Unknown,
LetterStatus.Unknown,
],
]
export async function generateWordSet(): Promise<{ wordSet: Set<string> }> {
let wordSet: Set<string> = new Set()
await fetch(wordBank)
.then((response) => response.text())
.then((result) => {
const wordArr = result.toUpperCase().split("\n")
wordSet = new Set(wordArr)
})
return { wordSet }
}
export function getRandomItemFromSet<X>(set: Set<X>) {
const arr = Array.from(set.keys())
const randomIndex = Math.floor(Math.random() * arr.length)
const item = arr[randomIndex]
return item
}