import { FC, useEffect, useState } from 'react'; import { LoadingState } from '../../types/general'; import { WASMDataPax } from '../../types/WASMData'; import { CoherentCallStationEntryPax, inRangeOf, loadAircraft, unloadAircraft } from '../../utils/utils'; import ActionBar from '../actionbar/ActionBar'; import Input from '../input/Input'; interface StationEntryProps { WASMData: WASMDataPax; loadingState: LoadingState; gsxActive: boolean; setLoadingState: (newState: LoadingState) => void; } const StationEntryPax: FC = ({ WASMData, loadingState, gsxActive, setLoadingState }) => { const [business1, setBusiness1] = useState(WASMData.targetPayload.business1); const [business2, setBusiness2] = useState(WASMData.targetPayload.business2); const [economy1, setEconomy1] = useState(WASMData.targetPayload.economy1); const [economy2, setEconomy2] = useState(WASMData.targetPayload.economy2); const [forwardCargo, setForwardCargo] = useState(WASMData.targetPayload.forwardCargo); const [rearCargo, setRearCargo] = useState(WASMData.targetPayload.rearCargo); const [fuel, setFuel] = useState(Math.round(WASMData.livePayload.fuel)); const [fuelEnabled, setFuelEnabled] = useState(true); const ZFW = () => { if (loadingState !== 'loaded' && !gsxActive) return Math.round(WASMData.targetPayload.total); 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 updateData = () => { CoherentCallStationEntryPax(business1, business2, economy1, economy2, forwardCargo, rearCargo); }; useEffect(() => updateData(), [business1, business2, economy1, economy2, forwardCargo, rearCargo]); 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]); return ( <>
handleInput(value, WASMData.limits.maxFuel, setFuel)} disabled={loadingState !== 'preview' || gsxActive} />
handleInput(value, WASMData.limits.business1, setBusiness1)} disabled={loadingState !== 'preview' || gsxActive} />
handleInput(value, WASMData.limits.business2, setBusiness2)} disabled={loadingState !== 'preview' || gsxActive} />
handleInput(value, WASMData.limits.economy1, setEconomy1)} disabled={loadingState !== 'preview' || gsxActive} />
handleInput(value, WASMData.limits.economy2, setEconomy2)} disabled={loadingState !== 'preview' || gsxActive} />
handleInput(value, WASMData.limits.forwardCargo, setForwardCargo)} disabled={loadingState !== 'preview' || gsxActive} />
handleInput(value, WASMData.limits.rearCargo, setRearCargo)} disabled={loadingState !== 'preview' || gsxActive} />
{ setLoadingState('loaded'); loadAircraft(); }} unload={() => { setLoadingState('preview'); unloadAircraft(); }} /> ); }; export default StationEntryPax;