shlink-web-client/src/settings/RealTimeUpdatesSettings.tsx

55 lines
2 KiB
TypeScript
Raw Normal View History

import { FormGroup, Input } from 'reactstrap';
import classNames from 'classnames';
2020-07-14 17:05:00 +03:00
import ToggleSwitch from '../utils/ToggleSwitch';
import { SimpleCard } from '../utils/SimpleCard';
2022-03-05 16:04:01 +03:00
import { FormText } from '../utils/FormText';
2020-08-24 18:32:20 +03:00
import { Settings } from './reducers/settings';
2020-08-24 18:32:20 +03:00
interface RealTimeUpdatesProps {
settings: Settings;
toggleRealTimeUpdates: (enabled: boolean) => void;
setRealTimeUpdatesInterval: (interval: number) => void;
2020-08-24 18:32:20 +03:00
}
const intervalValue = (interval?: number) => !interval ? '' : `${interval}`;
const RealTimeUpdatesSettings = (
{ settings: { realTimeUpdates }, toggleRealTimeUpdates, setRealTimeUpdatesInterval }: RealTimeUpdatesProps,
) => (
<SimpleCard title="Real-time updates" className="h-100">
<FormGroup>
<ToggleSwitch checked={realTimeUpdates.enabled} onChange={toggleRealTimeUpdates}>
Enable or disable real-time updates.
2022-03-05 16:04:01 +03:00
<FormText>
Real-time updates are currently being <b>{realTimeUpdates.enabled ? 'processed' : 'ignored'}</b>.
2022-03-05 16:04:01 +03:00
</FormText>
</ToggleSwitch>
</FormGroup>
<FormGroup className="mb-0">
<label className={classNames({ 'text-muted': !realTimeUpdates.enabled })}>
Real-time updates frequency (in minutes):
</label>
<Input
type="number"
min={0}
placeholder="Immediate"
disabled={!realTimeUpdates.enabled}
value={intervalValue(realTimeUpdates.interval)}
onChange={({ target }) => setRealTimeUpdatesInterval(Number(target.value))}
/>
{realTimeUpdates.enabled && (
2022-03-05 16:04:01 +03:00
<FormText>
{realTimeUpdates.interval !== undefined && realTimeUpdates.interval > 0 && (
<span>
Updates will be reflected in the UI every <b>{realTimeUpdates.interval}</b> minute{realTimeUpdates.interval > 1 && 's'}.
</span>
)}
{!realTimeUpdates.interval && 'Updates will be reflected in the UI as soon as they happen.'}
2022-03-05 16:04:01 +03:00
</FormText>
)}
</FormGroup>
</SimpleCard>
);
export default RealTimeUpdatesSettings;