@douglas-serena/ng-inputs
Version:
angular entry library
113 lines • 15 kB
JavaScript
import { Component, ElementRef, forwardRef, HostBinding, Input, Renderer2, ViewChild, } from '@angular/core';
import { CheckboxControlValueAccessor, ControlContainer, FormControlDirective, NG_VALUE_ACCESSOR, } from '@angular/forms';
import { NgInputConfigService } from './../core/ng-input-config.service';
export class NgCheckboxComponent extends CheckboxControlValueAccessor {
constructor(controlContainer, elementRef, renderer, configService) {
super(renderer, elementRef);
this.controlContainer = controlContainer;
this.elementRef = elementRef;
this.renderer = renderer;
this.configService = configService;
this.label = 'Sem label: ';
this.type = 'checkbox';
this.line = false;
this.required = false;
this.errors = {};
this.suffix = '';
this.prefix = '';
this._cols = {
default: 12,
};
this.readonly = false;
}
set cols(cols) {
this._cols = Object.assign(Object.assign({}, this._cols), cols);
}
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() { }
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)));
}
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);
}
writeValue(value) {
this.renderer.setProperty(this.elementRef.nativeElement, 'checked', value);
}
registerOnChange(fn) {
this.onChange = fn;
}
registerOnTouched(fn) {
this.onTouched = fn;
}
setDisabledState(isDisabled) {
this.renderer.setProperty(this.elementRef.nativeElement, 'disabled', isDisabled);
}
}
NgCheckboxComponent.decorators = [
{ type: Component, args: [{
selector: 'dss-checkbox',
template: "<div\r\n class=\"form-group form-control-checkbox\"\r\n [class.form-switch]=\"type === 'switch'\"\r\n [class.form-check-inline]=\"line\"\r\n [ngClass]=\"{\r\n invalid: control.invalid && control.touched,\r\n valid: control.valid && control.touched\r\n }\"\r\n>\r\n <div\r\n class=\"form-content\"\r\n [class.switch]=\"type === 'switch' || type === 'button-switch'\"\r\n >\r\n <label\r\n class=\"form-check-label\"\r\n [class]=\"\r\n type === 'button-checkbox' || type === 'button-switch'\r\n ? 'btn btn-light w-100'\r\n : ''\r\n \"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"form-check-input filled-in\"\r\n [formControl]=\"control\"\r\n [readonly]=\"readonly\"\r\n [class.is-invalid]=\"!readonly && control.invalid && control.touched\"\r\n [class.readonly]=\"readonly\"\r\n />\r\n <span [class.lever]=\"type === 'switch'\"> </span>\r\n {{ label }}\r\n </label>\r\n </div>\r\n\r\n <ng-container *ngFor=\"let error of getKeys(errors)\">\r\n <!-- MESSAGE ERROR -->\r\n <div *ngIf=\"getError(error)\" class=\"message error\">\r\n {{ errors[error] }}\r\n </div>\r\n </ng-container>\r\n\r\n <!-- MESSAGE HELp -->\r\n <div *ngIf=\"!!help\" class=\"message\">\r\n {{ help }}\r\n </div>\r\n</div>\r\n",
host: {
'(change)': 'onChange($event.target.checked)',
'(blur)': 'onTouched()',
},
providers: [
{
provide: NG_VALUE_ACCESSOR,
multi: true,
useExisting: forwardRef(() => NgCheckboxComponent),
},
],
styles: [""]
},] }
];
NgCheckboxComponent.ctorParameters = () => [
{ type: ControlContainer },
{ type: ElementRef },
{ type: Renderer2 },
{ type: NgInputConfigService }
];
NgCheckboxComponent.propDecorators = {
label: [{ type: Input }],
type: [{ type: Input }],
line: [{ type: Input }],
readonly: [{ type: Input }],
required: [{ type: Input }],
help: [{ type: Input }],
errors: [{ type: Input }],
suffix: [{ type: Input }],
prefix: [{ type: Input }],
cols: [{ type: Input }],
classCols: [{ type: HostBinding, args: ['class',] }],
formControlDirective: [{ type: ViewChild, args: [FormControlDirective, { static: true },] }],
formControl: [{ type: Input }],
formControlName: [{ type: Input }]
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-checkbox.component.js","sourceRoot":"","sources":["../../../../../projects/ng-inputs/src/lib/ng-checkbox/ng-checkbox.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  forwardRef,\r\n  HostBinding,\r\n  Input,\r\n  Renderer2,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport {\r\n  CheckboxControlValueAccessor,\r\n  ControlContainer,\r\n  FormControl,\r\n  FormControlDirective,\r\n  NG_VALUE_ACCESSOR,\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@Component({\r\n  selector: 'dss-checkbox',\r\n  templateUrl: './ng-checkbox.component.html',\r\n  styleUrls: ['./ng-checkbox.component.scss'],\r\n  host: {\r\n    '(change)': 'onChange($event.target.checked)',\r\n    '(blur)': 'onTouched()',\r\n  },\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: forwardRef(() => NgCheckboxComponent),\r\n    },\r\n  ],\r\n})\r\nexport class NgCheckboxComponent extends CheckboxControlValueAccessor {\r\n  @Input() label: string = 'Sem label: ';\r\n  @Input() type: 'checkbox' | 'switch' | 'button-checkbox' | 'button-switch' =\r\n    'checkbox';\r\n  @Input() line: boolean = false;\r\n\r\n  @Input() readonly: boolean;\r\n  @Input() required: boolean = false;\r\n  @Input() help?: string;\r\n\r\n  @Input() errors: IObject = {};\r\n\r\n  @Input() suffix: string = '';\r\n  @Input() prefix: string = '';\r\n\r\n  _cols: { default: number; lg?: number; md?: number; sm?: number } = {\r\n    default: 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  @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 elementRef: ElementRef,\r\n    private renderer: Renderer2,\r\n    public configService: NgInputConfigService\r\n  ) {\r\n    super(renderer, elementRef);\r\n    this.readonly = false;\r\n  }\r\n\r\n  ngOnInit() {}\r\n\r\n  // #############################\r\n\r\n  // ATTRIBUTE AND METHODS CONTROL\r\n\r\n  // #############################\r\n\r\n  @ViewChild(FormControlDirective, { static: true })\r\n  formControlDirective: FormControlDirective;\r\n  @Input() formControl: FormControl;\r\n  @Input() formControlName: string;\r\n\r\n  get control(): FormControl {\r\n    return (this.formControl ||\r\n      this.controlContainer?.control?.get(this.formControlName)) as FormControl;\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  writeValue(value: any): void {\r\n    this.renderer.setProperty(this.elementRef.nativeElement, 'checked', value);\r\n  }\r\n  onChange: (_: any) => {};\r\n  registerOnChange(fn: (_: any) => {}): void {\r\n    this.onChange = fn;\r\n  }\r\n  onTouched: () => {};\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.renderer.setProperty(\r\n      this.elementRef.nativeElement,\r\n      'disabled',\r\n      isDisabled\r\n    );\r\n  }\r\n}\r\n"]}