UNPKG

@douglas-serena/ng-inputs

Version:
157 lines 19.2 kB
import { ChangeDetectorRef } from '@angular/core'; import { Component, ElementRef, EventEmitter, HostBinding, Input, Output, Renderer2, ViewChild, } from '@angular/core'; import { ControlContainer, FormControlDirective, SelectControlValueAccessor, } from '@angular/forms'; import { NgInputConfigService } from '../core/ng-input-config.service'; export class SelectCustomControlValueAccessor extends SelectControlValueAccessor { constructor(_controlContainer, elementRef, renderer, _configService, _changeDetectorRef) { super(renderer, elementRef); this._controlContainer = _controlContainer; this.elementRef = elementRef; this.renderer = renderer; this._configService = _configService; this._changeDetectorRef = _changeDetectorRef; this.formControlName = ''; this.disabled = false; this.change = new EventEmitter(); 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; this.readonly = false; } get _placeholder() { return this.field === 'floating' && !!this.label && this.placeholder.length === 0 ? false : this.placeholder; } 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; this.validRequired(); } getMultiLabels(labels, label) { const lastLabel = label.concat([]); const rest = label.splice(1, label.length - 1); return lastLabel.length === 1 ? labels === null || labels === void 0 ? void 0 : labels[lastLabel[0]] : this.getMultiLabels(labels === null || labels === void 0 ? void 0 : labels[lastLabel[0]], rest); } 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); } validRequired() { var _a, _b, _c; const value = this.control.value; (_a = this === null || this === void 0 ? void 0 : this.onWrite) === null || _a === void 0 ? void 0 : _a.call(this, null); this._changeDetectorRef.detectChanges(); if (this.required === undefined) { this.required = (_b = this.control.errors) === null || _b === void 0 ? void 0 : _b.required; } (_c = this === null || this === void 0 ? void 0 : this.onWrite) === null || _c === void 0 ? void 0 : _c.call(this, value); this._changeDetectorRef.detectChanges(); } 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; } } SelectCustomControlValueAccessor.decorators = [ { type: Component, args: [{ selector: '', template: '' },] } ]; SelectCustomControlValueAccessor.ctorParameters = () => [ { type: ControlContainer }, { type: ElementRef }, { type: Renderer2 }, { type: NgInputConfigService }, { type: ChangeDetectorRef } ]; SelectCustomControlValueAccessor.propDecorators = { formControlDirective: [{ type: ViewChild, args: [FormControlDirective, { static: true },] }], formControl: [{ type: Input }], formControlName: [{ type: Input }], name: [{ type: Input }], disabled: [{ type: Input }], help: [{ type: Input }], change: [{ type: Output }], 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":"select-custom-control-value-accessor.domain.js","sourceRoot":"","sources":["../../../../../projects/ng-inputs/src/lib/ng-select/select-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  ElementRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  Renderer2,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport {\r\n  ControlContainer,\r\n  FormControl,\r\n  FormControlDirective,\r\n  SelectControlValueAccessor,\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 SelectCustomControlValueAccessor\r\n  extends SelectControlValueAccessor\r\n  implements 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() disabled = false;\r\n  @Input() help?: string;\r\n\r\n  @Output() public change = new EventEmitter();\r\n  @Output() public blur = new EventEmitter();\r\n  @Output() public focus = new EventEmitter();\r\n\r\n  get _placeholder() {\r\n    return this.field === 'floating' &&\r\n      !!this.label &&\r\n      this.placeholder.length === 0\r\n      ? false\r\n      : this.placeholder;\r\n  }\r\n  @Input() placeholder: string = '';\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    protected _controlContainer: ControlContainer,\r\n    protected elementRef: ElementRef,\r\n    protected renderer: Renderer2,\r\n    private _configService: NgInputConfigService,\r\n    private _changeDetectorRef: ChangeDetectorRef\r\n  ) {\r\n    super(renderer, elementRef);\r\n    this.readonly = false;\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.ngOnInitSuper();\r\n\r\n    if (this.disabled) this.control.disable();\r\n    else this.control.enable();\r\n  }\r\n\r\n  ngOnInitSuper() {\r\n    if (this.name === undefined) this.name = this.formControlName;\r\n\r\n    this.validRequired();\r\n  }\r\n\r\n  getMultiLabels(labels: any, label: string[]): any {\r\n    const lastLabel = label.concat([]);\r\n    const rest = label.splice(1, label.length - 1);\r\n\r\n    return lastLabel.length === 1\r\n      ? labels?.[lastLabel[0]]\r\n      : this.getMultiLabels(labels?.[lastLabel[0]], rest);\r\n  }\r\n\r\n  getKeys(errors: IObject) {\r\n    return Object.keys(errors);\r\n  }\r\n\r\n  getError(key: string) {\r\n    return this.control?.errors?.[key] && this.control?.touched;\r\n  }\r\n\r\n  validRequired() {\r\n    const value = this.control.value;\r\n    this?.onWrite?.(null);\r\n    this._changeDetectorRef.detectChanges();\r\n    if (this.required === undefined) {\r\n      this.required = this.control.errors?.required;\r\n    }\r\n    this?.onWrite?.(value);\r\n    this._changeDetectorRef.detectChanges();\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"]}