2023-08-04 22:59:33 +02:00
|
|
|
import { LabeledFormGroup, SimpleCard, ToggleSwitch, useDomId } from '@shlinkio/shlink-frontend-kit';
|
|
|
|
import type { Settings } from '@shlinkio/shlink-web-component';
|
2020-09-09 19:16:04 +02:00
|
|
|
import classNames from 'classnames';
|
2023-02-18 11:11:01 +01:00
|
|
|
import { FormGroup, Input } from 'reactstrap';
|
2022-03-05 14:43:43 +01:00
|
|
|
import { FormText } from '../utils/forms/FormText';
|
2020-04-25 09:49:54 +02:00
|
|
|
|
2023-07-27 09:22:03 +02:00
|
|
|
type RealTimeUpdatesProps = {
|
2020-08-24 17:32:20 +02:00
|
|
|
settings: Settings;
|
2020-09-09 19:16:04 +02:00
|
|
|
toggleRealTimeUpdates: (enabled: boolean) => void;
|
|
|
|
setRealTimeUpdatesInterval: (interval: number) => void;
|
2023-07-27 09:22:03 +02:00
|
|
|
};
|
2020-04-25 09:49:54 +02:00
|
|
|
|
2022-03-26 12:17:42 +01:00
|
|
|
const intervalValue = (interval?: number) => (!interval ? '' : `${interval}`);
|
2020-09-09 19:16:04 +02:00
|
|
|
|
2022-05-28 10:47:39 +02:00
|
|
|
export const RealTimeUpdatesSettings = (
|
2023-07-27 09:22:03 +02:00
|
|
|
{ settings, toggleRealTimeUpdates, setRealTimeUpdatesInterval }: RealTimeUpdatesProps,
|
2022-06-06 22:23:21 +02:00
|
|
|
) => {
|
2023-07-27 09:22:03 +02:00
|
|
|
const { realTimeUpdates = { enabled: true } } = settings;
|
2022-06-06 22:23:21 +02:00
|
|
|
const inputId = useDomId();
|
|
|
|
|
|
|
|
return (
|
|
|
|
<SimpleCard title="Real-time updates" className="h-100">
|
|
|
|
<FormGroup>
|
|
|
|
<ToggleSwitch checked={realTimeUpdates.enabled} onChange={toggleRealTimeUpdates}>
|
|
|
|
Enable or disable real-time updates.
|
|
|
|
<FormText>
|
|
|
|
Real-time updates are currently being <b>{realTimeUpdates.enabled ? 'processed' : 'ignored'}</b>.
|
|
|
|
</FormText>
|
|
|
|
</ToggleSwitch>
|
|
|
|
</FormGroup>
|
|
|
|
<LabeledFormGroup
|
|
|
|
noMargin
|
|
|
|
label="Real-time updates frequency (in minutes):"
|
|
|
|
labelClassName={classNames('form-label', { 'text-muted': !realTimeUpdates.enabled })}
|
|
|
|
id={inputId}
|
|
|
|
>
|
|
|
|
<Input
|
|
|
|
type="number"
|
|
|
|
min={0}
|
|
|
|
placeholder="Immediate"
|
|
|
|
disabled={!realTimeUpdates.enabled}
|
|
|
|
value={intervalValue(realTimeUpdates.interval)}
|
|
|
|
id={inputId}
|
|
|
|
onChange={({ target }) => setRealTimeUpdatesInterval(Number(target.value))}
|
|
|
|
/>
|
|
|
|
{realTimeUpdates.enabled && (
|
|
|
|
<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.'}
|
|
|
|
</FormText>
|
|
|
|
)}
|
|
|
|
</LabeledFormGroup>
|
|
|
|
</SimpleCard>
|
|
|
|
);
|
|
|
|
};
|