import React, {useState} from 'react'; import ValidatingInputNumberField from "./ValidatingInputNumberField"; export default function InputForm({handleResult}) { const [width, setWidth] = useState(10); const [height, setHeight] = useState(10); const [id, setId] = useState(null); const [status, setStatus] = useState("typing"); // "typing", "submitting" if (status === "submitted") { return ; } const callAPI = () => { let url = "https://manuel.friedli.info/labyrinth/create/json?w=" + width + "&h=" + height; if (!!id) { url += "&id=" + id; } fetch(url) .then(response => response.json()) .then(result => { handleResult(result); setId(_ => result.id); }) .catch(reason => { console.error("Failed to fetch maze data.", reason); // FIXME alert is not user friendly alert("Failed to fetch maze data: " + reason); }) .finally(() => { setStatus("typing"); }); }; const handleSubmit = (e) => { e.preventDefault(); setStatus("submitting"); callAPI(); }; const validateWidthHeightInput = value => { if (isNaN(value) || "" === value || (Math.floor(value) !== Number(value))) { return { valid: false, message: "Must be an integer greater than 1.", value }; } if (value < 1) { return { valid: false, message: "Must be greater than 1.", value }; } return { valid: true, value }; }; const validateIdInput = value => { // FIXME doesn't handle strings with characters correctly (e.g. "asdf" yields an empty value, due to "type=number"). if (isNaN(value) || ("" !== value && ((Math.floor(value) !== Number(value))))) { return { valid: false, message: "Must be empty or an integer", value }; } return { valid: true, value } }; return (
); }