import { FC, useEffect, useState } from 'react'; import { LocalizeText, WiredFurniType } from '../../../../api'; import { Text } from '../../../../common'; import { useWired } from '../../../../hooks'; import { WiredActionBaseView } from './WiredActionBaseView'; import { WiredActionLayoutCode } from '../../../../api/wired/WiredActionLayoutCode'; import { WiredSourcesSelector } from '../WiredSourcesSelector'; export const WiredActionTeleportView: FC<{}> = props => { const { trigger = null, setIntParams = null } = useWired(); const isTeleportEffect = (trigger?.code === WiredActionLayoutCode.TELEPORT); const isUserToFurniEffect = (trigger?.code === WiredActionLayoutCode.USER_TO_FURNI); const [ fastTeleport, setFastTeleport ] = useState(() => { if(isTeleportEffect && trigger?.intData?.length >= 3) return (trigger.intData[0] === 1); return false; }); const [ walkMode, setWalkMode ] = useState(() => { if(isUserToFurniEffect && trigger?.intData?.length >= 3) return trigger.intData[2]; return 1; }); const [ furniSource, setFurniSource ] = useState(() => { if(isTeleportEffect && trigger?.intData?.length >= 3) return trigger.intData[1]; if(isUserToFurniEffect && trigger?.intData?.length >= 3) return trigger.intData[0]; if(trigger?.intData?.length >= 1) return trigger.intData[0]; return (trigger?.selectedItems?.length ?? 0) > 0 ? 100 : 0; }); const [ userSource, setUserSource ] = useState(() => { if(isTeleportEffect && trigger?.intData?.length >= 3) return trigger.intData[2]; if(isUserToFurniEffect && trigger?.intData?.length >= 3) return trigger.intData[1]; if(trigger?.intData?.length >= 2) return trigger.intData[1]; return 0; }); useEffect(() => { if(!trigger) return; if(isTeleportEffect && trigger.intData.length >= 3) { setFastTeleport(trigger.intData[0] === 1); setFurniSource(trigger.intData[1]); setUserSource(trigger.intData[2]); setWalkMode(1); return; } if(isUserToFurniEffect && trigger.intData.length >= 3) { setFastTeleport(false); setFurniSource(trigger.intData[0]); setUserSource(trigger.intData[1]); setWalkMode(trigger.intData[2]); return; } setFastTeleport(false); setWalkMode(1); if(trigger.intData.length >= 1) setFurniSource(trigger.intData[0]); else setFurniSource((trigger.selectedItems?.length ?? 0) > 0 ? 100 : 0); if(trigger.intData.length >= 2) setUserSource(trigger.intData[1]); else setUserSource(0); }, [ isTeleportEffect, isUserToFurniEffect, trigger ]); const onChangeFurniSource = (next: number) => setFurniSource(next); const save = () => setIntParams(isTeleportEffect ? [ fastTeleport ? 1 : 0, furniSource, userSource ] : (isUserToFurniEffect ? [ furniSource, userSource, walkMode ] : [ furniSource, userSource ])); const requiresFurni = WiredFurniType.STUFF_SELECTION_OPTION_BY_ID_BY_TYPE_OR_FROM_CONTEXT; return ( }> { isTeleportEffect &&
setFastTeleport(event.target.checked) } /> { LocalizeText('wiredfurni.params.teleport.options.0') }
} { isUserToFurniEffect &&
{ [ 0, 1, 2 ].map(option => ( )) }
}
); };