mirror of
https://github.com/ionic-team/ionic-framework.git
synced 2025-08-16 18:17:31 +08:00
34 lines
795 B
TypeScript
34 lines
795 B
TypeScript
import { Directive, ElementRef, HostListener } from '@angular/core';
|
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
|
|
import { ValueAccessor } from './value-accessor';
|
|
|
|
@Directive({
|
|
/* tslint:disable-next-line:directive-selector */
|
|
selector: 'ion-input[type=number]',
|
|
providers: [
|
|
{
|
|
provide: NG_VALUE_ACCESSOR,
|
|
useExisting: NumericValueAccessor,
|
|
multi: true
|
|
}
|
|
]
|
|
})
|
|
export class NumericValueAccessor extends ValueAccessor {
|
|
|
|
constructor(el: ElementRef) {
|
|
super(el);
|
|
}
|
|
|
|
@HostListener('ionChange', ['$event.target'])
|
|
_handleIonChange(el: any) {
|
|
this.handleChangeEvent(el, el.value);
|
|
}
|
|
|
|
registerOnChange(fn: (_: number | null) => void) {
|
|
super.registerOnChange(value => {
|
|
fn(value === '' ? null : parseFloat(value));
|
|
});
|
|
}
|
|
}
|