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