Skip to content

Commit

Permalink
fix(input): adiciona indicacao visual de campo invalido
Browse files Browse the repository at this point in the history
 adiciona indicacao visual de campo invalido no `po-input`

 Fixes 7479
  • Loading branch information
anliben committed Sep 19, 2023
1 parent 323dff2 commit db03c5c
Show file tree
Hide file tree
Showing 4 changed files with 63 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -101,7 +101,8 @@ describe('PoInputGeneric:', () => {
objMask: {
keydown: (value: any) => {}
},
eventOnBlur: e => {}
eventOnBlur: e => {},
validateClassesForMask: (value: boolean) => {}
};
spyOn(fakeThis.objMask, 'keydown');
component.onKeydown.call(fakeThis, fakeEvent);
Expand Down Expand Up @@ -644,6 +645,35 @@ describe('PoInputGeneric:', () => {
expect(component.el.nativeElement.classList).not.toContain('ng-invalid');
});

it('validateClassesForMask: should add invalid classes if maskValid validation failed.', fakeAsync((): void => {
const fakeThis = {
inputEl: {
nativeElement: {
value: undefined
}
},
el: {
nativeElement: {
classList: {
add: value => {},
get: 'ng-invalid ng-dirty'
}
}
},
mask: '99999-999',
validMask: false,
objMask: {
getValidMask: true
}
};

component.validateClassesForMask.call(fakeThis);
tick(200);

expect(fakeThis.el.nativeElement.classList.get).toContain('ng-invalid');
expect(fakeThis.el.nativeElement.classList.get).toContain('ng-dirty');
}));

it('controlChangeEmitter: should emit change with input value if input value changes', fakeAsync((): void => {
const inputValue = 'value';

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,12 +22,16 @@ export abstract class PoInputGeneric extends PoInputBaseComponent implements Aft
super(cd);

this.el = el;
this.validateClassesForMask(this.objMask.getValidMask);
}

@HostListener('keydown', ['$event']) onKeydown(e: any) {
if (this.mask && !this.readonly && e.target.keyCode !== 229) {
this.eventOnBlur(e);
this.objMask.keydown(e);
if (!this.required) {
this.validateClassesForMask(this.objMask.getValidMask);
}
}
}

Expand Down Expand Up @@ -166,6 +170,20 @@ export abstract class PoInputGeneric extends PoInputBaseComponent implements Aft
}
}

validateClassesForMask(validMask) {
const element = this.el.nativeElement;
setTimeout(() => {
const elementValue = this.inputEl.nativeElement.value;

if (!elementValue && !validMask && this.objMask.getValidMask) {
element.classList.add('ng-invalid');
element.classList.add('ng-dirty');
} else {
element.classList.remove('ng-invalid');
}
}, 200);
}

verifyPattern(pattern: string, value: any) {
return new RegExp(pattern).test(value);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -343,7 +343,9 @@ export abstract class PoInputBaseComponent implements ControlValueAccessor, Vali
}
}

constructor(private cd?: ChangeDetectorRef) {}
constructor(private cd?: ChangeDetectorRef) {
this.objMask = new PoMask(this.mask, this.maskFormatModel);
}

callOnChange(value: any) {
this.updateModel(value);
Expand Down
11 changes: 11 additions & 0 deletions projects/ui/src/lib/components/po-field/po-input/po-mask.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,15 @@ export class PoMask {
// controle de posição
initialPosition: number = 0;
finalPosition: number = 0;
validMask: boolean = false;

get getValidMask(): boolean {
return this.validMask;
}

set setValidMask(value: boolean) {
this.validMask = value;
}

pattern: string = '';
get getPattern(): string {
Expand Down Expand Up @@ -352,6 +361,7 @@ export class PoMask {
this.valueToInput = valueProcessed;
this.valueToModel = this.removeFormattingValue(valueProcessed);
}
this.setValidMask = true;
return valueProcessed;
}
// verifica se tem algum caracter de mascara antes do cursor
Expand Down Expand Up @@ -428,6 +438,7 @@ export class PoMask {
// Remove a formatacão do valor
// É possível ser melhorado para remover pontualmente os caracteres fixos de acordo com a máscara
removeFormattingValue(value: string) {
this.setValidMask = false;
return value.replace(this.getFixedCharacterGuide(), '');
}

Expand Down

0 comments on commit db03c5c

Please sign in to comment.