Skip to content

Commit

Permalink
disable mouse behaviour for input number
Browse files Browse the repository at this point in the history
  • Loading branch information
eperedo committed Aug 12, 2024
1 parent b6005c6 commit 7c8ffa4
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 0 deletions.
16 changes: 16 additions & 0 deletions src/webapp/reports/autogenerated-forms/AutogeneratedForm.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -174,6 +174,22 @@ function useDataFormInfo(): [
style.setAttribute("id", "disabled-arrows-css");
style.appendChild(document.createTextNode(css));
head.appendChild(style);

function disableScrollInputs() {
if (
window.document.activeElement instanceof HTMLInputElement &&
window.document.activeElement.type === "number" &&
window.document.activeElement.classList.contains("noscroll")
) {
window.document.activeElement.blur();
}
}

document.addEventListener("wheel", disableScrollInputs);

return () => {
document.removeEventListener("wheel", disableScrollInputs);
};
}, []);

useEffect(() => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,12 @@ const NumberWidget: React.FC<NumberWidgetProps> = props => {
[onValueChange, dataValue]
);

const onKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {
if (e.key === "ArrowUp" || e.key === "ArrowDown") {
e.preventDefault();
}
};

return (
<WidgetFeedback state={props.state}>
{disabled ? (
Expand All @@ -36,6 +42,8 @@ const NumberWidget: React.FC<NumberWidgetProps> = props => {
type="number"
onBlur={e => notifyChange({ value: e.target.value })}
defaultValue={dataValue.value}
onKeyDown={onKeyDown}
className="noscroll"
/>
)}
</WidgetFeedback>
Expand Down

0 comments on commit 7c8ffa4

Please sign in to comment.