@sebgroup/green-angular 4.6.1 → 4.6.3
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/esm2022/src/v-angular/base-control-value-accessor/base-control-value-accessor.component.mjs +9 -9
- package/esm2022/src/v-angular/button/button.component.mjs +5 -5
- package/esm2022/src/v-angular/character-countdown/character-countdown.directive.mjs +5 -5
- package/esm2022/src/v-angular/core/core.globals.mjs +3 -3
- package/esm2022/src/v-angular/dropdown/dropdown-list/dropdown-list.component.mjs +4 -4
- package/esm2022/src/v-angular/dropdown/typeahead/index.mjs +4 -1
- package/esm2022/src/v-angular/dropdown/typeahead/typeahead-dropdown-list/typeahead-dropdown-list.component.mjs +5 -5
- package/esm2022/src/v-angular/dropdown/typeahead/typeahead.directive.mjs +177 -0
- package/esm2022/src/v-angular/info-circle/info-circle.component.mjs +3 -3
- package/esm2022/src/v-angular/input/input.component.mjs +7 -7
- package/esm2022/src/v-angular/input-mask/input-mask-format.pipe.mjs +5 -4
- package/esm2022/src/v-angular/input-mask/input-mask.directive.mjs +8 -8
- package/esm2022/src/v-angular/modal/dialog/dialog.component.mjs +16 -16
- package/esm2022/src/v-angular/modal/fold-out/fold-out.directive.mjs +3 -3
- package/esm2022/src/v-angular/modal/modal.globals.mjs +3 -3
- package/esm2022/src/v-angular/modal/slide-out/slide-out.component.mjs +15 -15
- package/esm2022/src/v-angular/textarea/textarea.component.mjs +4 -3
- package/esm2022/src/v-angular/textarea/textarea.module.mjs +5 -4
- package/esm2022/src/v-angular/tooltip/tooltip.directive.mjs +13 -13
- package/esm2022/v-angular/base-control-value-accessor/base-control-value-accessor.component.mjs +287 -0
- package/esm2022/v-angular/base-control-value-accessor/base-control-value-accessor.module.mjs +17 -0
- package/esm2022/v-angular/base-control-value-accessor/index.mjs +3 -0
- package/esm2022/v-angular/breadcrumbs/breadcrumbs.component.mjs +25 -0
- package/esm2022/v-angular/breadcrumbs/breadcrumbs.module.mjs +20 -0
- package/esm2022/v-angular/breadcrumbs/index.mjs +3 -0
- package/esm2022/v-angular/button/button.component.mjs +108 -0
- package/esm2022/v-angular/button/button.module.mjs +20 -0
- package/esm2022/v-angular/button/index.mjs +3 -0
- package/esm2022/v-angular/card/card.component.mjs +11 -0
- package/esm2022/v-angular/card/card.module.mjs +18 -0
- package/esm2022/v-angular/card/index.mjs +3 -0
- package/esm2022/v-angular/character-countdown/character-countdown.directive.mjs +51 -0
- package/esm2022/v-angular/character-countdown/character-countdown.module.mjs +18 -0
- package/esm2022/v-angular/character-countdown/index.mjs +3 -0
- package/esm2022/v-angular/checkbox/checkbox.component.mjs +72 -0
- package/esm2022/v-angular/checkbox/checkbox.module.mjs +19 -0
- package/esm2022/v-angular/checkbox/index.mjs +3 -0
- package/esm2022/v-angular/dropdown/dropdown-list/dropdown-list.component.mjs +256 -0
- package/esm2022/v-angular/dropdown/dropdown-list/index.mjs +2 -0
- package/esm2022/v-angular/dropdown/dropdown.component.mjs +239 -0
- package/esm2022/v-angular/dropdown/dropdown.module.mjs +22 -0
- package/esm2022/v-angular/dropdown/index.mjs +6 -0
- package/esm2022/v-angular/dropdown/typeahead/index.mjs +6 -0
- package/esm2022/v-angular/dropdown/typeahead/typeahead-dropdown-list/typeahead-dropdown-list.component.mjs +98 -0
- package/esm2022/v-angular/dropdown/typeahead/typeahead-highlight/typeahead-highlight.component.mjs +85 -0
- package/esm2022/v-angular/dropdown/typeahead/typeahead-input/typeahead-input.component.mjs +132 -0
- package/esm2022/v-angular/dropdown/typeahead/typeahead.directive.mjs +177 -0
- package/esm2022/v-angular/dropdown/typeahead/typeahead.module.mjs +33 -0
- package/esm2022/v-angular/i18n/i18n.json +12 -0
- package/esm2022/v-angular/i18n/i18n.module.mjs +83 -0
- package/esm2022/v-angular/i18n/i18n.test.module.mjs +89 -0
- package/esm2022/v-angular/i18n/index.mjs +3 -0
- package/esm2022/v-angular/index.mjs +18 -0
- package/esm2022/v-angular/info-circle/index.mjs +3 -0
- package/esm2022/v-angular/info-circle/info-circle.component.mjs +28 -0
- package/esm2022/v-angular/info-circle/info-circle.module.mjs +21 -0
- package/esm2022/v-angular/input/index.mjs +3 -0
- package/esm2022/v-angular/input/input.component.mjs +221 -0
- package/esm2022/v-angular/input/input.module.mjs +32 -0
- package/esm2022/v-angular/input-mask/config.mjs +9 -0
- package/esm2022/v-angular/input-mask/constants.mjs +2 -0
- package/esm2022/v-angular/input-mask/index.mjs +6 -0
- package/esm2022/v-angular/input-mask/input-mask-format.pipe.mjs +21 -0
- package/esm2022/v-angular/input-mask/input-mask.directive.mjs +165 -0
- package/esm2022/v-angular/input-mask/input-mask.module.mjs +35 -0
- package/esm2022/v-angular/input-mask/input-mask.types.mjs +2 -0
- package/esm2022/v-angular/modal/dialog/dialog.component.mjs +190 -0
- package/esm2022/v-angular/modal/fold-out/fold-out.component.mjs +56 -0
- package/esm2022/v-angular/modal/fold-out/fold-out.directive.mjs +19 -0
- package/esm2022/v-angular/modal/index.mjs +6 -0
- package/esm2022/v-angular/modal/modal.globals.mjs +20 -0
- package/esm2022/v-angular/modal/modal.module.mjs +40 -0
- package/esm2022/v-angular/modal/modal.types.mjs +2 -0
- package/esm2022/v-angular/modal/slide-out/slide-out.component.mjs +229 -0
- package/esm2022/v-angular/radio/index.mjs +3 -0
- package/esm2022/v-angular/radio/radio.component.mjs +130 -0
- package/esm2022/v-angular/radio/radio.module.mjs +20 -0
- package/esm2022/v-angular/sebgroup-green-angular-v-angular.mjs +5 -0
- package/esm2022/v-angular/textarea/index.mjs +3 -0
- package/esm2022/v-angular/textarea/textarea.component.mjs +102 -0
- package/esm2022/v-angular/textarea/textarea.module.mjs +19 -0
- package/esm2022/v-angular/tooltip/index.mjs +3 -0
- package/esm2022/v-angular/tooltip/tooltip.directive.mjs +273 -0
- package/esm2022/v-angular/tooltip/tooltip.module.mjs +18 -0
- package/esm2022/v-angular/v-angular.module.mjs +80 -0
- package/fesm2022/sebgroup-green-angular-src-v-angular-base-control-value-accessor.mjs +8 -8
- package/fesm2022/sebgroup-green-angular-src-v-angular-base-control-value-accessor.mjs.map +1 -1
- package/fesm2022/sebgroup-green-angular-src-v-angular-button.mjs +4 -4
- package/fesm2022/sebgroup-green-angular-src-v-angular-button.mjs.map +1 -1
- package/fesm2022/sebgroup-green-angular-src-v-angular-character-countdown.mjs +4 -4
- package/fesm2022/sebgroup-green-angular-src-v-angular-character-countdown.mjs.map +1 -1
- package/fesm2022/sebgroup-green-angular-src-v-angular-core.mjs +2 -2
- package/fesm2022/sebgroup-green-angular-src-v-angular-core.mjs.map +1 -1
- package/fesm2022/sebgroup-green-angular-src-v-angular-dropdown.mjs +179 -10
- package/fesm2022/sebgroup-green-angular-src-v-angular-dropdown.mjs.map +1 -1
- package/fesm2022/sebgroup-green-angular-src-v-angular-info-circle.mjs +2 -2
- package/fesm2022/sebgroup-green-angular-src-v-angular-info-circle.mjs.map +1 -1
- package/fesm2022/sebgroup-green-angular-src-v-angular-input-mask.mjs +11 -10
- package/fesm2022/sebgroup-green-angular-src-v-angular-input-mask.mjs.map +1 -1
- package/fesm2022/sebgroup-green-angular-src-v-angular-input.mjs +6 -6
- package/fesm2022/sebgroup-green-angular-src-v-angular-input.mjs.map +1 -1
- package/fesm2022/sebgroup-green-angular-src-v-angular-modal.mjs +33 -33
- package/fesm2022/sebgroup-green-angular-src-v-angular-modal.mjs.map +1 -1
- package/fesm2022/sebgroup-green-angular-src-v-angular-textarea.mjs +7 -5
- package/fesm2022/sebgroup-green-angular-src-v-angular-textarea.mjs.map +1 -1
- package/fesm2022/sebgroup-green-angular-src-v-angular-tooltip.mjs +12 -12
- package/fesm2022/sebgroup-green-angular-src-v-angular-tooltip.mjs.map +1 -1
- package/fesm2022/sebgroup-green-angular-v-angular.mjs +3408 -0
- package/fesm2022/sebgroup-green-angular-v-angular.mjs.map +1 -0
- package/package.json +8 -2
- package/src/v-angular/base-control-value-accessor/base-control-value-accessor.component.d.ts +3 -3
- package/src/v-angular/button/button.component.d.ts +2 -2
- package/src/v-angular/character-countdown/character-countdown.directive.d.ts +1 -1
- package/src/v-angular/core/core.globals.d.ts +1 -1
- package/src/v-angular/dropdown/typeahead/index.d.ts +3 -0
- package/src/v-angular/dropdown/typeahead/typeahead.directive.d.ts +76 -0
- package/src/v-angular/input/input.component.d.ts +3 -3
- package/src/v-angular/input-mask/input-mask-format.pipe.d.ts +1 -1
- package/src/v-angular/input-mask/input-mask.directive.d.ts +2 -2
- package/src/v-angular/modal/dialog/dialog.component.d.ts +5 -5
- package/src/v-angular/modal/fold-out/fold-out.directive.d.ts +1 -1
- package/src/v-angular/modal/modal.globals.d.ts +1 -1
- package/src/v-angular/modal/slide-out/slide-out.component.d.ts +6 -6
- package/src/v-angular/textarea/textarea.module.d.ts +2 -1
- package/src/v-angular/tooltip/tooltip.directive.d.ts +4 -4
- package/v-angular/base-control-value-accessor/base-control-value-accessor.component.d.ts +124 -0
- package/v-angular/base-control-value-accessor/base-control-value-accessor.module.d.ts +7 -0
- package/v-angular/base-control-value-accessor/index.d.ts +2 -0
- package/v-angular/breadcrumbs/breadcrumbs.component.d.ts +18 -0
- package/v-angular/breadcrumbs/breadcrumbs.module.d.ts +10 -0
- package/v-angular/breadcrumbs/index.d.ts +2 -0
- package/v-angular/button/button.component.d.ts +62 -0
- package/v-angular/button/button.module.d.ts +10 -0
- package/v-angular/button/index.d.ts +2 -0
- package/v-angular/card/card.component.d.ts +5 -0
- package/v-angular/card/card.module.d.ts +8 -0
- package/v-angular/card/index.d.ts +2 -0
- package/v-angular/character-countdown/character-countdown.directive.d.ts +17 -0
- package/v-angular/character-countdown/character-countdown.module.d.ts +8 -0
- package/v-angular/character-countdown/index.d.ts +2 -0
- package/v-angular/checkbox/checkbox.component.d.ts +27 -0
- package/v-angular/checkbox/checkbox.module.d.ts +9 -0
- package/v-angular/checkbox/index.d.ts +2 -0
- package/v-angular/dropdown/dropdown-list/dropdown-list.component.d.ts +89 -0
- package/v-angular/dropdown/dropdown-list/index.d.ts +1 -0
- package/v-angular/dropdown/dropdown.component.d.ts +99 -0
- package/v-angular/dropdown/dropdown.module.d.ts +12 -0
- package/v-angular/dropdown/index.d.ts +5 -0
- package/v-angular/dropdown/typeahead/index.d.ts +5 -0
- package/v-angular/dropdown/typeahead/typeahead-dropdown-list/typeahead-dropdown-list.component.d.ts +34 -0
- package/v-angular/dropdown/typeahead/typeahead-highlight/typeahead-highlight.component.d.ts +34 -0
- package/v-angular/dropdown/typeahead/typeahead-input/typeahead-input.component.d.ts +59 -0
- package/v-angular/dropdown/typeahead/typeahead.directive.d.ts +76 -0
- package/v-angular/dropdown/typeahead/typeahead.module.d.ts +11 -0
- package/v-angular/i18n/i18n.module.d.ts +15 -0
- package/v-angular/i18n/i18n.test.module.d.ts +27 -0
- package/v-angular/i18n/index.d.ts +2 -0
- package/v-angular/index.d.ts +17 -0
- package/v-angular/info-circle/index.d.ts +2 -0
- package/v-angular/info-circle/info-circle.component.d.ts +16 -0
- package/v-angular/info-circle/info-circle.module.d.ts +10 -0
- package/v-angular/input/index.d.ts +2 -0
- package/v-angular/input/input.component.d.ts +90 -0
- package/v-angular/input/input.module.d.ts +11 -0
- package/v-angular/input-mask/config.d.ts +6 -0
- package/v-angular/input-mask/constants.d.ts +2 -0
- package/v-angular/input-mask/index.d.ts +5 -0
- package/v-angular/input-mask/input-mask-format.pipe.d.ts +8 -0
- package/v-angular/input-mask/input-mask.directive.d.ts +39 -0
- package/v-angular/input-mask/input-mask.module.d.ts +11 -0
- package/v-angular/input-mask/input-mask.types.d.ts +20 -0
- package/v-angular/modal/dialog/dialog.component.d.ts +55 -0
- package/v-angular/modal/fold-out/fold-out.component.d.ts +24 -0
- package/v-angular/modal/fold-out/fold-out.directive.d.ts +6 -0
- package/v-angular/modal/index.d.ts +5 -0
- package/v-angular/modal/modal.globals.d.ts +13 -0
- package/v-angular/modal/modal.module.d.ts +13 -0
- package/v-angular/modal/modal.types.d.ts +5 -0
- package/v-angular/modal/slide-out/slide-out.component.d.ts +76 -0
- package/v-angular/radio/index.d.ts +2 -0
- package/v-angular/radio/radio.component.d.ts +48 -0
- package/v-angular/radio/radio.module.d.ts +9 -0
- package/v-angular/textarea/index.d.ts +2 -0
- package/v-angular/textarea/textarea.component.d.ts +44 -0
- package/v-angular/textarea/textarea.module.d.ts +9 -0
- package/v-angular/tooltip/index.d.ts +2 -0
- package/v-angular/tooltip/tooltip.directive.d.ts +106 -0
- package/v-angular/tooltip/tooltip.module.d.ts +8 -0
- package/v-angular/v-angular.module.d.ts +23 -0
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import _Inputmask from 'inputmask';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
const InputmaskStatic = _Inputmask.default ||
|
|
5
|
+
_Inputmask;
|
|
6
|
+
export class InputMaskFormatPipe {
|
|
7
|
+
transform(value, options) {
|
|
8
|
+
if (!value)
|
|
9
|
+
return value;
|
|
10
|
+
return InputmaskStatic.format(value, options);
|
|
11
|
+
}
|
|
12
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: InputMaskFormatPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
13
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: InputMaskFormatPipe, name: "nggvInputMaskFormat" }); }
|
|
14
|
+
}
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: InputMaskFormatPipe, decorators: [{
|
|
16
|
+
type: Pipe,
|
|
17
|
+
args: [{
|
|
18
|
+
name: 'nggvInputMaskFormat',
|
|
19
|
+
}]
|
|
20
|
+
}] });
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtbWFzay1mb3JtYXQucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9zcmMvdi1hbmd1bGFyL2lucHV0LW1hc2svaW5wdXQtbWFzay1mb3JtYXQucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQTtBQUduRCxPQUFPLFVBQVUsTUFBTSxXQUFXLENBQUE7O0FBSWxDLE1BQU0sZUFBZSxHQUNsQixVQUF3RCxDQUFDLE9BQU87SUFDakUsVUFBVSxDQUFBO0FBS1osTUFBTSxPQUFPLG1CQUFtQjtJQUM5QixTQUFTLENBQVUsS0FBVSxFQUFFLE9BQTRCO1FBQ3pELElBQUksQ0FBQyxLQUFLO1lBQUUsT0FBTyxLQUFLLENBQUE7UUFDeEIsT0FBTyxlQUFlLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQTtJQUMvQyxDQUFDOytHQUpVLG1CQUFtQjs2R0FBbkIsbUJBQW1COzs0RkFBbkIsbUJBQW1CO2tCQUgvQixJQUFJO21CQUFDO29CQUNKLElBQUksRUFBRSxxQkFBcUI7aUJBQzVCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5cbmltcG9ydCB0eXBlIElucHV0bWFzayBmcm9tICdpbnB1dG1hc2snXG5pbXBvcnQgX0lucHV0bWFzayBmcm9tICdpbnB1dG1hc2snXG5cbmltcG9ydCB0eXBlIHsgSW5wdXRtYXNrT3B0aW9ucyB9IGZyb20gJy4vaW5wdXQtbWFzay50eXBlcydcblxuY29uc3QgSW5wdXRtYXNrU3RhdGljID1cbiAgKF9JbnB1dG1hc2sgYXMgdW5rbm93biBhcyB7IGRlZmF1bHQ/OiBJbnB1dG1hc2suU3RhdGljIH0pLmRlZmF1bHQgfHxcbiAgX0lucHV0bWFza1xuXG5AUGlwZSh7XG4gIG5hbWU6ICduZ2d2SW5wdXRNYXNrRm9ybWF0Jyxcbn0pXG5leHBvcnQgY2xhc3MgSW5wdXRNYXNrRm9ybWF0UGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICB0cmFuc2Zvcm08VCA9IGFueT4odmFsdWU6IGFueSwgb3B0aW9uczogSW5wdXRtYXNrT3B0aW9uczxUPik6IGFueSB7XG4gICAgaWYgKCF2YWx1ZSkgcmV0dXJuIHZhbHVlXG4gICAgcmV0dXJuIElucHV0bWFza1N0YXRpYy5mb3JtYXQodmFsdWUsIG9wdGlvbnMpXG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
import { isPlatformServer } from '@angular/common';
|
|
2
|
+
import { Directive, ElementRef, HostListener, Inject, Input, NgZone, Optional, PLATFORM_ID, Renderer2, Self, } from '@angular/core';
|
|
3
|
+
import { NgControl, } from '@angular/forms';
|
|
4
|
+
import _Inputmask from 'inputmask';
|
|
5
|
+
import { INPUT_MASK_CONFIG, InputMaskConfig } from './config';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/forms";
|
|
8
|
+
import * as i2 from "./config";
|
|
9
|
+
const InputmaskConstructor = _Inputmask.default ||
|
|
10
|
+
_Inputmask;
|
|
11
|
+
export class NgvInputMaskDirective {
|
|
12
|
+
constructor(ngControl, config, platformId, elementRef, renderer, ngZone) {
|
|
13
|
+
this.ngControl = ngControl;
|
|
14
|
+
this.platformId = platformId;
|
|
15
|
+
this.elementRef = elementRef;
|
|
16
|
+
this.renderer = renderer;
|
|
17
|
+
this.ngZone = ngZone;
|
|
18
|
+
/** Input settings of directive */
|
|
19
|
+
this.nggvInputMask = {};
|
|
20
|
+
this.defaultInputMaskConfig = new InputMaskConfig();
|
|
21
|
+
this.onInput = (_) => {
|
|
22
|
+
// Empty method
|
|
23
|
+
};
|
|
24
|
+
this.onTouched = (_) => {
|
|
25
|
+
// Empty method
|
|
26
|
+
};
|
|
27
|
+
this.validate = (control) => !control.value || !this.inputMaskPlugin || this.inputMaskPlugin.isValid()
|
|
28
|
+
? null
|
|
29
|
+
: { invalidformat: true };
|
|
30
|
+
if (this.ngControl) {
|
|
31
|
+
this.ngControl.valueAccessor = this;
|
|
32
|
+
}
|
|
33
|
+
this.setNativeInputElement(config);
|
|
34
|
+
}
|
|
35
|
+
onKeyUp(event) {
|
|
36
|
+
// Trigger "onInput" when pressing delete or backspace, when input is focused
|
|
37
|
+
if (['Delete', 'Backspace'].includes(event.key)) {
|
|
38
|
+
this.elementRef.nativeElement.dispatchEvent(new Event('input', {
|
|
39
|
+
bubbles: true,
|
|
40
|
+
cancelable: true,
|
|
41
|
+
}));
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
ngOnInit() {
|
|
45
|
+
if (this.control) {
|
|
46
|
+
this.control.setValidators(this.control.validator
|
|
47
|
+
? [this.control.validator, this.validate]
|
|
48
|
+
: [this.validate]);
|
|
49
|
+
this.control.updateValueAndValidity();
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
ngOnDestroy() {
|
|
53
|
+
this.inputMaskPlugin?.remove();
|
|
54
|
+
this.mutationObserver?.disconnect();
|
|
55
|
+
}
|
|
56
|
+
initInputMask() {
|
|
57
|
+
if (isPlatformServer(this.platformId) ||
|
|
58
|
+
!this.nativeInputElement ||
|
|
59
|
+
!Object.keys(this.nggvInputMask).length) {
|
|
60
|
+
return;
|
|
61
|
+
}
|
|
62
|
+
this.inputMaskPlugin = this.ngZone.runOutsideAngular(() => new InputmaskConstructor(this.inputMaskOptions).mask(this.nativeInputElement));
|
|
63
|
+
if (this.control) {
|
|
64
|
+
setTimeout(() => {
|
|
65
|
+
this.control.updateValueAndValidity();
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
ngAfterViewInit() {
|
|
70
|
+
this.initInputMask();
|
|
71
|
+
}
|
|
72
|
+
get inputMaskOptions() {
|
|
73
|
+
const { parser, ...options } = this.nggvInputMask;
|
|
74
|
+
return options;
|
|
75
|
+
}
|
|
76
|
+
writeValue(value) {
|
|
77
|
+
if (this.nativeInputElement) {
|
|
78
|
+
this.renderer.setProperty(this.nativeInputElement, 'value', value ?? '');
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
registerOnChange(fn) {
|
|
82
|
+
// Use injected parser from settings to modify value
|
|
83
|
+
// of users desire
|
|
84
|
+
this.onInput = (value) => {
|
|
85
|
+
const parser = this.nggvInputMask?.parser;
|
|
86
|
+
const newValue = parser && value ? parser(value) : value;
|
|
87
|
+
fn(newValue);
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
registerOnTouched(fn) {
|
|
91
|
+
this.onTouched = fn;
|
|
92
|
+
}
|
|
93
|
+
setDisabledState(disabled) {
|
|
94
|
+
if (this.nativeInputElement) {
|
|
95
|
+
this.renderer.setProperty(this.nativeInputElement, 'disabled', disabled);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
get control() {
|
|
99
|
+
return this.ngControl?.control;
|
|
100
|
+
}
|
|
101
|
+
setNativeInputElement(config) {
|
|
102
|
+
if (this.elementRef.nativeElement.tagName === 'INPUT') {
|
|
103
|
+
this.nativeInputElement = this.elementRef.nativeElement;
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
this.defaultInputMaskConfig = {
|
|
107
|
+
...this.defaultInputMaskConfig,
|
|
108
|
+
...config,
|
|
109
|
+
};
|
|
110
|
+
if (this.defaultInputMaskConfig.isAsync) {
|
|
111
|
+
// Create an observer instance linked to the callback function
|
|
112
|
+
this.mutationObserver = new MutationObserver((mutationsList) => {
|
|
113
|
+
for (const mutation of mutationsList) {
|
|
114
|
+
if (mutation.type === 'childList') {
|
|
115
|
+
const nativeInputElement = this.elementRef.nativeElement.querySelector(this.defaultInputMaskConfig.inputSelector);
|
|
116
|
+
if (nativeInputElement) {
|
|
117
|
+
this.nativeInputElement = nativeInputElement;
|
|
118
|
+
this.mutationObserver?.disconnect();
|
|
119
|
+
this.initInputMask();
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
});
|
|
124
|
+
// Start observing the target node for configured mutations
|
|
125
|
+
this.mutationObserver.observe(this.elementRef.nativeElement, {
|
|
126
|
+
childList: true,
|
|
127
|
+
subtree: true,
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
this.nativeInputElement = this.elementRef.nativeElement.querySelector(this.defaultInputMaskConfig.inputSelector);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvInputMaskDirective, deps: [{ token: i1.NgControl, optional: true, self: true }, { token: INPUT_MASK_CONFIG }, { token: PLATFORM_ID }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
136
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: NgvInputMaskDirective, selector: "[nggvInputMask]", inputs: { nggvInputMask: "nggvInputMask" }, host: { listeners: { "input": "onInput($event.target.value)", "blur": "onTouched($event.target.value)", "keyup": "onKeyUp($event)" } }, ngImport: i0 }); }
|
|
137
|
+
}
|
|
138
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvInputMaskDirective, decorators: [{
|
|
139
|
+
type: Directive,
|
|
140
|
+
args: [{
|
|
141
|
+
selector: '[nggvInputMask]',
|
|
142
|
+
}]
|
|
143
|
+
}], ctorParameters: function () { return [{ type: i1.NgControl, decorators: [{
|
|
144
|
+
type: Optional
|
|
145
|
+
}, {
|
|
146
|
+
type: Self
|
|
147
|
+
}] }, { type: i2.InputMaskConfig, decorators: [{
|
|
148
|
+
type: Inject,
|
|
149
|
+
args: [INPUT_MASK_CONFIG]
|
|
150
|
+
}] }, { type: undefined, decorators: [{
|
|
151
|
+
type: Inject,
|
|
152
|
+
args: [PLATFORM_ID]
|
|
153
|
+
}] }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.NgZone }]; }, propDecorators: { nggvInputMask: [{
|
|
154
|
+
type: Input
|
|
155
|
+
}], onInput: [{
|
|
156
|
+
type: HostListener,
|
|
157
|
+
args: ['input', ['$event.target.value']]
|
|
158
|
+
}], onTouched: [{
|
|
159
|
+
type: HostListener,
|
|
160
|
+
args: ['blur', ['$event.target.value']]
|
|
161
|
+
}], onKeyUp: [{
|
|
162
|
+
type: HostListener,
|
|
163
|
+
args: ['keyup', ['$event']]
|
|
164
|
+
}] } });
|
|
165
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-mask.directive.js","sourceRoot":"","sources":["../../../../../../libs/angular/src/v-angular/input-mask/input-mask.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformServer } from '@angular/common'\nimport {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  HostListener,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Optional,\n  PLATFORM_ID,\n  Renderer2,\n  Self,\n} from '@angular/core'\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  NgControl,\n  Validator,\n} from '@angular/forms'\n\nimport type Inputmask from 'inputmask'\nimport _Inputmask from 'inputmask'\n\nimport { INPUT_MASK_CONFIG, InputMaskConfig } from './config'\nimport type { InputmaskOptions } from './input-mask.types'\n\nconst InputmaskConstructor =\n  (_Inputmask as unknown as { default?: Inputmask.Static }).default ||\n  _Inputmask\n\n@Directive({\n  selector: '[nggvInputMask]',\n})\nexport class NgvInputMaskDirective<T = any>\n  implements OnInit, AfterViewInit, OnDestroy, ControlValueAccessor, Validator\n{\n  /** Input settings of directive */\n  @Input() nggvInputMask: InputmaskOptions<T> = {}\n\n  inputMaskPlugin: Inputmask.Instance | undefined\n  nativeInputElement: HTMLInputElement | undefined\n  defaultInputMaskConfig = new InputMaskConfig()\n\n  private mutationObserver: MutationObserver | undefined\n\n  constructor(\n    @Optional() @Self() public ngControl: NgControl,\n    @Inject(INPUT_MASK_CONFIG) config: InputMaskConfig,\n    @Inject(PLATFORM_ID) private platformId: string,\n    private elementRef: ElementRef<HTMLInputElement | any>,\n    private renderer: Renderer2,\n    private ngZone: NgZone,\n  ) {\n    if (this.ngControl) {\n      this.ngControl.valueAccessor = this\n    }\n    this.setNativeInputElement(config)\n  }\n\n  @HostListener('input', ['$event.target.value'])\n  onInput = (_: any) => {\n    // Empty method\n  }\n\n  @HostListener('blur', ['$event.target.value'])\n  onTouched = (_: any) => {\n    // Empty method\n  }\n\n  @HostListener('keyup', ['$event'])\n  onKeyUp(event: KeyboardEvent) {\n    // Trigger \"onInput\" when pressing delete or backspace, when input is focused\n    if (['Delete', 'Backspace'].includes(event.key)) {\n      this.elementRef.nativeElement.dispatchEvent(\n        new Event('input', {\n          bubbles: true,\n          cancelable: true,\n        }),\n      )\n    }\n  }\n\n  ngOnInit() {\n    if (this.control) {\n      this.control.setValidators(\n        this.control.validator\n          ? [this.control.validator, this.validate]\n          : [this.validate],\n      )\n\n      this.control.updateValueAndValidity()\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.inputMaskPlugin?.remove()\n    this.mutationObserver?.disconnect()\n  }\n\n  initInputMask() {\n    if (\n      isPlatformServer(this.platformId) ||\n      !this.nativeInputElement ||\n      !Object.keys(this.nggvInputMask).length\n    ) {\n      return\n    }\n\n    this.inputMaskPlugin = this.ngZone.runOutsideAngular(() =>\n      new InputmaskConstructor(this.inputMaskOptions).mask(\n        this.nativeInputElement as HTMLInputElement,\n      ),\n    )\n\n    if (this.control) {\n      setTimeout(() => {\n        this.control!.updateValueAndValidity()\n      })\n    }\n  }\n\n  ngAfterViewInit() {\n    this.initInputMask()\n  }\n\n  get inputMaskOptions(): Inputmask.Options {\n    const { parser, ...options } = this.nggvInputMask\n    return options\n  }\n\n  writeValue(value: string): void {\n    if (this.nativeInputElement) {\n      this.renderer.setProperty(this.nativeInputElement, 'value', value ?? '')\n    }\n  }\n\n  registerOnChange(fn: (_: T | null) => void): void {\n    // Use injected parser from settings to modify value\n    // of users desire\n    this.onInput = (value) => {\n      const parser = this.nggvInputMask?.parser\n      const newValue = parser && value ? parser(value) : value\n      fn(newValue)\n    }\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn\n  }\n\n  validate = (control: AbstractControl): { [key: string]: any } | null =>\n    !control.value || !this.inputMaskPlugin || this.inputMaskPlugin.isValid()\n      ? null\n      : { invalidformat: true }\n\n  setDisabledState(disabled: boolean): void {\n    if (this.nativeInputElement) {\n      this.renderer.setProperty(this.nativeInputElement, 'disabled', disabled)\n    }\n  }\n\n  private get control(): AbstractControl | null | undefined {\n    return this.ngControl?.control\n  }\n\n  private setNativeInputElement(config: InputMaskConfig) {\n    if (this.elementRef.nativeElement.tagName === 'INPUT') {\n      this.nativeInputElement = this.elementRef.nativeElement\n    } else {\n      this.defaultInputMaskConfig = {\n        ...this.defaultInputMaskConfig,\n        ...config,\n      }\n      if (this.defaultInputMaskConfig.isAsync) {\n        // Create an observer instance linked to the callback function\n        this.mutationObserver = new MutationObserver((mutationsList) => {\n          for (const mutation of mutationsList) {\n            if (mutation.type === 'childList') {\n              const nativeInputElement =\n                this.elementRef.nativeElement.querySelector(\n                  this.defaultInputMaskConfig.inputSelector,\n                )\n              if (nativeInputElement) {\n                this.nativeInputElement = nativeInputElement\n                this.mutationObserver?.disconnect()\n                this.initInputMask()\n              }\n            }\n          }\n        })\n\n        // Start observing the target node for configured mutations\n        this.mutationObserver.observe(this.elementRef.nativeElement, {\n          childList: true,\n          subtree: true,\n        })\n      } else {\n        this.nativeInputElement = this.elementRef.nativeElement.querySelector(\n          this.defaultInputMaskConfig.inputSelector,\n        )\n      }\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { INPUT_MASK_CONFIG, InputMaskConfig } from './config';
|
|
3
|
+
import { InputMaskFormatPipe } from './input-mask-format.pipe';
|
|
4
|
+
import { NgvInputMaskDirective } from './input-mask.directive';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class NgvInputMaskModule {
|
|
7
|
+
static forRoot(config) {
|
|
8
|
+
return {
|
|
9
|
+
ngModule: NgvInputMaskModule,
|
|
10
|
+
providers: [{ provide: INPUT_MASK_CONFIG, useValue: config }],
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvInputMaskModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
14
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: NgvInputMaskModule, declarations: [NgvInputMaskDirective, InputMaskFormatPipe], exports: [NgvInputMaskDirective, InputMaskFormatPipe] }); }
|
|
15
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvInputMaskModule, providers: [
|
|
16
|
+
{
|
|
17
|
+
provide: INPUT_MASK_CONFIG,
|
|
18
|
+
useClass: InputMaskConfig,
|
|
19
|
+
},
|
|
20
|
+
] }); }
|
|
21
|
+
}
|
|
22
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvInputMaskModule, decorators: [{
|
|
23
|
+
type: NgModule,
|
|
24
|
+
args: [{
|
|
25
|
+
declarations: [NgvInputMaskDirective, InputMaskFormatPipe],
|
|
26
|
+
exports: [NgvInputMaskDirective, InputMaskFormatPipe],
|
|
27
|
+
providers: [
|
|
28
|
+
{
|
|
29
|
+
provide: INPUT_MASK_CONFIG,
|
|
30
|
+
useClass: InputMaskConfig,
|
|
31
|
+
},
|
|
32
|
+
],
|
|
33
|
+
}]
|
|
34
|
+
}] });
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtbWFzay5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL3YtYW5ndWxhci9pbnB1dC1tYXNrL2lucHV0LW1hc2subW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBdUIsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBRTdELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxlQUFlLEVBQUUsTUFBTSxVQUFVLENBQUE7QUFDN0QsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sMEJBQTBCLENBQUE7QUFDOUQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sd0JBQXdCLENBQUE7O0FBWTlELE1BQU0sT0FBTyxrQkFBa0I7SUFDN0IsTUFBTSxDQUFDLE9BQU8sQ0FDWixNQUFpQztRQUVqQyxPQUFPO1lBQ0wsUUFBUSxFQUFFLGtCQUFrQjtZQUM1QixTQUFTLEVBQUUsQ0FBQyxFQUFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLENBQUM7U0FDOUQsQ0FBQTtJQUNILENBQUM7K0dBUlUsa0JBQWtCO2dIQUFsQixrQkFBa0IsaUJBVGQscUJBQXFCLEVBQUUsbUJBQW1CLGFBQy9DLHFCQUFxQixFQUFFLG1CQUFtQjtnSEFRekMsa0JBQWtCLGFBUGxCO1lBQ1Q7Z0JBQ0UsT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsUUFBUSxFQUFFLGVBQWU7YUFDMUI7U0FDRjs7NEZBRVUsa0JBQWtCO2tCQVY5QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLHFCQUFxQixFQUFFLG1CQUFtQixDQUFDO29CQUMxRCxPQUFPLEVBQUUsQ0FBQyxxQkFBcUIsRUFBRSxtQkFBbUIsQ0FBQztvQkFDckQsU0FBUyxFQUFFO3dCQUNUOzRCQUNFLE9BQU8sRUFBRSxpQkFBaUI7NEJBQzFCLFFBQVEsRUFBRSxlQUFlO3lCQUMxQjtxQkFDRjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1vZHVsZVdpdGhQcm92aWRlcnMsIE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcblxuaW1wb3J0IHsgSU5QVVRfTUFTS19DT05GSUcsIElucHV0TWFza0NvbmZpZyB9IGZyb20gJy4vY29uZmlnJ1xuaW1wb3J0IHsgSW5wdXRNYXNrRm9ybWF0UGlwZSB9IGZyb20gJy4vaW5wdXQtbWFzay1mb3JtYXQucGlwZSdcbmltcG9ydCB7IE5ndklucHV0TWFza0RpcmVjdGl2ZSB9IGZyb20gJy4vaW5wdXQtbWFzay5kaXJlY3RpdmUnXG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW05ndklucHV0TWFza0RpcmVjdGl2ZSwgSW5wdXRNYXNrRm9ybWF0UGlwZV0sXG4gIGV4cG9ydHM6IFtOZ3ZJbnB1dE1hc2tEaXJlY3RpdmUsIElucHV0TWFza0Zvcm1hdFBpcGVdLFxuICBwcm92aWRlcnM6IFtcbiAgICB7XG4gICAgICBwcm92aWRlOiBJTlBVVF9NQVNLX0NPTkZJRyxcbiAgICAgIHVzZUNsYXNzOiBJbnB1dE1hc2tDb25maWcsXG4gICAgfSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgTmd2SW5wdXRNYXNrTW9kdWxlIHtcbiAgc3RhdGljIGZvclJvb3QoXG4gICAgY29uZmlnPzogUGFydGlhbDxJbnB1dE1hc2tDb25maWc+LFxuICApOiBNb2R1bGVXaXRoUHJvdmlkZXJzPE5ndklucHV0TWFza01vZHVsZT4ge1xuICAgIHJldHVybiB7XG4gICAgICBuZ01vZHVsZTogTmd2SW5wdXRNYXNrTW9kdWxlLFxuICAgICAgcHJvdmlkZXJzOiBbeyBwcm92aWRlOiBJTlBVVF9NQVNLX0NPTkZJRywgdXNlVmFsdWU6IGNvbmZpZyB9XSxcbiAgICB9XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtbWFzay50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9zcmMvdi1hbmd1bGFyL2lucHV0LW1hc2svaW5wdXQtbWFzay50eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgSW5wdXRtYXNrIGZyb20gJ2lucHV0bWFzayc7XG5cbmV4cG9ydCB0eXBlIElucHV0bWFza09wdGlvbnM8VD4gPSBJbnB1dG1hc2suT3B0aW9ucyAmIHtcbiAgcGFyc2VyPzogKHZhbHVlOiBhbnkpID0+IFQ7XG59O1xuXG4vKipcbiAqIFVzZWZ1bCB3aGVuIHlvdSB3YW50IHRvIGFkZCBpbnB1dC1tYXNrIG9uIGlucHV0IHdoaWNoIGlzIGNoaWxkIG9mIHlvdXIgY29tcG9uZW50XG4gKlxuICogQHNpbmNlIDIuMS4wXG4gKi9cbmV4cG9ydCB0eXBlIElucHV0TWFza0NvbmZpZyA9IHtcbiAgLyoqXG4gICAqIElmIHNldCB0cnVlLCBNdXRhdGlvbk9ic2VydmVyIHdpbGwgYmUgdXNlZCB0byBsb29rIGZvciBjaGFuZ2VzIHVudGlsIGl0IGZpbmRzIGlucHV0IHdpdGggaW5wdXRTZWxlY3RvclxuICAgKi9cbiAgaXNBc3luYzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIENTUyBsaWtlIHNlbGVjdG9yLCB3aGljaCB3aWxsIGJlIHVzZWQgd2l0aCBgcXVlcnlTZWxlY3RvcmAgdG8gZ2V0IHRoZSBuYXRpdmUgaW5wdXQuXG4gICAqIElmIHlvdXIgaW5wdXQgaXMgbG9hZGVkIGxhemlseSwgcGxlYXNlIHVzZSBgaXNBc3luY2Agb3B0aW9uIHdpdGggdGhpc1xuICAgKi9cbiAgaW5wdXRTZWxlY3Rvcjogc3RyaW5nO1xufTtcbiJdfQ==
|
|
@@ -0,0 +1,190 @@
|
|
|
1
|
+
import { Component, EventEmitter, HostBinding, HostListener, Input, Output, ViewChild, } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
export class NgvDialogComponent {
|
|
5
|
+
constructor() {
|
|
6
|
+
/** Special property used for selecting DOM elements during automated UI testing. */
|
|
7
|
+
this.thook = 'dialog';
|
|
8
|
+
/** @internal */
|
|
9
|
+
this.baseClass = true;
|
|
10
|
+
/** @internal Defines the default visibility state of the dialog. */
|
|
11
|
+
this.shown = false;
|
|
12
|
+
/** Defines the default visibility state of the dialog. */
|
|
13
|
+
this.initiallyShown = false;
|
|
14
|
+
/**
|
|
15
|
+
* Sets modal title. Will be translated (using transloco) if the string matches a cms key.
|
|
16
|
+
* @deprecated - use heading instead.
|
|
17
|
+
*/
|
|
18
|
+
this.title = 'Attention';
|
|
19
|
+
/** Defines if dialog should close on action. */
|
|
20
|
+
this.autoClose = true;
|
|
21
|
+
/** An array of event payloads that will be added to every click context menu item click. */
|
|
22
|
+
this.payload = {};
|
|
23
|
+
/** It gives an ability for parent component to control if modal should be closed on esc button click. */
|
|
24
|
+
this.closeModalOnEscape = true;
|
|
25
|
+
// /** @internal */
|
|
26
|
+
// closeIcon = faTimes
|
|
27
|
+
this.nggvCloseEvent = new EventEmitter();
|
|
28
|
+
this.nggvPositiveEvent = new EventEmitter();
|
|
29
|
+
this.nggvNeutralEvent = new EventEmitter();
|
|
30
|
+
this.nggvNegativeEvent = new EventEmitter();
|
|
31
|
+
}
|
|
32
|
+
/** @internal */
|
|
33
|
+
get ariaHidden() {
|
|
34
|
+
return !this.shown;
|
|
35
|
+
}
|
|
36
|
+
/** Buttons are defined as a key-value pair where key is one of "positive|neutral|negative" and value is the button label. */
|
|
37
|
+
set buttons(buttons) {
|
|
38
|
+
this._buttons = buttons;
|
|
39
|
+
}
|
|
40
|
+
ngOnInit() {
|
|
41
|
+
this.dialogTitleId =
|
|
42
|
+
this.dialogTitleId ?? 'sdv-dialog-title-' + window.nggv?.nextId();
|
|
43
|
+
this.dialogBodyId =
|
|
44
|
+
this.dialogBodyId ?? 'sdv-dialog-body-' + window.nggv?.nextId();
|
|
45
|
+
this.shown = this.initiallyShown;
|
|
46
|
+
if (this.shown)
|
|
47
|
+
this._limitFocusable();
|
|
48
|
+
}
|
|
49
|
+
onAction(event, action) {
|
|
50
|
+
event.preventDefault();
|
|
51
|
+
const emitEvent = {
|
|
52
|
+
original: event,
|
|
53
|
+
payload: this.payload,
|
|
54
|
+
};
|
|
55
|
+
switch (action) {
|
|
56
|
+
case 'positive':
|
|
57
|
+
this.nggvPositiveEvent.emit(emitEvent);
|
|
58
|
+
break;
|
|
59
|
+
case 'neutral':
|
|
60
|
+
this.nggvNeutralEvent.emit(emitEvent);
|
|
61
|
+
break;
|
|
62
|
+
case 'negative':
|
|
63
|
+
this.nggvNegativeEvent.emit(emitEvent);
|
|
64
|
+
break;
|
|
65
|
+
// case 'close' is handled by if-statement below with call to this.close()
|
|
66
|
+
}
|
|
67
|
+
if (this.autoClose)
|
|
68
|
+
this.close(event, 'action');
|
|
69
|
+
}
|
|
70
|
+
open(opener) {
|
|
71
|
+
this.shown = true;
|
|
72
|
+
this._previous = opener || document.activeElement;
|
|
73
|
+
this._limitFocusable();
|
|
74
|
+
return true;
|
|
75
|
+
}
|
|
76
|
+
_limitFocusable() {
|
|
77
|
+
window.setTimeout(() => {
|
|
78
|
+
if (!this.dialogRef)
|
|
79
|
+
return;
|
|
80
|
+
const focusable = this.dialogRef.nativeElement.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])');
|
|
81
|
+
this._firstFocusable = focusable[0];
|
|
82
|
+
this._lastFocusable = focusable[focusable.length - 1];
|
|
83
|
+
if (this._lastFocusable)
|
|
84
|
+
this._lastFocusable.focus();
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
close(event, initiator) {
|
|
88
|
+
if (initiator === 'host' && event instanceof MouseEvent)
|
|
89
|
+
return;
|
|
90
|
+
// prevent modal from closing on esc button click when closeModalOnEscape is set to false
|
|
91
|
+
if (!this.closeModalOnEscape)
|
|
92
|
+
return;
|
|
93
|
+
if (this.shown) {
|
|
94
|
+
const emitEvent = {
|
|
95
|
+
original: event,
|
|
96
|
+
payload: this.payload,
|
|
97
|
+
};
|
|
98
|
+
this.nggvCloseEvent.emit(emitEvent);
|
|
99
|
+
}
|
|
100
|
+
this.shown = false;
|
|
101
|
+
window.setTimeout(() => {
|
|
102
|
+
if (this._previous)
|
|
103
|
+
this._previous.focus();
|
|
104
|
+
this._previous = undefined;
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
focusTrap(event) {
|
|
108
|
+
if (event.key !== 'Tab')
|
|
109
|
+
return;
|
|
110
|
+
if (event.shiftKey) {
|
|
111
|
+
// shift + tab
|
|
112
|
+
if (this._lastFocusable &&
|
|
113
|
+
document.activeElement === this._firstFocusable) {
|
|
114
|
+
this._lastFocusable.focus();
|
|
115
|
+
event.preventDefault();
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
else {
|
|
119
|
+
// tab
|
|
120
|
+
if (this._firstFocusable &&
|
|
121
|
+
document.activeElement === this._lastFocusable) {
|
|
122
|
+
this._firstFocusable.focus();
|
|
123
|
+
event.preventDefault();
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvDialogComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
128
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgvDialogComponent, selector: "nggv-dialog", inputs: { thook: "thook", shown: "shown", initiallyShown: "initiallyShown", heading: "heading", title: "title", content: "content", autoClose: "autoClose", payload: "payload", dialogTitleId: "dialogTitleId", dialogBodyId: "dialogBodyId", closeModalOnEscape: "closeModalOnEscape", buttons: "buttons" }, outputs: { nggvCloseEvent: "nggvCloseEvent", nggvPositiveEvent: "nggvPositiveEvent", nggvNeutralEvent: "nggvNeutralEvent", nggvNegativeEvent: "nggvNegativeEvent" }, host: { listeners: { "click": "close($event,\"host\")", "document:keydown.escape": "close($event)", "keydown": "focusTrap($event)" }, properties: { "attr.data-thook": "this.thook", "class.sdv-modal-dialog": "this.baseClass", "class.-active": "this.shown", "attr.aria-hidden": "this.ariaHidden" } }, viewQueries: [{ propertyName: "dialogRef", first: true, predicate: ["dialog"], descendants: true }], exportAs: ["dialog"], ngImport: i0, template: "<div\n class=\"sdv-modal-dialog__container\"\n *transloco=\"let t\"\n #dialog\n role=\"dialog\"\n aria-dialog=\"true\"\n [attr.aria-labelledby]=\"dialogTitleId\"\n [attr.aria-describedby]=\"dialogBodyId\"\n>\n <header class=\"sdv-modal-dialog__heading\">\n <h3 [attr.id]=\"dialogTitleId\">{{ t(heading || title || '') }}</h3>\n <button\n type=\"button\"\n data-thook=\"dialog-close\"\n (click)=\"onAction($event, 'close')\"\n (keydown.enter)=\"onAction($event, 'close')\"\n class=\"close\"\n >\n <gds-icon-cross-small\n *nggCoreElement\n width=\"24\"\n height=\"24\"\n ></gds-icon-cross-small>\n </button>\n </header>\n <section class=\"sdv-modal-dialog__body\" [attr.id]=\"dialogBodyId\">\n <div [innerHtml]=\"content\"></div>\n <ng-content></ng-content>\n </section>\n <footer class=\"sdv-modal-dialog__actions\">\n <button\n class=\"sdv-button sdv-button-delete\"\n type=\"reset\"\n [attr.data-thook]=\"'dialog-' + (_buttons?.negative || 'negative')\"\n (click)=\"onAction($event, 'negative')\"\n (keydown.enter)=\"onAction($event, 'negative')\"\n *ngIf=\"_buttons && _buttons.negative\"\n >\n {{ t(_buttons.negative) }}\n </button>\n <button\n class=\"sdv-button sdv-button-secondary\"\n type=\"button\"\n [attr.data-thook]=\"'dialog-' + (_buttons?.neutral || 'neutral')\"\n (click)=\"onAction($event, 'neutral')\"\n (keydown.enter)=\"onAction($event, 'neutral')\"\n *ngIf=\"_buttons && _buttons.neutral\"\n >\n {{ t(_buttons.neutral) }}\n </button>\n <button\n class=\"sdv-button\"\n type=\"submit\"\n [attr.data-thook]=\"'dialog-' + (_buttons?.positive || 'positive')\"\n (click)=\"onAction($event, 'positive')\"\n (keydown.enter)=\"onAction($event, 'positive')\"\n *ngIf=\"_buttons && _buttons.positive\"\n >\n {{ t(_buttons.positive) }}\n </button>\n </footer>\n</div>\n\n<div class=\"sdv-modal-backdrop\"></div>\n", styles: [":host{inset:0;position:fixed;display:grid;place-content:center;z-index:calc(var(--sg-z-index-modal-backdrop) + 1)}:host .sdv-modal-dialog__container{background:var(--sg-modal-background);display:flex;flex-direction:column;box-shadow:var(--sg-modal-box-shadow);position:absolute;width:100%;z-index:var(--sg-z-index-modal);position:initial;width:375px;max-width:95vw}:host .sdv-modal-dialog__container>.header,:host .sdv-modal-dialog__container>header{padding:1rem;border-bottom:solid var(--sg-border-width) var(--sg-border-color);--border-color: var(--sg-border-color);display:inline-flex;justify-content:space-between;align-items:center;width:100%}:host .sdv-modal-dialog__container>.header h3,:host .sdv-modal-dialog__container>.header .h3,:host .sdv-modal-dialog__container>header h3,:host .sdv-modal-dialog__container>header .h3{margin-bottom:0;margin-top:0}:host .sdv-modal-dialog__container>.header h3+.close,:host .sdv-modal-dialog__container>.header .h3+.close,:host .sdv-modal-dialog__container>header h3+.close,:host .sdv-modal-dialog__container>header .h3+.close{margin:-7px}:host .sdv-modal-dialog__container>.body{padding:1rem;overflow:auto;width:100%}:host .sdv-modal-dialog__container>.body p{margin-bottom:0;margin-top:0}:host .sdv-modal-dialog__container>.footer,:host .sdv-modal-dialog__container>footer{padding:1rem;width:100%}@media (min-width: 36em){:host .sdv-modal-dialog__container>.footer,:host .sdv-modal-dialog__container>footer{display:flex;justify-content:flex-end}}@media (max-width: 35.98em){:host .sdv-modal-dialog__container>.footer button+button,:host .sdv-modal-dialog__container>.footer button+.button,:host .sdv-modal-dialog__container>.footer .button+button,:host .sdv-modal-dialog__container>.footer .button+.button,:host .sdv-modal-dialog__container>footer button+button,:host .sdv-modal-dialog__container>footer button+.button,:host .sdv-modal-dialog__container>footer .button+button,:host .sdv-modal-dialog__container>footer .button+.button{margin-top:.75rem}}@media (min-width: 36em){:host .sdv-modal-dialog__container>.footer button+button,:host .sdv-modal-dialog__container>.footer button+.button,:host .sdv-modal-dialog__container>.footer .button+button,:host .sdv-modal-dialog__container>.footer .button+.button,:host .sdv-modal-dialog__container>footer button+button,:host .sdv-modal-dialog__container>footer button+.button,:host .sdv-modal-dialog__container>footer .button+button,:host .sdv-modal-dialog__container>footer .button+.button{margin-left:.75rem}}:host .sdv-modal-dialog__container.medium{width:512px}:host .sdv-modal-dialog__container.large{width:720px}:host .sdv-modal-dialog__heading{padding:1rem;border-bottom:solid var(--sg-border-width) var(--sg-border-color);--border-color: var(--sg-border-color);display:inline-flex;justify-content:space-between;align-items:center;width:100%}:host .sdv-modal-dialog__heading h3,:host .sdv-modal-dialog__heading .h3{margin-bottom:0;margin-top:0}:host .sdv-modal-dialog__heading h3+.close,:host .sdv-modal-dialog__heading .h3+.close{margin:-7px}:host .sdv-modal-dialog__heading button{display:grid;place-content:center}:host .sdv-modal-dialog__body{padding:1rem;overflow:auto;width:100%}:host .sdv-modal-dialog__body p{margin-bottom:0;margin-top:0}:host .sdv-modal-backdrop{background:#00000059;inset:0;position:fixed;z-index:999;display:block;transition:opacity .5s cubic-bezier(.33,1,.68,1)}:host .sdv-modal-backdrop--transparent{opacity:0}:host .sdv-modal-backdrop--transparent.entered,:host .sdv-modal-backdrop--transparent.is-entering{opacity:1}:host .sdv-modal-backdrop--transparent.is-exiting{opacity:0}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
129
|
+
}
|
|
130
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvDialogComponent, decorators: [{
|
|
131
|
+
type: Component,
|
|
132
|
+
args: [{ selector: 'nggv-dialog', exportAs: 'dialog', template: "<div\n class=\"sdv-modal-dialog__container\"\n *transloco=\"let t\"\n #dialog\n role=\"dialog\"\n aria-dialog=\"true\"\n [attr.aria-labelledby]=\"dialogTitleId\"\n [attr.aria-describedby]=\"dialogBodyId\"\n>\n <header class=\"sdv-modal-dialog__heading\">\n <h3 [attr.id]=\"dialogTitleId\">{{ t(heading || title || '') }}</h3>\n <button\n type=\"button\"\n data-thook=\"dialog-close\"\n (click)=\"onAction($event, 'close')\"\n (keydown.enter)=\"onAction($event, 'close')\"\n class=\"close\"\n >\n <gds-icon-cross-small\n *nggCoreElement\n width=\"24\"\n height=\"24\"\n ></gds-icon-cross-small>\n </button>\n </header>\n <section class=\"sdv-modal-dialog__body\" [attr.id]=\"dialogBodyId\">\n <div [innerHtml]=\"content\"></div>\n <ng-content></ng-content>\n </section>\n <footer class=\"sdv-modal-dialog__actions\">\n <button\n class=\"sdv-button sdv-button-delete\"\n type=\"reset\"\n [attr.data-thook]=\"'dialog-' + (_buttons?.negative || 'negative')\"\n (click)=\"onAction($event, 'negative')\"\n (keydown.enter)=\"onAction($event, 'negative')\"\n *ngIf=\"_buttons && _buttons.negative\"\n >\n {{ t(_buttons.negative) }}\n </button>\n <button\n class=\"sdv-button sdv-button-secondary\"\n type=\"button\"\n [attr.data-thook]=\"'dialog-' + (_buttons?.neutral || 'neutral')\"\n (click)=\"onAction($event, 'neutral')\"\n (keydown.enter)=\"onAction($event, 'neutral')\"\n *ngIf=\"_buttons && _buttons.neutral\"\n >\n {{ t(_buttons.neutral) }}\n </button>\n <button\n class=\"sdv-button\"\n type=\"submit\"\n [attr.data-thook]=\"'dialog-' + (_buttons?.positive || 'positive')\"\n (click)=\"onAction($event, 'positive')\"\n (keydown.enter)=\"onAction($event, 'positive')\"\n *ngIf=\"_buttons && _buttons.positive\"\n >\n {{ t(_buttons.positive) }}\n </button>\n </footer>\n</div>\n\n<div class=\"sdv-modal-backdrop\"></div>\n", styles: [":host{inset:0;position:fixed;display:grid;place-content:center;z-index:calc(var(--sg-z-index-modal-backdrop) + 1)}:host .sdv-modal-dialog__container{background:var(--sg-modal-background);display:flex;flex-direction:column;box-shadow:var(--sg-modal-box-shadow);position:absolute;width:100%;z-index:var(--sg-z-index-modal);position:initial;width:375px;max-width:95vw}:host .sdv-modal-dialog__container>.header,:host .sdv-modal-dialog__container>header{padding:1rem;border-bottom:solid var(--sg-border-width) var(--sg-border-color);--border-color: var(--sg-border-color);display:inline-flex;justify-content:space-between;align-items:center;width:100%}:host .sdv-modal-dialog__container>.header h3,:host .sdv-modal-dialog__container>.header .h3,:host .sdv-modal-dialog__container>header h3,:host .sdv-modal-dialog__container>header .h3{margin-bottom:0;margin-top:0}:host .sdv-modal-dialog__container>.header h3+.close,:host .sdv-modal-dialog__container>.header .h3+.close,:host .sdv-modal-dialog__container>header h3+.close,:host .sdv-modal-dialog__container>header .h3+.close{margin:-7px}:host .sdv-modal-dialog__container>.body{padding:1rem;overflow:auto;width:100%}:host .sdv-modal-dialog__container>.body p{margin-bottom:0;margin-top:0}:host .sdv-modal-dialog__container>.footer,:host .sdv-modal-dialog__container>footer{padding:1rem;width:100%}@media (min-width: 36em){:host .sdv-modal-dialog__container>.footer,:host .sdv-modal-dialog__container>footer{display:flex;justify-content:flex-end}}@media (max-width: 35.98em){:host .sdv-modal-dialog__container>.footer button+button,:host .sdv-modal-dialog__container>.footer button+.button,:host .sdv-modal-dialog__container>.footer .button+button,:host .sdv-modal-dialog__container>.footer .button+.button,:host .sdv-modal-dialog__container>footer button+button,:host .sdv-modal-dialog__container>footer button+.button,:host .sdv-modal-dialog__container>footer .button+button,:host .sdv-modal-dialog__container>footer .button+.button{margin-top:.75rem}}@media (min-width: 36em){:host .sdv-modal-dialog__container>.footer button+button,:host .sdv-modal-dialog__container>.footer button+.button,:host .sdv-modal-dialog__container>.footer .button+button,:host .sdv-modal-dialog__container>.footer .button+.button,:host .sdv-modal-dialog__container>footer button+button,:host .sdv-modal-dialog__container>footer button+.button,:host .sdv-modal-dialog__container>footer .button+button,:host .sdv-modal-dialog__container>footer .button+.button{margin-left:.75rem}}:host .sdv-modal-dialog__container.medium{width:512px}:host .sdv-modal-dialog__container.large{width:720px}:host .sdv-modal-dialog__heading{padding:1rem;border-bottom:solid var(--sg-border-width) var(--sg-border-color);--border-color: var(--sg-border-color);display:inline-flex;justify-content:space-between;align-items:center;width:100%}:host .sdv-modal-dialog__heading h3,:host .sdv-modal-dialog__heading .h3{margin-bottom:0;margin-top:0}:host .sdv-modal-dialog__heading h3+.close,:host .sdv-modal-dialog__heading .h3+.close{margin:-7px}:host .sdv-modal-dialog__heading button{display:grid;place-content:center}:host .sdv-modal-dialog__body{padding:1rem;overflow:auto;width:100%}:host .sdv-modal-dialog__body p{margin-bottom:0;margin-top:0}:host .sdv-modal-backdrop{background:#00000059;inset:0;position:fixed;z-index:999;display:block;transition:opacity .5s cubic-bezier(.33,1,.68,1)}:host .sdv-modal-backdrop--transparent{opacity:0}:host .sdv-modal-backdrop--transparent.entered,:host .sdv-modal-backdrop--transparent.is-entering{opacity:1}:host .sdv-modal-backdrop--transparent.is-exiting{opacity:0}\n"] }]
|
|
133
|
+
}], propDecorators: { dialogRef: [{
|
|
134
|
+
type: ViewChild,
|
|
135
|
+
args: ['dialog']
|
|
136
|
+
}], thook: [{
|
|
137
|
+
type: HostBinding,
|
|
138
|
+
args: ['attr.data-thook']
|
|
139
|
+
}, {
|
|
140
|
+
type: Input
|
|
141
|
+
}], baseClass: [{
|
|
142
|
+
type: HostBinding,
|
|
143
|
+
args: ['class.sdv-modal-dialog']
|
|
144
|
+
}], shown: [{
|
|
145
|
+
type: HostBinding,
|
|
146
|
+
args: ['class.-active']
|
|
147
|
+
}, {
|
|
148
|
+
type: Input
|
|
149
|
+
}], ariaHidden: [{
|
|
150
|
+
type: HostBinding,
|
|
151
|
+
args: ['attr.aria-hidden']
|
|
152
|
+
}], initiallyShown: [{
|
|
153
|
+
type: Input
|
|
154
|
+
}], heading: [{
|
|
155
|
+
type: Input
|
|
156
|
+
}], title: [{
|
|
157
|
+
type: Input
|
|
158
|
+
}], content: [{
|
|
159
|
+
type: Input
|
|
160
|
+
}], autoClose: [{
|
|
161
|
+
type: Input
|
|
162
|
+
}], payload: [{
|
|
163
|
+
type: Input
|
|
164
|
+
}], dialogTitleId: [{
|
|
165
|
+
type: Input
|
|
166
|
+
}], dialogBodyId: [{
|
|
167
|
+
type: Input
|
|
168
|
+
}], closeModalOnEscape: [{
|
|
169
|
+
type: Input
|
|
170
|
+
}], buttons: [{
|
|
171
|
+
type: Input
|
|
172
|
+
}], nggvCloseEvent: [{
|
|
173
|
+
type: Output
|
|
174
|
+
}], nggvPositiveEvent: [{
|
|
175
|
+
type: Output
|
|
176
|
+
}], nggvNeutralEvent: [{
|
|
177
|
+
type: Output
|
|
178
|
+
}], nggvNegativeEvent: [{
|
|
179
|
+
type: Output
|
|
180
|
+
}], close: [{
|
|
181
|
+
type: HostListener,
|
|
182
|
+
args: ['click', ['$event', '"host"']]
|
|
183
|
+
}, {
|
|
184
|
+
type: HostListener,
|
|
185
|
+
args: ['document:keydown.escape', ['$event']]
|
|
186
|
+
}], focusTrap: [{
|
|
187
|
+
type: HostListener,
|
|
188
|
+
args: ['keydown', ['$event']]
|
|
189
|
+
}] } });
|
|
190
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/src/v-angular/modal/dialog/dialog.component.ts","../../../../../../../libs/angular/src/v-angular/modal/dialog/dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  HostListener,\n  Input,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core'\n\nimport { DialogButtons } from '../modal.types'\n\nexport interface DialogEvent<T = any> {\n  original: Event | undefined\n  payload: T | undefined\n}\n\n@Component({\n  selector: 'nggv-dialog',\n  templateUrl: './dialog.component.html',\n  styleUrls: ['./dialog.component.scss'],\n  exportAs: 'dialog',\n})\nexport class NgvDialogComponent implements OnInit {\n  @ViewChild('dialog') dialogRef: ElementRef | undefined\n\n  /** Special property used for selecting DOM elements during automated UI testing. */\n  @HostBinding('attr.data-thook') @Input() thook = 'dialog'\n  /** @internal */\n  @HostBinding('class.sdv-modal-dialog') baseClass = true\n  /** @internal Defines the default visibility state of the dialog. */\n  @HostBinding('class.-active') @Input() shown = false\n  /** @internal */\n  @HostBinding('attr.aria-hidden') get ariaHidden() {\n    return !this.shown\n  }\n  /** Defines the default visibility state of the dialog. */\n  @Input() initiallyShown = false\n  /** Sets modal heading. Will be translated (using transloco) if the string matches a cms key. */\n  @Input() heading!: string\n  /**\n   * Sets modal title. Will be translated (using transloco) if the string matches a cms key.\n   * @deprecated - use heading instead.\n   */\n  @Input() title = 'Attention'\n  /** Sets content body and can contain html code. The content body can also be set by nesting children to the dialog tag. */\n  @Input() content?: string\n  /** Defines if dialog should close on action. */\n  @Input() autoClose = true\n  /** An array of event payloads that will be added to every click context menu item click. */\n  @Input() payload: any = {}\n\n  @Input() dialogTitleId!: string\n  @Input() dialogBodyId!: string\n  /** It gives an ability for parent component to control if modal should be closed on esc button click. */\n  @Input() closeModalOnEscape = true\n\n  _buttons: DialogButtons | undefined\n  /** Buttons are defined as a key-value pair where key is one of \"positive|neutral|negative\" and value is the button label. */\n  @Input() set buttons(buttons: DialogButtons) {\n    this._buttons = buttons\n  }\n  // /** @internal */\n  // closeIcon = faTimes\n\n  @Output() nggvCloseEvent = new EventEmitter<DialogEvent>()\n  @Output() nggvPositiveEvent = new EventEmitter<DialogEvent>()\n  @Output() nggvNeutralEvent = new EventEmitter<DialogEvent>()\n  @Output() nggvNegativeEvent = new EventEmitter<DialogEvent>()\n\n  protected _previous: HTMLElement | undefined\n  protected _firstFocusable: HTMLElement | undefined\n  protected _lastFocusable: HTMLElement | undefined\n\n  ngOnInit() {\n    this.dialogTitleId =\n      this.dialogTitleId ?? 'sdv-dialog-title-' + window.nggv?.nextId()\n    this.dialogBodyId =\n      this.dialogBodyId ?? 'sdv-dialog-body-' + window.nggv?.nextId()\n\n    this.shown = this.initiallyShown\n    if (this.shown) this._limitFocusable()\n  }\n\n  public onAction(event: Event, action: string) {\n    event.preventDefault()\n    const emitEvent = {\n      original: event,\n      payload: this.payload,\n    }\n    switch (action) {\n      case 'positive':\n        this.nggvPositiveEvent.emit(emitEvent)\n        break\n      case 'neutral':\n        this.nggvNeutralEvent.emit(emitEvent)\n        break\n      case 'negative':\n        this.nggvNegativeEvent.emit(emitEvent)\n        break\n      // case 'close' is handled by if-statement below with call to this.close()\n    }\n    if (this.autoClose) this.close(event, 'action')\n  }\n\n  open(opener?: HTMLElement) {\n    this.shown = true\n    this._previous = opener || (document.activeElement as HTMLElement)\n    this._limitFocusable()\n    return true\n  }\n\n  protected _limitFocusable() {\n    window.setTimeout(() => {\n      if (!this.dialogRef) return\n      const focusable = this.dialogRef.nativeElement.querySelectorAll(\n        'button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"])',\n      )\n      this._firstFocusable = focusable[0]\n      this._lastFocusable = focusable[focusable.length - 1]\n      if (this._lastFocusable) this._lastFocusable.focus()\n    })\n  }\n\n  @HostListener('click', ['$event', '\"host\"'])\n  @HostListener('document:keydown.escape', ['$event'])\n  close(event?: Event, initiator?: string) {\n    if (initiator === 'host' && event instanceof MouseEvent) return\n    // prevent modal from closing on esc button click when closeModalOnEscape is set to false\n    if (!this.closeModalOnEscape) return\n    if (this.shown) {\n      const emitEvent = {\n        original: event,\n        payload: this.payload,\n      }\n      this.nggvCloseEvent.emit(emitEvent)\n    }\n    this.shown = false\n    window.setTimeout(() => {\n      if (this._previous) this._previous.focus()\n      this._previous = undefined\n    })\n  }\n\n  @HostListener('keydown', ['$event'])\n  focusTrap(event: KeyboardEvent) {\n    if (event.key !== 'Tab') return\n    if (event.shiftKey) {\n      // shift + tab\n      if (\n        this._lastFocusable &&\n        document.activeElement === this._firstFocusable\n      ) {\n        this._lastFocusable.focus()\n        event.preventDefault()\n      }\n    } else {\n      // tab\n      if (\n        this._firstFocusable &&\n        document.activeElement === this._lastFocusable\n      ) {\n        this._firstFocusable.focus()\n        event.preventDefault()\n      }\n    }\n  }\n}\n","<div\n  class=\"sdv-modal-dialog__container\"\n  *transloco=\"let t\"\n  #dialog\n  role=\"dialog\"\n  aria-dialog=\"true\"\n  [attr.aria-labelledby]=\"dialogTitleId\"\n  [attr.aria-describedby]=\"dialogBodyId\"\n>\n  <header class=\"sdv-modal-dialog__heading\">\n    <h3 [attr.id]=\"dialogTitleId\">{{ t(heading || title || '') }}</h3>\n    <button\n      type=\"button\"\n      data-thook=\"dialog-close\"\n      (click)=\"onAction($event, 'close')\"\n      (keydown.enter)=\"onAction($event, 'close')\"\n      class=\"close\"\n    >\n      <gds-icon-cross-small\n        *nggCoreElement\n        width=\"24\"\n        height=\"24\"\n      ></gds-icon-cross-small>\n    </button>\n  </header>\n  <section class=\"sdv-modal-dialog__body\" [attr.id]=\"dialogBodyId\">\n    <div [innerHtml]=\"content\"></div>\n    <ng-content></ng-content>\n  </section>\n  <footer class=\"sdv-modal-dialog__actions\">\n    <button\n      class=\"sdv-button sdv-button-delete\"\n      type=\"reset\"\n      [attr.data-thook]=\"'dialog-' + (_buttons?.negative || 'negative')\"\n      (click)=\"onAction($event, 'negative')\"\n      (keydown.enter)=\"onAction($event, 'negative')\"\n      *ngIf=\"_buttons && _buttons.negative\"\n    >\n      {{ t(_buttons.negative) }}\n    </button>\n    <button\n      class=\"sdv-button sdv-button-secondary\"\n      type=\"button\"\n      [attr.data-thook]=\"'dialog-' + (_buttons?.neutral || 'neutral')\"\n      (click)=\"onAction($event, 'neutral')\"\n      (keydown.enter)=\"onAction($event, 'neutral')\"\n      *ngIf=\"_buttons && _buttons.neutral\"\n    >\n      {{ t(_buttons.neutral) }}\n    </button>\n    <button\n      class=\"sdv-button\"\n      type=\"submit\"\n      [attr.data-thook]=\"'dialog-' + (_buttons?.positive || 'positive')\"\n      (click)=\"onAction($event, 'positive')\"\n      (keydown.enter)=\"onAction($event, 'positive')\"\n      *ngIf=\"_buttons && _buttons.positive\"\n    >\n      {{ t(_buttons.positive) }}\n    </button>\n  </footer>\n</div>\n\n<div class=\"sdv-modal-backdrop\"></div>\n"]}
|