import { FC, useEffect, useState } from 'react'; import { GSX_SERVICE_CALLED, GSX_SERVICE_FINISHED } from '../../constants'; import { WASMDataF } from '../../types/WASMData'; import { LoadingState } from '../../types/general'; import { CoherentCallZFWEntry, inRangeOf, loadAircraft, unloadAircraft } from '../../utils/utils'; import CGSelect from '../CGSelect/CGSelect'; import ActionBar from '../actionbar/ActionBar'; interface ZFWEntryProps { WASMData: WASMDataF; loadingState: LoadingState; gsxActive: boolean; setLoadingState: (newState: LoadingState) => void; } const ZFWEntryF: FC = ({ WASMData, loadingState, gsxActive, setLoadingState }) => { const [CGTarget, setCGTarget] = useState(WASMData.targetPayload.CGTarget); const [fuel, setFuel] = useState(Math.round(WASMData.livePayload.fuel)); const [ZFWTarget, setZFWTarget] = useState(Math.round(WASMData.targetPayload.total)); const [fuelEnabled, setFuelEnabled] = useState(true); const ZFW = () => { if (loadingState !== 'loaded' && !gsxActive) return ZFWTarget; return Math.round(WASMData.livePayload.total); }; const ZFWValid = () => { return ZFW() <= WASMData.limits.maxZFW; }; const GW = () => { return fuel + ZFW(); }; const GWValid = () => { return GW() <= WASMData.limits.maxTOW; }; const handleInput = (input: string, maxValue: number, setter: (value: number) => void) => { if (!input) { setter(0); return; } const converted = parseInt(input); if (converted) { if (converted < 0) setter(0); else if (converted > maxValue) setter(maxValue); else setter(converted); } }; const handleInputZFW = (input: string) => { if (!input) return; const converted = parseInt(input); if (converted) { if (converted < 0) setZFWTarget(Math.round(WASMData.targetPayload.empty + WASMData.targetPayload.crew)); else if (converted > WASMData.limits.maxZFW) setZFWTarget(WASMData.limits.maxZFW); else setZFWTarget(converted); } }; const handleBlur = (input: string) => { const minZFW = Math.round(WASMData.targetPayload.empty + WASMData.targetPayload.crew); if (!input) { setZFWTarget(minZFW); return; } const converted = parseInt(input); if (converted) { if (converted < minZFW) setZFWTarget(minZFW); else if (converted > WASMData.limits.maxZFW) setZFWTarget(WASMData.limits.maxZFW); else setZFWTarget(converted); } updateData(converted); }; useEffect( () => setFuel((prev) => { if (prev > WASMData.limits.maxFuel) return WASMData.limits.maxFuel; return prev; }), [WASMData.userData.isER] ); useEffect(() => { setFuelEnabled((prev) => (!prev ? inRangeOf(Math.round(WASMData.livePayload.fuel), fuel) : prev)); }, [WASMData.livePayload.fuel]); const updateData = (_ZFWTarget?: number, _CGTarget?: number) => { CoherentCallZFWEntry(_ZFWTarget ?? ZFWTarget, _CGTarget ?? CGTarget); }; return ( <>
handleInput(e.target.value, WASMData.limits.maxFuel, setFuel)} disabled={loadingState !== 'preview' || gsxActive} />
handleInputZFW(e.target.value)} onBlur={(e) => handleBlur(e.target.value)} disabled={loadingState !== 'preview' || gsxActive} />
setCGTarget((prev) => { const _new = prev + 0.1; updateData(undefined, _new); return _new; }) } decrease={() => setCGTarget((prev) => { const _new = prev - 0.1; updateData(undefined, _new); return _new; }) } />
{ setLoadingState('loaded'); loadAircraft(); }} unload={() => { setLoadingState('preview'); unloadAircraft(); }} /> ); }; export default ZFWEntryF;