Add an "About" link
This commit is contained in:
82
src/App.tsx
82
src/App.tsx
@@ -4,20 +4,84 @@ import { dictionarySet, pick } from "./util";
|
||||
import Game from "./Game";
|
||||
import { names } from "./names";
|
||||
import { useState } from "react";
|
||||
import { Row, RowState } from "./Row";
|
||||
import { Clue } from "./clue";
|
||||
|
||||
function App() {
|
||||
const [about, setAbout] = useState(false);
|
||||
const maxGuesses = 6;
|
||||
return (
|
||||
<>
|
||||
<div className="App-container">
|
||||
<h1>hello wordl</h1>
|
||||
<footer className="App-footer">
|
||||
by <a href="https://twitter.com/chordbug">@chordbug</a>, inspired by{" "}
|
||||
<a href="https://www.powerlanguage.co.uk/wordle/">wordle</a>. report
|
||||
issues <a href="https://github.com/lynn/hello-wordl/issues">here</a>
|
||||
</footer>
|
||||
<div className="App">
|
||||
<Game maxGuesses={6} />
|
||||
<div style={{ position: "absolute", right: 5, top: 5 }}>
|
||||
<a href="#" onClick={() => setAbout((a) => !a)}>
|
||||
{about ? "Close" : "About"}
|
||||
</a>
|
||||
</div>
|
||||
</>
|
||||
{about && (
|
||||
<div className="App-about">
|
||||
<p>
|
||||
<i>hello wordl</i> is a remake of the word game{" "}
|
||||
<a href="https://www.powerlanguage.co.uk/wordle/">
|
||||
<i>Wordle</i>
|
||||
</a>
|
||||
, which I think is based on the TV show <i>Lingo</i>.
|
||||
</p>
|
||||
<p>
|
||||
You get {maxGuesses} tries to guess a target word.
|
||||
<br />
|
||||
After each guess, you get Mastermind-style feedback:
|
||||
</p>
|
||||
<p>
|
||||
<Row
|
||||
rowState={RowState.LockedIn}
|
||||
wordLength={4}
|
||||
cluedLetters={[
|
||||
{ clue: Clue.Absent, letter: "w" },
|
||||
{ clue: Clue.Absent, letter: "o" },
|
||||
{ clue: Clue.Correct, letter: "r" },
|
||||
{ clue: Clue.Elsewhere, letter: "d" },
|
||||
]}
|
||||
/>
|
||||
</p>
|
||||
<p>
|
||||
<b>W</b> and <b>O</b> aren't in the target word at all.
|
||||
<br />
|
||||
<b>R</b> is correct! The third letter is <b>R</b>
|
||||
.<br />
|
||||
<b>D</b> occurs <em>elsewhere</em> in the target
|
||||
word.
|
||||
</p>
|
||||
<p>
|
||||
Let's move the <b>D</b> in our next guess:
|
||||
<Row
|
||||
rowState={RowState.LockedIn}
|
||||
wordLength={4}
|
||||
cluedLetters={[
|
||||
{ clue: Clue.Correct, letter: "d" },
|
||||
{ clue: Clue.Correct, letter: "a" },
|
||||
{ clue: Clue.Correct, letter: "r" },
|
||||
{ clue: Clue.Absent, letter: "k" },
|
||||
]}
|
||||
/>
|
||||
So close!
|
||||
<Row
|
||||
rowState={RowState.LockedIn}
|
||||
wordLength={4}
|
||||
cluedLetters={[
|
||||
{ clue: Clue.Correct, letter: "d" },
|
||||
{ clue: Clue.Correct, letter: "a" },
|
||||
{ clue: Clue.Correct, letter: "r" },
|
||||
{ clue: Clue.Correct, letter: "t" },
|
||||
]}
|
||||
/>
|
||||
Got it!
|
||||
</p>
|
||||
Report issues <a href="https://github.com/lynn/hello-wordl/issues">here</a>, or tweet <a href="https://twitter.com/chordbug">@chordbug</a>.
|
||||
</div>
|
||||
)}
|
||||
<Game maxGuesses={maxGuesses} hidden={about} />
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user