@simpleangularcontrols/sac-common 10.0.0-rc.2 → 10.0.0-rc.21
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/simpleangularcontrols-sac-common.umd.js +2232 -1604
- package/bundles/simpleangularcontrols-sac-common.umd.js.map +1 -1
- package/bundles/simpleangularcontrols-sac-common.umd.min.js +1 -1
- package/bundles/simpleangularcontrols-sac-common.umd.min.js.map +1 -1
- package/common/basedatetimecontrol.d.ts +100 -14
- package/common/baseinputcontrol.d.ts +0 -4
- package/common/basemodelcontrol.d.ts +55 -27
- package/common/baseuploadcontrol.d.ts +71 -55
- package/controls/checkbox/checkbox.d.ts +12 -3
- package/controls/checkbox/radiobutton.d.ts +61 -26
- package/controls/contextmenu/contextmenu.d.ts +26 -19
- package/controls/contextmenu/contextmenu.interface.d.ts +3 -0
- package/controls/contextmenu/contextmenuitem.d.ts +5 -0
- package/controls/contextmenu/contextmenuitembutton.d.ts +21 -20
- package/controls/datetime/date.d.ts +28 -31
- package/controls/datetime/datetime.d.ts +27 -31
- package/controls/datetime/time.d.ts +26 -30
- package/controls/dialog/dialog.d.ts +31 -43
- package/controls/grid/grid.d.ts +38 -36
- package/controls/grid/gridbutton.d.ts +13 -13
- package/controls/grid/gridcolumn.d.ts +8 -8
- package/controls/grid/gridcolumnaction.d.ts +3 -3
- package/controls/grid/gridcolumnbase.d.ts +45 -37
- package/controls/grid/gridimage.d.ts +2 -2
- package/controls/grid/model.d.ts +51 -42
- package/controls/grid/paging.d.ts +41 -43
- package/controls/input/input.d.ts +3 -3
- package/controls/input/inputarea.d.ts +5 -5
- package/controls/input/inputpassword.d.ts +7 -7
- package/controls/input/inputsearch.d.ts +13 -4
- package/controls/layout/formlayout.d.ts +17 -1
- package/controls/list/buildvaluestring.d.ts +6 -0
- package/controls/list/dropdown.d.ts +9 -51
- package/controls/list/dropdownoptions.d.ts +38 -0
- package/controls/multilanguage/multilanguageinput.d.ts +2 -2
- package/controls/multilanguage/multilanguageinputarea.d.ts +4 -4
- package/controls/static/formcontainer.d.ts +7 -3
- package/controls/tooltip/tooltip.d.ts +76 -69
- package/controls/treeview/treeview.d.ts +107 -107
- package/esm2015/common/basedatetimecontrol.js +185 -30
- package/esm2015/common/baseinputcontrol.js +2 -7
- package/esm2015/common/basemodelcontrol.js +109 -57
- package/esm2015/common/baseuploadcontrol.js +92 -59
- package/esm2015/controls/checkbox/checkbox.js +29 -6
- package/esm2015/controls/checkbox/radiobutton.js +94 -45
- package/esm2015/controls/contextmenu/contextmenu.interface.js +1 -0
- package/esm2015/controls/contextmenu/contextmenu.interface.ngfactory.js +7 -0
- package/esm2015/controls/contextmenu/contextmenu.js +22 -23
- package/esm2015/controls/contextmenu/contextmenuitem.js +13 -2
- package/esm2015/controls/contextmenu/contextmenuitembutton.js +34 -25
- package/esm2015/controls/datetime/date.js +44 -43
- package/esm2015/controls/datetime/datetime.js +43 -43
- package/esm2015/controls/datetime/time.js +43 -43
- package/esm2015/controls/dialog/dialog.js +41 -83
- package/esm2015/controls/grid/grid.js +21 -21
- package/esm2015/controls/grid/gridbutton.js +19 -13
- package/esm2015/controls/grid/gridcolumn.js +14 -7
- package/esm2015/controls/grid/gridcolumnaction.js +6 -5
- package/esm2015/controls/grid/gridcolumnbase.js +67 -55
- package/esm2015/controls/grid/gridimage.js +3 -3
- package/esm2015/controls/grid/model.js +51 -30
- package/esm2015/controls/grid/paging.js +40 -42
- package/esm2015/controls/input/input.js +6 -8
- package/esm2015/controls/input/inputarea.js +19 -12
- package/esm2015/controls/input/inputpassword.js +12 -12
- package/esm2015/controls/input/inputsearch.js +35 -6
- package/esm2015/controls/layout/formlayout.js +20 -8
- package/esm2015/controls/list/buildvaluestring.js +18 -0
- package/esm2015/controls/{treeview/ngtreeitemaction.ngfactory.js → list/buildvaluestring.ngfactory.js} +1 -1
- package/esm2015/controls/list/dropdown.js +16 -114
- package/esm2015/controls/list/dropdownoptions.js +72 -0
- package/esm2015/controls/{treeview/treeviewchild.ngfactory.js → list/dropdownoptions.ngfactory.js} +1 -1
- package/esm2015/controls/multilanguage/multilanguageinput.js +8 -14
- package/esm2015/controls/multilanguage/multilanguageinputarea.js +9 -15
- package/esm2015/controls/static/formcontainer.js +16 -5
- package/esm2015/controls/tooltip/tooltip.js +126 -245
- package/esm2015/controls/treeview/treeview.js +276 -231
- package/esm2015/interfaces/ISacConfigurationService.js +1 -1
- package/esm2015/interfaces/ISacIconService.js +1 -1
- package/esm2015/interfaces/ISacUploadEventCompleteState.js +1 -0
- package/esm2015/interfaces/ISacUploadEventCompleteState.ngfactory.js +7 -0
- package/esm2015/interfaces/ISacValidationKeyService.js +1 -1
- package/esm2015/interfaces/treeviewaction.interface.js +1 -0
- package/esm2015/interfaces/treeviewaction.interface.ngfactory.js +7 -0
- package/esm2015/public_api.js +15 -8
- package/esm2015/services/sac-configuration.service.js +31 -5
- package/esm2015/services/sac-icon.service.js +37 -1
- package/esm2015/services/sac-localisation.service.js +69 -180
- package/esm2015/services/sac-validationkey.service.js +12 -9
- package/esm2015/simpleangularcontrols-sac-common.js +1 -7
- package/esm2015/utilities/enums.js +5 -1
- package/esm2015/utilities/guid.js +4 -2
- package/esm2015/utilities/popuphelper.js +343 -0
- package/esm2015/utilities/popuphelper.ngfactory.js +7 -0
- package/esm2015/validation/equals.validator.js +14 -0
- package/esm2015/validation/equals.validator.ngfactory.js +7 -0
- package/esm2015/validation/isDateValid.js +9 -1
- package/esm2015/validation/mintextlength.validator.js +23 -0
- package/esm2015/validation/mintextlength.validator.ngfactory.js +7 -0
- package/esm2015/validation/notequals.validator.js +14 -0
- package/esm2015/validation/{minlength.validator.ngfactory.js → notequals.validator.ngfactory.js} +1 -1
- package/esm2015/validation/validation.class.js +35 -6
- package/fesm2015/simpleangularcontrols-sac-common.js +2070 -1498
- package/fesm2015/simpleangularcontrols-sac-common.js.map +1 -1
- package/interfaces/ISacConfigurationService.d.ts +20 -0
- package/interfaces/ISacIconService.d.ts +24 -0
- package/interfaces/ISacUploadEventCompleteState.d.ts +5 -0
- package/interfaces/ISacUploadEventCompleteState.ngfactory.d.ts +1 -0
- package/interfaces/ISacValidationKeyService.d.ts +2 -2
- package/interfaces/treeviewaction.interface.d.ts +4 -0
- package/interfaces/treeviewaction.interface.ngfactory.d.ts +1 -0
- package/package.json +2 -2
- package/public_api.d.ts +13 -6
- package/services/sac-configuration.service.d.ts +40 -0
- package/services/sac-icon.service.d.ts +49 -1
- package/services/sac-localisation.service.d.ts +10 -10
- package/services/sac-validationkey.service.d.ts +7 -7
- package/simpleangularcontrols-sac-common-10.0.0-rc.21.tgz +0 -0
- package/simpleangularcontrols-sac-common.d.ts +0 -6
- package/simpleangularcontrols-sac-common.metadata.json +1 -1
- package/utilities/enums.d.ts +3 -1
- package/utilities/popuphelper.d.ts +83 -0
- package/utilities/popuphelper.ngfactory.d.ts +1 -0
- package/validation/equals.validator.d.ts +2 -0
- package/validation/equals.validator.ngfactory.d.ts +1 -0
- package/validation/mintextlength.validator.d.ts +2 -0
- package/validation/mintextlength.validator.ngfactory.d.ts +1 -0
- package/validation/notequals.validator.d.ts +2 -0
- package/validation/notequals.validator.ngfactory.d.ts +1 -0
- package/validation/validation.class.d.ts +22 -3
- package/controls/treeview/ngtreeitemaction.d.ts +0 -40
- package/controls/treeview/treeviewchild.d.ts +0 -12
- package/esm2015/controls/treeview/ngtreeitemaction.js +0 -60
- package/esm2015/controls/treeview/treeviewchild.js +0 -18
- package/esm2015/validation/minlength.validator.js +0 -21
- package/simpleangularcontrols-sac-common-10.0.0-rc.2.tgz +0 -0
- package/validation/minlength.validator.d.ts +0 -2
- /package/controls/{treeview/ngtreeitemaction.ngfactory.d.ts → contextmenu/contextmenu.interface.ngfactory.d.ts} +0 -0
- /package/controls/{treeview/treeviewchild.ngfactory.d.ts → list/buildvaluestring.ngfactory.d.ts} +0 -0
- /package/{validation/minlength.validator.ngfactory.d.ts → controls/list/dropdownoptions.ngfactory.d.ts} +0 -0
|
@@ -1,14 +1,9 @@
|
|
|
1
|
-
import { Directive, ElementRef, HostListener, Injector, Input, } from '@angular/core';
|
|
2
|
-
import * as IMask from 'imask';
|
|
3
|
-
import * as moment_ from 'moment';
|
|
4
1
|
import { SacBaseDateTimeControl } from '../../common/basedatetimecontrol';
|
|
5
|
-
import { SACICON_SERVICE, SacDefaultIconService } from '../../services';
|
|
6
2
|
import { Validation } from '../../validation';
|
|
7
3
|
import { SacFormLayoutCommon } from '../layout/formlayout';
|
|
8
|
-
|
|
9
|
-
*
|
|
10
|
-
|
|
11
|
-
const moment = moment_['default'];
|
|
4
|
+
import { ChangeDetectorRef, Directive, ElementRef, HostListener, Injector, Input } from '@angular/core';
|
|
5
|
+
import * as IMask from 'imask';
|
|
6
|
+
import * as moment_ from 'moment';
|
|
12
7
|
/**
|
|
13
8
|
* Komponente für SacTimeCommon. Extends SacBaseDateTimeControl
|
|
14
9
|
*/
|
|
@@ -21,9 +16,10 @@ export class SacTimeCommon extends SacBaseDateTimeControl {
|
|
|
21
16
|
* @param injector Injector for injecting services
|
|
22
17
|
* @param elementRef reference to html element
|
|
23
18
|
*/
|
|
24
|
-
constructor(formlayout, injector, elementRef) {
|
|
25
|
-
super(formlayout, injector, elementRef);
|
|
19
|
+
constructor(formlayout, injector, elementRef, cdRef) {
|
|
20
|
+
super(formlayout, injector, elementRef, cdRef);
|
|
26
21
|
this.elementRef = elementRef;
|
|
22
|
+
// #region Properties
|
|
27
23
|
/**
|
|
28
24
|
* Format des Datums
|
|
29
25
|
*/
|
|
@@ -52,6 +48,18 @@ export class SacTimeCommon extends SacBaseDateTimeControl {
|
|
|
52
48
|
lazy: false,
|
|
53
49
|
overwrite: true,
|
|
54
50
|
};
|
|
51
|
+
/**
|
|
52
|
+
* Max Time
|
|
53
|
+
*/
|
|
54
|
+
this._maxtime = null;
|
|
55
|
+
/**
|
|
56
|
+
* Min Time
|
|
57
|
+
*/
|
|
58
|
+
this._mintime = null;
|
|
59
|
+
/**
|
|
60
|
+
* Moment JS module instance
|
|
61
|
+
*/
|
|
62
|
+
this.moment = moment_['default'];
|
|
55
63
|
/**
|
|
56
64
|
* Resource Key für Validation Message MinTime bei Control
|
|
57
65
|
*/
|
|
@@ -68,27 +76,20 @@ export class SacTimeCommon extends SacBaseDateTimeControl {
|
|
|
68
76
|
* Resource Key für Validation Message MinTime in Validation Summary
|
|
69
77
|
*/
|
|
70
78
|
this.validationmessagesummarymintime = this.validationKeyService.ValidationErrorSummaryMinTime;
|
|
71
|
-
/**
|
|
72
|
-
* Max Time
|
|
73
|
-
*/
|
|
74
|
-
this._maxtime = null;
|
|
75
|
-
/**
|
|
76
|
-
* Min Time
|
|
77
|
-
*/
|
|
78
|
-
this._mintime = null;
|
|
79
|
-
/**
|
|
80
|
-
* Definiert ob der Date Selector angezeigt wird
|
|
81
|
-
*/
|
|
82
|
-
this._showselector = false;
|
|
83
|
-
this.iconService = injector.get(SACICON_SERVICE, new SacDefaultIconService());
|
|
84
79
|
}
|
|
85
80
|
// #endregion Constructors
|
|
86
81
|
// #region Public Getters And Setters
|
|
82
|
+
/**
|
|
83
|
+
* icon for date selector button
|
|
84
|
+
*/
|
|
85
|
+
get IconSelector() {
|
|
86
|
+
return this.iconService.TimeComponentSelectorIcon;
|
|
87
|
+
}
|
|
87
88
|
/**
|
|
88
89
|
* Max Time
|
|
89
90
|
*/
|
|
90
91
|
set maxtime(v) {
|
|
91
|
-
let time = moment(v, [this.TIMEFORMAT], true);
|
|
92
|
+
let time = this.moment(v, [this.TIMEFORMAT], true);
|
|
92
93
|
time = this.ModifyParsedDateTimeValue(time);
|
|
93
94
|
if (time.isValid()) {
|
|
94
95
|
this._maxtime = super.getDate(time).toDate();
|
|
@@ -101,7 +102,7 @@ export class SacTimeCommon extends SacBaseDateTimeControl {
|
|
|
101
102
|
* Min Time
|
|
102
103
|
*/
|
|
103
104
|
set mintime(v) {
|
|
104
|
-
let time = moment(v, [this.TIMEFORMAT], true);
|
|
105
|
+
let time = this.moment(v, [this.TIMEFORMAT], true);
|
|
105
106
|
time = this.ModifyParsedDateTimeValue(time);
|
|
106
107
|
if (time.isValid()) {
|
|
107
108
|
this._mintime = super.getDate(time).toDate();
|
|
@@ -110,23 +111,8 @@ export class SacTimeCommon extends SacBaseDateTimeControl {
|
|
|
110
111
|
this._mintime = null;
|
|
111
112
|
}
|
|
112
113
|
}
|
|
113
|
-
/**
|
|
114
|
-
* icon for date selector button
|
|
115
|
-
*/
|
|
116
|
-
get IconSelector() {
|
|
117
|
-
return this.iconService.TimeComponentSelectorIcon;
|
|
118
|
-
}
|
|
119
114
|
// #endregion Public Getters And Setters
|
|
120
115
|
// #region Public Methods
|
|
121
|
-
/**
|
|
122
|
-
* HostListener
|
|
123
|
-
*/
|
|
124
|
-
onClick(targetElement) {
|
|
125
|
-
const clickedInside = this.elementRef.nativeElement.contains(targetElement);
|
|
126
|
-
if (!clickedInside) {
|
|
127
|
-
this._showselector = false;
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
116
|
/**
|
|
131
117
|
* Methode ergibt Datum-Format vom String
|
|
132
118
|
*/
|
|
@@ -142,6 +128,19 @@ export class SacTimeCommon extends SacBaseDateTimeControl {
|
|
|
142
128
|
v.year(1900);
|
|
143
129
|
return v;
|
|
144
130
|
}
|
|
131
|
+
/**
|
|
132
|
+
* HostListener
|
|
133
|
+
*/
|
|
134
|
+
onClick(targetElement) {
|
|
135
|
+
if (!this.pickercontainer) {
|
|
136
|
+
return;
|
|
137
|
+
}
|
|
138
|
+
const clickedInsideContainer = this.pickercontainer.nativeElement.contains(targetElement);
|
|
139
|
+
const clickedInsideReference = this.pickerbutton.nativeElement.contains(targetElement);
|
|
140
|
+
if (!clickedInsideContainer && !clickedInsideReference) {
|
|
141
|
+
this._showselector = false;
|
|
142
|
+
}
|
|
143
|
+
}
|
|
145
144
|
/**
|
|
146
145
|
* Zeigt Date Selector an
|
|
147
146
|
*/
|
|
@@ -163,7 +162,7 @@ export class SacTimeCommon extends SacBaseDateTimeControl {
|
|
|
163
162
|
this.setValueString('');
|
|
164
163
|
}
|
|
165
164
|
else {
|
|
166
|
-
this.value = moment(v.date).utc().toDate();
|
|
165
|
+
this.value = this.moment(v.date).utc().toDate();
|
|
167
166
|
}
|
|
168
167
|
this._showselector = false;
|
|
169
168
|
}
|
|
@@ -198,7 +197,8 @@ SacTimeCommon.decorators = [
|
|
|
198
197
|
SacTimeCommon.ctorParameters = () => [
|
|
199
198
|
{ type: SacFormLayoutCommon },
|
|
200
199
|
{ type: Injector },
|
|
201
|
-
{ type: ElementRef }
|
|
200
|
+
{ type: ElementRef },
|
|
201
|
+
{ type: ChangeDetectorRef }
|
|
202
202
|
];
|
|
203
203
|
SacTimeCommon.propDecorators = {
|
|
204
204
|
validationmessagemaxtime: [{ type: Input }],
|
|
@@ -209,4 +209,4 @@ SacTimeCommon.propDecorators = {
|
|
|
209
209
|
mintime: [{ type: Input }],
|
|
210
210
|
onClick: [{ type: HostListener, args: ['document:click', ['$event.target'],] }]
|
|
211
211
|
};
|
|
212
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["controls/datetime/time.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  ElementRef,\r\n  HostListener,\r\n  Injector,\r\n  Input,\r\n} from '@angular/core';\r\nimport { AbstractControl, ValidationErrors } from '@angular/forms';\r\nimport * as IMask from 'imask';\r\nimport * as moment_ from 'moment';\r\n// Import Moment.JS\r\nimport { Moment } from 'moment';\r\nimport { SacBaseDateTimeControl } from '../../common/basedatetimecontrol';\r\nimport { ISacIconService } from '../../interfaces/ISacIconService';\r\nimport { SACICON_SERVICE, SacDefaultIconService } from '../../services';\r\nimport { Validation } from '../../validation';\r\nimport { SacFormLayoutCommon } from '../layout/formlayout';\r\n\r\n/**\r\n * Moment\r\n */\r\nconst moment = moment_['default'];\r\n\r\n/**\r\n * Komponente für SacTimeCommon. Extends SacBaseDateTimeControl\r\n */\r\n@Directive()\r\nexport class SacTimeCommon extends SacBaseDateTimeControl {\r\n  // #region Properties\r\n\r\n  /**\r\n   * icon service\r\n   */\r\n  private iconService: ISacIconService;\r\n\r\n  /**\r\n   * Format des Datums\r\n   */\r\n  public readonly TIMEFORMAT: string = 'HH:mm';\r\n  /**\r\n   * Maske\r\n   */\r\n  public readonly imaskDate = {\r\n    mask: this.TIMEFORMAT,\r\n    blocks: {\r\n      HH: {\r\n        mask: IMask.MaskedRange,\r\n        from: 0,\r\n        to: 23,\r\n        maxLength: 2,\r\n      },\r\n      mm: {\r\n        mask: IMask.MaskedRange,\r\n        from: 0,\r\n        to: 59,\r\n        maxLength: 2,\r\n      },\r\n    },\r\n    placeholderChar: '_',\r\n    autofix: true,\r\n    lazy: false,\r\n    overwrite: true,\r\n  };\r\n\r\n  /**\r\n   * Resource Key für Validation Message MinTime bei Control\r\n   */\r\n  @Input() public validationmessagemaxtime: string =\r\n    this.validationKeyService.ValidationErrorMaxTime;\r\n  /**\r\n   * Resource Key für Validation Message MinTime bei Control\r\n   */\r\n  @Input() public validationmessagemintime: string =\r\n    this.validationKeyService.ValidationErrorMinTime;\r\n  /**\r\n   * Resource Key für Validation Message MinTime in Validation Summary\r\n   */\r\n  @Input() public validationmessagesummarymaxtime: string =\r\n    this.validationKeyService.ValidationErrorSummaryMaxTime;\r\n  /**\r\n   * Resource Key für Validation Message MinTime in Validation Summary\r\n   */\r\n  @Input() public validationmessagesummarymintime: string =\r\n    this.validationKeyService.ValidationErrorSummaryMinTime;\r\n\r\n  /**\r\n   * Max Time\r\n   */\r\n  public _maxtime: Date = null;\r\n  /**\r\n   * Min Time\r\n   */\r\n  public _mintime: Date = null;\r\n  /**\r\n   * Definiert ob der Date Selector angezeigt wird\r\n   */\r\n  public _showselector: boolean = false;\r\n\r\n  // #endregion Properties\r\n\r\n  // #region Constructors\r\n\r\n  /**\r\n   * Constructor\r\n   * @param formlayout SacFormLayoutCommon to define scoped layout settings\r\n   * @param injector Injector for injecting services\r\n   * @param elementRef reference to html element\r\n   */\r\n  constructor(\r\n    formlayout: SacFormLayoutCommon,\r\n    injector: Injector,\r\n    protected elementRef: ElementRef\r\n  ) {\r\n    super(formlayout, injector, elementRef);\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   * Max Time\r\n   */\r\n  @Input()\r\n  public set maxtime(v: string | Date | null) {\r\n    let time = moment(v, [this.TIMEFORMAT], true);\r\n\r\n    time = this.ModifyParsedDateTimeValue(time);\r\n\r\n    if (time.isValid()) {\r\n      this._maxtime = super.getDate(time).toDate();\r\n    } else {\r\n      this._maxtime = null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Min Time\r\n   */\r\n  @Input()\r\n  public set mintime(v: string | Date | null) {\r\n    let time = moment(v, [this.TIMEFORMAT], true);\r\n\r\n    time = this.ModifyParsedDateTimeValue(time);\r\n\r\n    if (time.isValid()) {\r\n      this._mintime = super.getDate(time).toDate();\r\n    } else {\r\n      this._mintime = null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * icon for date selector button\r\n   */\r\n  public get IconSelector(): string {\r\n    return this.iconService.TimeComponentSelectorIcon;\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\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 clickedInside = this.elementRef.nativeElement.contains(targetElement);\r\n    if (!clickedInside) {\r\n      this._showselector = false;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Methode ergibt Datum-Format vom String\r\n   */\r\n  public GetDateTimeFormatString(): string {\r\n    return this.TIMEFORMAT;\r\n  }\r\n\r\n  /**\r\n   * Methode ergibt Datum - Moment\r\n   */\r\n  public ModifyParsedDateTimeValue(v: Moment): Moment {\r\n    v.date(1);\r\n    v.month(0);\r\n    v.year(1900);\r\n    return v;\r\n  }\r\n\r\n  /**\r\n   * Zeigt Date Selector an\r\n   */\r\n  public showTimeSelector(): void {\r\n    // Touch Event auslösen\r\n    this.onTouch();\r\n\r\n    if (this._showselector) {\r\n      this._showselector = false;\r\n    } else {\r\n      this._showselector = true;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Time Selector\r\n   */\r\n  public timeselect(v: any) {\r\n    if (v.date === null) {\r\n      this.setValueString('');\r\n    } else {\r\n      this.value = moment(v.date).utc().toDate();\r\n    }\r\n\r\n    this._showselector = false;\r\n  }\r\n\r\n  /**\r\n   * Validator\r\n   */\r\n  public validateData(c: AbstractControl): ValidationErrors | null {\r\n    let error: ValidationErrors | null = null;\r\n\r\n    error = super.validateData(c);\r\n\r\n    if (\r\n      error === null &&\r\n      c.value !== null &&\r\n      c.value !== undefined &&\r\n      c.value !== '' &&\r\n      this._mintime !== undefined &&\r\n      this._mintime !== null\r\n    ) {\r\n      error = Validation.minTime(\r\n        this._mintime,\r\n        this.validationmessagemintime,\r\n        this.validationmessagesummarymintime\r\n      )(c);\r\n    }\r\n\r\n    if (\r\n      error === null &&\r\n      c.value !== null &&\r\n      c.value !== undefined &&\r\n      c.value !== '' &&\r\n      this._maxtime !== undefined &&\r\n      this._maxtime !== null\r\n    ) {\r\n      error = Validation.maxTime(\r\n        this._maxtime,\r\n        this.validationmessagemaxtime,\r\n        this.validationmessagesummarymaxtime\r\n      )(c);\r\n    }\r\n\r\n    return error;\r\n  }\r\n\r\n  // #endregion Public Methods\r\n}\r\n"]}
|
|
212
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["controls/datetime/time.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,kCAAkC,CAAC;AAC1E,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAC3D,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAAE,UAAU,EAAE,YAAY,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAExG,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,KAAK,OAAO,MAAM,QAAQ,CAAC;AAElC;;GAEG;AAEH,MAAM,OAAO,aAAc,SAAQ,sBAAsB;IAoErD,wBAAwB;IAExB,uBAAuB;IAEvB;;;;;OAKG;IACH,YACI,UAA+B,EAC/B,QAAkB,EACR,UAAsB,EAChC,KAAwB;QAExB,KAAK,CAAC,UAAU,EAAE,QAAQ,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC;QAHrC,eAAU,GAAV,UAAU,CAAY;QAhFpC,qBAAqB;QAErB;;WAEG;QACa,eAAU,GAAW,OAAO,CAAC;QAE7C;;WAEG;QACa,cAAS,GAAG;YACxB,IAAI,EAAE,IAAI,CAAC,UAAU;YACrB,MAAM,EAAE;gBACJ,EAAE,EAAE;oBACA,IAAI,EAAE,KAAK,CAAC,WAAW;oBACvB,IAAI,EAAE,CAAC;oBACP,EAAE,EAAE,EAAE;oBACN,SAAS,EAAE,CAAC;iBACf;gBACD,EAAE,EAAE;oBACA,IAAI,EAAE,KAAK,CAAC,WAAW;oBACvB,IAAI,EAAE,CAAC;oBACP,EAAE,EAAE,EAAE;oBACN,SAAS,EAAE,CAAC;iBACf;aACJ;YACD,eAAe,EAAE,GAAG;YACpB,OAAO,EAAE,IAAI;YACb,IAAI,EAAE,KAAK;YACX,SAAS,EAAE,IAAI;SAClB,CAAC;QAEF;;WAEG;QACI,aAAQ,GAAS,IAAI,CAAC;QAE7B;;WAEG;QACI,aAAQ,GAAS,IAAI,CAAC;QAE7B;;WAEG;QACI,WAAM,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC;QAEnC;;WAEG;QACa,6BAAwB,GAAW,IAAI,CAAC,oBAAoB,CAAC,sBAAsB,CAAC;QAEpG;;WAEG;QACa,6BAAwB,GAAW,IAAI,CAAC,oBAAoB,CAAC,sBAAsB,CAAC;QAEpG;;WAEG;QACa,oCAA+B,GAAW,IAAI,CAAC,oBAAoB,CAAC,6BAA6B,CAAC;QAElH;;WAEG;QACa,oCAA+B,GAAW,IAAI,CAAC,oBAAoB,CAAC,6BAA6B,CAAC;IAmBlH,CAAC;IAED,0BAA0B;IAE1B,qCAAqC;IAErC;;OAEG;IACH,IAAW,YAAY;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC,yBAAyB,CAAC;IACtD,CAAC;IAED;;OAEG;IACH,IACW,OAAO,CAAC,CAAuB;QACtC,IAAI,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,IAAI,CAAC,CAAC;QAEnD,IAAI,GAAG,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,CAAC;QAE5C,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE;YAChB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC;SAChD;aAAM;YACH,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;SACxB;IACL,CAAC;IAED;;OAEG;IACH,IACW,OAAO,CAAC,CAAuB;QACtC,IAAI,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,IAAI,CAAC,CAAC;QAEnD,IAAI,GAAG,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,CAAC;QAE5C,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE;YAChB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC;SAChD;aAAM;YACH,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;SACxB;IACL,CAAC;IAED,wCAAwC;IAExC,yBAAyB;IAEzB;;OAEG;IACI,uBAAuB;QAC1B,OAAO,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IAED;;OAEG;IACI,yBAAyB,CAAC,CAAiB;QAC9C,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACV,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACX,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACb,OAAO,CAAC,CAAC;IACb,CAAC;IAED;;OAEG;IAKI,OAAO,CAAC,aAAa;QACxB,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;YACvB,OAAO;SACV;QAED,MAAM,sBAAsB,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;QAC1F,MAAM,sBAAsB,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;QACvF,IAAI,CAAC,sBAAsB,IAAI,CAAC,sBAAsB,EAAE;YACpD,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;SAC9B;IACL,CAAC;IAED;;OAEG;IACI,gBAAgB;QACnB,uBAAuB;QACvB,IAAI,CAAC,OAAO,EAAE,CAAC;QAEf,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;SAC9B;aAAM;YACH,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;SAC7B;IACL,CAAC;IAED;;OAEG;IACI,UAAU,CAAC,CAAM;QACpB,IAAI,CAAC,CAAC,IAAI,KAAK,IAAI,EAAE;YACjB,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;SAC3B;aAAM;YACH,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC;SACnD;QAED,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;IAC/B,CAAC;IAED;;OAEG;IACI,YAAY,CAAC,CAAkB;QAClC,IAAI,KAAK,GAA4B,IAAI,CAAC;QAE1C,KAAK,GAAG,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAE9B,IACI,KAAK,KAAK,IAAI;YACd,CAAC,CAAC,KAAK,KAAK,IAAI;YAChB,CAAC,CAAC,KAAK,KAAK,SAAS;YACrB,CAAC,CAAC,KAAK,KAAK,EAAE;YACd,IAAI,CAAC,QAAQ,KAAK,SAAS;YAC3B,IAAI,CAAC,QAAQ,KAAK,IAAI,EACxB;YACE,KAAK,GAAG,UAAU,CAAC,OAAO,CACtB,IAAI,CAAC,QAAQ,EACb,IAAI,CAAC,wBAAwB,EAC7B,IAAI,CAAC,+BAA+B,CACvC,CAAC,CAAC,CAAC,CAAC;SACR;QAED,IACI,KAAK,KAAK,IAAI;YACd,CAAC,CAAC,KAAK,KAAK,IAAI;YAChB,CAAC,CAAC,KAAK,KAAK,SAAS;YACrB,CAAC,CAAC,KAAK,KAAK,EAAE;YACd,IAAI,CAAC,QAAQ,KAAK,SAAS;YAC3B,IAAI,CAAC,QAAQ,KAAK,IAAI,EACxB;YACE,KAAK,GAAG,UAAU,CAAC,OAAO,CACtB,IAAI,CAAC,QAAQ,EACb,IAAI,CAAC,wBAAwB,EAC7B,IAAI,CAAC,+BAA+B,CACvC,CAAC,CAAC,CAAC,CAAC;SACR;QAED,OAAO,KAAK,CAAC;IACjB,CAAC;;;YA7OJ,SAAS;;;YATD,mBAAmB;YACqC,QAAQ;YAAlC,UAAU;YAAxC,iBAAiB;;;uCA4DrB,KAAK;uCAKL,KAAK;8CAKL,KAAK;8CAKL,KAAK;sBAmCL,KAAK;sBAgBL,KAAK;sBAqCL,YAAY,SAAC,gBAAgB,EAAE,CAAC,eAAe,CAAC","sourcesContent":["import { SacBaseDateTimeControl } from '../../common/basedatetimecontrol';\r\nimport { Validation } from '../../validation';\r\nimport { SacFormLayoutCommon } from '../layout/formlayout';\r\nimport { ChangeDetectorRef, Directive, ElementRef, HostListener, Injector, Input } from '@angular/core';\r\nimport { AbstractControl, ValidationErrors } from '@angular/forms';\r\nimport * as IMask from 'imask';\r\nimport * as moment_ from 'moment';\r\n\r\n/**\r\n * Komponente für SacTimeCommon. Extends SacBaseDateTimeControl\r\n */\r\n@Directive()\r\nexport class SacTimeCommon extends SacBaseDateTimeControl {\r\n    // #region Properties\r\n\r\n    /**\r\n     * Format des Datums\r\n     */\r\n    public readonly TIMEFORMAT: string = 'HH:mm';\r\n\r\n    /**\r\n     * Maske\r\n     */\r\n    public readonly imaskDate = {\r\n        mask: this.TIMEFORMAT,\r\n        blocks: {\r\n            HH: {\r\n                mask: IMask.MaskedRange,\r\n                from: 0,\r\n                to: 23,\r\n                maxLength: 2,\r\n            },\r\n            mm: {\r\n                mask: IMask.MaskedRange,\r\n                from: 0,\r\n                to: 59,\r\n                maxLength: 2,\r\n            },\r\n        },\r\n        placeholderChar: '_',\r\n        autofix: true,\r\n        lazy: false,\r\n        overwrite: true,\r\n    };\r\n\r\n    /**\r\n     * Max Time\r\n     */\r\n    public _maxtime: Date = null;\r\n\r\n    /**\r\n     * Min Time\r\n     */\r\n    public _mintime: Date = null;\r\n\r\n    /**\r\n     * Moment JS module instance\r\n     */\r\n    public moment = moment_['default'];\r\n\r\n    /**\r\n     * Resource Key für Validation Message MinTime bei Control\r\n     */\r\n    @Input() public validationmessagemaxtime: string = this.validationKeyService.ValidationErrorMaxTime;\r\n\r\n    /**\r\n     * Resource Key für Validation Message MinTime bei Control\r\n     */\r\n    @Input() public validationmessagemintime: string = this.validationKeyService.ValidationErrorMinTime;\r\n\r\n    /**\r\n     * Resource Key für Validation Message MinTime in Validation Summary\r\n     */\r\n    @Input() public validationmessagesummarymaxtime: string = this.validationKeyService.ValidationErrorSummaryMaxTime;\r\n\r\n    /**\r\n     * Resource Key für Validation Message MinTime in Validation Summary\r\n     */\r\n    @Input() public validationmessagesummarymintime: string = this.validationKeyService.ValidationErrorSummaryMinTime;\r\n\r\n    // #endregion Properties\r\n\r\n    // #region Constructors\r\n\r\n    /**\r\n     * Constructor\r\n     * @param formlayout SacFormLayoutCommon to define scoped layout settings\r\n     * @param injector Injector for injecting services\r\n     * @param elementRef reference to html element\r\n     */\r\n    constructor(\r\n        formlayout: SacFormLayoutCommon,\r\n        injector: Injector,\r\n        protected elementRef: ElementRef,\r\n        cdRef: ChangeDetectorRef\r\n    ) {\r\n        super(formlayout, injector, elementRef, cdRef);\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 date selector button\r\n     */\r\n    public get IconSelector(): string {\r\n        return this.iconService.TimeComponentSelectorIcon;\r\n    }\r\n\r\n    /**\r\n     * Max Time\r\n     */\r\n    @Input()\r\n    public set maxtime(v: string | Date | null) {\r\n        let time = this.moment(v, [this.TIMEFORMAT], true);\r\n\r\n        time = this.ModifyParsedDateTimeValue(time);\r\n\r\n        if (time.isValid()) {\r\n            this._maxtime = super.getDate(time).toDate();\r\n        } else {\r\n            this._maxtime = null;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Min Time\r\n     */\r\n    @Input()\r\n    public set mintime(v: string | Date | null) {\r\n        let time = this.moment(v, [this.TIMEFORMAT], true);\r\n\r\n        time = this.ModifyParsedDateTimeValue(time);\r\n\r\n        if (time.isValid()) {\r\n            this._mintime = super.getDate(time).toDate();\r\n        } else {\r\n            this._mintime = null;\r\n        }\r\n    }\r\n\r\n    // #endregion Public Getters And Setters\r\n\r\n    // #region Public Methods\r\n\r\n    /**\r\n     * Methode ergibt Datum-Format vom String\r\n     */\r\n    public GetDateTimeFormatString(): string {\r\n        return this.TIMEFORMAT;\r\n    }\r\n\r\n    /**\r\n     * Methode ergibt Datum - Moment\r\n     */\r\n    public ModifyParsedDateTimeValue(v: moment_.Moment): moment_.Moment {\r\n        v.date(1);\r\n        v.month(0);\r\n        v.year(1900);\r\n        return v;\r\n    }\r\n\r\n    /**\r\n     * HostListener\r\n     */\r\n    @HostListener('document:click', ['$event.target'])\r\n    /**\r\n     * Click Event\r\n     */\r\n    public onClick(targetElement) {\r\n        if (!this.pickercontainer) {\r\n            return;\r\n        }\r\n\r\n        const clickedInsideContainer = this.pickercontainer.nativeElement.contains(targetElement);\r\n        const clickedInsideReference = this.pickerbutton.nativeElement.contains(targetElement);\r\n        if (!clickedInsideContainer && !clickedInsideReference) {\r\n            this._showselector = false;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Zeigt Date Selector an\r\n     */\r\n    public showTimeSelector(): void {\r\n        // Touch Event auslösen\r\n        this.onTouch();\r\n\r\n        if (this._showselector) {\r\n            this._showselector = false;\r\n        } else {\r\n            this._showselector = true;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Time Selector\r\n     */\r\n    public timeselect(v: any) {\r\n        if (v.date === null) {\r\n            this.setValueString('');\r\n        } else {\r\n            this.value = this.moment(v.date).utc().toDate();\r\n        }\r\n\r\n        this._showselector = false;\r\n    }\r\n\r\n    /**\r\n     * Validator\r\n     */\r\n    public validateData(c: AbstractControl): ValidationErrors | null {\r\n        let error: ValidationErrors | null = null;\r\n\r\n        error = super.validateData(c);\r\n\r\n        if (\r\n            error === null &&\r\n            c.value !== null &&\r\n            c.value !== undefined &&\r\n            c.value !== '' &&\r\n            this._mintime !== undefined &&\r\n            this._mintime !== null\r\n        ) {\r\n            error = Validation.minTime(\r\n                this._mintime,\r\n                this.validationmessagemintime,\r\n                this.validationmessagesummarymintime\r\n            )(c);\r\n        }\r\n\r\n        if (\r\n            error === null &&\r\n            c.value !== null &&\r\n            c.value !== undefined &&\r\n            c.value !== '' &&\r\n            this._maxtime !== undefined &&\r\n            this._maxtime !== null\r\n        ) {\r\n            error = Validation.maxTime(\r\n                this._maxtime,\r\n                this.validationmessagemaxtime,\r\n                this.validationmessagesummarymaxtime\r\n            )(c);\r\n        }\r\n\r\n        return error;\r\n    }\r\n\r\n    // #endregion Public Methods\r\n}\r\n"]}
|
|
@@ -1,10 +1,8 @@
|
|
|
1
|
-
import { ChangeDetectorRef, ElementRef, EventEmitter, HostListener, Input, Output, ViewChild,
|
|
1
|
+
import { ChangeDetectorRef, Directive, ElementRef, EventEmitter, HostListener, Input, Output, ViewChild, } from '@angular/core';
|
|
2
2
|
/**
|
|
3
3
|
* Base Komponente für Dialog
|
|
4
4
|
*/
|
|
5
5
|
export class SacDialogCommon {
|
|
6
|
-
// #endregion
|
|
7
|
-
// #region Constructor
|
|
8
6
|
/**
|
|
9
7
|
* Konstruktor
|
|
10
8
|
* Inject des Formulars
|
|
@@ -21,11 +19,6 @@ export class SacDialogCommon {
|
|
|
21
19
|
* Die akzeptabel keywordssind: 'small', 'large', 'extralarge', 'medium', ''.
|
|
22
20
|
*/
|
|
23
21
|
this._size = '';
|
|
24
|
-
// #region Properties
|
|
25
|
-
/**
|
|
26
|
-
* Input Property. Erhält den Title des Dialog. Default Value: 'Dialog'.
|
|
27
|
-
*/
|
|
28
|
-
this.title = 'Dialog';
|
|
29
22
|
/**
|
|
30
23
|
* Das input property akzeptiert boolen Wert. Definiert ob das Dialog darf durch ESC geschlossen werden. Default ist true.
|
|
31
24
|
*/
|
|
@@ -34,26 +27,22 @@ export class SacDialogCommon {
|
|
|
34
27
|
* Das input property akzeptiert boolen Wert. Definiert ob das Dialog darf durch click außerhalb des Dialog-Fenster geschlossen werden. Default ist true.
|
|
35
28
|
*/
|
|
36
29
|
this.backdrop = true;
|
|
37
|
-
/**
|
|
38
|
-
* Input Property. Erhält den Namen des Dialog - benutzt für das ID. Default Value: ''
|
|
39
|
-
*/
|
|
40
|
-
this.name = '';
|
|
41
30
|
/**
|
|
42
31
|
* Steuert ob im Header des Dialogs ein Button angezeigt wird.
|
|
43
32
|
*/
|
|
44
33
|
this.closebutton = true;
|
|
45
34
|
/**
|
|
46
|
-
*
|
|
35
|
+
* Output Emitter. Wird aufgerufen, wenn das Wert des _show property geändert ist - damait das Dialog geöfnet/geschlossen wird.
|
|
47
36
|
*/
|
|
48
|
-
this.
|
|
37
|
+
this.isvisibleChange = new EventEmitter();
|
|
49
38
|
/**
|
|
50
|
-
*
|
|
39
|
+
* Input Property. Erhält den Namen des Dialog - benutzt für das ID. Default Value: ''
|
|
51
40
|
*/
|
|
52
|
-
this.
|
|
41
|
+
this.name = '';
|
|
53
42
|
/**
|
|
54
|
-
*
|
|
43
|
+
* Input Property. Erhält den Title des Dialog. Default Value: 'Dialog'.
|
|
55
44
|
*/
|
|
56
|
-
this.
|
|
45
|
+
this.title = 'Dialog';
|
|
57
46
|
}
|
|
58
47
|
/**
|
|
59
48
|
* Implementation als Setter, da mit ngIf das Element bei Unsichtbarkeit UNDEFINED ist.
|
|
@@ -62,14 +51,10 @@ export class SacDialogCommon {
|
|
|
62
51
|
this.dialogElement = content;
|
|
63
52
|
}
|
|
64
53
|
/**
|
|
65
|
-
*
|
|
66
|
-
* case insensitive.
|
|
67
|
-
* Die akzeptabel default-size-Klassen sind: 'small', 'large', 'extralarge', 'medium', ''.
|
|
68
|
-
* Wenn size ist NICHT gesetzt (oder 'medium' oder ''), default ist in medium size: max-width 500px.
|
|
54
|
+
* Getter. Ergibt das boolen Wert des _show property
|
|
69
55
|
*/
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
this._size = v;
|
|
56
|
+
get isvisible() {
|
|
57
|
+
return this._show;
|
|
73
58
|
}
|
|
74
59
|
/**
|
|
75
60
|
* Setter. Erhält das boolen Wert des _show property
|
|
@@ -90,77 +75,40 @@ export class SacDialogCommon {
|
|
|
90
75
|
this._show = v;
|
|
91
76
|
}
|
|
92
77
|
/**
|
|
93
|
-
*
|
|
78
|
+
* Das Input akzeptiert sowohl default size-css-Klassen als auch custom Klassen.
|
|
79
|
+
* case insensitive.
|
|
80
|
+
* Die akzeptabel default-size-Klassen sind: 'small', 'large', 'extralarge', 'medium', ''.
|
|
81
|
+
* Wenn size ist NICHT gesetzt (oder 'medium' oder ''), default ist in medium size: max-width 500px.
|
|
94
82
|
*/
|
|
95
|
-
|
|
96
|
-
|
|
83
|
+
set size(v) {
|
|
84
|
+
this._size = v;
|
|
97
85
|
}
|
|
98
86
|
/**
|
|
99
|
-
*
|
|
87
|
+
* Getter for ChangeDetector.
|
|
100
88
|
*/
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
switch (this._size) {
|
|
104
|
-
case 'small':
|
|
105
|
-
result = true;
|
|
106
|
-
break;
|
|
107
|
-
case 'medium':
|
|
108
|
-
result = true;
|
|
109
|
-
break;
|
|
110
|
-
case 'large':
|
|
111
|
-
result = true;
|
|
112
|
-
break;
|
|
113
|
-
case 'extralarge':
|
|
114
|
-
result = true;
|
|
115
|
-
break;
|
|
116
|
-
case '':
|
|
117
|
-
result = true;
|
|
118
|
-
break;
|
|
119
|
-
}
|
|
120
|
-
return result;
|
|
89
|
+
get ChangeDetector() {
|
|
90
|
+
return this.cdRef;
|
|
121
91
|
}
|
|
122
|
-
// #endregion
|
|
123
92
|
/**
|
|
124
|
-
* Methode
|
|
93
|
+
* Die Methode setz den Wert des _show property auf false
|
|
125
94
|
*/
|
|
126
|
-
|
|
95
|
+
hide() {
|
|
127
96
|
if (this.hasSetBodyTag && document.body.classList.contains('modal-open')) {
|
|
128
97
|
document.body.classList.remove('modal-open');
|
|
129
98
|
this.hasSetBodyTag = false;
|
|
130
99
|
}
|
|
131
|
-
|
|
132
|
-
// #region Methods
|
|
133
|
-
/**
|
|
134
|
-
* Die Methode setz den Wert des _show property auf true
|
|
135
|
-
*/
|
|
136
|
-
show() {
|
|
137
|
-
this._show = true;
|
|
138
|
-
if (!this.hasSetBodyTag &&
|
|
139
|
-
!document.body.classList.contains('modal-open')) {
|
|
140
|
-
document.body.classList.add('modal-open');
|
|
141
|
-
this.hasSetBodyTag = true;
|
|
142
|
-
}
|
|
100
|
+
this._show = false;
|
|
143
101
|
this.isvisibleChange.emit(this._show);
|
|
144
102
|
}
|
|
145
103
|
/**
|
|
146
|
-
*
|
|
104
|
+
* Methode wenn Componente entfernt wird
|
|
147
105
|
*/
|
|
148
|
-
|
|
106
|
+
ngOnDestroy() {
|
|
149
107
|
if (this.hasSetBodyTag && document.body.classList.contains('modal-open')) {
|
|
150
108
|
document.body.classList.remove('modal-open');
|
|
151
109
|
this.hasSetBodyTag = false;
|
|
152
110
|
}
|
|
153
|
-
this._show = false;
|
|
154
|
-
this.isvisibleChange.emit(this._show);
|
|
155
111
|
}
|
|
156
|
-
/**
|
|
157
|
-
* Getter for ChangeDetector.
|
|
158
|
-
*/
|
|
159
|
-
get ChangeDetector() {
|
|
160
|
-
return this.cdRef;
|
|
161
|
-
}
|
|
162
|
-
// #endregion
|
|
163
|
-
// #region Host Actions
|
|
164
112
|
/**
|
|
165
113
|
* Allow Close by Click outside Dialog
|
|
166
114
|
*/
|
|
@@ -182,6 +130,18 @@ export class SacDialogCommon {
|
|
|
182
130
|
this.hide();
|
|
183
131
|
}
|
|
184
132
|
}
|
|
133
|
+
/**
|
|
134
|
+
* Die Methode setz den Wert des _show property auf true
|
|
135
|
+
*/
|
|
136
|
+
show() {
|
|
137
|
+
this._show = true;
|
|
138
|
+
if (!this.hasSetBodyTag &&
|
|
139
|
+
!document.body.classList.contains('modal-open')) {
|
|
140
|
+
document.body.classList.add('modal-open');
|
|
141
|
+
this.hasSetBodyTag = true;
|
|
142
|
+
}
|
|
143
|
+
this.isvisibleChange.emit(this._show);
|
|
144
|
+
}
|
|
185
145
|
}
|
|
186
146
|
SacDialogCommon.decorators = [
|
|
187
147
|
{ type: Directive }
|
|
@@ -190,18 +150,16 @@ SacDialogCommon.ctorParameters = () => [
|
|
|
190
150
|
{ type: ChangeDetectorRef }
|
|
191
151
|
];
|
|
192
152
|
SacDialogCommon.propDecorators = {
|
|
193
|
-
dialogElementSetter: [{ type: ViewChild, args: ['dialog', { static: false },] }],
|
|
194
|
-
title: [{ type: Input }],
|
|
195
153
|
allowesc: [{ type: Input }],
|
|
196
154
|
backdrop: [{ type: Input }],
|
|
197
|
-
name: [{ type: Input }],
|
|
198
155
|
closebutton: [{ type: Input }],
|
|
199
|
-
width: [{ type: Input }],
|
|
200
|
-
height: [{ type: Input }],
|
|
201
|
-
size: [{ type: Input }],
|
|
202
156
|
isvisibleChange: [{ type: Output }],
|
|
157
|
+
name: [{ type: Input }],
|
|
158
|
+
title: [{ type: Input }],
|
|
159
|
+
dialogElementSetter: [{ type: ViewChild, args: ['dialog', { static: false },] }],
|
|
203
160
|
isvisible: [{ type: Input }],
|
|
161
|
+
size: [{ type: Input }],
|
|
204
162
|
onClick: [{ type: HostListener, args: ['click', ['$event'],] }],
|
|
205
163
|
onKeydownHandler: [{ type: HostListener, args: ['document:keydown', ['$event'],] }]
|
|
206
164
|
};
|
|
207
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["controls/dialog/dialog.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  Output,\r\n  ViewChild,\r\n  Directive,\r\n  OnDestroy,\r\n} from '@angular/core';\r\n\r\n/**\r\n * Base Komponente für Dialog\r\n */\r\n@Directive()\r\nexport class SacDialogCommon implements OnDestroy {\r\n  /**\r\n   * Name des Containers für den Dialog\r\n   */\r\n  dialogElement: ElementRef;\r\n\r\n  private hasSetBodyTag = false;\r\n\r\n  /**\r\n   * Implementation als Setter, da mit ngIf das Element bei Unsichtbarkeit UNDEFINED ist.\r\n   */\r\n  @ViewChild('dialog', { static: false })\r\n  set dialogElementSetter(content: ElementRef) {\r\n    this.dialogElement = content;\r\n  }\r\n\r\n  /**\r\n   * Boolean Property definiert ob das Dialog angezeigt wird\r\n   */\r\n  _show: boolean = false;\r\n\r\n  /**\r\n   * Das property enthielt (wenn überhaupt gesetzt) entweder keywords für sizing oder custom css Klassen.\r\n   * Die akzeptabel keywordssind: 'small', 'large', 'extralarge', 'medium', ''.\r\n   */\r\n  _size: string = '';\r\n\r\n  // #region Properties\r\n\r\n  /**\r\n   * Input Property. Erhält den Title des Dialog. Default Value: 'Dialog'.\r\n   */\r\n  @Input()\r\n  public title: string = 'Dialog';\r\n\r\n  /**\r\n   * Das input property akzeptiert boolen Wert. Definiert ob das Dialog darf durch ESC geschlossen werden. Default ist true.\r\n   */\r\n  @Input()\r\n  public allowesc: boolean = true;\r\n\r\n  /**\r\n   * Das input property akzeptiert boolen Wert. Definiert ob das Dialog darf durch click außerhalb des Dialog-Fenster geschlossen werden. Default ist true.\r\n   */\r\n  @Input()\r\n  public backdrop: boolean = true;\r\n\r\n  /**\r\n   * Input Property. Erhält den Namen des Dialog - benutzt für das ID. Default Value: ''\r\n   */\r\n  @Input()\r\n  public name: string = '';\r\n\r\n  /**\r\n   * Steuert ob im Header des Dialogs ein Button angezeigt wird.\r\n   */\r\n  @Input()\r\n  public closebutton: boolean = true;\r\n\r\n  /**\r\n   * Input Property. Erhält die Breite des Dialog\r\n   */\r\n  @Input()\r\n  public width: string = null;\r\n\r\n  /**\r\n   * Definiert eine feste Höhe beim Dialog.\r\n   */\r\n  @Input()\r\n  public height: string = null;\r\n\r\n  /**\r\n   * Das Input akzeptiert sowohl default size-css-Klassen als auch custom Klassen.\r\n   * case insensitive.\r\n   * Die akzeptabel default-size-Klassen sind: 'small', 'large', 'extralarge', 'medium', ''.\r\n   * Wenn size ist NICHT gesetzt (oder 'medium' oder ''), default ist in medium size: max-width 500px.\r\n   */\r\n  @Input()\r\n  set size(v: string) {\r\n    v = v.toLowerCase();\r\n    this._size = v;\r\n  }\r\n\r\n  /**\r\n   * Output Emitter. Wird aufgerufen, wenn das Wert des _show property geändert ist - damait das Dialog geöfnet/geschlossen wird.\r\n   */\r\n  @Output()\r\n  isvisibleChange: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n\r\n  /**\r\n   * Setter. Erhält das boolen Wert des _show property\r\n   */\r\n  @Input()\r\n  set isvisible(v: boolean) {\r\n    if (\r\n      v &&\r\n      !this.hasSetBodyTag &&\r\n      !document.body.classList.contains('modal-open')\r\n    ) {\r\n      document.body.classList.add('modal-open');\r\n      this.hasSetBodyTag = true;\r\n    }\r\n\r\n    if (\r\n      !v &&\r\n      this.hasSetBodyTag &&\r\n      document.body.classList.contains('modal-open')\r\n    ) {\r\n      document.body.classList.remove('modal-open');\r\n      this.hasSetBodyTag = false;\r\n    }\r\n\r\n    this._show = v;\r\n  }\r\n\r\n  /**\r\n   * Getter. Ergibt das boolen Wert des _show property\r\n   */\r\n  get isvisible(): boolean {\r\n    return this._show;\r\n  }\r\n\r\n  /**\r\n   * Die Funktion prüft ob es ein default css classe für Size des Dialog durch den size Input gesetzt wurde.\r\n   */\r\n  issetdefaultsize(): boolean {\r\n    let result: boolean = false;\r\n\r\n    switch (this._size) {\r\n      case 'small':\r\n        result = true;\r\n        break;\r\n      case 'medium':\r\n        result = true;\r\n        break;\r\n      case 'large':\r\n        result = true;\r\n        break;\r\n      case 'extralarge':\r\n        result = true;\r\n        break;\r\n      case '':\r\n        result = true;\r\n        break;\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  // #endregion\r\n\r\n  // #region Constructor\r\n\r\n  /**\r\n   * Konstruktor\r\n   * Inject des Formulars\r\n   */\r\n  constructor(private cdRef: ChangeDetectorRef) {}\r\n\r\n  // #endregion\r\n\r\n  /**\r\n   * Methode wenn Componente entfernt wird\r\n   */\r\n  ngOnDestroy(): void {\r\n    if (this.hasSetBodyTag && document.body.classList.contains('modal-open')) {\r\n      document.body.classList.remove('modal-open');\r\n      this.hasSetBodyTag = false;\r\n    }\r\n  }\r\n\r\n  // #region Methods\r\n\r\n  /**\r\n   * Die Methode setz den Wert des _show property auf true\r\n   */\r\n  public show(): void {\r\n    this._show = true;\r\n\r\n    if (\r\n      !this.hasSetBodyTag &&\r\n      !document.body.classList.contains('modal-open')\r\n    ) {\r\n      document.body.classList.add('modal-open');\r\n      this.hasSetBodyTag = true;\r\n    }\r\n\r\n    this.isvisibleChange.emit(this._show);\r\n  }\r\n\r\n  /**\r\n   * Die Methode setz den Wert des _show property auf false\r\n   */\r\n  public hide(): void {\r\n    if (this.hasSetBodyTag && document.body.classList.contains('modal-open')) {\r\n      document.body.classList.remove('modal-open');\r\n      this.hasSetBodyTag = false;\r\n    }\r\n\r\n    this._show = false;\r\n    this.isvisibleChange.emit(this._show);\r\n  }\r\n\r\n  /**\r\n   * Getter for ChangeDetector.\r\n   */\r\n  protected get ChangeDetector(): ChangeDetectorRef {\r\n    return this.cdRef;\r\n  }\r\n\r\n  // #endregion\r\n\r\n  // #region Host Actions\r\n\r\n  /**\r\n   * Allow Close by Click outside Dialog\r\n   */\r\n  @HostListener('click', ['$event'])\r\n  onClick(event: any): void {\r\n    if (\r\n      this.allowesc === false ||\r\n      (this.dialogElement !== null &&\r\n        this.dialogElement !== undefined &&\r\n        event.target !== this.dialogElement.nativeElement)\r\n    ) {\r\n      return;\r\n    }\r\n    this.hide();\r\n  }\r\n\r\n  /**\r\n   * Allow Close by ESC\r\n   */\r\n  @HostListener('document:keydown', ['$event'])\r\n  onKeydownHandler(event: KeyboardEvent) {\r\n    const ESCAPE_KEYCODE = 'Escape';\r\n\r\n    if (this.allowesc === true && event.key === ESCAPE_KEYCODE) {\r\n      this.hide();\r\n    }\r\n  }\r\n\r\n  // #endregion\r\n}\r\n"]}
|
|
165
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["controls/dialog/dialog.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Directive,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  OnDestroy,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\n\r\n/**\r\n * Base Komponente für Dialog\r\n */\r\n@Directive()\r\nexport class SacDialogCommon implements OnDestroy {\r\n  private hasSetBodyTag = false;\r\n\r\n  /**\r\n   * Boolean Property definiert ob das Dialog angezeigt wird\r\n   */\r\n  public _show: boolean = false;\r\n\r\n  /**\r\n   * Das property enthielt (wenn überhaupt gesetzt) entweder keywords für sizing oder custom css Klassen.\r\n   * Die akzeptabel keywordssind: 'small', 'large', 'extralarge', 'medium', ''.\r\n   */\r\n  public _size: 'small' | 'large' | 'extralarge' | 'medium' | '' = '';\r\n\r\n  /**\r\n   * Das input property akzeptiert boolen Wert. Definiert ob das Dialog darf durch ESC geschlossen werden. Default ist true.\r\n   */\r\n  @Input()\r\n  public allowesc: boolean = true;\r\n\r\n  /**\r\n   * Das input property akzeptiert boolen Wert. Definiert ob das Dialog darf durch click außerhalb des Dialog-Fenster geschlossen werden. Default ist true.\r\n   */\r\n  @Input()\r\n  public backdrop: boolean = true;\r\n\r\n  /**\r\n   * Steuert ob im Header des Dialogs ein Button angezeigt wird.\r\n   */\r\n  @Input()\r\n  public closebutton: boolean = true;\r\n\r\n  /**\r\n   * Name des Containers für den Dialog\r\n   */\r\n  public dialogElement: ElementRef;\r\n\r\n  /**\r\n   * Output Emitter. Wird aufgerufen, wenn das Wert des _show property geändert ist - damait das Dialog geöfnet/geschlossen wird.\r\n   */\r\n  @Output()\r\n  public isvisibleChange: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n\r\n  /**\r\n   * Input Property. Erhält den Namen des Dialog - benutzt für das ID. Default Value: ''\r\n   */\r\n  @Input()\r\n  public name: string = '';\r\n\r\n  /**\r\n   * Input Property. Erhält den Title des Dialog. Default Value: 'Dialog'.\r\n   */\r\n  @Input()\r\n  public title: string = 'Dialog';\r\n\r\n  /**\r\n   * Konstruktor\r\n   * Inject des Formulars\r\n   */\r\n  constructor(private cdRef: ChangeDetectorRef) {}\r\n\r\n  /**\r\n   * Implementation als Setter, da mit ngIf das Element bei Unsichtbarkeit UNDEFINED ist.\r\n   */\r\n  @ViewChild('dialog', { static: false })\r\n  public set dialogElementSetter(content: ElementRef) {\r\n    this.dialogElement = content;\r\n  }\r\n\r\n  /**\r\n   * Getter. Ergibt das boolen Wert des _show property\r\n   */\r\n  public get isvisible(): boolean {\r\n    return this._show;\r\n  }\r\n\r\n  /**\r\n   * Setter. Erhält das boolen Wert des _show property\r\n   */\r\n  @Input()\r\n  public set isvisible(v: boolean) {\r\n    if (\r\n      v &&\r\n      !this.hasSetBodyTag &&\r\n      !document.body.classList.contains('modal-open')\r\n    ) {\r\n      document.body.classList.add('modal-open');\r\n      this.hasSetBodyTag = true;\r\n    }\r\n\r\n    if (\r\n      !v &&\r\n      this.hasSetBodyTag &&\r\n      document.body.classList.contains('modal-open')\r\n    ) {\r\n      document.body.classList.remove('modal-open');\r\n      this.hasSetBodyTag = false;\r\n    }\r\n\r\n    this._show = v;\r\n  }\r\n\r\n  /**\r\n   * Das Input akzeptiert sowohl default size-css-Klassen als auch custom Klassen.\r\n   * case insensitive.\r\n   * Die akzeptabel default-size-Klassen sind: 'small', 'large', 'extralarge', 'medium', ''.\r\n   * Wenn size ist NICHT gesetzt (oder 'medium' oder ''), default ist in medium size: max-width 500px.\r\n   */\r\n  @Input()\r\n  public set size(v: 'small' | 'large' | 'extralarge' | 'medium' | '') {\r\n    this._size = v;\r\n  }\r\n\r\n  /**\r\n   * Getter for ChangeDetector.\r\n   */\r\n  protected get ChangeDetector(): ChangeDetectorRef {\r\n    return this.cdRef;\r\n  }\r\n\r\n  /**\r\n   * Die Methode setz den Wert des _show property auf false\r\n   */\r\n  public hide(): void {\r\n    if (this.hasSetBodyTag && document.body.classList.contains('modal-open')) {\r\n      document.body.classList.remove('modal-open');\r\n      this.hasSetBodyTag = false;\r\n    }\r\n\r\n    this._show = false;\r\n    this.isvisibleChange.emit(this._show);\r\n  }\r\n\r\n  /**\r\n   * Methode wenn Componente entfernt wird\r\n   */\r\n  public ngOnDestroy(): void {\r\n    if (this.hasSetBodyTag && document.body.classList.contains('modal-open')) {\r\n      document.body.classList.remove('modal-open');\r\n      this.hasSetBodyTag = false;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Allow Close by Click outside Dialog\r\n   */\r\n  @HostListener('click', ['$event'])\r\n  public onClick(event: any): void {\r\n    if (\r\n      this.allowesc === false ||\r\n      (this.dialogElement !== null &&\r\n        this.dialogElement !== undefined &&\r\n        event.target !== this.dialogElement.nativeElement)\r\n    ) {\r\n      return;\r\n    }\r\n    this.hide();\r\n  }\r\n\r\n  /**\r\n   * Allow Close by ESC\r\n   */\r\n  @HostListener('document:keydown', ['$event'])\r\n  public onKeydownHandler(event: KeyboardEvent) {\r\n    const ESCAPE_KEYCODE = 'Escape';\r\n\r\n    if (this.allowesc === true && event.key === ESCAPE_KEYCODE) {\r\n      this.hide();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Die Methode setz den Wert des _show property auf true\r\n   */\r\n  public show(): void {\r\n    this._show = true;\r\n\r\n    if (\r\n      !this.hasSetBodyTag &&\r\n      !document.body.classList.contains('modal-open')\r\n    ) {\r\n      document.body.classList.add('modal-open');\r\n      this.hasSetBodyTag = true;\r\n    }\r\n\r\n    this.isvisibleChange.emit(this._show);\r\n  }\r\n}\r\n"]}
|