@pega/angular-sdk-components 0.23.5 → 0.24.1

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.
Files changed (46) hide show
  1. package/esm2022/lib/_bridge/angular-pconnect.mjs +14 -2
  2. package/esm2022/lib/_bridge/helpers/sdk-pega-component-map.mjs +3 -1
  3. package/esm2022/lib/_components/designSystemExtension/material-case-summary/material-case-summary.component.mjs +6 -3
  4. package/esm2022/lib/_components/designSystemExtension/operator/operator.component.mjs +9 -5
  5. package/esm2022/lib/_components/field/auto-complete/auto-complete.component.mjs +2 -2
  6. package/esm2022/lib/_components/field/check-box/check-box.component.mjs +107 -42
  7. package/esm2022/lib/_components/field/group/group.component.mjs +6 -3
  8. package/esm2022/lib/_components/field/multiselect/multiselect.component.mjs +311 -0
  9. package/esm2022/lib/_components/field/multiselect/utils.mjs +187 -0
  10. package/esm2022/lib/_components/field/rich-text/rich-text.component.mjs +3 -3
  11. package/esm2022/lib/_components/field/time/time.component.mjs +5 -3
  12. package/esm2022/lib/_components/field/url/url.component.mjs +5 -3
  13. package/esm2022/lib/_components/infra/Containers/view-container/view-container.component.mjs +6 -6
  14. package/esm2022/lib/_components/infra/multi-step/multi-step.component.mjs +3 -3
  15. package/esm2022/lib/_components/infra/navbar/navbar.component.mjs +6 -3
  16. package/esm2022/lib/_components/template/case-summary/case-summary.component.mjs +33 -4
  17. package/esm2022/lib/_components/template/field-value-list/field-value-list.component.mjs +8 -3
  18. package/esm2022/lib/_components/template/list-view/list-view.component.mjs +23 -25
  19. package/esm2022/lib/_components/template/list-view/utils.mjs +5 -3
  20. package/esm2022/lib/_components/template/simple-table-manual/helpers.mjs +2 -2
  21. package/esm2022/lib/_components/template/simple-table-manual/simple-table-manual.component.mjs +41 -12
  22. package/esm2022/lib/_components/template/wss-nav-bar/wss-nav-bar.component.mjs +5 -3
  23. package/esm2022/lib/_components/widget/attachment/attachment.component.mjs +7 -3
  24. package/esm2022/lib/_helpers/instructions-utils.mjs +36 -0
  25. package/esm2022/lib/_helpers/utils.mjs +2 -2
  26. package/fesm2022/pega-angular-sdk-components.mjs +782 -114
  27. package/fesm2022/pega-angular-sdk-components.mjs.map +1 -1
  28. package/lib/_bridge/angular-pconnect.d.ts +2 -0
  29. package/lib/_bridge/helpers/sdk-pega-component-map.d.ts +2 -0
  30. package/lib/_components/designSystemExtension/material-case-summary/material-case-summary.component.d.ts +2 -0
  31. package/lib/_components/designSystemExtension/operator/operator.component.d.ts +2 -1
  32. package/lib/_components/field/check-box/check-box.component.d.ts +18 -0
  33. package/lib/_components/field/multiselect/multiselect.component.d.ts +64 -0
  34. package/lib/_components/field/multiselect/utils.d.ts +8 -0
  35. package/lib/_components/field/time/time.component.d.ts +1 -0
  36. package/lib/_components/field/url/url.component.d.ts +1 -0
  37. package/lib/_components/infra/navbar/navbar.component.d.ts +2 -0
  38. package/lib/_components/template/case-summary/case-summary.component.d.ts +2 -0
  39. package/lib/_components/template/field-value-list/field-value-list.component.d.ts +2 -1
  40. package/lib/_components/template/list-view/list-view.component.d.ts +0 -2
  41. package/lib/_components/template/simple-table-manual/simple-table-manual.component.d.ts +2 -0
  42. package/lib/_components/template/wss-nav-bar/wss-nav-bar.component.d.ts +2 -0
  43. package/lib/_components/widget/attachment/attachment.component.d.ts +4 -0
  44. package/lib/_helpers/instructions-utils.d.ts +4 -0
  45. package/lib/doc/KeyReleaseUpdates.md +63 -0
  46. package/package.json +1 -1
