import * as React from "react"; import {GameWasm, Letter as LetterData, MyResult, PlayedTile, PlayerAndScore, Tray, WordResult} from "word_grid"; import { LocationType, matchCoordinate, mergeTrays, PlayableLetterData, Settings, TileDispatchAction, TileDispatchActionType } from "./utils"; import {useEffect, useMemo, useReducer, useRef, useState} from "react"; import {TileExchangeModal} from "./TileExchange"; import {Grid, Scores, TileTray} from "./UI"; function addLogInfo(existingLog: React.JSX.Element[], newItem: React.JSX.Element) { newItem = React.cloneElement(newItem, { key: existingLog.length }) existingLog.push(newItem); return existingLog.slice(); } export function Game(props: {wasm: GameWasm, settings: Settings}) { const cellTypes = useMemo(() => { return props.wasm.get_board_cell_types(); }, []); const [confirmedScorePoints, setConfirmedScorePoints] = useState(-1); function movePlayableLetters(playerLetters: PlayableLetterData[], update: TileDispatchAction) { if(update.action === TileDispatchActionType.RETRIEVE) { let tray: Tray = props.wasm.get_tray("Player"); return mergeTrays(playerLetters, tray.letters); } else if (update.action === TileDispatchActionType.MOVE) { let startIndex = matchCoordinate(playerLetters, update.start); let endIndex = matchCoordinate(playerLetters, update.end); if(startIndex != null) { let startLetter = playerLetters[startIndex]; startLetter.location = update.end.location; startLetter.index = update.end.index; } if(endIndex != null) { let endLetter = playerLetters[endIndex]; endLetter.location = update.start.location; endLetter.index = update.start.index; } setConfirmedScorePoints(-1); return playerLetters.slice(); } if (update.action === TileDispatchActionType.SET_BLANK) { const blankLetter = playerLetters[update.blankIndex]; if(blankLetter.text !== update.newBlankValue) { blankLetter.text = update.newBlankValue; if (blankLetter.location == LocationType.GRID) { setConfirmedScorePoints(-1); } } return playerLetters.slice(); } else if (update.action === TileDispatchActionType.RETURN) { return mergeTrays(playerLetters, playerLetters); } else { console.error("Unknown tray update"); console.error({update}); } } const [playerLetters, trayDispatch] = useReducer(movePlayableLetters, []); const [logInfo, logDispatch] = useReducer(addLogInfo, []); const [turnCount, setTurnCount] = useState(1); const playerAndScores: PlayerAndScore[] = useMemo(() => { return props.wasm.get_scores(); }, [turnCount]); const boardLetters: LetterData[] = useMemo(() => { return props.wasm.get_board_letters(); }, [turnCount]); useEffect(() => { logDispatch(

Turn {turnCount}

); setConfirmedScorePoints(-1); trayDispatch({action: TileDispatchActionType.RETRIEVE}); }, [turnCount]); const logDivRef = useRef(null); const [isTileExchangeOpen, setIsTileExchangeOpen] = useState(false); useEffect(() => { // Effect is to keep the log window scrolled down if (logDivRef.current != null) { logDivRef.current.scrollTo(0, logDivRef.current.scrollHeight); // scroll down } }, [logInfo]) function exchangeFunction(selectedArray: Array) { let numSelected = 0; selectedArray.forEach((x) => { if (x){ numSelected++; } }) const result: MyResult = props.wasm.exchange_tiles("Player", selectedArray); console.log({result}); if(result.response_type === "ERR") { logDispatch(
{(result.value as string)}
); } else { logDispatch(
You exchanged {numSelected} tiles.
); setTurnCount(turnCount + 1); } } return <>
{logInfo}
; }