UNPKG

@anjuna/angular-core

Version:

<p align="center"> <img src="//cdn.zuora.com/theme/0.6.0/assets/anjuna/anjuna-logo.svg"/> <br/><br/> </p>

172 lines 19 kB
import { __decorate, __metadata, __param } from "tslib"; import { AfterViewInit, ChangeDetectorRef, Directive, ElementRef, EventEmitter, HostBinding, HostListener, Inject, Injector, Input, LOCALE_ID, OnChanges, OnInit, Optional, Output, Self } from '@angular/core'; import { FormArray, ControlValueAccessor, FormControl, NgForm, FormGroupDirective, NgControl, NG_VALUE_ACCESSOR, NgModel } from '@angular/forms'; /* tslint:disable:directive-selector */ var ListValueDirective = /** @class */ (function () { function ListValueDirective(_element, changeRef, parentForm, parentGroup, ngControl) { this._element = _element; this.changeRef = changeRef; this.ngControl = ngControl; this.valueChange = new EventEmitter(); this.onChange = function () { }; this.onTouch = function () { }; this.parent = parentForm ? parentForm : parentGroup ? parentGroup : null; if (this.ngControl) { this.ngControl.valueAccessor = this; } } Object.defineProperty(ListValueDirective.prototype, "parsedField", { get: function () { return (this.field) ? this.field.parsedList : undefined; }, enumerable: true, configurable: true }); Object.defineProperty(ListValueDirective.prototype, "list", { get: function () { if (!this._list) { this.list = this._element.nativeElement; } return this._list; }, set: function (el) { this._list = el; }, enumerable: true, configurable: true }); ListValueDirective.prototype.onAnjBlur = function () { this.onTouch(); }; ListValueDirective.prototype.onAnjChange = function (target) { if (!target.matches('anj-list')) { return; } this.changeHandler(target.value.slice(0)); }; Object.defineProperty(ListValueDirective.prototype, "isInvalid", { get: function () { if (this.ngControl) { var isSubmitted = (this.parent && this.parent.submitted); return (this.ngControl.invalid && (this.ngControl.touched || isSubmitted)); } if (this.control) { return this.control.invalid; } }, enumerable: true, configurable: true }); ListValueDirective.prototype.ngAfterViewInit = function () { if ((this.ngControl && this.ngControl.value) || this.ngModel) { this.value = this.ngModel || this.ngControl.value; this.list.value = this.value; this.changeRef.detectChanges(); } }; ListValueDirective.prototype.ngOnChanges = function () { this.setAttributes(); if (this.control && this.control.value) { this.value = this.control.value; this.list.value = this.value; this.changeRef.detectChanges(); } }; ListValueDirective.prototype.setAttributes = function () { if (this.field) { this.list.setAttribute('min', this.field.minItems || this.list.min); this.list.setAttribute('max', this.field.maxItems || this.list.max); } if (this.parsedField) { this.list.setAttribute('options', this.parsedField.options || this.list.options); this.list.setAttribute('type', this.parsedField.toInputType() || this.list.type); } }; // Start: ControlValueAccessor requirements ListValueDirective.prototype.writeValue = function (newValue) { this.value = newValue; this.list.value = this.value; }; ListValueDirective.prototype.registerOnChange = function (fn) { this.onChange = fn; }; ListValueDirective.prototype.registerOnTouched = function (fn) { this.onTouch = fn; }; // End: ControlValueAccessor requirements ListValueDirective.prototype.changeHandler = function (changedVal) { this.onTouch(); this.value = changedVal; this.valueChange.emit(this.value); this.propogateValueChange(); }; ListValueDirective.prototype.propogateValueChange = function () { var _this = this; if (this.ngControl) { this.ngControl.control.patchValue(this.value); } else if (this.control) { this.control.controls = []; this.value.map(function (value) { return _this.control.push(new FormControl(value)); }); } this.changeRef.detectChanges(); }; ListValueDirective.ctorParameters = function () { return [ { type: ElementRef }, { type: ChangeDetectorRef }, { type: NgForm, decorators: [{ type: Optional }] }, { type: FormGroupDirective, decorators: [{ type: Optional }] }, { type: NgControl, decorators: [{ type: Optional }, { type: Self }] } ]; }; __decorate([ Input(), __metadata("design:type", NgModel) ], ListValueDirective.prototype, "ngModel", void 0); __decorate([ Input(), __metadata("design:type", Object) ], ListValueDirective.prototype, "control", void 0); __decorate([ Input(), __metadata("design:type", Object) ], ListValueDirective.prototype, "field", void 0); __decorate([ Output(), __metadata("design:type", EventEmitter) ], ListValueDirective.prototype, "valueChange", void 0); __decorate([ HostListener('anjBlur'), __metadata("design:type", Function), __metadata("design:paramtypes", []), __metadata("design:returntype", void 0) ], ListValueDirective.prototype, "onAnjBlur", null); __decorate([ HostListener('anjChange', ['$event.target']), __metadata("design:type", Function), __metadata("design:paramtypes", [HTMLInputElement]), __metadata("design:returntype", void 0) ], ListValueDirective.prototype, "onAnjChange", null); __decorate([ HostBinding('attr.invalid'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], ListValueDirective.prototype, "isInvalid", null); ListValueDirective = __decorate([ Directive({ selector: 'anj-list' }), __param(2, Optional()), __param(3, Optional()), __param(4, Optional()), __param(4, Self()), __metadata("design:paramtypes", [ElementRef, ChangeDetectorRef, NgForm, FormGroupDirective, NgControl]) ], ListValueDirective); return ListValueDirective; }()); export { ListValueDirective }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-value.directive.js","sourceRoot":"ng://@anjuna/angular-core/","sources":["lib/forms/directives/list-value.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener, Inject, Injector,\n    Input, LOCALE_ID,\n    OnChanges, OnInit, Optional, Output, Self\n} from '@angular/core';\nimport {\n    FormArray,\n    ControlValueAccessor,\n    FormControl, NgForm, FormGroupDirective, NgControl, NG_VALUE_ACCESSOR, NgModel\n} from '@angular/forms';\nimport { ValueAccessor } from './value-accessor';\nimport { TIME_MERIDIEM } from '../interfaces/Tokens';\n\n/* tslint:disable:directive-selector */\n@Directive({\n    selector: 'anj-list'\n})\nexport class ListValueDirective implements AfterViewInit, ControlValueAccessor, OnChanges {\n    private _list;\n    private readonly parent: NgForm | FormGroupDirective | null;\n\n    public value: string[];\n\n    get parsedField() {\n        return (this.field) ? this.field.parsedList : undefined;\n    }\n\n    get list() {\n        if (!this._list) {\n            this.list = this._element.nativeElement;\n        }\n        return this._list;\n    }\n    set list(el) {\n        this._list = el;\n    }\n\n    @Input() ngModel: NgModel;\n    @Input() public control: any;\n    @Input() public field: any;\n\n    @Output() public readonly valueChange: EventEmitter<any> = new EventEmitter<any>();\n\n    @HostListener('anjBlur')\n    onAnjBlur() {\n        this.onTouch();\n    }\n\n    @HostListener('anjChange', ['$event.target'])\n    public onAnjChange(target: HTMLInputElement) {\n\n        if (!target.matches('anj-list')) {\n            return;\n        }\n\n        this.changeHandler(target.value.slice(0));\n    }\n\n    @HostBinding('attr.invalid') get isInvalid(): boolean {\n        if (this.ngControl) {\n            const isSubmitted = (this.parent && this.parent.submitted);\n            return (this.ngControl.invalid && (this.ngControl.touched || isSubmitted));\n        }\n\n        if (this.control) {\n            return this.control.invalid;\n        }\n    }\n\n    constructor(private _element: ElementRef,\n                private changeRef: ChangeDetectorRef,\n                @Optional() parentForm: NgForm,\n                @Optional() parentGroup: FormGroupDirective,\n                @Optional() @Self() private ngControl?: NgControl) {\n        this.parent = parentForm ? parentForm : parentGroup ? parentGroup : null;\n\n        if (this.ngControl) {\n            this.ngControl.valueAccessor = this;\n        }\n    }\n\n    ngAfterViewInit() {\n        if ((this.ngControl && this.ngControl.value) || this.ngModel) {\n            this.value = this.ngModel || this.ngControl.value;\n            this.list.value = this.value;\n\n            this.changeRef.detectChanges();\n        }\n    }\n\n    ngOnChanges() {\n        this.setAttributes();\n\n        if (this.control && this.control.value) {\n            this.value = this.control.value;\n            this.list.value = this.value;\n\n            this.changeRef.detectChanges();\n        }\n    }\n\n    setAttributes() {\n        if (this.field) {\n            this.list.setAttribute('min', this.field.minItems || this.list.min);\n            this.list.setAttribute('max', this.field.maxItems || this.list.max);\n        }\n\n        if (this.parsedField) {\n            this.list.setAttribute('options', this.parsedField.options || this.list.options);\n            this.list.setAttribute('type', this.parsedField.toInputType() || this.list.type);\n        }\n    }\n\n    // Start: ControlValueAccessor requirements\n    public writeValue(newValue: any): void {\n        this.value = newValue;\n        this.list.value = this.value;\n    }\n\n    public onChange: (value: any) => void = () => {/**/};\n    public onTouch: () => void = () => {/**/};\n\n    public registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n\n    public registerOnTouched(fn: any): void {\n        this.onTouch = fn;\n    }\n    // End: ControlValueAccessor requirements\n\n    private changeHandler(changedVal): void {\n        this.onTouch();\n        this.value = changedVal;\n\n        this.valueChange.emit(this.value);\n        this.propogateValueChange();\n    }\n\n    private propogateValueChange(): void {\n        if (this.ngControl) {\n            this.ngControl.control.patchValue(this.value);\n        } else if (this.control) {\n            this.control.controls = [];\n            this.value.map(value =>\n                this.control.push(new FormControl(value))\n            );\n        }\n\n        this.changeRef.detectChanges();\n    }\n}\n"]}