@@ -0,0 +1,311 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { Component, forwardRef, Input } from '@angular/core';
3
+ import { FormControl, ReactiveFormsModule } from '@angular/forms';
4
+ import { MatAutocompleteModule } from '@angular/material/autocomplete';
5
+ import { MatChipsModule } from '@angular/material/chips';
6
+ import { MatCheckboxModule } from '@angular/material/checkbox';
7
+ import { MatOptionModule } from '@angular/material/core';
8
+ import { MatFormFieldModule } from '@angular/material/form-field';
9
+ import { MatInputModule } from '@angular/material/input';
10
+ import { MatIconModule } from '@angular/material/icon';
11
+ import { ComponentMapperComponent } from '../../../_bridge/component-mapper/component-mapper.component';
12
+ import { doSearch, getDisplayFieldsMetaData, getGroupDataForItemsTree, preProcessColumns } from './utils';
13
+ import { deleteInstruction, insertInstruction } from '../../../_helpers/instructions-utils';
14
+ import * as i0 from "@angular/core";
15
+ import * as i1 from "../../../_bridge/angular-pconnect";
16
+ import * as i2 from "../../../_helpers/utils";
17
+ import * as i3 from "@angular/common";
18
+ import * as i4 from "@angular/forms";
19
+ import * as i5 from "@angular/material/form-field";
20
+ import * as i6 from "@angular/material/input";
21
+ import * as i7 from "@angular/material/autocomplete";
22
+ import * as i8 from "@angular/material/core";
23
+ import * as i9 from "@angular/material/checkbox";
24
+ import * as i10 from "@angular/material/icon";
25
+ import * as i11 from "@angular/material/chips";
26
+ export class MultiselectComponent {
27
+ constructor(angularPConnect, utils) {
28
+ this.angularPConnect = angularPConnect;
29
+ this.utils = utils;
30
+ // Used with AngularPConnect
31
+ this.angularPConnectData = {};
32
+ this.label$ = '';
33
+ this.value$ = '';
34
+ this.bRequired$ = false;
35
+ this.bDisabled$ = false;
36
+ this.bVisible$ = true;
37
+ this.bHasForm$ = true;
38
+ this.fieldControl = new FormControl('', null);
39
+ this.showSecondaryInSearchOnly = false;
40
+ this.isGroupData = false;
41
+ this.groupDataSource = [];
42
+ this.matchPosition = 'contains';
43
+ this.groupColumnsConfig = [{}];
44
+ this.selectedItems = [];
45
+ this.itemsTreeBaseData = [];
46
+ this.itemsTree = [];
47
+ this.optionClicked = (event, data, trigger) => {
48
+ event.stopPropagation();
49
+ this.toggleSelection(data, trigger);
50
+ };
51
+ this.toggleSelection = (data, trigger) => {
52
+ data.selected = !data.selected;
53
+ this.trigger = trigger;
54
+ this.itemsTree.map((ele) => {
55
+ if (ele.id === data.id) {
56
+ ele.selected = data.selected;
57
+ }
58
+ return ele;
59
+ });
60
+ if (data.selected === true) {
61
+ this.selectedItems.push(data);
62
+ }
63
+ else {
64
+ const index = this.selectedItems.findIndex(value => value.id === data.id);
65
+ this.selectedItems.splice(index, 1);
66
+ }
67
+ this.value$ = '';
68
+ // if this is a referenceList case
69
+ if (this.referenceList)
70
+ this.setSelectedItemsForReferenceList(data);
71
+ this.getCaseListBasedOnParams(this.value$, '', [...this.selectedItems], [...this.itemsTree], true);
72
+ };
73
+ this.removeChip = (data) => {
74
+ if (data) {
75
+ data = this.itemsTree.filter((ele) => {
76
+ return ele.id === data.id;
77
+ });
78
+ this.toggleSelection(data[0]);
79
+ }
80
+ };
81
+ }
82
+ ngOnInit() {
83
+ // First thing in initialization is registering and subscribing to the AngularPConnect service
84
+ this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
85
+ this.controlName$ = this.angularPConnect.getComponentID(this);
86
+ // Then, continue on with other initialization
87
+ this.checkAndUpdate();
88
+ if (this.formGroup$) {
89
+ // add control to formGroup
90
+ this.formGroup$.addControl(this.controlName$, this.fieldControl);
91
+ this.fieldControl.setValue(this.value$);
92
+ this.bHasForm$ = true;
93
+ }
94
+ else {
95
+ this.bHasForm$ = false;
96
+ }
97
+ }
98
+ ngOnDestroy() {
99
+ if (this.formGroup$) {
100
+ this.formGroup$.removeControl(this.controlName$);
101
+ }
102
+ if (this.angularPConnectData.unsubscribeFn) {
103
+ this.angularPConnectData.unsubscribeFn();
104
+ }
105
+ }
106
+ // Callback passed when subscribing to store change
107
+ onStateChange() {
108
+ this.checkAndUpdate();
109
+ }
110
+ checkAndUpdate() {
111
+ // Should always check the bridge to see if the component should
112
+ // update itself (re-render)
113
+ const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
114
+ // ONLY call updateSelf when the component should update
115
+ if (bUpdateSelf) {
116
+ this.updateSelf();
117
+ }
118
+ }
119
+ // updateSelf
120
+ updateSelf() {
121
+ this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
122
+ let { datasource = [], columns = [{}] } = this.configProps$;
123
+ this.setPropertyValuesFromProps();
124
+ if (this.referenceList.length > 0) {
125
+ datasource = this.referenceList;
126
+ columns = [
127
+ {
128
+ value: this.primaryField,
129
+ display: 'true',
130
+ useForSearch: true,
131
+ primary: 'true'
132
+ },
133
+ {
134
+ value: this.selectionKey,
135
+ setProperty: this.selectionKey,
136
+ key: 'true'
137
+ }
138
+ ];
139
+ let secondaryColumns = [];
140
+ if (this.secondaryFields) {
141
+ secondaryColumns = this.secondaryFields.map(secondaryField => ({
142
+ value: secondaryField,
143
+ display: 'true',
144
+ secondary: 'true',
145
+ useForSearch: 'true'
146
+ }));
147
+ }
148
+ else {
149
+ secondaryColumns = [
150
+ {
151
+ value: this.selectionKey,
152
+ display: 'true',
153
+ secondary: 'true',
154
+ useForSearch: 'true'
155
+ }
156
+ ];
157
+ }
158
+ if (this.referenceType === 'Case') {
159
+ columns = [...columns, ...secondaryColumns];
160
+ }
161
+ }
162
+ this.value$ = this.value$ ? this.value$ : '';
163
+ const contextName = this.pConn$.getContextName();
164
+ const dataConfig = {
165
+ dataSource: datasource,
166
+ groupDataSource: this.groupDataSource,
167
+ isGroupData: this.isGroupData,
168
+ showSecondaryInSearchOnly: this.showSecondaryInSearchOnly,
169
+ parameters: this.parameters,
170
+ matchPosition: this.matchPosition,
171
+ listType: this.listType,
172
+ maxResultsDisplay: this.maxResultsDisplay || '100',
173
+ columns: preProcessColumns(columns),
174
+ groupColumnsConfig: preProcessColumns(this.groupColumnsConfig)
175
+ };
176
+ const groupsDisplayFieldMeta = this.listType !== 'associated' ? getDisplayFieldsMetaData(dataConfig.groupColumnsConfig) : null;
177
+ this.itemsTreeBaseData = getGroupDataForItemsTree(this.groupDataSource, groupsDisplayFieldMeta, this.showSecondaryInSearchOnly) || [];
178
+ this.itemsTree = this.isGroupData ? getGroupDataForItemsTree(this.groupDataSource, groupsDisplayFieldMeta, this.showSecondaryInSearchOnly) : [];
179
+ this.displayFieldMeta = this.listType !== 'associated' ? getDisplayFieldsMetaData(dataConfig.columns) : null;
180
+ this.listActions = this.pConn$.getListActions();
181
+ this.pConn$.setReferenceList(this.selectionList);
182
+ if (this.configProps$.visibility != null) {
183
+ this.bVisible$ = this.utils.getBooleanValue(this.configProps$.visibility);
184
+ }
185
+ // disabled
186
+ if (this.configProps$.disabled != undefined) {
187
+ this.bDisabled$ = this.utils.getBooleanValue(this.configProps$.disabled);
188
+ }
189
+ if (this.bDisabled$) {
190
+ this.fieldControl.disable();
191
+ }
192
+ else {
193
+ this.fieldControl.enable();
194
+ }
195
+ if (this.listType !== 'associated') {
196
+ PCore.getDataApi()
197
+ ?.init(dataConfig, contextName)
198
+ .then(async (dataObj) => {
199
+ this.dataApiObj = dataObj;
200
+ if (!this.isGroupData) {
201
+ this.getCaseListBasedOnParams(this.value$ ?? '', '', [...this.selectedItems], [...this.itemsTree]);
202
+ }
203
+ });
204
+ }
205
+ }
206
+ setPropertyValuesFromProps() {
207
+ this.label$ = this.configProps$.label;
208
+ this.placeholder = this.configProps$.placeholder || '';
209
+ this.listType = this.configProps$.listType ? this.configProps$.listType : '';
210
+ this.hideLabel = this.configProps$.hideLabel;
211
+ this.parameters = this.configProps$?.parameters ? this.configProps$?.parameters : {};
212
+ this.referenceList = this.configProps$?.referenceList;
213
+ this.selectionKey = this.configProps$?.selectionKey;
214
+ this.primaryField = this.configProps$?.primaryField;
215
+ this.initialCaseClass = this.configProps$?.initialCaseClass;
216
+ this.showSecondaryInSearchOnly = this.configProps$?.showSecondaryInSearchOnly ? this.configProps$?.showSecondaryInSearchOnly : false;
217
+ this.isGroupData = this.configProps$?.isGroupData ? this.configProps$.isGroupData : false;
218
+ this.referenceType = this.configProps$?.referenceType;
219
+ this.secondaryFields = this.configProps$?.secondaryFields;
220
+ this.groupDataSource = this.configProps$?.groupDataSource ? this.configProps$?.groupDataSource : [];
221
+ this.matchPosition = this.configProps$?.matchPosition ? this.configProps$?.matchPosition : 'contains';
222
+ this.maxResultsDisplay = this.configProps$?.maxResultsDisplay;
223
+ this.groupColumnsConfig = this.configProps$?.groupColumnsConfig ? this.configProps$?.groupColumnsConfig : [{}];
224
+ this.selectionList = this.configProps$?.selectionList;
225
+ this.value$ = this.configProps$?.value;
226
+ }
227
+ // main search function trigger
228
+ getCaseListBasedOnParams(searchText, group, selectedRows, currentItemsTree, isTriggeredFromSearch = false) {
229
+ if (this.referenceList && this.referenceList.length > 0) {
230
+ this.listActions.getSelectedRows(true).then(result => {
231
+ selectedRows =
232
+ result.length > 0
233
+ ? result.map(item => {
234
+ return {
235
+ id: item[this.selectionKey.startsWith('.') ? this.selectionKey.substring(1) : this.selectionKey],
236
+ primary: item[this.primaryField.startsWith('.') ? this.primaryField.substring(1) : this.primaryField]
237
+ };
238
+ })
239
+ : [];
240
+ this.selectedItems = selectedRows;
241
+ const initalItemsTree = isTriggeredFromSearch || !currentItemsTree ? [...this.itemsTreeBaseData] : [...currentItemsTree];
242
+ doSearch(searchText, group, this.initialCaseClass, this.displayFieldMeta, this.dataApiObj, initalItemsTree, this.isGroupData, this.showSecondaryInSearchOnly, selectedRows || []).then(res => {
243
+ this.itemsTree = res || [];
244
+ if (this.trigger) {
245
+ this.trigger.openPanel();
246
+ }
247
+ });
248
+ });
249
+ }
250
+ }
251
+ fieldOnChange(event) {
252
+ this.value$ = event.target.value;
253
+ this.getCaseListBasedOnParams(this.value$, '', [...this.selectedItems], [...this.itemsTree], true);
254
+ }
255
+ optionChanged(event) {
256
+ this.angularPConnectData.actions?.onChange(this, event);
257
+ }
258
+ setSelectedItemsForReferenceList(data) {
259
+ // Clear error messages if any
260
+ const propName = this.pConn$.getStateProps().selectionList;
261
+ this.pConn$.clearErrorMessages({
262
+ property: propName,
263
+ category: '',
264
+ context: ''
265
+ });
266
+ const { selected } = data;
267
+ if (selected) {
268
+ insertInstruction(this.pConn$, this.selectionList, this.selectionKey, this.primaryField, data);
269
+ }
270
+ else {
271
+ deleteInstruction(this.pConn$, this.selectionList, this.selectionKey, data);
272
+ }
273
+ }
274
+ getErrorMessage() {
275
+ let errMessage = '';
276
+ // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
277
+ if (this.fieldControl.hasError('message')) {
278
+ errMessage = this.angularPConnectData.validateMessage ?? '';
279
+ return errMessage;
280
+ }
281
+ if (this.fieldControl.hasError('required')) {
282
+ errMessage = 'You must enter a value';
283
+ }
284
+ else if (this.fieldControl.errors) {
285
+ errMessage = this.fieldControl.errors.toString();
286
+ }
287
+ return errMessage;
288
+ }
289
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MultiselectComponent, deps: [{ token: i1.AngularPConnectService }, { token: i2.Utils }], target: i0.ɵɵFactoryTarget.Component }); }
290
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: MultiselectComponent, isStandalone: true, selector: "app-multiselect", inputs: { pConn$: "pConn$", formGroup$: "formGroup$" }, ngImport: i0, template: "<div [formGroup]=\"formGroup$\">\n <mat-form-field class=\"psdk-full-width\" subscriptSizing=\"dynamic\">\n <mat-label>{{ label$ }}</mat-label>\n <mat-chip-grid #chipGrid>\n <ng-container *ngFor=\"let select of selectedItems\">\n <mat-chip-row (removed)=\"removeChip(select)\">\n {{ select.primary }}\n <button matChipRemove>\n <mat-icon>cancel</mat-icon>\n </button>\n </mat-chip-row>\n </ng-container>\n </mat-chip-grid>\n <input\n matInput\n [placeholder]=\"placeholder\"\n [formControl]=\"fieldControl\"\n [value]=\"value$\"\n [required]=\"bRequired$\"\n [matAutocomplete]=\"auto\"\n (input)=\"fieldOnChange($event)\"\n [matChipInputFor]=\"chipGrid\"\n #trigger=\"matAutocompleteTrigger\"\n />\n <mat-autocomplete #auto=\"matAutocomplete\">\n <mat-option *ngFor=\"let item of itemsTree\" [value]=\"item.primary\" (click)=\"optionClicked($event, item, trigger)\">\n <mat-checkbox [checked]=\"item.selected\" (click)=\"optionClicked($event, item, trigger)\">\n <span>{{ item.primary }}</span>\n </mat-checkbox>\n </mat-option>\n </mat-autocomplete>\n <mat-error *ngIf=\"fieldControl.invalid\">{{ getErrorMessage() }}</mat-error>\n </mat-form-field>\n</div>\n", styles: [".psdk-full-width{width:100%}::ng-deep .mat-mdc-form-field-infix{padding-left:10px}\n"], dependencies: [{ kind: "ngmodule", type: i0.forwardRef(function () { return CommonModule; }) }, { kind: "directive", type: i0.forwardRef(function () { return i3.NgForOf; }), selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i0.forwardRef(function () { return i3.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: i0.forwardRef(function () { return ReactiveFormsModule; }) }, { kind: "directive", type: i0.forwardRef(function () { return i4.DefaultValueAccessor; }), selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i0.forwardRef(function () { return i4.NgControlStatus; }), selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i0.forwardRef(function () { return i4.NgControlStatusGroup; }), selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i0.forwardRef(function () { return i4.RequiredValidator; }), selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i0.forwardRef(function () { return i4.FormControlDirective; }), selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i0.forwardRef(function () { return i4.FormGroupDirective; }), selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: i0.forwardRef(function () { return MatFormFieldModule; }) }, { kind: "component", type: i0.forwardRef(function () { return i5.MatFormField; }), selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i0.forwardRef(function () { return i5.MatLabel; }), selector: "mat-label" }, { kind: "directive", type: i0.forwardRef(function () { return i5.MatError; }), selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "ngmodule", type: i0.forwardRef(function () { return MatInputModule; }) }, { kind: "directive", type: i0.forwardRef(function () { return i6.MatInput; }), selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: i0.forwardRef(function () { return MatAutocompleteModule; }) }, { kind: "component", type: i0.forwardRef(function () { return i7.MatAutocomplete; }), selector: "mat-autocomplete", inputs: ["disableRipple", "hideSingleSelectionIndicator"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i0.forwardRef(function () { return i8.MatOption; }), selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i0.forwardRef(function () { return i7.MatAutocompleteTrigger; }), selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { kind: "ngmodule", type: i0.forwardRef(function () { return MatOptionModule; }) }, { kind: "ngmodule", type: i0.forwardRef(function () { return MatCheckboxModule; }) }, { kind: "component", type: i0.forwardRef(function () { return i9.MatCheckbox; }), selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "ngmodule", type: i0.forwardRef(function () { return MatIconModule; }) }, { kind: "component", type: i0.forwardRef(function () { return i10.MatIcon; }), selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: i0.forwardRef(function () { return MatChipsModule; }) }, { kind: "component", type: i0.forwardRef(function () { return i11.MatChipGrid; }), selector: "mat-chip-grid", inputs: ["tabIndex", "disabled", "placeholder", "required", "value", "errorStateMatcher"], outputs: ["change", "valueChange"] }, { kind: "directive", type: i0.forwardRef(function () { return i11.MatChipInput; }), selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { kind: "directive", type: i0.forwardRef(function () { return i11.MatChipRemove; }), selector: "[matChipRemove]" }, { kind: "component", type: i0.forwardRef(function () { return i11.MatChipRow; }), selector: "mat-chip-row, [mat-chip-row], mat-basic-chip-row, [mat-basic-chip-row]", inputs: ["color", "disabled", "disableRipple", "tabIndex", "editable"], outputs: ["edited"] }] }); }
291
+ }
292
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MultiselectComponent, decorators: [{
293
+ type: Component,
294
+ args: [{ selector: 'app-multiselect', standalone: true, imports: [
295
+ CommonModule,
296
+ ReactiveFormsModule,
297
+ MatFormFieldModule,
298
+ MatInputModule,
299
+ MatAutocompleteModule,
300
+ MatOptionModule,
301
+ MatCheckboxModule,
302
+ MatIconModule,
303
+ MatChipsModule,
304
+ forwardRef(() => ComponentMapperComponent)
305
+ ], template: "<div [formGroup]=\"formGroup$\">\n <mat-form-field class=\"psdk-full-width\" subscriptSizing=\"dynamic\">\n <mat-label>{{ label$ }}</mat-label>\n <mat-chip-grid #chipGrid>\n <ng-container *ngFor=\"let select of selectedItems\">\n <mat-chip-row (removed)=\"removeChip(select)\">\n {{ select.primary }}\n <button matChipRemove>\n <mat-icon>cancel</mat-icon>\n </button>\n </mat-chip-row>\n </ng-container>\n </mat-chip-grid>\n <input\n matInput\n [placeholder]=\"placeholder\"\n [formControl]=\"fieldControl\"\n [value]=\"value$\"\n [required]=\"bRequired$\"\n [matAutocomplete]=\"auto\"\n (input)=\"fieldOnChange($event)\"\n [matChipInputFor]=\"chipGrid\"\n #trigger=\"matAutocompleteTrigger\"\n />\n <mat-autocomplete #auto=\"matAutocomplete\">\n <mat-option *ngFor=\"let item of itemsTree\" [value]=\"item.primary\" (click)=\"optionClicked($event, item, trigger)\">\n <mat-checkbox [checked]=\"item.selected\" (click)=\"optionClicked($event, item, trigger)\">\n <span>{{ item.primary }}</span>\n </mat-checkbox>\n </mat-option>\n </mat-autocomplete>\n <mat-error *ngIf=\"fieldControl.invalid\">{{ getErrorMessage() }}</mat-error>\n </mat-form-field>\n</div>\n", styles: [".psdk-full-width{width:100%}::ng-deep .mat-mdc-form-field-infix{padding-left:10px}\n"] }]
306
+ }], ctorParameters: function () { return [{ type: i1.AngularPConnectService }, { type: i2.Utils }]; }, propDecorators: { pConn$: [{
307
+ type: Input
308
+ }], formGroup$: [{
309
+ type: Input
310
+ }] } });
311
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multiselect.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular-sdk-components/src/lib/_components/field/multiselect/multiselect.component.ts","../../../../../../../packages/angular-sdk-components/src/lib/_components/field/multiselect/multiselect.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAqB,MAAM,eAAe,CAAC;AAChF,OAAO,EAAE,WAAW,EAAa,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAC7E,OAAO,EAAE,qBAAqB,EAAwD,MAAM,gCAAgC,CAAC;AAC7H,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAEvD,OAAO,EAAE,wBAAwB,EAAE,MAAM,8DAA8D,CAAC;AAExG,OAAO,EAAE,QAAQ,EAAE,wBAAwB,EAAE,wBAAwB,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;AAC1G,OAAO,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,MAAM,sCAAsC,CAAC;;;;;;;;;;;;;AAoB5F,MAAM,OAAO,oBAAoB;IA0C/B,YACU,eAAuC,EACvC,KAAY;QADZ,oBAAe,GAAf,eAAe,CAAwB;QACvC,UAAK,GAAL,KAAK,CAAO;QAxCtB,4BAA4B;QAC5B,wBAAmB,GAAwB,EAAE,CAAC;QAE9C,WAAM,GAAG,EAAE,CAAC;QACZ,WAAM,GAAG,EAAE,CAAC;QACZ,eAAU,GAAG,KAAK,CAAC;QACnB,eAAU,GAAG,KAAK,CAAC;QACnB,cAAS,GAAG,IAAI,CAAC;QAEjB,cAAS,GAAG,IAAI,CAAC;QAGjB,iBAAY,GAAG,IAAI,WAAW,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;QASzC,8BAAyB,GAAG,KAAK,CAAC;QAClC,gBAAW,GAAG,KAAK,CAAC;QAGpB,oBAAe,GAAG,EAAE,CAAC;QACrB,kBAAa,GAAG,UAAU,CAAC;QAE3B,uBAAkB,GAAG,CAAC,EAAE,CAAC,CAAC;QAG1B,kBAAa,GAAU,EAAE,CAAC;QAC1B,sBAAiB,GAAG,EAAE,CAAC;QAGvB,cAAS,GAAU,EAAE,CAAC;QA2NtB,kBAAa,GAAG,CAAC,KAAY,EAAE,IAAS,EAAE,OAAgC,EAAQ,EAAE;YAClF,KAAK,CAAC,eAAe,EAAE,CAAC;YACxB,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QACtC,CAAC,CAAC;QAEF,oBAAe,GAAG,CAAC,IAAS,EAAE,OAAgC,EAAQ,EAAE;YACtE,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC;YAC/B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;YACvB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE;gBAC9B,IAAI,GAAG,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,EAAE;oBACtB,GAAG,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;iBAC9B;gBACD,OAAO,GAAG,CAAC;YACb,CAAC,CAAC,CAAC;YAEH,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,EAAE;gBAC1B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aAC/B;iBAAM;gBACL,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,CAAC,CAAC;gBAC1E,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;aACrC;YAED,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;YACjB,kCAAkC;YAClC,IAAI,IAAI,CAAC,aAAa;gBAAE,IAAI,CAAC,gCAAgC,CAAC,IAAI,CAAC,CAAC;YAEpE,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,CAAC;QACrG,CAAC,CAAC;QAEF,eAAU,GAAG,CAAC,IAAS,EAAQ,EAAE;YAC/B,IAAI,IAAI,EAAE;gBACR,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE;oBACxC,OAAO,GAAG,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,CAAC;gBAC5B,CAAC,CAAC,CAAC;gBACH,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;aAC/B;QACH,CAAC,CAAC;IAzPC,CAAC;IAEJ,QAAQ;QACN,8FAA8F;QAC9F,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,eAAe,CAAC,6BAA6B,CAAC,IAAI,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QACxG,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAE9D,8CAA8C;QAC9C,IAAI,CAAC,cAAc,EAAE,CAAC;QAEtB,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,2BAA2B;YAC3B,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;YACjE,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACxC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;SACvB;aAAM;YACL,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;SACxB;IACH,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;SAClD;QAED,IAAI,IAAI,CAAC,mBAAmB,CAAC,aAAa,EAAE;YAC1C,IAAI,CAAC,mBAAmB,CAAC,aAAa,EAAE,CAAC;SAC1C;IACH,CAAC;IAED,mDAAmD;IACnD,aAAa;QACX,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED,cAAc;QACZ,gEAAgE;QAChE,4BAA4B;QAC5B,MAAM,WAAW,GAAG,IAAI,CAAC,eAAe,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;QAErE,wDAAwD;QACxD,IAAI,WAAW,EAAE;YACf,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;IACH,CAAC;IAED,aAAa;IACb,UAAU;QACR,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,kBAAkB,CAAC,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC,CAAC;QAEjF,IAAI,EAAE,UAAU,GAAG,EAAE,EAAE,OAAO,GAAG,CAAC,EAAE,CAAC,EAAE,GAAG,IAAI,CAAC,YAAY,CAAC;QAC5D,IAAI,CAAC,0BAA0B,EAAE,CAAC;QAElC,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE;YACjC,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC;YAChC,OAAO,GAAG;gBACR;oBACE,KAAK,EAAE,IAAI,CAAC,YAAY;oBACxB,OAAO,EAAE,MAAM;oBACf,YAAY,EAAE,IAAI;oBAClB,OAAO,EAAE,MAAM;iBAChB;gBACD;oBACE,KAAK,EAAE,IAAI,CAAC,YAAY;oBACxB,WAAW,EAAE,IAAI,CAAC,YAAY;oBAC9B,GAAG,EAAE,MAAM;iBACZ;aACF,CAAC;YACF,IAAI,gBAAgB,GAAQ,EAAE,CAAC;YAC/B,IAAI,IAAI,CAAC,eAAe,EAAE;gBACxB,gBAAgB,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;oBAC7D,KAAK,EAAE,cAAc;oBACrB,OAAO,EAAE,MAAM;oBACf,SAAS,EAAE,MAAM;oBACjB,YAAY,EAAE,MAAM;iBACrB,CAAC,CAAC,CAAC;aACL;iBAAM;gBACL,gBAAgB,GAAG;oBACjB;wBACE,KAAK,EAAE,IAAI,CAAC,YAAY;wBACxB,OAAO,EAAE,MAAM;wBACf,SAAS,EAAE,MAAM;wBACjB,YAAY,EAAE,MAAM;qBACrB;iBACF,CAAC;aACH;YACD,IAAI,IAAI,CAAC,aAAa,KAAK,MAAM,EAAE;gBACjC,OAAO,GAAG,CAAC,GAAG,OAAO,EAAE,GAAG,gBAAgB,CAAC,CAAC;aAC7C;SACF;QAED,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC;QAC7C,MAAM,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC;QAEjD,MAAM,UAAU,GAAG;YACjB,UAAU,EAAE,UAAU;YACtB,eAAe,EAAE,IAAI,CAAC,eAAe;YACrC,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,yBAAyB,EAAE,IAAI,CAAC,yBAAyB;YACzD,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,iBAAiB,EAAE,IAAI,CAAC,iBAAiB,IAAI,KAAK;YAClD,OAAO,EAAE,iBAAiB,CAAC,OAAO,CAAC;YACnC,kBAAkB,EAAE,iBAAiB,CAAC,IAAI,CAAC,kBAAkB,CAAC;SAC/D,CAAC;QAEF,MAAM,sBAAsB,GAAG,IAAI,CAAC,QAAQ,KAAK,YAAY,CAAC,CAAC,CAAC,wBAAwB,CAAC,UAAU,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAE/H,IAAI,CAAC,iBAAiB,GAAG,wBAAwB,CAAC,IAAI,CAAC,eAAe,EAAE,sBAAsB,EAAE,IAAI,CAAC,yBAAyB,CAAC,IAAI,EAAE,CAAC;QAEtI,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,wBAAwB,CAAC,IAAI,CAAC,eAAe,EAAE,sBAAsB,EAAE,IAAI,CAAC,yBAAyB,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAEhJ,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,QAAQ,KAAK,YAAY,CAAC,CAAC,CAAC,wBAAwB,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAE7G,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC;QAChD,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAEjD,IAAI,IAAI,CAAC,YAAY,CAAC,UAAU,IAAI,IAAI,EAAE;YACxC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;SAC3E;QAED,WAAW;QACX,IAAI,IAAI,CAAC,YAAY,CAAC,QAAQ,IAAI,SAAS,EAAE;YAC3C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;SAC1E;QAED,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;SAC7B;aAAM;YACL,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;SAC5B;QAED,IAAI,IAAI,CAAC,QAAQ,KAAK,YAAY,EAAE;YAClC,KAAK,CAAC,UAAU,EAAE;gBAChB,EAAE,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC;iBAC9B,IAAI,CAAC,KAAK,EAAC,OAAO,EAAC,EAAE;gBACpB,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC;gBAC1B,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;oBACrB,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,MAAM,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;iBACpG;YACH,CAAC,CAAC,CAAC;SACN;IACH,CAAC;IAED,0BAA0B;QACxB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC;QACtC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,IAAI,EAAE,CAAC;QACvD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC;QAC7E,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC;QAC7C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC;QACrF,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,YAAY,EAAE,aAAa,CAAC;QACtD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,EAAE,YAAY,CAAC;QACpD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,EAAE,YAAY,CAAC;QACpD,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,YAAY,EAAE,gBAAgB,CAAC;QAC5D,IAAI,CAAC,yBAAyB,GAAG,IAAI,CAAC,YAAY,EAAE,yBAAyB,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,yBAAyB,CAAC,CAAC,CAAC,KAAK,CAAC;QACrI,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,EAAE,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK,CAAC;QAC1F,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,YAAY,EAAE,aAAa,CAAC;QACtD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,YAAY,EAAE,eAAe,CAAC;QAC1D,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,YAAY,EAAE,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,eAAe,CAAC,CAAC,CAAC,EAAE,CAAC;QACpG,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,YAAY,EAAE,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,aAAa,CAAC,CAAC,CAAC,UAAU,CAAC;QACtG,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,YAAY,EAAE,iBAAiB,CAAC;QAC9D,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAC/G,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,YAAY,EAAE,aAAa,CAAC;QACtD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,YAAY,EAAE,KAAK,CAAC;IACzC,CAAC;IAED,+BAA+B;IAC/B,wBAAwB,CAAC,UAAU,EAAE,KAAK,EAAE,YAAY,EAAE,gBAAgB,EAAE,qBAAqB,GAAG,KAAK;QACvG,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE;YACvD,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE;gBACnD,YAAY;oBACV,MAAM,CAAC,MAAM,GAAG,CAAC;wBACf,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;4BAChB,OAAO;gCACL,EAAE,EAAE,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC;gCAChG,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC;6BACtG,CAAC;wBACJ,CAAC,CAAC;wBACJ,CAAC,CAAC,EAAE,CAAC;gBACT,IAAI,CAAC,aAAa,GAAG,YAAY,CAAC;gBAElC,MAAM,eAAe,GAAG,qBAAqB,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,gBAAgB,CAAC,CAAC;gBAEzH,QAAQ,CACN,UAAU,EACV,KAAK,EACL,IAAI,CAAC,gBAAgB,EACrB,IAAI,CAAC,gBAAgB,EACrB,IAAI,CAAC,UAAU,EACf,eAAe,EACf,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,yBAAyB,EAC9B,YAAY,IAAI,EAAE,CACnB,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE;oBACX,IAAI,CAAC,SAAS,GAAG,GAAG,IAAI,EAAE,CAAC;oBAC3B,IAAI,IAAI,CAAC,OAAO,EAAE;wBAChB,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC;qBAC1B;gBACH,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAED,aAAa,CAAC,KAAY;QACxB,IAAI,CAAC,MAAM,GAAI,KAAK,CAAC,MAA2B,CAAC,KAAK,CAAC;QACvD,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,CAAC;IACrG,CAAC;IAED,aAAa,CAAC,KAAmC;QAC/C,IAAI,CAAC,mBAAmB,CAAC,OAAO,EAAE,QAAQ,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IAC1D,CAAC;IAwCD,gCAAgC,CAAC,IAAS;QACxC,8BAA8B;QAC9B,MAAM,QAAQ,GAAI,IAAI,CAAC,MAAM,CAAC,aAAa,EAAU,CAAC,aAAa,CAAC;QACpE,IAAI,CAAC,MAAM,CAAC,kBAAkB,CAAC;YAC7B,QAAQ,EAAE,QAAQ;YAClB,QAAQ,EAAE,EAAE;YACZ,OAAO,EAAE,EAAE;SACZ,CAAC,CAAC;QACH,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC;QAC1B,IAAI,QAAQ,EAAE;YACZ,iBAAiB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;SAChG;aAAM;YACL,iBAAiB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;SAC7E;IACH,CAAC;IAED,eAAe;QACb,IAAI,UAAU,GAAG,EAAE,CAAC;QAEpB,iGAAiG;QACjG,IAAI,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE;YACzC,UAAU,GAAG,IAAI,CAAC,mBAAmB,CAAC,eAAe,IAAI,EAAE,CAAC;YAC5D,OAAO,UAAU,CAAC;SACnB;QACD,IAAI,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE;YAC1C,UAAU,GAAG,wBAAwB,CAAC;SACvC;aAAM,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE;YACnC,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;SAClD;QAED,OAAO,UAAU,CAAC;IACpB,CAAC;+GAvUU,oBAAoB;mGAApB,oBAAoB,mIClCjC,gzCAkCA,gLDZI,YAAY,oXACZ,mBAAmB,o2CACnB,kBAAkB,miBAClB,cAAc,wbACd,qBAAqB,4lBACrB,eAAe,qEACf,iBAAiB,8PACjB,aAAa,kQACb,cAAc;;4FAIL,oBAAoB;kBAlBhC,SAAS;+BACE,iBAAiB,cAGf,IAAI,WACP;wBACP,YAAY;wBACZ,mBAAmB;wBACnB,kBAAkB;wBAClB,cAAc;wBACd,qBAAqB;wBACrB,eAAe;wBACf,iBAAiB;wBACjB,aAAa;wBACb,cAAc;wBACd,UAAU,CAAC,GAAG,EAAE,CAAC,wBAAwB,CAAC;qBAC3C;iIAGQ,MAAM;sBAAd,KAAK;gBACG,UAAU;sBAAlB,KAAK","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, forwardRef, Input, OnDestroy, OnInit } from '@angular/core';\nimport { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';\nimport { MatAutocompleteModule, MatAutocompleteSelectedEvent, MatAutocompleteTrigger } from '@angular/material/autocomplete';\nimport { MatChipsModule } from '@angular/material/chips';\nimport { MatCheckboxModule } from '@angular/material/checkbox';\nimport { MatOptionModule } from '@angular/material/core';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatIconModule } from '@angular/material/icon';\nimport { AngularPConnectData, AngularPConnectService } from '../../../_bridge/angular-pconnect';\nimport { ComponentMapperComponent } from '../../../_bridge/component-mapper/component-mapper.component';\nimport { Utils } from '../../../_helpers/utils';\nimport { doSearch, getDisplayFieldsMetaData, getGroupDataForItemsTree, preProcessColumns } from './utils';\nimport { deleteInstruction, insertInstruction } from '../../../_helpers/instructions-utils';\n\n@Component({\n  selector: 'app-multiselect',\n  templateUrl: './multiselect.component.html',\n  styleUrls: ['./multiselect.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    MatFormFieldModule,\n    MatInputModule,\n    MatAutocompleteModule,\n    MatOptionModule,\n    MatCheckboxModule,\n    MatIconModule,\n    MatChipsModule,\n    forwardRef(() => ComponentMapperComponent)\n  ]\n})\nexport class MultiselectComponent implements OnInit, OnDestroy {\n  @Input() pConn$: typeof PConnect;\n  @Input() formGroup$: FormGroup;\n\n  // Used with AngularPConnect\n  angularPConnectData: AngularPConnectData = {};\n\n  label$ = '';\n  value$ = '';\n  bRequired$ = false;\n  bDisabled$ = false;\n  bVisible$ = true;\n  controlName$: string;\n  bHasForm$ = true;\n  listType: string;\n  placeholder: string;\n  fieldControl = new FormControl('', null);\n  parameters: {};\n  hideLabel: boolean;\n  configProps$: any;\n\n  referenceList: any;\n  selectionKey: string;\n  primaryField: string;\n  initialCaseClass: any;\n  showSecondaryInSearchOnly = false;\n  isGroupData = false;\n  referenceType;\n  secondaryFields;\n  groupDataSource = [];\n  matchPosition = 'contains';\n  maxResultsDisplay;\n  groupColumnsConfig = [{}];\n  selectionList;\n  listActions: any;\n  selectedItems: any[] = [];\n  itemsTreeBaseData = [];\n  displayFieldMeta: any;\n  dataApiObj: any;\n  itemsTree: any[] = [];\n  trigger: any;\n\n  constructor(\n    private angularPConnect: AngularPConnectService,\n    private utils: Utils\n  ) {}\n\n  ngOnInit(): void {\n    // First thing in initialization is registering and subscribing to the AngularPConnect service\n    this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);\n    this.controlName$ = this.angularPConnect.getComponentID(this);\n\n    // Then, continue on with other initialization\n    this.checkAndUpdate();\n\n    if (this.formGroup$) {\n      // add control to formGroup\n      this.formGroup$.addControl(this.controlName$, this.fieldControl);\n      this.fieldControl.setValue(this.value$);\n      this.bHasForm$ = true;\n    } else {\n      this.bHasForm$ = false;\n    }\n  }\n\n  ngOnDestroy(): void {\n    if (this.formGroup$) {\n      this.formGroup$.removeControl(this.controlName$);\n    }\n\n    if (this.angularPConnectData.unsubscribeFn) {\n      this.angularPConnectData.unsubscribeFn();\n    }\n  }\n\n  // Callback passed when subscribing to store change\n  onStateChange() {\n    this.checkAndUpdate();\n  }\n\n  checkAndUpdate() {\n    // Should always check the bridge to see if the component should\n    // update itself (re-render)\n    const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);\n\n    // ONLY call updateSelf when the component should update\n    if (bUpdateSelf) {\n      this.updateSelf();\n    }\n  }\n\n  // updateSelf\n  updateSelf() {\n    this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());\n\n    let { datasource = [], columns = [{}] } = this.configProps$;\n    this.setPropertyValuesFromProps();\n\n    if (this.referenceList.length > 0) {\n      datasource = this.referenceList;\n      columns = [\n        {\n          value: this.primaryField,\n          display: 'true',\n          useForSearch: true,\n          primary: 'true'\n        },\n        {\n          value: this.selectionKey,\n          setProperty: this.selectionKey,\n          key: 'true'\n        }\n      ];\n      let secondaryColumns: any = [];\n      if (this.secondaryFields) {\n        secondaryColumns = this.secondaryFields.map(secondaryField => ({\n          value: secondaryField,\n          display: 'true',\n          secondary: 'true',\n          useForSearch: 'true'\n        }));\n      } else {\n        secondaryColumns = [\n          {\n            value: this.selectionKey,\n            display: 'true',\n            secondary: 'true',\n            useForSearch: 'true'\n          }\n        ];\n      }\n      if (this.referenceType === 'Case') {\n        columns = [...columns, ...secondaryColumns];\n      }\n    }\n\n    this.value$ = this.value$ ? this.value$ : '';\n    const contextName = this.pConn$.getContextName();\n\n    const dataConfig = {\n      dataSource: datasource,\n      groupDataSource: this.groupDataSource,\n      isGroupData: this.isGroupData,\n      showSecondaryInSearchOnly: this.showSecondaryInSearchOnly,\n      parameters: this.parameters,\n      matchPosition: this.matchPosition,\n      listType: this.listType,\n      maxResultsDisplay: this.maxResultsDisplay || '100',\n      columns: preProcessColumns(columns),\n      groupColumnsConfig: preProcessColumns(this.groupColumnsConfig)\n    };\n\n    const groupsDisplayFieldMeta = this.listType !== 'associated' ? getDisplayFieldsMetaData(dataConfig.groupColumnsConfig) : null;\n\n    this.itemsTreeBaseData = getGroupDataForItemsTree(this.groupDataSource, groupsDisplayFieldMeta, this.showSecondaryInSearchOnly) || [];\n\n    this.itemsTree = this.isGroupData ? getGroupDataForItemsTree(this.groupDataSource, groupsDisplayFieldMeta, this.showSecondaryInSearchOnly) : [];\n\n    this.displayFieldMeta = this.listType !== 'associated' ? getDisplayFieldsMetaData(dataConfig.columns) : null;\n\n    this.listActions = this.pConn$.getListActions();\n    this.pConn$.setReferenceList(this.selectionList);\n\n    if (this.configProps$.visibility != null) {\n      this.bVisible$ = this.utils.getBooleanValue(this.configProps$.visibility);\n    }\n\n    // disabled\n    if (this.configProps$.disabled != undefined) {\n      this.bDisabled$ = this.utils.getBooleanValue(this.configProps$.disabled);\n    }\n\n    if (this.bDisabled$) {\n      this.fieldControl.disable();\n    } else {\n      this.fieldControl.enable();\n    }\n\n    if (this.listType !== 'associated') {\n      PCore.getDataApi()\n        ?.init(dataConfig, contextName)\n        .then(async dataObj => {\n          this.dataApiObj = dataObj;\n          if (!this.isGroupData) {\n            this.getCaseListBasedOnParams(this.value$ ?? '', '', [...this.selectedItems], [...this.itemsTree]);\n          }\n        });\n    }\n  }\n\n  setPropertyValuesFromProps() {\n    this.label$ = this.configProps$.label;\n    this.placeholder = this.configProps$.placeholder || '';\n    this.listType = this.configProps$.listType ? this.configProps$.listType : '';\n    this.hideLabel = this.configProps$.hideLabel;\n    this.parameters = this.configProps$?.parameters ? this.configProps$?.parameters : {};\n    this.referenceList = this.configProps$?.referenceList;\n    this.selectionKey = this.configProps$?.selectionKey;\n    this.primaryField = this.configProps$?.primaryField;\n    this.initialCaseClass = this.configProps$?.initialCaseClass;\n    this.showSecondaryInSearchOnly = this.configProps$?.showSecondaryInSearchOnly ? this.configProps$?.showSecondaryInSearchOnly : false;\n    this.isGroupData = this.configProps$?.isGroupData ? this.configProps$.isGroupData : false;\n    this.referenceType = this.configProps$?.referenceType;\n    this.secondaryFields = this.configProps$?.secondaryFields;\n    this.groupDataSource = this.configProps$?.groupDataSource ? this.configProps$?.groupDataSource : [];\n    this.matchPosition = this.configProps$?.matchPosition ? this.configProps$?.matchPosition : 'contains';\n    this.maxResultsDisplay = this.configProps$?.maxResultsDisplay;\n    this.groupColumnsConfig = this.configProps$?.groupColumnsConfig ? this.configProps$?.groupColumnsConfig : [{}];\n    this.selectionList = this.configProps$?.selectionList;\n    this.value$ = this.configProps$?.value;\n  }\n\n  // main search function trigger\n  getCaseListBasedOnParams(searchText, group, selectedRows, currentItemsTree, isTriggeredFromSearch = false) {\n    if (this.referenceList && this.referenceList.length > 0) {\n      this.listActions.getSelectedRows(true).then(result => {\n        selectedRows =\n          result.length > 0\n            ? result.map(item => {\n                return {\n                  id: item[this.selectionKey.startsWith('.') ? this.selectionKey.substring(1) : this.selectionKey],\n                  primary: item[this.primaryField.startsWith('.') ? this.primaryField.substring(1) : this.primaryField]\n                };\n              })\n            : [];\n        this.selectedItems = selectedRows;\n\n        const initalItemsTree = isTriggeredFromSearch || !currentItemsTree ? [...this.itemsTreeBaseData] : [...currentItemsTree];\n\n        doSearch(\n          searchText,\n          group,\n          this.initialCaseClass,\n          this.displayFieldMeta,\n          this.dataApiObj,\n          initalItemsTree,\n          this.isGroupData,\n          this.showSecondaryInSearchOnly,\n          selectedRows || []\n        ).then(res => {\n          this.itemsTree = res || [];\n          if (this.trigger) {\n            this.trigger.openPanel();\n          }\n        });\n      });\n    }\n  }\n\n  fieldOnChange(event: Event) {\n    this.value$ = (event.target as HTMLInputElement).value;\n    this.getCaseListBasedOnParams(this.value$, '', [...this.selectedItems], [...this.itemsTree], true);\n  }\n\n  optionChanged(event: MatAutocompleteSelectedEvent) {\n    this.angularPConnectData.actions?.onChange(this, event);\n  }\n\n  optionClicked = (event: Event, data: any, trigger?: MatAutocompleteTrigger): void => {\n    event.stopPropagation();\n    this.toggleSelection(data, trigger);\n  };\n\n  toggleSelection = (data: any, trigger?: MatAutocompleteTrigger): void => {\n    data.selected = !data.selected;\n    this.trigger = trigger;\n    this.itemsTree.map((ele: any) => {\n      if (ele.id === data.id) {\n        ele.selected = data.selected;\n      }\n      return ele;\n    });\n\n    if (data.selected === true) {\n      this.selectedItems.push(data);\n    } else {\n      const index = this.selectedItems.findIndex(value => value.id === data.id);\n      this.selectedItems.splice(index, 1);\n    }\n\n    this.value$ = '';\n    // if this is a referenceList case\n    if (this.referenceList) this.setSelectedItemsForReferenceList(data);\n\n    this.getCaseListBasedOnParams(this.value$, '', [...this.selectedItems], [...this.itemsTree], true);\n  };\n\n  removeChip = (data: any): void => {\n    if (data) {\n      data = this.itemsTree.filter((ele: any) => {\n        return ele.id === data.id;\n      });\n      this.toggleSelection(data[0]);\n    }\n  };\n\n  setSelectedItemsForReferenceList(data: any) {\n    // Clear error messages if any\n    const propName = (this.pConn$.getStateProps() as any).selectionList;\n    this.pConn$.clearErrorMessages({\n      property: propName,\n      category: '',\n      context: ''\n    });\n    const { selected } = data;\n    if (selected) {\n      insertInstruction(this.pConn$, this.selectionList, this.selectionKey, this.primaryField, data);\n    } else {\n      deleteInstruction(this.pConn$, this.selectionList, this.selectionKey, data);\n    }\n  }\n\n  getErrorMessage() {\n    let errMessage = '';\n\n    // look for validation messages for json, pre-defined or just an error pushed from workitem (400)\n    if (this.fieldControl.hasError('message')) {\n      errMessage = this.angularPConnectData.validateMessage ?? '';\n      return errMessage;\n    }\n    if (this.fieldControl.hasError('required')) {\n      errMessage = 'You must enter a value';\n    } else if (this.fieldControl.errors) {\n      errMessage = this.fieldControl.errors.toString();\n    }\n\n    return errMessage;\n  }\n}\n","<div [formGroup]=\"formGroup$\">\n  <mat-form-field class=\"psdk-full-width\" subscriptSizing=\"dynamic\">\n    <mat-label>{{ label$ }}</mat-label>\n    <mat-chip-grid #chipGrid>\n      <ng-container *ngFor=\"let select of selectedItems\">\n        <mat-chip-row (removed)=\"removeChip(select)\">\n          {{ select.primary }}\n          <button matChipRemove>\n            <mat-icon>cancel</mat-icon>\n          </button>\n        </mat-chip-row>\n      </ng-container>\n    </mat-chip-grid>\n    <input\n      matInput\n      [placeholder]=\"placeholder\"\n      [formControl]=\"fieldControl\"\n      [value]=\"value$\"\n      [required]=\"bRequired$\"\n      [matAutocomplete]=\"auto\"\n      (input)=\"fieldOnChange($event)\"\n      [matChipInputFor]=\"chipGrid\"\n      #trigger=\"matAutocompleteTrigger\"\n    />\n    <mat-autocomplete #auto=\"matAutocomplete\">\n      <mat-option *ngFor=\"let item of itemsTree\" [value]=\"item.primary\" (click)=\"optionClicked($event, item, trigger)\">\n        <mat-checkbox [checked]=\"item.selected\" (click)=\"optionClicked($event, item, trigger)\">\n          <span>{{ item.primary }}</span>\n        </mat-checkbox>\n      </mat-option>\n    </mat-autocomplete>\n    <mat-error *ngIf=\"fieldControl.invalid\">{{ getErrorMessage() }}</mat-error>\n  </mat-form-field>\n</div>\n"]}
@@ -0,0 +1,187 @@
1
+ import cloneDeep from 'lodash/cloneDeep';
2
+ export function setVisibilityForList(c11nEnv, visibility) {
3
+ const { selectionMode, selectionList, renderMode, referenceList } = c11nEnv.getComponentConfig();
4
+ // usecase:multiselect, fieldgroup, editable table
5
+ if ((selectionMode === PCore.getConstants().LIST_SELECTION_MODE.MULTI && selectionList) || (renderMode === 'Editable' && referenceList)) {
6
+ c11nEnv.getListActions().setVisibility(visibility);
7
+ }
8
+ }
9
+ function preProcessColumns(columns) {
10
+ return columns?.map(col => {
11
+ const tempColObj = { ...col };
12
+ tempColObj.value = col.value && col.value.startsWith('.') ? col.value.substring(1) : col.value;
13
+ if (tempColObj.setProperty) {
14
+ tempColObj.setProperty = col.setProperty && col.setProperty.startsWith('.') ? col.setProperty.substring(1) : col.setProperty;
15
+ }
16
+ return tempColObj;
17
+ });
18
+ }
19
+ function getDisplayFieldsMetaData(columns) {
20
+ const displayColumns = columns?.filter(col => col.display === 'true');
21
+ const metaDataObj = {
22
+ key: '',
23
+ primary: '',
24
+ secondary: []
25
+ };
26
+ const keyCol = columns?.filter(col => col.key === 'true');
27
+ metaDataObj.key = keyCol?.length > 0 ? keyCol[0].value : 'auto';
28
+ const itemsRecordsColumn = columns?.filter(col => col.itemsRecordsColumn === 'true');
29
+ if (itemsRecordsColumn?.length > 0) {
30
+ metaDataObj.itemsRecordsColumn = itemsRecordsColumn[0].value;
31
+ }
32
+ const itemsGroupKeyColumn = columns?.filter(col => col.itemsGroupKeyColumn === 'true');
33
+ if (itemsGroupKeyColumn?.length > 0) {
34
+ metaDataObj.itemsGroupKeyColumn = itemsGroupKeyColumn[0].value;
35
+ }
36
+ for (let index = 0; index < displayColumns?.length; index += 1) {
37
+ if (displayColumns[index].secondary === 'true') {
38
+ metaDataObj.secondary.push(displayColumns[index].value);
39
+ }
40
+ else if (displayColumns[index].primary === 'true') {
41
+ metaDataObj.primary = displayColumns[index].value;
42
+ }
43
+ }
44
+ return metaDataObj;
45
+ }
46
+ function createSingleTreeObejct(entry, displayFieldMeta, showSecondaryData, selected) {
47
+ const secondaryArr = [];
48
+ displayFieldMeta.secondary.forEach(col => {
49
+ secondaryArr.push(entry[col]);
50
+ });
51
+ const isSelected = selected.some(item => item.id === entry[displayFieldMeta.key]);
52
+ return {
53
+ id: entry[displayFieldMeta.key],
54
+ primary: entry[displayFieldMeta.primary],
55
+ secondary: showSecondaryData ? secondaryArr : [],
56
+ selected: isSelected
57
+ };
58
+ }
59
+ function putItemsDataInItemsTree(listObjData, displayFieldMeta, itemsTree, showSecondaryInSearchOnly, selected) {
60
+ let newTreeItems = itemsTree.slice();
61
+ const showSecondaryData = !showSecondaryInSearchOnly;
62
+ for (const obj of listObjData) {
63
+ const items = obj[displayFieldMeta.itemsRecordsColumn].map(entry => createSingleTreeObejct(entry, displayFieldMeta, showSecondaryData, selected));
64
+ newTreeItems = newTreeItems.map(caseObject => {
65
+ if (caseObject.id === obj[displayFieldMeta.itemsGroupKeyColumn]) {
66
+ caseObject.items = [...items];
67
+ }
68
+ return caseObject;
69
+ });
70
+ }
71
+ return newTreeItems;
72
+ }
73
+ function prepareSearchResults(listObjData, displayFieldMeta) {
74
+ const searchResults = [];
75
+ for (const obj of listObjData) {
76
+ searchResults.push(...obj[displayFieldMeta.itemsRecordsColumn]);
77
+ }
78
+ return searchResults;
79
+ }
80
+ async function doSearch(searchText, clickedGroup, initialCaseClass, displayFieldMeta, dataApiObj, // deep clone of the dataApiObj
81
+ itemsTree, isGroupData, showSecondaryInSearchOnly, selected) {
82
+ let searchTextForUngroupedData = '';
83
+ if (dataApiObj) {
84
+ // creating dataApiObject in grouped data cases
85
+ if (isGroupData) {
86
+ dataApiObj = cloneDeep(dataApiObj);
87
+ dataApiObj.fetchedNQData = false;
88
+ dataApiObj.cache = {};
89
+ // if we have no search text and no group selected, return the original tree
90
+ if (searchText === '' && clickedGroup === '') {
91
+ return itemsTree;
92
+ }
93
+ // setting the inital search text & search classes in ApiObject
94
+ dataApiObj.parameters[Object.keys(dataApiObj.parameters)[1]] = searchText;
95
+ dataApiObj.parameters[Object.keys(dataApiObj.parameters)[0]] = initialCaseClass;
96
+ // if we have a selected group
97
+ if (clickedGroup) {
98
+ // check if the data for this group is already present and no search text
99
+ if (searchText === '') {
100
+ const containsData = itemsTree.find(item => item.id === clickedGroup);
101
+ // do not make API call when items of respective group are already fetched
102
+ if (containsData?.items?.length)
103
+ return itemsTree;
104
+ }
105
+ dataApiObj.parameters[Object.keys(dataApiObj.parameters)[0]] = JSON.stringify([clickedGroup]);
106
+ }
107
+ }
108
+ else {
109
+ searchTextForUngroupedData = searchText;
110
+ }
111
+ // search API call
112
+ const response = await dataApiObj.fetchData(searchTextForUngroupedData).catch(() => {
113
+ return itemsTree;
114
+ });
115
+ let listObjData = response.data;
116
+ let newItemsTree = [];
117
+ if (isGroupData) {
118
+ if (searchText) {
119
+ listObjData = prepareSearchResults(listObjData, displayFieldMeta);
120
+ }
121
+ else {
122
+ newItemsTree = putItemsDataInItemsTree(listObjData, displayFieldMeta, itemsTree, showSecondaryInSearchOnly, selected);
123
+ return newItemsTree;
124
+ }
125
+ }
126
+ const showSecondaryData = showSecondaryInSearchOnly ? !!searchText : true;
127
+ if (listObjData !== undefined && listObjData.length > 0) {
128
+ newItemsTree = listObjData.map(entry => createSingleTreeObejct(entry, displayFieldMeta, showSecondaryData, selected));
129
+ }
130
+ return newItemsTree;
131
+ }
132
+ return itemsTree;
133
+ }
134
+ function setValuesToPropertyList(searchText, assocProp, items, columns, actions, updatePropertyInRedux = true) {
135
+ const setPropertyList = columns
136
+ ?.filter(col => col.setProperty)
137
+ .map(col => {
138
+ return {
139
+ source: col.value,
140
+ target: col.setProperty,
141
+ key: col.key,
142
+ primary: col.primary
143
+ };
144
+ });
145
+ const valueToSet = [];
146
+ if (setPropertyList.length > 0) {
147
+ setPropertyList.forEach(prop => {
148
+ items.forEach(item => {
149
+ if (prop.key === 'true' && item) {
150
+ valueToSet.push(item.id);
151
+ }
152
+ else if (prop.primary === 'true' || !item) {
153
+ valueToSet.push(searchText);
154
+ }
155
+ });
156
+ if (updatePropertyInRedux) {
157
+ // BUG-666851 setting options so that the store values are replaced and not merged
158
+ const options = {
159
+ isArrayDeepMerge: false
160
+ };
161
+ if (prop.target === 'Associated property') {
162
+ actions.updateFieldValue(assocProp, valueToSet, options);
163
+ }
164
+ else {
165
+ actions.updateFieldValue(`.${prop.target}`, valueToSet, options);
166
+ }
167
+ }
168
+ });
169
+ }
170
+ return valueToSet;
171
+ }
172
+ function getGroupDataForItemsTree(groupDataSource, groupsDisplayFieldMeta, showSecondaryInSearchOnly) {
173
+ return groupDataSource?.map(group => {
174
+ const secondaryArr = [];
175
+ groupsDisplayFieldMeta.secondary.forEach(col => {
176
+ secondaryArr.push(group[col]);
177
+ });
178
+ return {
179
+ id: group[groupsDisplayFieldMeta.key],
180
+ primary: group[groupsDisplayFieldMeta.primary],
181
+ secondary: showSecondaryInSearchOnly ? [] : secondaryArr,
182
+ items: []
183
+ };
184
+ });
185
+ }
186
+ export { preProcessColumns, getDisplayFieldsMetaData, doSearch, setValuesToPropertyList, getGroupDataForItemsTree };
187
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../../../packages/angular-sdk-components/src/lib/_components/field/multiselect/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import cloneDeep from 'lodash/cloneDeep';\n\nexport function setVisibilityForList(c11nEnv, visibility) {\n  const { selectionMode, selectionList, renderMode, referenceList } = c11nEnv.getComponentConfig();\n  // usecase:multiselect, fieldgroup, editable table\n  if ((selectionMode === PCore.getConstants().LIST_SELECTION_MODE.MULTI && selectionList) || (renderMode === 'Editable' && referenceList)) {\n    c11nEnv.getListActions().setVisibility(visibility);\n  }\n}\n\nfunction preProcessColumns(columns) {\n  return columns?.map(col => {\n    const tempColObj = { ...col };\n    tempColObj.value = col.value && col.value.startsWith('.') ? col.value.substring(1) : col.value;\n    if (tempColObj.setProperty) {\n      tempColObj.setProperty = col.setProperty && col.setProperty.startsWith('.') ? col.setProperty.substring(1) : col.setProperty;\n    }\n    return tempColObj;\n  });\n}\n\nfunction getDisplayFieldsMetaData(columns) {\n  const displayColumns = columns?.filter(col => col.display === 'true');\n  const metaDataObj: any = {\n    key: '',\n    primary: '',\n    secondary: []\n  };\n  const keyCol = columns?.filter(col => col.key === 'true');\n  metaDataObj.key = keyCol?.length > 0 ? keyCol[0].value : 'auto';\n  const itemsRecordsColumn = columns?.filter(col => col.itemsRecordsColumn === 'true');\n  if (itemsRecordsColumn?.length > 0) {\n    metaDataObj.itemsRecordsColumn = itemsRecordsColumn[0].value;\n  }\n  const itemsGroupKeyColumn = columns?.filter(col => col.itemsGroupKeyColumn === 'true');\n  if (itemsGroupKeyColumn?.length > 0) {\n    metaDataObj.itemsGroupKeyColumn = itemsGroupKeyColumn[0].value;\n  }\n  for (let index = 0; index < displayColumns?.length; index += 1) {\n    if (displayColumns[index].secondary === 'true') {\n      metaDataObj.secondary.push(displayColumns[index].value);\n    } else if (displayColumns[index].primary === 'true') {\n      metaDataObj.primary = displayColumns[index].value;\n    }\n  }\n  return metaDataObj;\n}\n\nfunction createSingleTreeObejct(entry, displayFieldMeta, showSecondaryData, selected) {\n  const secondaryArr: any = [];\n  displayFieldMeta.secondary.forEach(col => {\n    secondaryArr.push(entry[col]);\n  });\n  const isSelected = selected.some(item => item.id === entry[displayFieldMeta.key]);\n\n  return {\n    id: entry[displayFieldMeta.key],\n    primary: entry[displayFieldMeta.primary],\n    secondary: showSecondaryData ? secondaryArr : [],\n    selected: isSelected\n  };\n}\n\nfunction putItemsDataInItemsTree(listObjData, displayFieldMeta, itemsTree, showSecondaryInSearchOnly, selected) {\n  let newTreeItems = itemsTree.slice();\n  const showSecondaryData = !showSecondaryInSearchOnly;\n  for (const obj of listObjData) {\n    const items = obj[displayFieldMeta.itemsRecordsColumn].map(entry => createSingleTreeObejct(entry, displayFieldMeta, showSecondaryData, selected));\n\n    newTreeItems = newTreeItems.map(caseObject => {\n      if (caseObject.id === obj[displayFieldMeta.itemsGroupKeyColumn]) {\n        caseObject.items = [...items];\n      }\n      return caseObject;\n    });\n  }\n  return newTreeItems;\n}\n\nfunction prepareSearchResults(listObjData, displayFieldMeta) {\n  const searchResults: any = [];\n  for (const obj of listObjData) {\n    searchResults.push(...obj[displayFieldMeta.itemsRecordsColumn]);\n  }\n  return searchResults;\n}\n\nasync function doSearch(\n  searchText,\n  clickedGroup,\n  initialCaseClass,\n  displayFieldMeta,\n  dataApiObj, // deep clone of the dataApiObj\n  itemsTree,\n  isGroupData,\n  showSecondaryInSearchOnly,\n  selected\n) {\n  let searchTextForUngroupedData = '';\n  if (dataApiObj) {\n    // creating dataApiObject in grouped data cases\n    if (isGroupData) {\n      dataApiObj = cloneDeep(dataApiObj);\n      dataApiObj.fetchedNQData = false;\n      dataApiObj.cache = {};\n\n      // if we have no search text and no group selected, return the original tree\n      if (searchText === '' && clickedGroup === '') {\n        return itemsTree;\n      }\n\n      // setting the inital search text & search classes in ApiObject\n      dataApiObj.parameters[Object.keys(dataApiObj.parameters)[1]] = searchText;\n      dataApiObj.parameters[Object.keys(dataApiObj.parameters)[0]] = initialCaseClass;\n\n      // if we have a selected group\n      if (clickedGroup) {\n        // check if the data for this group is already present and no search text\n        if (searchText === '') {\n          const containsData = itemsTree.find(item => item.id === clickedGroup);\n          // do not make API call when items of respective group are already fetched\n          if (containsData?.items?.length) return itemsTree;\n        }\n\n        dataApiObj.parameters[Object.keys(dataApiObj.parameters)[0]] = JSON.stringify([clickedGroup]);\n      }\n    } else {\n      searchTextForUngroupedData = searchText;\n    }\n\n    // search API call\n    const response = await dataApiObj.fetchData(searchTextForUngroupedData).catch(() => {\n      return itemsTree;\n    });\n\n    let listObjData = response.data;\n    let newItemsTree = [];\n    if (isGroupData) {\n      if (searchText) {\n        listObjData = prepareSearchResults(listObjData, displayFieldMeta);\n      } else {\n        newItemsTree = putItemsDataInItemsTree(listObjData, displayFieldMeta, itemsTree, showSecondaryInSearchOnly, selected);\n        return newItemsTree;\n      }\n    }\n    const showSecondaryData = showSecondaryInSearchOnly ? !!searchText : true;\n    if (listObjData !== undefined && listObjData.length > 0) {\n      newItemsTree = listObjData.map(entry => createSingleTreeObejct(entry, displayFieldMeta, showSecondaryData, selected));\n    }\n    return newItemsTree;\n  }\n\n  return itemsTree;\n}\n\nfunction setValuesToPropertyList(searchText, assocProp, items, columns, actions, updatePropertyInRedux = true) {\n  const setPropertyList = columns\n    ?.filter(col => col.setProperty)\n    .map(col => {\n      return {\n        source: col.value,\n        target: col.setProperty,\n        key: col.key,\n        primary: col.primary\n      };\n    });\n  const valueToSet: any = [];\n  if (setPropertyList.length > 0) {\n    setPropertyList.forEach(prop => {\n      items.forEach(item => {\n        if (prop.key === 'true' && item) {\n          valueToSet.push(item.id);\n        } else if (prop.primary === 'true' || !item) {\n          valueToSet.push(searchText);\n        }\n      });\n\n      if (updatePropertyInRedux) {\n        // BUG-666851 setting options so that the store values are replaced and not merged\n        const options = {\n          isArrayDeepMerge: false\n        };\n        if (prop.target === 'Associated property') {\n          actions.updateFieldValue(assocProp, valueToSet, options);\n        } else {\n          actions.updateFieldValue(`.${prop.target}`, valueToSet, options);\n        }\n      }\n    });\n  }\n  return valueToSet;\n}\n\nfunction getGroupDataForItemsTree(groupDataSource, groupsDisplayFieldMeta, showSecondaryInSearchOnly) {\n  return groupDataSource?.map(group => {\n    const secondaryArr: any = [];\n    groupsDisplayFieldMeta.secondary.forEach(col => {\n      secondaryArr.push(group[col]);\n    });\n    return {\n      id: group[groupsDisplayFieldMeta.key],\n      primary: group[groupsDisplayFieldMeta.primary],\n      secondary: showSecondaryInSearchOnly ? [] : secondaryArr,\n      items: []\n    };\n  });\n}\n\nexport { preProcessColumns, getDisplayFieldsMetaData, doSearch, setValuesToPropertyList, getGroupDataForItemsTree };\n"]}