UNPKG

@douglas-serena/ng-inputs

Version:
113 lines 15 kB
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"]}