mirror of
https://github.com/duckietm/Nitro-Cool-UI.git
synced 2025-06-21 22:36:58 +00:00
43 lines
1.7 KiB
TypeScript
43 lines
1.7 KiB
TypeScript
import { FC, useEffect, useState } from 'react';
|
|
import ReactSlider from 'react-slider';
|
|
import { GetConfiguration, LocalizeText, WiredFurniType } from '../../../../api';
|
|
import { Column, Slider, Text } from '../../../../common';
|
|
import { useWired } from '../../../../hooks';
|
|
import { WiredActionBaseView } from './WiredActionBaseView';
|
|
|
|
export const WiredActionMuteUserView: FC<{}> = props =>
|
|
{
|
|
const [ time, setTime ] = useState(-1);
|
|
const [ message, setMessage ] = useState('');
|
|
const { trigger = null, setIntParams = null, setStringParam = null } = useWired();
|
|
|
|
const save = () =>
|
|
{
|
|
setIntParams([ time ]);
|
|
setStringParam(message);
|
|
}
|
|
|
|
useEffect(() =>
|
|
{
|
|
setTime((trigger.intData.length > 0) ? trigger.intData[0] : 0);
|
|
setMessage(trigger.stringData);
|
|
}, [ trigger ]);
|
|
|
|
return (
|
|
<WiredActionBaseView requiresFurni={ WiredFurniType.STUFF_SELECTION_OPTION_NONE } hasSpecialInput={ true } save={ save }>
|
|
<Column gap={ 1 }>
|
|
<Text bold>{ LocalizeText('wiredfurni.params.length.minutes', [ 'minutes' ], [ time.toString() ]) }</Text>
|
|
<Slider
|
|
min={ 1 }
|
|
max={ 10 }
|
|
value={ time }
|
|
onChange={ event => setTime(event) } />
|
|
</Column>
|
|
<Column gap={ 1 }>
|
|
<Text bold>{ LocalizeText('wiredfurni.params.message') }</Text>
|
|
<input type="text" className="form-control form-control-sm" value={ message } onChange={ event => setMessage(event.target.value) } maxLength={ GetConfiguration<number>('wired.action.mute.user.max.length', 100) } />
|
|
</Column>
|
|
</WiredActionBaseView>
|
|
);
|
|
}
|