UNPKG

@junte/ui

Version:

Quality Angular UI components kit

211 lines 22.1 kB
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"]}