import { FC, useEffect, useState } from 'react'; import { LocalizeText, WiredFurniType, WiredSelectionVisualizer } from '../../../../api'; import { Text } from '../../../../common'; import { useWired } from '../../../../hooks'; import { WiredConditionBaseView } from './WiredConditionBaseView'; import { WiredSourcesSelector } from '../WiredSourcesSelector'; export const WiredConditionFurniHasFurniOnView: FC<{}> = props => { const [ requireAll, setRequireAll ] = useState(-1); const { trigger = null, furniIds = [], setFurniIds = null, setIntParams = null } = useWired(); const [ furniSource, setFurniSource ] = useState(() => { if(trigger?.intData?.length > 1) return trigger.intData[1]; return (trigger?.selectedItems?.length ?? 0) > 0 ? 100 : 0; }); const save = () => setIntParams([ requireAll, furniSource ]); useEffect(() => { setRequireAll((trigger.intData.length > 0) ? trigger.intData[0] : 0); if(trigger.intData.length > 1) setFurniSource(trigger.intData[1]); else setFurniSource((trigger.selectedItems?.length ?? 0) > 0 ? 100 : 0); }, [ trigger ]); const onChangeFurniSource = (next: number) => { if(furniIds.length && setFurniIds) { setFurniIds(prev => { if(prev && prev.length) WiredSelectionVisualizer.clearSelectionShaderFromFurni(prev); return []; }); } setFurniSource(next); }; const requiresFurni = (furniSource === 100) ? WiredFurniType.STUFF_SELECTION_OPTION_BY_ID : WiredFurniType.STUFF_SELECTION_OPTION_NONE; return ( }>
{ LocalizeText('wiredfurni.params.requireall') } { [ 0, 1 ].map(value => { return (
setRequireAll(value) } /> { LocalizeText('wiredfurni.params.requireall.' + value) }
); }) }
); };