myrta-ui 17.0.0-beta.24 → 17.0.0-beta.25

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -53,10 +53,8 @@ export class CheckboxGroupComponent {
53
53
  }
54
54
  groupItemsWrapper;
55
55
  changed = new EventEmitter();
56
- changeChecked = new EventEmitter();
57
56
  modelChange = new EventEmitter();
58
57
  changedInner = new EventEmitter();
59
- changeCheckedInner = new EventEmitter();
60
58
  modelChangeInner = new EventEmitter();
61
59
  modelItemChange = new EventEmitter();
62
60
  constructor(_detector) {
@@ -137,17 +135,16 @@ export class CheckboxGroupComponent {
137
135
  }
138
136
  updateValue(list, checkedList) {
139
137
  const clearedList = innerListToList(checkedList);
138
+ const clearedInnerList = innerListToList(this.innerList);
140
139
  this.changed.emit(clearedList);
141
- this.changeChecked.emit(clearedList);
142
- this.modelChange.emit({ value: clearedList, id: this.uuid });
140
+ this.modelChange.emit({ value: clearedList, full: clearedInnerList, id: this.uuid });
143
141
  this.changedInner.emit(checkedList);
144
- this.changeCheckedInner.emit(checkedList);
145
- this.modelChangeInner.emit({ value: checkedList, id: this.uuid });
142
+ this.modelChangeInner.emit({ value: checkedList, full: this.innerList, id: this.uuid });
146
143
  this.onChange(checkedList);
147
144
  this.onTouched();
148
145
  }
149
146
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: CheckboxGroupComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
150
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: CheckboxGroupComponent, selector: "mrx-checkbox-group", inputs: { fields: "fields", scrollMaxHeight: "scrollMaxHeight", searchable: "searchable", scrollable: "scrollable", sortable: "sortable", disabled: "disabled", readonly: "readonly", enableMessage: "enableMessage", searchPlaceholder: "searchPlaceholder", customClasses: "customClasses", tooltip: "tooltip", labelText: "labelText", linkText: "linkText", invalid: "invalid", invalidMessage: "invalidMessage", items: "items" }, outputs: { changed: "changed", changeChecked: "changeChecked", modelChange: "modelChange", changedInner: "changedInner", changeCheckedInner: "changeCheckedInner", modelChangeInner: "modelChangeInner", modelItemChange: "modelItemChange" }, providers: [
147
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: CheckboxGroupComponent, selector: "mrx-checkbox-group", inputs: { fields: "fields", scrollMaxHeight: "scrollMaxHeight", searchable: "searchable", scrollable: "scrollable", sortable: "sortable", disabled: "disabled", readonly: "readonly", enableMessage: "enableMessage", searchPlaceholder: "searchPlaceholder", customClasses: "customClasses", tooltip: "tooltip", labelText: "labelText", linkText: "linkText", invalid: "invalid", invalidMessage: "invalidMessage", items: "items" }, outputs: { changed: "changed", modelChange: "modelChange", changedInner: "changedInner", modelChangeInner: "modelChangeInner", modelItemChange: "modelItemChange" }, providers: [
151
148
  {
152
149
  provide: NG_VALUE_ACCESSOR,
153
150
  useExisting: forwardRef(() => CheckboxGroupComponent),
@@ -207,17 +204,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
207
204
  args: ['groupItemsWrapper']
208
205
  }], changed: [{
209
206
  type: Output
210
- }], changeChecked: [{
211
- type: Output
212
207
  }], modelChange: [{
213
208
  type: Output
214
209
  }], changedInner: [{
215
210
  type: Output
216
- }], changeCheckedInner: [{
217
- type: Output
218
211
  }], modelChangeInner: [{
219
212
  type: Output
220
213
  }], modelItemChange: [{
221
214
  type: Output
222
215
  }] } });
