@colijnit/corecomponents_v12 12.0.103 → 12.0.104

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 (49) hide show
  1. package/bundles/colijnit-corecomponents_v12.umd.js +606 -238
  2. package/bundles/colijnit-corecomponents_v12.umd.js.map +1 -1
  3. package/colijnit-corecomponents_v12.d.ts +11 -10
  4. package/colijnit-corecomponents_v12.metadata.json +1 -1
  5. package/esm2015/colijnit-corecomponents_v12.js +12 -11
  6. package/esm2015/lib/components/list-of-values/list-of-values-popup.component.js +79 -0
  7. package/esm2015/lib/components/list-of-values/list-of-values.component.js +174 -0
  8. package/esm2015/lib/components/list-of-values/list-of-values.module.js +33 -0
  9. package/esm2015/lib/components/list-of-values-multiselect-search/list-of-values-multiselect-search.component.js +101 -0
  10. package/esm2015/lib/components/list-of-values-multiselect-search/list-of-values-multiselect-search.module.js +25 -0
  11. package/esm2015/lib/directives/overlay/overlay.directive.js +7 -2
  12. package/esm2015/lib/service/overlay.service.js +9 -2
  13. package/esm2015/public-api.js +5 -1
  14. package/fesm2015/colijnit-corecomponents_v12.js +659 -263
  15. package/fesm2015/colijnit-corecomponents_v12.js.map +1 -1
  16. package/lib/components/base-input-date-picker/style/_layout.scss +91 -0
  17. package/lib/components/base-input-date-picker/style/_material-definition.scss +0 -0
  18. package/lib/components/base-input-date-picker/style/_theme.scss +4 -0
  19. package/lib/components/base-input-date-picker/style/material.scss +4 -0
  20. package/lib/components/co-input-date-picker/style/_layout.scss +5 -0
  21. package/lib/components/co-input-date-picker/style/_material-definition.scss +0 -0
  22. package/lib/components/co-input-date-picker/style/_theme.scss +0 -0
  23. package/lib/components/co-input-date-picker/style/material.scss +4 -0
  24. package/lib/components/co-input-date-range-picker/style/_layout.scss +18 -0
  25. package/lib/components/co-input-date-range-picker/style/_material-definition.scss +0 -0
  26. package/lib/components/co-input-date-range-picker/style/_theme.scss +0 -0
  27. package/lib/components/co-input-date-range-picker/style/material.scss +4 -0
  28. package/lib/components/filter-item/style/_material-definition.scss +1 -1
  29. package/lib/components/filter-item/style/_theme.scss +4 -1
  30. package/lib/components/input-checkbox/style/_layout.scss +1 -4
  31. package/lib/components/input-checkbox/style/_theme.scss +2 -1
  32. package/lib/components/list-of-values/list-of-values-popup.component.d.ts +22 -0
  33. package/lib/components/list-of-values/list-of-values.component.d.ts +35 -0
  34. package/lib/components/list-of-values/list-of-values.module.d.ts +2 -0
  35. package/lib/components/list-of-values/style/_layout.scss +101 -13
  36. package/lib/components/list-of-values/style/_material-definition.scss +15 -0
  37. package/lib/components/list-of-values-multiselect-search/list-of-values-multiselect-search.component.d.ts +21 -0
  38. package/lib/components/list-of-values-multiselect-search/list-of-values-multiselect-search.module.d.ts +2 -0
  39. package/lib/components/list-of-values-multiselect-search/style/_layout.scss +69 -0
  40. package/lib/components/list-of-values-multiselect-search/style/_material-definition.scss +8 -0
  41. package/lib/components/list-of-values-multiselect-search/style/_theme.scss +0 -0
  42. package/lib/components/list-of-values-multiselect-search/style/material.scss +4 -0
  43. package/lib/components/simple-grid/style/_layout.scss +4 -3
  44. package/lib/components/simple-grid/style/_material-definition.scss +3 -2
  45. package/lib/directives/overlay/overlay.directive.d.ts +1 -0
  46. package/lib/service/overlay.service.d.ts +1 -1
  47. package/lib/style/_variables.scss +9 -7
  48. package/package.json +1 -1
  49. package/public-api.d.ts +4 -0
@@ -6,25 +6,26 @@ export { BaseInputComponent as ɵm } from './lib/components/base/base-input.comp
6
6
  export { BaseModule as ɵj } from './lib/components/base/base.module';
7
7
  export { CommitButtonsComponent as ɵu } from './lib/components/base/commit-buttons/commit-buttons.component';
8
8
  export { CommitButtonsModule as ɵt } from './lib/components/base/commit-buttons/commit-buttons.module';
9
- export { CheckmarkOverlayComponent as ɵbm } from './lib/components/checkmark-overlay/checkmark-overlay.component';
9
+ export { CheckmarkOverlayComponent as ɵbn } from './lib/components/checkmark-overlay/checkmark-overlay.component';
10
10
  export { BaseGridComponent as ɵq } from './lib/components/grid/base/base-grid.component';
11
11
  export { BaseInlineEditGridComponent as ɵo } from './lib/components/grid/base/base-inline-edit-grid.component';
12
12
  export { BaseSelectionGridComponent as ɵn } from './lib/components/grid/base/base-selection-grid.component';
13
13
  export { BaseToolbarGridComponent as ɵp } from './lib/components/grid/base/base-toolbar-grid.component';
14
+ export { ListOfValuesPopupComponent as ɵbh } from './lib/components/list-of-values/list-of-values-popup.component';
14
15
  export { PaginatePipe as ɵbd } from './lib/components/pagination/paginate.pipe';
15
16
  export { PaginationService as ɵbc } from './lib/components/pagination/pagination.service';
16
17
  export { PopupShowerService as ɵz } from './lib/components/popup/service/popup-shower.service';
17
18
  export { BaseSimpleGridComponent as ɵba } from './lib/components/simple-grid/base-simple-grid.component';
18
19
  export { SimpleGridCellComponent as ɵbe } from './lib/components/simple-grid/simple-grid-cell.component';
19
- export { TooltipComponent as ɵbk } from './lib/components/tooltip/tooltip.component';
20
- export { TooltipModule as ɵbj } from './lib/components/tooltip/tooltip.module';
20
+ export { TooltipComponent as ɵbl } from './lib/components/tooltip/tooltip.component';
21
+ export { TooltipModule as ɵbk } from './lib/components/tooltip/tooltip.module';
21
22
  export { ValidationErrorComponent as ɵy } from './lib/components/validation-error/validation-error.component';
22
23
  export { ValidationErrorModule as ɵv } from './lib/components/validation-error/validation-error.module';
23
24
  export { InputBoolean as ɵi } from './lib/core/decorator/input-boolean.decorator';
24
25
  export { FormInputUserModelChangeListenerService as ɵk } from './lib/core/service/form-input-user-change-listener.service';
25
26
  export { NgZoneWrapperService as ɵl } from './lib/core/service/ng-zone-wrapper.service';
26
- export { ClickOutsideMasterService as ɵbi } from './lib/directives/clickoutside/click-outside-master.service';
27
- export { ClickOutsideDirective as ɵbh } from './lib/directives/clickoutside/click-outside.directive';
27
+ export { ClickOutsideMasterService as ɵbg } from './lib/directives/clickoutside/click-outside-master.service';
28
+ export { ClickOutsideDirective as ɵbf } from './lib/directives/clickoutside/click-outside.directive';
28
29
  export { ObserveVisibilityDirective as ɵbb } from './lib/directives/observe-visibility/observe-visibility.directive';
29
30
  export { OverlayParentDirective as ɵx } from './lib/directives/overlay/overlay-parent.directive';
30
31
  export { OverlayDirective as ɵw } from './lib/directives/overlay/overlay.directive';
@@ -33,13 +34,13 @@ export { RippleModule as ɵa } from './lib/directives/ripple/ripple.module';
33
34
  export { CoScrollDispatcherService as ɵe } from './lib/directives/ripple/scroll-dispatcher.service';
34
35
  export { CoScrollableDirective as ɵf } from './lib/directives/ripple/scrollable.directive';
