Skip to content

Commit

Permalink
I think this is the right rule
Browse files Browse the repository at this point in the history
  • Loading branch information
lynn committed Jan 22, 2022
1 parent e07726f commit e9a2912
Show file tree
Hide file tree
Showing 3 changed files with 22 additions and 14 deletions.
17 changes: 7 additions & 10 deletions src/App.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@ function App() {
useEffect(() => {
document.body.className = dark ? "dark" : "";
setTimeout(() => {
// Avoid transition on page load
document.body.style.transition = "0.3s background-color ease-out";
}, 1);
}, [dark]);
Expand All @@ -58,14 +59,10 @@ function App() {
<div className="App-container">
<h1>
<span
style={
difficulty > 0
? {
color: "#e66",
textShadow: difficulty > 1 ? "0px 0px 5px #e66" : "none",
}
: {}
}
style={{
color: difficulty > 0 ? "#e66" : "inherit",
fontStyle: difficulty > 1 ? "italic" : "inherit",
}}
>
hell
</span>
Expand Down Expand Up @@ -136,9 +133,9 @@ function App() {
>
{
[
`No restrictions on guesses.`,
`Guesses must be valid dictionary words.`,
`Wordle's "Hard Mode". Green letters must stay fixed, and yellow letters must be reused.`,
`An even stricter Hard Mode. Yellow letters must move away from where they were clued.`,
`An even stricter Hard Mode. Yellow letters must move away from where they were clued, and gray clues must be obeyed.`,
][difficulty]
}
</div>
Expand Down
16 changes: 12 additions & 4 deletions src/clue.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Difficulty, ordinal } from "./util";
import { Difficulty, englishNumbers, ordinal } from "./util";

export enum Clue {
Absent,
Expand Down Expand Up @@ -71,9 +71,17 @@ export function violation(
const upper = letter.toUpperCase();
const nth = ordinal(i + 1);
if (clue === Clue.Absent) {
// if (difficulty === Difficulty.UltraHard && guess.includes(letter)) {
// return "Guess can't contain " + upper;
// }
if (difficulty === Difficulty.UltraHard) {
const max = clues.filter(
(c) => c.letter === letter && c.clue !== Clue.Absent
).length;
const count = guess.split(letter).length - 1;
if (count > max) {
const amount = max ? `more than ${englishNumbers[max]} ` : "";
const s = max > 1 ? "s" : "";
return `Guess can't contain ${amount}${upper}${s}`;
}
}
} else if (clue === Clue.Correct) {
if (guess[i] !== letter) {
return nth + " letter must be " + upper;
Expand Down
3 changes: 3 additions & 0 deletions src/util.ts
Original file line number Diff line number Diff line change
Expand Up @@ -59,3 +59,6 @@ export function speak(
export function ordinal(n: number): string {
return n + ([, "st", "nd", "rd"][(n % 100 >> 3) ^ 1 && n % 10] || "th");
}

export const englishNumbers =
"zero one two three four five six seven eight nine ten eleven".split(" ");

0 comments on commit e9a2912

Please sign in to comment.