Skip to content

Commit

Permalink
Fix primefaces#2849: InputNumber spinner touch events
Browse files Browse the repository at this point in the history
  • Loading branch information
melloware committed May 5, 2022
1 parent f9fab4b commit 359f2b7
Showing 1 changed file with 32 additions and 2 deletions.
34 changes: 32 additions & 2 deletions components/lib/inputnumber/InputNumber.js
Original file line number Diff line number Diff line change
Expand Up @@ -189,6 +189,13 @@ export const InputNumber = React.memo(React.forwardRef((props, ref) => {
}
}

const onUpButtonTouchStart = (event) => {
if (!props.disabled && !props.readOnly) {
repeat(event, null, 1);
event.preventDefault();
}
}

const onUpButtonMouseDown = (event) => {
if (!props.disabled && !props.readOnly) {
inputRef.current.focus();
Expand All @@ -197,6 +204,13 @@ export const InputNumber = React.memo(React.forwardRef((props, ref) => {
}
}

const onUpButtonTouchEnd = () => {
if (!props.disabled && !props.readOnly) {
clearTimer();
event.preventDefault();
}
}

const onUpButtonMouseUp = () => {
if (!props.disabled && !props.readOnly) {
clearTimer();
Expand All @@ -221,6 +235,20 @@ export const InputNumber = React.memo(React.forwardRef((props, ref) => {
}
}

const onDownButtonTouchStart = (event) => {
if (!props.disabled && !props.readOnly) {
repeat(event, null, -1);
event.preventDefault();
}
}

const onDownButtonTouchEnd = () => {
if (!props.disabled && !props.readOnly) {
clearTimer();
event.preventDefault();
}
}

const onDownButtonMouseDown = (event) => {
if (!props.disabled && !props.readOnly) {
inputRef.current.focus();
Expand Down Expand Up @@ -953,7 +981,8 @@ export const InputNumber = React.memo(React.forwardRef((props, ref) => {

return (
<button type="button" className={className} onMouseLeave={onUpButtonMouseLeave} onMouseDown={onUpButtonMouseDown} onMouseUp={onUpButtonMouseUp}
onKeyDown={onUpButtonKeyDown} onKeyUp={onUpButtonKeyUp} disabled={props.disabled} tabIndex={-1}>
onKeyDown={onUpButtonKeyDown} onKeyUp={onUpButtonKeyUp} onTouchStart={onUpButtonTouchStart} onTouchEnd={onUpButtonTouchEnd}
disabled={props.disabled} tabIndex={-1}>
<span className={icon}></span>
<Ripple />
</button>
Expand All @@ -968,7 +997,8 @@ export const InputNumber = React.memo(React.forwardRef((props, ref) => {

return (
<button type="button" className={className} onMouseLeave={onDownButtonMouseLeave} onMouseDown={onDownButtonMouseDown} onMouseUp={onDownButtonMouseUp}
onKeyDown={onDownButtonKeyDown} onKeyUp={onDownButtonKeyUp} disabled={props.disabled} tabIndex={-1}>
onKeyDown={onDownButtonKeyDown} onKeyUp={onDownButtonKeyUp} onTouchStart={onDownButtonTouchStart} onTouchEnd={onDownButtonTouchEnd}
disabled={props.disabled} tabIndex={-1}>
<span className={icon}></span>
<Ripple />
</button>
Expand Down

0 comments on commit 359f2b7

Please sign in to comment.