@simpleangularcontrols/sac-common 16.0.0-rc.2 → 16.0.0-rc.4
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/common/basedatetimecontrol.d.ts +33 -33
- package/common/basedatetimecontrol.d.ts.map +1 -1
- package/common/baseinputcontrol.d.ts +9 -9
- package/common/baseinputcontrol.d.ts.map +1 -1
- package/common/basemodelcontrol.d.ts +122 -89
- package/common/basemodelcontrol.d.ts.map +1 -1
- package/common/baseuploadcontrol.d.ts +140 -140
- package/common/baseuploadcontrol.d.ts.map +1 -1
- package/controls/checkbox/checkbox.d.ts +7 -3
- package/controls/checkbox/checkbox.d.ts.map +1 -1
- package/controls/checkbox/radiobuttons.d.ts +5 -4
- package/controls/checkbox/radiobuttons.d.ts.map +1 -1
- package/controls/contextmenu/contextmenu.d.ts +42 -42
- package/controls/contextmenu/contextmenu.d.ts.map +1 -1
- package/controls/contextmenu/contextmenuanchor.d.ts +2 -2
- package/controls/contextmenu/contextmenuanchor.d.ts.map +1 -1
- package/controls/contextmenu/contextmenucontainer.d.ts +2 -2
- package/controls/contextmenu/contextmenucontainer.d.ts.map +1 -1
- package/controls/datetime/date.d.ts +7 -7
- package/controls/datetime/date.d.ts.map +1 -1
- package/controls/datetime/datetime.d.ts +7 -7
- package/controls/datetime/datetime.d.ts.map +1 -1
- package/controls/datetime/time.d.ts +7 -7
- package/controls/datetime/time.d.ts.map +1 -1
- package/controls/form/form.d.ts +7 -43
- package/controls/form/form.d.ts.map +1 -1
- package/controls/input/inputdecimal.d.ts +21 -21
- package/controls/input/inputdecimal.d.ts.map +1 -1
- package/controls/layout/formlayout.d.ts +45 -0
- package/controls/layout/formlayout.d.ts.map +1 -0
- package/controls/list/dropdown.d.ts +45 -45
- package/controls/list/dropdown.d.ts.map +1 -1
- package/controls/multilanguage/multilanguageinput.d.ts +5 -4
- package/controls/multilanguage/multilanguageinput.d.ts.map +1 -1
- package/controls/multilanguage/multilanguageinputarea.d.ts +5 -4
- package/controls/multilanguage/multilanguageinputarea.d.ts.map +1 -1
- package/controls/tinymce/tinymce.d.ts +63 -63
- package/controls/tinymce/tinymce.d.ts.map +1 -1
- package/esm2022/common/basedatetimecontrol.mjs +75 -81
- package/esm2022/common/baseinputcontrol.mjs +20 -20
- package/esm2022/common/basemodelcontrol.mjs +295 -201
- package/esm2022/common/baseuploadcontrol.mjs +225 -224
- package/esm2022/controls/checkbox/checkbox.mjs +11 -5
- package/esm2022/controls/checkbox/radiobuttons.mjs +13 -12
- package/esm2022/controls/contextmenu/contextmenu.mjs +85 -75
- package/esm2022/controls/contextmenu/contextmenuanchor.mjs +6 -4
- package/esm2022/controls/contextmenu/contextmenucontainer.mjs +6 -4
- package/esm2022/controls/datetime/date.mjs +12 -12
- package/esm2022/controls/datetime/datetime.mjs +15 -15
- package/esm2022/controls/datetime/time.mjs +15 -15
- package/esm2022/controls/form/form.mjs +26 -80
- package/esm2022/controls/input/inputdecimal.mjs +58 -53
- package/esm2022/controls/layout/formlayout.mjs +73 -0
- package/esm2022/controls/list/dropdown.mjs +110 -91
- package/esm2022/controls/multilanguage/multilanguageinput.mjs +10 -9
- package/esm2022/controls/multilanguage/multilanguageinputarea.mjs +10 -9
- package/esm2022/controls/tinymce/tinymce.mjs +102 -95
- package/esm2022/interfaces/ISacConfigurationService.mjs +2 -0
- package/esm2022/interfaces/ISacIconService.mjs +1 -1
- package/esm2022/interfaces/ISacLabelSizes.mjs +2 -0
- package/esm2022/public_api.mjs +20 -18
- package/esm2022/services/index.mjs +6 -5
- package/esm2022/services/sac-configuration.service.mjs +71 -0
- package/esm2022/utilities/guid.mjs +16 -0
- package/fesm2022/simpleangularcontrols-sac-common.mjs +2157 -1916
- package/fesm2022/simpleangularcontrols-sac-common.mjs.map +1 -1
- package/interfaces/ISacConfigurationService.d.ts +30 -0
- package/interfaces/ISacConfigurationService.d.ts.map +1 -0
- package/interfaces/ISacIconService.d.ts +2 -2
- package/interfaces/ISacIconService.d.ts.map +1 -1
- package/interfaces/ISacLabelSizes.d.ts +27 -0
- package/interfaces/ISacLabelSizes.d.ts.map +1 -0
- package/package.json +2 -2
- package/public_api.d.ts +19 -17
- package/public_api.d.ts.map +1 -1
- package/services/index.d.ts +5 -4
- package/services/index.d.ts.map +1 -1
- package/services/sac-configuration.service.d.ts +70 -0
- package/services/sac-configuration.service.d.ts.map +1 -0
- package/simpleangularcontrols-sac-common-16.0.0-rc.4.tgz +0 -0
- package/utilities/guid.d.ts +5 -0
- package/utilities/guid.d.ts.map +1 -0
- package/simpleangularcontrols-sac-common-16.0.0-rc.2.tgz +0 -0
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { Directive, Input } from '@angular/core';
|
|
2
2
|
import { SacBaseModelControl } from '../../common/basemodelcontrol';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
/**
|
|
@@ -8,9 +8,13 @@ class SacCheckboxCommon extends SacBaseModelControl {
|
|
|
8
8
|
constructor() {
|
|
9
9
|
super(...arguments);
|
|
10
10
|
/**
|
|
11
|
-
|
|
12
|
-
|
|
11
|
+
* Text welcher als Tooltip angezeigt wird.
|
|
12
|
+
*/
|
|
13
13
|
this.tooltiptext = '';
|
|
14
|
+
/**
|
|
15
|
+
* Defines that the checkbox can be used in a list of checkboxes and is not handled as a single form control
|
|
16
|
+
*/
|
|
17
|
+
this.stacked = false;
|
|
14
18
|
}
|
|
15
19
|
/**
|
|
16
20
|
* Control hat keinen Validator
|
|
@@ -19,7 +23,7 @@ class SacCheckboxCommon extends SacBaseModelControl {
|
|
|
19
23
|
return null;
|
|
20
24
|
}
|
|
21
25
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacCheckboxCommon, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
22
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: SacCheckboxCommon, inputs: { tooltiptext: "tooltiptext", checkboxtext: "checkboxtext" }, usesInheritance: true, ngImport: i0 }); }
|
|
26
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: SacCheckboxCommon, inputs: { tooltiptext: "tooltiptext", checkboxtext: "checkboxtext", stacked: "stacked" }, usesInheritance: true, ngImport: i0 }); }
|
|
23
27
|
}
|
|
24
28
|
export { SacCheckboxCommon };
|
|
25
29
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacCheckboxCommon, decorators: [{
|
|
@@ -28,5 +32,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
28
32
|
type: Input
|
|
29
33
|
}], checkboxtext: [{
|
|
30
34
|
type: Input
|
|
35
|
+
}], stacked: [{
|
|
36
|
+
type: Input
|
|
31
37
|
}] } });
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3guanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zYWMtY29tbW9uL3NyYy9jb250cm9scy9jaGVja2JveC9jaGVja2JveC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVqRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQzs7QUFFcEU7O0dBRUc7QUFDSCxNQUNhLGlCQUFrQixTQUFRLG1CQUE0QjtJQURuRTs7UUFFRTs7V0FFRztRQUNNLGdCQUFXLEdBQVcsRUFBRSxDQUFDO1FBT2xDOztXQUVHO1FBQ00sWUFBTyxHQUFZLEtBQUssQ0FBQztLQVFuQztJQU5DOztPQUVHO0lBQ0gsWUFBWSxDQUFDLENBQWtCO1FBQzdCLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQzsrR0FyQlUsaUJBQWlCO21HQUFqQixpQkFBaUI7O1NBQWpCLGlCQUFpQjs0RkFBakIsaUJBQWlCO2tCQUQ3QixTQUFTOzhCQUtDLFdBQVc7c0JBQW5CLEtBQUs7Z0JBS0csWUFBWTtzQkFBcEIsS0FBSztnQkFLRyxPQUFPO3NCQUFmLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEFic3RyYWN0Q29udHJvbCwgVmFsaWRhdGlvbkVycm9ycyB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgU2FjQmFzZU1vZGVsQ29udHJvbCB9IGZyb20gJy4uLy4uL2NvbW1vbi9iYXNlbW9kZWxjb250cm9sJztcclxuXHJcbi8qKlxyXG4gKiBCYXNpcyBLb21wb25lbnRlIGbDvHIgU2FjQ2hlY2tib3hDb21tb24uIEV4dGVuZHMgU2FjQmFzZU1vZGVsQ29udHJvbFxyXG4gKi9cclxuQERpcmVjdGl2ZSgpXHJcbmV4cG9ydCBjbGFzcyBTYWNDaGVja2JveENvbW1vbiBleHRlbmRzIFNhY0Jhc2VNb2RlbENvbnRyb2w8Ym9vbGVhbj4ge1xyXG4gIC8qKlxyXG4gICAqIFRleHQgd2VsY2hlciBhbHMgVG9vbHRpcCBhbmdlemVpZ3Qgd2lyZC5cclxuICAgKi9cclxuICBASW5wdXQoKSB0b29sdGlwdGV4dDogc3RyaW5nID0gJyc7XHJcblxyXG4gIC8qKlxyXG4gICAqIFRleHQgdm9tIENoZWNrYm94LUNvbnRyb2wuIERlciBUZXh0IHdpcmQgcmVjaHRzIHZvbiBkZXIgQ2hlY2tib3ggYW5nZXplaWd0LlxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIGNoZWNrYm94dGV4dDtcclxuXHJcbiAgLyoqXHJcbiAgICogRGVmaW5lcyB0aGF0IHRoZSBjaGVja2JveCBjYW4gYmUgdXNlZCBpbiBhIGxpc3Qgb2YgY2hlY2tib3hlcyBhbmQgaXMgbm90IGhhbmRsZWQgYXMgYSBzaW5nbGUgZm9ybSBjb250cm9sXHJcbiAgICovXHJcbiAgQElucHV0KCkgc3RhY2tlZDogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICAvKipcclxuICAgKiBDb250cm9sIGhhdCBrZWluZW4gVmFsaWRhdG9yXHJcbiAgICovXHJcbiAgdmFsaWRhdGVEYXRhKGM6IEFic3RyYWN0Q29udHJvbCk6IFZhbGlkYXRpb25FcnJvcnMgfCBudWxsIHtcclxuICAgIHJldHVybiBudWxsO1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -1,18 +1,19 @@
|
|
|
1
|
-
import { Host, Input
|
|
1
|
+
import { Directive, Host, Input } from '@angular/core';
|
|
2
2
|
import { SacBaseModelControl } from '../../common/basemodelcontrol';
|
|
3
3
|
import { Validation } from '../../validation';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "../
|
|
5
|
+
import * as i1 from "../layout/formlayout";
|
|
6
6
|
/**
|
|
7
7
|
* Basis Komponente für SacRadiobuttonsCommon. Extends SacBaseModelControl
|
|
8
8
|
*/
|
|
9
9
|
class SacRadiobuttonsCommon extends SacBaseModelControl {
|
|
10
10
|
/**
|
|
11
|
-
*
|
|
12
|
-
*
|
|
11
|
+
* Constructor
|
|
12
|
+
* @param formlayout SacFormLayoutCommon to define scoped layout settings
|
|
13
|
+
* @param injector Injector for injecting services
|
|
13
14
|
*/
|
|
14
|
-
constructor(
|
|
15
|
-
super(
|
|
15
|
+
constructor(formlayout, injector) {
|
|
16
|
+
super(formlayout, injector);
|
|
16
17
|
/**
|
|
17
18
|
* Radio Button Index
|
|
18
19
|
*/
|
|
@@ -61,7 +62,7 @@ class SacRadiobuttonsCommon extends SacBaseModelControl {
|
|
|
61
62
|
writeValue(value) {
|
|
62
63
|
super.writeValue(value);
|
|
63
64
|
if (value !== null && value !== undefined) {
|
|
64
|
-
this.contentRadiobuttons.forEach(itm => {
|
|
65
|
+
this.contentRadiobuttons.forEach((itm) => {
|
|
65
66
|
itm.checked = itm.value === value;
|
|
66
67
|
});
|
|
67
68
|
}
|
|
@@ -71,7 +72,7 @@ class SacRadiobuttonsCommon extends SacBaseModelControl {
|
|
|
71
72
|
* Item selektieren
|
|
72
73
|
*/
|
|
73
74
|
SelectItem(value) {
|
|
74
|
-
this.contentRadiobuttons.forEach(itm => {
|
|
75
|
+
this.contentRadiobuttons.forEach((itm) => {
|
|
75
76
|
itm.checked = itm.value === value;
|
|
76
77
|
});
|
|
77
78
|
this.value = value;
|
|
@@ -84,7 +85,7 @@ class SacRadiobuttonsCommon extends SacBaseModelControl {
|
|
|
84
85
|
if (radioButtons === undefined || radioButtons === null) {
|
|
85
86
|
return false;
|
|
86
87
|
}
|
|
87
|
-
return this.contentRadiobuttons.some(itm => itm.checked);
|
|
88
|
+
return this.contentRadiobuttons.some((itm) => itm.checked);
|
|
88
89
|
}
|
|
89
90
|
/**
|
|
90
91
|
* Validator
|
|
@@ -97,17 +98,17 @@ class SacRadiobuttonsCommon extends SacBaseModelControl {
|
|
|
97
98
|
return null;
|
|
98
99
|
}
|
|
99
100
|
}
|
|
100
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacRadiobuttonsCommon, deps: [{ token: i1.
|
|
101
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacRadiobuttonsCommon, deps: [{ token: i1.SacFormLayoutCommon, host: true }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
101
102
|
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: SacRadiobuttonsCommon, inputs: { validationmessagerequired: "validationmessagerequired", validationmessagesummaryrequired: "validationmessagesummaryrequired" }, usesInheritance: true, ngImport: i0 }); }
|
|
102
103
|
}
|
|
103
104
|
export { SacRadiobuttonsCommon };
|
|
104
105
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacRadiobuttonsCommon, decorators: [{
|
|
105
106
|
type: Directive
|
|
106
|
-
}], ctorParameters: function () { return [{ type: i1.
|
|
107
|
+
}], ctorParameters: function () { return [{ type: i1.SacFormLayoutCommon, decorators: [{
|
|
107
108
|
type: Host
|
|
108
109
|
}] }, { type: i0.Injector }]; }, propDecorators: { validationmessagerequired: [{
|
|
109
110
|
type: Input
|
|
110
111
|
}], validationmessagesummaryrequired: [{
|
|
111
112
|
type: Input
|
|
112
113
|
}] } });
|
|
113
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
114
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFkaW9idXR0b25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2FjLWNvbW1vbi9zcmMvY29udHJvbHMvY2hlY2tib3gvcmFkaW9idXR0b25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsSUFBSSxFQUFZLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVqRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNwRSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7OztBQUk5Qzs7R0FFRztBQUNILE1BQ3NCLHFCQUNwQixTQUFRLG1CQUF3QjtJQVFoQzs7OztPQUlHO0lBQ0gsWUFBb0IsVUFBK0IsRUFBRSxRQUFrQjtRQUNyRSxLQUFLLENBQUMsVUFBVSxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBWDlCOztXQUVHO1FBQ0sscUJBQWdCLEdBQVcsQ0FBQyxDQUFDO1FBV3JDOztXQUVHO1FBQ00sOEJBQXlCLEdBQVcsMkJBQTJCLENBQUM7UUFDekU7O1dBRUc7UUFDTSxxQ0FBZ0MsR0FDdkMsbUNBQW1DLENBQUM7UUFFdEMsa0NBQWtDO1FBRWxDOztXQUVHO1FBQ0ssd0JBQW1CLEdBQTJCLEVBQUUsQ0FBQztJQWpCekQsQ0FBQztJQW1CRDs7T0FFRztJQUNJLG1CQUFtQixDQUFDLFdBQWlDO1FBQzFELElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUVEOztPQUVHO0lBQ0kscUJBQXFCLENBQUMsV0FBaUM7UUFDNUQsTUFBTSxLQUFLLEdBQVcsSUFBSSxDQUFDLG1CQUFtQixDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUVwRSxJQUFJLEtBQUssSUFBSSxDQUFDLEVBQUU7WUFDZCxJQUFJLENBQUMsbUJBQW1CLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQztTQUMzQztJQUNILENBQUM7SUFFRCxZQUFZO0lBRVo7O09BRUc7SUFDSSxvQkFBb0I7UUFDekIsSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUM7UUFDeEIsT0FBTyxJQUFJLENBQUMsZ0JBQWdCLENBQUM7SUFDL0IsQ0FBQztJQUVELGdDQUFnQztJQUVoQzs7T0FFRztJQUNILFVBQVUsQ0FBQyxLQUFVO1FBQ25CLEtBQUssQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDeEIsSUFBSSxLQUFLLEtBQUssSUFBSSxJQUFJLEtBQUssS0FBSyxTQUFTLEVBQUU7WUFDekMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLE9BQU8sQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFO2dCQUN2QyxHQUFHLENBQUMsT0FBTyxHQUFHLEdBQUcsQ0FBQyxLQUFLLEtBQUssS0FBSyxDQUFDO1lBQ3BDLENBQUMsQ0FBQyxDQUFDO1NBQ0o7SUFDSCxDQUFDO0lBRUQsWUFBWTtJQUVaOztPQUVHO0lBQ0ksVUFBVSxDQUFDLEtBQVU7UUFDMUIsSUFBSSxDQUFDLG1CQUFtQixDQUFDLE9BQU8sQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFO1lBQ3ZDLEdBQUcsQ0FBQyxPQUFPLEdBQUcsR0FBRyxDQUFDLEtBQUssS0FBSyxLQUFLLENBQUM7UUFDcEMsQ0FBQyxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztJQUNyQixDQUFDO0lBRUQ7O09BRUc7SUFDSSxjQUFjO1FBQ25CLE1BQU0sWUFBWSxHQUEyQixJQUFJLENBQUMsbUJBQW1CLENBQUM7UUFFdEUsSUFBSSxZQUFZLEtBQUssU0FBUyxJQUFJLFlBQVksS0FBSyxJQUFJLEVBQUU7WUFDdkQsT0FBTyxLQUFLLENBQUM7U0FDZDtRQUVELE9BQU8sSUFBSSxDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQzdELENBQUM7SUFFRDs7T0FFRztJQUNILFlBQVksQ0FBQyxDQUFrQjtRQUM3QixJQUFJLENBQUMsSUFBSSxDQUFDLGNBQWMsRUFBRSxFQUFFO1lBQzFCLE9BQU8sVUFBVSxDQUFDLHNCQUFzQixDQUN0QyxVQUFVLEVBQ1YsSUFBSSxDQUFDLHlCQUF5QixFQUM5QixJQUFJLENBQUMsZ0NBQWdDLEVBQ3JDLElBQUksQ0FBQyxLQUFLLENBQ1gsQ0FBQztTQUNIO2FBQU07WUFDTCxPQUFPLElBQUksQ0FBQztTQUNiO0lBQ0gsQ0FBQzsrR0FySG1CLHFCQUFxQjttR0FBckIscUJBQXFCOztTQUFyQixxQkFBcUI7NEZBQXJCLHFCQUFxQjtrQkFEMUMsU0FBUzs7MEJBZUssSUFBSTttRUFPUix5QkFBeUI7c0JBQWpDLEtBQUs7Z0JBSUcsZ0NBQWdDO3NCQUF4QyxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBIb3N0LCBJbmplY3RvciwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQWJzdHJhY3RDb250cm9sLCBWYWxpZGF0aW9uRXJyb3JzLCBWYWxpZGF0b3IgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IFNhY0Jhc2VNb2RlbENvbnRyb2wgfSBmcm9tICcuLi8uLi9jb21tb24vYmFzZW1vZGVsY29udHJvbCc7XHJcbmltcG9ydCB7IFZhbGlkYXRpb24gfSBmcm9tICcuLi8uLi92YWxpZGF0aW9uJztcclxuaW1wb3J0IHsgU2FjRm9ybUxheW91dENvbW1vbiB9IGZyb20gJy4uL2xheW91dC9mb3JtbGF5b3V0JztcclxuaW1wb3J0IHsgU2FjUmFkaW9idXR0b25Db21tb24gfSBmcm9tICcuL3JhZGlvYnV0dG9uJztcclxuXHJcbi8qKlxyXG4gKiBCYXNpcyBLb21wb25lbnRlIGbDvHIgU2FjUmFkaW9idXR0b25zQ29tbW9uLiBFeHRlbmRzIFNhY0Jhc2VNb2RlbENvbnRyb2xcclxuICovXHJcbkBEaXJlY3RpdmUoKVxyXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgU2FjUmFkaW9idXR0b25zQ29tbW9uXHJcbiAgZXh0ZW5kcyBTYWNCYXNlTW9kZWxDb250cm9sPGFueT5cclxuICBpbXBsZW1lbnRzIFZhbGlkYXRvclxyXG57XHJcbiAgLyoqXHJcbiAgICogUmFkaW8gQnV0dG9uIEluZGV4XHJcbiAgICovXHJcbiAgcHJpdmF0ZSByYWRpb0J1dHRvbkluZGV4OiBudW1iZXIgPSAwO1xyXG5cclxuICAvKipcclxuICAgKiBDb25zdHJ1Y3RvclxyXG4gICAqIEBwYXJhbSBmb3JtbGF5b3V0IFNhY0Zvcm1MYXlvdXRDb21tb24gdG8gZGVmaW5lIHNjb3BlZCBsYXlvdXQgc2V0dGluZ3NcclxuICAgKiBAcGFyYW0gaW5qZWN0b3IgSW5qZWN0b3IgZm9yIGluamVjdGluZyBzZXJ2aWNlc1xyXG4gICAqL1xyXG4gIGNvbnN0cnVjdG9yKEBIb3N0KCkgZm9ybWxheW91dDogU2FjRm9ybUxheW91dENvbW1vbiwgaW5qZWN0b3I6IEluamVjdG9yKSB7XHJcbiAgICBzdXBlcihmb3JtbGF5b3V0LCBpbmplY3Rvcik7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBSZXNvdXJjZSBLZXkgZsO8ciBWYWxpZGF0aW9uIE1lc3NhZ2UgUmVxdWlyZWQgYmVpIENvbnRyb2xcclxuICAgKi9cclxuICBASW5wdXQoKSB2YWxpZGF0aW9ubWVzc2FnZXJlcXVpcmVkOiBzdHJpbmcgPSAnVkFMSURBVElPTl9FUlJPUl9SRVFVSVJFRCc7XHJcbiAgLyoqXHJcbiAgICogUmVzb3VyY2UgS2V5IGbDvHIgVmFsaWRhdGlvbiBNZXNzYWdlIFJlcXVpcmVkIGluIFZhbGlkYXRpb24gU3VtbWFyeVxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIHZhbGlkYXRpb25tZXNzYWdlc3VtbWFyeXJlcXVpcmVkOiBzdHJpbmcgPVxyXG4gICAgJ1ZBTElEQVRJT05fRVJST1JfU1VNTUFSWV9SRVFVSVJFRCc7XHJcblxyXG4gIC8vI3JlZ2lvbiBTdWIgQ29udHJvbCByZWdpc3RyYXRpb25cclxuXHJcbiAgLyoqXHJcbiAgICogUmFkaW8gQnV0dG9ucyBDb250ZW50XHJcbiAgICovXHJcbiAgcHJpdmF0ZSBjb250ZW50UmFkaW9idXR0b25zOiBTYWNSYWRpb2J1dHRvbkNvbW1vbltdID0gW107XHJcblxyXG4gIC8qKlxyXG4gICAqIEVyc3RlbGx1bmcgZGVzIFJhZGlvQnV0dG9uXHJcbiAgICovXHJcbiAgcHVibGljIFJlZ2lzdGVyUmFkaW9CdXR0b24ocmFkaW9CdXR0b246IFNhY1JhZGlvYnV0dG9uQ29tbW9uKSB7XHJcbiAgICB0aGlzLmNvbnRlbnRSYWRpb2J1dHRvbnMucHVzaChyYWRpb0J1dHRvbik7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBMw7ZzY2hlbiBkZXMgUmFkaW8gQnV0dG9uXHJcbiAgICovXHJcbiAgcHVibGljIFVucmVnaXN0ZXJSYWRpb0J1dHRvbihyYWRpb0J1dHRvbjogU2FjUmFkaW9idXR0b25Db21tb24pIHtcclxuICAgIGNvbnN0IGluZGV4OiBudW1iZXIgPSB0aGlzLmNvbnRlbnRSYWRpb2J1dHRvbnMuaW5kZXhPZihyYWRpb0J1dHRvbik7XHJcblxyXG4gICAgaWYgKGluZGV4ID49IDApIHtcclxuICAgICAgdGhpcy5jb250ZW50UmFkaW9idXR0b25zLnNwbGljZShpbmRleCwgMSk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICAvLyNlbmRyZWdpb25cclxuXHJcbiAgLyoqXHJcbiAgICogR0V0dGVyIGbDvHIgUmFkaW8gQnV0dG9uIEluZGV4XHJcbiAgICovXHJcbiAgcHVibGljIEdldFJhZGlvbkJ1dHRvbkluZGV4KCk6IG51bWJlciB7XHJcbiAgICB0aGlzLnJhZGlvQnV0dG9uSW5kZXgrKztcclxuICAgIHJldHVybiB0aGlzLnJhZGlvQnV0dG9uSW5kZXg7XHJcbiAgfVxyXG5cclxuICAvLyNyZWdpb24gbmdNb2RlbCBJbXBsZW1lbnRhdGlvblxyXG5cclxuICAvKipcclxuICAgKiBXZXJ0IHNjaHJlaWJlblxyXG4gICAqL1xyXG4gIHdyaXRlVmFsdWUodmFsdWU6IGFueSkge1xyXG4gICAgc3VwZXIud3JpdGVWYWx1ZSh2YWx1ZSk7XHJcbiAgICBpZiAodmFsdWUgIT09IG51bGwgJiYgdmFsdWUgIT09IHVuZGVmaW5lZCkge1xyXG4gICAgICB0aGlzLmNvbnRlbnRSYWRpb2J1dHRvbnMuZm9yRWFjaCgoaXRtKSA9PiB7XHJcbiAgICAgICAgaXRtLmNoZWNrZWQgPSBpdG0udmFsdWUgPT09IHZhbHVlO1xyXG4gICAgICB9KTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIC8vI2VuZHJlZ2lvblxyXG5cclxuICAvKipcclxuICAgKiBJdGVtIHNlbGVrdGllcmVuXHJcbiAgICovXHJcbiAgcHVibGljIFNlbGVjdEl0ZW0odmFsdWU6IGFueSkge1xyXG4gICAgdGhpcy5jb250ZW50UmFkaW9idXR0b25zLmZvckVhY2goKGl0bSkgPT4ge1xyXG4gICAgICBpdG0uY2hlY2tlZCA9IGl0bS52YWx1ZSA9PT0gdmFsdWU7XHJcbiAgICB9KTtcclxuXHJcbiAgICB0aGlzLnZhbHVlID0gdmFsdWU7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBNZXRob2RlIHByw7xmdCBvYiBJdGVtIGNoZWNrZWQgaXN0XHJcbiAgICovXHJcbiAgcHVibGljIEhhc0NoZWNrZWRJdGVtKCk6IGJvb2xlYW4ge1xyXG4gICAgY29uc3QgcmFkaW9CdXR0b25zOiBTYWNSYWRpb2J1dHRvbkNvbW1vbltdID0gdGhpcy5jb250ZW50UmFkaW9idXR0b25zO1xyXG5cclxuICAgIGlmIChyYWRpb0J1dHRvbnMgPT09IHVuZGVmaW5lZCB8fCByYWRpb0J1dHRvbnMgPT09IG51bGwpIHtcclxuICAgICAgcmV0dXJuIGZhbHNlO1xyXG4gICAgfVxyXG5cclxuICAgIHJldHVybiB0aGlzLmNvbnRlbnRSYWRpb2J1dHRvbnMuc29tZSgoaXRtKSA9PiBpdG0uY2hlY2tlZCk7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBWYWxpZGF0b3JcclxuICAgKi9cclxuICB2YWxpZGF0ZURhdGEoYzogQWJzdHJhY3RDb250cm9sKTogVmFsaWRhdGlvbkVycm9ycyB7XHJcbiAgICBpZiAoIXRoaXMuSGFzQ2hlY2tlZEl0ZW0oKSkge1xyXG4gICAgICByZXR1cm4gVmFsaWRhdGlvbi5HZXRWYWxpZGF0aW9uRXJyb3JJdGVtKFxyXG4gICAgICAgICdyZXF1aXJlZCcsXHJcbiAgICAgICAgdGhpcy52YWxpZGF0aW9ubWVzc2FnZXJlcXVpcmVkLFxyXG4gICAgICAgIHRoaXMudmFsaWRhdGlvbm1lc3NhZ2VzdW1tYXJ5cmVxdWlyZWQsXHJcbiAgICAgICAgdGhpcy5sYWJlbFxyXG4gICAgICApO1xyXG4gICAgfSBlbHNlIHtcclxuICAgICAgcmV0dXJuIG51bGw7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -9,46 +9,37 @@ import * as i0 from "@angular/core";
|
|
|
9
9
|
* Base Context Menü Element. Die Logik wurde aus NG-BOOTSTRAP übernommen.
|
|
10
10
|
*/
|
|
11
11
|
class SacContextmenuCommon {
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
*/
|
|
15
|
-
onClick(targetElement) {
|
|
16
|
-
const anchor = this._anchor || this._anchorTemplate;
|
|
17
|
-
if (this._menu &&
|
|
18
|
-
!this._menu.nativeElement.contains(targetElement) &&
|
|
19
|
-
!anchor.nativeElement.contains(targetElement)) {
|
|
20
|
-
this.close();
|
|
21
|
-
}
|
|
22
|
-
}
|
|
12
|
+
// #endregion Properties
|
|
13
|
+
// #region Constructors
|
|
23
14
|
/**
|
|
24
15
|
* Konstruktor
|
|
25
|
-
* @param
|
|
26
|
-
* @param
|
|
27
|
-
* @param
|
|
28
|
-
* @param
|
|
29
|
-
* @param
|
|
16
|
+
* @param document HTML Document Element
|
|
17
|
+
* @param ngZone Angular Zone Service
|
|
18
|
+
* @param elementRef HTML Element des aktuellen Controls
|
|
19
|
+
* @param renderer Angular Rendering Service
|
|
20
|
+
* @param injector injector to resolve the icon service
|
|
30
21
|
*/
|
|
31
|
-
constructor(
|
|
32
|
-
this.
|
|
33
|
-
this.
|
|
34
|
-
this.
|
|
35
|
-
this.
|
|
22
|
+
constructor(document, ngZone, elementRef, renderer, injector) {
|
|
23
|
+
this.document = document;
|
|
24
|
+
this.ngZone = ngZone;
|
|
25
|
+
this.elementRef = elementRef;
|
|
26
|
+
this.renderer = renderer;
|
|
36
27
|
/**
|
|
37
28
|
* Body HTML Element
|
|
38
29
|
*/
|
|
39
30
|
this.bodyContainer = null;
|
|
40
31
|
/**
|
|
41
|
-
*
|
|
32
|
+
* Container an welchem die Position ausgerichtet wird. Aktuell wird nun Body Supported
|
|
42
33
|
*/
|
|
43
|
-
this.
|
|
34
|
+
this.container = 'body';
|
|
44
35
|
/**
|
|
45
36
|
* Extra CSS Klassen für das Control
|
|
46
37
|
*/
|
|
47
38
|
this.cssclass = '';
|
|
48
39
|
/**
|
|
49
|
-
*
|
|
40
|
+
* Definiert ob das Dropdown offen ist.
|
|
50
41
|
*/
|
|
51
|
-
this.
|
|
42
|
+
this.isopen = false;
|
|
52
43
|
/**
|
|
53
44
|
* The preferred placement of the dropdown.
|
|
54
45
|
*
|
|
@@ -68,34 +59,31 @@ class SacContextmenuCommon {
|
|
|
68
59
|
'top-left',
|
|
69
60
|
'top-right',
|
|
70
61
|
];
|
|
71
|
-
this.zoneSubscription = this.
|
|
62
|
+
this.zoneSubscription = this.ngZone.onStable.subscribe(() => {
|
|
72
63
|
this._positionMenu();
|
|
73
64
|
});
|
|
74
|
-
this.iconService =
|
|
65
|
+
this.iconService = injector.get(SACICON_SERVICE, new SacDefaultIconService());
|
|
75
66
|
}
|
|
67
|
+
// #endregion Constructors
|
|
68
|
+
// #region Public Getters And Setters
|
|
76
69
|
/**
|
|
77
|
-
*
|
|
70
|
+
* icon for default context menü button
|
|
78
71
|
*/
|
|
79
|
-
|
|
80
|
-
this.
|
|
72
|
+
get IconContextMenu() {
|
|
73
|
+
return this.iconService.ContextMenuOpenIcon;
|
|
81
74
|
}
|
|
75
|
+
// #endregion Public Getters And Setters
|
|
76
|
+
// #region Public Methods
|
|
82
77
|
/**
|
|
83
|
-
*
|
|
78
|
+
* HostListener um das Dropdown zu schliessen wenn nicht auf das Element geklickt wird.
|
|
84
79
|
*/
|
|
85
|
-
|
|
86
|
-
|
|
80
|
+
onClick(targetElement) {
|
|
81
|
+
const anchor = this._anchor || this._anchorTemplate;
|
|
82
|
+
if (this._menu &&
|
|
83
|
+
!this._menu.nativeElement.contains(targetElement) &&
|
|
84
|
+
!anchor.nativeElement.contains(targetElement)) {
|
|
87
85
|
this.close();
|
|
88
86
|
}
|
|
89
|
-
else {
|
|
90
|
-
this.open();
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
/**
|
|
94
|
-
* Öffnet das Dropdown / Zeigt das Menü an.
|
|
95
|
-
*/
|
|
96
|
-
open() {
|
|
97
|
-
this._applyContainer(this.container);
|
|
98
|
-
this.isopen = true;
|
|
99
87
|
}
|
|
100
88
|
/**
|
|
101
89
|
* Schliesst das Dropdown
|
|
@@ -105,11 +93,31 @@ class SacContextmenuCommon {
|
|
|
105
93
|
this.isopen = false;
|
|
106
94
|
}
|
|
107
95
|
/**
|
|
108
|
-
*
|
|
96
|
+
* Event wenn Component entfernt wird.
|
|
109
97
|
*/
|
|
110
|
-
|
|
111
|
-
|
|
98
|
+
ngOnDestroy() {
|
|
99
|
+
this.zoneSubscription.unsubscribe();
|
|
100
|
+
}
|
|
101
|
+
/**
|
|
102
|
+
* Öffnet das Dropdown / Zeigt das Menü an.
|
|
103
|
+
*/
|
|
104
|
+
open() {
|
|
105
|
+
this._applyContainer(this.container);
|
|
106
|
+
this.isopen = true;
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* Toggle von Dropdown
|
|
110
|
+
*/
|
|
111
|
+
toggle() {
|
|
112
|
+
if (this.isopen) {
|
|
113
|
+
this.close();
|
|
114
|
+
}
|
|
115
|
+
else {
|
|
116
|
+
this.open();
|
|
117
|
+
}
|
|
112
118
|
}
|
|
119
|
+
// #endregion Public Methods
|
|
120
|
+
// #region Protected Methods
|
|
113
121
|
/**
|
|
114
122
|
* Setzt die Position des Menüs im Markup
|
|
115
123
|
*/
|
|
@@ -119,23 +127,8 @@ class SacContextmenuCommon {
|
|
|
119
127
|
positionElements(anchor.nativeElement, this.bodyContainer || this._menu.nativeElement, this.placement, this.container === 'body');
|
|
120
128
|
}
|
|
121
129
|
}
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
*/
|
|
125
|
-
_resetContainer() {
|
|
126
|
-
const renderer = this._renderer;
|
|
127
|
-
if (this._menu) {
|
|
128
|
-
const dropdownElement = this._elementRef.nativeElement;
|
|
129
|
-
const dropdownMenuElement = this._menu.nativeElement;
|
|
130
|
-
renderer.appendChild(dropdownElement, dropdownMenuElement);
|
|
131
|
-
renderer.removeStyle(dropdownMenuElement, 'position');
|
|
132
|
-
renderer.removeStyle(dropdownMenuElement, 'transform');
|
|
133
|
-
}
|
|
134
|
-
if (this.bodyContainer) {
|
|
135
|
-
renderer.removeChild(this._document.body, this.bodyContainer);
|
|
136
|
-
this.bodyContainer = null;
|
|
137
|
-
}
|
|
138
|
-
}
|
|
130
|
+
// #endregion Protected Methods
|
|
131
|
+
// #region Private Methods
|
|
139
132
|
/**
|
|
140
133
|
* Setzt die Position des Menüs innerhalb der Seite. Die Ausrichtung passiert innerhalb der Seite
|
|
141
134
|
* damit das Menü innerhalb eines Dialogs sauber funktionioniert.
|
|
@@ -145,7 +138,7 @@ class SacContextmenuCommon {
|
|
|
145
138
|
// Reset Classes on Container
|
|
146
139
|
this._resetContainer();
|
|
147
140
|
if (container === 'body') {
|
|
148
|
-
const renderer = this.
|
|
141
|
+
const renderer = this.renderer;
|
|
149
142
|
const dropdownMenuElement = this._menu.nativeElement;
|
|
150
143
|
const bodyContainer = (this.bodyContainer =
|
|
151
144
|
this.bodyContainer || renderer.createElement('div'));
|
|
@@ -154,11 +147,28 @@ class SacContextmenuCommon {
|
|
|
154
147
|
renderer.setStyle(dropdownMenuElement, 'position', 'static');
|
|
155
148
|
renderer.setStyle(bodyContainer, 'z-index', '1050');
|
|
156
149
|
renderer.appendChild(bodyContainer, dropdownMenuElement);
|
|
157
|
-
renderer.appendChild(this.
|
|
150
|
+
renderer.appendChild(this.document.body, bodyContainer);
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
/**
|
|
154
|
+
* Setzt die CSS Klassen auf dem Menü Container auf den Standard zurück
|
|
155
|
+
*/
|
|
156
|
+
_resetContainer() {
|
|
157
|
+
const renderer = this.renderer;
|
|
158
|
+
if (this._menu) {
|
|
159
|
+
const dropdownElement = this.elementRef.nativeElement;
|
|
160
|
+
const dropdownMenuElement = this._menu.nativeElement;
|
|
161
|
+
renderer.appendChild(dropdownElement, dropdownMenuElement);
|
|
162
|
+
renderer.removeStyle(dropdownMenuElement, 'position');
|
|
163
|
+
renderer.removeStyle(dropdownMenuElement, 'transform');
|
|
164
|
+
}
|
|
165
|
+
if (this.bodyContainer) {
|
|
166
|
+
renderer.removeChild(this.document.body, this.bodyContainer);
|
|
167
|
+
this.bodyContainer = null;
|
|
158
168
|
}
|
|
159
169
|
}
|
|
160
170
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacContextmenuCommon, deps: [{ token: DOCUMENT }, { token: i0.NgZone }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
161
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: SacContextmenuCommon, inputs: {
|
|
171
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: SacContextmenuCommon, inputs: { buttontemplate: "buttontemplate", container: "container", cssclass: "cssclass", isopen: "isopen", placement: "placement" }, host: { listeners: { "document:click": "onClick($event.target)" } }, queries: [{ propertyName: "_anchorTemplate", first: true, predicate: SacContextmenuAnchorCommon, descendants: true }], viewQueries: [{ propertyName: "_anchor", first: true, predicate: SacContextmenuAnchorCommon, descendants: true }, { propertyName: "_menu", first: true, predicate: SacContextMenuContrainerCommon, descendants: true }], ngImport: i0 }); }
|
|
162
172
|
}
|
|
163
173
|
export { SacContextmenuCommon };
|
|
164
174
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacContextmenuCommon, decorators: [{
|
|
@@ -166,27 +176,27 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
166
176
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
167
177
|
type: Inject,
|
|
168
178
|
args: [DOCUMENT]
|
|
169
|
-
}] }, { type: i0.NgZone }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.Injector }]; }, propDecorators: {
|
|
170
|
-
type: ViewChild,
|
|
171
|
-
args: [SacContextmenuAnchorCommon, { static: false }]
|
|
172
|
-
}], _anchorTemplate: [{
|
|
179
|
+
}] }, { type: i0.NgZone }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.Injector }]; }, propDecorators: { _anchorTemplate: [{
|
|
173
180
|
type: ContentChild,
|
|
174
181
|
args: [SacContextmenuAnchorCommon, { static: false }]
|
|
182
|
+
}], _anchor: [{
|
|
183
|
+
type: ViewChild,
|
|
184
|
+
args: [SacContextmenuAnchorCommon, { static: false }]
|
|
175
185
|
}], _menu: [{
|
|
176
186
|
type: ViewChild,
|
|
177
187
|
args: [SacContextMenuContrainerCommon, { static: false }]
|
|
178
|
-
}], isopen: [{
|
|
179
|
-
type: Input
|
|
180
|
-
}], cssclass: [{
|
|
181
|
-
type: Input
|
|
182
188
|
}], buttontemplate: [{
|
|
183
189
|
type: Input
|
|
184
190
|
}], container: [{
|
|
185
191
|
type: Input
|
|
192
|
+
}], cssclass: [{
|
|
193
|
+
type: Input
|
|
194
|
+
}], isopen: [{
|
|
195
|
+
type: Input
|
|
186
196
|
}], placement: [{
|
|
187
197
|
type: Input
|
|
188
198
|
}], onClick: [{
|
|
189
199
|
type: HostListener,
|
|
190
200
|
args: ['document:click', ['$event.target']]
|
|
191
201
|
}] } });
|
|
192
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contextmenu.js","sourceRoot":"","sources":["../../../../../projects/sac-common/src/controls/contextmenu/contextmenu.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\r\nimport {\r\n  ContentChild,\r\n  Directive,\r\n  ElementRef,\r\n  HostListener,\r\n  Inject,\r\n  Injector,\r\n  Input,\r\n  NgZone,\r\n  OnDestroy,\r\n  Renderer2,\r\n  TemplateRef,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { ISacIconService } from '../../interfaces/ISacIconService';\r\nimport { SACICON_SERVICE, SacDefaultIconService } from '../../services';\r\nimport { PlacementArray, positionElements } from '../../utilities/positioning';\r\nimport { SacContextmenuAnchorCommon } from './contextmenuanchor';\r\nimport { SacContextMenuContrainerCommon } from './contextmenucontainer';\r\n\r\n/**\r\n * Base Context Menü Element. Die Logik wurde aus NG-BOOTSTRAP übernommen.\r\n */\r\n@Directive()\r\nexport class SacContextmenuCommon implements OnDestroy {\r\n  /**\r\n   * Zone Subscription für Postitonierung des Elements\r\n   */\r\n  private zoneSubscription: Subscription;\r\n  /**\r\n   * Body HTML Element\r\n   */\r\n  private bodyContainer: HTMLElement | null = null;\r\n\r\n  /**\r\n   * Button für Open/Close Event\r\n   */\r\n  @ViewChild(SacContextmenuAnchorCommon, { static: false })\r\n  private _anchor: SacContextmenuAnchorCommon;\r\n\r\n  /**\r\n   * Button für Open/Close Event aus Template\r\n   */\r\n  @ContentChild(SacContextmenuAnchorCommon, { static: false })\r\n  private _anchorTemplate: SacContextmenuAnchorCommon;\r\n\r\n  /**\r\n   * Container Element für Dropdown\r\n   */\r\n  @ViewChild(SacContextMenuContrainerCommon, { static: false })\r\n  private _menu: SacContextMenuContrainerCommon;\r\n\r\n  /**\r\n   * icon service\r\n   */\r\n  protected iconService: ISacIconService;\r\n\r\n  /**\r\n   * Definiert ob das Dropdown offen ist.\r\n   */\r\n  @Input()\r\n  public isopen: boolean = false;\r\n\r\n  /**\r\n   * Extra CSS Klassen für das Control\r\n   */\r\n  @Input()\r\n  public cssclass: string = '';\r\n\r\n  /**\r\n   * Custom HTML Template für Dropdown Button. Button muss den Marker \"ngContextmenuAnchor\" beinhalten, damit das Control korrekt funktioniert.\r\n   */\r\n  @Input()\r\n  public buttontemplate: TemplateRef<any>;\r\n\r\n  /**\r\n   * Container an welchem die Position ausgerichtet wird. Aktuell wird nun Body Supported\r\n   */\r\n  @Input()\r\n  public container: null | 'body' = 'body';\r\n\r\n  /**\r\n   * The preferred placement of the dropdown.\r\n   *\r\n   * Possible values are `\"top\"`, `\"top-left\"`, `\"top-right\"`, `\"bottom\"`, `\"bottom-left\"`,\r\n   * `\"bottom-right\"`, `\"left\"`, `\"left-top\"`, `\"left-bottom\"`, `\"right\"`, `\"right-top\"`,\r\n   * `\"right-bottom\"`\r\n   *\r\n   * Accepts an array of strings or a string with space separated possible values.\r\n   *\r\n   * The default order of preference is `\"bottom-left bottom-right top-left top-right\"`\r\n   *\r\n   * Please see the [positioning overview](#/positioning) for more details.\r\n   */\r\n  @Input() placement: PlacementArray = [\r\n    'bottom-left',\r\n    'bottom-right',\r\n    'top-left',\r\n    'top-right',\r\n  ];\r\n\r\n  /**\r\n   * HostListener um das Dropdown zu schliessen wenn nicht auf das Element geklickt wird.\r\n   */\r\n  @HostListener('document:click', ['$event.target'])\r\n  /**\r\n   * Click Event\r\n   */\r\n  public onClick(targetElement) {\r\n    const anchor: SacContextmenuAnchorCommon =\r\n      this._anchor || this._anchorTemplate;\r\n\r\n    if (\r\n      this._menu &&\r\n      !this._menu.nativeElement.contains(targetElement) &&\r\n      !anchor.nativeElement.contains(targetElement)\r\n    ) {\r\n      this.close();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Konstruktor\r\n   * @param _document HTML Document Element\r\n   * @param _ngZone Angular Zone Service\r\n   * @param _elementRef HTML Element des aktuellen Controls\r\n   * @param _renderer Angular Rendering Service\r\n   * @param _injector injector to resolve the icon service\r\n   */\r\n  constructor(\r\n    @Inject(DOCUMENT) private _document: any,\r\n    private _ngZone: NgZone,\r\n    private _elementRef: ElementRef<HTMLElement>,\r\n    private _renderer: Renderer2,\r\n    _injector: Injector\r\n  ) {\r\n    this.zoneSubscription = this._ngZone.onStable.subscribe(() => {\r\n      this._positionMenu();\r\n    });\r\n\r\n    this.iconService = _injector.get(\r\n      SACICON_SERVICE,\r\n      new SacDefaultIconService()\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Event wenn Component entfernt wird.\r\n   */\r\n  ngOnDestroy(): void {\r\n    this.zoneSubscription.unsubscribe();\r\n  }\r\n\r\n  /**\r\n   * Toggle von Dropdown\r\n   */\r\n  public toggle(): void {\r\n    if (this.isopen) {\r\n      this.close();\r\n    } else {\r\n      this.open();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Öffnet das Dropdown / Zeigt das Menü an.\r\n   */\r\n  public open(): void {\r\n    this._applyContainer(this.container);\r\n    this.isopen = true;\r\n  }\r\n\r\n  /**\r\n   * Schliesst das Dropdown\r\n   */\r\n  public close(): void {\r\n    this._resetContainer();\r\n    this.isopen = false;\r\n  }\r\n\r\n  /**\r\n   * icon for default context menü button\r\n   */\r\n  public get IconContextMenu(): string {\r\n    return this.iconService.ContextMenuOpenIcon;\r\n  }\r\n\r\n  /**\r\n   * Setzt die Position des Menüs im Markup\r\n   */\r\n  protected _positionMenu() {\r\n    const anchor: SacContextmenuAnchorCommon =\r\n      this._anchor || this._anchorTemplate;\r\n\r\n    if (anchor && this._menu) {\r\n      positionElements(\r\n        anchor.nativeElement,\r\n        this.bodyContainer || this._menu.nativeElement,\r\n        this.placement,\r\n        this.container === 'body'\r\n      );\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Setzt die CSS Klassen auf dem Menü Container auf den Standard zurück\r\n   */\r\n  private _resetContainer() {\r\n    const renderer = this._renderer;\r\n    if (this._menu) {\r\n      const dropdownElement = this._elementRef.nativeElement;\r\n      const dropdownMenuElement = this._menu.nativeElement;\r\n\r\n      renderer.appendChild(dropdownElement, dropdownMenuElement);\r\n      renderer.removeStyle(dropdownMenuElement, 'position');\r\n      renderer.removeStyle(dropdownMenuElement, 'transform');\r\n    }\r\n    if (this.bodyContainer) {\r\n      renderer.removeChild(this._document.body, this.bodyContainer);\r\n      this.bodyContainer = null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Setzt die Position des Menüs innerhalb der Seite. Die Ausrichtung passiert innerhalb der Seite\r\n   * damit das Menü innerhalb eines Dialogs sauber funktionioniert.\r\n   * @param container Definiert wo das Menü ausgerichtet wird. Im Moment nur BODY Supported\r\n   */\r\n  private _applyContainer(container: null | 'body' = null) {\r\n    // Reset Classes on Container\r\n    this._resetContainer();\r\n\r\n    if (container === 'body') {\r\n      const renderer = this._renderer;\r\n      const dropdownMenuElement = this._menu.nativeElement;\r\n      const bodyContainer = (this.bodyContainer =\r\n        this.bodyContainer || renderer.createElement('div'));\r\n\r\n      // Override some styles to have the positioning working\r\n      renderer.setStyle(bodyContainer, 'position', 'absolute');\r\n      renderer.setStyle(dropdownMenuElement, 'position', 'static');\r\n      renderer.setStyle(bodyContainer, 'z-index', '1050');\r\n\r\n      renderer.appendChild(bodyContainer, dropdownMenuElement);\r\n      renderer.appendChild(this._document.body, bodyContainer);\r\n    }\r\n  }\r\n}\r\n"]}
|
|
202
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contextmenu.js","sourceRoot":"","sources":["../../../../../projects/sac-common/src/controls/contextmenu/contextmenu.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\r\nimport {\r\n  ContentChild,\r\n  Directive,\r\n  ElementRef,\r\n  HostListener,\r\n  Inject,\r\n  Injector,\r\n  Input,\r\n  NgZone,\r\n  OnDestroy,\r\n  Renderer2,\r\n  TemplateRef,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { ISacIconService } from '../../interfaces/ISacIconService';\r\nimport { SACICON_SERVICE, SacDefaultIconService } from '../../services';\r\nimport { PlacementArray, positionElements } from '../../utilities/positioning';\r\nimport { SacContextmenuAnchorCommon } from './contextmenuanchor';\r\nimport { SacContextMenuContrainerCommon } from './contextmenucontainer';\r\n\r\n/**\r\n * Base Context Menü Element. Die Logik wurde aus NG-BOOTSTRAP übernommen.\r\n */\r\n@Directive()\r\nexport class SacContextmenuCommon implements OnDestroy {\r\n  // #region Properties\r\n\r\n  /**\r\n   * Button für Open/Close Event aus Template\r\n   */\r\n  @ContentChild(SacContextmenuAnchorCommon, { static: false })\r\n  private _anchorTemplate: SacContextmenuAnchorCommon;\r\n  /**\r\n   * Button für Open/Close Event\r\n   */\r\n  @ViewChild(SacContextmenuAnchorCommon, { static: false })\r\n  private _anchor: SacContextmenuAnchorCommon;\r\n  /**\r\n   * Container Element für Dropdown\r\n   */\r\n  @ViewChild(SacContextMenuContrainerCommon, { static: false })\r\n  private _menu: SacContextMenuContrainerCommon;\r\n\r\n  /**\r\n   * Body HTML Element\r\n   */\r\n  private bodyContainer: HTMLElement | null = null;\r\n  /**\r\n   * Zone Subscription für Postitonierung des Elements\r\n   */\r\n  private zoneSubscription: Subscription;\r\n\r\n  /**\r\n   * icon service\r\n   */\r\n  protected iconService: ISacIconService;\r\n\r\n  /**\r\n   * Custom HTML Template für Dropdown Button. Button muss den Marker \"ngContextmenuAnchor\" beinhalten, damit das Control korrekt funktioniert.\r\n   */\r\n  @Input()\r\n  public buttontemplate: TemplateRef<any>;\r\n  /**\r\n   * Container an welchem die Position ausgerichtet wird. Aktuell wird nun Body Supported\r\n   */\r\n  @Input()\r\n  public container: null | 'body' = 'body';\r\n  /**\r\n   * Extra CSS Klassen für das Control\r\n   */\r\n  @Input()\r\n  public cssclass: string = '';\r\n  /**\r\n   * Definiert ob das Dropdown offen ist.\r\n   */\r\n  @Input()\r\n  public isopen: boolean = false;\r\n  /**\r\n   * The preferred placement of the dropdown.\r\n   *\r\n   * Possible values are `\"top\"`, `\"top-left\"`, `\"top-right\"`, `\"bottom\"`, `\"bottom-left\"`,\r\n   * `\"bottom-right\"`, `\"left\"`, `\"left-top\"`, `\"left-bottom\"`, `\"right\"`, `\"right-top\"`,\r\n   * `\"right-bottom\"`\r\n   *\r\n   * Accepts an array of strings or a string with space separated possible values.\r\n   *\r\n   * The default order of preference is `\"bottom-left bottom-right top-left top-right\"`\r\n   *\r\n   * Please see the [positioning overview](#/positioning) for more details.\r\n   */\r\n  @Input() public placement: PlacementArray = [\r\n    'bottom-left',\r\n    'bottom-right',\r\n    'top-left',\r\n    'top-right',\r\n  ];\r\n\r\n  // #endregion Properties\r\n\r\n  // #region Constructors\r\n\r\n  /**\r\n   * Konstruktor\r\n   * @param document HTML Document Element\r\n   * @param ngZone Angular Zone Service\r\n   * @param elementRef HTML Element des aktuellen Controls\r\n   * @param renderer Angular Rendering Service\r\n   * @param injector injector to resolve the icon service\r\n   */\r\n  constructor(\r\n    @Inject(DOCUMENT) private document: any,\r\n    private ngZone: NgZone,\r\n    private elementRef: ElementRef<HTMLElement>,\r\n    private renderer: Renderer2,\r\n    injector: Injector\r\n  ) {\r\n    this.zoneSubscription = this.ngZone.onStable.subscribe(() => {\r\n      this._positionMenu();\r\n    });\r\n\r\n    this.iconService = injector.get(\r\n      SACICON_SERVICE,\r\n      new SacDefaultIconService()\r\n    );\r\n  }\r\n\r\n  // #endregion Constructors\r\n\r\n  // #region Public Getters And Setters\r\n\r\n  /**\r\n   * icon for default context menü button\r\n   */\r\n  public get IconContextMenu(): string {\r\n    return this.iconService.ContextMenuOpenIcon;\r\n  }\r\n\r\n  // #endregion Public Getters And Setters\r\n\r\n  // #region Public Methods\r\n\r\n  /**\r\n   * HostListener um das Dropdown zu schliessen wenn nicht auf das Element geklickt wird.\r\n   */\r\n  @HostListener('document:click', ['$event.target'])\r\n  /**\r\n   * Click Event\r\n   */\r\n  public onClick(targetElement) {\r\n    const anchor: SacContextmenuAnchorCommon =\r\n      this._anchor || this._anchorTemplate;\r\n\r\n    if (\r\n      this._menu &&\r\n      !this._menu.nativeElement.contains(targetElement) &&\r\n      !anchor.nativeElement.contains(targetElement)\r\n    ) {\r\n      this.close();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Schliesst das Dropdown\r\n   */\r\n  public close(): void {\r\n    this._resetContainer();\r\n    this.isopen = false;\r\n  }\r\n\r\n  /**\r\n   * Event wenn Component entfernt wird.\r\n   */\r\n  public ngOnDestroy(): void {\r\n    this.zoneSubscription.unsubscribe();\r\n  }\r\n\r\n  /**\r\n   * Öffnet das Dropdown / Zeigt das Menü an.\r\n   */\r\n  public open(): void {\r\n    this._applyContainer(this.container);\r\n    this.isopen = true;\r\n  }\r\n\r\n  /**\r\n   * Toggle von Dropdown\r\n   */\r\n  public toggle(): void {\r\n    if (this.isopen) {\r\n      this.close();\r\n    } else {\r\n      this.open();\r\n    }\r\n  }\r\n\r\n  // #endregion Public Methods\r\n\r\n  // #region Protected Methods\r\n\r\n  /**\r\n   * Setzt die Position des Menüs im Markup\r\n   */\r\n  protected _positionMenu() {\r\n    const anchor: SacContextmenuAnchorCommon =\r\n      this._anchor || this._anchorTemplate;\r\n\r\n    if (anchor && this._menu) {\r\n      positionElements(\r\n        anchor.nativeElement,\r\n        this.bodyContainer || this._menu.nativeElement,\r\n        this.placement,\r\n        this.container === 'body'\r\n      );\r\n    }\r\n  }\r\n\r\n  // #endregion Protected Methods\r\n\r\n  // #region Private Methods\r\n\r\n  /**\r\n   * Setzt die Position des Menüs innerhalb der Seite. Die Ausrichtung passiert innerhalb der Seite\r\n   * damit das Menü innerhalb eines Dialogs sauber funktionioniert.\r\n   * @param container Definiert wo das Menü ausgerichtet wird. Im Moment nur BODY Supported\r\n   */\r\n  private _applyContainer(container: null | 'body' = null) {\r\n    // Reset Classes on Container\r\n    this._resetContainer();\r\n\r\n    if (container === 'body') {\r\n      const renderer = this.renderer;\r\n      const dropdownMenuElement = this._menu.nativeElement;\r\n      const bodyContainer = (this.bodyContainer =\r\n        this.bodyContainer || renderer.createElement('div'));\r\n\r\n      // Override some styles to have the positioning working\r\n      renderer.setStyle(bodyContainer, 'position', 'absolute');\r\n      renderer.setStyle(dropdownMenuElement, 'position', 'static');\r\n      renderer.setStyle(bodyContainer, 'z-index', '1050');\r\n\r\n      renderer.appendChild(bodyContainer, dropdownMenuElement);\r\n      renderer.appendChild(this.document.body, bodyContainer);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Setzt die CSS Klassen auf dem Menü Container auf den Standard zurück\r\n   */\r\n  private _resetContainer() {\r\n    const renderer = this.renderer;\r\n    if (this._menu) {\r\n      const dropdownElement = this.elementRef.nativeElement;\r\n      const dropdownMenuElement = this._menu.nativeElement;\r\n\r\n      renderer.appendChild(dropdownElement, dropdownMenuElement);\r\n      renderer.removeStyle(dropdownMenuElement, 'position');\r\n      renderer.removeStyle(dropdownMenuElement, 'transform');\r\n    }\r\n    if (this.bodyContainer) {\r\n      renderer.removeChild(this.document.body, this.bodyContainer);\r\n      this.bodyContainer = null;\r\n    }\r\n  }\r\n\r\n  // #endregion Private Methods\r\n}\r\n"]}
|
|
@@ -4,12 +4,14 @@ import * as i0 from "@angular/core";
|
|
|
4
4
|
* Base Context Menu Anchor Component für Open/Close Event
|
|
5
5
|
*/
|
|
6
6
|
class SacContextmenuAnchorCommon {
|
|
7
|
+
// #endregion Properties
|
|
8
|
+
// #region Constructors
|
|
7
9
|
/**
|
|
8
10
|
* Konstruktor
|
|
9
|
-
* @param
|
|
11
|
+
* @param elementRef Refernz auf das HTML welcher als Anker für das Context Menü verwendet wird
|
|
10
12
|
*/
|
|
11
|
-
constructor(
|
|
12
|
-
this.nativeElement =
|
|
13
|
+
constructor(elementRef) {
|
|
14
|
+
this.nativeElement = elementRef.nativeElement;
|
|
13
15
|
}
|
|
14
16
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacContextmenuAnchorCommon, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
15
17
|
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: SacContextmenuAnchorCommon, ngImport: i0 }); }
|
|
@@ -18,4 +20,4 @@ export { SacContextmenuAnchorCommon };
|
|
|
18
20
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacContextmenuAnchorCommon, decorators: [{
|
|
19
21
|
type: Directive
|
|
20
22
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGV4dG1lbnVhbmNob3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zYWMtY29tbW9uL3NyYy9jb250cm9scy9jb250ZXh0bWVudS9jb250ZXh0bWVudWFuY2hvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLE1BQU0sZUFBZSxDQUFDOztBQUV0RDs7R0FFRztBQUNILE1BQ2EsMEJBQTBCO0lBUXJDLHdCQUF3QjtJQUV4Qix1QkFBdUI7SUFFdkI7OztPQUdHO0lBQ0gsWUFBWSxVQUFtQztRQUM3QyxJQUFJLENBQUMsYUFBYSxHQUFHLFVBQVUsQ0FBQyxhQUFhLENBQUM7SUFDaEQsQ0FBQzsrR0FsQlUsMEJBQTBCO21HQUExQiwwQkFBMEI7O1NBQTFCLDBCQUEwQjs0RkFBMUIsMEJBQTBCO2tCQUR0QyxTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG4vKipcclxuICogQmFzZSBDb250ZXh0IE1lbnUgQW5jaG9yIENvbXBvbmVudCBmw7xyIE9wZW4vQ2xvc2UgRXZlbnRcclxuICovXHJcbkBEaXJlY3RpdmUoKVxyXG5leHBvcnQgY2xhc3MgU2FjQ29udGV4dG1lbnVBbmNob3JDb21tb24ge1xyXG4gIC8vICNyZWdpb24gUHJvcGVydGllc1xyXG5cclxuICAvKipcclxuICAgKiBSZWZlcmVueiBhdWYgZGFzIE5hdGl2ZSBIVE1MIEVsZW1lbnRcclxuICAgKi9cclxuICBwdWJsaWMgbmF0aXZlRWxlbWVudDogSFRNTEVsZW1lbnQ7XHJcblxyXG4gIC8vICNlbmRyZWdpb24gUHJvcGVydGllc1xyXG5cclxuICAvLyAjcmVnaW9uIENvbnN0cnVjdG9yc1xyXG5cclxuICAvKipcclxuICAgKiBLb25zdHJ1a3RvclxyXG4gICAqIEBwYXJhbSBlbGVtZW50UmVmIFJlZmVybnogYXVmIGRhcyBIVE1MIHdlbGNoZXIgYWxzIEFua2VyIGbDvHIgZGFzIENvbnRleHQgTWVuw7wgdmVyd2VuZGV0IHdpcmRcclxuICAgKi9cclxuICBjb25zdHJ1Y3RvcihlbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50Pikge1xyXG4gICAgdGhpcy5uYXRpdmVFbGVtZW50ID0gZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50O1xyXG4gIH1cclxuXHJcbiAgLy8gI2VuZHJlZ2lvbiBDb25zdHJ1Y3RvcnNcclxufVxyXG4iXX0=
|
|
@@ -4,12 +4,14 @@ import * as i0 from "@angular/core";
|
|
|
4
4
|
* Common Marker Klasse für den Menü Container
|
|
5
5
|
*/
|
|
6
6
|
class SacContextMenuContrainerCommon {
|
|
7
|
+
// #endregion Properties
|
|
8
|
+
// #region Constructors
|
|
7
9
|
/**
|
|
8
10
|
* Konstruktor
|
|
9
|
-
* @param
|
|
11
|
+
* @param elementRef Referenz auf das HTML Element mit der Marker Direktive
|
|
10
12
|
*/
|
|
11
|
-
constructor(
|
|
12
|
-
this.nativeElement =
|
|
13
|
+
constructor(elementRef) {
|
|
14
|
+
this.nativeElement = elementRef.nativeElement;
|
|
13
15
|
}
|
|
14
16
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacContextMenuContrainerCommon, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
15
17
|
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: SacContextMenuContrainerCommon, ngImport: i0 }); }
|
|
@@ -18,4 +20,4 @@ export { SacContextMenuContrainerCommon };
|
|
|
18
20
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacContextMenuContrainerCommon, decorators: [{
|
|
19
21
|
type: Directive
|
|
20
22
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGV4dG1lbnVjb250YWluZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zYWMtY29tbW9uL3NyYy9jb250cm9scy9jb250ZXh0bWVudS9jb250ZXh0bWVudWNvbnRhaW5lci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLE1BQU0sZUFBZSxDQUFDOztBQUV0RDs7R0FFRztBQUNILE1BQ2EsOEJBQThCO0lBUXpDLHdCQUF3QjtJQUV4Qix1QkFBdUI7SUFFdkI7OztPQUdHO0lBQ0gsWUFBWSxVQUFtQztRQUM3QyxJQUFJLENBQUMsYUFBYSxHQUFHLFVBQVUsQ0FBQyxhQUFhLENBQUM7SUFDaEQsQ0FBQzsrR0FsQlUsOEJBQThCO21HQUE5Qiw4QkFBOEI7O1NBQTlCLDhCQUE4Qjs0RkFBOUIsOEJBQThCO2tCQUQxQyxTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG4vKipcclxuICogQ29tbW9uIE1hcmtlciBLbGFzc2UgZsO8ciBkZW4gTWVuw7wgQ29udGFpbmVyXHJcbiAqL1xyXG5ARGlyZWN0aXZlKClcclxuZXhwb3J0IGNsYXNzIFNhY0NvbnRleHRNZW51Q29udHJhaW5lckNvbW1vbiB7XHJcbiAgLy8gI3JlZ2lvbiBQcm9wZXJ0aWVzXHJcblxyXG4gIC8qKlxyXG4gICAqIFJlZmVyZW56IGF1ZiBkYXMgSFRNTCBFbGVtZW50IGRlcyBNZW7DvCBDb250YWluZXJzXHJcbiAgICovXHJcbiAgcHVibGljIG5hdGl2ZUVsZW1lbnQ6IEhUTUxFbGVtZW50O1xyXG5cclxuICAvLyAjZW5kcmVnaW9uIFByb3BlcnRpZXNcclxuXHJcbiAgLy8gI3JlZ2lvbiBDb25zdHJ1Y3RvcnNcclxuXHJcbiAgLyoqXHJcbiAgICogS29uc3RydWt0b3JcclxuICAgKiBAcGFyYW0gZWxlbWVudFJlZiBSZWZlcmVueiBhdWYgZGFzIEhUTUwgRWxlbWVudCBtaXQgZGVyIE1hcmtlciBEaXJla3RpdmVcclxuICAgKi9cclxuICBjb25zdHJ1Y3RvcihlbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50Pikge1xyXG4gICAgdGhpcy5uYXRpdmVFbGVtZW50ID0gZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50O1xyXG4gIH1cclxuXHJcbiAgLy8gI2VuZHJlZ2lvbiBDb25zdHJ1Y3RvcnNcclxufVxyXG4iXX0=
|