UNPKG

@douglas-serena/ng-inputs

Version:
134 lines 15.7 kB
import { ChangeDetectorRef } from '@angular/core'; import { Component, EventEmitter, HostBinding, Input, Output, ViewChild, } from '@angular/core'; import { ControlContainer, FormControlDirective, } from '@angular/forms'; import { NgInputConfigService } from '../core/ng-input-config.service'; export class InputCustomControlValueAccessor { constructor(_controlContainer, _configService, _changeDetectorRef) { this._controlContainer = _controlContainer; this._configService = _configService; this._changeDetectorRef = _changeDetectorRef; this.disabled = false; this.blur = new EventEmitter(); this.focus = new EventEmitter(); this._placeholder = ''; this.label = ''; this._cols = { default: 12, sm: 12, }; this._field = null; this.readonly = false; this.errors = {}; this.time = 0; } get placeholder() { return this._placeholder; } set placeholder(value) { this._placeholder = value; } set cols(cols) { this._cols = Object.assign(Object.assign({}, this._cols), cols); } set field(value) { this._field = value; } get field() { return this._field ? this._field : this._configService.field.type; } get control() { var _a, _b; return (this.formControl || ((_b = (_a = this._controlContainer) === null || _a === void 0 ? void 0 : _a.control) === null || _b === void 0 ? void 0 : _b.get(this.formControlName))); } get classCols() { let className = this._configService.theme === 'bootstrap' ? `col-${this._cols.default}` : `col`; if (this._cols.lg) className += this._configService.theme === 'bootstrap' ? ` col-lg-${this._cols.lg}` : ` l${this._cols.lg}`; if (this._cols.md) className += this._configService.theme === 'bootstrap' ? ` col-md-${this._cols.md}` : ` m${this._cols.md}`; if (this._cols.sm) className += this._configService.theme === 'bootstrap' ? ` col-sm-${this._cols.sm}` : ` s${this._cols.sm}`; return className; } ngOnInit() { this.ngOnInitSuper(); if (this.disabled) this.control.disable(); else this.control.enable(); } ngOnInitSuper() { if (this.name === undefined) this.name = this.formControlName; if (this.required === null) { const value = this.control.value; this.control.reset(); this.required = !!this.control.getError('required'); this.control.setValue(value); } } getKeys(errors) { return Object.keys(errors); } getError(key) { var _a, _b, _c; return ((_b = (_a = this.control) === null || _a === void 0 ? void 0 : _a.errors) === null || _b === void 0 ? void 0 : _b[key]) && ((_c = this.control) === null || _c === void 0 ? void 0 : _c.touched); } registerOnTouched(fn) { var _a; (_a = this.formControlDirective.valueAccessor) === null || _a === void 0 ? void 0 : _a.registerOnTouched(fn); } registerOnChange(fn) { this.onWrite = fn; } writeValue(obj) { clearTimeout(this.time); this.time = setTimeout(() => { this.onWrite(obj); }); } setDisabledState(isDisabled) { this.disabled = isDisabled; } } InputCustomControlValueAccessor.decorators = [ { type: Component, args: [{ selector: '', template: '' },] } ]; InputCustomControlValueAccessor.ctorParameters = () => [ { type: ControlContainer }, { type: NgInputConfigService }, { type: ChangeDetectorRef } ]; InputCustomControlValueAccessor.propDecorators = { formControlDirective: [{ type: ViewChild, args: [FormControlDirective, { static: true },] }], formControl: [{ type: Input }], formControlName: [{ type: Input }], name: [{ type: Input }], help: [{ type: Input }], disabled: [{ type: Input }], blur: [{ type: Output }], focus: [{ type: Output }], placeholder: [{ type: Input }], label: [{ type: Input }], cols: [{ type: Input }], field: [{ type: Input }], readonly: [{ type: Input }], required: [{ type: Input }], errors: [{ type: Input }], classCols: [{ type: HostBinding, args: ['class',] }] }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-custom-control-value-accessor.domain.js","sourceRoot":"","sources":["../../../../../projects/ng-inputs/src/lib/ng-input/input-custom-control-value-accessor.domain.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef } from '@angular/core';\r\nimport {\r\n  AfterViewInit,\r\n  Component,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport {\r\n  ControlContainer,\r\n  ControlValueAccessor,\r\n  FormControl,\r\n  FormControlDirective,\r\n} from '@angular/forms';\r\nimport { NgInputConfigService } from '../core/ng-input-config.service';\r\n\r\ninterface IObject {\r\n  [key: string]: string;\r\n}\r\n\r\ninterface IOnWrite {\r\n  (value: any): void;\r\n}\r\n\r\n@Component({ selector: '', template: '' })\r\nexport class InputCustomControlValueAccessor\r\n  implements ControlValueAccessor, OnInit\r\n{\r\n  @ViewChild(FormControlDirective, { static: true })\r\n  formControlDirective: FormControlDirective;\r\n  @Input() formControl: FormControl;\r\n  @Input() formControlName: string;\r\n  @Input() name?: string;\r\n  @Input() help?: string;\r\n  @Input() disabled: boolean = false;\r\n\r\n  @Output() blur = new EventEmitter();\r\n  @Output() focus = new EventEmitter();\r\n\r\n  private _placeholder: string = '';\r\n  get placeholder(): string {\r\n    return this._placeholder;\r\n  }\r\n  @Input() set placeholder(value: string) {\r\n    this._placeholder = value;\r\n  }\r\n\r\n  @Input() label: string = '';\r\n  _cols: { default: number; lg?: number; md?: number; sm?: number } = {\r\n    default: 12,\r\n    sm: 12,\r\n  };\r\n  @Input() set cols(cols: {\r\n    default?: number;\r\n    lg?: number;\r\n    md?: number;\r\n    sm?: number;\r\n  }) {\r\n    this._cols = { ...this._cols, ...cols };\r\n  }\r\n\r\n  _field: null | 'group' | 'floating' = null;\r\n  @Input() set field(value: 'group' | 'floating') {\r\n    this._field = value;\r\n  }\r\n  get field() {\r\n    return this._field\r\n      ? this._field\r\n      : (this._configService.field.type as 'group' | 'floating');\r\n  }\r\n\r\n  @Input() readonly: boolean = false;\r\n  @Input() required?: boolean;\r\n\r\n  @Input() errors: IObject = {};\r\n\r\n  get control(): FormControl {\r\n    return (this.formControl ||\r\n      this._controlContainer?.control?.get(\r\n        this.formControlName\r\n      )) as FormControl;\r\n  }\r\n\r\n  @HostBinding('class') get classCols() {\r\n    let className =\r\n      this._configService.theme === 'bootstrap'\r\n        ? `col-${this._cols.default}`\r\n        : `col`;\r\n    if (this._cols.lg)\r\n      className +=\r\n        this._configService.theme === 'bootstrap'\r\n          ? ` col-lg-${this._cols.lg}`\r\n          : ` l${this._cols.lg}`;\r\n    if (this._cols.md)\r\n      className +=\r\n        this._configService.theme === 'bootstrap'\r\n          ? ` col-md-${this._cols.md}`\r\n          : ` m${this._cols.md}`;\r\n    if (this._cols.sm)\r\n      className +=\r\n        this._configService.theme === 'bootstrap'\r\n          ? ` col-sm-${this._cols.sm}`\r\n          : ` s${this._cols.sm}`;\r\n    return className;\r\n  }\r\n\r\n  constructor(\r\n    private _controlContainer: ControlContainer,\r\n    private _configService: NgInputConfigService,\r\n    private _changeDetectorRef: ChangeDetectorRef\r\n  ) {}\r\n\r\n  ngOnInit() {\r\n    this.ngOnInitSuper();\r\n    if (this.disabled) this.control.disable();\r\n    else this.control.enable();\r\n  }\r\n\r\n  protected ngOnInitSuper() {\r\n    if (this.name === undefined) this.name = this.formControlName;\r\n\r\n    if (this.required === null) {\r\n      const value = this.control.value;\r\n      this.control.reset();\r\n      this.required = !!this.control.getError('required');\r\n      this.control.setValue(value);\r\n    }\r\n  }\r\n\r\n  getKeys(errors: IObject) {\r\n    return Object.keys(errors);\r\n  }\r\n  getError(key: string) {\r\n    return this.control?.errors?.[key] && this.control?.touched;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.formControlDirective.valueAccessor?.registerOnTouched(fn);\r\n  }\r\n\r\n  onWrite: IOnWrite;\r\n  registerOnChange(fn: IOnWrite): void {\r\n    this.onWrite = fn;\r\n  }\r\n\r\n  time: any = 0;\r\n  writeValue(obj: any): void {\r\n    clearTimeout(this.time);\r\n    this.time = setTimeout(() => {\r\n      this.onWrite(obj);\r\n    });\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n}\r\n"]}