import { FC, useEffect, useState } from 'react'; import { LocalizeText, WiredFurniType } from '../../../../api'; import { Text } from '../../../../common'; import { useWired } from '../../../../hooks'; import { WiredSourcesSelector } from '../WiredSourcesSelector'; import { WiredActionBaseView } from './WiredActionBaseView'; const COUNTER_INTERACTION_TYPES = [ 'game_upcounter' ]; const CONTROL_OPTIONS = [ { value: 0, label: 'wiredfurni.params.clock_control.0' }, { value: 1, label: 'wiredfurni.params.clock_control.1' }, { value: 2, label: 'wiredfurni.params.clock_control.2' }, { value: 3, label: 'wiredfurni.params.clock_control.3' }, { value: 4, label: 'wiredfurni.params.clock_control.4' } ]; const normalizeControl = (value: number) => { if(value < 0 || value > 4) return 0; return value; }; export const WiredActionControlClockView: FC<{}> = () => { const { trigger = null, setIntParams = null, setAllowedInteractionTypes = null, setAllowedInteractionErrorKey = null } = useWired(); const [ control, setControl ] = useState(0); const [ furniSource, setFurniSource ] = useState(() => { if(trigger?.intData?.length > 1) return trigger.intData[1]; return (trigger?.selectedItems?.length ?? 0) > 0 ? 100 : 0; }); const save = () => { setIntParams([ control, furniSource ]); }; useEffect(() => { if(!trigger) return; setControl((trigger.intData.length > 0) ? normalizeControl(trigger.intData[0]) : 0); setFurniSource((trigger.intData.length > 1) ? trigger.intData[1] : ((trigger.selectedItems?.length ?? 0) > 0 ? 100 : 0)); }, [ trigger ]); useEffect(() => { setAllowedInteractionTypes(COUNTER_INTERACTION_TYPES); setAllowedInteractionErrorKey('wiredfurni.error.require_counter_furni'); return () => { setAllowedInteractionTypes(null); setAllowedInteractionErrorKey(null); }; }, [ setAllowedInteractionErrorKey, setAllowedInteractionTypes ]); return ( }>
{ CONTROL_OPTIONS.map(option => { return (
setControl(option.value) } /> { LocalizeText(option.label) }
); }) }
); };