@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
JavaScript
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"]}