@douglas-serena/ng-inputs
Version:
angular entry library
134 lines • 15.7 kB
JavaScript
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"]}