@colijnit/corecomponents_v12 12.0.102 → 12.0.103

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 (50) hide show
  1. package/bundles/colijnit-corecomponents_v12.umd.js +428 -299
  2. package/bundles/colijnit-corecomponents_v12.umd.js.map +1 -1
  3. package/colijnit-corecomponents_v12.d.ts +13 -13
  4. package/colijnit-corecomponents_v12.metadata.json +1 -1
  5. package/esm2015/colijnit-corecomponents_v12.js +14 -14
  6. package/esm2015/lib/components/base/base-input.component.js +37 -30
  7. package/esm2015/lib/components/drop-down-list/drop-down-list.component.js +37 -34
  8. package/esm2015/lib/components/input-checkbox/input-checkbox.component.js +25 -20
  9. package/esm2015/lib/components/input-checkbox-multi-select/input-checkbox-multi-select.component.js +28 -23
  10. package/esm2015/lib/components/input-combo-box/input-combo-box.component.js +38 -34
  11. package/esm2015/lib/components/input-date-picker/input-date-picker.component.js +41 -37
  12. package/esm2015/lib/components/input-date-picker/input-date-picker.module.js +6 -2
  13. package/esm2015/lib/components/input-date-range-picker/input-date-range-picker.component.js +28 -25
  14. package/esm2015/lib/components/input-date-range-picker/input-date-range-picker.module.js +6 -2
  15. package/esm2015/lib/components/input-listbox/input-listbox.component.js +30 -26
  16. package/esm2015/lib/components/input-number-picker/input-number-picker.component.js +45 -40
  17. package/esm2015/lib/components/input-radio-button/input-radio-button.component.js +29 -24
  18. package/esm2015/lib/components/input-search/input-search.component.js +5 -1
  19. package/esm2015/lib/components/input-text/input-text.component.js +50 -44
  20. package/esm2015/lib/components/input-text/input-text.module.js +4 -2
  21. package/esm2015/lib/components/input-textarea/input-textarea.component.js +38 -34
  22. package/esm2015/lib/components/multi-select-list/multi-select-list.component.js +37 -34
  23. package/esm2015/lib/components/validation-error/validation-error.component.js +8 -5
  24. package/esm2015/lib/components/validation-error/validation-error.module.js +4 -2
  25. package/esm2015/lib/directives/overlay/overlay.directive.js +39 -18
  26. package/esm2015/lib/service/overlay.service.js +44 -0
  27. package/esm2015/public-api.js +3 -2
  28. package/fesm2015/colijnit-corecomponents_v12.js +587 -466
  29. package/fesm2015/colijnit-corecomponents_v12.js.map +1 -1
  30. package/lib/components/base/base-input.component.d.ts +4 -3
  31. package/lib/components/drop-down-list/drop-down-list.component.d.ts +8 -6
  32. package/lib/components/input-checkbox/input-checkbox.component.d.ts +9 -7
  33. package/lib/components/input-checkbox-multi-select/input-checkbox-multi-select.component.d.ts +8 -6
  34. package/lib/components/input-combo-box/input-combo-box.component.d.ts +9 -7
  35. package/lib/components/input-date-picker/input-date-picker.component.d.ts +11 -9
  36. package/lib/components/input-date-range-picker/input-date-range-picker.component.d.ts +1 -1
  37. package/lib/components/input-listbox/input-listbox.component.d.ts +9 -7
  38. package/lib/components/input-number-picker/input-number-picker.component.d.ts +12 -10
  39. package/lib/components/input-radio-button/input-radio-button.component.d.ts +7 -5
  40. package/lib/components/input-text/input-text.component.d.ts +9 -7
  41. package/lib/components/input-text/style/_layout.scss +1 -1
  42. package/lib/components/input-textarea/input-textarea.component.d.ts +8 -6
  43. package/lib/components/multi-select-list/multi-select-list.component.d.ts +8 -6
  44. package/lib/components/validation-error/style/_layout.scss +40 -30
  45. package/lib/components/validation-error/style/_theme.scss +23 -9
  46. package/lib/components/validation-error/validation-error.component.d.ts +2 -0
  47. package/lib/directives/overlay/overlay.directive.d.ts +4 -3
  48. package/lib/service/overlay.service.d.ts +10 -0
  49. package/package.json +1 -1
  50. package/public-api.d.ts +2 -1
@@ -8,6 +8,7 @@ import { AppendPipeModule } from "../../pipes/append.pipe.module";
8
8
  import { NumericTextBoxModule, TextBoxAllModule } from "@syncfusion/ej2-angular-inputs";
9
9
  import { ValidationErrorModule } from "../validation-error/validation-error.module";
10
10
  import { CommitButtonsModule } from "../base/commit-buttons/commit-buttons.module";
11
+ import { OverlayModule } from '../../directives/overlay/overlay.module';
11
12
  export class InputTextModule {
12
13
  }
13
14
  InputTextModule.decorators = [
@@ -21,7 +22,8 @@ InputTextModule.decorators = [
21
22
  TextBoxAllModule,
22
23
  NumericTextBoxModule,
23
24
  ValidationErrorModule,
24
- CommitButtonsModule
25
+ CommitButtonsModule,
26
+ OverlayModule
25
27
  ],
26
28
  declarations: [
27
29
  InputTextComponent
@@ -31,4 +33,4 @@ InputTextModule.decorators = [
31
33
  ]
32
34
  },] }
