mirror of
https://github.com/prymitive/karma
synced 2026-05-09 03:36:44 +00:00
43 lines
1.1 KiB
TypeScript
43 lines
1.1 KiB
TypeScript
import React, { FC, useState } from "react";
|
|
|
|
import { Range } from "react-range";
|
|
|
|
import { Settings } from "Stores/Settings";
|
|
|
|
const FetchConfiguration: FC<{
|
|
settingsStore: Settings;
|
|
}> = ({ settingsStore }) => {
|
|
const [fetchInterval, setFetchInterval] = useState<number[]>([
|
|
settingsStore.fetchConfig.config.interval,
|
|
]);
|
|
|
|
const onChangeComplete = (value: number) => {
|
|
settingsStore.fetchConfig.setInterval(value);
|
|
};
|
|
|
|
return (
|
|
<div className="form-group mb-0 text-center">
|
|
<Range
|
|
step={10}
|
|
min={10}
|
|
max={120}
|
|
values={fetchInterval}
|
|
onChange={(values) => setFetchInterval(values)}
|
|
onFinalChange={(values) => onChangeComplete(values[0])}
|
|
renderTrack={({ props, children }) => (
|
|
<div className="input-range-track" {...props}>
|
|
{children}
|
|
</div>
|
|
)}
|
|
renderThumb={({ props }) => (
|
|
<div className="input-range-thumb" {...props}>
|
|
{fetchInterval}s
|
|
</div>
|
|
)}
|
|
/>
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export { FetchConfiguration };
|