UNPKG

ack-angular

Version:

Extra special directives, components, providers and pipes to aide in tackling everyday interface development needs in Angular2

160 lines 19.1 kB
import { Component, Directive, Input, Output, EventEmitter } from "@angular/core"; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; export class EnterKey { constructor(element) { this.element = element; this.enterKey = new EventEmitter(); element.nativeElement.addEventListener('keydown', (event) => { var yesNo = [13, 10].indexOf(event.which || event.keyCode) >= 0; if (yesNo) { this.enterKey.emit(event); } }); } } EnterKey.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: EnterKey, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); EnterKey.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.4", type: EnterKey, selector: "[enterKey]", outputs: { enterKey: "enterKey" }, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: EnterKey, decorators: [{ type: Directive, args: [{ selector: '[enterKey]' }] }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { enterKey: [{ type: Output }] } }); export class EscapeKey { constructor(element) { this.element = element; this.escapeKey = new EventEmitter(); element.nativeElement.addEventListener('keydown', (event) => { const code = event.which || event.keyCode; if (code == 27) { this.escapeKey.emit(event); } }); } } EscapeKey.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: EscapeKey, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); EscapeKey.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.4", type: EscapeKey, selector: "[escapeKey]", outputs: { escapeKey: "escapeKey" }, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: EscapeKey, decorators: [{ type: Directive, args: [{ selector: '[escapeKey]' }] }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { escapeKey: [{ type: Output }] } }); /** Disallow keyboard access to the backspace key */ export class PreventBackKey { constructor(element) { this.element = element; this.preventBackKey = new EventEmitter(); element.nativeElement.addEventListener('keydown', (event) => { var yesNo = [8].indexOf(event.which || event.keyCode) < 0; if (!yesNo) { this.preventBackKey.emit(event); if (event.preventDefault) { event.preventDefault(); } } return yesNo; }); } } PreventBackKey.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: PreventBackKey, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); PreventBackKey.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.4", type: PreventBackKey, selector: "[preventBackKey]", outputs: { preventBackKey: "preventBackKey" }, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: PreventBackKey, decorators: [{ type: Directive, args: [{ selector: '[preventBackKey]' }] }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { preventBackKey: [{ type: Output }] } }); /** Disallow keyboard access to the enter keys */ export class PreventEnterKey { constructor(element) { this.element = element; this.preventEnterKey = new EventEmitter(); element.nativeElement.addEventListener('keydown', (event) => { var yesNo = [13, 10].indexOf(event.which || event.keyCode) < 0; if (!yesNo) { this.preventEnterKey.emit(event); if (event.preventDefault) { event.preventDefault(); } } return yesNo; }); } } PreventEnterKey.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: PreventEnterKey, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); PreventEnterKey.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.4", type: PreventEnterKey, selector: "[preventEnterKey]", outputs: { preventEnterKey: "preventEnterKey" }, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: PreventEnterKey, decorators: [{ type: Directive, args: [{ selector: '[preventEnterKey]' }] }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { preventEnterKey: [{ type: Output }] } }); export class InputHint { constructor() { this.hintStyle = { 'font-size': '75%', 'color': '#BBB' }; } } InputHint.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: InputHint, deps: [], target: i0.ɵɵFactoryTarget.Component }); InputHint.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.4", type: InputHint, selector: "input-hint", inputs: { hintStyle: "hintStyle" }, ngImport: i0, template: '<div style="position:relative;" [ngStyle]="hintStyle"><div style="position:absolute;top:0;width:100%"><ng-content></ng-content></div></div>', isInline: true, dependencies: [{ kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: InputHint, decorators: [{ type: Component, args: [{ selector: 'input-hint', template: '<div style="position:relative;" [ngStyle]="hintStyle"><div style="position:absolute;top:0;width:100%"><ng-content></ng-content></div></div>' }] }], propDecorators: { hintStyle: [{ type: Input }] } }); /** adds form element onchange listener via addEventListener('change') that calls formChanged scope argument */ export class FormChanged { constructor(element) { this.element = element; this.formChanged = new EventEmitter(); this.onChange = (event) => { this.formChanged.emit(event); }; element.nativeElement.addEventListener('change', this.onChange); } ngOnDestroy() { this.element.nativeElement.removeEventListener('change', this.onChange); } } FormChanged.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: FormChanged, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); FormChanged.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.4", type: FormChanged, selector: "[formChanged]", outputs: { formChanged: "formChanged" }, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: FormChanged, decorators: [{ type: Directive, args: [{ selector: '[formChanged]' //Also try : (formAlter) directive that watches the form "input" event }] }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { formChanged: [{ type: Output }] } }); /** when ever change or input form event triggered, bindings are called */ export class FormAlter { constructor(element) { this.element = element; this.formAlter = new EventEmitter(); this.onChange = (event) => { this.formAlter.emit(event); }; element.nativeElement.addEventListener('input', this.onChange); element.nativeElement.addEventListener('change', this.onChange); } ngOnDestroy() { this.element.nativeElement.removeEventListener('change', this.onChange); this.element.nativeElement.removeEventListener('input', this.onChange); } } FormAlter.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: FormAlter, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); FormAlter.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.4", type: FormAlter, selector: "[formAlter]", outputs: { formAlter: "formAlter" }, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: FormAlter, decorators: [{ type: Directive, args: [{ selector: '[formAlter]' }] }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { formAlter: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"declarations.short.js","sourceRoot":"","sources":["../../src/declarations.short.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Directive,\n  Input,\n  Output,\n  EventEmitter,\n  ElementRef\n} from \"@angular/core\"\n\n@Directive({selector:'[enterKey]'})\nexport class EnterKey{\n  @Output() enterKey:EventEmitter<Event> = new EventEmitter()\n  constructor(public element:ElementRef){\n    element.nativeElement.addEventListener('keydown', (event: any)=>{\n      var yesNo = [13,10].indexOf(event.which||event.keyCode)>=0\n      if(yesNo){\n        this.enterKey.emit(event)\n      }\n    })\n  }\n}\n\n@Directive({selector:'[escapeKey]'})\nexport class EscapeKey{\n  @Output() escapeKey:EventEmitter<Event> = new EventEmitter()\n\n  constructor(public element:ElementRef){\n    element.nativeElement.addEventListener('keydown', (event: any)=>{\n      const code = event.which||event.keyCode\n      if(code==27){\n        this.escapeKey.emit(event)\n      }\n    })\n  }\n}\n\n/** Disallow keyboard access to the backspace key */\n@Directive({selector:'[preventBackKey]'})\nexport class PreventBackKey {\n  @Output() preventBackKey = new EventEmitter()\n  constructor(public element:ElementRef){\n    element.nativeElement.addEventListener('keydown', (event: any)=>{\n      var yesNo = [8].indexOf(event.which||event.keyCode)<0\n      if(!yesNo){\n        this.preventBackKey.emit(event)\n        if(event.preventDefault){\n          event.preventDefault()\n        }\n      }\n      return yesNo\n    })\n  }\n}\n\n/** Disallow keyboard access to the enter keys */\n@Directive({selector:'[preventEnterKey]'})\nexport class PreventEnterKey{\n  @Output() preventEnterKey = new EventEmitter()\n  constructor(public element:ElementRef){\n    element.nativeElement.addEventListener('keydown', (event: any)=>{\n      var yesNo = [13,10].indexOf(event.which||event.keyCode)<0\n      if(!yesNo){\n        this.preventEnterKey.emit(event)\n        if(event.preventDefault){\n          event.preventDefault()\n        }\n      }\n      return yesNo\n    })\n  }\n}\n\n@Component({\n  selector:'input-hint',\n  template:'<div style=\"position:relative;\" [ngStyle]=\"hintStyle\"><div style=\"position:absolute;top:0;width:100%\"><ng-content></ng-content></div></div>'\n}) export class InputHint {\n  @Input() hintStyle = {'font-size':'75%','color':'#BBB'}\n}\n\n\n/** adds form element onchange listener via addEventListener('change') that calls formChanged scope argument */\n@Directive({\n  selector:'[formChanged]'//Also try : (formAlter) directive that watches the form \"input\" event\n}) export class FormChanged{\n  //static parameters = [[ElementRef]]\n  onChange: any\n\n  @Output() formChanged = new EventEmitter()\n\n  constructor(public element:ElementRef){\n    this.onChange = (event: Event)=>{\n      this.formChanged.emit(event)\n    }\n\n    element.nativeElement.addEventListener('change',this.onChange)\n  }\n\n  ngOnDestroy(){\n    this.element.nativeElement.removeEventListener('change',this.onChange)\n  }\n}\n\n/** when ever change or input form event triggered, bindings are called */\n@Directive({\n  selector:'[formAlter]'\n}) export class FormAlter{\n  //-static parameters = [[ElementRef]]\n  onChange: (Event: Event)=>void\n  @Output() formAlter:EventEmitter<Event> = new EventEmitter()\n\n  constructor(public element:ElementRef){\n    this.onChange = (event:Event)=>{\n      this.formAlter.emit(event)\n    }\n\n    element.nativeElement.addEventListener('input',this.onChange)\n    element.nativeElement.addEventListener('change',this.onChange)\n  }\n\n  ngOnDestroy(){\n    this.element.nativeElement.removeEventListener('change',this.onChange)\n    this.element.nativeElement.removeEventListener('input',this.onChange)\n  }\n}"]}