33
35
  ];
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtdGV4dC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvaW5wdXQtdGV4dC9pbnB1dC10ZXh0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDM0MsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDMUQsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBQy9DLE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUMvQyxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNoRSxPQUFPLEVBQUMsb0JBQW9CLEVBQUUsZ0JBQWdCLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN0RixPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSw2Q0FBNkMsQ0FBQztBQUNsRixPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSw4Q0FBOEMsQ0FBQztBQXFCakYsTUFBTSxPQUFPLGVBQWU7OztZQW5CM0IsUUFBUSxTQUFDO2dCQUNOLE9BQU8sRUFBRTtvQkFDTCxVQUFVO29CQUNWLFlBQVk7b0JBQ1osV0FBVztvQkFDWCxVQUFVO29CQUNWLGdCQUFnQjtvQkFDaEIsZ0JBQWdCO29CQUNoQixvQkFBb0I7b0JBQ3BCLHFCQUFxQjtvQkFDckIsbUJBQW1CO2lCQUN0QjtnQkFDSCxZQUFZLEVBQUU7b0JBQ1osa0JBQWtCO2lCQUNuQjtnQkFDRCxPQUFPLEVBQUU7b0JBQ1Asa0JBQWtCO2lCQUNuQjthQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHtGb3Jtc01vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XHJcbmltcG9ydCB7SW5wdXRUZXh0Q29tcG9uZW50fSBmcm9tIFwiLi9pbnB1dC10ZXh0LmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0ljb25Nb2R1bGV9IGZyb20gXCIuLi9pY29uL2ljb24ubW9kdWxlXCI7XHJcbmltcG9ydCB7QmFzZU1vZHVsZX0gZnJvbSBcIi4uL2Jhc2UvYmFzZS5tb2R1bGVcIjtcclxuaW1wb3J0IHtBcHBlbmRQaXBlTW9kdWxlfSBmcm9tIFwiLi4vLi4vcGlwZXMvYXBwZW5kLnBpcGUubW9kdWxlXCI7XHJcbmltcG9ydCB7TnVtZXJpY1RleHRCb3hNb2R1bGUsIFRleHRCb3hBbGxNb2R1bGV9IGZyb20gXCJAc3luY2Z1c2lvbi9lajItYW5ndWxhci1pbnB1dHNcIjtcclxuaW1wb3J0IHtWYWxpZGF0aW9uRXJyb3JNb2R1bGV9IGZyb20gXCIuLi92YWxpZGF0aW9uLWVycm9yL3ZhbGlkYXRpb24tZXJyb3IubW9kdWxlXCI7XHJcbmltcG9ydCB7Q29tbWl0QnV0dG9uc01vZHVsZX0gZnJvbSBcIi4uL2Jhc2UvY29tbWl0LWJ1dHRvbnMvY29tbWl0LWJ1dHRvbnMubW9kdWxlXCI7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIEJhc2VNb2R1bGUsXHJcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgICAgIEljb25Nb2R1bGUsXHJcbiAgICAgICAgQXBwZW5kUGlwZU1vZHVsZSxcclxuICAgICAgICBUZXh0Qm94QWxsTW9kdWxlLFxyXG4gICAgICAgIE51bWVyaWNUZXh0Qm94TW9kdWxlLFxyXG4gICAgICAgIFZhbGlkYXRpb25FcnJvck1vZHVsZSxcclxuICAgICAgICBDb21taXRCdXR0b25zTW9kdWxlXHJcbiAgICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgSW5wdXRUZXh0Q29tcG9uZW50XHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBJbnB1dFRleHRDb21wb25lbnRcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBJbnB1dFRleHRNb2R1bGUge1xyXG59XHJcbiJdfQ==
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtdGV4dC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvaW5wdXQtdGV4dC9pbnB1dC10ZXh0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDM0MsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDMUQsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBQy9DLE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUMvQyxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNoRSxPQUFPLEVBQUMsb0JBQW9CLEVBQUUsZ0JBQWdCLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN0RixPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSw2Q0FBNkMsQ0FBQztBQUNsRixPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSw4Q0FBOEMsQ0FBQztBQUNqRixPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0seUNBQXlDLENBQUM7QUFzQnRFLE1BQU0sT0FBTyxlQUFlOzs7WUFwQjNCLFFBQVEsU0FBQztnQkFDTixPQUFPLEVBQUU7b0JBQ0wsVUFBVTtvQkFDVixZQUFZO29CQUNaLFdBQVc7b0JBQ1gsVUFBVTtvQkFDVixnQkFBZ0I7b0JBQ2hCLGdCQUFnQjtvQkFDaEIsb0JBQW9CO29CQUNwQixxQkFBcUI7b0JBQ3JCLG1CQUFtQjtvQkFDbkIsYUFBYTtpQkFDaEI7Z0JBQ0gsWUFBWSxFQUFFO29CQUNaLGtCQUFrQjtpQkFDbkI7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLGtCQUFrQjtpQkFDbkI7YUFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XHJcbmltcG9ydCB7Rm9ybXNNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xyXG5pbXBvcnQge0lucHV0VGV4dENvbXBvbmVudH0gZnJvbSBcIi4vaW5wdXQtdGV4dC5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtJY29uTW9kdWxlfSBmcm9tIFwiLi4vaWNvbi9pY29uLm1vZHVsZVwiO1xyXG5pbXBvcnQge0Jhc2VNb2R1bGV9IGZyb20gXCIuLi9iYXNlL2Jhc2UubW9kdWxlXCI7XHJcbmltcG9ydCB7QXBwZW5kUGlwZU1vZHVsZX0gZnJvbSBcIi4uLy4uL3BpcGVzL2FwcGVuZC5waXBlLm1vZHVsZVwiO1xyXG5pbXBvcnQge051bWVyaWNUZXh0Qm94TW9kdWxlLCBUZXh0Qm94QWxsTW9kdWxlfSBmcm9tIFwiQHN5bmNmdXNpb24vZWoyLWFuZ3VsYXItaW5wdXRzXCI7XHJcbmltcG9ydCB7VmFsaWRhdGlvbkVycm9yTW9kdWxlfSBmcm9tIFwiLi4vdmFsaWRhdGlvbi1lcnJvci92YWxpZGF0aW9uLWVycm9yLm1vZHVsZVwiO1xyXG5pbXBvcnQge0NvbW1pdEJ1dHRvbnNNb2R1bGV9IGZyb20gXCIuLi9iYXNlL2NvbW1pdC1idXR0b25zL2NvbW1pdC1idXR0b25zLm1vZHVsZVwiO1xyXG5pbXBvcnQge092ZXJsYXlNb2R1bGV9IGZyb20gJy4uLy4uL2RpcmVjdGl2ZXMvb3ZlcmxheS9vdmVybGF5Lm1vZHVsZSc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIEJhc2VNb2R1bGUsXHJcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgICAgIEljb25Nb2R1bGUsXHJcbiAgICAgICAgQXBwZW5kUGlwZU1vZHVsZSxcclxuICAgICAgICBUZXh0Qm94QWxsTW9kdWxlLFxyXG4gICAgICAgIE51bWVyaWNUZXh0Qm94TW9kdWxlLFxyXG4gICAgICAgIFZhbGlkYXRpb25FcnJvck1vZHVsZSxcclxuICAgICAgICBDb21taXRCdXR0b25zTW9kdWxlLFxyXG4gICAgICAgIE92ZXJsYXlNb2R1bGVcclxuICAgIF0sXHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBJbnB1dFRleHRDb21wb25lbnRcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIElucHV0VGV4dENvbXBvbmVudFxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIElucHV0VGV4dE1vZHVsZSB7XHJcbn1cclxuIl19
@@ -1,19 +1,21 @@
1
- import { ChangeDetectorRef, Component, ComponentFactoryResolver, ElementRef, forwardRef, HostBinding, Input, Optional, ViewEncapsulation } from "@angular/core";
2
- import { BaseInputComponent } from "../base/base-input.component";
3
- import { SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME } from "../../interfaces/screen-config-adapter-component-interface-name";
4
- import { FormInputUserModelChangeListenerService } from "../../core/service/form-input-user-change-listener.service";
5
- import { NgZoneWrapperService } from "../../core/service/ng-zone-wrapper.service";
6
- import { FormComponent } from "../form/form.component";
1
+ import { ChangeDetectorRef, Component, ComponentFactoryResolver, ElementRef, forwardRef, HostBinding, Input, Optional, ViewEncapsulation } from '@angular/core';
2
+ import { BaseInputComponent } from '../base/base-input.component';
3
+ import { SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME } from '../../interfaces/screen-config-adapter-component-interface-name';
4
+ import { FormInputUserModelChangeListenerService } from '../../core/service/form-input-user-change-listener.service';
5
+ import { NgZoneWrapperService } from '../../core/service/ng-zone-wrapper.service';
6
+ import { FormComponent } from '../form/form.component';
7
+ import { OverlayService } from '../../service/overlay.service';
7
8
  export class InputTextareaComponent extends BaseInputComponent {
8
- constructor(formComponent, changeDetector, componentFactoryResolver, formUserChangeListener, ngZoneWrapper, elementRef) {
9
- super(changeDetector, componentFactoryResolver, formUserChangeListener, ngZoneWrapper, elementRef);
9
+ constructor(formComponent, changeDetector, overlayService, componentFactoryResolver, formUserChangeListener, ngZoneWrapper, elementRef) {
10
+ super(changeDetector, componentFactoryResolver, overlayService, formUserChangeListener, ngZoneWrapper, elementRef);
10
11
  this.formComponent = formComponent;
11
12
  this.changeDetector = changeDetector;
13
+ this.overlayService = overlayService;
12
14
  this.componentFactoryResolver = componentFactoryResolver;
13
15
  this.formUserChangeListener = formUserChangeListener;
14
16
  this.ngZoneWrapper = ngZoneWrapper;
15
17
  this.elementRef = elementRef;
16
- this.placeholder = "";
18
+ this.placeholder = '';
17
19
  this.hasOwnLabel = true;
18
20
  super._markAsOnPush();
19
21
  }
@@ -23,40 +25,42 @@ export class InputTextareaComponent extends BaseInputComponent {
23
25
  }
24
26
  InputTextareaComponent.decorators = [
25
27
  { type: Component, args: [{
26
- selector: "co-input-textarea",
28
+ selector: 'co-input-textarea',
27
29
  template: `
28
- <label [textContent]="placeholder"></label>
29
- <textarea
30
- #input
31
- type="textarea"
32
- [ngModel]="model"
33
- [readonly]="readonly"
34
- [required]="required"
35
- (ngModelChange)="modelChange.emit($event)"
36
- ></textarea>
37
- <co-commit-buttons *ngIf="showSaveCancel && focused && canSaveOrCancel"
38
- [committing]="committing"
39
- [commitFinished]="commitFinished"
40
- (commitClick)="commitClick($event)"
41
- (cancelClick)="cancelClick($event)"
42
- >
43
- </co-commit-buttons>
44
- <div class="required-indicator"></div>
45
- <ng-template #validationError></ng-template>
46
- `,
47
- providers: [{
30
+ <label [textContent]="placeholder"></label>
31
+ <textarea
32
+ #input
33
+ type="textarea"
34
+ [ngModel]="model"
35
+ [readonly]="readonly"
36
+ [required]="required"
37
+ (ngModelChange)="modelChange.emit($event)"
38
+ ></textarea>
39
+ <co-commit-buttons *ngIf="showSaveCancel && focused && canSaveOrCancel"
40
+ [committing]="committing"
41
+ [commitFinished]="commitFinished"
42
+ (commitClick)="commitClick($event)"
43
+ (cancelClick)="cancelClick($event)"
44
+ >
45
+ </co-commit-buttons>
46
+ <div class="required-indicator"></div>
47
+ `,
48
+ providers: [
49
+ OverlayService, {
48
50
  provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,
49
51
  useExisting: forwardRef(() => InputTextareaComponent)
50
52
  }, {
51
53
  provide: BaseInputComponent,
52
54
  useExisting: InputTextareaComponent
53
- }],
55
+ }
56
+ ],
54
57
  encapsulation: ViewEncapsulation.None
55
58
  },] }
56
59
  ];
57
60
  InputTextareaComponent.ctorParameters = () => [
58
61
  { type: FormComponent, decorators: [{ type: Optional }] },
59
62
  { type: ChangeDetectorRef },
63
+ { type: OverlayService },
60
64
  { type: ComponentFactoryResolver },
61
65
  { type: FormInputUserModelChangeListenerService },
62
66
  { type: NgZoneWrapperService },
@@ -64,7 +68,7 @@ InputTextareaComponent.ctorParameters = () => [
64
68
  ];
65
69
  InputTextareaComponent.propDecorators = {
66
70
  placeholder: [{ type: Input }],
67
- showClass: [{ type: HostBinding, args: ["class.co-input-textarea",] }],
68
- hasOwnLabel: [{ type: HostBinding, args: ["class.has-own-label",] }]
71
+ showClass: [{ type: HostBinding, args: ['class.co-input-textarea',] }],
72
+ hasOwnLabel: [{ type: HostBinding, args: ['class.has-own-label',] }]
69
73
  };
70
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtdGV4dGFyZWEuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2lucHV0LXRleHRhcmVhL2lucHV0LXRleHRhcmVhLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsaUJBQWlCLEVBQ2pCLFNBQVMsRUFDVCx3QkFBd0IsRUFDeEIsVUFBVSxFQUNWLFVBQVUsRUFDVixXQUFXLEVBQ1gsS0FBSyxFQUNMLFFBQVEsRUFDUixpQkFBaUIsRUFDbEIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDaEUsT0FBTyxFQUFDLDhDQUE4QyxFQUFDLE1BQU0saUVBQWlFLENBQUM7QUFDL0gsT0FBTyxFQUFDLHVDQUF1QyxFQUFDLE1BQU0sNERBQTRELENBQUM7QUFDbkgsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sNENBQTRDLENBQUM7QUFDaEYsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBaUNyRCxNQUFNLE9BQU8sc0JBQXVCLFNBQVEsa0JBQXVCO0lBY2pFLFlBQ3FCLGFBQTRCLEVBQ3JDLGNBQWlDLEVBQ2pDLHdCQUFrRCxFQUNsRCxzQkFBZ0UsRUFDaEUsYUFBb0MsRUFDdkMsVUFBdUI7UUFFOUIsS0FBSyxDQUFDLGNBQWMsRUFBRSx3QkFBd0IsRUFBRSxzQkFBc0IsRUFBRSxhQUFhLEVBQUUsVUFBVSxDQUFDLENBQUM7UUFQaEYsa0JBQWEsR0FBYixhQUFhLENBQWU7UUFDckMsbUJBQWMsR0FBZCxjQUFjLENBQW1CO1FBQ2pDLDZCQUF3QixHQUF4Qix3QkFBd0IsQ0FBMEI7UUFDbEQsMkJBQXNCLEdBQXRCLHNCQUFzQixDQUEwQztRQUNoRSxrQkFBYSxHQUFiLGFBQWEsQ0FBdUI7UUFDdkMsZUFBVSxHQUFWLFVBQVUsQ0FBYTtRQWxCekIsZ0JBQVcsR0FBVyxFQUFFLENBQUM7UUFRekIsZ0JBQVcsR0FBWSxJQUFJLENBQUM7UUFhakMsS0FBSyxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQ3hCLENBQUM7SUFuQk0sU0FBUztRQUNkLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQzs7O1lBdENGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsbUJBQW1CO2dCQUM3QixRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FtQlQ7Z0JBQ0QsU0FBUyxFQUFFLENBQUM7d0JBQ1YsT0FBTyxFQUFFLDhDQUE4Qzt3QkFDdkQsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztxQkFDdEQsRUFBRTt3QkFDRCxPQUFPLEVBQUUsa0JBQWtCO3dCQUMzQixXQUFXLEVBQUUsc0JBQXNCO3FCQUNwQyxDQUFDO2dCQUNGLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2FBQ3RDOzs7WUFoQ08sYUFBYSx1QkFnRGhCLFFBQVE7WUE5RFgsaUJBQWlCO1lBRWpCLHdCQUF3QjtZQVVsQix1Q0FBdUM7WUFDdkMsb0JBQW9CO1lBVjFCLFVBQVU7OzswQkE2Q1QsS0FBSzt3QkFHTCxXQUFXLFNBQUMseUJBQXlCOzBCQUtyQyxXQUFXLFNBQUMscUJBQXFCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBBZnRlclZpZXdJbml0LFxyXG4gIENoYW5nZURldGVjdG9yUmVmLFxyXG4gIENvbXBvbmVudCxcclxuICBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsXHJcbiAgRWxlbWVudFJlZixcclxuICBmb3J3YXJkUmVmLFxyXG4gIEhvc3RCaW5kaW5nLFxyXG4gIElucHV0LFxyXG4gIE9wdGlvbmFsLFxyXG4gIFZpZXdFbmNhcHN1bGF0aW9uXHJcbn0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtCYXNlSW5wdXRDb21wb25lbnR9IGZyb20gXCIuLi9iYXNlL2Jhc2UtaW5wdXQuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7U0NSRUVOX0NPTkZJR19BREFQVEVSX0NPTVBPTkVOVF9JTlRFUkZBQ0VfTkFNRX0gZnJvbSBcIi4uLy4uL2ludGVyZmFjZXMvc2NyZWVuLWNvbmZpZy1hZGFwdGVyLWNvbXBvbmVudC1pbnRlcmZhY2UtbmFtZVwiO1xyXG5pbXBvcnQge0Zvcm1JbnB1dFVzZXJNb2RlbENoYW5nZUxpc3RlbmVyU2VydmljZX0gZnJvbSBcIi4uLy4uL2NvcmUvc2VydmljZS9mb3JtLWlucHV0LXVzZXItY2hhbmdlLWxpc3RlbmVyLnNlcnZpY2VcIjtcclxuaW1wb3J0IHtOZ1pvbmVXcmFwcGVyU2VydmljZX0gZnJvbSBcIi4uLy4uL2NvcmUvc2VydmljZS9uZy16b25lLXdyYXBwZXIuc2VydmljZVwiO1xyXG5pbXBvcnQge0Zvcm1Db21wb25lbnR9IGZyb20gXCIuLi9mb3JtL2Zvcm0uY29tcG9uZW50XCI7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogXCJjby1pbnB1dC10ZXh0YXJlYVwiLFxyXG4gIHRlbXBsYXRlOiBgXHJcbiAgICA8bGFiZWwgW3RleHRDb250ZW50XT1cInBsYWNlaG9sZGVyXCI+PC9sYWJlbD5cclxuICAgIDx0ZXh0YXJlYVxyXG4gICAgICAjaW5wdXRcclxuICAgICAgdHlwZT1cInRleHRhcmVhXCJcclxuICAgICAgW25nTW9kZWxdPVwibW9kZWxcIlxyXG4gICAgICBbcmVhZG9ubHldPVwicmVhZG9ubHlcIlxyXG4gICAgICBbcmVxdWlyZWRdPVwicmVxdWlyZWRcIlxyXG4gICAgICAobmdNb2RlbENoYW5nZSk9XCJtb2RlbENoYW5nZS5lbWl0KCRldmVudClcIlxyXG4gICAgPjwvdGV4dGFyZWE+XHJcbiAgICA8Y28tY29tbWl0LWJ1dHRvbnMgKm5nSWY9XCJzaG93U2F2ZUNhbmNlbCAmJiBmb2N1c2VkICYmIGNhblNhdmVPckNhbmNlbFwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgW2NvbW1pdHRpbmddPVwiY29tbWl0dGluZ1wiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgW2NvbW1pdEZpbmlzaGVkXT1cImNvbW1pdEZpbmlzaGVkXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAoY29tbWl0Q2xpY2spPVwiY29tbWl0Q2xpY2soJGV2ZW50KVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgKGNhbmNlbENsaWNrKT1cImNhbmNlbENsaWNrKCRldmVudClcIlxyXG4gICAgPlxyXG4gICAgPC9jby1jb21taXQtYnV0dG9ucz5cclxuICAgIDxkaXYgY2xhc3M9XCJyZXF1aXJlZC1pbmRpY2F0b3JcIj48L2Rpdj5cclxuICAgIDxuZy10ZW1wbGF0ZSAjdmFsaWRhdGlvbkVycm9yPjwvbmctdGVtcGxhdGU+XHJcbiAgYCxcclxuICBwcm92aWRlcnM6IFt7XHJcbiAgICBwcm92aWRlOiBTQ1JFRU5fQ09ORklHX0FEQVBURVJfQ09NUE9ORU5UX0lOVEVSRkFDRV9OQU1FLFxyXG4gICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gSW5wdXRUZXh0YXJlYUNvbXBvbmVudClcclxuICB9LCB7XHJcbiAgICBwcm92aWRlOiBCYXNlSW5wdXRDb21wb25lbnQsXHJcbiAgICB1c2VFeGlzdGluZzogSW5wdXRUZXh0YXJlYUNvbXBvbmVudFxyXG4gIH1dLFxyXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcclxufSlcclxuZXhwb3J0IGNsYXNzIElucHV0VGV4dGFyZWFDb21wb25lbnQgZXh0ZW5kcyBCYXNlSW5wdXRDb21wb25lbnQ8YW55PiBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQge1xyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHBsYWNlaG9sZGVyOiBzdHJpbmcgPSBcIlwiO1xyXG5cclxuICBASG9zdEJpbmRpbmcoXCJjbGFzcy5jby1pbnB1dC10ZXh0YXJlYVwiKVxyXG4gIHB1YmxpYyBzaG93Q2xhc3MoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdHJ1ZTtcclxuICB9XHJcblxyXG4gIEBIb3N0QmluZGluZyhcImNsYXNzLmhhcy1vd24tbGFiZWxcIilcclxuICBwdWJsaWMgaGFzT3duTGFiZWw6IGJvb2xlYW4gPSB0cnVlO1xyXG5cclxuXHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgQE9wdGlvbmFsKCkgcHVibGljIGZvcm1Db21wb25lbnQ6IEZvcm1Db21wb25lbnQsXHJcbiAgICBwcm90ZWN0ZWQgY2hhbmdlRGV0ZWN0b3I6IENoYW5nZURldGVjdG9yUmVmLFxyXG4gICAgcHJvdGVjdGVkIGNvbXBvbmVudEZhY3RvcnlSZXNvbHZlcjogQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyLFxyXG4gICAgcHJvdGVjdGVkIGZvcm1Vc2VyQ2hhbmdlTGlzdGVuZXI/OiBGb3JtSW5wdXRVc2VyTW9kZWxDaGFuZ2VMaXN0ZW5lclNlcnZpY2UsXHJcbiAgICBwcm90ZWN0ZWQgbmdab25lV3JhcHBlcj86IE5nWm9uZVdyYXBwZXJTZXJ2aWNlLFxyXG4gICAgcHVibGljIGVsZW1lbnRSZWY/OiBFbGVtZW50UmVmLFxyXG4gICkge1xyXG4gICAgc3VwZXIoY2hhbmdlRGV0ZWN0b3IsIGNvbXBvbmVudEZhY3RvcnlSZXNvbHZlciwgZm9ybVVzZXJDaGFuZ2VMaXN0ZW5lciwgbmdab25lV3JhcHBlciwgZWxlbWVudFJlZik7XHJcbiAgICBzdXBlci5fbWFya0FzT25QdXNoKCk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
74
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtdGV4dGFyZWEuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2lucHV0LXRleHRhcmVhL2lucHV0LXRleHRhcmVhLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUgsaUJBQWlCLEVBQ2pCLFNBQVMsRUFDVCx3QkFBd0IsRUFDeEIsVUFBVSxFQUNWLFVBQVUsRUFDVixXQUFXLEVBQ1gsS0FBSyxFQUNMLFFBQVEsRUFDUixpQkFBaUIsRUFDcEIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDaEUsT0FBTyxFQUFDLDhDQUE4QyxFQUFDLE1BQU0saUVBQWlFLENBQUM7QUFDL0gsT0FBTyxFQUFDLHVDQUF1QyxFQUFDLE1BQU0sNERBQTRELENBQUM7QUFDbkgsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sNENBQTRDLENBQUM7QUFDaEYsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ3JELE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSwrQkFBK0IsQ0FBQztBQWlDN0QsTUFBTSxPQUFPLHNCQUF1QixTQUFRLGtCQUF1QjtJQWEvRCxZQUN1QixhQUE0QixFQUNyQyxjQUFpQyxFQUNqQyxjQUE4QixFQUM5Qix3QkFBa0QsRUFDbEQsc0JBQWdFLEVBQ2hFLGFBQW9DLEVBQ3ZDLFVBQXVCO1FBRTlCLEtBQUssQ0FBQyxjQUFjLEVBQUUsd0JBQXdCLEVBQUUsY0FBYyxFQUFFLHNCQUFzQixFQUFFLGFBQWEsRUFBRSxVQUFVLENBQUMsQ0FBQztRQVJoRyxrQkFBYSxHQUFiLGFBQWEsQ0FBZTtRQUNyQyxtQkFBYyxHQUFkLGNBQWMsQ0FBbUI7UUFDakMsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBQzlCLDZCQUF3QixHQUF4Qix3QkFBd0IsQ0FBMEI7UUFDbEQsMkJBQXNCLEdBQXRCLHNCQUFzQixDQUEwQztRQUNoRSxrQkFBYSxHQUFiLGFBQWEsQ0FBdUI7UUFDdkMsZUFBVSxHQUFWLFVBQVUsQ0FBYTtRQWxCM0IsZ0JBQVcsR0FBVyxFQUFFLENBQUM7UUFRekIsZ0JBQVcsR0FBWSxJQUFJLENBQUM7UUFhL0IsS0FBSyxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQzFCLENBQUM7SUFuQk0sU0FBUztRQUNaLE9BQU8sSUFBSSxDQUFDO0lBQ2hCLENBQUM7OztZQXRDSixTQUFTLFNBQUM7Z0JBQ1AsUUFBUSxFQUFFLG1CQUFtQjtnQkFDN0IsUUFBUSxFQUFFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7S0FrQlQ7Z0JBQ0QsU0FBUyxFQUFFO29CQUNQLGNBQWMsRUFBRTt3QkFDWixPQUFPLEVBQUUsOENBQThDO3dCQUN2RCxXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLHNCQUFzQixDQUFDO3FCQUN4RCxFQUFFO3dCQUNDLE9BQU8sRUFBRSxrQkFBa0I7d0JBQzNCLFdBQVcsRUFBRSxzQkFBc0I7cUJBQ3RDO2lCQUFDO2dCQUNOLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2FBQ3hDOzs7WUFqQ08sYUFBYSx1QkFnRFosUUFBUTtZQTlEYixpQkFBaUI7WUFlYixjQUFjO1lBYmxCLHdCQUF3QjtZQVVwQix1Q0FBdUM7WUFDdkMsb0JBQW9CO1lBVnhCLFVBQVU7OzswQkE4Q1QsS0FBSzt3QkFHTCxXQUFXLFNBQUMseUJBQXlCOzBCQUtyQyxXQUFXLFNBQUMscUJBQXFCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICAgIEFmdGVyVmlld0luaXQsXHJcbiAgICBDaGFuZ2VEZXRlY3RvclJlZixcclxuICAgIENvbXBvbmVudCxcclxuICAgIENvbXBvbmVudEZhY3RvcnlSZXNvbHZlcixcclxuICAgIEVsZW1lbnRSZWYsXHJcbiAgICBmb3J3YXJkUmVmLFxyXG4gICAgSG9zdEJpbmRpbmcsXHJcbiAgICBJbnB1dCxcclxuICAgIE9wdGlvbmFsLFxyXG4gICAgVmlld0VuY2Fwc3VsYXRpb25cclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHtCYXNlSW5wdXRDb21wb25lbnR9IGZyb20gJy4uL2Jhc2UvYmFzZS1pbnB1dC5jb21wb25lbnQnO1xyXG5pbXBvcnQge1NDUkVFTl9DT05GSUdfQURBUFRFUl9DT01QT05FTlRfSU5URVJGQUNFX05BTUV9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMvc2NyZWVuLWNvbmZpZy1hZGFwdGVyLWNvbXBvbmVudC1pbnRlcmZhY2UtbmFtZSc7XHJcbmltcG9ydCB7Rm9ybUlucHV0VXNlck1vZGVsQ2hhbmdlTGlzdGVuZXJTZXJ2aWNlfSBmcm9tICcuLi8uLi9jb3JlL3NlcnZpY2UvZm9ybS1pbnB1dC11c2VyLWNoYW5nZS1saXN0ZW5lci5zZXJ2aWNlJztcclxuaW1wb3J0IHtOZ1pvbmVXcmFwcGVyU2VydmljZX0gZnJvbSAnLi4vLi4vY29yZS9zZXJ2aWNlL25nLXpvbmUtd3JhcHBlci5zZXJ2aWNlJztcclxuaW1wb3J0IHtGb3JtQ29tcG9uZW50fSBmcm9tICcuLi9mb3JtL2Zvcm0uY29tcG9uZW50JztcclxuaW1wb3J0IHtPdmVybGF5U2VydmljZX0gZnJvbSAnLi4vLi4vc2VydmljZS9vdmVybGF5LnNlcnZpY2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2NvLWlucHV0LXRleHRhcmVhJyxcclxuICAgIHRlbXBsYXRlOiBgXHJcbiAgICAgICAgPGxhYmVsIFt0ZXh0Q29udGVudF09XCJwbGFjZWhvbGRlclwiPjwvbGFiZWw+XHJcbiAgICAgICAgPHRleHRhcmVhXHJcbiAgICAgICAgICAgICAgICAjaW5wdXRcclxuICAgICAgICAgICAgICAgIHR5cGU9XCJ0ZXh0YXJlYVwiXHJcbiAgICAgICAgICAgICAgICBbbmdNb2RlbF09XCJtb2RlbFwiXHJcbiAgICAgICAgICAgICAgICBbcmVhZG9ubHldPVwicmVhZG9ubHlcIlxyXG4gICAgICAgICAgICAgICAgW3JlcXVpcmVkXT1cInJlcXVpcmVkXCJcclxuICAgICAgICAgICAgICAgIChuZ01vZGVsQ2hhbmdlKT1cIm1vZGVsQ2hhbmdlLmVtaXQoJGV2ZW50KVwiXHJcbiAgICAgICAgPjwvdGV4dGFyZWE+XHJcbiAgICAgICAgPGNvLWNvbW1pdC1idXR0b25zICpuZ0lmPVwic2hvd1NhdmVDYW5jZWwgJiYgZm9jdXNlZCAmJiBjYW5TYXZlT3JDYW5jZWxcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICBbY29tbWl0dGluZ109XCJjb21taXR0aW5nXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgW2NvbW1pdEZpbmlzaGVkXT1cImNvbW1pdEZpbmlzaGVkXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgKGNvbW1pdENsaWNrKT1cImNvbW1pdENsaWNrKCRldmVudClcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAoY2FuY2VsQ2xpY2spPVwiY2FuY2VsQ2xpY2soJGV2ZW50KVwiXHJcbiAgICAgICAgPlxyXG4gICAgICAgIDwvY28tY29tbWl0LWJ1dHRvbnM+XHJcbiAgICAgICAgPGRpdiBjbGFzcz1cInJlcXVpcmVkLWluZGljYXRvclwiPjwvZGl2PlxyXG4gICAgYCxcclxuICAgIHByb3ZpZGVyczogW1xyXG4gICAgICAgIE92ZXJsYXlTZXJ2aWNlLCB7XHJcbiAgICAgICAgICAgIHByb3ZpZGU6IFNDUkVFTl9DT05GSUdfQURBUFRFUl9DT01QT05FTlRfSU5URVJGQUNFX05BTUUsXHJcbiAgICAgICAgICAgIHVzZUV4aXN0aW5nOiBmb3J3YXJkUmVmKCgpID0+IElucHV0VGV4dGFyZWFDb21wb25lbnQpXHJcbiAgICAgICAgfSwge1xyXG4gICAgICAgICAgICBwcm92aWRlOiBCYXNlSW5wdXRDb21wb25lbnQsXHJcbiAgICAgICAgICAgIHVzZUV4aXN0aW5nOiBJbnB1dFRleHRhcmVhQ29tcG9uZW50XHJcbiAgICAgICAgfV0sXHJcbiAgICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBJbnB1dFRleHRhcmVhQ29tcG9uZW50IGV4dGVuZHMgQmFzZUlucHV0Q29tcG9uZW50PGFueT4gaW1wbGVtZW50cyBBZnRlclZpZXdJbml0IHtcclxuICAgIEBJbnB1dCgpXHJcbiAgICBwdWJsaWMgcGxhY2Vob2xkZXI6IHN0cmluZyA9ICcnO1xyXG5cclxuICAgIEBIb3N0QmluZGluZygnY2xhc3MuY28taW5wdXQtdGV4dGFyZWEnKVxyXG4gICAgcHVibGljIHNob3dDbGFzcygpOiBib29sZWFuIHtcclxuICAgICAgICByZXR1cm4gdHJ1ZTtcclxuICAgIH1cclxuXHJcbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzLmhhcy1vd24tbGFiZWwnKVxyXG4gICAgcHVibGljIGhhc093bkxhYmVsOiBib29sZWFuID0gdHJ1ZTtcclxuXHJcblxyXG4gICAgY29uc3RydWN0b3IoXHJcbiAgICAgICAgQE9wdGlvbmFsKCkgcHVibGljIGZvcm1Db21wb25lbnQ6IEZvcm1Db21wb25lbnQsXHJcbiAgICAgICAgcHJvdGVjdGVkIGNoYW5nZURldGVjdG9yOiBDaGFuZ2VEZXRlY3RvclJlZixcclxuICAgICAgICBwcm90ZWN0ZWQgb3ZlcmxheVNlcnZpY2U6IE92ZXJsYXlTZXJ2aWNlLFxyXG4gICAgICAgIHByb3RlY3RlZCBjb21wb25lbnRGYWN0b3J5UmVzb2x2ZXI6IENvbXBvbmVudEZhY3RvcnlSZXNvbHZlcixcclxuICAgICAgICBwcm90ZWN0ZWQgZm9ybVVzZXJDaGFuZ2VMaXN0ZW5lcj86IEZvcm1JbnB1dFVzZXJNb2RlbENoYW5nZUxpc3RlbmVyU2VydmljZSxcclxuICAgICAgICBwcm90ZWN0ZWQgbmdab25lV3JhcHBlcj86IE5nWm9uZVdyYXBwZXJTZXJ2aWNlLFxyXG4gICAgICAgIHB1YmxpYyBlbGVtZW50UmVmPzogRWxlbWVudFJlZixcclxuICAgICkge1xyXG4gICAgICAgIHN1cGVyKGNoYW5nZURldGVjdG9yLCBjb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsIG92ZXJsYXlTZXJ2aWNlLCBmb3JtVXNlckNoYW5nZUxpc3RlbmVyLCBuZ1pvbmVXcmFwcGVyLCBlbGVtZW50UmVmKTtcclxuICAgICAgICBzdXBlci5fbWFya0FzT25QdXNoKCk7XHJcbiAgICB9XHJcbn1cclxuIl19
@@ -1,15 +1,17 @@
1
- import { ChangeDetectorRef, Component, ComponentFactoryResolver, ElementRef, forwardRef, HostBinding, Input, Optional, ViewEncapsulation } from "@angular/core";
2
- import { SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME } from "../../interfaces/screen-config-adapter-component-interface-name";
3
- import { BaseInputComponent } from "../base/base-input.component";
4
- import { CheckBoxSelectionService } from "@syncfusion/ej2-angular-dropdowns";
5
- import { FormInputUserModelChangeListenerService } from "../../core/service/form-input-user-change-listener.service";
6
- import { NgZoneWrapperService } from "../../core/service/ng-zone-wrapper.service";
7
- import { FormComponent } from "../form/form.component";
1
+ import { ChangeDetectorRef, Component, ComponentFactoryResolver, ElementRef, forwardRef, HostBinding, Input, Optional, ViewEncapsulation } from '@angular/core';
2
+ import { SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME } from '../../interfaces/screen-config-adapter-component-interface-name';
3
+ import { BaseInputComponent } from '../base/base-input.component';
4
+ import { CheckBoxSelectionService } from '@syncfusion/ej2-angular-dropdowns';
5
+ import { FormInputUserModelChangeListenerService } from '../../core/service/form-input-user-change-listener.service';
6
+ import { NgZoneWrapperService } from '../../core/service/ng-zone-wrapper.service';
7
+ import { FormComponent } from '../form/form.component';
8
+ import { OverlayService } from '../../service/overlay.service';
8
9
  export class MultiSelectListComponent extends BaseInputComponent {
9
- constructor(formComponent, changeDetector, componentFactoryResolver, formUserChangeListener, ngZoneWrapper, elementRef) {
10
- super(changeDetector, componentFactoryResolver, formUserChangeListener, ngZoneWrapper, elementRef);
10
+ constructor(formComponent, changeDetector, overlayService, componentFactoryResolver, formUserChangeListener, ngZoneWrapper, elementRef) {
11
+ super(changeDetector, componentFactoryResolver, overlayService, formUserChangeListener, ngZoneWrapper, elementRef);
11
12
  this.formComponent = formComponent;
12
13
  this.changeDetector = changeDetector;
14
+ this.overlayService = overlayService;
13
15
  this.componentFactoryResolver = componentFactoryResolver;
14
16
  this.formUserChangeListener = formUserChangeListener;
15
17
  this.ngZoneWrapper = ngZoneWrapper;
@@ -20,12 +22,12 @@ export class MultiSelectListComponent extends BaseInputComponent {
20
22
  */
21
23
  this.fields = {};
22
24
  this.showSelectAll = true;
23
- this.mode = "Default";
25
+ this.mode = 'Default';
24
26
  super._markAsOnPush();
25
27
  }
26
28
  set showCheckbox(value) {
27
29
  if (value) {
28
- this.mode = "CheckBox";
30
+ this.mode = 'CheckBox';
29
31
  }
30
32
  }
31
33
  showClass() {
@@ -42,29 +44,29 @@ export class MultiSelectListComponent extends BaseInputComponent {
42
44
  }
43
45
  MultiSelectListComponent.decorators = [
44
46
  { type: Component, args: [{
45
- selector: "co-multi-select-list",
47
+ selector: 'co-multi-select-list',
46
48
  template: `
47
- <ejs-multiselect
48
- [dataSource]="collection"
49
- [placeholder]="placeholder"
50
- [value]="model"
51
- [mode]="mode"
52
- [fields]="fields"
53
- [readonly]="readonly"
54
- [itemTemplate]="itemTemplate"
55
- [headerTemplate]="headerTemplate"
56
- [valueTemplate]="valueTemplate"
57
- [footerTemplate]="footerTemplate"
58
- [selectAllText]="'Select All'"
59
- [showSelectAll]=showSelectAll
60
- [ngModel]="model"
61
- (ngModelChange)="handleModelChange($event)"
62
- (valueChange)="handleModelChange($event)"
63
- ></ejs-multiselect>
64
- <div class="required-indicator"></div>
65
- <ng-template #validationError></ng-template>
66
- `,
49
+ <ejs-multiselect
50
+ [dataSource]="collection"
51
+ [placeholder]="placeholder"
52
+ [value]="model"
53
+ [mode]="mode"
54
+ [fields]="fields"
55
+ [readonly]="readonly"
56
+ [itemTemplate]="itemTemplate"
57
+ [headerTemplate]="headerTemplate"
58
+ [valueTemplate]="valueTemplate"
59
+ [footerTemplate]="footerTemplate"
60
+ [selectAllText]="'Select All'"
61
+ [showSelectAll]=showSelectAll
62
+ [ngModel]="model"
63
+ (ngModelChange)="handleModelChange($event)"
64
+ (valueChange)="handleModelChange($event)"
65
+ ></ejs-multiselect>
66
+ <div class="required-indicator"></div>
67
+ `,
67
68
  providers: [
69
+ OverlayService,
68
70
  CheckBoxSelectionService,
69
71
  {
70
72
  provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,
@@ -80,6 +82,7 @@ MultiSelectListComponent.decorators = [
80
82
  MultiSelectListComponent.ctorParameters = () => [
81
83
  { type: FormComponent, decorators: [{ type: Optional }] },
82
84
  { type: ChangeDetectorRef },
85
+ { type: OverlayService },
83
86
  { type: ComponentFactoryResolver },
84
87
  { type: FormInputUserModelChangeListenerService },
85
88
  { type: NgZoneWrapperService },
@@ -95,6 +98,6 @@ MultiSelectListComponent.propDecorators = {
95
98
  footerTemplate: [{ type: Input }],
96
99
  showSelectAll: [{ type: Input }],
97
100
  showCheckbox: [{ type: Input }],
98
- showClass: [{ type: HostBinding, args: ["class.co-multi-select-list",] }]
101
+ showClass: [{ type: HostBinding, args: ['class.co-multi-select-list',] }]
99
102
  };
100
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXVsdGktc2VsZWN0LWxpc3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL211bHRpLXNlbGVjdC1saXN0L211bHRpLXNlbGVjdC1saXN0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsaUJBQWlCLEVBQ2pCLFNBQVMsRUFDVCx3QkFBd0IsRUFDeEIsVUFBVSxFQUNWLFVBQVUsRUFDVixXQUFXLEVBQ1gsS0FBSyxFQUNMLFFBQVEsRUFFUixpQkFBaUIsRUFDbEIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFDLDhDQUE4QyxFQUFDLE1BQU0saUVBQWlFLENBQUM7QUFDL0gsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDaEUsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDM0UsT0FBTyxFQUFDLHVDQUF1QyxFQUFDLE1BQU0sNERBQTRELENBQUM7QUFDbkgsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sNENBQTRDLENBQUM7QUFDaEYsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBcUNyRCxNQUFNLE9BQU8sd0JBQXlCLFNBQVEsa0JBQXlCO0lBMENyRSxZQUNxQixhQUE0QixFQUNyQyxjQUFpQyxFQUNqQyx3QkFBa0QsRUFDbEQsc0JBQWdFLEVBQ2hFLGFBQW9DLEVBQ3ZDLFVBQXVCO1FBRTlCLEtBQUssQ0FBQyxjQUFjLEVBQUUsd0JBQXdCLEVBQUUsc0JBQXNCLEVBQUUsYUFBYSxFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBUGhGLGtCQUFhLEdBQWIsYUFBYSxDQUFlO1FBQ3JDLG1CQUFjLEdBQWQsY0FBYyxDQUFtQjtRQUNqQyw2QkFBd0IsR0FBeEIsd0JBQXdCLENBQTBCO1FBQ2xELDJCQUFzQixHQUF0QixzQkFBc0IsQ0FBMEM7UUFDaEUsa0JBQWEsR0FBYixhQUFhLENBQXVCO1FBQ3ZDLGVBQVUsR0FBVixVQUFVLENBQWE7UUEzQ2hDOzs7V0FHRztRQUVJLFdBQU0sR0FBVyxFQUFFLENBQUM7UUFrQnBCLGtCQUFhLEdBQVksSUFBSSxDQUFDO1FBMEI5QixTQUFJLEdBQVEsU0FBUyxDQUFDO1FBSDNCLEtBQUssQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUN4QixDQUFDO0lBdEJELElBQ1csWUFBWSxDQUFDLEtBQWM7UUFDcEMsSUFBSSxLQUFLLEVBQUU7WUFDVCxJQUFJLENBQUMsSUFBSSxHQUFHLFVBQVUsQ0FBQztTQUN4QjtJQUNILENBQUM7SUFHTSxTQUFTO1FBQ2QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBZ0JNLGlCQUFpQixDQUFDLEdBQVE7UUFDL0IsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1lBQ3RCLElBQUksR0FBRyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7Z0JBQ2xCLEdBQUcsR0FBRyxTQUFTLENBQUM7YUFDakI7U0FDRjtRQUNELElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzdCLENBQUM7OztZQWxHRixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLHNCQUFzQjtnQkFDaEMsUUFBUSxFQUFFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW9CVDtnQkFDRCxTQUFTLEVBQUU7b0JBQ1Qsd0JBQXdCO29CQUN4Qjt3QkFDRSxPQUFPLEVBQUUsOENBQThDO3dCQUN2RCxXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLHdCQUF3QixDQUFDO3FCQUN4RCxFQUFFO3dCQUNELE9BQU8sRUFBRSxrQkFBa0I7d0JBQzNCLFdBQVcsRUFBRSx3QkFBd0I7cUJBQ3RDO2lCQUNGO2dCQUNELGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2FBQ3RDOzs7WUFwQ08sYUFBYSx1QkFnRmhCLFFBQVE7WUFoR1gsaUJBQWlCO1lBRWpCLHdCQUF3QjtZQVlsQix1Q0FBdUM7WUFDdkMsb0JBQW9CO1lBWjFCLFVBQVU7Ozt5QkFvRFQsS0FBSztxQkFPTCxLQUFLOzBCQUdMLEtBQUs7MkJBR0wsS0FBSzs2QkFHTCxLQUFLOzRCQUdMLEtBQUs7NkJBR0wsS0FBSzs0QkFHTCxLQUFLOzJCQUdMLEtBQUs7d0JBT0wsV0FBVyxTQUFDLDRCQUE0QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ2hhbmdlRGV0ZWN0b3JSZWYsXHJcbiAgQ29tcG9uZW50LFxyXG4gIENvbXBvbmVudEZhY3RvcnlSZXNvbHZlcixcclxuICBFbGVtZW50UmVmLFxyXG4gIGZvcndhcmRSZWYsXHJcbiAgSG9zdEJpbmRpbmcsXHJcbiAgSW5wdXQsXHJcbiAgT3B0aW9uYWwsXHJcbiAgVGVtcGxhdGVSZWYsXHJcbiAgVmlld0VuY2Fwc3VsYXRpb25cclxufSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge1NDUkVFTl9DT05GSUdfQURBUFRFUl9DT01QT05FTlRfSU5URVJGQUNFX05BTUV9IGZyb20gXCIuLi8uLi9pbnRlcmZhY2VzL3NjcmVlbi1jb25maWctYWRhcHRlci1jb21wb25lbnQtaW50ZXJmYWNlLW5hbWVcIjtcclxuaW1wb3J0IHtCYXNlSW5wdXRDb21wb25lbnR9IGZyb20gXCIuLi9iYXNlL2Jhc2UtaW5wdXQuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7Q2hlY2tCb3hTZWxlY3Rpb25TZXJ2aWNlfSBmcm9tIFwiQHN5bmNmdXNpb24vZWoyLWFuZ3VsYXItZHJvcGRvd25zXCI7XHJcbmltcG9ydCB7Rm9ybUlucHV0VXNlck1vZGVsQ2hhbmdlTGlzdGVuZXJTZXJ2aWNlfSBmcm9tIFwiLi4vLi4vY29yZS9zZXJ2aWNlL2Zvcm0taW5wdXQtdXNlci1jaGFuZ2UtbGlzdGVuZXIuc2VydmljZVwiO1xyXG5pbXBvcnQge05nWm9uZVdyYXBwZXJTZXJ2aWNlfSBmcm9tIFwiLi4vLi4vY29yZS9zZXJ2aWNlL25nLXpvbmUtd3JhcHBlci5zZXJ2aWNlXCI7XHJcbmltcG9ydCB7Rm9ybUNvbXBvbmVudH0gZnJvbSBcIi4uL2Zvcm0vZm9ybS5jb21wb25lbnRcIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiBcImNvLW11bHRpLXNlbGVjdC1saXN0XCIsXHJcbiAgdGVtcGxhdGU6IGBcclxuICAgIDxlanMtbXVsdGlzZWxlY3RcclxuICAgICAgW2RhdGFTb3VyY2VdPVwiY29sbGVjdGlvblwiXHJcbiAgICAgIFtwbGFjZWhvbGRlcl09XCJwbGFjZWhvbGRlclwiXHJcbiAgICAgIFt2YWx1ZV09XCJtb2RlbFwiXHJcbiAgICAgIFttb2RlXT1cIm1vZGVcIlxyXG4gICAgICBbZmllbGRzXT1cImZpZWxkc1wiXHJcbiAgICAgIFtyZWFkb25seV09XCJyZWFkb25seVwiXHJcbiAgICAgIFtpdGVtVGVtcGxhdGVdPVwiaXRlbVRlbXBsYXRlXCJcclxuICAgICAgW2hlYWRlclRlbXBsYXRlXT1cImhlYWRlclRlbXBsYXRlXCJcclxuICAgICAgW3ZhbHVlVGVtcGxhdGVdPVwidmFsdWVUZW1wbGF0ZVwiXHJcbiAgICAgIFtmb290ZXJUZW1wbGF0ZV09XCJmb290ZXJUZW1wbGF0ZVwiXHJcbiAgICAgIFtzZWxlY3RBbGxUZXh0XT1cIidTZWxlY3QgQWxsJ1wiXHJcbiAgICAgIFtzaG93U2VsZWN0QWxsXT1zaG93U2VsZWN0QWxsXHJcbiAgICAgIFtuZ01vZGVsXT1cIm1vZGVsXCJcclxuICAgICAgKG5nTW9kZWxDaGFuZ2UpPVwiaGFuZGxlTW9kZWxDaGFuZ2UoJGV2ZW50KVwiXHJcbiAgICAgICh2YWx1ZUNoYW5nZSk9XCJoYW5kbGVNb2RlbENoYW5nZSgkZXZlbnQpXCJcclxuICAgID48L2Vqcy1tdWx0aXNlbGVjdD5cclxuICAgIDxkaXYgY2xhc3M9XCJyZXF1aXJlZC1pbmRpY2F0b3JcIj48L2Rpdj5cclxuICAgIDxuZy10ZW1wbGF0ZSAjdmFsaWRhdGlvbkVycm9yPjwvbmctdGVtcGxhdGU+XHJcbiAgYCxcclxuICBwcm92aWRlcnM6IFtcclxuICAgIENoZWNrQm94U2VsZWN0aW9uU2VydmljZSxcclxuICAgIHtcclxuICAgICAgcHJvdmlkZTogU0NSRUVOX0NPTkZJR19BREFQVEVSX0NPTVBPTkVOVF9JTlRFUkZBQ0VfTkFNRSxcclxuICAgICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gTXVsdGlTZWxlY3RMaXN0Q29tcG9uZW50KVxyXG4gICAgfSwge1xyXG4gICAgICBwcm92aWRlOiBCYXNlSW5wdXRDb21wb25lbnQsXHJcbiAgICAgIHVzZUV4aXN0aW5nOiBNdWx0aVNlbGVjdExpc3RDb21wb25lbnRcclxuICAgIH1cclxuICBdLFxyXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcclxufSlcclxuZXhwb3J0IGNsYXNzIE11bHRpU2VsZWN0TGlzdENvbXBvbmVudCBleHRlbmRzIEJhc2VJbnB1dENvbXBvbmVudDxhbnlbXT4ge1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBjb2xsZWN0aW9uOiBhbnlbXTtcclxuXHJcbiAgLyoqXHJcbiAgICogSW4gdGhlIGZvcm0geyB0ZXh0OiAnbmFtZScsIHZhbHVlOiAnaWQnIH1cclxuICAgKiBXaGVyZSAndGV4dCcgaXMgc2hvd2luZyBpbiB0aGUgZHJvcGRvd24gYW5kICdpZCcgdXNlZCBmb3IgdGhlIG1vZGVsIGJpbmRpbmdcclxuICAgKi9cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBmaWVsZHM6IE9iamVjdCA9IHt9O1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBwbGFjZWhvbGRlcjogc3RyaW5nO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBpdGVtVGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT47XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGhlYWRlclRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+O1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyB2YWx1ZVRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+O1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBmb290ZXJUZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55PjtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgc2hvd1NlbGVjdEFsbDogYm9vbGVhbiA9IHRydWU7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHNldCBzaG93Q2hlY2tib3godmFsdWU6IGJvb2xlYW4pIHtcclxuICAgIGlmICh2YWx1ZSkge1xyXG4gICAgICB0aGlzLm1vZGUgPSBcIkNoZWNrQm94XCI7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBASG9zdEJpbmRpbmcoXCJjbGFzcy5jby1tdWx0aS1zZWxlY3QtbGlzdFwiKVxyXG4gIHB1YmxpYyBzaG93Q2xhc3MoKSB7XHJcbiAgICByZXR1cm4gdHJ1ZTtcclxuICB9XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgQE9wdGlvbmFsKCkgcHVibGljIGZvcm1Db21wb25lbnQ6IEZvcm1Db21wb25lbnQsXHJcbiAgICBwcm90ZWN0ZWQgY2hhbmdlRGV0ZWN0b3I6IENoYW5nZURldGVjdG9yUmVmLFxyXG4gICAgcHJvdGVjdGVkIGNvbXBvbmVudEZhY3RvcnlSZXNvbHZlcjogQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyLFxyXG4gICAgcHJvdGVjdGVkIGZvcm1Vc2VyQ2hhbmdlTGlzdGVuZXI/OiBGb3JtSW5wdXRVc2VyTW9kZWxDaGFuZ2VMaXN0ZW5lclNlcnZpY2UsXHJcbiAgICBwcm90ZWN0ZWQgbmdab25lV3JhcHBlcj86IE5nWm9uZVdyYXBwZXJTZXJ2aWNlLFxyXG4gICAgcHVibGljIGVsZW1lbnRSZWY/OiBFbGVtZW50UmVmLFxyXG4gICkge1xyXG4gICAgc3VwZXIoY2hhbmdlRGV0ZWN0b3IsIGNvbXBvbmVudEZhY3RvcnlSZXNvbHZlciwgZm9ybVVzZXJDaGFuZ2VMaXN0ZW5lciwgbmdab25lV3JhcHBlciwgZWxlbWVudFJlZik7XHJcbiAgICBzdXBlci5fbWFya0FzT25QdXNoKCk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgbW9kZTogYW55ID0gXCJEZWZhdWx0XCI7XHJcblxyXG4gIHB1YmxpYyBoYW5kbGVNb2RlbENoYW5nZSh2YWw6IGFueSk6IHZvaWQge1xyXG4gICAgaWYgKEFycmF5LmlzQXJyYXkodmFsKSkge1xyXG4gICAgICBpZiAodmFsLmxlbmd0aCA8IDEpIHtcclxuICAgICAgICB2YWwgPSB1bmRlZmluZWQ7XHJcbiAgICAgIH1cclxuICAgIH1cclxuICAgIHRoaXMubW9kZWxDaGFuZ2UubmV4dCh2YWwpO1xyXG4gIH1cclxufVxyXG4iXX0=
103
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-select-list.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/multi-select-list/multi-select-list.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,iBAAiB,EACjB,SAAS,EACT,wBAAwB,EACxB,UAAU,EACV,UAAU,EACV,WAAW,EACX,KAAK,EACL,QAAQ,EAER,iBAAiB,EACpB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,8CAA8C,EAAC,MAAM,iEAAiE,CAAC;AAC/H,OAAO,EAAC,kBAAkB,EAAC,MAAM,8BAA8B,CAAC;AAChE,OAAO,EAAC,wBAAwB,EAAC,MAAM,mCAAmC,CAAC;AAC3E,OAAO,EAAC,uCAAuC,EAAC,MAAM,4DAA4D,CAAC;AACnH,OAAO,EAAC,oBAAoB,EAAC,MAAM,4CAA4C,CAAC;AAChF,OAAO,EAAC,aAAa,EAAC,MAAM,wBAAwB,CAAC;AACrD,OAAO,EAAC,cAAc,EAAC,MAAM,+BAA+B,CAAC;AAqC7D,MAAM,OAAO,wBAAyB,SAAQ,kBAAyB;IA0CnE,YACuB,aAA4B,EACrC,cAAiC,EACjC,cAA8B,EAC9B,wBAAkD,EAClD,sBAAgE,EAChE,aAAoC,EACvC,UAAuB;QAE9B,KAAK,CAAC,cAAc,EAAE,wBAAwB,EAAE,cAAc,EAAE,sBAAsB,EAAE,aAAa,EAAE,UAAU,CAAC,CAAC;QARhG,kBAAa,GAAb,aAAa,CAAe;QACrC,mBAAc,GAAd,cAAc,CAAmB;QACjC,mBAAc,GAAd,cAAc,CAAgB;QAC9B,6BAAwB,GAAxB,wBAAwB,CAA0B;QAClD,2BAAsB,GAAtB,sBAAsB,CAA0C;QAChE,kBAAa,GAAb,aAAa,CAAuB;QACvC,eAAU,GAAV,UAAU,CAAa;QA5ClC;;;WAGG;QAEI,WAAM,GAAW,EAAE,CAAC;QAkBpB,kBAAa,GAAY,IAAI,CAAC;QA2B9B,SAAI,GAAQ,SAAS,CAAC;QAHzB,KAAK,CAAC,aAAa,EAAE,CAAC;IAC1B,CAAC;IAvBD,IACW,YAAY,CAAC,KAAc;QAClC,IAAI,KAAK,EAAE;YACP,IAAI,CAAC,IAAI,GAAG,UAAU,CAAC;SAC1B;IACL,CAAC;IAGM,SAAS;QACZ,OAAO,IAAI,CAAC;IAChB,CAAC;IAiBM,iBAAiB,CAAC,GAAQ;QAC7B,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;YACpB,IAAI,GAAG,CAAC,MAAM,GAAG,CAAC,EAAE;gBAChB,GAAG,GAAG,SAAS,CAAC;aACnB;SACJ;QACD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC/B,CAAC;;;YAnGJ,SAAS,SAAC;gBACP,QAAQ,EAAE,sBAAsB;gBAChC,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;KAmBT;gBACD,SAAS,EAAE;oBACP,cAAc;oBACd,wBAAwB;oBACxB;wBACI,OAAO,EAAE,8CAA8C;wBACvD,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,wBAAwB,CAAC;qBAC1D,EAAE;wBACC,OAAO,EAAE,kBAAkB;wBAC3B,WAAW,EAAE,wBAAwB;qBACxC;iBACJ;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACxC;;;YArCO,aAAa,uBAiFZ,QAAQ;YAjGb,iBAAiB;YAiBb,cAAc;YAflB,wBAAwB;YAYpB,uCAAuC;YACvC,oBAAoB;YAZxB,UAAU;;;yBAqDT,KAAK;qBAOL,KAAK;0BAGL,KAAK;2BAGL,KAAK;6BAGL,KAAK;4BAGL,KAAK;6BAGL,KAAK;4BAGL,KAAK;2BAGL,KAAK;wBAOL,WAAW,SAAC,4BAA4B","sourcesContent":["import {\r\n    ChangeDetectorRef,\r\n    Component,\r\n    ComponentFactoryResolver,\r\n    ElementRef,\r\n    forwardRef,\r\n    HostBinding,\r\n    Input,\r\n    Optional,\r\n    TemplateRef,\r\n    ViewEncapsulation\r\n} from '@angular/core';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '../../interfaces/screen-config-adapter-component-interface-name';\r\nimport {BaseInputComponent} from '../base/base-input.component';\r\nimport {CheckBoxSelectionService} from '@syncfusion/ej2-angular-dropdowns';\r\nimport {FormInputUserModelChangeListenerService} from '../../core/service/form-input-user-change-listener.service';\r\nimport {NgZoneWrapperService} from '../../core/service/ng-zone-wrapper.service';\r\nimport {FormComponent} from '../form/form.component';\r\nimport {OverlayService} from '../../service/overlay.service';\r\n\r\n@Component({\r\n    selector: 'co-multi-select-list',\r\n    template: `\r\n        <ejs-multiselect\r\n                [dataSource]=\"collection\"\r\n                [placeholder]=\"placeholder\"\r\n                [value]=\"model\"\r\n                [mode]=\"mode\"\r\n                [fields]=\"fields\"\r\n                [readonly]=\"readonly\"\r\n                [itemTemplate]=\"itemTemplate\"\r\n                [headerTemplate]=\"headerTemplate\"\r\n                [valueTemplate]=\"valueTemplate\"\r\n                [footerTemplate]=\"footerTemplate\"\r\n                [selectAllText]=\"'Select All'\"\r\n                [showSelectAll]=showSelectAll\r\n                [ngModel]=\"model\"\r\n                (ngModelChange)=\"handleModelChange($event)\"\r\n                (valueChange)=\"handleModelChange($event)\"\r\n        ></ejs-multiselect>\r\n        <div class=\"required-indicator\"></div>\r\n    `,\r\n    providers: [\r\n        OverlayService,\r\n        CheckBoxSelectionService,\r\n        {\r\n            provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n            useExisting: forwardRef(() => MultiSelectListComponent)\r\n        }, {\r\n            provide: BaseInputComponent,\r\n            useExisting: MultiSelectListComponent\r\n        }\r\n    ],\r\n    encapsulation: ViewEncapsulation.None\r\n})\r\nexport class MultiSelectListComponent extends BaseInputComponent<any[]> {\r\n\r\n    @Input()\r\n    public collection: any[];\r\n\r\n    /**\r\n     * In the form { text: 'name', value: 'id' }\r\n     * Where 'text' is showing in the dropdown and 'id' used for the model binding\r\n     */\r\n    @Input()\r\n    public fields: Object = {};\r\n\r\n    @Input()\r\n    public placeholder: string;\r\n\r\n    @Input()\r\n    public itemTemplate: TemplateRef<any>;\r\n\r\n    @Input()\r\n    public headerTemplate: TemplateRef<any>;\r\n\r\n    @Input()\r\n    public valueTemplate: TemplateRef<any>;\r\n\r\n    @Input()\r\n    public footerTemplate: TemplateRef<any>;\r\n\r\n    @Input()\r\n    public showSelectAll: boolean = true;\r\n\r\n    @Input()\r\n    public set showCheckbox(value: boolean) {\r\n        if (value) {\r\n            this.mode = 'CheckBox';\r\n        }\r\n    }\r\n\r\n    @HostBinding('class.co-multi-select-list')\r\n    public showClass() {\r\n        return true;\r\n    }\r\n\r\n    constructor(\r\n        @Optional() public formComponent: FormComponent,\r\n        protected changeDetector: ChangeDetectorRef,\r\n        protected overlayService: OverlayService,\r\n        protected componentFactoryResolver: ComponentFactoryResolver,\r\n        protected formUserChangeListener?: FormInputUserModelChangeListenerService,\r\n        protected ngZoneWrapper?: NgZoneWrapperService,\r\n        public elementRef?: ElementRef,\r\n    ) {\r\n        super(changeDetector, componentFactoryResolver, overlayService, formUserChangeListener, ngZoneWrapper, elementRef);\r\n        super._markAsOnPush();\r\n    }\r\n\r\n    public mode: any = 'Default';\r\n\r\n    public handleModelChange(val: any): void {\r\n        if (Array.isArray(val)) {\r\n            if (val.length < 1) {\r\n                val = undefined;\r\n            }\r\n        }\r\n        this.modelChange.next(val);\r\n    }\r\n}\r\n"]}
@@ -1,4 +1,4 @@
1
- import { Component, HostBinding, Input, ViewEncapsulation } from "@angular/core";
1
+ import { Component, HostBinding, Input, ViewEncapsulation } from '@angular/core';
2
2
  import { CoreComponentsIcon } from "../../core/enum/core-components-icon.enum";
3
3
  import { IconCacheService } from "../icon/icon-cache.service";
4
4
  export class ValidationErrorComponent {
@@ -14,9 +14,11 @@ ValidationErrorComponent.decorators = [
14
14
  { type: Component, args: [{
15
15
  selector: "co-validation-error",
16
16
  template: `
17
- <div class="validation-error-content">
18
- <co-icon [iconData]="icons.getIcon(Icons.InformationRoundOpen)"></co-icon>
19
- <div class="validation-error-message" [textContent]="error"></div>
17
+ <div class="validation-error-wrapper" [overlay]="parentForOverlay">
18
+ <div class="validation-error-content">
19
+ <co-icon [iconData]="icons.getIcon(Icons.InformationRoundOpen)"></co-icon>
20
+ <div class="validation-error-message" [textContent]="error"></div>
21
+ </div>
20
22
  </div>
21
23
  `,
22
24
  animations: [],
@@ -28,8 +30,9 @@ ValidationErrorComponent.ctorParameters = () => [
28
30
  ];
29
31
  ValidationErrorComponent.propDecorators = {
30
32
  error: [{ type: Input }],
33
+ parentForOverlay: [{ type: Input }],
31
34
  top: [{ type: HostBinding, args: ['style.top.px',] }, { type: Input }],
32
35
  left: [{ type: HostBinding, args: ['style.left.px',] }, { type: Input }],
33
36
  showClass: [{ type: HostBinding, args: ['class.co-validation-error',] }]
34
37
  };
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi1lcnJvci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvdmFsaWRhdGlvbi1lcnJvci92YWxpZGF0aW9uLWVycm9yLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsaUJBQWlCLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDL0UsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sMkNBQTJDLENBQUM7QUFDN0UsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sNEJBQTRCLENBQUM7QUFlNUQsTUFBTSxPQUFPLHdCQUF3QjtJQW1CbkMsWUFBbUIsS0FBdUI7UUFBdkIsVUFBSyxHQUFMLEtBQUssQ0FBa0I7UUFsQjFCLFVBQUssR0FBUSxrQkFBa0IsQ0FBQztJQW1CaEQsQ0FBQztJQUxNLFNBQVM7UUFDZCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7OztZQTlCRixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLHFCQUFxQjtnQkFDL0IsUUFBUSxFQUFFOzs7OztHQUtUO2dCQUNELFVBQVUsRUFBRSxFQUVYO2dCQUNELGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2FBQ3RDOzs7WUFkTyxnQkFBZ0I7OztvQkFrQnJCLEtBQUs7a0JBR0wsV0FBVyxTQUFDLGNBQWMsY0FDMUIsS0FBSzttQkFHTCxXQUFXLFNBQUMsZUFBZSxjQUMzQixLQUFLO3dCQUdMLFdBQVcsU0FBQywyQkFBMkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgSG9zdEJpbmRpbmcsIElucHV0LCBWaWV3RW5jYXBzdWxhdGlvbn0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtDb3JlQ29tcG9uZW50c0ljb259IGZyb20gXCIuLi8uLi9jb3JlL2VudW0vY29yZS1jb21wb25lbnRzLWljb24uZW51bVwiO1xyXG5pbXBvcnQge0ljb25DYWNoZVNlcnZpY2V9IGZyb20gXCIuLi9pY29uL2ljb24tY2FjaGUuc2VydmljZVwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IFwiY28tdmFsaWRhdGlvbi1lcnJvclwiLFxyXG4gIHRlbXBsYXRlOiBgXHJcbiAgICA8ZGl2IGNsYXNzPVwidmFsaWRhdGlvbi1lcnJvci1jb250ZW50XCI+XHJcbiAgICAgIDxjby1pY29uIFtpY29uRGF0YV09XCJpY29ucy5nZXRJY29uKEljb25zLkluZm9ybWF0aW9uUm91bmRPcGVuKVwiPjwvY28taWNvbj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwidmFsaWRhdGlvbi1lcnJvci1tZXNzYWdlXCIgW3RleHRDb250ZW50XT1cImVycm9yXCI+PC9kaXY+XHJcbiAgICA8L2Rpdj5cclxuICBgLFxyXG4gIGFuaW1hdGlvbnM6IFtcclxuXHJcbiAgXSxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgVmFsaWRhdGlvbkVycm9yQ29tcG9uZW50IHtcclxuICBwdWJsaWMgcmVhZG9ubHkgSWNvbnM6IGFueSA9IENvcmVDb21wb25lbnRzSWNvbjtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgZXJyb3I6IHN0cmluZztcclxuXHJcbiAgQEhvc3RCaW5kaW5nKCdzdHlsZS50b3AucHgnKVxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHRvcDogbnVtYmVyO1xyXG5cclxuICBASG9zdEJpbmRpbmcoJ3N0eWxlLmxlZnQucHgnKVxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGxlZnQ6IG51bWJlcjtcclxuXHJcbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy5jby12YWxpZGF0aW9uLWVycm9yJylcclxuICBwdWJsaWMgc2hvd0NsYXNzKCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIHRydWU7XHJcbiAgfVxyXG5cclxuICBjb25zdHJ1Y3RvcihwdWJsaWMgaWNvbnM6IEljb25DYWNoZVNlcnZpY2UpIHtcclxuICB9XHJcblxyXG59XHJcbiJdfQ==
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi1lcnJvci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvdmFsaWRhdGlvbi1lcnJvci92YWxpZGF0aW9uLWVycm9yLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFjLFdBQVcsRUFBRSxLQUFLLEVBQUUsaUJBQWlCLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDM0YsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sMkNBQTJDLENBQUM7QUFDN0UsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sNEJBQTRCLENBQUM7QUFpQjVELE1BQU0sT0FBTyx3QkFBd0I7SUFzQm5DLFlBQW1CLEtBQXVCO1FBQXZCLFVBQUssR0FBTCxLQUFLLENBQWtCO1FBckIxQixVQUFLLEdBQVEsa0JBQWtCLENBQUM7SUFzQmhELENBQUM7SUFMTSxTQUFTO1FBQ2QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDOzs7WUFuQ0YsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxxQkFBcUI7Z0JBQy9CLFFBQVEsRUFBRTs7Ozs7OztHQU9UO2dCQUNELFVBQVUsRUFBRSxFQUVYO2dCQUNELGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2FBQ3RDOzs7WUFoQk8sZ0JBQWdCOzs7b0JBb0JyQixLQUFLOytCQUdMLEtBQUs7a0JBR0wsV0FBVyxTQUFDLGNBQWMsY0FDMUIsS0FBSzttQkFHTCxXQUFXLFNBQUMsZUFBZSxjQUMzQixLQUFLO3dCQUdMLFdBQVcsU0FBQywyQkFBMkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgRWxlbWVudFJlZiwgSG9zdEJpbmRpbmcsIElucHV0LCBWaWV3RW5jYXBzdWxhdGlvbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7Q29yZUNvbXBvbmVudHNJY29ufSBmcm9tIFwiLi4vLi4vY29yZS9lbnVtL2NvcmUtY29tcG9uZW50cy1pY29uLmVudW1cIjtcclxuaW1wb3J0IHtJY29uQ2FjaGVTZXJ2aWNlfSBmcm9tIFwiLi4vaWNvbi9pY29uLWNhY2hlLnNlcnZpY2VcIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiBcImNvLXZhbGlkYXRpb24tZXJyb3JcIixcclxuICB0ZW1wbGF0ZTogYFxyXG4gICAgPGRpdiBjbGFzcz1cInZhbGlkYXRpb24tZXJyb3Itd3JhcHBlclwiIFtvdmVybGF5XT1cInBhcmVudEZvck92ZXJsYXlcIj5cclxuICAgICAgPGRpdiBjbGFzcz1cInZhbGlkYXRpb24tZXJyb3ItY29udGVudFwiPlxyXG4gICAgICAgIDxjby1pY29uIFtpY29uRGF0YV09XCJpY29ucy5nZXRJY29uKEljb25zLkluZm9ybWF0aW9uUm91bmRPcGVuKVwiPjwvY28taWNvbj5cclxuICAgICAgICAgIDxkaXYgY2xhc3M9XCJ2YWxpZGF0aW9uLWVycm9yLW1lc3NhZ2VcIiBbdGV4dENvbnRlbnRdPVwiZXJyb3JcIj48L2Rpdj5cclxuICAgICAgPC9kaXY+XHJcbiAgICA8L2Rpdj5cclxuICBgLFxyXG4gIGFuaW1hdGlvbnM6IFtcclxuXHJcbiAgXSxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgVmFsaWRhdGlvbkVycm9yQ29tcG9uZW50IHtcclxuICBwdWJsaWMgcmVhZG9ubHkgSWNvbnM6IGFueSA9IENvcmVDb21wb25lbnRzSWNvbjtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgZXJyb3I6IHN0cmluZztcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgcGFyZW50Rm9yT3ZlcmxheTogRWxlbWVudFJlZjtcclxuXHJcbiAgQEhvc3RCaW5kaW5nKCdzdHlsZS50b3AucHgnKVxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHRvcDogbnVtYmVyO1xyXG5cclxuICBASG9zdEJpbmRpbmcoJ3N0eWxlLmxlZnQucHgnKVxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGxlZnQ6IG51bWJlcjtcclxuXHJcbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy5jby12YWxpZGF0aW9uLWVycm9yJylcclxuICBwdWJsaWMgc2hvd0NsYXNzKCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIHRydWU7XHJcbiAgfVxyXG5cclxuICBjb25zdHJ1Y3RvcihwdWJsaWMgaWNvbnM6IEljb25DYWNoZVNlcnZpY2UpIHtcclxuICB9XHJcblxyXG59XHJcbiJdfQ==
@@ -2,13 +2,15 @@ import { NgModule } from "@angular/core";
2
2
  import { CommonModule } from "@angular/common";
3
3
  import { ValidationErrorComponent } from "./validation-error.component";
4
4
  import { IconModule } from "../icon/icon.module";
5
+ import { OverlayModule } from '../../directives/overlay/overlay.module';
5
6
  export class ValidationErrorModule {
6
7
  }
7
8
  ValidationErrorModule.decorators = [
8
9
  { type: NgModule, args: [{
9
10
  imports: [
10
11
  CommonModule,
11
- IconModule
12
+ IconModule,
13
+ OverlayModule
12
14
  ],
13
15
  declarations: [
14
16
  ValidationErrorComponent
@@ -18,4 +20,4 @@ ValidationErrorModule.decorators = [
18
20
  ]
19
21
  },] }
20
22
  ];
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi1lcnJvci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvdmFsaWRhdGlvbi1lcnJvci92YWxpZGF0aW9uLWVycm9yLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQUN0RSxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFjL0MsTUFBTSxPQUFPLHFCQUFxQjs7O1lBWmpDLFFBQVEsU0FBQztnQkFDTixPQUFPLEVBQUU7b0JBQ1AsWUFBWTtvQkFDWixVQUFVO2lCQUNYO2dCQUNILFlBQVksRUFBRTtvQkFDWix3QkFBd0I7aUJBQ3pCO2dCQUNELE9BQU8sRUFBRTtvQkFDUCx3QkFBd0I7aUJBQ3pCO2FBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xyXG5pbXBvcnQge1ZhbGlkYXRpb25FcnJvckNvbXBvbmVudH0gZnJvbSBcIi4vdmFsaWRhdGlvbi1lcnJvci5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtJY29uTW9kdWxlfSBmcm9tIFwiLi4vaWNvbi9pY29uLm1vZHVsZVwiO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICAgIGltcG9ydHM6IFtcclxuICAgICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgICBJY29uTW9kdWxlXHJcbiAgICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgVmFsaWRhdGlvbkVycm9yQ29tcG9uZW50XHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBWYWxpZGF0aW9uRXJyb3JDb21wb25lbnRcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBWYWxpZGF0aW9uRXJyb3JNb2R1bGUge1xyXG5cclxufVxyXG4iXX0=
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi1lcnJvci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvdmFsaWRhdGlvbi1lcnJvci92YWxpZGF0aW9uLWVycm9yLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQUN0RSxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFDL0MsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHlDQUF5QyxDQUFDO0FBZXRFLE1BQU0sT0FBTyxxQkFBcUI7OztZQWJqQyxRQUFRLFNBQUM7Z0JBQ04sT0FBTyxFQUFFO29CQUNMLFlBQVk7b0JBQ1osVUFBVTtvQkFDVixhQUFhO2lCQUNoQjtnQkFDSCxZQUFZLEVBQUU7b0JBQ1osd0JBQXdCO2lCQUN6QjtnQkFDRCxPQUFPLEVBQUU7b0JBQ1Asd0JBQXdCO2lCQUN6QjthQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHtWYWxpZGF0aW9uRXJyb3JDb21wb25lbnR9IGZyb20gXCIuL3ZhbGlkYXRpb24tZXJyb3IuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7SWNvbk1vZHVsZX0gZnJvbSBcIi4uL2ljb24vaWNvbi5tb2R1bGVcIjtcclxuaW1wb3J0IHtPdmVybGF5TW9kdWxlfSBmcm9tICcuLi8uLi9kaXJlY3RpdmVzL292ZXJsYXkvb3ZlcmxheS5tb2R1bGUnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICAgIGltcG9ydHM6IFtcclxuICAgICAgICBDb21tb25Nb2R1bGUsXHJcbiAgICAgICAgSWNvbk1vZHVsZSxcclxuICAgICAgICBPdmVybGF5TW9kdWxlXHJcbiAgICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgVmFsaWRhdGlvbkVycm9yQ29tcG9uZW50XHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBWYWxpZGF0aW9uRXJyb3JDb21wb25lbnRcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBWYWxpZGF0aW9uRXJyb3JNb2R1bGUge1xyXG5cclxufVxyXG4iXX0=
@@ -1,48 +1,70 @@
1
- import { Directive, ElementRef, HostListener, Input } from '@angular/core';
1
+ import { Directive, ElementRef, Input } from '@angular/core';
2
2
  export class OverlayDirective {
3
3
  constructor(elementRef) {
4
4
  this.keepInView = false;
5
+ this.handleScroll = (event) => {
6
+ this._checkAndPlaceElement();
7
+ };
5
8
  this._elementRef = elementRef;
6
9
  }
7
10
  set parent(value) {
8
- if (value && value.elementRef) {
9
- this._parent = value.elementRef;
11
+ if (value) {
12
+ this._parent = value instanceof ElementRef ? value : value.elementRef;
10
13
  }
11
14
  else {
12
15
  if (this._parent) {
13
- this._observer.disconnect();
16
+ this._resizeObserver.disconnect();
14
17
  }
15
18
  }
16
19
  }
17
- handleScroll(event) {
18
- this._checkAndPlaceElement();
19
- }
20
20
  ngOnDestroy() {
21
- // document.removeEventListener("scroll", (event) => this._handleScroll(event), false);
22
- this._observer.disconnect();
21
+ document.removeEventListener("scroll", this.handleScroll, true);
22
+ this._intersectionObserver.disconnect();
23
+ this._resizeObserver.disconnect();
23
24
  this._elementRef = undefined;
24
25
  this._parent = undefined;
25
26
  }
26
27
  ngOnInit() {
27
- // document.addEventListener("scroll", (event) => this._handleScroll(event), false);
28
+ if (!this._elementRef || !this._elementRef.nativeElement) {
29
+ return;
30
+ }
31
+ document.addEventListener("scroll", this.handleScroll, true);
28
32
  this._checkAndPlaceElement();
29
- this._observer = new ResizeObserver((entries) => {
33
+ this._resizeObserver = new ResizeObserver((entries) => {
30
34
  this._checkAndPlaceElement();
31
35
  });
32
- this._observer.observe(document.body);
36
+ this._intersectionObserver = new IntersectionObserver((entries) => {
37
+ if (entries && entries.length > 0) {
38
+ if (entries[0].isIntersecting === false) {
39
+ this._elementRef.nativeElement.style.opacity = 0; // hide cause parent is not visible
40
+ }
41
+ else {
42
+ this._elementRef.nativeElement.style.opacity = 1;
43
+ }
44
+ }
45
+ }, {
46
+ root: null
47
+ });
48
+ this._intersectionObserver.observe(this._parent.nativeElement); // observe parent for visibility
49
+ this._resizeObserver.observe(document.body);
33
50
  }
34
51
  _checkAndPlaceElement() {
35
- const elementRect = this._elementRef.nativeElement.getBoundingClientRect();
36
- const parentRect = this._parent.nativeElement.getBoundingClientRect();
37
- this._placeElement(window.innerHeight, window.innerWidth, parentRect, elementRect);
52
+ if (this._elementRef && this._elementRef.nativeElement && this._parent && this._parent.nativeElement) {
53
+ const elementRect = this._elementRef.nativeElement.getBoundingClientRect();
54
+ const parentRect = this._parent.nativeElement.getBoundingClientRect();
55
+ this._placeElement(window.innerHeight, window.innerWidth, parentRect, elementRect);
56
+ }
38
57
  }
39
58
  _placeElement(bottom, right, parentRect, elementRect) {
40
59
  if (bottom < parentRect.bottom + elementRect.height) { // make sure it fits at the bottom
41
60
  this._elementRef.nativeElement.style.top = (parentRect.top - elementRect.height) + "px";
61
+ this._elementRef.nativeElement.classList.add('top');
42
62
  }
43
63
  else {
64
+ this._elementRef.nativeElement.classList.remove('top');
44
65
  this._elementRef.nativeElement.style.top = parentRect.bottom + "px";
45
66
  }
67
+ this._elementRef.nativeElement.style.left = parentRect.left + "px";
46
68
  if (this.keepInView) {
47
69
  if (elementRect.right > window.innerWidth) {
48
70
  //see if we can move it to the left
@@ -67,7 +89,6 @@ OverlayDirective.ctorParameters = () => [
67
89
  ];
68
90
  OverlayDirective.propDecorators = {
69
91
  parent: [{ type: Input, args: ["overlay",] }],
70
- keepInView: [{ type: Input }],
71
- handleScroll: [{ type: HostListener, args: ["document:scroll", ["$event"],] }]
92
+ keepInView: [{ type: Input }]
72
93
  };
73
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3ZlcmxheS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlY29tcG9uZW50cy9zcmMvbGliL2RpcmVjdGl2ZXMvb3ZlcmxheS9vdmVybGF5LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFVBQVUsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFvQixNQUFNLGVBQWUsQ0FBQztBQUs1RixNQUFNLE9BQU8sZ0JBQWdCO0lBeUIzQixZQUNJLFVBQXNCO1FBWm5CLGVBQVUsR0FBWSxLQUFLLENBQUM7UUFjakMsSUFBSSxDQUFDLFdBQVcsR0FBRyxVQUFVLENBQUM7SUFDaEMsQ0FBQztJQTNCRCxJQUNXLE1BQU0sQ0FBQyxLQUE2QjtRQUM3QyxJQUFJLEtBQUssSUFBSSxLQUFLLENBQUMsVUFBVSxFQUFFO1lBQzdCLElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDLFVBQVUsQ0FBQztTQUNqQzthQUFNO1lBQ0wsSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFO2dCQUNoQixJQUFJLENBQUMsU0FBUyxDQUFDLFVBQVUsRUFBRSxDQUFDO2FBQzdCO1NBQ0Y7SUFDSCxDQUFDO0lBTU0sWUFBWSxDQUFDLEtBQWlCO1FBQ25DLElBQUksQ0FBQyxxQkFBcUIsRUFBRSxDQUFDO0lBQy9CLENBQUM7SUFZTSxXQUFXO1FBQ2hCLHVGQUF1RjtRQUN2RixJQUFJLENBQUMsU0FBUyxDQUFDLFVBQVUsRUFBRSxDQUFDO1FBQzVCLElBQUksQ0FBQyxXQUFXLEdBQUcsU0FBUyxDQUFDO1FBQzdCLElBQUksQ0FBQyxPQUFPLEdBQUcsU0FBUyxDQUFDO0lBQzNCLENBQUM7SUFFRCxRQUFRO1FBQ04sb0ZBQW9GO1FBQ3BGLElBQUksQ0FBQyxxQkFBcUIsRUFBRSxDQUFDO1FBQzdCLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxjQUFjLENBQy9CLENBQUMsT0FBTyxFQUFFLEVBQUU7WUFDVixJQUFJLENBQUMscUJBQXFCLEVBQUUsQ0FBQztRQUMvQixDQUFDLENBQ0osQ0FBQztRQUNGLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN4QyxDQUFDO0lBRU8scUJBQXFCO1FBQzNCLE1BQU0sV0FBVyxHQUFlLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLHFCQUFxQixFQUFFLENBQUM7UUFDdkYsTUFBTSxVQUFVLEdBQWUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMscUJBQXFCLEVBQUUsQ0FBQztRQUNsRixJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxXQUFXLEVBQUUsTUFBTSxDQUFDLFVBQVUsRUFBRSxVQUFVLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDckYsQ0FBQztJQUVPLGFBQWEsQ0FBQyxNQUFjLEVBQUUsS0FBYSxFQUFFLFVBQXNCLEVBQUUsV0FBdUI7UUFDbEcsSUFBSSxNQUFNLEdBQUcsVUFBVSxDQUFDLE1BQU0sR0FBRyxXQUFXLENBQUMsTUFBTSxFQUFFLEVBQUUsa0NBQWtDO1lBQ3ZGLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxHQUFHLEdBQUcsQ0FBQyxVQUFVLENBQUMsR0FBRyxHQUFHLFdBQVcsQ0FBQyxNQUFNLENBQUMsR0FBRyxJQUFJLENBQUM7U0FDekY7YUFBTTtZQUNMLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxHQUFHLEdBQUcsVUFBVSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUM7U0FDckU7UUFDRCxJQUFJLElBQUksQ0FBQyxVQUFVLEVBQUU7WUFDbkIsSUFBSSxXQUFXLENBQUMsS0FBSyxHQUFHLE1BQU0sQ0FBQyxVQUFVLEVBQUU7Z0JBQ3pDLG1DQUFtQztnQkFDbkMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLEdBQUcsV0FBVyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsRUFBRTtvQkFDL0MsSUFBSSxDQUFDLFdBQVcsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLElBQUksR0FBRyxDQUFDLE1BQU0sQ0FBQyxVQUFVLEdBQUcsV0FBVyxDQUFDLEtBQUssQ0FBQyxHQUFHLElBQUksQ0FBQztpQkFDNUY7cUJBQU0sRUFBRSw2QkFBNkI7b0JBQ3BDLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxLQUFLLEdBQUcsTUFBTSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUM7b0JBQ3RFLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDO2lCQUMvQzthQUNGO1NBQ0Y7SUFDSCxDQUFDOzs7WUEzRUYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxXQUFXO2FBQ3RCOzs7WUFKa0IsVUFBVTs7O3FCQU8xQixLQUFLLFNBQUMsU0FBUzt5QkFXZixLQUFLOzJCQUdMLFlBQVksU0FBQyxpQkFBaUIsRUFBRSxDQUFDLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RGlyZWN0aXZlLCBFbGVtZW50UmVmLCBIb3N0TGlzdGVuZXIsIElucHV0LCBPbkRlc3Ryb3ksIE9uSW5pdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7T3ZlcmxheVBhcmVudERpcmVjdGl2ZX0gZnJvbSBcIi4vb3ZlcmxheS1wYXJlbnQuZGlyZWN0aXZlXCI7XHJcbkBEaXJlY3RpdmUoe1xyXG4gIHNlbGVjdG9yOiBcIltvdmVybGF5XVwiXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBPdmVybGF5RGlyZWN0aXZlIGltcGxlbWVudHMgT25EZXN0cm95LCBPbkluaXQge1xyXG5cclxuICBASW5wdXQoXCJvdmVybGF5XCIpXHJcbiAgcHVibGljIHNldCBwYXJlbnQodmFsdWU6IE92ZXJsYXlQYXJlbnREaXJlY3RpdmUpIHtcclxuICAgIGlmICh2YWx1ZSAmJiB2YWx1ZS5lbGVtZW50UmVmKSB7XHJcbiAgICAgIHRoaXMuX3BhcmVudCA9IHZhbHVlLmVsZW1lbnRSZWY7XHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICBpZiAodGhpcy5fcGFyZW50KSB7XHJcbiAgICAgICAgdGhpcy5fb2JzZXJ2ZXIuZGlzY29ubmVjdCgpO1xyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBrZWVwSW5WaWV3OiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIEBIb3N0TGlzdGVuZXIoXCJkb2N1bWVudDpzY3JvbGxcIiwgW1wiJGV2ZW50XCJdKVxyXG4gIHB1YmxpYyBoYW5kbGVTY3JvbGwoZXZlbnQ6IE1vdXNlRXZlbnQpOiB2b2lkIHtcclxuICAgIHRoaXMuX2NoZWNrQW5kUGxhY2VFbGVtZW50KCk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIF9lbGVtZW50UmVmOiBFbGVtZW50UmVmO1xyXG4gIHByaXZhdGUgX29ic2VydmVyOiBSZXNpemVPYnNlcnZlcjtcclxuICBwcml2YXRlIF9wYXJlbnQ6IEVsZW1lbnRSZWY7XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgICBlbGVtZW50UmVmOiBFbGVtZW50UmVmXHJcbiAgKSB7XHJcbiAgICB0aGlzLl9lbGVtZW50UmVmID0gZWxlbWVudFJlZjtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBuZ09uRGVzdHJveSgpOiB2b2lkIHtcclxuICAgIC8vIGRvY3VtZW50LnJlbW92ZUV2ZW50TGlzdGVuZXIoXCJzY3JvbGxcIiwgKGV2ZW50KSA9PiB0aGlzLl9oYW5kbGVTY3JvbGwoZXZlbnQpLCBmYWxzZSk7XHJcbiAgICB0aGlzLl9vYnNlcnZlci5kaXNjb25uZWN0KCk7XHJcbiAgICB0aGlzLl9lbGVtZW50UmVmID0gdW5kZWZpbmVkO1xyXG4gICAgdGhpcy5fcGFyZW50ID0gdW5kZWZpbmVkO1xyXG4gIH1cclxuXHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICAvLyBkb2N1bWVudC5hZGRFdmVudExpc3RlbmVyKFwic2Nyb2xsXCIsIChldmVudCkgPT4gdGhpcy5faGFuZGxlU2Nyb2xsKGV2ZW50KSwgZmFsc2UpO1xyXG4gICAgdGhpcy5fY2hlY2tBbmRQbGFjZUVsZW1lbnQoKTtcclxuICAgIHRoaXMuX29ic2VydmVyID0gbmV3IFJlc2l6ZU9ic2VydmVyKFxyXG4gICAgICAgIChlbnRyaWVzKSA9PiB7XHJcbiAgICAgICAgICB0aGlzLl9jaGVja0FuZFBsYWNlRWxlbWVudCgpO1xyXG4gICAgICAgIH1cclxuICAgICk7XHJcbiAgICB0aGlzLl9vYnNlcnZlci5vYnNlcnZlKGRvY3VtZW50LmJvZHkpO1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBfY2hlY2tBbmRQbGFjZUVsZW1lbnQoKTogdm9pZCB7XHJcbiAgICBjb25zdCBlbGVtZW50UmVjdDogQ2xpZW50UmVjdCA9IHRoaXMuX2VsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtcclxuICAgIGNvbnN0IHBhcmVudFJlY3Q6IENsaWVudFJlY3QgPSB0aGlzLl9wYXJlbnQubmF0aXZlRWxlbWVudC5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtcclxuICAgIHRoaXMuX3BsYWNlRWxlbWVudCh3aW5kb3cuaW5uZXJIZWlnaHQsIHdpbmRvdy5pbm5lcldpZHRoLCBwYXJlbnRSZWN0LCBlbGVtZW50UmVjdCk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIF9wbGFjZUVsZW1lbnQoYm90dG9tOiBudW1iZXIsIHJpZ2h0OiBudW1iZXIsIHBhcmVudFJlY3Q6IENsaWVudFJlY3QsIGVsZW1lbnRSZWN0OiBDbGllbnRSZWN0KTogdm9pZCB7XHJcbiAgICBpZiAoYm90dG9tIDwgcGFyZW50UmVjdC5ib3R0b20gKyBlbGVtZW50UmVjdC5oZWlnaHQpIHsgLy8gbWFrZSBzdXJlIGl0IGZpdHMgYXQgdGhlIGJvdHRvbVxyXG4gICAgICB0aGlzLl9lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuc3R5bGUudG9wID0gKHBhcmVudFJlY3QudG9wIC0gZWxlbWVudFJlY3QuaGVpZ2h0KSArIFwicHhcIjtcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIHRoaXMuX2VsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5zdHlsZS50b3AgPSBwYXJlbnRSZWN0LmJvdHRvbSArIFwicHhcIjtcclxuICAgIH1cclxuICAgIGlmICh0aGlzLmtlZXBJblZpZXcpIHtcclxuICAgICAgaWYgKGVsZW1lbnRSZWN0LnJpZ2h0ID4gd2luZG93LmlubmVyV2lkdGgpIHtcclxuICAgICAgICAvL3NlZSBpZiB3ZSBjYW4gbW92ZSBpdCB0byB0aGUgbGVmdFxyXG4gICAgICAgIGlmICgod2luZG93LmlubmVyV2lkdGggLSBlbGVtZW50UmVjdC53aWR0aCkgPiAwKSB7XHJcbiAgICAgICAgICB0aGlzLl9lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuc3R5bGUubGVmdCA9ICh3aW5kb3cuaW5uZXJXaWR0aCAtIGVsZW1lbnRSZWN0LndpZHRoKSArIFwicHhcIjtcclxuICAgICAgICB9IGVsc2UgeyAvL3Jlc2l6ZSBzbyBpdCBmaXRzIGludG8gdmlld1xyXG4gICAgICAgICAgdGhpcy5fZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LnN0eWxlLndpZHRoID0gd2luZG93LmlubmVyV2lkdGggKyBcInB4XCI7XHJcbiAgICAgICAgICB0aGlzLl9lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuc3R5bGUubGVmdCA9IDA7XHJcbiAgICAgICAgfVxyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
94
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.directive.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/directives/overlay/overlay.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,UAAU,EAAgB,KAAK,EAAoB,MAAM,eAAe,CAAC;AAK5F,MAAM,OAAO,gBAAgB;IAqB3B,YACI,UAAsB;QARnB,eAAU,GAAY,KAAK,CAAC;QAiD5B,iBAAY,GAAG,CAAC,KAAY,EAAE,EAAE;YACrC,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC/B,CAAC,CAAA;QAzCC,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC;IAChC,CAAC;IAvBD,IACW,MAAM,CAAC,KAA0C;QAC1D,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,OAAO,GAAG,KAAK,YAAY,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC;SACvE;aAAM;YACL,IAAI,IAAI,CAAC,OAAO,EAAE;gBAChB,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,CAAC;aACnC;SACF;IACH,CAAC;IAgBM,WAAW;QAChB,QAAQ,CAAC,mBAAmB,CAAC,QAAQ,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;QAChE,IAAI,CAAC,qBAAqB,CAAC,UAAU,EAAE,CAAC;QACxC,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,CAAC;QAClC,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC;QAC7B,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;IAC3B,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE;YACxD,OAAO;SACR;QACD,QAAQ,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;QAC7D,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC7B,IAAI,CAAC,eAAe,GAAG,IAAI,cAAc,CACrC,CAAC,OAAO,EAAE,EAAE;YACV,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC/B,CAAC,CACJ,CAAC;QACF,IAAI,CAAC,qBAAqB,GAAG,IAAI,oBAAoB,CACjD,CAAC,OAAoC,EAAE,EAAE;YACvC,IAAI,OAAO,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;gBACjC,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC,cAAc,KAAK,KAAK,EAAE;oBACvC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,mCAAmC;iBACtF;qBAAM;oBACL,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,CAAC;iBAClD;aACF;QACH,CAAC,EAAE;YACD,IAAI,EAAE,IAAI;SACX,CACJ,CAAC;QACF,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC,gCAAgC;QAChG,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IAC9C,CAAC;IAMO,qBAAqB;QAC3B,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC,aAAa,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE;YACpG,MAAM,WAAW,GAAe,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;YACvF,MAAM,UAAU,GAAe,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;YAClF,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,UAAU,EAAE,UAAU,EAAE,WAAW,CAAC,CAAC;SACpF;IACH,CAAC;IAEO,aAAa,CAAC,MAAc,EAAE,KAAa,EAAE,UAAsB,EAAE,WAAuB;QAClG,IAAI,MAAM,GAAG,UAAU,CAAC,MAAM,GAAG,WAAW,CAAC,MAAM,EAAE,EAAE,kCAAkC;YACvF,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,UAAU,CAAC,GAAG,GAAG,WAAW,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC;YACxF,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;SACrD;aAAM;YACL,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACvD,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,GAAG,GAAG,UAAU,CAAC,MAAM,GAAG,IAAI,CAAC;SACrE;QACD,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,GAAG,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC;QACnE,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,IAAI,WAAW,CAAC,KAAK,GAAG,MAAM,CAAC,UAAU,EAAE;gBACzC,mCAAmC;gBACnC,IAAI,CAAC,MAAM,CAAC,UAAU,GAAG,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE;oBAC/C,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,MAAM,CAAC,UAAU,GAAG,WAAW,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC;iBAC5F;qBAAM,EAAE,6BAA6B;oBACpC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,GAAG,MAAM,CAAC,UAAU,GAAG,IAAI,CAAC;oBACtE,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,CAAC;iBAC/C;aACF;SACF;IACH,CAAC;;;YAlGF,SAAS,SAAC;gBACT,QAAQ,EAAE,WAAW;aACtB;;;YAJkB,UAAU;;;qBAO1B,KAAK,SAAC,SAAS;yBAWf,KAAK","sourcesContent":["import {Directive, ElementRef, HostListener, Input, OnDestroy, OnInit} from '@angular/core';\r\nimport {OverlayParentDirective} from \"./overlay-parent.directive\";\r\n@Directive({\r\n  selector: \"[overlay]\"\r\n})\r\nexport class OverlayDirective implements OnDestroy, OnInit {\r\n\r\n  @Input(\"overlay\")\r\n  public set parent(value: OverlayParentDirective | ElementRef) {\r\n    if (value) {\r\n      this._parent = value instanceof ElementRef ? value : value.elementRef;\r\n    } else {\r\n      if (this._parent) {\r\n        this._resizeObserver.disconnect();\r\n      }\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public keepInView: boolean = false;\r\n\r\n  private _elementRef: ElementRef;\r\n  private _resizeObserver: ResizeObserver;\r\n  private _intersectionObserver: IntersectionObserver;\r\n  private _parent: ElementRef;\r\n\r\n  constructor(\r\n      elementRef: ElementRef\r\n  ) {\r\n    this._elementRef = elementRef;\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    document.removeEventListener(\"scroll\", this.handleScroll, true);\r\n    this._intersectionObserver.disconnect();\r\n    this._resizeObserver.disconnect();\r\n    this._elementRef = undefined;\r\n    this._parent = undefined;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (!this._elementRef || !this._elementRef.nativeElement) {\r\n      return;\r\n    }\r\n    document.addEventListener(\"scroll\", this.handleScroll, true);\r\n    this._checkAndPlaceElement();\r\n    this._resizeObserver = new ResizeObserver(\r\n        (entries) => {\r\n          this._checkAndPlaceElement();\r\n        }\r\n    );\r\n    this._intersectionObserver = new IntersectionObserver(\r\n        (entries: IntersectionObserverEntry[]) => {\r\n          if (entries && entries.length > 0) {\r\n            if (entries[0].isIntersecting === false) {\r\n              this._elementRef.nativeElement.style.opacity = 0; // hide cause parent is not visible\r\n            } else {\r\n              this._elementRef.nativeElement.style.opacity = 1;\r\n            }\r\n          }\r\n        }, {\r\n          root: null\r\n        }\r\n    );\r\n    this._intersectionObserver.observe(this._parent.nativeElement); // observe parent for visibility\r\n    this._resizeObserver.observe(document.body);\r\n  }\r\n\r\n  public handleScroll = (event: Event) => {\r\n    this._checkAndPlaceElement();\r\n  }\r\n\r\n  private _checkAndPlaceElement(): void {\r\n    if (this._elementRef && this._elementRef.nativeElement && this._parent && this._parent.nativeElement) {\r\n      const elementRect: ClientRect = this._elementRef.nativeElement.getBoundingClientRect();\r\n      const parentRect: ClientRect = this._parent.nativeElement.getBoundingClientRect();\r\n      this._placeElement(window.innerHeight, window.innerWidth, parentRect, elementRect);\r\n    }\r\n  }\r\n\r\n  private _placeElement(bottom: number, right: number, parentRect: ClientRect, elementRect: ClientRect): void {\r\n    if (bottom < parentRect.bottom + elementRect.height) { // make sure it fits at the bottom\r\n      this._elementRef.nativeElement.style.top = (parentRect.top - elementRect.height) + \"px\";\r\n      this._elementRef.nativeElement.classList.add('top');\r\n    } else {\r\n      this._elementRef.nativeElement.classList.remove('top');\r\n      this._elementRef.nativeElement.style.top = parentRect.bottom + \"px\";\r\n    }\r\n    this._elementRef.nativeElement.style.left = parentRect.left + \"px\";\r\n    if (this.keepInView) {\r\n      if (elementRect.right > window.innerWidth) {\r\n        //see if we can move it to the left\r\n        if ((window.innerWidth - elementRect.width) > 0) {\r\n          this._elementRef.nativeElement.style.left = (window.innerWidth - elementRect.width) + \"px\";\r\n        } else { //resize so it fits into view\r\n          this._elementRef.nativeElement.style.width = window.innerWidth + \"px\";\r\n          this._elementRef.nativeElement.style.left = 0;\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,44 @@
1
+ import { ApplicationRef, ComponentFactoryResolver, Injectable, Injector } from '@angular/core';
2
+ export class OverlayService {
3
+ constructor(_componentFactoryResolver, _appRef, _injector) {
4
+ this._componentFactoryResolver = _componentFactoryResolver;
5
+ this._appRef = _appRef;
6
+ this._injector = _injector;
7
+ }
8
+ createComponent(compClass, inputs) {
9
+ if (this._componentRef) {
10
+ this.removeComponent();
11
+ }
12
+ this._componentRef = this._componentFactoryResolver
13
+ .resolveComponentFactory(compClass)
14
+ .create(this._injector);
15
+ if (inputs) {
16
+ for (let property in inputs) {
17
+ if (inputs.hasOwnProperty(property)) {
18
+ this._componentRef.instance[property] = inputs[property];
19
+ }
20
+ }
21
+ }
22
+ this._appRef.attachView(this._componentRef.hostView);
23
+ const domElem = this._componentRef.hostView
24
+ .rootNodes[0];
25
+ document.body.appendChild(domElem);
26
+ this._componentRef.onDestroy(() => {
27
+ this._appRef.detachView(this._componentRef.hostView);
28
+ });
29
+ }
30
+ removeComponent() {
31
+ if (this._componentRef) {
32
+ this._componentRef.destroy();
33
+ }
34
+ }
35
+ }
36
+ OverlayService.decorators = [
37
+ { type: Injectable }
38
+ ];
39
+ OverlayService.ctorParameters = () => [
40
+ { type: ComponentFactoryResolver },
41
+ { type: ApplicationRef },
42
+ { type: Injector }
43
+ ];
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3ZlcmxheS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9zZXJ2aWNlL292ZXJsYXkuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsY0FBYyxFQUFFLHdCQUF3QixFQUFpQyxVQUFVLEVBQUUsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRzVILE1BQU0sT0FBTyxjQUFjO0lBSXZCLFlBQ1kseUJBQW1ELEVBQ25ELE9BQXVCLEVBQ3ZCLFNBQW1CO1FBRm5CLDhCQUF5QixHQUF6Qix5QkFBeUIsQ0FBMEI7UUFDbkQsWUFBTyxHQUFQLE9BQU8sQ0FBZ0I7UUFDdkIsY0FBUyxHQUFULFNBQVMsQ0FBVTtJQUUvQixDQUFDO0lBRU0sZUFBZSxDQUFDLFNBQWMsRUFBRSxNQUFXO1FBQ2hELElBQUksSUFBSSxDQUFDLGFBQWEsRUFBRTtZQUN0QixJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7U0FDeEI7UUFDQyxJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQyx5QkFBeUI7YUFDOUMsdUJBQXVCLENBQUMsU0FBUyxDQUFDO2FBQ2xDLE1BQU0sQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7UUFFNUIsSUFBSSxNQUFNLEVBQUU7WUFDUixLQUFLLElBQUksUUFBUSxJQUFJLE1BQU0sRUFBRTtnQkFDekIsSUFBSSxNQUFNLENBQUMsY0FBYyxDQUFDLFFBQVEsQ0FBQyxFQUFFO29CQUNqQyxJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7aUJBQzVEO2FBQ0o7U0FDSjtRQUNELElBQUksQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLENBQUM7UUFFckQsTUFBTSxPQUFPLEdBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQyxRQUFpQzthQUNoRSxTQUFTLENBQUMsQ0FBQyxDQUFnQixDQUFDO1FBRWpDLFFBQVEsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ25DLElBQUksQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtZQUM5QixJQUFJLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQ3pELENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVNLGVBQWU7UUFDbEIsSUFBSSxJQUFJLENBQUMsYUFBYSxFQUFFO1lBQ3BCLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxFQUFFLENBQUM7U0FDaEM7SUFDTCxDQUFDOzs7WUExQ0osVUFBVTs7O1lBRmEsd0JBQXdCO1lBQXhDLGNBQWM7WUFBdUUsUUFBUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QXBwbGljYXRpb25SZWYsIENvbXBvbmVudEZhY3RvcnlSZXNvbHZlciwgQ29tcG9uZW50UmVmLCBFbWJlZGRlZFZpZXdSZWYsIEluamVjdGFibGUsIEluamVjdG9yfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIE92ZXJsYXlTZXJ2aWNlIHtcclxuXHJcbiAgICBwcml2YXRlIF9jb21wb25lbnRSZWY6IENvbXBvbmVudFJlZjxhbnk+O1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKFxyXG4gICAgICAgIHByaXZhdGUgX2NvbXBvbmVudEZhY3RvcnlSZXNvbHZlcjogQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyLFxyXG4gICAgICAgIHByaXZhdGUgX2FwcFJlZjogQXBwbGljYXRpb25SZWYsXHJcbiAgICAgICAgcHJpdmF0ZSBfaW5qZWN0b3I6IEluamVjdG9yXHJcbiAgICApIHtcclxuICAgIH1cclxuXHJcbiAgICBwdWJsaWMgY3JlYXRlQ29tcG9uZW50KGNvbXBDbGFzczogYW55LCBpbnB1dHM6IGFueSk6IHZvaWQge1xyXG4gICAgICBpZiAodGhpcy5fY29tcG9uZW50UmVmKSB7XHJcbiAgICAgICAgdGhpcy5yZW1vdmVDb21wb25lbnQoKTtcclxuICAgICAgfVxyXG4gICAgICAgIHRoaXMuX2NvbXBvbmVudFJlZiA9IHRoaXMuX2NvbXBvbmVudEZhY3RvcnlSZXNvbHZlclxyXG4gICAgICAgICAgICAucmVzb2x2ZUNvbXBvbmVudEZhY3RvcnkoY29tcENsYXNzKVxyXG4gICAgICAgICAgICAuY3JlYXRlKHRoaXMuX2luamVjdG9yKTtcclxuXHJcbiAgICAgICAgaWYgKGlucHV0cykge1xyXG4gICAgICAgICAgICBmb3IgKGxldCBwcm9wZXJ0eSBpbiBpbnB1dHMpIHtcclxuICAgICAgICAgICAgICAgIGlmIChpbnB1dHMuaGFzT3duUHJvcGVydHkocHJvcGVydHkpKSB7XHJcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5fY29tcG9uZW50UmVmLmluc3RhbmNlW3Byb3BlcnR5XSA9IGlucHV0c1twcm9wZXJ0eV07XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9XHJcbiAgICAgICAgdGhpcy5fYXBwUmVmLmF0dGFjaFZpZXcodGhpcy5fY29tcG9uZW50UmVmLmhvc3RWaWV3KTtcclxuXHJcbiAgICAgICAgY29uc3QgZG9tRWxlbSA9ICh0aGlzLl9jb21wb25lbnRSZWYuaG9zdFZpZXcgYXMgRW1iZWRkZWRWaWV3UmVmPGFueT4pXHJcbiAgICAgICAgICAgIC5yb290Tm9kZXNbMF0gYXMgSFRNTEVsZW1lbnQ7XHJcblxyXG4gICAgICAgIGRvY3VtZW50LmJvZHkuYXBwZW5kQ2hpbGQoZG9tRWxlbSk7XHJcbiAgICAgICAgdGhpcy5fY29tcG9uZW50UmVmLm9uRGVzdHJveSgoKSA9PiB7XHJcbiAgICAgICAgICAgIHRoaXMuX2FwcFJlZi5kZXRhY2hWaWV3KHRoaXMuX2NvbXBvbmVudFJlZi5ob3N0Vmlldyk7XHJcbiAgICAgICAgfSk7XHJcbiAgICB9XHJcblxyXG4gICAgcHVibGljIHJlbW92ZUNvbXBvbmVudCgpOiB2b2lkIHtcclxuICAgICAgICBpZiAodGhpcy5fY29tcG9uZW50UmVmKSB7XHJcbiAgICAgICAgICAgIHRoaXMuX2NvbXBvbmVudFJlZi5kZXN0cm95KCk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG59XHJcbiJdfQ==