@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.
- package/bundles/colijnit-corecomponents_v12.umd.js +428 -299
- package/bundles/colijnit-corecomponents_v12.umd.js.map +1 -1
- package/colijnit-corecomponents_v12.d.ts +13 -13
- package/colijnit-corecomponents_v12.metadata.json +1 -1
- package/esm2015/colijnit-corecomponents_v12.js +14 -14
- package/esm2015/lib/components/base/base-input.component.js +37 -30
- package/esm2015/lib/components/drop-down-list/drop-down-list.component.js +37 -34
- package/esm2015/lib/components/input-checkbox/input-checkbox.component.js +25 -20
- package/esm2015/lib/components/input-checkbox-multi-select/input-checkbox-multi-select.component.js +28 -23
- package/esm2015/lib/components/input-combo-box/input-combo-box.component.js +38 -34
- package/esm2015/lib/components/input-date-picker/input-date-picker.component.js +41 -37
- package/esm2015/lib/components/input-date-picker/input-date-picker.module.js +6 -2
- package/esm2015/lib/components/input-date-range-picker/input-date-range-picker.component.js +28 -25
- package/esm2015/lib/components/input-date-range-picker/input-date-range-picker.module.js +6 -2
- package/esm2015/lib/components/input-listbox/input-listbox.component.js +30 -26
- package/esm2015/lib/components/input-number-picker/input-number-picker.component.js +45 -40
- package/esm2015/lib/components/input-radio-button/input-radio-button.component.js +29 -24
- package/esm2015/lib/components/input-search/input-search.component.js +5 -1
- package/esm2015/lib/components/input-text/input-text.component.js +50 -44
- package/esm2015/lib/components/input-text/input-text.module.js +4 -2
- package/esm2015/lib/components/input-textarea/input-textarea.component.js +38 -34
- package/esm2015/lib/components/multi-select-list/multi-select-list.component.js +37 -34
- package/esm2015/lib/components/validation-error/validation-error.component.js +8 -5
- package/esm2015/lib/components/validation-error/validation-error.module.js +4 -2
- package/esm2015/lib/directives/overlay/overlay.directive.js +39 -18
- package/esm2015/lib/service/overlay.service.js +44 -0
- package/esm2015/public-api.js +3 -2
- package/fesm2015/colijnit-corecomponents_v12.js +587 -466
- package/fesm2015/colijnit-corecomponents_v12.js.map +1 -1
- package/lib/components/base/base-input.component.d.ts +4 -3
- package/lib/components/drop-down-list/drop-down-list.component.d.ts +8 -6
- package/lib/components/input-checkbox/input-checkbox.component.d.ts +9 -7
- package/lib/components/input-checkbox-multi-select/input-checkbox-multi-select.component.d.ts +8 -6
- package/lib/components/input-combo-box/input-combo-box.component.d.ts +9 -7
- package/lib/components/input-date-picker/input-date-picker.component.d.ts +11 -9
- package/lib/components/input-date-range-picker/input-date-range-picker.component.d.ts +1 -1
- package/lib/components/input-listbox/input-listbox.component.d.ts +9 -7
- package/lib/components/input-number-picker/input-number-picker.component.d.ts +12 -10
- package/lib/components/input-radio-button/input-radio-button.component.d.ts +7 -5
- package/lib/components/input-text/input-text.component.d.ts +9 -7
- package/lib/components/input-text/style/_layout.scss +1 -1
- package/lib/components/input-textarea/input-textarea.component.d.ts +8 -6
- package/lib/components/multi-select-list/multi-select-list.component.d.ts +8 -6
- package/lib/components/validation-error/style/_layout.scss +40 -30
- package/lib/components/validation-error/style/_theme.scss +23 -9
- package/lib/components/validation-error/validation-error.component.d.ts +2 -0
- package/lib/directives/overlay/overlay.directive.d.ts +4 -3
- package/lib/service/overlay.service.d.ts +10 -0
- package/package.json +1 -1
- 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,
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtdGV4dC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvaW5wdXQtdGV4dC9pbnB1dC10ZXh0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDM0MsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDMUQsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBQy9DLE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUMvQyxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNoRSxPQUFPLEVBQUMsb0JBQW9CLEVBQUUsZ0JBQWdCLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN0RixPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSw2Q0FBNkMsQ0FBQztBQUNsRixPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSw4Q0FBOEMsQ0FBQztBQUNqRixPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0seUNBQXlDLENBQUM7QUFzQnRFLE1BQU0sT0FBTyxlQUFlOzs7WUFwQjNCLFFBQVEsU0FBQztnQkFDTixPQUFPLEVBQUU7b0JBQ0wsVUFBVTtvQkFDVixZQUFZO29CQUNaLFdBQVc7b0JBQ1gsVUFBVTtvQkFDVixnQkFBZ0I7b0JBQ2hCLGdCQUFnQjtvQkFDaEIsb0JBQW9CO29CQUNwQixxQkFBcUI7b0JBQ3JCLG1CQUFtQjtvQkFDbkIsYUFBYTtpQkFDaEI7Z0JBQ0gsWUFBWSxFQUFFO29CQUNaLGtCQUFrQjtpQkFDbkI7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLGtCQUFrQjtpQkFDbkI7YUFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XHJcbmltcG9ydCB7Rm9ybXNNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xyXG5pbXBvcnQge0lucHV0VGV4dENvbXBvbmVudH0gZnJvbSBcIi4vaW5wdXQtdGV4dC5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtJY29uTW9kdWxlfSBmcm9tIFwiLi4vaWNvbi9pY29uLm1vZHVsZVwiO1xyXG5pbXBvcnQge0Jhc2VNb2R1bGV9IGZyb20gXCIuLi9iYXNlL2Jhc2UubW9kdWxlXCI7XHJcbmltcG9ydCB7QXBwZW5kUGlwZU1vZHVsZX0gZnJvbSBcIi4uLy4uL3BpcGVzL2FwcGVuZC5waXBlLm1vZHVsZVwiO1xyXG5pbXBvcnQge051bWVyaWNUZXh0Qm94TW9kdWxlLCBUZXh0Qm94QWxsTW9kdWxlfSBmcm9tIFwiQHN5bmNmdXNpb24vZWoyLWFuZ3VsYXItaW5wdXRzXCI7XHJcbmltcG9ydCB7VmFsaWRhdGlvbkVycm9yTW9kdWxlfSBmcm9tIFwiLi4vdmFsaWRhdGlvbi1lcnJvci92YWxpZGF0aW9uLWVycm9yLm1vZHVsZVwiO1xyXG5pbXBvcnQge0NvbW1pdEJ1dHRvbnNNb2R1bGV9IGZyb20gXCIuLi9iYXNlL2NvbW1pdC1idXR0b25zL2NvbW1pdC1idXR0b25zLm1vZHVsZVwiO1xyXG5pbXBvcnQge092ZXJsYXlNb2R1bGV9IGZyb20gJy4uLy4uL2RpcmVjdGl2ZXMvb3ZlcmxheS9vdmVybGF5Lm1vZHVsZSc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIEJhc2VNb2R1bGUsXHJcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgICAgIEljb25Nb2R1bGUsXHJcbiAgICAgICAgQXBwZW5kUGlwZU1vZHVsZSxcclxuICAgICAgICBUZXh0Qm94QWxsTW9kdWxlLFxyXG4gICAgICAgIE51bWVyaWNUZXh0Qm94TW9kdWxlLFxyXG4gICAgICAgIFZhbGlkYXRpb25FcnJvck1vZHVsZSxcclxuICAgICAgICBDb21taXRCdXR0b25zTW9kdWxlLFxyXG4gICAgICAgIE92ZXJsYXlNb2R1bGVcclxuICAgIF0sXHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBJbnB1dFRleHRDb21wb25lbnRcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIElucHV0VGV4dENvbXBvbmVudFxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIElucHV0VGV4dE1vZHVsZSB7XHJcbn1cclxuIl19
|
|
@@ -1,19 +1,21 @@
|
|
|
1
|
-
import { ChangeDetectorRef, Component, ComponentFactoryResolver, ElementRef, forwardRef, HostBinding, Input, Optional, ViewEncapsulation } from
|
|
2
|
-
import { BaseInputComponent } from
|
|
3
|
-
import { SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME } from
|
|
4
|
-
import { FormInputUserModelChangeListenerService } from
|
|
5
|
-
import { NgZoneWrapperService } from
|
|
6
|
-
import { FormComponent } from
|
|
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:
|
|
28
|
+
selector: 'co-input-textarea',
|
|
27
29
|
template: `
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
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: [
|
|
68
|
-
hasOwnLabel: [{ type: HostBinding, args: [
|
|
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,
|
|
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
|
|
2
|
-
import { SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME } from
|
|
3
|
-
import { BaseInputComponent } from
|
|
4
|
-
import { CheckBoxSelectionService } from
|
|
5
|
-
import { FormInputUserModelChangeListenerService } from
|
|
6
|
-
import { NgZoneWrapperService } from
|
|
7
|
-
import { FormComponent } from
|
|
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 =
|
|
25
|
+
this.mode = 'Default';
|
|
24
26
|
super._markAsOnPush();
|
|
25
27
|
}
|
|
26
28
|
set showCheckbox(value) {
|
|
27
29
|
if (value) {
|
|
28
|
-
this.mode =
|
|
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:
|
|
47
|
+
selector: 'co-multi-select-list',
|
|
46
48
|
template: `
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
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: [
|
|
101
|
+
showClass: [{ type: HostBinding, args: ['class.co-multi-select-list',] }]
|
|
99
102
|
};
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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
|
|
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-
|
|
18
|
-
<
|
|
19
|
-
<
|
|
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,
|
|
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,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi1lcnJvci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvdmFsaWRhdGlvbi1lcnJvci92YWxpZGF0aW9uLWVycm9yLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQUN0RSxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFDL0MsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHlDQUF5QyxDQUFDO0FBZXRFLE1BQU0sT0FBTyxxQkFBcUI7OztZQWJqQyxRQUFRLFNBQUM7Z0JBQ04sT0FBTyxFQUFFO29CQUNMLFlBQVk7b0JBQ1osVUFBVTtvQkFDVixhQUFhO2lCQUNoQjtnQkFDSCxZQUFZLEVBQUU7b0JBQ1osd0JBQXdCO2lCQUN6QjtnQkFDRCxPQUFPLEVBQUU7b0JBQ1Asd0JBQXdCO2lCQUN6QjthQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHtWYWxpZGF0aW9uRXJyb3JDb21wb25lbnR9IGZyb20gXCIuL3ZhbGlkYXRpb24tZXJyb3IuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7SWNvbk1vZHVsZX0gZnJvbSBcIi4uL2ljb24vaWNvbi5tb2R1bGVcIjtcclxuaW1wb3J0IHtPdmVybGF5TW9kdWxlfSBmcm9tICcuLi8uLi9kaXJlY3RpdmVzL292ZXJsYXkvb3ZlcmxheS5tb2R1bGUnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICAgIGltcG9ydHM6IFtcclxuICAgICAgICBDb21tb25Nb2R1bGUsXHJcbiAgICAgICAgSWNvbk1vZHVsZSxcclxuICAgICAgICBPdmVybGF5TW9kdWxlXHJcbiAgICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgVmFsaWRhdGlvbkVycm9yQ29tcG9uZW50XHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBWYWxpZGF0aW9uRXJyb3JDb21wb25lbnRcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBWYWxpZGF0aW9uRXJyb3JNb2R1bGUge1xyXG5cclxufVxyXG4iXX0=
|
|
@@ -1,48 +1,70 @@
|
|
|
1
|
-
import { Directive, ElementRef,
|
|
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
|
|
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.
|
|
16
|
+
this._resizeObserver.disconnect();
|
|
14
17
|
}
|
|
15
18
|
}
|
|
16
19
|
}
|
|
17
|
-
handleScroll(event) {
|
|
18
|
-
this._checkAndPlaceElement();
|
|
19
|
-
}
|
|
20
20
|
ngOnDestroy() {
|
|
21
|
-
|
|
22
|
-
this.
|
|
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
|
-
|
|
28
|
+
if (!this._elementRef || !this._elementRef.nativeElement) {
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
document.addEventListener("scroll", this.handleScroll, true);
|
|
28
32
|
this._checkAndPlaceElement();
|
|
29
|
-
this.
|
|
33
|
+
this._resizeObserver = new ResizeObserver((entries) => {
|
|
30
34
|
this._checkAndPlaceElement();
|
|
31
35
|
});
|
|
32
|
-
this.
|
|
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
|
-
|
|
36
|
-
|
|
37
|
-
|
|
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,
|
|
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":"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","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==
|