Files
ragflow/web/src/components/originui/number-input.tsx
balibabu afd3a508e5 Fix: Set the maximum number of rounds for the agent to 1 #3221 (#9238)
### What problem does this PR solve?

Fix: Fixed the issue where numbers could not be displayed in the numeric
input box under white theme #3221
Fix: Set the maximum number of rounds for the agent to 1 #3221

### Type of change


- [x] New Feature (non-breaking change which adds functionality)
2025-08-05 14:32:06 +08:00

93 lines
2.2 KiB
TypeScript

import { MinusIcon, PlusIcon } from 'lucide-react';
import React, { useEffect, useMemo, useState } from 'react';
interface NumberInputProps {
className?: string;
value?: number;
onChange?: (value: number) => void;
height?: number | string;
}
const NumberInput: React.FC<NumberInputProps> = ({
className,
value: initialValue,
onChange,
height,
}) => {
const [value, setValue] = useState<number>(() => {
return initialValue ?? 0;
});
useEffect(() => {
if (initialValue !== undefined) {
setValue(initialValue);
}
}, [initialValue]);
const handleDecrement = () => {
if (value > 0) {
setValue(value - 1);
onChange?.(value - 1);
}
};
const handleIncrement = () => {
setValue(value + 1);
onChange?.(value + 1);
};
const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => {
const newValue = Number(e.target.value);
if (!isNaN(newValue)) {
setValue(newValue);
onChange?.(newValue);
}
};
const handleInput = (e: React.ChangeEvent<HTMLInputElement>) => {
// If the input value is not a number, the input is not allowed
if (!/^\d*$/.test(e.target.value)) {
e.preventDefault();
}
};
const style = useMemo(
() => ({
height: height ? `${height.toString().replace('px', '')}px` : 'auto',
}),
[height],
);
return (
<div
className={`flex h-10 items-center space-x-2 border-[1px] rounded-lg w-[150px] ${className || ''}`}
style={style}
>
<button
type="button"
className="w-10 p-2 focus:outline-none border-r-[1px]"
onClick={handleDecrement}
style={style}
>
<MinusIcon size={16} aria-hidden="true" />
</button>
<input
type="text"
value={value}
onInput={handleInput}
onChange={handleChange}
className="w-full flex-1 text-center bg-transparent focus:outline-none"
style={style}
/>
<button
type="button"
className="w-10 p-2 focus:outline-none border-l-[1px]"
onClick={handleIncrement}
style={style}
>
<PlusIcon size={16} aria-hidden="true" />
</button>
</div>
);
};
export default NumberInput;