35
36
  export { CoViewportRulerService as ɵd } from './lib/directives/ripple/viewport-ruler.service';
36
- export { ScreenConfigComponentWrapper as ɵbo } from './lib/directives/screen-configuration/screen-config-component-wrapper.component';
37
- export { ScreenConfigurationDirective as ɵbn } from './lib/directives/screen-configuration/screen-configuration.directive';
37
+ export { ScreenConfigComponentWrapper as ɵbp } from './lib/directives/screen-configuration/screen-config-component-wrapper.component';
38
+ export { ScreenConfigurationDirective as ɵbo } from './lib/directives/screen-configuration/screen-configuration.directive';
38
39
  export { StopClickDirective as ɵh } from './lib/directives/stopclick/stop-click.directive';
39
40
  export { StopClickModule as ɵg } from './lib/directives/stopclick/stop-click.module';
40
- export { TooltipDirective as ɵbl } from './lib/directives/tooltip/tooltip.directive';
41
+ export { TooltipDirective as ɵbm } from './lib/directives/tooltip/tooltip.directive';
41
42
  export { AppendPipe as ɵs } from './lib/pipes/append.pipe';
42
43
  export { AppendPipeModule as ɵr } from './lib/pipes/append.pipe.module';
43
- export { PrependPipe as ɵbg } from './lib/pipes/prepend.pipe';
44
- export { PrependPipeModule as ɵbf } from './lib/pipes/prepend.pipe.module';
45
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"colijnit-corecomponents_v12.js","sourceRoot":"","sources":["../../../projects/corecomponents/src/colijnit-corecomponents_v12.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n\nexport {BaseInputComponent as ɵm} from './lib/components/base/base-input.component';\nexport {BaseModule as ɵj} from './lib/components/base/base.module';\nexport {CommitButtonsComponent as ɵu} from './lib/components/base/commit-buttons/commit-buttons.component';\nexport {CommitButtonsModule as ɵt} from './lib/components/base/commit-buttons/commit-buttons.module';\nexport {CheckmarkOverlayComponent as ɵbm} from './lib/components/checkmark-overlay/checkmark-overlay.component';\nexport {BaseGridComponent as ɵq} from './lib/components/grid/base/base-grid.component';\nexport {BaseInlineEditGridComponent as ɵo} from './lib/components/grid/base/base-inline-edit-grid.component';\nexport {BaseSelectionGridComponent as ɵn} from './lib/components/grid/base/base-selection-grid.component';\nexport {BaseToolbarGridComponent as ɵp} from './lib/components/grid/base/base-toolbar-grid.component';\nexport {PaginatePipe as ɵbd} from './lib/components/pagination/paginate.pipe';\nexport {PaginationService as ɵbc} from './lib/components/pagination/pagination.service';\nexport {PopupShowerService as ɵz} from './lib/components/popup/service/popup-shower.service';\nexport {BaseSimpleGridComponent as ɵba} from './lib/components/simple-grid/base-simple-grid.component';\nexport {SimpleGridCellComponent as ɵbe} from './lib/components/simple-grid/simple-grid-cell.component';\nexport {TooltipComponent as ɵbk} from './lib/components/tooltip/tooltip.component';\nexport {TooltipModule as ɵbj} from './lib/components/tooltip/tooltip.module';\nexport {ValidationErrorComponent as ɵy} from './lib/components/validation-error/validation-error.component';\nexport {ValidationErrorModule as ɵv} from './lib/components/validation-error/validation-error.module';\nexport {InputBoolean as ɵi} from './lib/core/decorator/input-boolean.decorator';\nexport {FormInputUserModelChangeListenerService as ɵk} from './lib/core/service/form-input-user-change-listener.service';\nexport {NgZoneWrapperService as ɵl} from './lib/core/service/ng-zone-wrapper.service';\nexport {ClickOutsideMasterService as ɵbi} from './lib/directives/clickoutside/click-outside-master.service';\nexport {ClickOutsideDirective as ɵbh} from './lib/directives/clickoutside/click-outside.directive';\nexport {ObserveVisibilityDirective as ɵbb} from './lib/directives/observe-visibility/observe-visibility.directive';\nexport {OverlayParentDirective as ɵx} from './lib/directives/overlay/overlay-parent.directive';\nexport {OverlayDirective as ɵw} from './lib/directives/overlay/overlay.directive';\nexport {CoRippleDirective as ɵc,MD_RIPPLE_GLOBAL_OPTIONS as ɵb} from './lib/directives/ripple/ripple.directive';\nexport {RippleModule as ɵa} from './lib/directives/ripple/ripple.module';\nexport {CoScrollDispatcherService as ɵe} from './lib/directives/ripple/scroll-dispatcher.service';\nexport {CoScrollableDirective as ɵf} from './lib/directives/ripple/scrollable.directive';\nexport {CoViewportRulerService as ɵd} from './lib/directives/ripple/viewport-ruler.service';\nexport {ScreenConfigComponentWrapper as ɵbo} from './lib/directives/screen-configuration/screen-config-component-wrapper.component';\nexport {ScreenConfigurationDirective as ɵbn} from './lib/directives/screen-configuration/screen-configuration.directive';\nexport {StopClickDirective as ɵh} from './lib/directives/stopclick/stop-click.directive';\nexport {StopClickModule as ɵg} from './lib/directives/stopclick/stop-click.module';\nexport {TooltipDirective as ɵbl} from './lib/directives/tooltip/tooltip.directive';\nexport {AppendPipe as ɵs} from './lib/pipes/append.pipe';\nexport {AppendPipeModule as ɵr} from './lib/pipes/append.pipe.module';\nexport {PrependPipe as ɵbg} from './lib/pipes/prepend.pipe';\nexport {PrependPipeModule as ɵbf} from './lib/pipes/prepend.pipe.module';"]}
44
+ export { PrependPipe as ɵbj } from './lib/pipes/prepend.pipe';
45
+ export { PrependPipeModule as ɵbi } from './lib/pipes/prepend.pipe.module';
46
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"colijnit-corecomponents_v12.js","sourceRoot":"","sources":["../../../projects/corecomponents/src/colijnit-corecomponents_v12.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n\nexport {BaseInputComponent as ɵm} from './lib/components/base/base-input.component';\nexport {BaseModule as ɵj} from './lib/components/base/base.module';\nexport {CommitButtonsComponent as ɵu} from './lib/components/base/commit-buttons/commit-buttons.component';\nexport {CommitButtonsModule as ɵt} from './lib/components/base/commit-buttons/commit-buttons.module';\nexport {CheckmarkOverlayComponent as ɵbn} from './lib/components/checkmark-overlay/checkmark-overlay.component';\nexport {BaseGridComponent as ɵq} from './lib/components/grid/base/base-grid.component';\nexport {BaseInlineEditGridComponent as ɵo} from './lib/components/grid/base/base-inline-edit-grid.component';\nexport {BaseSelectionGridComponent as ɵn} from './lib/components/grid/base/base-selection-grid.component';\nexport {BaseToolbarGridComponent as ɵp} from './lib/components/grid/base/base-toolbar-grid.component';\nexport {ListOfValuesPopupComponent as ɵbh} from './lib/components/list-of-values/list-of-values-popup.component';\nexport {PaginatePipe as ɵbd} from './lib/components/pagination/paginate.pipe';\nexport {PaginationService as ɵbc} from './lib/components/pagination/pagination.service';\nexport {PopupShowerService as ɵz} from './lib/components/popup/service/popup-shower.service';\nexport {BaseSimpleGridComponent as ɵba} from './lib/components/simple-grid/base-simple-grid.component';\nexport {SimpleGridCellComponent as ɵbe} from './lib/components/simple-grid/simple-grid-cell.component';\nexport {TooltipComponent as ɵbl} from './lib/components/tooltip/tooltip.component';\nexport {TooltipModule as ɵbk} from './lib/components/tooltip/tooltip.module';\nexport {ValidationErrorComponent as ɵy} from './lib/components/validation-error/validation-error.component';\nexport {ValidationErrorModule as ɵv} from './lib/components/validation-error/validation-error.module';\nexport {InputBoolean as ɵi} from './lib/core/decorator/input-boolean.decorator';\nexport {FormInputUserModelChangeListenerService as ɵk} from './lib/core/service/form-input-user-change-listener.service';\nexport {NgZoneWrapperService as ɵl} from './lib/core/service/ng-zone-wrapper.service';\nexport {ClickOutsideMasterService as ɵbg} from './lib/directives/clickoutside/click-outside-master.service';\nexport {ClickOutsideDirective as ɵbf} from './lib/directives/clickoutside/click-outside.directive';\nexport {ObserveVisibilityDirective as ɵbb} from './lib/directives/observe-visibility/observe-visibility.directive';\nexport {OverlayParentDirective as ɵx} from './lib/directives/overlay/overlay-parent.directive';\nexport {OverlayDirective as ɵw} from './lib/directives/overlay/overlay.directive';\nexport {CoRippleDirective as ɵc,MD_RIPPLE_GLOBAL_OPTIONS as ɵb} from './lib/directives/ripple/ripple.directive';\nexport {RippleModule as ɵa} from './lib/directives/ripple/ripple.module';\nexport {CoScrollDispatcherService as ɵe} from './lib/directives/ripple/scroll-dispatcher.service';\nexport {CoScrollableDirective as ɵf} from './lib/directives/ripple/scrollable.directive';\nexport {CoViewportRulerService as ɵd} from './lib/directives/ripple/viewport-ruler.service';\nexport {ScreenConfigComponentWrapper as ɵbp} from './lib/directives/screen-configuration/screen-config-component-wrapper.component';\nexport {ScreenConfigurationDirective as ɵbo} from './lib/directives/screen-configuration/screen-configuration.directive';\nexport {StopClickDirective as ɵh} from './lib/directives/stopclick/stop-click.directive';\nexport {StopClickModule as ɵg} from './lib/directives/stopclick/stop-click.module';\nexport {TooltipDirective as ɵbm} from './lib/directives/tooltip/tooltip.directive';\nexport {AppendPipe as ɵs} from './lib/pipes/append.pipe';\nexport {AppendPipeModule as ɵr} from './lib/pipes/append.pipe.module';\nexport {PrependPipe as ɵbj} from './lib/pipes/prepend.pipe';\nexport {PrependPipeModule as ɵbi} from './lib/pipes/prepend.pipe.module';"]}
@@ -0,0 +1,79 @@
1
+ import { Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from '@angular/core';
2
+ import { BaseInputComponent } from "../base/base-input.component";
3
+ import { OverlayService } from "../../service/overlay.service";
4
+ export class ListOfValuesPopupComponent extends BaseInputComponent {
5
+ constructor() {
6
+ super(...arguments);
7
+ this.chosenOption = new EventEmitter();
8
+ this.closePopup = new EventEmitter();
9
+ this.displayField = 'description';
10
+ this.searchDisabled = false;
11
+ this.filteredOptions = this.collection;
12
+ this.searchTerm = '';
13
+ this._collection = [];
14
+ }
15
+ showClass() {
16
+ return true;
17
+ }
18
+ set collection(value) {
19
+ this._collection = value || [];
20
+ this.filterOptions();
21
+ }
22
+ get collection() {
23
+ return this._collection;
24
+ }
25
+ ngOnInit() {
26
+ super.ngOnInit();
27
+ if (this.model) {
28
+ this.selectedModel = this.model[this.displayField];
29
+ }
30
+ }
31
+ filterOptions() {
32
+ this.filteredOptions = this.collection.filter(option => option[this.displayField].toLowerCase().includes(this.searchTerm.toLowerCase()));
33
+ }
34
+ onOptionClick(option) {
35
+ this.model = option;
36
+ this.selectedModel = this.model[this.displayField];
37
+ this.modelChange.emit(this.model);
38
+ this.searchTerm = option.label;
39
+ this.searchTerm = "";
40
+ this.filterOptions();
41
+ this.chosenOption.emit(option);
42
+ }
43
+ optionClicked() {
44
+ this.overlayService.removeComponent();
45
+ this.closePopup.emit();
46
+ }
47
+ }
48
+ ListOfValuesPopupComponent.decorators = [
49
+ { type: Component, args: [{
50
+ selector: "co-list-of-values-popup",
51
+ template: `
52
+ <div class="lov-options" [overlay]="parentForOverlay" [inheritWidth]="true" [ngClass]="customCssClass" (clickOutside)="optionClicked()">
53
+ <co-input-text *ngIf="!searchDisabled" [(model)]="searchTerm" [placeholder]="searchPlaceholder" (modelChange)="filterOptions()"></co-input-text>
54
+ <ul>
55
+ <li *ngFor="let option of filteredOptions" [class.selected]="option === model" (click)="onOptionClick(option)">
56
+ <span [textContent]="option[displayField]"></span>
57
+ </li>
58
+ </ul>
59
+ </div>
60
+
61
+ `,
62
+ providers: [
63
+ OverlayService
64
+ ],
65
+ encapsulation: ViewEncapsulation.None
66
+ },] }
67
+ ];
68
+ ListOfValuesPopupComponent.propDecorators = {
69
+ showClass: [{ type: HostBinding, args: ["class.co-list-of-values-popup",] }],
70
+ chosenOption: [{ type: Output }],
71
+ closePopup: [{ type: Output }],
72
+ displayField: [{ type: Input }],
73
+ searchPlaceholder: [{ type: Input }],
74
+ customCssClass: [{ type: Input }],
75
+ searchDisabled: [{ type: Input }],
76
+ parentForOverlay: [{ type: Input }],
77
+ collection: [{ type: Input }]
78
+ };
79
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC1vZi12YWx1ZXMtcG9wdXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2xpc3Qtb2YtdmFsdWVzL2xpc3Qtb2YtdmFsdWVzLXBvcHVwLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUVULFlBQVksRUFDWixXQUFXLEVBQ1gsS0FBSyxFQUVMLE1BQU0sRUFDTixpQkFBaUIsRUFDbEIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDaEUsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBb0I3RCxNQUFNLE9BQU8sMEJBQTJCLFNBQVEsa0JBQXVCO0lBbEJ2RTs7UUEwQlMsaUJBQVksR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUcxRCxlQUFVLEdBQXNCLElBQUksWUFBWSxFQUFPLENBQUM7UUFHeEQsaUJBQVksR0FBVyxhQUFhLENBQUM7UUFTckMsbUJBQWMsR0FBWSxLQUFLLENBQUM7UUFlaEMsb0JBQWUsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDO1FBQ2xDLGVBQVUsR0FBRyxFQUFFLENBQUM7UUFHZixnQkFBVyxHQUFVLEVBQUUsQ0FBQztJQThCbEMsQ0FBQztJQXJFUSxTQUFTO1FBQ2QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBdUJELElBQ1csVUFBVSxDQUFDLEtBQVk7UUFDaEMsSUFBSSxDQUFDLFdBQVcsR0FBRyxLQUFLLElBQUksRUFBRSxDQUFDO1FBQy9CLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBRUQsSUFBVyxVQUFVO1FBQ25CLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUMxQixDQUFDO0lBUUQsUUFBUTtRQUNOLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqQixJQUFJLElBQUksQ0FBQyxLQUFLLEVBQUU7WUFDZCxJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO1NBQ3BEO0lBQ0gsQ0FBQztJQUVNLGFBQWE7UUFDbEIsSUFBSSxDQUFDLGVBQWUsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUNyRCxNQUFNLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQ2hGLENBQUM7SUFDSixDQUFDO0lBRU0sYUFBYSxDQUFDLE1BQVc7UUFDNUIsSUFBSSxDQUFDLEtBQUssR0FBRyxNQUFNLENBQUM7UUFDcEIsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUNuRCxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDbEMsSUFBSSxDQUFDLFVBQVUsR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDO1FBQy9CLElBQUksQ0FBQyxVQUFVLEdBQUcsRUFBRSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztRQUNyQixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBRU0sYUFBYTtRQUNsQixJQUFJLENBQUMsY0FBYyxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ3RDLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDekIsQ0FBQzs7O1lBeEZGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUseUJBQXlCO2dCQUNuQyxRQUFRLEVBQUU7Ozs7Ozs7Ozs7S0FVUDtnQkFDSCxTQUFTLEVBQUU7b0JBQ1QsY0FBYztpQkFDZjtnQkFDRCxhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTthQUN0Qzs7O3dCQUdFLFdBQVcsU0FBQywrQkFBK0I7MkJBSzNDLE1BQU07eUJBR04sTUFBTTsyQkFHTixLQUFLO2dDQUdMLEtBQUs7NkJBR0wsS0FBSzs2QkFHTCxLQUFLOytCQUdMLEtBQUs7eUJBR0wsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ29tcG9uZW50LFxyXG4gIEVsZW1lbnRSZWYsXHJcbiAgRXZlbnRFbWl0dGVyLFxyXG4gIEhvc3RCaW5kaW5nLFxyXG4gIElucHV0LFxyXG4gIE9uSW5pdCxcclxuICBPdXRwdXQsXHJcbiAgVmlld0VuY2Fwc3VsYXRpb25cclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHtCYXNlSW5wdXRDb21wb25lbnR9IGZyb20gXCIuLi9iYXNlL2Jhc2UtaW5wdXQuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7T3ZlcmxheVNlcnZpY2V9IGZyb20gXCIuLi8uLi9zZXJ2aWNlL292ZXJsYXkuc2VydmljZVwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IFwiY28tbGlzdC1vZi12YWx1ZXMtcG9wdXBcIixcclxuICB0ZW1wbGF0ZTogYFxyXG4gICAgICAgICAgPGRpdiBjbGFzcz1cImxvdi1vcHRpb25zXCIgW292ZXJsYXldPVwicGFyZW50Rm9yT3ZlcmxheVwiIFtpbmhlcml0V2lkdGhdPVwidHJ1ZVwiIFtuZ0NsYXNzXT1cImN1c3RvbUNzc0NsYXNzXCIgKGNsaWNrT3V0c2lkZSk9XCJvcHRpb25DbGlja2VkKClcIj5cclxuICAgICAgICAgICAgPGNvLWlucHV0LXRleHQgKm5nSWY9XCIhc2VhcmNoRGlzYWJsZWRcIiBbKG1vZGVsKV09XCJzZWFyY2hUZXJtXCIgW3BsYWNlaG9sZGVyXT1cInNlYXJjaFBsYWNlaG9sZGVyXCIgKG1vZGVsQ2hhbmdlKT1cImZpbHRlck9wdGlvbnMoKVwiPjwvY28taW5wdXQtdGV4dD5cclxuICAgICAgICAgICAgPHVsPlxyXG4gICAgICAgICAgICAgIDxsaSAqbmdGb3I9XCJsZXQgb3B0aW9uIG9mIGZpbHRlcmVkT3B0aW9uc1wiIFtjbGFzcy5zZWxlY3RlZF09XCJvcHRpb24gPT09IG1vZGVsXCIgKGNsaWNrKT1cIm9uT3B0aW9uQ2xpY2sob3B0aW9uKVwiPlxyXG4gICAgICAgICAgICAgICAgPHNwYW4gW3RleHRDb250ZW50XT1cIm9wdGlvbltkaXNwbGF5RmllbGRdXCI+PC9zcGFuPlxyXG4gICAgICAgICAgICAgIDwvbGk+XHJcbiAgICAgICAgICAgIDwvdWw+XHJcbiAgICAgICAgICA8L2Rpdj5cclxuXHJcbiAgICBgLFxyXG4gIHByb3ZpZGVyczogW1xyXG4gICAgT3ZlcmxheVNlcnZpY2VcclxuICBdLFxyXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBMaXN0T2ZWYWx1ZXNQb3B1cENvbXBvbmVudCBleHRlbmRzIEJhc2VJbnB1dENvbXBvbmVudDxhbnk+IGltcGxlbWVudHMgT25Jbml0IHtcclxuXHJcbiAgQEhvc3RCaW5kaW5nKFwiY2xhc3MuY28tbGlzdC1vZi12YWx1ZXMtcG9wdXBcIilcclxuICBwdWJsaWMgc2hvd0NsYXNzKCkge1xyXG4gICAgcmV0dXJuIHRydWU7XHJcbiAgfVxyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgY2hvc2VuT3B0aW9uOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgY2xvc2VQb3B1cDogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgZGlzcGxheUZpZWxkOiBzdHJpbmcgPSAnZGVzY3JpcHRpb24nO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBzZWFyY2hQbGFjZWhvbGRlcjogc3RyaW5nO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBjdXN0b21Dc3NDbGFzczogc3RyaW5nO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBzZWFyY2hEaXNhYmxlZDogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBwYXJlbnRGb3JPdmVybGF5OiBFbGVtZW50UmVmO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBzZXQgY29sbGVjdGlvbih2YWx1ZTogYW55W10pIHtcclxuICAgIHRoaXMuX2NvbGxlY3Rpb24gPSB2YWx1ZSB8fCBbXTtcclxuICAgIHRoaXMuZmlsdGVyT3B0aW9ucygpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldCBjb2xsZWN0aW9uKCk6IGFueVtdIHtcclxuICAgIHJldHVybiB0aGlzLl9jb2xsZWN0aW9uO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGZpbHRlcmVkT3B0aW9ucyA9IHRoaXMuY29sbGVjdGlvbjtcclxuICBwdWJsaWMgc2VhcmNoVGVybSA9ICcnO1xyXG4gIHB1YmxpYyBzZWxlY3RlZE1vZGVsOiBzdHJpbmc7XHJcblxyXG4gIHByaXZhdGUgX2NvbGxlY3Rpb246IGFueVtdID0gW107XHJcblxyXG4gIG5nT25Jbml0KCkge1xyXG4gICAgc3VwZXIubmdPbkluaXQoKTtcclxuICAgIGlmICh0aGlzLm1vZGVsKSB7XHJcbiAgICAgIHRoaXMuc2VsZWN0ZWRNb2RlbCA9IHRoaXMubW9kZWxbdGhpcy5kaXNwbGF5RmllbGRdO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgcHVibGljIGZpbHRlck9wdGlvbnMoKTogdm9pZCB7XHJcbiAgICB0aGlzLmZpbHRlcmVkT3B0aW9ucyA9IHRoaXMuY29sbGVjdGlvbi5maWx0ZXIob3B0aW9uID0+XHJcbiAgICAgIG9wdGlvblt0aGlzLmRpc3BsYXlGaWVsZF0udG9Mb3dlckNhc2UoKS5pbmNsdWRlcyh0aGlzLnNlYXJjaFRlcm0udG9Mb3dlckNhc2UoKSlcclxuICAgICk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25PcHRpb25DbGljayhvcHRpb246IGFueSk6IHZvaWQge1xyXG4gICAgICB0aGlzLm1vZGVsID0gb3B0aW9uO1xyXG4gICAgICB0aGlzLnNlbGVjdGVkTW9kZWwgPSB0aGlzLm1vZGVsW3RoaXMuZGlzcGxheUZpZWxkXTtcclxuICAgICAgdGhpcy5tb2RlbENoYW5nZS5lbWl0KHRoaXMubW9kZWwpO1xyXG4gICAgICB0aGlzLnNlYXJjaFRlcm0gPSBvcHRpb24ubGFiZWw7XHJcbiAgICAgIHRoaXMuc2VhcmNoVGVybSA9IFwiXCI7XHJcbiAgICAgIHRoaXMuZmlsdGVyT3B0aW9ucygpO1xyXG4gICAgICB0aGlzLmNob3Nlbk9wdGlvbi5lbWl0KG9wdGlvbik7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb3B0aW9uQ2xpY2tlZCgpOiB2b2lkIHtcclxuICAgIHRoaXMub3ZlcmxheVNlcnZpY2UucmVtb3ZlQ29tcG9uZW50KCk7XHJcbiAgICB0aGlzLmNsb3NlUG9wdXAuZW1pdCgpO1xyXG4gIH1cclxuXHJcbn1cclxuIl19
@@ -0,0 +1,174 @@
1
+ import { Component, ElementRef, HostBinding, Input, ViewChild, ViewEncapsulation } from '@angular/core';
2
+ import { animate, state, style, transition, trigger } from "@angular/animations";
3
+ import { BaseInputComponent } from "../base/base-input.component";
4
+ import { CoreComponentsIcon } from "../../core/enum/core-components-icon.enum";
5
+ import { OverlayService } from "../../service/overlay.service";
6
+ import { ListOfValuesPopupComponent } from "./list-of-values-popup.component";
7
+ export class ListOfValuesComponent extends BaseInputComponent {
8
+ constructor() {
9
+ super(...arguments);
10
+ this.icons = CoreComponentsIcon;
11
+ this.multiselect = false;
12
+ this.displayField = 'description';
13
+ this.searchDisabled = false;
14
+ this.selectedOptions = [];
15
+ this.filteredOptions = this.collection;
16
+ this.searchTerm = '';
17
+ this.isSelectOpen = false;
18
+ this.state = 'default';
19
+ this.searchClicked = false;
20
+ this.multiselectTags = [];
21
+ this._collection = [];
22
+ }
23
+ showClass() {
24
+ return true;
25
+ }
26
+ set collection(value) {
27
+ this._collection = value || [];
28
+ this.filterOptions();
29
+ }
30
+ get collection() {
31
+ return this._collection;
32
+ }
33
+ ngOnInit() {
34
+ super.ngOnInit();
35
+ if (this.model) {
36
+ this.selectedModel = this.model[this.displayField];
37
+ }
38
+ }
39
+ filterOptions() {
40
+ if (!this.multiselect) {
41
+ this.filteredOptions = this.collection.filter(option => option[this.displayField].toLowerCase().includes(this.searchTerm.toLowerCase()));
42
+ }
43
+ else {
44
+ this.selectedOptions = this.selectedOptions.filter((option) => {
45
+ if (this.collection) {
46
+ return this.searchTerm.includes(option.label);
47
+ }
48
+ else {
49
+ return this.searchTerm.includes(option.value);
50
+ }
51
+ });
52
+ }
53
+ }
54
+ onOptionClick(option) {
55
+ if (!this.multiselect) {
56
+ this.model = option;
57
+ this.selectedModel = this.model[this.displayField];
58
+ this.modelChange.emit(this.model);
59
+ this.searchTerm = option.label;
60
+ this.isSelectOpen = false;
61
+ this.searchTerm = "";
62
+ this.filterOptions();
63
+ }
64
+ if (this.multiselect) {
65
+ if (this.selectedOptions.includes(option)) {
66
+ this.selectedOptions.splice(this.selectedOptions.indexOf(option), 1);
67
+ }
68
+ else {
69
+ this.selectedOptions.push(option);
70
+ }
71
+ this.modelChange.emit(this.selectedOptions);
72
+ }
73
+ }
74
+ toggleSelect() {
75
+ this.isSelectOpen = !this.isSelectOpen;
76
+ if (this.isSelectOpen) {
77
+ this.overlayService.createComponent(ListOfValuesPopupComponent, {
78
+ parentForOverlay: this.parentForOverlay,
79
+ customCssClass: this.customCssClass,
80
+ searchDisabled: this.searchDisabled,
81
+ searchPlaceholder: this.searchPlaceholder,
82
+ displayField: this.displayField,
83
+ collection: this.collection
84
+ }, {
85
+ chosenOption: (value) => this.optionChosen(value),
86
+ closePopup: () => this.closePopup()
87
+ });
88
+ }
89
+ else {
90
+ this.overlayService.removeComponent();
91
+ }
92
+ this.state = (this.state === 'default' ? 'rotated' : 'default');
93
+ }
94
+ multiselectOkClick() {
95
+ this.searchClicked = false;
96
+ }
97
+ createMultiSelectTags(tags) {
98
+ this.multiselectTags = tags;
99
+ }
100
+ openMultiselectSearch() {
101
+ this.searchClicked = true;
102
+ }
103
+ optionChosen(option) {
104
+ this.selectedModel = option[this.displayField];
105
+ }
106
+ closePopup() {
107
+ this.overlayService.removeComponent();
108
+ }
109
+ }
110
+ ListOfValuesComponent.decorators = [
111
+ { type: Component, args: [{
112
+ selector: "co-list-of-values",
113
+ template: `
114
+ <div class="lov-container">
115
+ <div class="lov-container-child" *ngIf="!multiselect">
116
+ <div class="search-wrapper" overlayParent #parentForOverlay="overlayParent">
117
+ <co-input-text class="lov-search no-focus-line"
118
+ type="text"
119
+ [model]="selectedModel"
120
+ [placeholder]="label"
121
+ [readonly]="readonly"
122
+ [disabled]="disabled"
123
+ [required]="required"
124
+ [rightIcon]="icons.ArrowPointDown"
125
+ (click)="toggleSelect()"
126
+ (rightIconClick)="toggleSelect()"
127
+ ></co-input-text>
128
+ </div>
129
+
130
+
131
+
132
+ </div>
133
+ <div *ngIf="multiselect">
134
+ <div class="search-wrapper-multiselect" (click)="openMultiselectSearch()" *ngIf="!searchClicked">
135
+ <div class="tag-wrapper">
136
+ <ul class="tag-ul-wrapper">
137
+ <li class="tag" *ngFor="let tags of multiselectTags">
138
+ <span [textContent]="tags.label"></span>
139
+ </li>
140
+ </ul>
141
+ </div>
142
+ </div>
143
+ <div *ngIf="searchClicked">
144
+ <co-list-of-values-multiselect-search [collection]="filteredOptions" [returnChosenCollection]="multiselectTags" (okButtonClicked)="multiselectOkClick()" (chosenCollection)="createMultiSelectTags($event)"></co-list-of-values-multiselect-search>
145
+ </div>
146
+ </div>
147
+ </div>
148
+ `,
149
+ providers: [
150
+ OverlayService
151
+ ],
152
+ animations: [
153
+ trigger('rotatedState', [
154
+ state('default', style({ transform: 'rotate(0)' })),
155
+ state('rotated', style({ transform: 'rotate(-180deg)' })),
156
+ transition('rotated => default', animate('300ms ease-out')),
157
+ transition('default => rotated', animate('300ms ease-out'))
158
+ ])
159
+ ],
160
+ encapsulation: ViewEncapsulation.None
161
+ },] }
162
+ ];
163
+ ListOfValuesComponent.propDecorators = {
164
+ parentForOverlay: [{ type: ViewChild, args: ["parentForOverlay", { read: ElementRef },] }],
165
+ multiselect: [{ type: Input }],
166
+ showClass: [{ type: HostBinding, args: ["class.co-list-of-values",] }],
167
+ displayField: [{ type: Input }],
168
+ collection: [{ type: Input }],
169
+ searchPlaceholder: [{ type: Input }],
170
+ label: [{ type: Input }],
171
+ customCssClass: [{ type: Input }],
172
+ searchDisabled: [{ type: Input }]
173
+ };
174
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-of-values.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/list-of-values/list-of-values.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  HostBinding,\r\n  Input,\r\n  OnInit,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {animate, state, style, transition, trigger} from \"@angular/animations\";\r\nimport {BaseInputComponent} from \"../base/base-input.component\";\r\nimport {CoreComponentsIcon} from \"../../core/enum/core-components-icon.enum\";\r\nimport {OverlayService} from \"../../service/overlay.service\";\r\nimport {ListOfValuesPopupComponent} from \"./list-of-values-popup.component\";\r\n\r\n@Component({\r\n  selector: \"co-list-of-values\",\r\n  template: `\r\n      <div class=\"lov-container\">\r\n        <div class=\"lov-container-child\" *ngIf=\"!multiselect\">\r\n          <div class=\"search-wrapper\" overlayParent #parentForOverlay=\"overlayParent\">\r\n            <co-input-text class=\"lov-search no-focus-line\"\r\n                           type=\"text\"\r\n                           [model]=\"selectedModel\"\r\n                           [placeholder]=\"label\"\r\n                           [readonly]=\"readonly\"\r\n                           [disabled]=\"disabled\"\r\n                           [required]=\"required\"\r\n                           [rightIcon]=\"icons.ArrowPointDown\"\r\n                           (click)=\"toggleSelect()\"\r\n                           (rightIconClick)=\"toggleSelect()\"\r\n            ></co-input-text>\r\n          </div>\r\n\r\n\r\n\r\n        </div>\r\n        <div *ngIf=\"multiselect\">\r\n          <div class=\"search-wrapper-multiselect\" (click)=\"openMultiselectSearch()\" *ngIf=\"!searchClicked\">\r\n            <div class=\"tag-wrapper\">\r\n              <ul class=\"tag-ul-wrapper\">\r\n                <li class=\"tag\" *ngFor=\"let tags of multiselectTags\">\r\n                  <span [textContent]=\"tags.label\"></span>\r\n                </li>\r\n              </ul>\r\n            </div>\r\n          </div>\r\n          <div *ngIf=\"searchClicked\">\r\n            <co-list-of-values-multiselect-search [collection]=\"filteredOptions\" [returnChosenCollection]=\"multiselectTags\" (okButtonClicked)=\"multiselectOkClick()\" (chosenCollection)=\"createMultiSelectTags($event)\"></co-list-of-values-multiselect-search>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    `,\r\n  providers: [\r\n    OverlayService\r\n  ],\r\n  animations: [\r\n    trigger('rotatedState', [\r\n      state('default', style({ transform: 'rotate(0)' })),\r\n      state('rotated', style({ transform: 'rotate(-180deg)' })),\r\n      transition('rotated => default', animate('300ms ease-out')),\r\n      transition('default => rotated', animate('300ms ease-out'))\r\n    ])\r\n  ],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class ListOfValuesComponent extends BaseInputComponent<any> implements OnInit {\r\n  public readonly icons: typeof CoreComponentsIcon = CoreComponentsIcon;\r\n\r\n  @ViewChild(\"parentForOverlay\", {read: ElementRef})\r\n  public parentForOverlay: ElementRef;\r\n\r\n  @Input()\r\n  public multiselect: boolean = false;\r\n\r\n  @HostBinding(\"class.co-list-of-values\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  @Input()\r\n  public displayField: string = 'description';\r\n\r\n  @Input()\r\n  public set collection(value: any[]) {\r\n    this._collection = value || [];\r\n    this.filterOptions();\r\n  }\r\n\r\n  public get collection(): any[] {\r\n    return this._collection;\r\n  }\r\n\r\n  @Input()\r\n  public searchPlaceholder: string;\r\n\r\n  @Input()\r\n  public label: string;\r\n\r\n  @Input()\r\n  public customCssClass: string;\r\n\r\n  @Input()\r\n  public searchDisabled: boolean = false;\r\n\r\n  public selectedOptions: any[] = [];\r\n\r\n  public filteredOptions = this.collection;\r\n  public searchTerm = '';\r\n  public isSelectOpen: boolean = false;\r\n  public state: string = 'default';\r\n  public searchClicked: boolean = false;\r\n  public multiselectTags: any[] = [];\r\n  public selectedModel: string;\r\n\r\n  public chosenOption: any;\r\n\r\n  private _collection: any[] = [];\r\n\r\n  ngOnInit() {\r\n    super.ngOnInit();\r\n    if (this.model) {\r\n      this.selectedModel = this.model[this.displayField];\r\n    }\r\n  }\r\n\r\n  public filterOptions(): void {\r\n    if (!this.multiselect) {\r\n      this.filteredOptions = this.collection.filter(option =>\r\n        option[this.displayField].toLowerCase().includes(this.searchTerm.toLowerCase())\r\n      );\r\n    } else {\r\n      this.selectedOptions = this.selectedOptions.filter((option) => {\r\n        if (this.collection) {\r\n          return this.searchTerm.includes(option.label);\r\n        } else {\r\n          return this.searchTerm.includes(option.value);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  public onOptionClick(option: any): void {\r\n    if (!this.multiselect) {\r\n      this.model = option;\r\n      this.selectedModel = this.model[this.displayField];\r\n      this.modelChange.emit(this.model);\r\n      this.searchTerm = option.label;\r\n      this.isSelectOpen = false;\r\n      this.searchTerm = \"\";\r\n      this.filterOptions();\r\n    }\r\n\r\n    if (this.multiselect) {\r\n      if (this.selectedOptions.includes(option)) {\r\n        this.selectedOptions.splice(this.selectedOptions.indexOf(option), 1);\r\n      } else {\r\n        this.selectedOptions.push(option);\r\n      }\r\n      this.modelChange.emit(this.selectedOptions);\r\n    }\r\n  }\r\n\r\n  public toggleSelect(): void {\r\n    this.isSelectOpen = !this.isSelectOpen;\r\n    if (this.isSelectOpen) {\r\n      this.overlayService.createComponent(ListOfValuesPopupComponent, {\r\n        parentForOverlay: this.parentForOverlay,\r\n        customCssClass: this.customCssClass,\r\n        searchDisabled: this.searchDisabled,\r\n        searchPlaceholder: this.searchPlaceholder,\r\n        displayField: this.displayField,\r\n        collection: this.collection\r\n      }, {\r\n        chosenOption: (value) => this.optionChosen(value),\r\n        closePopup: () => this.closePopup()\r\n      });\r\n    } else {\r\n      this.overlayService.removeComponent();\r\n    }\r\n    this.state = (this.state === 'default' ? 'rotated' : 'default');\r\n  }\r\n\r\n  public multiselectOkClick(): void {\r\n    this.searchClicked = false;\r\n  }\r\n\r\n  public createMultiSelectTags(tags: any): void {\r\n    this.multiselectTags = tags;\r\n  }\r\n\r\n  public openMultiselectSearch(): void {\r\n    this.searchClicked = true;\r\n  }\r\n\r\n  public optionChosen(option: any): void {\r\n    this.selectedModel = option[this.displayField];\r\n\r\n  }\r\n\r\n  public closePopup(): void {\r\n    this.overlayService.removeComponent();\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,33 @@
1
+ import { NgModule } from "@angular/core";
2
+ import { CommonModule } from "@angular/common";
3
+ import { ListOfValuesComponent } from "./list-of-values.component";
4
+ import { FormsModule } from "@angular/forms";
5
+ import { InputTextModule } from "../input-text/input-text.module";
6
+ import { InputCheckboxModule } from "../input-checkbox/input-checkbox.module";
7
+ import { OverlayModule } from "../../directives/overlay/overlay.module";
8
+ import { ClickoutsideModule } from "../../directives/clickoutside/clickoutside.module";
9
+ import { ListOfValuesMultiselectSearchModule } from "../list-of-values-multiselect-search/list-of-values-multiselect-search.module";
10
+ import { ListOfValuesPopupComponent } from "./list-of-values-popup.component";
11
+ export class ListOfValuesModule {
12
+ }
13
+ ListOfValuesModule.decorators = [
14
+ { type: NgModule, args: [{
15
+ imports: [
16
+ CommonModule,
17
+ FormsModule,
18
+ InputTextModule,
19
+ InputCheckboxModule,
20
+ OverlayModule,
21
+ ClickoutsideModule,
22
+ ListOfValuesMultiselectSearchModule
23
+ ],
24
+ declarations: [
25
+ ListOfValuesComponent,
26
+ ListOfValuesPopupComponent
27
+ ],
28
+ exports: [
29
+ ListOfValuesComponent
30
+ ]
31
+ },] }
32
+ ];
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC1vZi12YWx1ZXMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2xpc3Qtb2YtdmFsdWVzL2xpc3Qtb2YtdmFsdWVzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUNqRSxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDM0MsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLGlDQUFpQyxDQUFDO0FBQ2hFLE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLHlDQUF5QyxDQUFDO0FBQzVFLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUN0RSxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSxtREFBbUQsQ0FBQztBQUNyRixPQUFPLEVBQ0wsbUNBQW1DLEVBQ3BDLE1BQU0sK0VBQStFLENBQUM7QUFDdkYsT0FBTyxFQUFDLDBCQUEwQixFQUFDLE1BQU0sa0NBQWtDLENBQUM7QUFvQjVFLE1BQU0sT0FBTyxrQkFBa0I7OztZQWxCOUIsUUFBUSxTQUFDO2dCQUNSLE9BQU8sRUFBRTtvQkFDUCxZQUFZO29CQUNaLFdBQVc7b0JBQ1gsZUFBZTtvQkFDZixtQkFBbUI7b0JBQ25CLGFBQWE7b0JBQ2Isa0JBQWtCO29CQUNsQixtQ0FBbUM7aUJBQ3BDO2dCQUNELFlBQVksRUFBRTtvQkFDWixxQkFBcUI7b0JBQ3JCLDBCQUEwQjtpQkFDM0I7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLHFCQUFxQjtpQkFDdEI7YUFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XHJcbmltcG9ydCB7TGlzdE9mVmFsdWVzQ29tcG9uZW50fSBmcm9tIFwiLi9saXN0LW9mLXZhbHVlcy5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtGb3Jtc01vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XHJcbmltcG9ydCB7SW5wdXRUZXh0TW9kdWxlfSBmcm9tIFwiLi4vaW5wdXQtdGV4dC9pbnB1dC10ZXh0Lm1vZHVsZVwiO1xyXG5pbXBvcnQge0lucHV0Q2hlY2tib3hNb2R1bGV9IGZyb20gXCIuLi9pbnB1dC1jaGVja2JveC9pbnB1dC1jaGVja2JveC5tb2R1bGVcIjtcclxuaW1wb3J0IHtPdmVybGF5TW9kdWxlfSBmcm9tIFwiLi4vLi4vZGlyZWN0aXZlcy9vdmVybGF5L292ZXJsYXkubW9kdWxlXCI7XHJcbmltcG9ydCB7Q2xpY2tvdXRzaWRlTW9kdWxlfSBmcm9tIFwiLi4vLi4vZGlyZWN0aXZlcy9jbGlja291dHNpZGUvY2xpY2tvdXRzaWRlLm1vZHVsZVwiO1xyXG5pbXBvcnQge1xyXG4gIExpc3RPZlZhbHVlc011bHRpc2VsZWN0U2VhcmNoTW9kdWxlXHJcbn0gZnJvbSBcIi4uL2xpc3Qtb2YtdmFsdWVzLW11bHRpc2VsZWN0LXNlYXJjaC9saXN0LW9mLXZhbHVlcy1tdWx0aXNlbGVjdC1zZWFyY2gubW9kdWxlXCI7XHJcbmltcG9ydCB7TGlzdE9mVmFsdWVzUG9wdXBDb21wb25lbnR9IGZyb20gXCIuL2xpc3Qtb2YtdmFsdWVzLXBvcHVwLmNvbXBvbmVudFwiO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBGb3Jtc01vZHVsZSxcclxuICAgIElucHV0VGV4dE1vZHVsZSxcclxuICAgIElucHV0Q2hlY2tib3hNb2R1bGUsXHJcbiAgICBPdmVybGF5TW9kdWxlLFxyXG4gICAgQ2xpY2tvdXRzaWRlTW9kdWxlLFxyXG4gICAgTGlzdE9mVmFsdWVzTXVsdGlzZWxlY3RTZWFyY2hNb2R1bGVcclxuICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgTGlzdE9mVmFsdWVzQ29tcG9uZW50LFxyXG4gICAgTGlzdE9mVmFsdWVzUG9wdXBDb21wb25lbnRcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIExpc3RPZlZhbHVlc0NvbXBvbmVudFxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIExpc3RPZlZhbHVlc01vZHVsZSB7fVxyXG4iXX0=
@@ -0,0 +1,101 @@
1
+ import { Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from '@angular/core';
2
+ import { BaseInputComponent } from "../base/base-input.component";
3
+ import { CoreComponentsIcon } from "../../core/enum/core-components-icon.enum";
4
+ export class ListOfValuesMultiselectSearch extends BaseInputComponent {
5
+ constructor() {
6
+ super(...arguments);
7
+ this.icons = CoreComponentsIcon;
8
+ this.chosenCollection = new EventEmitter();
9
+ this.okButtonClicked = new EventEmitter();
10
+ this.selectedCollection = [];
11
+ this.selectedOptions = [];
12
+ this.allOptionsSelected = false;
13
+ this.searchTerm = '';
14
+ }
15
+ showClass() {
16
+ return true;
17
+ }
18
+ get filteredCollection() {
19
+ if (this.searchTerm.trim() === '') {
20
+ return this.collection;
21
+ }
22
+ return this.collection.filter((option) => option.label.toLowerCase().includes(this.searchTerm.toLowerCase()));
23
+ }
24
+ ngOnInit() {
25
+ if (this.returnChosenCollection) {
26
+ this.selectedCollection = this.returnChosenCollection;
27
+ }
28
+ }
29
+ onOptionClick(option) {
30
+ const index = this.selectedCollection.findIndex((selectedOption) => selectedOption.value === option.value);
31
+ if (index !== -1) {
32
+ this.selectedCollection.splice(index, 1);
33
+ }
34
+ else {
35
+ this.selectedCollection.push(option);
36
+ }
37
+ }
38
+ okClicked() {
39
+ this.chosenCollection.emit(this.selectedCollection);
40
+ this.okButtonClicked.emit();
41
+ }
42
+ onToggleSelectAll() {
43
+ if (this.allOptionsSelected) {
44
+ this.selectedCollection = [];
45
+ this.allOptionsSelected = false;
46
+ }
47
+ else {
48
+ this.selectedCollection = [...this.collection];
49
+ this.allOptionsSelected = true;
50
+ }
51
+ }
52
+ searchCollection() {
53
+ this.selectedOptions = this.selectedOptions.filter((option) => {
54
+ if (this.collection) {
55
+ return this.searchTerm.includes(option.label);
56
+ }
57
+ else {
58
+ return this.searchTerm.includes(option.value);
59
+ }
60
+ });
61
+ }
62
+ }
63
+ ListOfValuesMultiselectSearch.decorators = [
64
+ { type: Component, args: [{
65
+ selector: "co-list-of-values-multiselect-search",
66
+ template: `
67
+ <div class="co-list-of-values-multiselect-search">
68
+ <div class="list-of-values-multiselect-search-input-text">
69
+ <co-input-text [placeholder]="'Zoeken...'" [(model)]="searchTerm" (input)="searchCollection()"></co-input-text>
70
+ </div>
71
+ <div class="list-of-values-multiselect-options">
72
+ <div class="list-of-values-multiselect-search-deselect" (click)="onToggleSelectAll()">
73
+ <span [textContent]="'(De)selecteer alles'"></span>
74
+ <co-icon [icon]="icons.CheckRound"></co-icon>
75
+ </div>
76
+ <div class="list-of-values-multiselect-list">
77
+ <ul>
78
+ <li *ngFor="let option of filteredCollection" (click)="onOptionClick(option)">
79
+ <co-input-checkbox class="lov-options-checkbox" (modelChange)="onOptionClick(option)" [model]="selectedCollection.includes(option)"></co-input-checkbox>
80
+ <span>{{ option.label }}</span>
81
+ </li>
82
+ </ul>
83
+ </div>
84
+ <div class="list-of-values-multiselect-ok-button" (click)="okClicked()">
85
+ <span [textContent]="'Ok'"></span>
86
+ <co-icon [icon]="icons.Check"></co-icon>
87
+ </div>
88
+ </div>
89
+ </div>
90
+ `,
91
+ encapsulation: ViewEncapsulation.None
92
+ },] }
93
+ ];
94
+ ListOfValuesMultiselectSearch.propDecorators = {
95
+ showClass: [{ type: HostBinding, args: ["class.co-list-of-values-multiselect-search",] }],
96
+ collection: [{ type: Input }],
97
+ returnChosenCollection: [{ type: Input }],
98
+ chosenCollection: [{ type: Output }],
99
+ okButtonClicked: [{ type: Output }]
100
+ };
101
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-of-values-multiselect-search.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/list-of-values-multiselect-search/list-of-values-multiselect-search.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation} from '@angular/core';\r\nimport {BaseInputComponent} from \"../base/base-input.component\";\r\nimport {CoreComponentsIcon} from \"../../core/enum/core-components-icon.enum\";\r\n\r\n@Component({\r\n  selector: \"co-list-of-values-multiselect-search\",\r\n  template: `\r\n        <div class=\"co-list-of-values-multiselect-search\">\r\n          <div class=\"list-of-values-multiselect-search-input-text\">\r\n            <co-input-text [placeholder]=\"'Zoeken...'\" [(model)]=\"searchTerm\" (input)=\"searchCollection()\"></co-input-text>\r\n          </div>\r\n          <div class=\"list-of-values-multiselect-options\">\r\n            <div class=\"list-of-values-multiselect-search-deselect\" (click)=\"onToggleSelectAll()\">\r\n              <span [textContent]=\"'(De)selecteer alles'\"></span>\r\n              <co-icon [icon]=\"icons.CheckRound\"></co-icon>\r\n            </div>\r\n            <div class=\"list-of-values-multiselect-list\">\r\n              <ul>\r\n                <li *ngFor=\"let option of filteredCollection\" (click)=\"onOptionClick(option)\">\r\n                  <co-input-checkbox class=\"lov-options-checkbox\" (modelChange)=\"onOptionClick(option)\" [model]=\"selectedCollection.includes(option)\"></co-input-checkbox>\r\n                  <span>{{ option.label }}</span>\r\n                </li>\r\n              </ul>\r\n            </div>\r\n            <div class=\"list-of-values-multiselect-ok-button\" (click)=\"okClicked()\">\r\n              <span [textContent]=\"'Ok'\"></span>\r\n              <co-icon [icon]=\"icons.Check\"></co-icon>\r\n            </div>\r\n          </div>\r\n        </div>\r\n    `,\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class ListOfValuesMultiselectSearch extends BaseInputComponent<any> implements OnInit {\r\n  public readonly icons: typeof CoreComponentsIcon = CoreComponentsIcon;\r\n\r\n  @HostBinding(\"class.co-list-of-values-multiselect-search\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  @Input()\r\n  public collection: any;\r\n\r\n  @Input()\r\n  public returnChosenCollection: any[];\r\n\r\n  @Output()\r\n  public chosenCollection: EventEmitter<any[]> = new EventEmitter<any[]>();\r\n\r\n  @Output()\r\n  public okButtonClicked: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n\r\n  public selectedCollection: any[] = [];\r\n  public selectedOptions: any[] = [];\r\n  public allOptionsSelected: boolean = false;\r\n  public searchTerm = '';\r\n\r\n  public get filteredCollection(): any {\r\n    if (this.searchTerm.trim() === '') {\r\n      return this.collection;\r\n    }\r\n    return this.collection.filter((option: any) =>\r\n      option.label.toLowerCase().includes(this.searchTerm.toLowerCase())\r\n    );\r\n  }\r\n\r\n  ngOnInit() {\r\n    if(this.returnChosenCollection) {\r\n      this.selectedCollection = this.returnChosenCollection;\r\n    }\r\n  }\r\n\r\n  public onOptionClick(option: any): void {\r\n    const index = this.selectedCollection.findIndex((selectedOption) => selectedOption.value === option.value);\r\n    if (index !== -1) {\r\n      this.selectedCollection.splice(index, 1);\r\n    } else {\r\n      this.selectedCollection.push(option);\r\n    }\r\n  }\r\n\r\n  public okClicked(): void {\r\n    this.chosenCollection.emit(this.selectedCollection);\r\n    this.okButtonClicked.emit();\r\n  }\r\n\r\n  public onToggleSelectAll(): void {\r\n    if (this.allOptionsSelected) {\r\n      this.selectedCollection = [];\r\n      this.allOptionsSelected = false;\r\n    } else {\r\n      this.selectedCollection = [...this.collection];\r\n      this.allOptionsSelected = true;\r\n    }\r\n  }\r\n\r\n  public searchCollection(): void {\r\n    this.selectedOptions = this.selectedOptions.filter((option) => {\r\n      if (this.collection) {\r\n        return this.searchTerm.includes(option.label);\r\n      } else {\r\n        return this.searchTerm.includes(option.value);\r\n      }\r\n    });\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,25 @@
1
+ import { NgModule } from "@angular/core";
2
+ import { CommonModule } from "@angular/common";
3
+ import { ListOfValuesMultiselectSearch } from "./list-of-values-multiselect-search.component";
4
+ import { InputTextModule } from "../input-text/input-text.module";
5
+ import { IconModule } from "../icon/icon.module";
6
+ import { InputCheckboxModule } from "../input-checkbox/input-checkbox.module";
7
+ export class ListOfValuesMultiselectSearchModule {
8
+ }
9
+ ListOfValuesMultiselectSearchModule.decorators = [
10
+ { type: NgModule, args: [{
11
+ imports: [
12
+ CommonModule,
13
+ InputTextModule,
14
+ IconModule,
15
+ InputCheckboxModule,
16
+ ],
17
+ declarations: [
18
+ ListOfValuesMultiselectSearch
19
+ ],
20
+ exports: [
21
+ ListOfValuesMultiselectSearch
22
+ ]
23
+ },] }
24
+ ];
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC1vZi12YWx1ZXMtbXVsdGlzZWxlY3Qtc2VhcmNoLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmVjb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9saXN0LW9mLXZhbHVlcy1tdWx0aXNlbGVjdC1zZWFyY2gvbGlzdC1vZi12YWx1ZXMtbXVsdGlzZWxlY3Qtc2VhcmNoLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsNkJBQTZCLEVBQUMsTUFBTSwrQ0FBK0MsQ0FBQztBQUM1RixPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0saUNBQWlDLENBQUM7QUFDaEUsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBQy9DLE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLHlDQUF5QyxDQUFDO0FBZ0I1RSxNQUFNLE9BQU8sbUNBQW1DOzs7WUFkL0MsUUFBUSxTQUFDO2dCQUNSLE9BQU8sRUFBRTtvQkFDUCxZQUFZO29CQUNaLGVBQWU7b0JBQ2YsVUFBVTtvQkFDVixtQkFBbUI7aUJBQ3BCO2dCQUNELFlBQVksRUFBRTtvQkFDWiw2QkFBNkI7aUJBQzlCO2dCQUNELE9BQU8sRUFBRTtvQkFDUCw2QkFBNkI7aUJBQzlCO2FBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xyXG5pbXBvcnQge0xpc3RPZlZhbHVlc011bHRpc2VsZWN0U2VhcmNofSBmcm9tIFwiLi9saXN0LW9mLXZhbHVlcy1tdWx0aXNlbGVjdC1zZWFyY2guY29tcG9uZW50XCI7XHJcbmltcG9ydCB7SW5wdXRUZXh0TW9kdWxlfSBmcm9tIFwiLi4vaW5wdXQtdGV4dC9pbnB1dC10ZXh0Lm1vZHVsZVwiO1xyXG5pbXBvcnQge0ljb25Nb2R1bGV9IGZyb20gXCIuLi9pY29uL2ljb24ubW9kdWxlXCI7XHJcbmltcG9ydCB7SW5wdXRDaGVja2JveE1vZHVsZX0gZnJvbSBcIi4uL2lucHV0LWNoZWNrYm94L2lucHV0LWNoZWNrYm94Lm1vZHVsZVwiO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBJbnB1dFRleHRNb2R1bGUsXHJcbiAgICBJY29uTW9kdWxlLFxyXG4gICAgSW5wdXRDaGVja2JveE1vZHVsZSxcclxuICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgTGlzdE9mVmFsdWVzTXVsdGlzZWxlY3RTZWFyY2hcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIExpc3RPZlZhbHVlc011bHRpc2VsZWN0U2VhcmNoXHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTGlzdE9mVmFsdWVzTXVsdGlzZWxlY3RTZWFyY2hNb2R1bGUge31cclxuIl19