@junte/ui
Version:
Quality Angular UI components kit
211 lines • 22.1 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { animate, state, style, transition, trigger } from '@angular/animations';
import { Component, ContentChild, ContentChildren, EventEmitter, HostBinding, HostListener, Input, Output, QueryList, TemplateRef } from '@angular/core';
import { FormArray, FormGroup } from '@angular/forms';
import { NGXLogger } from 'ngx-logger';
import { MethodApi, PropertyApi } from '../../core/decorators/api';
import { Height } from '../../core/enums/height';
import { State } from '../../core/enums/state';
import { UI } from '../../core/enums/ui';
import { FormControlComponent } from './control/form-control.component';
var FormComponent = /** @class */ (function () {
function FormComponent(logger) {
this.logger = logger;
this.host = 'jnt-form-host';
this.ui = UI;
this._state = { success: false };
this._height = Height.default;
this.submitted = new EventEmitter();
this.checked = new EventEmitter();
}
Object.defineProperty(FormComponent.prototype, "height", {
set: function (height) {
this._height = height || Height.default;
},
enumerable: true,
configurable: true
});
FormComponent.prototype.success = function () {
var _this = this;
this._state.success = true;
setTimeout(function () { return _this._state.success = false; }, 2100);
};
FormComponent.prototype.ngOnInit = function () {
var _this = this;
if (!!this.form) {
this.form.statusChanges.subscribe(function () {
_this.render();
_this.checked.emit(_this.check(_this.form));
});
}
};
FormComponent.prototype.render = function () {
this.logger.debug('render form');
if (!!this.controls) {
this.controls.filter(function (component) { return !!component.name && !!component.messages.length; })
.forEach(function (component) { return component.check(); });
}
};
FormComponent.prototype.check = function (form) {
this.logger.debug('check form');
var errors = [];
for (var key in form.controls) {
var control = form.controls[key];
if (control instanceof FormGroup || control instanceof FormArray) {
errors = errors.concat(this.check(control));
}
else {
if (!!control.errors && control.dirty) {
errors.push(control);
}
}
}
this.logger.debug('controls have errors = ', errors.map(function (e) { return e.name; }));
return errors;
};
/**
* @deprecated please use submit() instead
*/
FormComponent.prototype.onSubmit = function () {
this.submit();
};
FormComponent.prototype.submit = function () {
this.logger.debug('submit form');
if (!!this.form) {
this.validate(this.form);
if (this.form.valid) {
this.submitted.emit();
this.refresh(this.form);
}
}
};
FormComponent.prototype.validate = function (form) {
this.logger.debug('validate form');
for (var key in form.controls) {
var control = form.controls[key];
if (control instanceof FormGroup || control instanceof FormArray) {
this.validate(control);
}
else {
control.markAsDirty();
control.updateValueAndValidity({ emitEvent: false });
}
}
this.render();
this.checked.emit(this.check(this.form));
};
FormComponent.prototype.refresh = function (form) {
this.logger.debug('refresh form');
for (var key in form.controls) {
var control = form.controls[key];
if (control instanceof FormGroup || control instanceof FormArray) {
this.refresh(control);
}
else {
control.markAsPristine();
}
}
};
FormComponent.ctorParameters = function () { return [
{ type: NGXLogger }
]; };
__decorate([
HostBinding('attr.host'),
__metadata("design:type", Object)
], FormComponent.prototype, "host", void 0);
__decorate([
HostBinding('attr.data-height'),
__metadata("design:type", String)
], FormComponent.prototype, "_height", void 0);
__decorate([
PropertyApi({
description: 'Name form group',
type: 'FormGroup',
}),
Input('formGroup'),
__metadata("design:type", FormGroup)
], FormComponent.prototype, "form", void 0);
__decorate([
PropertyApi({
description: 'Title for form',
type: 'string',
}),
Input(),
__metadata("design:type", String)
], FormComponent.prototype, "title", void 0);
__decorate([
PropertyApi({
description: 'State of form',
path: 'ui.state',
options: [State.error, State.loading]
}),
Input(),
__metadata("design:type", String)
], FormComponent.prototype, "state", void 0);
__decorate([
PropertyApi({
description: 'Height of form',
path: 'ui.height',
options: [Height.default, Height.fluid],
default: Height.default
}),
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], FormComponent.prototype, "height", null);
__decorate([
ContentChild('formTitleTemplate'),
__metadata("design:type", TemplateRef)
], FormComponent.prototype, "titleTemplate", void 0);
__decorate([
ContentChild('formFooterTemplate'),
__metadata("design:type", TemplateRef)
], FormComponent.prototype, "footerTemplate", void 0);
__decorate([
ContentChildren(FormControlComponent, { descendants: true }),
__metadata("design:type", QueryList)
], FormComponent.prototype, "controls", void 0);
__decorate([
Output(),
__metadata("design:type", Object)
], FormComponent.prototype, "submitted", void 0);
__decorate([
Output(),
__metadata("design:type", Object)
], FormComponent.prototype, "checked", void 0);
__decorate([
MethodApi({ description: 'show success animation' }),
__metadata("design:type", Function),
__metadata("design:paramtypes", []),
__metadata("design:returntype", void 0)
], FormComponent.prototype, "success", null);
__decorate([
HostListener('submit'),
__metadata("design:type", Function),
__metadata("design:paramtypes", []),
__metadata("design:returntype", void 0)
], FormComponent.prototype, "submit", null);
FormComponent = __decorate([
Component({
selector: 'jnt-form',
template: "<form child-of=\"jnt-form-host\" >\n <header child-of=\"jnt-form-host\" *ngIf=\"!!title || !!titleTemplate\">\n <h3 child-of=\"jnt-form-host\" *ngIf=\"!!title && !titleTemplate\">{{title}}</h3>\n <ng-container *ngIf=\"!!titleTemplate\">\n <ng-container *ngTemplateOutlet=\"titleTemplate\"></ng-container>\n </ng-container>\n </header>\n\n <div child-of=\"jnt-form-host\" data-content>\n <ng-content></ng-content>\n </div>\n\n <footer child-of=\"jnt-form-host\" *ngIf=\"!!footerTemplate\">\n <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\n </footer>\n\n <div child-of=\"jnt-form-host\" data-loading *ngIf=\"state === ui.state.loading\">\n <jnt-spinner child-of=\"jnt-form-host\" [size]=\"ui.size.large\"></jnt-spinner>\n </div>\n <div child-of=\"jnt-form-host\" data-error *ngIf=\"state === ui.state.error\">\n <jnt-icon child-of=\"jnt-form-host\" [icon]=\"ui.icons.sad\"></jnt-icon>\n </div>\n <div child-of=\"jnt-form-host\" data-success *ngIf=\"_state.success\" [@success]=\"_state.success\">\n <jnt-icon child-of=\"jnt-form-host\" [icon]=\"ui.icons.animated.success\"></jnt-icon>\n </div>\n</form>",
animations: [
trigger('success', [
state('void', style({
opacity: 0
})),
state('*', style({
opacity: 1
})),
transition('void <=> *', [
animate('.3s ease-in-out')
]),
]),
]
}),
__metadata("design:paramtypes", [NGXLogger])
], FormComponent);
return FormComponent;
}());
export { FormComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"ng://@junte/ui/","sources":["lib/forms/form/form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { animate, state, style, transition, trigger } from '@angular/animations';\nimport {\n  Component,\n  ContentChild,\n  ContentChildren,\n  EventEmitter,\n  HostBinding,\n  HostListener,\n  Input,\n  OnInit,\n  Output,\n  QueryList,\n  TemplateRef\n} from '@angular/core';\nimport { AbstractControl, FormArray, FormGroup } from '@angular/forms';\nimport { NGXLogger } from 'ngx-logger';\nimport { MethodApi, PropertyApi } from '../../core/decorators/api';\nimport { Height } from '../../core/enums/height';\nimport { State } from '../../core/enums/state';\nimport { UI } from '../../core/enums/ui';\nimport { FormControlComponent } from './control/form-control.component';\n\n@Component({\n  selector: 'jnt-form',\n  templateUrl: './form.encapsulated.html',\n  animations: [\n    trigger('success', [\n        state(\n          'void',\n          style({\n            opacity: 0\n          })\n        ),\n        state(\n          '*',\n          style({\n            opacity: 1\n          })\n        ),\n        transition(\n          'void <=> *',\n          [\n            animate('.3s ease-in-out')\n          ]\n        ),\n      ]\n    ),\n  ]\n})\nexport class FormComponent implements OnInit {\n\n  @HostBinding('attr.host')\n  readonly host = 'jnt-form-host';\n\n  ui = UI;\n\n  _state = {success: false};\n\n  @HostBinding('attr.data-height')\n  _height: Height = Height.default;\n\n  @PropertyApi({\n    description: 'Name form group',\n    type: 'FormGroup',\n  })\n  @Input('formGroup')\n  form: FormGroup;\n\n  @PropertyApi({\n    description: 'Title for form',\n    type: 'string',\n  })\n  @Input()\n  title: string;\n\n  @PropertyApi({\n    description: 'State of form',\n    path: 'ui.state',\n    options: [State.error, State.loading]\n  })\n  @Input()\n  state: State;\n\n  @PropertyApi({\n    description: 'Height of form',\n    path: 'ui.height',\n    options: [Height.default, Height.fluid],\n    default: Height.default\n  })\n  @Input() set height(height: Height) {\n    this._height = height || Height.default;\n  }\n\n  @ContentChild('formTitleTemplate')\n  titleTemplate: TemplateRef<any>;\n\n  @ContentChild('formFooterTemplate')\n  footerTemplate: TemplateRef<any>;\n\n  @ContentChildren(FormControlComponent, {descendants: true})\n  controls: QueryList<FormControlComponent>;\n\n  @Output()\n  submitted = new EventEmitter();\n\n  @Output()\n  checked = new EventEmitter<AbstractControl[]>();\n\n  @MethodApi({description: 'show success animation'})\n  success() {\n    this._state.success = true;\n    setTimeout(() => this._state.success = false, 2100);\n  }\n\n  constructor(private logger: NGXLogger) {\n  }\n\n  ngOnInit() {\n    if (!!this.form) {\n      this.form.statusChanges.subscribe(() => {\n        this.render();\n        this.checked.emit(this.check(this.form));\n      });\n    }\n  }\n\n  render() {\n    this.logger.debug('render form');\n    if (!!this.controls) {\n      this.controls.filter(component => !!component.name && !!component.messages.length)\n        .forEach(component => component.check());\n    }\n  }\n\n  private check(form: FormGroup | FormArray): AbstractControl[] {\n    this.logger.debug('check form');\n    let errors = [];\n    for (const key in form.controls) {\n      const control = form.controls[key];\n\n      if (control instanceof FormGroup || control instanceof FormArray) {\n        errors = errors.concat(this.check(control));\n      } else {\n        if (!!control.errors && control.dirty) {\n          errors.push(control);\n        }\n      }\n    }\n    this.logger.debug('controls have errors = ', errors.map(e => e.name));\n    return errors;\n  }\n\n  /**\n   * @deprecated please use submit() instead\n   */\n  onSubmit() {\n    this.submit();\n  }\n\n  @HostListener('submit')\n  submit() {\n    this.logger.debug('submit form');\n    if (!!this.form) {\n      this.validate(this.form);\n\n      if (this.form.valid) {\n        this.submitted.emit();\n        this.refresh(this.form);\n      }\n    }\n  }\n\n  private validate(form: FormGroup | FormArray) {\n    this.logger.debug('validate form');\n    for (const key in form.controls) {\n      const control = form.controls[key];\n\n      if (control instanceof FormGroup || control instanceof FormArray) {\n        this.validate(control);\n      } else {\n        control.markAsDirty();\n        control.updateValueAndValidity({emitEvent: false});\n      }\n    }\n\n    this.render();\n    this.checked.emit(this.check(this.form));\n  }\n\n  private refresh(form: FormGroup | FormArray) {\n    this.logger.debug('refresh form');\n    for (const key in form.controls) {\n      const control = form.controls[key];\n\n      if (control instanceof FormGroup || control instanceof FormArray) {\n        this.refresh(control);\n      } else {\n        control.markAsPristine();\n      }\n    }\n  }\n}\n"]}