From e5952e6cb6d71e3232d91ce01ae45dad229dc285 Mon Sep 17 00:00:00 2001 From: Luca Peruzzo Date: Fri, 22 Nov 2024 16:04:11 +0100 Subject: [PATCH] fix: handle otp keyboard filling Fixes #16373 --- packages/primeng/src/inputotp/inputotp.ts | 26 ++++++++++++++++------- 1 file changed, 18 insertions(+), 8 deletions(-) diff --git a/packages/primeng/src/inputotp/inputotp.ts b/packages/primeng/src/inputotp/inputotp.ts index 1e588e2ca4b..e1aaf37f274 100644 --- a/packages/primeng/src/inputotp/inputotp.ts +++ b/packages/primeng/src/inputotp/inputotp.ts @@ -69,7 +69,7 @@ export interface InputOtpInputTemplateContext { type="text" pInputText [value]="getModelValue(i)" - [maxLength]="1" + [maxLength]="i === 1 ? length : 1" [type]="inputType" class="p-inputotp-input" [size]="size" @@ -213,7 +213,13 @@ export class InputOtp extends BaseComponent implements AfterContentInit { } onInput(event, index) { - this.tokens[index] = event.target.value; + const value = event.target.value; + if (index === 0 && value.length > 1) { + this.handleOnPaste(value, event); + event.stopPropagation(); + return; + } + this.tokens[index] = value; this.updateModel(event); if (event.inputType === 'deleteContentBackward') { @@ -367,18 +373,22 @@ export class InputOtp extends BaseComponent implements AfterContentInit { let paste = event.clipboardData.getData('text'); if (paste.length) { - let pastedCode = paste.substring(0, this.length + 1); - - if (!this.integerOnly || !isNaN(pastedCode)) { - this.tokens = pastedCode.split(''); - this.updateModel(event); - } + this.handleOnPaste(paste, event); } event.preventDefault(); } } + handleOnPaste(paste, event) { + let pastedCode = paste.substring(0, this.length + 1); + + if (!this.integerOnly || !isNaN(pastedCode)) { + this.tokens = pastedCode.split(''); + this.updateModel(event); + } + } + getRange(n: number): number[] { return Array.from({ length: n }, (_, index) => index + 1); }