@junte/ui
Version:
Quality Angular UI components kit
135 lines • 17.8 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { Component, ContentChildren, forwardRef, HostBinding, HostListener, Input, QueryList } from '@angular/core';
import { ControlValueAccessor, FormBuilder, FormControl, NG_VALUE_ACCESSOR } from '@angular/forms';
import { NGXLogger } from 'ngx-logger';
import { distinctUntilChanged, map } from 'rxjs/operators';
import { PropertyApi } from '../../../core/decorators/api';
import { Size } from '../../../core/enums/size';
import { UI } from '../../../core/enums/ui';
import { isEqual } from '../../../core/utils/equal';
import { CheckboxComponent } from '../checkbox.component';
var CheckboxGroupComponent = /** @class */ (function () {
function CheckboxGroupComponent(fb, logger) {
var _this = this;
this.fb = fb;
this.logger = logger;
this.ui = UI;
this.host = 'jnt-checkbox-group-host';
this._size = Size.normal;
this.selectedItems = [];
this.checkboxesControl = this.fb.array([]);
this.form = this.fb.group({
checkboxes: this.checkboxesControl
});
this.cols = 1;
this.onChange = function () { return _this.logger.error('value accessor is not registered'); };
this.onTouched = function () { return _this.logger.error('value accessor is not registered'); };
this.registerOnChange = function (fn) { return _this.onChange = fn; };
this.registerOnTouched = function (fn) { return _this.onTouched = fn; };
this.onBlur = function () { return _this.onTouched(); };
}
CheckboxGroupComponent_1 = CheckboxGroupComponent;
Object.defineProperty(CheckboxGroupComponent.prototype, "size", {
get: function () {
return this._size;
},
set: function (size) {
this._size = size || Size.normal;
},
enumerable: true,
configurable: true
});
CheckboxGroupComponent.prototype.ngAfterViewInit = function () {
var _this = this;
this.update();
this.checkboxes.changes.subscribe(function () { return _this.update(); });
this.checkboxesControl.valueChanges.pipe(map(function (checkboxes) { return _this.checkboxes
.filter(function (_, i) { return checkboxes[i]; })
.map(function (checkbox) { return checkbox.value; }); }), distinctUntilChanged(function (a, b) { return isEqual(a, b); })).subscribe(function (selectedItems) {
_this.selectedItems = selectedItems;
_this.onChange(selectedItems);
});
};
CheckboxGroupComponent.prototype.update = function () {
var _this = this;
if (!!this.checkboxes) {
this.checkboxesControl.reset([], { emitEvent: false });
this.checkboxes.forEach(function (checkbox, i) {
var control = _this.checkboxesControl.get(i.toString());
if (!!control) {
control.setValue(_this.selectedItems.includes(checkbox.value), { emitEvent: false });
}
else {
_this.checkboxesControl.push(new FormControl(_this.selectedItems.includes(checkbox.value)));
}
});
}
};
CheckboxGroupComponent.prototype.writeValue = function (value) {
var selectedItems = [];
if (!!value) {
selectedItems = Array.isArray(value) ? value : [value];
}
this.selectedItems = selectedItems;
this.update();
};
CheckboxGroupComponent.prototype.setDisabledState = function (isDisabled) {
isDisabled ? this.checkboxesControl.disable({ emitEvent: false })
: this.checkboxesControl.enable({ emitEvent: false });
};
var CheckboxGroupComponent_1;
CheckboxGroupComponent.ctorParameters = function () { return [
{ type: FormBuilder },
{ type: NGXLogger }
]; };
__decorate([
HostBinding('attr.host'),
__metadata("design:type", Object)
], CheckboxGroupComponent.prototype, "host", void 0);
__decorate([
PropertyApi({
description: 'Count of cols in checkbox group',
type: 'number',
default: 1
}),
Input(),
__metadata("design:type", Object)
], CheckboxGroupComponent.prototype, "cols", void 0);
__decorate([
PropertyApi({
description: 'Size for checkbox in checkbox group',
path: 'ui.size',
options: [Size.tiny, Size.small, Size.normal, Size.large],
default: Size.normal
}),
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], CheckboxGroupComponent.prototype, "size", null);
__decorate([
ContentChildren(CheckboxComponent),
__metadata("design:type", QueryList)
], CheckboxGroupComponent.prototype, "checkboxes", void 0);
__decorate([
HostListener('blur'),
__metadata("design:type", Object)
], CheckboxGroupComponent.prototype, "onBlur", void 0);
CheckboxGroupComponent = CheckboxGroupComponent_1 = __decorate([
Component({
selector: 'jnt-checkbox-group',
template: "<form child-of=\"jnt-checkbox-group-host\" [formGroup]=\"form\">\n <ng-container formArrayName=\"checkboxes\">\n <ng-container *ngIf=\"!!checkboxesControl.length\">\n <ng-container *ngIf=\"cols <= 1; else colTemplate\">\n <jnt-stack child-of=\"jnt-checkbox-group-host\" [gutter]=\"ui.gutter.small\" [align]=\"ui.align.stretch\">\n <jnt-checkbox child-of=\"jnt-checkbox-group-host\" *ngFor=\"let item of checkboxes; let i = index\"\n [formControlName]=\"i\"\n [size]=\"size\"\n [label]=\"item.label\"\n [value]=\"item.value\">\n <ng-template *ngIf=\"!!item.labelTemplate\" #checkboxLabelTemplate>\n <ng-container *ngTemplateOutlet=\"item.labelTemplate\"></ng-container>\n </ng-template>\n </jnt-checkbox>\n </jnt-stack>\n </ng-container>\n <ng-template #colTemplate>\n <jnt-row child-of=\"jnt-checkbox-group-host\" >\n <jnt-col child-of=\"jnt-checkbox-group-host\" *ngFor=\"let item of checkboxes; let i = index\" [tablet]=\"(12 / cols) | trunc\">\n <jnt-checkbox child-of=\"jnt-checkbox-group-host\" [formControlName]=\"i\"\n [size]=\"size\"\n [label]=\"item.label\"\n [value]=\"item.value\">\n <ng-template *ngIf=\"!!item.labelTemplate\" #checkboxLabelTemplate>\n <ng-container *ngTemplateOutlet=\"item.labelTemplate\"></ng-container>\n </ng-template>\n </jnt-checkbox>\n </jnt-col>\n </jnt-row>\n </ng-template>\n </ng-container>\n </ng-container>\n</form>",
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(function () { return CheckboxGroupComponent_1; }),
multi: true
}
]
}),
__metadata("design:paramtypes", [FormBuilder,
NGXLogger])
], CheckboxGroupComponent);
return CheckboxGroupComponent;
}());
export { CheckboxGroupComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox-group.component.js","sourceRoot":"ng://@junte/ui/","sources":["lib/forms/checkbox/checkbox-group/checkbox-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ContentChildren,\n  forwardRef,\n  HostBinding,\n  HostListener,\n  Input,\n  QueryList\n} from '@angular/core';\nimport { ControlValueAccessor, FormBuilder, FormControl, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { NGXLogger } from 'ngx-logger';\nimport { distinctUntilChanged, map } from 'rxjs/operators';\nimport { PropertyApi } from '../../../core/decorators/api';\nimport { Size } from '../../../core/enums/size';\nimport { UI } from '../../../core/enums/ui';\nimport { isEqual } from '../../../core/utils/equal';\nimport { CheckboxComponent } from '../checkbox.component';\n\n@Component({\n  selector: 'jnt-checkbox-group',\n  templateUrl: './checkbox-group.encapsulated.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => CheckboxGroupComponent),\n      multi: true\n    }\n  ]\n})\n\nexport class CheckboxGroupComponent implements ControlValueAccessor, AfterViewInit {\n\n  ui = UI;\n\n  @HostBinding('attr.host')\n  readonly host = 'jnt-checkbox-group-host';\n\n  private _size: Size = Size.normal;\n  private selectedItems = [];\n\n  checkboxesControl = this.fb.array([]);\n  form = this.fb.group({\n    checkboxes: this.checkboxesControl\n  });\n\n  @PropertyApi({\n    description: 'Count of cols in checkbox group',\n    type: 'number',\n    default: 1\n  })\n  @Input()\n  cols = 1;\n\n  @PropertyApi({\n    description: 'Size for checkbox in checkbox group',\n    path: 'ui.size',\n    options: [Size.tiny, Size.small, Size.normal, Size.large],\n    default: Size.normal\n  })\n  @Input()\n  set size(size: Size) {\n    this._size = size || Size.normal;\n  }\n\n  get size() {\n    return this._size;\n  }\n\n  @ContentChildren(CheckboxComponent)\n  checkboxes: QueryList<CheckboxComponent>;\n\n  onChange: (value: any) => void = () => this.logger.error('value accessor is not registered');\n  onTouched: () => void = () => this.logger.error('value accessor is not registered');\n  registerOnChange = fn => this.onChange = fn;\n  registerOnTouched = fn => this.onTouched = fn;\n  @HostListener('blur') onBlur = () => this.onTouched();\n\n  constructor(private fb: FormBuilder,\n              private logger: NGXLogger) {\n  }\n\n  ngAfterViewInit() {\n    this.update();\n    this.checkboxes.changes.subscribe(() => this.update());\n\n    this.checkboxesControl.valueChanges.pipe(\n      map(checkboxes => this.checkboxes\n        .filter((_, i) => checkboxes[i])\n        .map(checkbox => checkbox.value)),\n      distinctUntilChanged((a, b) => isEqual(a, b))\n    ).subscribe(selectedItems => {\n      this.selectedItems = selectedItems;\n      this.onChange(selectedItems);\n    });\n  }\n\n  update() {\n    if (!!this.checkboxes) {\n      this.checkboxesControl.reset([], {emitEvent: false});\n      this.checkboxes.forEach((checkbox, i) => {\n        const control = this.checkboxesControl.get(i.toString());\n        if (!!control) {\n          control.setValue(this.selectedItems.includes(checkbox.value), {emitEvent: false});\n        } else {\n          this.checkboxesControl.push(new FormControl(this.selectedItems.includes(checkbox.value)));\n        }\n      });\n    }\n  }\n\n  writeValue(value: any) {\n    let selectedItems = [];\n    if (!!value) {\n      selectedItems = Array.isArray(value) ? value : [value];\n    }\n    this.selectedItems = selectedItems;\n    this.update();\n  }\n\n  setDisabledState(isDisabled: boolean) {\n    isDisabled ? this.checkboxesControl.disable({emitEvent: false})\n      : this.checkboxesControl.enable({emitEvent: false});\n  }\n}\n"]}