myrta-ui 1.1.35 → 1.1.37
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.
- package/esm2020/lib/components/form/checkbox-group/checkbox-group.component.mjs +60 -37
- package/esm2020/lib/components/form/checkbox-group/components/checkbox-group-header/checkbox-group-header.component.mjs +4 -4
- package/esm2020/lib/components/form/checkbox-group/components/checkbox-group-item/checkbox-group-item.component.mjs +42 -43
- package/esm2020/lib/components/form/checkbox-group/helpers/change-group-value.mjs +7 -8
- package/esm2020/lib/components/form/checkbox-group/helpers/change-item-value.mjs +2 -2
- package/esm2020/lib/components/form/checkbox-group/helpers/filter-search-group.mjs +5 -5
- package/esm2020/lib/components/form/checkbox-group/helpers/get-checked-items.mjs +2 -2
- package/esm2020/lib/components/form/checkbox-group/helpers/get-inner-list.helper.mjs +46 -0
- package/esm2020/lib/components/form/checkbox-group/helpers/get-item-by-id.mjs +4 -4
- package/esm2020/lib/components/form/checkbox-group/helpers/get-sorted-list.mjs +2 -2
- package/esm2020/lib/components/form/checkbox-group/models/checkbox-group.model.mjs +1 -1
- package/esm2020/lib/components/form/radio-group/components/radio-group-item/radio-group-item.component.mjs +3 -3
- package/esm2020/lib/services/mrx-form-validator/helpers/get-sorting-validations.helper.mjs +4 -3
- package/esm2020/lib/services/mrx-form-validator/validations/max-length.validation.mjs +6 -2
- package/esm2020/lib/services/mrx-form-validator/validations/max-value.validation.mjs +1 -1
- package/esm2020/lib/services/mrx-form-validator/validations/min-length.validation.mjs +6 -2
- package/esm2020/lib/services/mrx-form-validator/validations/required.validation.mjs +1 -1
- package/fesm2015/myrta-ui.mjs +173 -98
- package/fesm2015/myrta-ui.mjs.map +1 -1
- package/fesm2020/myrta-ui.mjs +172 -98
- package/fesm2020/myrta-ui.mjs.map +1 -1
- package/lib/components/form/checkbox-group/checkbox-group.component.d.ts +21 -14
- package/lib/components/form/checkbox-group/components/checkbox-group-item/checkbox-group-item.component.d.ts +13 -9
- package/lib/components/form/checkbox-group/helpers/change-group-value.d.ts +3 -3
- package/lib/components/form/checkbox-group/helpers/change-item-value.d.ts +3 -3
- package/lib/components/form/checkbox-group/helpers/filter-search-group.d.ts +2 -2
- package/lib/components/form/checkbox-group/helpers/get-checked-items.d.ts +2 -2
- package/lib/components/form/checkbox-group/helpers/get-inner-list.helper.d.ts +2 -0
- package/lib/components/form/checkbox-group/helpers/get-item-by-id.d.ts +2 -2
- package/lib/components/form/checkbox-group/helpers/get-sorted-list.d.ts +2 -2
- package/lib/components/form/checkbox-group/models/checkbox-group.model.d.ts +7 -2
- package/lib/services/mrx-form-validator/helpers/get-sorting-validations.helper.d.ts +1 -1
- package/package.json +1 -1
|
@@ -3,28 +3,31 @@ import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
|
3
3
|
import { cloneDeep } from 'lodash-es';
|
|
4
4
|
import { getSortedList } from './helpers/get-sorted-list';
|
|
5
5
|
import { filterSearchGroup } from './helpers/filter-search-group';
|
|
6
|
-
import {
|
|
6
|
+
import { getItemInnerById } from './helpers/get-item-by-id';
|
|
7
7
|
import { changeItemValue, changeListValue } from './helpers/change-item-value';
|
|
8
8
|
import { changeGroupValue } from './helpers/change-group-value';
|
|
9
9
|
import { getCheckedItems } from './helpers/get-checked-items';
|
|
10
10
|
import { v4 as uuid } from 'uuid';
|
|
11
|
+
import { getInnerList } from './helpers/get-inner-list.helper';
|
|
11
12
|
import * as i0 from "@angular/core";
|
|
12
13
|
import * as i1 from "../../save-state/save-state.component";
|
|
13
14
|
import * as i2 from "./components/checkbox-group-header/checkbox-group-header.component";
|
|
14
15
|
import * as i3 from "./components/checkbox-group-item/checkbox-group-item.component";
|
|
15
|
-
import * as i4 from "
|
|
16
|
+
import * as i4 from "../../error-message/error-message.component";
|
|
17
|
+
import * as i5 from "@angular/common";
|
|
16
18
|
export class CheckboxGroupComponent {
|
|
17
|
-
constructor() {
|
|
19
|
+
constructor(_detector) {
|
|
20
|
+
this._detector = _detector;
|
|
18
21
|
this._isInit = false;
|
|
19
22
|
this._groupItemsWrapperHeight = 0;
|
|
20
23
|
this._searchValue = '';
|
|
21
24
|
this.list = [];
|
|
22
|
-
this.
|
|
25
|
+
this.innerList = [];
|
|
23
26
|
this.checkedList = [];
|
|
27
|
+
this.filteredList = [];
|
|
24
28
|
// SAVE STATE
|
|
25
29
|
this.uuid = uuid();
|
|
26
30
|
this.fields = [];
|
|
27
|
-
this.items = [];
|
|
28
31
|
this.scrollMaxHeight = 200;
|
|
29
32
|
this.searchable = false;
|
|
30
33
|
this.scrollable = false;
|
|
@@ -39,19 +42,34 @@ export class CheckboxGroupComponent {
|
|
|
39
42
|
// LABEL
|
|
40
43
|
this.labelText = '';
|
|
41
44
|
this.linkText = '';
|
|
45
|
+
// VALIDATE
|
|
46
|
+
this.invalid = false;
|
|
47
|
+
this.invalidMessage = '';
|
|
42
48
|
this.changed = new EventEmitter();
|
|
43
49
|
this.changeChecked = new EventEmitter();
|
|
44
50
|
this.modelChange = new EventEmitter();
|
|
45
|
-
this.
|
|
51
|
+
this.modelChangeInner = new EventEmitter();
|
|
46
52
|
this.modelItemChange = new EventEmitter();
|
|
47
53
|
this.onChange = (value) => { };
|
|
48
54
|
this.onTouched = () => { };
|
|
49
55
|
}
|
|
56
|
+
set items(list) {
|
|
57
|
+
this.list = list;
|
|
58
|
+
}
|
|
59
|
+
get items() {
|
|
60
|
+
return this.filteredList;
|
|
61
|
+
}
|
|
50
62
|
get isSearchValue() {
|
|
51
63
|
return this._searchValue;
|
|
52
64
|
}
|
|
53
65
|
get displaced() {
|
|
54
|
-
return this.list.some((item) => item.
|
|
66
|
+
return this.list.some((item) => item.items?.length);
|
|
67
|
+
}
|
|
68
|
+
get getInvalid() {
|
|
69
|
+
return this.invalid;
|
|
70
|
+
}
|
|
71
|
+
get getInvalidMessage() {
|
|
72
|
+
return this.invalidMessage;
|
|
55
73
|
}
|
|
56
74
|
get getClasses() {
|
|
57
75
|
return `${this.customClasses}`;
|
|
@@ -62,38 +80,24 @@ export class CheckboxGroupComponent {
|
|
|
62
80
|
trackByFn(index, item) {
|
|
63
81
|
return item.id;
|
|
64
82
|
}
|
|
65
|
-
writeValue(
|
|
66
|
-
if (
|
|
67
|
-
this.
|
|
68
|
-
this.
|
|
69
|
-
this.
|
|
83
|
+
writeValue(selectedValue) {
|
|
84
|
+
if (selectedValue !== null) {
|
|
85
|
+
this.checkedList = selectedValue;
|
|
86
|
+
this.innerList = getInnerList(this.list, this.checkedList);
|
|
87
|
+
this.filteredList = getSortedList(this.innerList, this.sortable);
|
|
70
88
|
this._isInit = true;
|
|
71
89
|
}
|
|
72
90
|
}
|
|
73
|
-
registerOnChange(fn) {
|
|
74
|
-
this.onChange = fn;
|
|
75
|
-
}
|
|
76
|
-
registerOnTouched(fn) {
|
|
77
|
-
this.onTouched = fn;
|
|
78
|
-
}
|
|
79
|
-
updateValue(list, checkedList) {
|
|
80
|
-
this.changed.emit(list);
|
|
81
|
-
this.changeChecked.emit();
|
|
82
|
-
this.modelChange.emit({ value: list, id: this.uuid });
|
|
83
|
-
this.modelCheckedChange.emit({ value: checkedList, id: this.uuid });
|
|
84
|
-
this.onChange(list);
|
|
85
|
-
this.onTouched();
|
|
86
|
-
}
|
|
87
91
|
checkHeightGroupWrapper() {
|
|
88
92
|
this._groupItemsWrapperHeight = this.groupItemsWrapper.nativeElement.scrollHeight;
|
|
89
93
|
}
|
|
90
94
|
updateCheckboxGroupSearchValue(searchValue) {
|
|
91
95
|
this._searchValue = searchValue;
|
|
92
|
-
this.filteredList = filterSearchGroup(this.
|
|
96
|
+
this.filteredList = filterSearchGroup(this.innerList, this._searchValue);
|
|
93
97
|
}
|
|
94
98
|
checkboxChanged({ value, item }) {
|
|
95
99
|
const cloneList = cloneDeep(this.filteredList);
|
|
96
|
-
const findItem =
|
|
100
|
+
const findItem = getItemInnerById(cloneList, item.id);
|
|
97
101
|
let changedItem = null;
|
|
98
102
|
if (findItem) {
|
|
99
103
|
changedItem = changeItemValue(findItem, value);
|
|
@@ -106,6 +110,7 @@ export class CheckboxGroupComponent {
|
|
|
106
110
|
if (changedItem) {
|
|
107
111
|
this.modelItemChange.emit(changedItem);
|
|
108
112
|
}
|
|
113
|
+
this._detector.detectChanges();
|
|
109
114
|
}
|
|
110
115
|
clearFilters() {
|
|
111
116
|
const cloneList = cloneDeep(this.filteredList);
|
|
@@ -115,15 +120,29 @@ export class CheckboxGroupComponent {
|
|
|
115
120
|
this.checkedList = getCheckedItems(cloneList);
|
|
116
121
|
this.updateValue(this.filteredList, this.checkedList);
|
|
117
122
|
}
|
|
123
|
+
registerOnChange(fn) {
|
|
124
|
+
this.onChange = fn;
|
|
125
|
+
}
|
|
126
|
+
registerOnTouched(fn) {
|
|
127
|
+
this.onTouched = fn;
|
|
128
|
+
}
|
|
129
|
+
updateValue(list, checkedList) {
|
|
130
|
+
this.changed.emit(checkedList);
|
|
131
|
+
this.changeChecked.emit();
|
|
132
|
+
this.modelChange.emit({ value: checkedList, id: this.uuid });
|
|
133
|
+
this.modelChangeInner.emit({ value: this.innerList, id: this.uuid });
|
|
134
|
+
this.onChange(checkedList);
|
|
135
|
+
this.onTouched();
|
|
136
|
+
}
|
|
118
137
|
}
|
|
119
|
-
CheckboxGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: CheckboxGroupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
120
|
-
CheckboxGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: CheckboxGroupComponent, selector: "mrx-checkbox-group", inputs: { fields: "fields",
|
|
138
|
+
CheckboxGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: CheckboxGroupComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
139
|
+
CheckboxGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", 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", modelChangeInner: "modelChangeInner", modelItemChange: "modelItemChange" }, providers: [
|
|
121
140
|
{
|
|
122
141
|
provide: NG_VALUE_ACCESSOR,
|
|
123
142
|
useExisting: forwardRef(() => CheckboxGroupComponent),
|
|
124
143
|
multi: true,
|
|
125
144
|
},
|
|
126
|
-
], viewQueries: [{ propertyName: "groupItemsWrapper", first: true, predicate: ["groupItemsWrapper"], descendants: true }], ngImport: i0, template: "<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; 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 (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</div>\r\n", styles: [".mrx-checkbox-group{position:relative}.mrx-checkbox-group-wrapper--scrollable{overflow-y:auto;border-width:1px 0 1px 0;border-style:solid;border-color:transparent;padding-top:0;padding-bottom:0;transition:boder-color .2s,padding-top .2s,padding-bottom .2s}.mrx-checkbox-group-wrapper--scrollable::-webkit-scrollbar{width:8px;height:8px}.mrx-checkbox-group-wrapper--scrollable::-webkit-scrollbar-thumb{background:var(--neutral-bg-stroke-default);border-radius:8px}.mrx-checkbox-group-wrapper--scrollable.--active{padding-top:12px;padding-bottom:12px;border-color:var(--neutral-bg-divider)}.mrx-checkbox-group__empty-message{padding-top:12px;padding-bottom:12px}\n"], components: [{ type: i1.SaveStateComponent, selector: "mrx-save-state", inputs: ["type", "fields", "id"] }, { type: i2.CheckboxGroupHeaderComponent, selector: "mrx-checkbox-group-header", inputs: ["searchable", "searchPlaceholder", "tooltip", "labelText", "linkText", "checkedItemsCount"], outputs: ["updateCheckboxGroupSearchValue", "clearFilters"] }, { type: i3.CheckboxGroupItemComponent, selector: "mrx-checkbox-group-item", inputs: ["
|
|
145
|
+
], viewQueries: [{ propertyName: "groupItemsWrapper", first: true, predicate: ["groupItemsWrapper"], descendants: true }], ngImport: i0, template: "<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 ></mrx-error-message>\r\n</div>\r\n", styles: [".mrx-checkbox-group{position:relative}.mrx-checkbox-group-wrapper--scrollable{overflow-y:auto;border-width:1px 0 1px 0;border-style:solid;border-color:transparent;padding-top:0;padding-bottom:0;transition:boder-color .2s,padding-top .2s,padding-bottom .2s}.mrx-checkbox-group-wrapper--scrollable::-webkit-scrollbar{width:8px;height:8px}.mrx-checkbox-group-wrapper--scrollable::-webkit-scrollbar-thumb{background:var(--neutral-bg-stroke-default);border-radius:8px}.mrx-checkbox-group-wrapper--scrollable.--active{padding-top:12px;padding-bottom:12px;border-color:var(--neutral-bg-divider)}.mrx-checkbox-group__empty-message{padding-top:12px;padding-bottom:12px}\n"], components: [{ type: i1.SaveStateComponent, selector: "mrx-save-state", inputs: ["type", "fields", "id"] }, { type: i2.CheckboxGroupHeaderComponent, selector: "mrx-checkbox-group-header", inputs: ["searchable", "searchPlaceholder", "tooltip", "labelText", "linkText", "checkedItemsCount"], outputs: ["updateCheckboxGroupSearchValue", "clearFilters"] }, { type: i3.CheckboxGroupItemComponent, selector: "mrx-checkbox-group-item", inputs: ["displaced", "level", "animationTrigger", "isLast", "disabled", "readonly", "invalid", "item"], outputs: ["animationEnd", "checkboxChanged"] }, { type: i4.ErrorMessageComponent, selector: "mrx-error-message", inputs: ["invalid", "invalidMessage", "customClasses"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
127
146
|
CheckboxGroupComponent.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: CheckboxGroupComponent, providedIn: CheckboxGroupComponent });
|
|
128
147
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: CheckboxGroupComponent, decorators: [{
|
|
129
148
|
type: Injectable,
|
|
@@ -138,10 +157,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
138
157
|
useExisting: forwardRef(() => CheckboxGroupComponent),
|
|
139
158
|
multi: true,
|
|
140
159
|
},
|
|
141
|
-
], template: "<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; 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 (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</div>\r\n", styles: [".mrx-checkbox-group{position:relative}.mrx-checkbox-group-wrapper--scrollable{overflow-y:auto;border-width:1px 0 1px 0;border-style:solid;border-color:transparent;padding-top:0;padding-bottom:0;transition:boder-color .2s,padding-top .2s,padding-bottom .2s}.mrx-checkbox-group-wrapper--scrollable::-webkit-scrollbar{width:8px;height:8px}.mrx-checkbox-group-wrapper--scrollable::-webkit-scrollbar-thumb{background:var(--neutral-bg-stroke-default);border-radius:8px}.mrx-checkbox-group-wrapper--scrollable.--active{padding-top:12px;padding-bottom:12px;border-color:var(--neutral-bg-divider)}.mrx-checkbox-group__empty-message{padding-top:12px;padding-bottom:12px}\n"] }]
|
|
142
|
-
}], ctorParameters: function () { return []; }, propDecorators: { fields: [{
|
|
143
|
-
type: Input
|
|
144
|
-
}], items: [{
|
|
160
|
+
], template: "<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 ></mrx-error-message>\r\n</div>\r\n", styles: [".mrx-checkbox-group{position:relative}.mrx-checkbox-group-wrapper--scrollable{overflow-y:auto;border-width:1px 0 1px 0;border-style:solid;border-color:transparent;padding-top:0;padding-bottom:0;transition:boder-color .2s,padding-top .2s,padding-bottom .2s}.mrx-checkbox-group-wrapper--scrollable::-webkit-scrollbar{width:8px;height:8px}.mrx-checkbox-group-wrapper--scrollable::-webkit-scrollbar-thumb{background:var(--neutral-bg-stroke-default);border-radius:8px}.mrx-checkbox-group-wrapper--scrollable.--active{padding-top:12px;padding-bottom:12px;border-color:var(--neutral-bg-divider)}.mrx-checkbox-group__empty-message{padding-top:12px;padding-bottom:12px}\n"] }]
|
|
161
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { fields: [{
|
|
145
162
|
type: Input
|
|
146
163
|
}], scrollMaxHeight: [{
|
|
147
164
|
type: Input
|
|
@@ -167,6 +184,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
167
184
|
type: Input
|
|
168
185
|
}], linkText: [{
|
|
169
186
|
type: Input
|
|
187
|
+
}], invalid: [{
|
|
188
|
+
type: Input
|
|
189
|
+
}], invalidMessage: [{
|
|
190
|
+
type: Input
|
|
191
|
+
}], items: [{
|
|
192
|
+
type: Input
|
|
170
193
|
}], groupItemsWrapper: [{
|
|
171
194
|
type: ViewChild,
|
|
172
195
|
args: ['groupItemsWrapper']
|
|
@@ -176,9 +199,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
176
199
|
type: Output
|
|
177
200
|
}], modelChange: [{
|
|
178
201
|
type: Output
|
|
179
|
-
}],
|
|
202
|
+
}], modelChangeInner: [{
|
|
180
203
|
type: Output
|
|
181
204
|
}], modelItemChange: [{
|
|
182
205
|
type: Output
|
|
183
206
|
}] } });
|
|
184
|
-
//# 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,\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 { CheckboxGroupItem, CheckboxGroupValueWithId } 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 { getItemById } 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/mrx-autosave/mrx-autosave.service';\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 _isInit = false\r\n  private _groupItemsWrapperHeight = 0\r\n  private _searchValue = ''\r\n\r\n  public list: CheckboxGroupItem[] = []\r\n  public filteredList: CheckboxGroupItem[] = []\r\n  public checkedList: CheckboxGroupItem[] = []\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuid()\r\n  @Input() public fields: Field[] = [];\r\n\r\n  @Input() public items: CheckboxGroupItem[] = []\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  @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  @Output() public modelCheckedChange: EventEmitter<CheckboxGroupValueWithId> = new EventEmitter<CheckboxGroupValueWithId>();\r\n  @Output() public modelItemChange: EventEmitter<CheckboxGroupItem> = new EventEmitter<CheckboxGroupItem>();\r\n\r\n  constructor() {}\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.array.length)\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: CheckboxGroupItem) {\r\n    return item.id;\r\n  }\r\n\r\n  private onChange = (value: CheckboxGroupItem[]) => {};\r\n  private onTouched = () => {};\r\n\r\n  public writeValue(list: CheckboxGroupItem[]): void {\r\n    if (list) {\r\n      this.list = list\r\n      this.filteredList = getSortedList(list, this.sortable)\r\n      this.checkedList = getCheckedItems(list)\r\n\r\n      this._isInit = true\r\n    }\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: CheckboxGroupItem[]): void {\r\n    this.changed.emit(list);\r\n    this.changeChecked.emit()\r\n    this.modelChange.emit({value: list, id: this.uuid})\r\n    this.modelCheckedChange.emit({value: checkedList, id: this.uuid})\r\n    this.onChange(list);\r\n    this.onTouched();\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.list, this._searchValue)\r\n  }\r\n\r\n  checkboxChanged({ value, item }: { value: boolean | null; item: CheckboxGroupItem }) {\r\n    const cloneList: CheckboxGroupItem[] = cloneDeep(this.filteredList)\r\n    const findItem: CheckboxGroupItem | null = getItemById(cloneList, item.id)\r\n    let changedItem: CheckboxGroupItem | 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\r\n  clearFilters() {\r\n    const cloneList: CheckboxGroupItem[] = 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","<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; 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        (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</div>\r\n"]}
|
|
207
|
+
//# 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 { CheckboxGroupInnerItem, CheckboxGroupItem, CheckboxGroupValueWithId } 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\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 _isInit = false\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: CheckboxGroupItem[] = []\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  }\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  @Output() public modelChangeInner: EventEmitter<CheckboxGroupValueWithId> = new EventEmitter<CheckboxGroupValueWithId>();\r\n  @Output() public modelItemChange: EventEmitter<CheckboxGroupItem> = new EventEmitter<CheckboxGroupItem>();\r\n\r\n  constructor(private _detector: ChangeDetectorRef) {}\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  private onTouched = () => {};\r\n\r\n  public writeValue(selectedValue: CheckboxGroupItem[]): void {\r\n    if (selectedValue !== null) {\r\n      this.checkedList = selectedValue\r\n      this.innerList = getInnerList(this.list, this.checkedList)\r\n      this.filteredList = getSortedList(this.innerList, this.sortable)\r\n      this._isInit = true\r\n    }\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: CheckboxGroupItem[]): void {\r\n    this.changed.emit(checkedList);\r\n    this.changeChecked.emit()\r\n    this.modelChange.emit({value: checkedList, id: this.uuid})\r\n    this.modelChangeInner.emit({value: this.innerList, id: this.uuid})\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  ></mrx-error-message>\r\n</div>\r\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
import * as i1 from "../../../../label/label.component";
|
|
4
4
|
import * as i2 from "../../../input-search/input-search.component";
|
|
@@ -25,10 +25,10 @@ export class CheckboxGroupHeaderComponent {
|
|
|
25
25
|
}
|
|
26
26
|
}
|
|
27
27
|
CheckboxGroupHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: CheckboxGroupHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
28
|
-
CheckboxGroupHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: CheckboxGroupHeaderComponent, selector: "mrx-checkbox-group-header", inputs: { searchable: "searchable", searchPlaceholder: "searchPlaceholder", tooltip: "tooltip", labelText: "labelText", linkText: "linkText", checkedItemsCount: "checkedItemsCount" }, outputs: { updateCheckboxGroupSearchValue: "updateCheckboxGroupSearchValue", clearFilters: "clearFilters" }, ngImport: i0, template: "<mrx-label\r\n *ngIf=\"labelText\"\r\n [counter]=\"checkedItemsCount\"\r\n [linkText]=\"linkText\"\r\n [tooltip]=\"tooltip\"\r\n (clickedLink)=\"onClearFilters()\"\r\n>{{ labelText }}</mrx-label>\r\n\r\n<div class=\"mrx-checkbox-group-head--search\" *ngIf=\"searchable\">\r\n <mrx-input-search\r\n [ngModel]=\"searchValue\"\r\n [size]=\"'medium'\"\r\n [placeholder]=\"searchPlaceholder\"\r\n (ngModelChange)=\"changeSearchValue($event)\"\r\n ></mrx-input-search>\r\n</div>\r\n", styles: [".mrx-checkbox-group-head--search{margin-bottom:12px}\n"], components: [{ type: i1.LabelComponent, selector: "mrx-label", inputs: ["requiredHidden", "required", "boldLabel", "disabled", "placeholder", "label", "customClasses", "triggerTextPosition", "isPublicInfo", "publicInfoTooltip", "isSwitch", "switchLabel", "switchValue", "counter", "linkText", "linkPrevent", "linkType", "linkMonochrome", "href", "triggerType", "tooltip", "tooltipInitialVisible", "isSaveToStorage"], outputs: ["changeCheckboxValue", "clickedLink"] }, { type: i2.InputSearchComponent, selector: "mrx-input-search", inputs: ["fields", "disabled", "required", "readonly", "maxlength", "minlength", "placeholder", "customClasses", "mask", "size", "invalid", "invalidMessage", "checkInvalid", "restrictInput"], outputs: ["changed", "modelChange", "blurred", "cleared", "searched"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
|
|
28
|
+
CheckboxGroupHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: CheckboxGroupHeaderComponent, selector: "mrx-checkbox-group-header", inputs: { searchable: "searchable", searchPlaceholder: "searchPlaceholder", tooltip: "tooltip", labelText: "labelText", linkText: "linkText", checkedItemsCount: "checkedItemsCount" }, outputs: { updateCheckboxGroupSearchValue: "updateCheckboxGroupSearchValue", clearFilters: "clearFilters" }, ngImport: i0, template: "<mrx-label\r\n *ngIf=\"labelText\"\r\n [counter]=\"checkedItemsCount\"\r\n [linkText]=\"linkText\"\r\n [tooltip]=\"tooltip\"\r\n (clickedLink)=\"onClearFilters()\"\r\n>{{ labelText }}</mrx-label>\r\n\r\n<div class=\"mrx-checkbox-group-head--search\" *ngIf=\"searchable\">\r\n <mrx-input-search\r\n [ngModel]=\"searchValue\"\r\n [size]=\"'medium'\"\r\n [placeholder]=\"searchPlaceholder\"\r\n (ngModelChange)=\"changeSearchValue($event)\"\r\n ></mrx-input-search>\r\n</div>\r\n", styles: [".mrx-checkbox-group-head--search{margin-bottom:12px}\n"], components: [{ type: i1.LabelComponent, selector: "mrx-label", inputs: ["requiredHidden", "required", "boldLabel", "disabled", "placeholder", "label", "customClasses", "triggerTextPosition", "isPublicInfo", "publicInfoTooltip", "isSwitch", "switchLabel", "switchValue", "counter", "linkText", "linkPrevent", "linkType", "linkMonochrome", "href", "triggerType", "tooltip", "tooltipInitialVisible", "isSaveToStorage"], outputs: ["changeCheckboxValue", "clickedLink"] }, { type: i2.InputSearchComponent, selector: "mrx-input-search", inputs: ["fields", "disabled", "required", "readonly", "maxlength", "minlength", "placeholder", "customClasses", "mask", "size", "invalid", "invalidMessage", "checkInvalid", "restrictInput"], outputs: ["changed", "modelChange", "blurred", "cleared", "searched"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
29
29
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: CheckboxGroupHeaderComponent, decorators: [{
|
|
30
30
|
type: Component,
|
|
31
|
-
args: [{ selector: 'mrx-checkbox-group-header', template: "<mrx-label\r\n *ngIf=\"labelText\"\r\n [counter]=\"checkedItemsCount\"\r\n [linkText]=\"linkText\"\r\n [tooltip]=\"tooltip\"\r\n (clickedLink)=\"onClearFilters()\"\r\n>{{ labelText }}</mrx-label>\r\n\r\n<div class=\"mrx-checkbox-group-head--search\" *ngIf=\"searchable\">\r\n <mrx-input-search\r\n [ngModel]=\"searchValue\"\r\n [size]=\"'medium'\"\r\n [placeholder]=\"searchPlaceholder\"\r\n (ngModelChange)=\"changeSearchValue($event)\"\r\n ></mrx-input-search>\r\n</div>\r\n", styles: [".mrx-checkbox-group-head--search{margin-bottom:12px}\n"] }]
|
|
31
|
+
args: [{ selector: 'mrx-checkbox-group-header', changeDetection: ChangeDetectionStrategy.OnPush, template: "<mrx-label\r\n *ngIf=\"labelText\"\r\n [counter]=\"checkedItemsCount\"\r\n [linkText]=\"linkText\"\r\n [tooltip]=\"tooltip\"\r\n (clickedLink)=\"onClearFilters()\"\r\n>{{ labelText }}</mrx-label>\r\n\r\n<div class=\"mrx-checkbox-group-head--search\" *ngIf=\"searchable\">\r\n <mrx-input-search\r\n [ngModel]=\"searchValue\"\r\n [size]=\"'medium'\"\r\n [placeholder]=\"searchPlaceholder\"\r\n (ngModelChange)=\"changeSearchValue($event)\"\r\n ></mrx-input-search>\r\n</div>\r\n", styles: [".mrx-checkbox-group-head--search{margin-bottom:12px}\n"] }]
|
|
32
32
|
}], ctorParameters: function () { return []; }, propDecorators: { searchable: [{
|
|
33
33
|
type: Input
|
|
34
34
|
}], searchPlaceholder: [{
|
|
@@ -46,4 +46,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
46
46
|
}], clearFilters: [{
|
|
47
47
|
type: Output
|
|
48
48
|
}] } });
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3gtZ3JvdXAtaGVhZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL215cnRhLXVpL3NyYy9saWIvY29tcG9uZW50cy9mb3JtL2NoZWNrYm94LWdyb3VwL2NvbXBvbmVudHMvY2hlY2tib3gtZ3JvdXAtaGVhZGVyL2NoZWNrYm94LWdyb3VwLWhlYWRlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9jaGVja2JveC1ncm91cC9jb21wb25lbnRzL2NoZWNrYm94LWdyb3VwLWhlYWRlci9jaGVja2JveC1ncm91cC1oZWFkZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7O0FBU2hHLE1BQU0sT0FBTyw0QkFBNEI7SUFldkM7UUFkTyxnQkFBVyxHQUFHLEVBQUUsQ0FBQTtRQUVkLGVBQVUsR0FBRyxLQUFLLENBQUE7UUFDbEIsc0JBQWlCLEdBQUcsRUFBRSxDQUFBO1FBRS9CLFFBQVE7UUFDQyxZQUFPLEdBQUcsRUFBRSxDQUFBO1FBQ1osY0FBUyxHQUFHLEVBQUUsQ0FBQTtRQUNkLGFBQVEsR0FBRyxFQUFFLENBQUE7UUFDYixzQkFBaUIsR0FBRyxDQUFDLENBQUE7UUFFYixtQ0FBOEIsR0FBeUIsSUFBSSxZQUFZLEVBQVUsQ0FBQztRQUNsRixpQkFBWSxHQUF1QixJQUFJLFlBQVksRUFBUSxDQUFDO0lBRTdELENBQUM7SUFFVixpQkFBaUIsQ0FBQyxXQUFxQztRQUM1RCxJQUFJLENBQUMsOEJBQThCLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFBO0lBQ3ZELENBQUM7SUFFTSxjQUFjO1FBQ25CLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxFQUFFLENBQUE7SUFDMUIsQ0FBQzs7eUhBdkJVLDRCQUE0Qjs2R0FBNUIsNEJBQTRCLHNXQ1R6QyxpZkFnQkE7MkZEUGEsNEJBQTRCO2tCQU54QyxTQUFTOytCQUNFLDJCQUEyQixtQkFHcEIsdUJBQXVCLENBQUMsTUFBTTswRUFLdEMsVUFBVTtzQkFBbEIsS0FBSztnQkFDRyxpQkFBaUI7c0JBQXpCLEtBQUs7Z0JBR0csT0FBTztzQkFBZixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxpQkFBaUI7c0JBQXpCLEtBQUs7Z0JBRVcsOEJBQThCO3NCQUE5QyxNQUFNO2dCQUNVLFlBQVk7c0JBQTVCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ2hlY2tib3hHcm91cFNlYXJjaFZhbHVlIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2NoZWNrYm94LWdyb3VwLm1vZGVsJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnbXJ4LWNoZWNrYm94LWdyb3VwLWhlYWRlcicsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2NoZWNrYm94LWdyb3VwLWhlYWRlci5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vY2hlY2tib3gtZ3JvdXAtaGVhZGVyLmNvbXBvbmVudC5sZXNzJ10sXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDaGVja2JveEdyb3VwSGVhZGVyQ29tcG9uZW50IHtcclxuICBwdWJsaWMgc2VhcmNoVmFsdWUgPSAnJ1xyXG5cclxuICBASW5wdXQoKSBzZWFyY2hhYmxlID0gZmFsc2VcclxuICBASW5wdXQoKSBzZWFyY2hQbGFjZWhvbGRlciA9ICcnXHJcblxyXG4gIC8vIExBQkVMXHJcbiAgQElucHV0KCkgdG9vbHRpcCA9ICcnXHJcbiAgQElucHV0KCkgbGFiZWxUZXh0ID0gJydcclxuICBASW5wdXQoKSBsaW5rVGV4dCA9ICcnXHJcbiAgQElucHV0KCkgY2hlY2tlZEl0ZW1zQ291bnQgPSAwXHJcblxyXG4gIEBPdXRwdXQoKSBwdWJsaWMgdXBkYXRlQ2hlY2tib3hHcm91cFNlYXJjaFZhbHVlOiBFdmVudEVtaXR0ZXI8c3RyaW5nPiA9IG5ldyBFdmVudEVtaXR0ZXI8c3RyaW5nPigpO1xyXG4gIEBPdXRwdXQoKSBwdWJsaWMgY2xlYXJGaWx0ZXJzOiBFdmVudEVtaXR0ZXI8bnVsbD4gPSBuZXcgRXZlbnRFbWl0dGVyPG51bGw+KCk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkgeyB9XHJcblxyXG4gIHB1YmxpYyBjaGFuZ2VTZWFyY2hWYWx1ZShzZWFyY2hWYWx1ZTogQ2hlY2tib3hHcm91cFNlYXJjaFZhbHVlKTogdm9pZCB7XHJcbiAgICB0aGlzLnVwZGF0ZUNoZWNrYm94R3JvdXBTZWFyY2hWYWx1ZS5lbWl0KHNlYXJjaFZhbHVlKVxyXG4gIH1cclxuXHJcbiAgcHVibGljIG9uQ2xlYXJGaWx0ZXJzKCk6IHZvaWQge1xyXG4gICAgdGhpcy5jbGVhckZpbHRlcnMuZW1pdCgpXHJcbiAgfVxyXG59XHJcbiIsIjxtcngtbGFiZWxcclxuICAqbmdJZj1cImxhYmVsVGV4dFwiXHJcbiAgW2NvdW50ZXJdPVwiY2hlY2tlZEl0ZW1zQ291bnRcIlxyXG4gIFtsaW5rVGV4dF09XCJsaW5rVGV4dFwiXHJcbiAgW3Rvb2x0aXBdPVwidG9vbHRpcFwiXHJcbiAgKGNsaWNrZWRMaW5rKT1cIm9uQ2xlYXJGaWx0ZXJzKClcIlxyXG4+e3sgbGFiZWxUZXh0IH19PC9tcngtbGFiZWw+XHJcblxyXG48ZGl2IGNsYXNzPVwibXJ4LWNoZWNrYm94LWdyb3VwLWhlYWQtLXNlYXJjaFwiICpuZ0lmPVwic2VhcmNoYWJsZVwiPlxyXG4gIDxtcngtaW5wdXQtc2VhcmNoXHJcbiAgICBbbmdNb2RlbF09XCJzZWFyY2hWYWx1ZVwiXHJcbiAgICBbc2l6ZV09XCInbWVkaXVtJ1wiXHJcbiAgICBbcGxhY2Vob2xkZXJdPVwic2VhcmNoUGxhY2Vob2xkZXJcIlxyXG4gICAgKG5nTW9kZWxDaGFuZ2UpPVwiY2hhbmdlU2VhcmNoVmFsdWUoJGV2ZW50KVwiXHJcbiAgPjwvbXJ4LWlucHV0LXNlYXJjaD5cclxuPC9kaXY+XHJcbiJdfQ==
|
|
@@ -1,32 +1,37 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
-
import { animate,
|
|
2
|
+
import { animate, state, style, transition, trigger } from '@angular/animations';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "../../../checkbox/checkbox.component";
|
|
5
5
|
import * as i2 from "@angular/common";
|
|
6
6
|
import * as i3 from "@angular/forms";
|
|
7
7
|
export class CheckboxGroupItemComponent {
|
|
8
|
-
constructor(
|
|
9
|
-
this.
|
|
8
|
+
constructor(_detector) {
|
|
9
|
+
this._detector = _detector;
|
|
10
10
|
this.animationState = 'close';
|
|
11
|
+
this.isOpen = false;
|
|
11
12
|
this.displaced = false;
|
|
12
13
|
this.level = 0;
|
|
13
14
|
this.animationTrigger = null;
|
|
14
15
|
this.disabled = false;
|
|
15
16
|
this.readonly = false;
|
|
17
|
+
this.invalid = false;
|
|
16
18
|
this.animationEnd = new EventEmitter();
|
|
17
19
|
this.checkboxChanged = new EventEmitter();
|
|
18
20
|
}
|
|
21
|
+
set item(value) {
|
|
22
|
+
this._item = value;
|
|
23
|
+
}
|
|
24
|
+
get item() {
|
|
25
|
+
return this._item;
|
|
26
|
+
}
|
|
19
27
|
get isIndeterminate() {
|
|
20
28
|
return this.item.value === null;
|
|
21
29
|
}
|
|
22
30
|
get translateChevron() {
|
|
23
|
-
return this.
|
|
24
|
-
}
|
|
25
|
-
trackByFn(index, item) {
|
|
26
|
-
return item.id;
|
|
31
|
+
return this.isOpen ? 'rotate(0deg)' : 'rotate(-90deg)';
|
|
27
32
|
}
|
|
28
33
|
toggleList(item) {
|
|
29
|
-
this.
|
|
34
|
+
this.isOpen = !this.isOpen;
|
|
30
35
|
}
|
|
31
36
|
checkboxChangeModel(value, item) {
|
|
32
37
|
if (this.isIndeterminate) {
|
|
@@ -35,64 +40,54 @@ export class CheckboxGroupItemComponent {
|
|
|
35
40
|
else {
|
|
36
41
|
this.checkboxChanged.emit({ value: value, item });
|
|
37
42
|
}
|
|
38
|
-
this.
|
|
43
|
+
this._detector.detectChanges();
|
|
39
44
|
}
|
|
40
45
|
ngOnChanges(changes) {
|
|
41
46
|
if (changes['item'] && (changes['item'].currentValue.value === null)) {
|
|
42
|
-
this.
|
|
47
|
+
this.isOpen = true;
|
|
43
48
|
}
|
|
44
49
|
else {
|
|
45
|
-
|
|
46
|
-
this.animationState = 'open';
|
|
47
|
-
}
|
|
48
|
-
else {
|
|
49
|
-
this.animationState = 'close';
|
|
50
|
-
}
|
|
50
|
+
this.isOpen = !!this.animationTrigger;
|
|
51
51
|
}
|
|
52
|
-
this.
|
|
52
|
+
this._detector.detectChanges();
|
|
53
53
|
}
|
|
54
54
|
onAnimationEvent() {
|
|
55
55
|
this.animationEnd.emit();
|
|
56
56
|
}
|
|
57
|
+
trackByFn(index, item) {
|
|
58
|
+
return item.id;
|
|
59
|
+
}
|
|
57
60
|
}
|
|
58
61
|
CheckboxGroupItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: CheckboxGroupItemComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
59
|
-
CheckboxGroupItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: CheckboxGroupItemComponent, selector: "mrx-checkbox-group-item", inputs: {
|
|
62
|
+
CheckboxGroupItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: CheckboxGroupItemComponent, selector: "mrx-checkbox-group-item", inputs: { displaced: "displaced", level: "level", animationTrigger: "animationTrigger", isLast: "isLast", disabled: "disabled", readonly: "readonly", invalid: "invalid", item: "item" }, outputs: { animationEnd: "animationEnd", checkboxChanged: "checkboxChanged" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"mrx-checkbox-group__item\" [class.mrx-checkbox-group__item--buttom-ident]=\"!isLast\">\r\n <div class=\"mrx-checkbox-group__item--array\" *ngIf=\"item.items?.length && level < 10; else singleCheckboxTemplate\">\r\n <div class=\"mrx-checkbox-group__item--array-head\">\r\n <div class=\"mrx-checkbox-group__item--head-icon mr-1\">\r\n <span\r\n class=\"mrx-icon icon-chevron-down icon-font-16 cursor-pointer\"\r\n (click)=\"toggleList(item)\"\r\n [style.transform]=\"translateChevron\"\r\n ></span>\r\n </div>\r\n\r\n <mrx-checkbox\r\n [ngModel]=\"item.value\"\r\n [indeterminate]=\"isIndeterminate\"\r\n (ngModelChange)=\"checkboxChangeModel($event, item)\"\r\n >{{ item.text }}</mrx-checkbox>\r\n </div>\r\n\r\n <div class=\"mrx-checkbox-group__item--array-list\" [@openList]=\"isOpen ? 'open' : 'close'\" (@openList.done)=\"onAnimationEvent()\">\r\n <ng-container>\r\n <mrx-checkbox-group-item\r\n *ngFor=\"let item of item.items; trackBy: trackByFn\"\r\n [level]=\"level + 1\"\r\n [item]=\"item\"\r\n [displaced]=\"true\"\r\n [animationTrigger]=\"animationTrigger\"\r\n [disabled]=\"disabled\"\r\n [readonly]=\"readonly\"\r\n [invalid]=\"invalid\"\r\n (checkboxChanged)=\"checkboxChanged.emit($event)\"\r\n ></mrx-checkbox-group-item>\r\n </ng-container>\r\n </div>\r\n </div>\r\n\r\n <ng-template #singleCheckboxTemplate>\r\n <div class=\"mrx-checkbox-group__item--single\" [class.item-displaced]=\"displaced\">\r\n <mrx-checkbox\r\n [ngModel]=\"item.value\"\r\n [indeterminate]=\"false\"\r\n [disabled]=\"disabled\"\r\n [readonly]=\"readonly\"\r\n [invalid]=\"invalid\"\r\n (ngModelChange)=\"checkboxChangeModel($event, item)\"\r\n >{{ item.text }}</mrx-checkbox>\r\n </div>\r\n </ng-template>\r\n</div>\r\n\r\n\r\n", styles: [".mrx-checkbox-group__item--single.item-displaced{margin-left:20px}.mrx-checkbox-group__item--array-head{display:flex;justify-content:flex-start;align-items:center}.mrx-checkbox-group__item--array-list{padding-left:20px}.mrx-checkbox-group__item--buttom-ident{margin-bottom:12px}\n"], components: [{ type: i1.CheckboxComponent, selector: "mrx-checkbox", inputs: ["fields", "required", "boldLabel", "indeterminate", "disabled", "readonly", "label", "customClasses", "customWrapperClasses", "invalid", "checkInvalid", "tooltip", "tooltipInitialVisible", "isSaveToStorage"], outputs: ["changed", "modelChange"] }, { type: CheckboxGroupItemComponent, selector: "mrx-checkbox-group-item", inputs: ["displaced", "level", "animationTrigger", "isLast", "disabled", "readonly", "invalid", "item"], outputs: ["animationEnd", "checkboxChanged"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], animations: [
|
|
60
63
|
trigger('openList', [
|
|
64
|
+
state('*', style({ height: '0', opacity: '0', visibility: 'hidden', marginTop: '0', overflow: 'hidden' })),
|
|
61
65
|
state('open', style({ height: '*', opacity: '1', visibility: 'visible', marginTop: '12px' })),
|
|
62
66
|
state('close', style({ height: '0', opacity: '0', visibility: 'hidden', marginTop: '0', overflow: 'hidden' })),
|
|
63
|
-
transition('
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
animate('200ms ease-in-out', style({ visibility: 'visible' })),
|
|
70
|
-
animate('200ms ease-in-out', style({ height: '*', marginTop: '12px' })),
|
|
71
|
-
animate('200ms ease-in-out', style({ opacity: '1' }))
|
|
72
|
-
])])
|
|
67
|
+
transition('* => open', [
|
|
68
|
+
animate(200)
|
|
69
|
+
]),
|
|
70
|
+
transition('* => close', [
|
|
71
|
+
animate(200)
|
|
72
|
+
]),
|
|
73
73
|
])
|
|
74
74
|
], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
75
75
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: CheckboxGroupItemComponent, decorators: [{
|
|
76
76
|
type: Component,
|
|
77
77
|
args: [{ selector: 'mrx-checkbox-group-item', changeDetection: ChangeDetectionStrategy.OnPush, animations: [
|
|
78
78
|
trigger('openList', [
|
|
79
|
+
state('*', style({ height: '0', opacity: '0', visibility: 'hidden', marginTop: '0', overflow: 'hidden' })),
|
|
79
80
|
state('open', style({ height: '*', opacity: '1', visibility: 'visible', marginTop: '12px' })),
|
|
80
81
|
state('close', style({ height: '0', opacity: '0', visibility: 'hidden', marginTop: '0', overflow: 'hidden' })),
|
|
81
|
-
transition('
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
animate('200ms ease-in-out', style({ visibility: 'visible' })),
|
|
88
|
-
animate('200ms ease-in-out', style({ height: '*', marginTop: '12px' })),
|
|
89
|
-
animate('200ms ease-in-out', style({ opacity: '1' }))
|
|
90
|
-
])])
|
|
82
|
+
transition('* => open', [
|
|
83
|
+
animate(200)
|
|
84
|
+
]),
|
|
85
|
+
transition('* => close', [
|
|
86
|
+
animate(200)
|
|
87
|
+
]),
|
|
91
88
|
])
|
|
92
|
-
], template: "<div class=\"mrx-checkbox-group__item\" [class.mrx-checkbox-group__item--buttom-ident]=\"!isLast\">\r\n <div class=\"mrx-checkbox-group__item--array\" *ngIf=\"item.
|
|
93
|
-
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: {
|
|
94
|
-
type: Input
|
|
95
|
-
}], displaced: [{
|
|
89
|
+
], template: "<div class=\"mrx-checkbox-group__item\" [class.mrx-checkbox-group__item--buttom-ident]=\"!isLast\">\r\n <div class=\"mrx-checkbox-group__item--array\" *ngIf=\"item.items?.length && level < 10; else singleCheckboxTemplate\">\r\n <div class=\"mrx-checkbox-group__item--array-head\">\r\n <div class=\"mrx-checkbox-group__item--head-icon mr-1\">\r\n <span\r\n class=\"mrx-icon icon-chevron-down icon-font-16 cursor-pointer\"\r\n (click)=\"toggleList(item)\"\r\n [style.transform]=\"translateChevron\"\r\n ></span>\r\n </div>\r\n\r\n <mrx-checkbox\r\n [ngModel]=\"item.value\"\r\n [indeterminate]=\"isIndeterminate\"\r\n (ngModelChange)=\"checkboxChangeModel($event, item)\"\r\n >{{ item.text }}</mrx-checkbox>\r\n </div>\r\n\r\n <div class=\"mrx-checkbox-group__item--array-list\" [@openList]=\"isOpen ? 'open' : 'close'\" (@openList.done)=\"onAnimationEvent()\">\r\n <ng-container>\r\n <mrx-checkbox-group-item\r\n *ngFor=\"let item of item.items; trackBy: trackByFn\"\r\n [level]=\"level + 1\"\r\n [item]=\"item\"\r\n [displaced]=\"true\"\r\n [animationTrigger]=\"animationTrigger\"\r\n [disabled]=\"disabled\"\r\n [readonly]=\"readonly\"\r\n [invalid]=\"invalid\"\r\n (checkboxChanged)=\"checkboxChanged.emit($event)\"\r\n ></mrx-checkbox-group-item>\r\n </ng-container>\r\n </div>\r\n </div>\r\n\r\n <ng-template #singleCheckboxTemplate>\r\n <div class=\"mrx-checkbox-group__item--single\" [class.item-displaced]=\"displaced\">\r\n <mrx-checkbox\r\n [ngModel]=\"item.value\"\r\n [indeterminate]=\"false\"\r\n [disabled]=\"disabled\"\r\n [readonly]=\"readonly\"\r\n [invalid]=\"invalid\"\r\n (ngModelChange)=\"checkboxChangeModel($event, item)\"\r\n >{{ item.text }}</mrx-checkbox>\r\n </div>\r\n </ng-template>\r\n</div>\r\n\r\n\r\n", styles: [".mrx-checkbox-group__item--single.item-displaced{margin-left:20px}.mrx-checkbox-group__item--array-head{display:flex;justify-content:flex-start;align-items:center}.mrx-checkbox-group__item--array-list{padding-left:20px}.mrx-checkbox-group__item--buttom-ident{margin-bottom:12px}\n"] }]
|
|
90
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { displaced: [{
|
|
96
91
|
type: Input
|
|
97
92
|
}], level: [{
|
|
98
93
|
type: Input
|
|
@@ -104,9 +99,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
104
99
|
type: Input
|
|
105
100
|
}], readonly: [{
|
|
106
101
|
type: Input
|
|
102
|
+
}], invalid: [{
|
|
103
|
+
type: Input
|
|
104
|
+
}], item: [{
|
|
105
|
+
type: Input
|
|
107
106
|
}], animationEnd: [{
|
|
108
107
|
type: Output
|
|
109
108
|
}], checkboxChanged: [{
|
|
110
109
|
type: Output
|
|
111
110
|
}] } });
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox-group-item.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/myrta-ui/src/lib/components/form/checkbox-group/components/checkbox-group-item/checkbox-group-item.component.ts","../../../../../../../../../projects/myrta-ui/src/lib/components/form/checkbox-group/components/checkbox-group-item/checkbox-group-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  Output,\r\n  SimpleChanges\r\n} from '@angular/core';\r\nimport { animate, group, state, style, transition, trigger } from '@angular/animations';\r\nimport { AnimateCheckboxGroupState, CheckboxGroupItem, CheckboxIndeterminateState } from '../../models/checkbox-group.model';\r\n\r\n@Component({\r\n  selector: 'mrx-checkbox-group-item',\r\n  templateUrl: './checkbox-group-item.component.html',\r\n  styleUrls: ['./checkbox-group-item.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  animations: [\r\n    trigger('openList', [\r\n      state('open', style({ height: '*', opacity: '1', visibility: 'visible', marginTop: '12px' })),\r\n      state('close', style({ height: '0', opacity: '0', visibility: 'hidden', marginTop: '0', overflow: 'hidden' })),\r\n      transition('open => close', [group([\r\n          animate('200ms ease-in-out', style({ opacity: '0' })),\r\n          animate('200ms ease-in-out', style({ height: '0px', marginTop: '0' })),\r\n          animate('200ms ease-in-out', style({ visibility: 'hidden' }))\r\n        ]\r\n      )]),\r\n      transition('close => open', [group([\r\n          animate('200ms ease-in-out', style({ visibility: 'visible' })),\r\n          animate('200ms ease-in-out', style({ height: '*', marginTop: '12px' })),\r\n          animate('200ms ease-in-out', style({ opacity: '1' }))\r\n        ],\r\n      )])\r\n    ])\r\n  ]\r\n})\r\nexport class CheckboxGroupItemComponent implements OnChanges {\r\n  public animationState: AnimateCheckboxGroupState = 'close'\r\n\r\n  @Input() item!: CheckboxGroupItem\r\n  @Input() displaced = false\r\n  @Input() level = 0\r\n  @Input() animationTrigger: boolean | null = null\r\n  @Input() isLast!: boolean\r\n  @Input() public disabled = false;\r\n  @Input() public readonly = false;\r\n\r\n  @Output() public animationEnd: EventEmitter<null> = new EventEmitter<null>();\r\n  @Output() public checkboxChanged: EventEmitter<{ value: CheckboxIndeterminateState, item: CheckboxGroupItem }> =\r\n    new EventEmitter<{ value: CheckboxIndeterminateState, item: CheckboxGroupItem }>();\r\n\r\n  constructor(private detector: ChangeDetectorRef) {\r\n  }\r\n\r\n  public get isIndeterminate(): boolean {\r\n    return this.item.value === null\r\n  }\r\n\r\n  public get translateChevron(): string {\r\n    return this.animationState === 'close' ? 'rotate(-90deg)' : 'rotate(0deg)';\r\n  }\r\n\r\n  public trackByFn(index: number, item: CheckboxGroupItem) {\r\n    return item.id;\r\n  }\r\n\r\n  public toggleList(item: CheckboxGroupItem): void {\r\n    this.animationState = this.animationState === 'close' ? 'open' : 'close';\r\n  }\r\n\r\n  public checkboxChangeModel(value: CheckboxIndeterminateState, item: CheckboxGroupItem): void {\r\n    if (this.isIndeterminate) {\r\n      this.checkboxChanged.emit({ value: false, item })\r\n    } else {\r\n      this.checkboxChanged.emit({ value: value, item })\r\n    }\r\n\r\n    this.detector.detectChanges()\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['item'] && (changes['item'].currentValue.value === null)) {\r\n      this.animationState = 'open'\r\n    } else {\r\n      if (this.animationTrigger) {\r\n        this.animationState = 'open'\r\n      } else {\r\n        this.animationState = 'close'\r\n      }\r\n    }\r\n\r\n    this.detector.detectChanges()\r\n  }\r\n\r\n  public onAnimationEvent(): void {\r\n    this.animationEnd.emit()\r\n  }\r\n}\r\n","<div class=\"mrx-checkbox-group__item\" [class.mrx-checkbox-group__item--buttom-ident]=\"!isLast\">\r\n  <div class=\"mrx-checkbox-group__item--array\" *ngIf=\"item.array.length && level < 10; else singleCheckboxTemplate\">\r\n    <div class=\"mrx-checkbox-group__item--array-head\">\r\n      <div class=\"mrx-checkbox-group__item--head-icon mr-1\">\r\n        <span\r\n          class=\"mrx-icon icon-chevron-down icon-font-16 cursor-pointer\"\r\n          (click)=\"toggleList(item)\"\r\n          [style.transform]=\"translateChevron\"\r\n          ></span>\r\n      </div>\r\n\r\n      <mrx-checkbox\r\n          [ngModel]=\"item.value\"\r\n          [indeterminate]=\"isIndeterminate\"\r\n          (ngModelChange)=\"checkboxChangeModel($event, item)\"\r\n      >{{ item.text }}</mrx-checkbox>\r\n    </div>\r\n\r\n    <div class=\"mrx-checkbox-group__item--array-list\" [@openList]=\"animationState\" (@openList.done)=\"onAnimationEvent()\">\r\n      <ng-container>\r\n        <mrx-checkbox-group-item\r\n            *ngFor=\"let item of item.array\"\r\n            [level]=\"level + 1\"\r\n            [item]=\"item\"\r\n            [displaced]=\"true\"\r\n            [animationTrigger]=\"animationTrigger\"\r\n            [disabled]=\"disabled\"\r\n            [readonly]=\"readonly\"\r\n            (checkboxChanged)=\"checkboxChanged.emit($event)\"\r\n        ></mrx-checkbox-group-item>\r\n      </ng-container>\r\n    </div>\r\n  </div>\r\n\r\n  <ng-template #singleCheckboxTemplate>\r\n    <div class=\"mrx-checkbox-group__item--single\" [class.item-displaced]=\"displaced\">\r\n      <mrx-checkbox\r\n          [ngModel]=\"item.value\"\r\n          [indeterminate]=\"false\"\r\n          [disabled]=\"disabled\"\r\n          [readonly]=\"readonly\"\r\n          (ngModelChange)=\"checkboxChangeModel($event, item)\"\r\n      >{{ item.text }}</mrx-checkbox>\r\n    </div>\r\n  </ng-template>\r\n</div>\r\n\r\n\r\n"]}
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox-group-item.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/myrta-ui/src/lib/components/form/checkbox-group/components/checkbox-group-item/checkbox-group-item.component.ts","../../../../../../../../../projects/myrta-ui/src/lib/components/form/checkbox-group/components/checkbox-group-item/checkbox-group-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  Output,\r\n  SimpleChanges\r\n} from '@angular/core';\r\nimport { animate, group, state, style, transition, trigger } from '@angular/animations';\r\nimport {\r\n  AnimateCheckboxGroupState,\r\n  CheckboxGroupInnerItem,\r\n  CheckboxIndeterminateState\r\n} from '../../models/checkbox-group.model';\r\n\r\n@Component({\r\n  selector: 'mrx-checkbox-group-item',\r\n  templateUrl: './checkbox-group-item.component.html',\r\n  styleUrls: ['./checkbox-group-item.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  animations: [\r\n    trigger('openList', [\r\n      state('*', style({ height: '0', opacity: '0', visibility: 'hidden', marginTop: '0', overflow: 'hidden' })),\r\n      state('open', style({ height: '*', opacity: '1', visibility: 'visible', marginTop: '12px' })),\r\n      state('close', style({ height: '0', opacity: '0', visibility: 'hidden', marginTop: '0', overflow: 'hidden' })),\r\n      transition('* => open', [\r\n        animate(200)\r\n      ]),\r\n      transition('* => close', [\r\n        animate(200)\r\n      ]),\r\n    ])\r\n  ]\r\n})\r\nexport class CheckboxGroupItemComponent implements OnChanges {\r\n  private _item!: CheckboxGroupInnerItem\r\n\r\n  public animationState: AnimateCheckboxGroupState = 'close'\r\n  public isOpen = false\r\n\r\n\r\n  @Input() displaced = false\r\n  @Input() level = 0\r\n  @Input() animationTrigger: boolean | null = null\r\n  @Input() isLast!: boolean\r\n  @Input() public disabled = false;\r\n  @Input() public readonly = false;\r\n  @Input() public invalid = false;\r\n\r\n  @Input() set item(value: CheckboxGroupInnerItem) {\r\n    this._item = value\r\n  }\r\n\r\n  public get item():CheckboxGroupInnerItem {\r\n    return this._item\r\n  }\r\n\r\n  @Output() public animationEnd: EventEmitter<null> = new EventEmitter<null>();\r\n  @Output() public checkboxChanged: EventEmitter<{ value: CheckboxIndeterminateState, item: CheckboxGroupInnerItem }> =\r\n    new EventEmitter<{ value: CheckboxIndeterminateState, item: CheckboxGroupInnerItem }>();\r\n\r\n  constructor(private _detector: ChangeDetectorRef) {\r\n  }\r\n\r\n  public get isIndeterminate(): boolean {\r\n    return this.item.value === null\r\n  }\r\n\r\n  public get translateChevron(): string {\r\n    return this.isOpen ? 'rotate(0deg)' : 'rotate(-90deg)';\r\n  }\r\n\r\n  public toggleList(item: CheckboxGroupInnerItem): void {\r\n    this.isOpen = !this.isOpen\r\n  }\r\n\r\n  public checkboxChangeModel(value: CheckboxIndeterminateState, item: CheckboxGroupInnerItem): void {\r\n    if (this.isIndeterminate) {\r\n      this.checkboxChanged.emit({ value: false, item })\r\n    } else {\r\n      this.checkboxChanged.emit({ value: value, item })\r\n    }\r\n\r\n    this._detector.detectChanges()\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['item'] && (changes['item'].currentValue.value === null)) {\r\n      this.isOpen = true\r\n    } else {\r\n\r\n      this.isOpen = !!this.animationTrigger;\r\n    }\r\n\r\n    this._detector.detectChanges()\r\n  }\r\n\r\n  public onAnimationEvent(): void {\r\n    this.animationEnd.emit()\r\n  }\r\n\r\n  public trackByFn(index: number, item: CheckboxGroupInnerItem) {\r\n    return item.id;\r\n  }\r\n}\r\n","<div class=\"mrx-checkbox-group__item\" [class.mrx-checkbox-group__item--buttom-ident]=\"!isLast\">\r\n  <div class=\"mrx-checkbox-group__item--array\" *ngIf=\"item.items?.length && level < 10; else singleCheckboxTemplate\">\r\n    <div class=\"mrx-checkbox-group__item--array-head\">\r\n      <div class=\"mrx-checkbox-group__item--head-icon mr-1\">\r\n        <span\r\n          class=\"mrx-icon icon-chevron-down icon-font-16 cursor-pointer\"\r\n          (click)=\"toggleList(item)\"\r\n          [style.transform]=\"translateChevron\"\r\n          ></span>\r\n      </div>\r\n\r\n      <mrx-checkbox\r\n          [ngModel]=\"item.value\"\r\n          [indeterminate]=\"isIndeterminate\"\r\n          (ngModelChange)=\"checkboxChangeModel($event, item)\"\r\n      >{{ item.text }}</mrx-checkbox>\r\n    </div>\r\n\r\n    <div class=\"mrx-checkbox-group__item--array-list\" [@openList]=\"isOpen ? 'open' : 'close'\" (@openList.done)=\"onAnimationEvent()\">\r\n      <ng-container>\r\n        <mrx-checkbox-group-item\r\n            *ngFor=\"let item of item.items; trackBy: trackByFn\"\r\n            [level]=\"level + 1\"\r\n            [item]=\"item\"\r\n            [displaced]=\"true\"\r\n            [animationTrigger]=\"animationTrigger\"\r\n            [disabled]=\"disabled\"\r\n            [readonly]=\"readonly\"\r\n            [invalid]=\"invalid\"\r\n            (checkboxChanged)=\"checkboxChanged.emit($event)\"\r\n        ></mrx-checkbox-group-item>\r\n      </ng-container>\r\n    </div>\r\n  </div>\r\n\r\n  <ng-template #singleCheckboxTemplate>\r\n    <div class=\"mrx-checkbox-group__item--single\" [class.item-displaced]=\"displaced\">\r\n      <mrx-checkbox\r\n          [ngModel]=\"item.value\"\r\n          [indeterminate]=\"false\"\r\n          [disabled]=\"disabled\"\r\n          [readonly]=\"readonly\"\r\n          [invalid]=\"invalid\"\r\n          (ngModelChange)=\"checkboxChangeModel($event, item)\"\r\n      >{{ item.text }}</mrx-checkbox>\r\n    </div>\r\n  </ng-template>\r\n</div>\r\n\r\n\r\n"]}
|