223
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox-group.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/checkbox-group/checkbox-group.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/checkbox-group/checkbox-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy, ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef, Injectable,\r\n  Input,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport {\r\n  CheckboxGroupInnerItem,\r\n  CheckboxGroupItem,\r\n  CheckboxGroupValueInnerWithId,\r\n  CheckboxGroupValueWithId\r\n} from './models/checkbox-group.model';\r\nimport { cloneDeep } from 'lodash-es';\r\nimport { getSortedList } from './helpers/get-sorted-list';\r\nimport { filterSearchGroup } from './helpers/filter-search-group';\r\nimport { getItemInnerById } from './helpers/get-item-by-id';\r\nimport { changeItemValue, changeListValue } from './helpers/change-item-value';\r\nimport { changeGroupValue } from './helpers/change-group-value';\r\nimport { getCheckedItems } from './helpers/get-checked-items';\r\nimport { v4 as uuid } from 'uuid';\r\nimport { Field } from '../../../services';\r\nimport { getInnerList } from './helpers/get-inner-list.helper';\r\nimport { innerListToList } from './helpers/inner-list-to-list.helper';\r\n\r\n@Injectable({\r\n  providedIn: CheckboxGroupComponent\r\n})\r\n@Component({\r\n  selector: 'mrx-checkbox-group',\r\n  templateUrl: './checkbox-group.component.html',\r\n  styleUrls: ['./checkbox-group.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => CheckboxGroupComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class CheckboxGroupComponent implements ControlValueAccessor {\r\n  private _groupItemsWrapperHeight = 0;\r\n  private _searchValue = '';\r\n\r\n  public list: CheckboxGroupItem[] = [];\r\n  public innerList: CheckboxGroupInnerItem[] = [];\r\n\r\n  public checkedList: CheckboxGroupInnerItem[] = [];\r\n  public filteredList: CheckboxGroupInnerItem[] = [];\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuid();\r\n  @Input() public fields: Field[] = [];\r\n\r\n  @Input() public scrollMaxHeight = 200;\r\n  @Input() public searchable = false;\r\n  @Input() public scrollable = false;\r\n  @Input() public sortable = false;\r\n  @Input() public disabled = false;\r\n  @Input() public readonly = false;\r\n  @Input() public enableMessage = 'Ничего не найдено';\r\n  @Input() public searchPlaceholder = '';\r\n  @Input() public customClasses = '';\r\n\r\n  // TOOLTIP\r\n  @Input() tooltip = '';\r\n\r\n  // LABEL\r\n  @Input() labelText = '';\r\n  @Input() linkText = '';\r\n\r\n  // VALIDATE\r\n  @Input() public invalid = false;\r\n  @Input() public invalidMessage: string | string[] = '';\r\n\r\n  @Input() set items(list: CheckboxGroupItem[]) {\r\n    this.list = list;\r\n    this._updateModifiedList();\r\n  }\r\n\r\n  get items(): CheckboxGroupInnerItem[] {\r\n    return this.filteredList;\r\n  }\r\n\r\n  @ViewChild('groupItemsWrapper') groupItemsWrapper!: ElementRef;\r\n\r\n  @Output() public changed: EventEmitter<CheckboxGroupItem[]> = new EventEmitter<CheckboxGroupItem[]>();\r\n  @Output() public changeChecked: EventEmitter<CheckboxGroupItem[]> = new EventEmitter<CheckboxGroupItem[]>();\r\n  @Output() public modelChange: EventEmitter<CheckboxGroupValueWithId> = new EventEmitter<CheckboxGroupValueWithId>();\r\n\r\n  @Output() public changedInner: EventEmitter<CheckboxGroupInnerItem[]> = new EventEmitter<CheckboxGroupInnerItem[]>();\r\n  @Output() public changeCheckedInner: EventEmitter<CheckboxGroupInnerItem[]> = new EventEmitter<CheckboxGroupInnerItem[]>();\r\n  @Output() public modelChangeInner: EventEmitter<CheckboxGroupValueInnerWithId> = new EventEmitter<CheckboxGroupValueInnerWithId>();\r\n\r\n  @Output() public modelItemChange: EventEmitter<CheckboxGroupInnerItem> = new EventEmitter<CheckboxGroupInnerItem>();\r\n\r\n  constructor(private _detector: ChangeDetectorRef) {\r\n  }\r\n\r\n  public get isSearchValue(): string {\r\n    return this._searchValue;\r\n  }\r\n\r\n  public get displaced(): boolean {\r\n    return this.list.some((item: CheckboxGroupItem) => item.items?.length);\r\n  }\r\n\r\n  public get getInvalid(): boolean {\r\n    return this.invalid;\r\n  }\r\n\r\n  public get getInvalidMessage(): string | string[] {\r\n    return this.invalidMessage;\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${this.customClasses}`;\r\n  }\r\n\r\n  public get getShowScroll(): boolean {\r\n    return this._groupItemsWrapperHeight > this.scrollMaxHeight;\r\n  }\r\n\r\n  public trackByFn(index: number, item: CheckboxGroupInnerItem) {\r\n    return item.id;\r\n  }\r\n\r\n  private onChange = (value: CheckboxGroupItem[]) => {\r\n  };\r\n  private onTouched = () => {\r\n  };\r\n\r\n  public writeValue(selectedValue: CheckboxGroupItem[]): void {\r\n    if (selectedValue !== null) {\r\n      this.checkedList = getInnerList(selectedValue, this.checkedList);\r\n      this._updateModifiedList();\r\n    }\r\n  }\r\n\r\n  private _updateModifiedList() {\r\n    this.innerList = getInnerList(this.list, this.checkedList);\r\n    this.filteredList = getSortedList(this.innerList, this.sortable);\r\n  }\r\n\r\n  public checkHeightGroupWrapper(): void {\r\n    this._groupItemsWrapperHeight = this.groupItemsWrapper.nativeElement.scrollHeight;\r\n  }\r\n\r\n  public updateCheckboxGroupSearchValue(searchValue: string): void {\r\n    this._searchValue = searchValue;\r\n    this.filteredList = filterSearchGroup(this.innerList, this._searchValue);\r\n  }\r\n\r\n  public checkboxChanged({value, item}: { value: boolean | null; item: CheckboxGroupInnerItem }) {\r\n    const cloneList: CheckboxGroupInnerItem[] = cloneDeep(this.filteredList);\r\n    const findItem: CheckboxGroupInnerItem | null = getItemInnerById(cloneList, item.id);\r\n    let changedItem: CheckboxGroupInnerItem | null = null;\r\n\r\n    if (findItem) {\r\n      changedItem = changeItemValue(findItem, value);\r\n      changeGroupValue(cloneList, item.parentId, value);\r\n      getSortedList(cloneList, this.sortable);\r\n    }\r\n\r\n    this.filteredList = cloneList;\r\n    this.checkedList = getCheckedItems(cloneList);\r\n    this.updateValue(this.filteredList, this.checkedList);\r\n\r\n    if (changedItem) {\r\n      this.modelItemChange.emit(changedItem);\r\n    }\r\n\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  public clearFilters() {\r\n    const cloneList: CheckboxGroupInnerItem[] = cloneDeep(this.filteredList);\r\n\r\n    changeListValue(cloneList, false);\r\n    getSortedList(cloneList, this.sortable);\r\n\r\n    this.filteredList = cloneList;\r\n    this.checkedList = getCheckedItems(cloneList);\r\n    this.updateValue(this.filteredList, this.checkedList);\r\n  }\r\n\r\n  public registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  public updateValue(list: CheckboxGroupItem[], checkedList: CheckboxGroupInnerItem[]): void {\r\n    const clearedList = innerListToList(checkedList)\r\n\r\n    this.changed.emit(clearedList);\r\n    this.changeChecked.emit(clearedList);\r\n    this.modelChange.emit({value: clearedList, id: this.uuid});\r\n\r\n    this.changedInner.emit(checkedList);\r\n    this.changeCheckedInner.emit(checkedList);\r\n    this.modelChangeInner.emit({value: checkedList, id: this.uuid});\r\n\r\n    this.onChange(checkedList);\r\n    this.onTouched();\r\n  }\r\n}\r\n","<div class=\"mrx-checkbox-group\" [class]=\"getClasses\">\r\n  <mrx-save-state [id]=\"uuid\" [fields]=\"fields\" type=\"checkboxGroup\"></mrx-save-state>\r\n\r\n  <mrx-checkbox-group-header\r\n    [searchable]=\"searchable\"\r\n    [searchPlaceholder]=\"searchPlaceholder\"\r\n    [tooltip]=\"tooltip\"\r\n    [labelText]=\"labelText\"\r\n    [linkText]=\"linkText\"\r\n    [checkedItemsCount]=\"checkedList.length\"\r\n    (updateCheckboxGroupSearchValue)=\"updateCheckboxGroupSearchValue($event)\"\r\n    (clearFilters)=\"clearFilters()\"\r\n  ></mrx-checkbox-group-header>\r\n\r\n  <div\r\n      #groupItemsWrapper\r\n      *ngIf=\"filteredList?.length; else enableMessageTemplate\"\r\n      class=\"mrx-checkbox-group-wrapper\"\r\n      [class.mrx-checkbox-group-wrapper--scrollable]=\"scrollable\"\r\n      [class.--active]=\"getShowScroll\"\r\n      [style.max-height]=\"scrollable ? scrollMaxHeight + 'px' : 'auto'\"\r\n  >\r\n    <mrx-checkbox-group-item\r\n        *ngFor=\"let item of filteredList; trackBy: trackByFn; let last = last\"\r\n        [displaced]=\"displaced || false\"\r\n        [item]=\"item\"\r\n        [isLast]=\"last\"\r\n        [animationTrigger]=\"!!isSearchValue\"\r\n        [disabled]=\"disabled\"\r\n        [readonly]=\"readonly\"\r\n        [invalid]=\"invalid\"\r\n        (animationEnd)=\"checkHeightGroupWrapper()\"\r\n        (checkboxChanged)=\"checkboxChanged($event)\"\r\n    ></mrx-checkbox-group-item>\r\n  </div>\r\n\r\n  <ng-template #enableMessageTemplate>\r\n    <p class=\"mrx-checkbox-group__empty-message\">{{ enableMessage }}</p>\r\n  </ng-template>\r\n\r\n  <mrx-error-message\r\n    *ngIf=\"getInvalid && getInvalidMessage\"\r\n    [invalidMessage]=\"getInvalidMessage\"\r\n    [customClasses]=\"'mt-2'\"\r\n  ></mrx-error-message>\r\n</div>\r\n"]}
216
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox-group.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/checkbox-group/checkbox-group.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/checkbox-group/checkbox-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy, ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef, Injectable,\r\n  Input,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport {\r\n  CheckboxGroupInnerItem,\r\n  CheckboxGroupItem,\r\n  CheckboxGroupValueInnerWithId,\r\n  CheckboxGroupValueWithId\r\n} from './models/checkbox-group.model';\r\nimport { cloneDeep } from 'lodash-es';\r\nimport { getSortedList } from './helpers/get-sorted-list';\r\nimport { filterSearchGroup } from './helpers/filter-search-group';\r\nimport { getItemInnerById } from './helpers/get-item-by-id';\r\nimport { changeItemValue, changeListValue } from './helpers/change-item-value';\r\nimport { changeGroupValue } from './helpers/change-group-value';\r\nimport { getCheckedItems } from './helpers/get-checked-items';\r\nimport { v4 as uuid } from 'uuid';\r\nimport { Field } from '../../../services';\r\nimport { getInnerList } from './helpers/get-inner-list.helper';\r\nimport { innerListToList } from './helpers/inner-list-to-list.helper';\r\n\r\n@Injectable({\r\n  providedIn: CheckboxGroupComponent\r\n})\r\n@Component({\r\n  selector: 'mrx-checkbox-group',\r\n  templateUrl: './checkbox-group.component.html',\r\n  styleUrls: ['./checkbox-group.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => CheckboxGroupComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class CheckboxGroupComponent implements ControlValueAccessor {\r\n  private _groupItemsWrapperHeight = 0;\r\n  private _searchValue = '';\r\n\r\n  public list: CheckboxGroupItem[] = [];\r\n  public innerList: CheckboxGroupInnerItem[] = [];\r\n\r\n  public checkedList: CheckboxGroupInnerItem[] = [];\r\n  public filteredList: CheckboxGroupInnerItem[] = [];\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuid();\r\n  @Input() public fields: Field[] = [];\r\n\r\n  @Input() public scrollMaxHeight = 200;\r\n  @Input() public searchable = false;\r\n  @Input() public scrollable = false;\r\n  @Input() public sortable = false;\r\n  @Input() public disabled = false;\r\n  @Input() public readonly = false;\r\n  @Input() public enableMessage = 'Ничего не найдено';\r\n  @Input() public searchPlaceholder = '';\r\n  @Input() public customClasses = '';\r\n\r\n  // TOOLTIP\r\n  @Input() tooltip = '';\r\n\r\n  // LABEL\r\n  @Input() labelText = '';\r\n  @Input() linkText = '';\r\n\r\n  // VALIDATE\r\n  @Input() public invalid = false;\r\n  @Input() public invalidMessage: string | string[] = '';\r\n\r\n  @Input() set items(list: CheckboxGroupItem[]) {\r\n    this.list = list;\r\n    this._updateModifiedList();\r\n  }\r\n\r\n  get items(): CheckboxGroupInnerItem[] {\r\n    return this.filteredList;\r\n  }\r\n\r\n  @ViewChild('groupItemsWrapper') groupItemsWrapper!: ElementRef;\r\n\r\n  @Output() public changed: EventEmitter<CheckboxGroupItem[]> = new EventEmitter<CheckboxGroupItem[]>();\r\n  @Output() public modelChange: EventEmitter<CheckboxGroupValueWithId> = new EventEmitter<CheckboxGroupValueWithId>();\r\n\r\n  @Output() public changedInner: EventEmitter<CheckboxGroupInnerItem[]> = new EventEmitter<CheckboxGroupInnerItem[]>();\r\n  @Output() public modelChangeInner: EventEmitter<CheckboxGroupValueInnerWithId> = new EventEmitter<CheckboxGroupValueInnerWithId>();\r\n\r\n  @Output() public modelItemChange: EventEmitter<CheckboxGroupInnerItem> = new EventEmitter<CheckboxGroupInnerItem>();\r\n\r\n  constructor(private _detector: ChangeDetectorRef) {\r\n  }\r\n\r\n  public get isSearchValue(): string {\r\n    return this._searchValue;\r\n  }\r\n\r\n  public get displaced(): boolean {\r\n    return this.list.some((item: CheckboxGroupItem) => item.items?.length);\r\n  }\r\n\r\n  public get getInvalid(): boolean {\r\n    return this.invalid;\r\n  }\r\n\r\n  public get getInvalidMessage(): string | string[] {\r\n    return this.invalidMessage;\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${this.customClasses}`;\r\n  }\r\n\r\n  public get getShowScroll(): boolean {\r\n    return this._groupItemsWrapperHeight > this.scrollMaxHeight;\r\n  }\r\n\r\n  public trackByFn(index: number, item: CheckboxGroupInnerItem) {\r\n    return item.id;\r\n  }\r\n\r\n  private onChange = (value: CheckboxGroupItem[]) => {\r\n  };\r\n  private onTouched = () => {\r\n  };\r\n\r\n  public writeValue(selectedValue: CheckboxGroupItem[]): void {\r\n    if (selectedValue !== null) {\r\n      this.checkedList = getInnerList(selectedValue, this.checkedList);\r\n      this._updateModifiedList();\r\n    }\r\n  }\r\n\r\n  private _updateModifiedList() {\r\n    this.innerList = getInnerList(this.list, this.checkedList);\r\n    this.filteredList = getSortedList(this.innerList, this.sortable);\r\n  }\r\n\r\n  public checkHeightGroupWrapper(): void {\r\n    this._groupItemsWrapperHeight = this.groupItemsWrapper.nativeElement.scrollHeight;\r\n  }\r\n\r\n  public updateCheckboxGroupSearchValue(searchValue: string): void {\r\n    this._searchValue = searchValue;\r\n    this.filteredList = filterSearchGroup(this.innerList, this._searchValue);\r\n  }\r\n\r\n  public checkboxChanged({value, item}: { value: boolean | null; item: CheckboxGroupInnerItem }) {\r\n    const cloneList: CheckboxGroupInnerItem[] = cloneDeep(this.filteredList);\r\n    const findItem: CheckboxGroupInnerItem | null = getItemInnerById(cloneList, item.id);\r\n    let changedItem: CheckboxGroupInnerItem | null = null;\r\n\r\n    if (findItem) {\r\n      changedItem = changeItemValue(findItem, value);\r\n      changeGroupValue(cloneList, item.parentId, value);\r\n      getSortedList(cloneList, this.sortable);\r\n    }\r\n\r\n    this.filteredList = cloneList;\r\n    this.checkedList = getCheckedItems(cloneList);\r\n    this.updateValue(this.filteredList, this.checkedList);\r\n\r\n    if (changedItem) {\r\n      this.modelItemChange.emit(changedItem);\r\n    }\r\n\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  public clearFilters() {\r\n    const cloneList: CheckboxGroupInnerItem[] = cloneDeep(this.filteredList);\r\n\r\n    changeListValue(cloneList, false);\r\n    getSortedList(cloneList, this.sortable);\r\n\r\n    this.filteredList = cloneList;\r\n    this.checkedList = getCheckedItems(cloneList);\r\n    this.updateValue(this.filteredList, this.checkedList);\r\n  }\r\n\r\n  public registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  public updateValue(list: CheckboxGroupItem[], checkedList: CheckboxGroupInnerItem[]): void {\r\n    const clearedList = innerListToList(checkedList)\r\n    const clearedInnerList = innerListToList(this.innerList)\r\n\r\n    this.changed.emit(clearedList);\r\n    this.modelChange.emit({value: clearedList, full: clearedInnerList, id: this.uuid});\r\n\r\n    this.changedInner.emit(checkedList);\r\n    this.modelChangeInner.emit({value: checkedList, full: this.innerList, id: this.uuid});\r\n\r\n    this.onChange(checkedList);\r\n    this.onTouched();\r\n  }\r\n}\r\n","<div class=\"mrx-checkbox-group\" [class]=\"getClasses\">\r\n  <mrx-save-state [id]=\"uuid\" [fields]=\"fields\" type=\"checkboxGroup\"></mrx-save-state>\r\n\r\n  <mrx-checkbox-group-header\r\n    [searchable]=\"searchable\"\r\n    [searchPlaceholder]=\"searchPlaceholder\"\r\n    [tooltip]=\"tooltip\"\r\n    [labelText]=\"labelText\"\r\n    [linkText]=\"linkText\"\r\n    [checkedItemsCount]=\"checkedList.length\"\r\n    (updateCheckboxGroupSearchValue)=\"updateCheckboxGroupSearchValue($event)\"\r\n    (clearFilters)=\"clearFilters()\"\r\n  ></mrx-checkbox-group-header>\r\n\r\n  <div\r\n      #groupItemsWrapper\r\n      *ngIf=\"filteredList?.length; else enableMessageTemplate\"\r\n      class=\"mrx-checkbox-group-wrapper\"\r\n      [class.mrx-checkbox-group-wrapper--scrollable]=\"scrollable\"\r\n      [class.--active]=\"getShowScroll\"\r\n      [style.max-height]=\"scrollable ? scrollMaxHeight + 'px' : 'auto'\"\r\n  >\r\n    <mrx-checkbox-group-item\r\n        *ngFor=\"let item of filteredList; trackBy: trackByFn; let last = last\"\r\n        [displaced]=\"displaced || false\"\r\n        [item]=\"item\"\r\n        [isLast]=\"last\"\r\n        [animationTrigger]=\"!!isSearchValue\"\r\n        [disabled]=\"disabled\"\r\n        [readonly]=\"readonly\"\r\n        [invalid]=\"invalid\"\r\n        (animationEnd)=\"checkHeightGroupWrapper()\"\r\n        (checkboxChanged)=\"checkboxChanged($event)\"\r\n    ></mrx-checkbox-group-item>\r\n  </div>\r\n\r\n  <ng-template #enableMessageTemplate>\r\n    <p class=\"mrx-checkbox-group__empty-message\">{{ enableMessage }}</p>\r\n  </ng-template>\r\n\r\n  <mrx-error-message\r\n    *ngIf=\"getInvalid && getInvalidMessage\"\r\n    [invalidMessage]=\"getInvalidMessage\"\r\n    [customClasses]=\"'mt-2'\"\r\n  ></mrx-error-message>\r\n</div>\r\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3gtZ3JvdXAubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9jaGVja2JveC1ncm91cC9tb2RlbHMvY2hlY2tib3gtZ3JvdXAubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgQ2hlY2tib3hHcm91cEl0ZW0ge1xyXG4gIGlkOiBzdHJpbmcgfCBudW1iZXIsXHJcbiAgdGV4dDogc3RyaW5nLFxyXG4gIGl0ZW1zPzogQ2hlY2tib3hHcm91cEl0ZW1bXSxcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBDaGVja2JveEdyb3VwSW5uZXJJdGVtIHtcclxuICBpZDogc3RyaW5nIHwgbnVtYmVyLFxyXG4gIHRleHQ6IHN0cmluZyxcclxuICBwYXJlbnRJZDogc3RyaW5nIHwgbnVtYmVyIHwgbnVsbCxcclxuICB2YWx1ZTogYm9vbGVhbiB8IG51bGwsXHJcbiAgdHlwZTogJ3NpbmdsZScgfCAnYXJyYXknLFxyXG4gIGl0ZW1zOiBDaGVja2JveEdyb3VwSW5uZXJJdGVtW10sXHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIENoZWNrYm94SW5kZXRlcm1pbmF0ZVN0YXRlID0gYm9vbGVhbiB8IG51bGxcclxuXHJcbmV4cG9ydCB0eXBlIENoZWNrYm94R3JvdXBTZWFyY2hWYWx1ZSA9IHN0cmluZ1xyXG5cclxuZXhwb3J0IHR5cGUgQW5pbWF0ZUNoZWNrYm94R3JvdXBTdGF0ZSA9ICdvcGVuJyB8ICdjbG9zZScgfCAnc3VzdGFpbidcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQ2hlY2tib3hHcm91cFZhbHVlV2l0aElkIHtcclxuICB2YWx1ZTogQ2hlY2tib3hHcm91cEl0ZW1bXSxcclxuICBpZDogc3RyaW5nXHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQ2hlY2tib3hHcm91cFZhbHVlSW5uZXJXaXRoSWQge1xyXG4gIHZhbHVlOiBDaGVja2JveEdyb3VwSW5uZXJJdGVtW10sXHJcbiAgaWQ6IHN0cmluZ1xyXG59XHJcbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3gtZ3JvdXAubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9jaGVja2JveC1ncm91cC9tb2RlbHMvY2hlY2tib3gtZ3JvdXAubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgQ2hlY2tib3hHcm91cEl0ZW0ge1xyXG4gIGlkOiBzdHJpbmcgfCBudW1iZXIsXHJcbiAgdGV4dDogc3RyaW5nLFxyXG4gIGl0ZW1zPzogQ2hlY2tib3hHcm91cEl0ZW1bXSxcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBDaGVja2JveEdyb3VwSW5uZXJJdGVtIHtcclxuICBpZDogc3RyaW5nIHwgbnVtYmVyLFxyXG4gIHRleHQ6IHN0cmluZyxcclxuICBwYXJlbnRJZDogc3RyaW5nIHwgbnVtYmVyIHwgbnVsbCxcclxuICB2YWx1ZTogYm9vbGVhbiB8IG51bGwsXHJcbiAgdHlwZTogJ3NpbmdsZScgfCAnYXJyYXknLFxyXG4gIGl0ZW1zOiBDaGVja2JveEdyb3VwSW5uZXJJdGVtW10sXHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIENoZWNrYm94SW5kZXRlcm1pbmF0ZVN0YXRlID0gYm9vbGVhbiB8IG51bGxcclxuXHJcbmV4cG9ydCB0eXBlIENoZWNrYm94R3JvdXBTZWFyY2hWYWx1ZSA9IHN0cmluZ1xyXG5cclxuZXhwb3J0IHR5cGUgQW5pbWF0ZUNoZWNrYm94R3JvdXBTdGF0ZSA9ICdvcGVuJyB8ICdjbG9zZScgfCAnc3VzdGFpbidcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQ2hlY2tib3hHcm91cFZhbHVlV2l0aElkIHtcclxuICB2YWx1ZTogQ2hlY2tib3hHcm91cEl0ZW1bXSxcclxuICBmdWxsOiBDaGVja2JveEdyb3VwSXRlbVtdLFxyXG4gIGlkOiBzdHJpbmdcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBDaGVja2JveEdyb3VwVmFsdWVJbm5lcldpdGhJZCB7XHJcbiAgdmFsdWU6IENoZWNrYm94R3JvdXBJbm5lckl0ZW1bXSxcclxuICBmdWxsOiBDaGVja2JveEdyb3VwSW5uZXJJdGVtW10sXHJcbiAgaWQ6IHN0cmluZ1xyXG59XHJcbiJdfQ==
@@ -12610,10 +12610,8 @@ class CheckboxGroupComponent {
12610
12610
  }
12611
12611
  groupItemsWrapper;
12612
12612
  changed = new EventEmitter();
12613
- changeChecked = new EventEmitter();
12614
12613
  modelChange = new EventEmitter();
12615
12614
  changedInner = new EventEmitter();
12616
- changeCheckedInner = new EventEmitter();
12617
12615
  modelChangeInner = new EventEmitter();
12618
12616
  modelItemChange = new EventEmitter();
12619
12617
  constructor(_detector) {
@@ -12694,17 +12692,16 @@ class CheckboxGroupComponent {
12694
12692
  }
12695
12693
  updateValue(list, checkedList) {
12696
12694
  const clearedList = innerListToList(checkedList);
12695
+ const clearedInnerList = innerListToList(this.innerList);
12697
12696
  this.changed.emit(clearedList);
12698
- this.changeChecked.emit(clearedList);
12699
- this.modelChange.emit({ value: clearedList, id: this.uuid });
12697
+ this.modelChange.emit({ value: clearedList, full: clearedInnerList, id: this.uuid });
12700
12698
  this.changedInner.emit(checkedList);
12701
- this.changeCheckedInner.emit(checkedList);
12702
- this.modelChangeInner.emit({ value: checkedList, id: this.uuid });
12699
+ this.modelChangeInner.emit({ value: checkedList, full: this.innerList, id: this.uuid });
12703
12700
  this.onChange(checkedList);
12704
12701
  this.onTouched();
12705
12702
  }
12706
12703
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: CheckboxGroupComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
12707
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: CheckboxGroupComponent, selector: "mrx-checkbox-group", inputs: { fields: "fields", scrollMaxHeight: "scrollMaxHeight", searchable: "searchable", scrollable: "scrollable", sortable: "sortable", disabled: "disabled", readonly: "readonly", enableMessage: "enableMessage", searchPlaceholder: "searchPlaceholder", customClasses: "customClasses", tooltip: "tooltip", labelText: "labelText", linkText: "linkText", invalid: "invalid", invalidMessage: "invalidMessage", items: "items" }, outputs: { changed: "changed", changeChecked: "changeChecked", modelChange: "modelChange", changedInner: "changedInner", changeCheckedInner: "changeCheckedInner", modelChangeInner: "modelChangeInner", modelItemChange: "modelItemChange" }, providers: [
12704
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: CheckboxGroupComponent, selector: "mrx-checkbox-group", inputs: { fields: "fields", scrollMaxHeight: "scrollMaxHeight", searchable: "searchable", scrollable: "scrollable", sortable: "sortable", disabled: "disabled", readonly: "readonly", enableMessage: "enableMessage", searchPlaceholder: "searchPlaceholder", customClasses: "customClasses", tooltip: "tooltip", labelText: "labelText", linkText: "linkText", invalid: "invalid", invalidMessage: "invalidMessage", items: "items" }, outputs: { changed: "changed", modelChange: "modelChange", changedInner: "changedInner", modelChangeInner: "modelChangeInner", modelItemChange: "modelItemChange" }, providers: [
12708
12705
  {
12709
12706
  provide: NG_VALUE_ACCESSOR,
12710
12707
  useExisting: forwardRef(() => CheckboxGroupComponent),
@@ -12764,14 +12761,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
12764
12761
  args: ['groupItemsWrapper']
12765
12762
  }], changed: [{
12766
12763
  type: Output
12767
- }], changeChecked: [{
12768
- type: Output
12769
12764
  }], modelChange: [{
12770
12765
  type: Output
12771
12766
  }], changedInner: [{
12772
12767
  type: Output
12773
- }], changeCheckedInner: [{
12774
- type: Output
12775
12768
  }], modelChangeInner: [{
12776
12769
  type: Output
12777
12770
  }], modelItemChange: [{