Skip to content

Instantly share code, notes, and snippets.

@Muzammil-Bilwani
Created November 29, 2018 05:48
Show Gist options
  • Save Muzammil-Bilwani/e84fc077320f516fc0acabed8bf0e259 to your computer and use it in GitHub Desktop.
Save Muzammil-Bilwani/e84fc077320f516fc0acabed8bf0e259 to your computer and use it in GitHub Desktop.
Stop key events
@Directive({
// tslint:disable-next-line:directive-selector
selector: "[OnlyNumber]"
})
export class OnlyNumberDirective {
constructor(private el: ElementRef) { }
@Input() OnlyNumber: boolean;
@HostListener("keydown", ["$event"]) onKeyDown(event) {
const e = <KeyboardEvent>event;
if (this.OnlyNumber) {
if ([46, 8, 9, 27, 13, 110, 188].indexOf(e.keyCode) !== -1 ||
// Allow: Ctrl+A
(e.keyCode === 65 && (e.ctrlKey || e.metaKey)) ||
// Allow: Ctrl+C
(e.keyCode === 67 && (e.ctrlKey || e.metaKey)) ||
// Allow: Ctrl+V
(e.keyCode === 86 && (e.ctrlKey || e.metaKey)) ||
// Allow: Ctrl+X
(e.keyCode === 88 && (e.ctrlKey || e.metaKey)) ||
// Allow: home, end, left, right
(e.keyCode >= 35 && e.keyCode <= 39)) {
// let it happen, don't do anything
return;
}
// Ensure that it is a number and stop the keypress
if ((e.shiftKey || (e.keyCode < 48 || e.keyCode > 57)) && (e.keyCode < 96 || e.keyCode > 105)) {
e.preventDefault();
}
}
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment